aboutsummaryrefslogtreecommitdiff
path: root/src/algebra/gaussian.spad.pamphlet
diff options
context:
space:
mode:
authoralfredoport <doyenatccny@gmail.com>2008-08-31 15:46:13 +0000
committeralfredoport <doyenatccny@gmail.com>2008-08-31 15:46:13 +0000
commit57dc994dc5354c1d8b9d823baa5befc8b2f50b03 (patch)
treecea042ad15797348882f2ea4b6dcc9ca96c45dba /src/algebra/gaussian.spad.pamphlet
parent8f29b67f349d337019093f0eeba09cc3bf09bfed (diff)
downloadopen-axiom-57dc994dc5354c1d8b9d823baa5befc8b2f50b03.tar.gz
Fix Bug AW15.
Diffstat (limited to 'src/algebra/gaussian.spad.pamphlet')
-rw-r--r--src/algebra/gaussian.spad.pamphlet16
1 files changed, 12 insertions, 4 deletions
diff --git a/src/algebra/gaussian.spad.pamphlet b/src/algebra/gaussian.spad.pamphlet
index b45a902e..e09ed0c5 100644
--- a/src/algebra/gaussian.spad.pamphlet
+++ b/src/algebra/gaussian.spad.pamphlet
@@ -367,10 +367,18 @@ ComplexCategory(R:CommutativeRing): Category ==
argument x == atan2loc(imag x, real x)
else
- -- Not ordered so dictate two quadrants
- argument x ==
- zero? real x => pi()$R * half
- atan(imag(x) * recip(real x)::R)
+ if R has RadicalCategory then
+ argument x ==
+ n1 := sqrt(norm(x))
+ x1 := real(x) + n1
+ (2::R)*atan(imag(x) * recip(x1)::R)
+
+ else
+ -- Emulate sqrt using exp and log
+ argument x ==
+ n1 := exp(half*log(norm(x)))
+ x1 := real(x) + n1
+ (2::R)*atan(imag(x) * recip(x1)::R)
pi() == pi()$R :: %