new defint.lisp bug - was: new defint.lisp andradexpand:false?



Since maxima does simplify this factor to 1.0 then we could fix that by 
using the value of polarform(-1) in the answer as suggested by Aleksas.

integrate(exp(x^7),x); should give

-%e^-(%i*%pi/7)*gamma_incomplete(1/7,-x^7)/7

and

integrate(exp(x^5),x); should give

-%e^-(%i*%pi/5)*gamma_incomplete(1/5,-x^5)/5

etc . . .

That would fix the problem, since Maxima's simplifier does not simplify away 
the exponential term.

Aleksas has already shown the proof but his method will not work in 
integrate(exp(x^n),x) when n is a known integer.  The reason is that Maxima 
has already converted the (-1) expression to 1.

Rich


-----Original Message----- 
From: Edwin Woollett
Sent: Thursday, January 12, 2012 3:28 PM
To: Richard Fateman
Cc: maxima mailing list
Subject: Re: [Maxima] new defint.lisp bug - was: new defint.lisp 
andradexpand:false?

On Jan. 11, 2012, Richard Fateman wrote:
----------------------------------
>> (%i3) integrate(exp(x^5),x,1,2);
>> (%o3) (gamma_incomplete(1/5,-32)-gamma_incomplete(1/5,-1))/5
>
>for what it is worth, Mathematica 7 returns
>
>1/5 (-1)^(4/5) (Gamma[1/5, -32] - Gamma[1/5, -1])}
>
>
>Notice the factor of (-1)^(4/5).
-------------------------------------------
This is a very important observation, and explains
a difference between Maxima and Mathematica results
for these type of integrals.  Maxima evaluates the
factor (-1)^(4/5) numerically to 1.0, which differs
from Mathematica's evaluation (see below).

Here I consider a different (but related via a simple
change of variables)  integral, and compare in detail
the results from Maxima and Mathematica (using the
Wolfram alpha site).

-----------------------------------------------------
Maxima 5.25.1 http://maxima.sourceforge.net
using Lisp GNU Common Lisp (GCL) GCL 2.6.8 (a.k.a. GCL)


(%i1) integrate(exp(y)/y^(4/5),y,1,2);
(%o1) gamma_incomplete(1/5,-2)-gamma_incomplete(1/5,-1)

/*  MMa NIntegrate[Exp[y]/y^(4/5),{y,1,2}] yields

    (-1)^(4/5)*(Gamma[1/5,-2] - Gamma[1/5,-1])

    does not agree with Maxima, since in Mathematica
    (-1)^(4/5) float value is not 1.0, whereas
    is does have value 1.0 in Maxima.  */


(%i2) expand(float(%o1));
(%o2) -1.951024982232477*%i-2.685355511932373

/* this Maxima float value agrees with the first 14 digits of

     Mma's   N[Gamma[1/5,-2] - Gamma[1/5,-1]] which gives

    -2.685355511932382... -1.951024982232483... i

    which translates into

    -2.685355511932382 - 1.951024982232483*%i     */

/* the approximate (real) value of the integral
    is given by quad_qags  */


(%i3) quad_qags(exp(y)/y^(4/5),y,1,2);
(%o3) [3.319281956502171,3.6851432533315483E-14,21,0]

   /* Maxima gives value 1.0 to (-1)^(4/5)  */

(%i4) expand(float(-1)^(4/5));
(%o4) 1.0


  /* whereas Mathematica gives

    N[(-1)^(4/5)]  --->

      -0.8090169943749474... + 0.5877852522924731... i

      which translates into

      -0.8090169943749474 + 0.5877852522924731*%i

If we multiply this factor by %o2 and expand we get the
   correct numerical answer to within floating point roundoff
   errors:    */

(%i5) expand((-0.8090169943749474 + 0.5877852522924731*%i)*%o2);

(%o5) 4.4408920985006262E-16*%i+3.319281956502161


/* the above was with 5.25.1 defint.lisp.
   The updated version makes no difference here  */


(%i6) load("defint-new.lisp");
(%o6) "c:/work2/defint-new.lisp"

(%i7) integrate(exp(y)/y^(4/5),y,1,2);
(%o7) gamma_incomplete(1/5,-2)-gamma_incomplete(1/5,-1)

(%i8) expand(float(%));
(%o8) -1.951024982232477*%i-2.685355511932373

--------------------------------------
Ted


_______________________________________________
Maxima mailing list
Maxima at math.utexas.edu
http://www.math.utexas.edu/mailman/listinfo/maxima