123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246 |
- scale = 50
- define e(x) {
- auto a, b, c, d, e, g, w, y, t, r
- r = ibase
- ibase = A
- t = scale
- scale = t + .434*x + 1
- w = 0
- if(x<0) {
- x = -x
- w = 1
- }
- y = 0
- while(x>2) {
- x /= 2
- y++
- }
- a = 1
- b = 1
- c = b
- d = 1
- e = 1
- for(a=1; 1; a++) {
- b *= x
- c = c*a+b
- d *= a
- g = c/d
- if(g == e) {
- g = g/1
- while(y--) {
- g *= g
- }
- scale = t
- if(w==1) {
- ibase = r
- return 1/g
- }
- ibase = r
- return g/1
- }
- e = g
- }
- }
- define l(x) {
- auto a, b, c, d, e, f, g, u, s, t, r, z
- r = ibase
- ibase = A
- if(x <= 0) {
- z = 1-10^scale
- ibase = r
- return z
- }
- t = scale
- f = 1
- scale += scale(x) - length(x) + 1
- s = scale
- while(x > 2) {
- s += (length(x)-scale(x))/2 + 1
- if(s>0) {
- scale = s
- }
- x = sqrt(x)
- f *= 2
- }
- while(x < .5) {
- s += (length(x)-scale(x))/2 + 1
- if(s>0) {
- scale = s
- }
- x = sqrt(x)
- f *= 2
- }
- scale = t + length(f) - scale(f) + 1
- u = (x-1)/(x+1)
- scale += 1.1*length(t) - 1.1*scale(t)
- s = u*u
- b = 2*f
- c = b
- d = 1
- e = 1
- for(a=3; 1; a=a+2){
- b *= s
- c = c*a + d*b
- d *= a
- g = c/d
- if(g==e) {
- scale = t
- ibase = r
- return u*c/d
- }
- e = g
- }
- }
- define s(x) {
- auto a, b, c, s, t, y, p, n, i, r
- r = ibase
- ibase = A
- t = scale
- y = x/.7853
- s = t + length(y) - scale(y)
- if(s<t) {
- s = t
- }
- scale = s
- p = a(1)
- scale = 0
- if(x>=0) {
- n = (x/(2*p)+1)/2
- }
- if(x<0) {
- n = (x/(2*p)-1)/2
- }
- x -= 4*n*p
- if(n%2 != 0) {
- x = -x
- }
- scale = t + length(1.2*t) - scale(1.2*t)
- y = -x*x
- a = x
- b = 1
- s = x
- for(i=3; 1; i+=2) {
- a *= y
- b *= i*(i-1)
- c = a/b
- if(c==0){
- scale = t
- ibase = r
- return s/1
- }
- s += c
- }
- }
- define c(x) {
- auto t, r
- r = ibase
- ibase = A
- t = scale
- scale = scale+1
- x = s(x + 2*a(1))
- scale = t
- ibase = r
- return x/1
- }
- define a(x) {
- auto a, b, c, d, e, f, g, s, t, r, z
- r = ibase
- ibase = A
- if(x==0) {
- return 0
- }
- if(x==1) {
- z = .7853981633974483096156608458198757210492923498437764/1
- ibase = r
- if(scale<52) {
- return z
- }
- }
- t = scale
- f = 1
- while(x > .5) {
- scale++
- x = -(1 - sqrt(1.+x*x))/x
- f *= 2
- }
- while(x < -.5) {
- scale++
- x = -(1 - sqrt(1.+x*x))/x
- f *= 2
- }
- s = -x*x
- b = f
- c = f
- d = 1
- e = 1
- for(a=3; 1; a+=2) {
- b *= s
- c = c*a + d*b
- d *= a
- g = c/d
- if(g==e) {
- scale = t
- ibase = r
- return x*c/d
- }
- e = g
- }
- }
- define j(n,x) {
- auto a,b,c,d,e,g,i,s,k,t,r
- r = ibase
- ibase = A
- t = scale
- k = 1.36*x + 1.16*t - n
- k = length(k) - scale(k)
- if(k>0) {
- scale += k
- }
- s = -x*x/4
- if(n<0) {
- n = -n
- x = -x
- }
- a = 1
- c = 1
- for(i=1; i<=n; i++) {
- a *= x
- c *= 2*i
- }
- b = a
- d = 1
- e = 1
- for(i=1; 1; i++) {
- a *= s
- b = b*i*(n+i) + a
- c *= i*(n+i)
- g = b/c
- if(g==e) {
- scale = t
- ibase = r
- return g/1
- }
- e = g
- }
- }
|