mirror of
https://github.com/Kitware/CMake.git
synced 2026-04-23 22:58:37 -05:00
ENH: step 3
This commit is contained in:
@@ -0,0 +1,4 @@
|
||||
add_library(MathFunctions mysqrt.cxx)
|
||||
|
||||
install_targets (/bin MathFunctions)
|
||||
install_files (/include FILES MathFunctions.h)
|
||||
@@ -0,0 +1 @@
|
||||
double mysqrt(double x);
|
||||
@@ -0,0 +1,29 @@
|
||||
#include <stdio.h>
|
||||
#include "MathFunctions.h"
|
||||
|
||||
// a hack square root calculation using simple operations
|
||||
double mysqrt(double x)
|
||||
{
|
||||
if (x <= 0)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
double result;
|
||||
double delta;
|
||||
result = x;
|
||||
|
||||
// do ten iterations
|
||||
int i;
|
||||
for (i = 0; i < 10; ++i)
|
||||
{
|
||||
if (result <= 0)
|
||||
{
|
||||
result = 0.1;
|
||||
}
|
||||
delta = x - (result*result);
|
||||
result = result + 0.5*delta/result;
|
||||
fprintf(stdout,"Computing sqrt of %g to be %g\n",x,result);
|
||||
}
|
||||
return result;
|
||||
}
|
||||
Reference in New Issue
Block a user