diff options
Diffstat (limited to 'src/interp')
-rw-r--r-- | src/interp/compat.boot (renamed from src/interp/compat.boot.pamphlet) | 43 | ||||
-rw-r--r-- | src/interp/sfsfun.boot (renamed from src/interp/sfsfun.boot.pamphlet) | 159 | ||||
-rw-r--r-- | src/interp/word.boot (renamed from src/interp/word.boot.pamphlet) | 22 |
3 files changed, 77 insertions, 147 deletions
diff --git a/src/interp/compat.boot.pamphlet b/src/interp/compat.boot index 2db27b0a..87e1227c 100644 --- a/src/interp/compat.boot.pamphlet +++ b/src/interp/compat.boot @@ -1,30 +1,7 @@ -\documentclass{article} -\usepackage{axiom} -\begin{document} -\title{\$SPAD/src/interp compat.boot} -\author{The Axiom Team} -\maketitle -\begin{abstract} -\end{abstract} -\eject -\tableofcontents -\eject -\section{readline} -Reads a line, defaulting stream to *standard-input* - -This was commented out in the NAG version, probably due to the -use of the saturn GUI interface but the real reason is uncertain. -<<readline>>= -READLINE(:s) == - s => read_-line(first s) - read_-line(_*STANDARD_-INPUT_*) - -@ -\section{compat.boot} -\section{License} -<<license>>= -- Copyright (c) 1991-2002, The Numerical ALgorithms Group Ltd. -- All rights reserved. +-- Copyright (C) 2007, Gabriel Dos Reis. +-- All rights reserved. -- -- Redistribution and use in source and binary forms, with or without -- modification, are permitted provided that the following conditions are @@ -54,9 +31,6 @@ READLINE(:s) == -- NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS -- SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -@ -<<*>>= -<<license>> import '"pathname" )package "BOOT" @@ -82,7 +56,7 @@ isSharpVarWithNum x == -- RREAD which takes erroval to return if key is missing rread(key,rstream,errorval) == if IDENTP key then key := PNAME key - RREAD(key,rstream,errorval) + RREAD(key,rstream,errorval) rwrite(key,val,stream) == if IDENTP key then key := PNAME key @@ -105,10 +79,7 @@ editFile file == makeBigFloat(mantissa,expon) == [$BFtag,mantissa,:expon] -<<readline>> -@ -\eject -\begin{thebibliography}{99} -\bibitem{1} nothing -\end{thebibliography} -\end{document} +READLINE(:s) == + s => read_-line(first s) + read_-line(_*STANDARD_-INPUT_*) + diff --git a/src/interp/sfsfun.boot.pamphlet b/src/interp/sfsfun.boot index 50bd7b5b..c6c28253 100644 --- a/src/interp/sfsfun.boot.pamphlet +++ b/src/interp/sfsfun.boot @@ -1,52 +1,7 @@ -\documentclass{article} -\usepackage{axiom} -\begin{document} -\title{\$SPAD/src/interp sfsfun.boot} -\author{The Axiom Team} -\maketitle -\begin{abstract} -\end{abstract} -\eject -\tableofcontents -\eject -\begin{verbatim} -NOTEfrom TTT: at least BesselJAsymptOrder needs work - -1. This file contains the contents of BWC's original files: - floaterrors.boot - floatutils.boot - rgamma.boot - cgamma.boot - rpsi.boot - cpsi.boot - f01.boot - chebf01cmake.boot - chebevalsf.boot - besselIJ.boot - -2. All declarations have been commented out with "--@@" - since the boot translator is generating bad lisp code from them. - -3. The functions PsiAsymptotic, PsiEps and PsiAsymptoticOrder - had inconpatible definitions in rpsi.boot and cpsi.boot -- - the local variables were declared float in one file and COMPLEX in - the other. The type declarations have been commented out and the - duplicate definitions have been deleted. - -4. BesselIJ was not compiling. I have modified the code from that - file to make it compile. It should be checked for correctness. - -SMW June 25, 1991 - -"Fixes" to BesselJ, B. Char June 14, 1992. Needs extensive testing and - further fixes to BesselI and BesselJ. -More fixes to BesselJ, T. Tsikas 24 Feb, 1995. - -\end{verbatim} -\section{License} -<<license>>= -- Copyright (c) 1991-2002, The Numerical ALgorithms Group Ltd. -- All rights reserved. +-- Copyright (C) 2007, Gabriel Dos Reis. +-- All rights reserved. -- -- Redistribution and use in source and binary forms, with or without -- modification, are permitted provided that the following conditions are @@ -76,9 +31,41 @@ More fixes to BesselJ, T. Tsikas 24 Feb, 1995. -- NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS -- SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -@ -<<*>>= -<<license>> + +-- NOTEfrom TTT: at least BesselJAsymptOrder needs work + +-- 1. This file contains the contents of BWC's original files: +-- floaterrors.boot +-- floatutils.boot +-- rgamma.boot +-- cgamma.boot +-- rpsi.boot +-- cpsi.boot +-- f01.boot +-- chebf01cmake.boot +-- chebevalsf.boot +-- besselIJ.boot + +-- 2. All declarations have been commented out with "--@@" +-- since the boot translator is generating bad lisp code from them. + +-- 3. The functions PsiAsymptotic, PsiEps and PsiAsymptoticOrder +-- had inconpatible definitions in rpsi.boot and cpsi.boot -- +-- the local variables were declared float in one file and COMPLEX in +-- the other. The type declarations have been commented out and the +-- duplicate definitions have been deleted. + +-- 4. BesselIJ was not compiling. I have modified the code from that +-- file to make it compile. It should be checked for correctness. + +-- SMW June 25, 1991 + +-- "Fixes" to BesselJ, B. Char June 14, 1992. Needs extensive testing and +-- further fixes to BesselI and BesselJ. +-- More fixes to BesselJ, T. Tsikas 24 Feb, 1995. + + + -- Used to be SPECFNSF )package "BOOT" @@ -119,7 +106,7 @@ horner(l,x) == rgamma (x) == if COMPLEXP(x) then FloatError('"Gamma not implemented for complex value ~D",x) - ZEROP (x-1.0) => 1.0 + ZEROP (x-1.0) => 1.0 if x>20 then gammaStirling(x) else gammaRatapprox(x) lnrgamma (x) == @@ -742,12 +729,12 @@ BesselJ(v,z) == n := 50 --- number of terms in Chebychev series. --- tests for negative integer order (FLOATP(v) and ZEROP fracpart(v) and (v<0)) or (COMPLEXP(v) and ZEROP IMAGPART(v) and ZEROP fracpart(REALPART(v)) and REALPART(v)<0.0) => - --- odd or even according to v (9.1.5 A&S) - --- $J_{-n}(z)=(-1)^{n} J_{n}(z)$ + --- odd or even according to v (9.1.5 A&S) + --- $J_{-n}(z)=(-1)^{n} J_{n}(z)$ BesselJ(-v,z)*EXPT(-1.0,v) (FLOATP(z) and (z<0)) or (COMPLEXP(z) and REALPART(z)<0.0) => --- negative argument (9.1.35 A&S) - --- $J_{\nu}(z e^{m \pi i}) = e^{m \nu \pi i} J_{\nu}(z)$ + --- $J_{\nu}(z e^{m \pi i}) = e^{m \nu \pi i} J_{\nu}(z)$ BesselJ(v,-z)*EXPT(-1.0,v) ZEROP z and ((FLOATP(v) and (v>=0.0)) or (COMPLEXP(v) and ZEROP IMAGPART(v) and REALPART(v)>=0.0)) => --- zero arg, pos. real order @@ -764,29 +751,29 @@ BesselJ(v,z) == w := 2.0*arg vp1 := v+1.0 [sum,arr] := chebf01coefmake(vp1,w,n) - ---if we get NaNs then half n - while not _=(sum,sum) repeat - n:=FLOOR(n/2) + ---if we get NaNs then half n + while not _=(sum,sum) repeat + n:=FLOOR(n/2) [sum,arr] := chebf01coefmake(vp1,w,n) - ---now n is safe, can we increase it (we know that 2*n is bad)? + ---now n is safe, can we increase it (we know that 2*n is bad)? chebstarevalarr(arr,arg/w,n)/cgamma(vp1)*EXPT(z/2.0,v) true => BesselJRecur(v,z) FloatError('"BesselJ not implemented for ~S", [v,z]) BesselJRecur(v,z) == - -- boost order + -- boost order --Numerical.Recipes. suggest so:=v+sqrt(n.s.f.^2*v) - so:=15.0*z - -- reduce order until non-zero + so:=15.0*z + -- reduce order until non-zero while ZEROP ABS(BesselJAsymptOrder(so,z)) repeat so:=so/2.0 - if ABS(so)<ABS(z) then so:=v+18.*SQRT(v) - m:= FLOOR(ABS(so-v))+1 - w:=MAKE_-ARRAY(m) - SETF(AREF(w,m-1),BesselJAsymptOrder(v+m-1,z)) + if ABS(so)<ABS(z) then so:=v+18.*SQRT(v) + m:= FLOOR(ABS(so-v))+1 + w:=MAKE_-ARRAY(m) + SETF(AREF(w,m-1),BesselJAsymptOrder(v+m-1,z)) SETF(AREF(w,m-2),BesselJAsymptOrder(v+m-2,z)) for i in m-3 .. 0 by -1 repeat SETF(AREF(w,i), 2.0 * (v+i+1.0) * AREF(w,i+1) /z -AREF(w,i+2)) - AREF(w,0) + AREF(w,0) BesselI(v,z) == B1 := 15.0 @@ -952,24 +939,24 @@ BesselJAsymptOrder(v,z) == ca := 1.0/tanhalpha Pi := PI - ca2:=ca*ca - ca4:=ca2*ca2 - ca8:=ca4*ca4 + ca2:=ca*ca + ca4:=ca2*ca2 + ca8:=ca4*ca4 EXP(-v*(alpha-tanhalpha))/SQRT(2.0*Pi*v*tanhalpha)*_ - (1.0+_ - horner([ -5.0, 3.0],_ - ca2)*ca/(v*24.0)+_ - horner([ 385.0, -462.0, 81.0],_ - ca2)*ca2/(1152.0*v*v)+_ - horner([ -425425.0, 765765.0, -369603.0, 30375.0],_ - ca2)*ca2*ca/(414720.0*v*v*v)+_ - horner([ 185910725.0, -446185740.0, 349922430.0, -94121676.0, 4465125.0],_ - ca2)*ca4/(39813120.0*v*v*v*v)+_ - horner([ -188699385875.0, 566098157625.0, -614135872350.0, 284499769554.0, -49286948607.0, 1519035525.0],_ - ca2)*ca4*ca/(6688604160.0*v*v*v*v*v)+_ - horner([1023694168371875.0,-3685299006138750.0,5104696716244125.0,-3369032068261860.0,1050760774457901.0,-127577298354750.0,2757049477875.0],_ - ca2)*ca4*ca2/(4815794995200.0*v*v*v*v*v*v)) - + (1.0+_ + horner([ -5.0, 3.0],_ + ca2)*ca/(v*24.0)+_ + horner([ 385.0, -462.0, 81.0],_ + ca2)*ca2/(1152.0*v*v)+_ + horner([ -425425.0, 765765.0, -369603.0, 30375.0],_ + ca2)*ca2*ca/(414720.0*v*v*v)+_ + horner([ 185910725.0, -446185740.0, 349922430.0, -94121676.0, 4465125.0],_ + ca2)*ca4/(39813120.0*v*v*v*v)+_ + horner([ -188699385875.0, 566098157625.0, -614135872350.0, 284499769554.0, -49286948607.0, 1519035525.0],_ + ca2)*ca4*ca/(6688604160.0*v*v*v*v*v)+_ + horner([1023694168371875.0,-3685299006138750.0,5104696716244125.0,-3369032068261860.0,1050760774457901.0,-127577298354750.0,2757049477875.0],_ + ca2)*ca4*ca2/(4815794995200.0*v*v*v*v*v*v)) + --- See Olver, p. 376-382. BesselIAsymptOrder(v,vz) == @@ -1023,9 +1010,3 @@ BesselKAsymptOrder (v,vz) == -@ -\eject -\begin{thebibliography}{99} -\bibitem{1} nothing -\end{thebibliography} -\end{document} diff --git a/src/interp/word.boot.pamphlet b/src/interp/word.boot index ac76dca3..95dfc7a1 100644 --- a/src/interp/word.boot.pamphlet +++ b/src/interp/word.boot @@ -1,16 +1,3 @@ -\documentclass{article} -\usepackage{axiom} -\begin{document} -\title{\$SPAD/src/interp word.boot} -\author{The Axiom Team} -\maketitle -\begin{abstract} -\end{abstract} -\eject -\tableofcontents -\eject -\section{License} -<<license>>= -- Copyright (c) 1991-2002, The Numerical ALgorithms Group Ltd. -- All rights reserved. -- @@ -42,9 +29,6 @@ -- NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS -- SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -@ -<<*>>= -<<license>> --======================================================================= -- Build Directories @@ -414,9 +398,3 @@ obSearch x == [y for i in 0..MAXINDEX OBARRAY() | (IDENTP (y := vec.i) or CVEC y) and match?(pattern,COPY y)] -@ -\eject -\begin{thebibliography}{99} -\bibitem{1} nothing -\end{thebibliography} -\end{document} |