Index problem - Problem Solved
- Subject: Index problem - Problem Solved
- From: Mike Thomas
- Date: Fri, 27 Sep 2002 17:26:16 +1000
I've worked out that I needed to put brackets around the do statements. I
had managed to convince myself that the "," allowed one to string statements
into a block until a ";" or a "$" occurred.
----- Original Message -----
From: "Mike Thomas" <miketh at brisbane>
To: <maxima@www.ma.utexas.edu>
Cc: <mthomas@gil.com.au>
Sent: Friday, September 27, 2002 4:29 PM
Subject: Index problem
> Hi there.
>
> I have been experimenting with Dan Stanger's Maple to Maxima translator,
> managing to get it to the point where it translates this:
>
> --------------------------------------------------------------------------
--
> -
>
> R:=0.00008314;
> PropMatrix:=[[304.2,73.76,.225],[425.2,38.00,.193]];
> k:=[[0,0.130],[0.130, 0]];
>
> PRparamsPure:=proc()
> local q; global Tc,Pc,omega,kap,b,ac,a;
> for q from 1 to 2 do
> Tc[q]:=PropMatrix[q,1];
> Pc[q]:=PropMatrix[q,2];
> omega[q]:=PropMatrix[q,3];
> kap[q]:=0.37464+1.54226*omega[q]-0.26992*(omega[q])^2;
> b[q]:=0.07780*R*Tc[q]/Pc[q];
> ac[q]:=0.45724*R^2*Tc[q]^2/Pc[q];
> a[q] := ac[q]*(1+kap[q]*(1-sqrt(T/Tc[q])))^2;
> od:
> end:
>
> --------------------------------------------------------------------------
--
> -
>
> into this:
>
> --------------------------------------------------------------------------
--
> -
>
> R : 0.8314;
> PropMatrix : matrix ( [ 304.2, 73.76, 0.225 ] , [ 425.2, 38.0,
.193 ] )
> ;
> k : matrix ( [ 0, 0.130 ] , [ 0.130, 0 ] ) ;
> PRparamsPure : lambda ([], block (
> [q],
> for q : 1 thru 2 do
> Tc[q] : PropMatrix[q, 1],
> Pc[q] : PropMatrix[q, 2],
> omega[q] : PropMatrix[q, 3],
> kap[q] : 0.37464 + 1.54226 * omega[q] - 0.26992 * ( (
omega[q] ) )
> ^ 2,
> b[q] : 0.7780 * R * Tc[q] / Pc[q],
> ac[q] : 0.45724 * R ^ 2 * Tc[q] ^ 2 / Pc[q],
> a[q] : ac[q] * ( ( 1 + kap[q] * ( ( 1 - sqrt ( T /
Tc[q] ) ) ) ) )
> ^ 2 ) )$
>
> --------------------------------------------------------------------------
--
> -
>
> Unfortunately, executing "PRparamsPure()" gives me the output listed at
the
> end of this email, complaining about the subscript "q" not being an
integer.
>
> I am a total beginner at both Maple and Maxima and this one eludes me -
"q"
> is assigned to the integers 1 and 2 in turn by the for loop and, by way of
> further testing, the following sequence works at the toplevel prompt (that
> is the for loop index works as expected) and the end result is that a new
> subscripted variable is initialised:
>
> -----------------------------------------------
> (C6) q:1;
>
> (D6) 1
> (C7) PropMatrix[q,1];
>
> (D7) 304.2
> (C8) Tc1[q]: PropMatrix[q,1];
>
> (D8) 304.2
> (C9) Tc1[q];
>
> (D9) 304.2
> (C10) Tc1[1];
>
> (D10) 304.2
>
> (C13) for q1 : 1 thru 2 do
> Tc2[q1] : PropMatrix[q1,1];
>
> (D13) DONE
> (C14) Tc2[1];
>
> (D14) 304.2
> (C15) Tc2[2];
>
> (D15) 425.2
> -----------------------------------------------
>
>
> Any advice would be appreciated.
>
> Cheers
>
> Mike Thomas.
>
>
> --------------------------------------------------------------------------
--
> -
> (C1) R : 0.8314;
>
> (D1) 0.8314
> (C2) PropMatrix : matrix ( [ 304.2, 73.76, 0.225 ] , [ 425.2, 38.0,
> 0.193 ] ) ;
>
> [ 304.2 73.76000000000001 0.225 ]
> (D2) [ ]
> [ 425.2 38.0 0.193 ]
> (C3) k : matrix ( [ 0, 0.130 ] , [ 0.130, 0 ] ) ;
>
> [ 0 0.13 ]
> (D3) [ ]
> [ 0.13 0 ]
> (C4) PRparamsPure : lambda ([], block (
> [q],
> for q : 1 thru 2 do
> Tc[q] : PropMatrix[q, 1],
> Pc[q] : PropMatrix[q, 2],
> omega[q] : PropMatrix[q, 3],
> kap[q] : 0.37464 + 1.54226 * omega[q] - 0.26992 * ( (
omega[q] ) )
> ^ 2,
> b[q] : 0.7780 * R * Tc[q] / Pc[q],
> ac[q] : 0.45724 * R ^ 2 * Tc[q] ^ 2 / Pc[q],
> a[q] : ac[q] * ( ( 1 + kap[q] * ( ( 1 - sqrt ( T /
Tc[q] ) ) ) ) )
> ^ 2 ) );
>
> (D4) LAMBDA([], BLOCK([q], FOR q THRU 2 DO Tc : PropMatrix ,
> q q, 1
>
> Pc : PropMatrix , OMEGA : PropMatrix ,
> q q, 2 q q, 3
>
> 0.778 R Tc
> 2 q
> kap : 0.37464 + 1.54226 OMEGA + (- 0.26992) OMEGA , b : -----------,
> q q q q Pc
> q
>
> 2 2
> 0.45724 R Tc
> q T 2
> ac : --------------, a : ac (1 + kap (1 - SQRT(---))) ))
> q Pc q q q Tc
> q q
> (C5) PRparamsPure();
>
> Subscript must be an integer:
> q
> #0: PRparamsPure()
> -- an error. Quitting. To debug this try DEBUGMODE(TRUE);)
> (C6)
>
> --------------------------------------------------------------------------
--
> -
>
>
> _______________________________________________
> Maxima mailing list
> Maxima@www.math.utexas.edu
> http://www.math.utexas.edu/mailman/listinfo/maxima
>