Subject: turning a sequence of expressions into a function
From: Michael S. Sadler
Date: Sun, 23 May 2010 18:59:26 -0400
That worked! I will brush up on that subtlety, Thanks a lot!
--------------------------------------------------
From: "Leo Butler" <l.butler at ed.ac.uk>
Sent: Sunday, May 23, 2010 12:13 PM
To: "Michael S. Sadler" <msadler at rochester.rr.com>
Cc: <maxima at math.utexas.edu>
Subject: Re: [Maxima] turning a sequence of epxressions into a function
>
>
> On Sun, 23 May 2010, Michael S. Sadler wrote:
>
> < I am new to Maxima, and I am trying to correct the subtle things that I
> am
> < doing wrong.
> <
> < If you have the time, perhaps you could examine some code for me.
> <
> < I have the start of a program that works, when I try to turn part of the
> code
> < into a function, I fail.
> <
> < The first snippet works just fine, I am plotting a graph knowing only
> the
> < curvature, an
> < initial point and direction. The following is somewhat contrived, but
> it is a
> < start, and works fine.
> <
> < I start off by defining the curvature k(a), the arclength, and a
> function
> < called the witch of agnesi.
> < I then create an array called points, big enough to hold all my
> increments,
> < calculate the initial point and direction,
> < then fill in the rest of the points using the curvature, moving along
> the arc
> < length.
> <
> < this works, but I want to turn it into a function.
>
> Welcome to Maxima.
>
> The error you are making is a subtle one: the double quote operator ''
> is implemented by the parser, so it does not work as you expect in
> functions. Since you are using it to do substitution, there is an easy
> fix: replace ''foo with subst('x=x,foo) in your function definition.
> When I do this, I get
>
> get(c,a,b,increment) :=
> block( [len,points,f,x,y,angle],
> len : arclength(c,a,b)/increment,
> points:makelist([0,0],x,0,floor(len)),
> f : k(c),
> angle : float(atan(diff(c,x))),
> x : a,
> y : subst('x=x,c),
> angle : subst('x=x,angle),
> points[1] : [x,y],
> for i : 2 thru len+1 do (
> angle : float(angle),
> angle : angle + float(subst('x=x,f))*increment,
> x : x + cos(angle)*increment,
> y : y + sin(angle)*increment,
> points[i] : [x,y]
> ),
> points
> )$
>
> and this works for me.
>
> (Note that length is a function, and while you can create a variable
> of the same name, I have changed its name).
>
> Incidentally, dispfun(foo) will show you the Maxima definition of the
> function foo. This can be useful for problems like this.
>
> Leo
>
> <
> <
> < ********************************************
> <
> < kill(all)$
> <
> < k(a) := diff(a,x,2)/(1+diff(a,x,1)^2)^(3/2)$
> < arclength(f,a,b) := quad_qags(sqrt(1+diff(f,x,1)^2),x,a,b)[1]$
> < witch(a) := (8*(a)^3)/(x^2+4*(a)^2)$
> <
> <
> < c : witch(1)$
> < a : -15$
> < b : 15$
> < increment : 0.01$
> <
> <
> < length : arclength(c,a,b)/increment$
> < points:makelist([0,0],x,0,floor(length))$
> <
> <
> < f : k(c)$
> <
> < angle : float(atan(diff(c,x)))$
> < x : a$
> < y : ''c$
> < angle : ''angle$
> < points[1] : [x,y]$
> <
> < for i : 2 thru length+1 do (
> < angle : angle + float(''f)*increment,
> < x : x + cos(angle)*increment,
> < y : y + sin(angle)*increment,
> < points[i] : [x,y]
> < )$
> <
> < plot2d([discrete, points]);
> <
> < ********************************************
> <
> <
> < The problem that I am having is turning this into a function. Here is
> what I
> < believe might be the right thing.
> <
> < ********************************************
> <
> < kill(all)$
> <
> < k(a) := diff(a,x,2)/(1+diff(a,x,1)^2)^(3/2)$
> < arclength(f,a,b) := quad_qags(sqrt(1+diff(f,x,1)^2),x,a,b)[1]$
> < witch(a) := (8*(a)^3)/(x^2+4*(a)^2)$
> <
> < get(c,a,b,increment) :=
> < block( [length,points,f,x,y,angle],
> < length : arclength(c,a,b)/increment,
> < points:makelist([0,0],x,0,floor(length)),
> < f : k(c),
> < angle : float(atan(diff(c,x))),
> < x : a,
> < y : ''c,
> < angle : ''angle,
> < points[1] : [x,y],
> < for i : 2 thru length+1 do (
> < angle : angle + float(''f)*increment,
> < x : x + cos(angle)*increment,
> < y : y + sin(angle)*increment,
> < points[i] : [x,y]
> < ),
> < points
> < )$
> <
> < c : witch(1)$
> < a : -15$
> < b : 15$
> < increment : 0.01$
> <
> < P : get(c,a,b,increment)$
> <
> < plot2d([discrete, P]);
> <
> < ********************************************
> <
> <
> < Maxima does not like this at all. Any help would be appreciated. I
> think it
> < may have to do with evaluating things wrong.
> < _______________________________________________
> < Maxima mailing list
> < Maxima at math.utexas.edu
> < http://www.math.utexas.edu/mailman/listinfo/maxima
> <
> <
>
> --
> The University of Edinburgh is a charitable body, registered in
> Scotland, with registration number SC005336.
>
>