diff options
| author | Brad King <brad.king@kitware.com> | 2019-01-29 14:15:31 (GMT) | 
|---|---|---|
| committer | Kitware Robot <kwrobot@kitware.com> | 2019-01-29 14:15:44 (GMT) | 
| commit | 5134e11ee4291c1eb53aa5014af2af75a2e33f3b (patch) | |
| tree | efe6fb3027892959ab723805bca025adbc4a5564 /Tests/Tutorial/Step8/MathFunctions/mysqrt.cxx | |
| parent | fa7077e7411f4f85724deae3427acb29be729567 (diff) | |
| parent | 0e2cdacf7b51c915acd1a2a9e58a080d2667b4cb (diff) | |
| download | CMake-5134e11ee4291c1eb53aa5014af2af75a2e33f3b.zip CMake-5134e11ee4291c1eb53aa5014af2af75a2e33f3b.tar.gz CMake-5134e11ee4291c1eb53aa5014af2af75a2e33f3b.tar.bz2 | |
Merge topic 'update-tutorial'
0e2cdacf7b Tests: Update style of c++ code snippets in Tutorial directions
f2ddedfa58 Tests: Update CMake tutorial
438651506a Tests: Make ExternalProjectLocal independent of Tutorial directory
Acked-by: Kitware Robot <kwrobot@kitware.com>
Merge-request: !2731
Diffstat (limited to 'Tests/Tutorial/Step8/MathFunctions/mysqrt.cxx')
| -rw-r--r-- | Tests/Tutorial/Step8/MathFunctions/mysqrt.cxx | 42 | 
1 files changed, 42 insertions, 0 deletions
| diff --git a/Tests/Tutorial/Step8/MathFunctions/mysqrt.cxx b/Tests/Tutorial/Step8/MathFunctions/mysqrt.cxx new file mode 100644 index 0000000..5b862fb --- /dev/null +++ b/Tests/Tutorial/Step8/MathFunctions/mysqrt.cxx @@ -0,0 +1,42 @@ +#include "MathFunctions.h" +#include "TutorialConfig.h" +#include <iostream> + +// include the generated table +#include "Table.h" + +#include <cmath> + +// a hack square root calculation using simple operations +double mysqrt(double x) +{ +  if (x <= 0) { +    return 0; +  } + +  // if we have both log and exp then use them +#if defined(HAVE_LOG) && defined(HAVE_EXP) +  double result = exp(log(x) * 0.5); +  std::cout << "Computing sqrt of " << x << " to be " << result << " using log" +            << std::endl; +#else +  // use the table to help find an initial value +  double result = x; +  if (x >= 1 && x < 10) { +    result = sqrtTable[static_cast<int>(x)]; +  } + +  // if we have both log and exp then use them + +  // do ten iterations +  for (int i = 0; i < 10; ++i) { +    if (result <= 0) { +      result = 0.1; +    } +    double delta = x - (result * result); +    result = result + 0.5 * delta / result; +    std::cout << "Computing sqrt of " << x << " to be " << result << std::endl; +  } +#endif +  return result; +} | 
