diff options
| author | icculus <icculus@5198baeb-e213-0410-be47-fc2ff85ca46f> | 2003-01-02 21:06:00 +0000 |
|---|---|---|
| committer | icculus <icculus@5198baeb-e213-0410-be47-fc2ff85ca46f> | 2003-01-02 21:06:00 +0000 |
| commit | e17acec1c9bec3a26d97ca2873bb77bdcb48665e (patch) | |
| tree | 26b14b6cedcb70df651c23dddbf0981970d0bd4d /Source/Maths.cpp | |
| parent | 59ca62d601e30b5467f8ecd2cb7d517bc682fc12 (diff) | |
| download | blackshades-e17acec1c9bec3a26d97ca2873bb77bdcb48665e.tar.gz | |
Initial revision
git-svn-id: svn://svn.icculus.org/blackshades/trunk@2 5198baeb-e213-0410-be47-fc2ff85ca46f
Diffstat (limited to 'Source/Maths.cpp')
| -rw-r--r-- | Source/Maths.cpp | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/Source/Maths.cpp b/Source/Maths.cpp new file mode 100644 index 0000000..f8f2664 --- /dev/null +++ b/Source/Maths.cpp @@ -0,0 +1,21 @@ +/**> HEADER FILES <**/ +#include "Maths.h" + +double fast_sqrt (register double arg) +{ + // Can replace with slower return std::sqrt(arg); + register double result; + + if (arg == 0.0) return 0.0; + + asm { + frsqrte result,arg // Calculate Square root + } + + // Newton Rhapson iterations. + result = result + 0.5 * result * (1.0 - arg * result * result); + result = result + 0.5 * result * (1.0 - arg * result * result); + + return result * arg; +} + |
