So far as I can tell, the original computation in Maxima was
(fc_all(n):=fc_ab(-1,n,-%pi,(-%pi)/2)+fc_ab(2,n,-%pi/2,0)
       +fc_ab(-1,n,0,%pi/2)+fc_ab(2,n,%pi/2,%pi),
fc_ab(e,n,a,b):=if n = 0 then [integrate(e,x,a,b)/(2*%pi),0]
       else fc1_ab(e,n,a,b),
fc1_ab(e,n,a,b):=[integrate(e*cos(n*x),x,a,b)/%pi,
       integrate(e*sin(n*x),x,a,b)/%pi],
coefs : map (fc_all, makelist (i, i, 0, 15)),
fsum : sum (coefs[1 + n][1] * cos (n*x) + coefs[1 + n][2] * sin (n*x),
n, 0, 15),
xx : makelist ((i - 1) * 2 * %pi / 100 - %pi,i,1,101),numer,
fsum_xx : makelist (''fsum, x, xx), numer);

which in my (GCL) maxima takes 5 seconds.
There are a number of peculiarities in the way this computation was
set up,
perhaps some because the original author was not concerned with
efficiency,
or aware of the consequences of programming in certain ways.
or perhaps Sage is itself producing bad stuff from good input. I don't
know which.
Anyway, a few changes to make it into idiomatic Maxima results in a
program that
is over 30X faster.  Usually this kind of speedup is an indication
that something
should have been done another way.  Especially when the faster program
is also
shorter and clearer.

What is being done wrong?   Well, it seems that many computations with
large expressions
are being done with symbols such as %pi in them, and then later, %pi
is replaced with
3.14159...  at which point the large expressions become a single
numbers.

If one does the same calculations but using 3.1415... instead of the
symbol %pi, few of
those large expressions are produced. Just numbers.

Another thing.
  If you are computing a symbolic integral  integrate(XXXX,x,a,b),
then when you change
the limits, you don't have to recompute the symbolic integral.  Just
change the limits.

Another thing. Using arrays instead of lists is usually a good thing,
if you are going to
access data by array references.

Also, if you are going to define global variables and functions and
never use them again
you should kill them.  In debugging, I usually use a "batch" file and
kill all the data
at the beginning, wiping out all previous definitions.

Here's a version of the same computation. Maybe Sagenatics
(Sagenicks?)  in addition to
the original author will be able to see some useful idioms here.


(kill(fc_ab,coefs,fsum,xx,fsum_xx,pi),
pi:ev(%pi,numer),
fc_ab[n,e](a,b):= [integrate(e*cos(n*x),x,a,b)/pi,  integrate(e*sin
(n*x),x,a,b)/pi],
coefs[n]:= fc_ab[n,-1](-pi,-pi/2)  +  fc_ab[n,2](-pi/2,0)  +fc_ab[n,-1]
(0,pi/2)  +  fc_ab[n,2](pi/2,pi),
fsum(z) := sum (coefs[n][1] * cos (n*z) + coefs[n][2] * sin (n*z), n,
0, 15),
xx[i] := pi*(i-51)/50,
fsum_xx:makelist(fsum(xx[i]),i,1,101))

--~--~---------~--~----~------------~-------~--~----~
To post to this group, send email to sage-devel@googlegroups.com
To unsubscribe from this group, send email to [EMAIL PROTECTED]
For more options, visit this group at http://groups.google.com/group/sage-devel
URLs: http://www.sagemath.org
-~----------~----~----~----~------~----~------~--~---

Reply via email to