[GiNaC-devel] expairseq::conjugate

Richard B. Kreckel kreckel at ginac.de
Wed May 11 00:13:18 CEST 2011


Hi Burcin,

On 05/08/2011 09:42 PM, Burcin Erocal wrote:
> the following problem (in Sage syntax) was reported to the Sage issue
> tracker [1]:
>
> ginsh - GiNaC Interactive Shell (ginac V1.5.8)
> <snip>
>> conjugate(I*sqrt(-3));
> -I*sqrt(-3)

Indeed. The patch I committed a year ago to make the branch cut 
tranformations less aggressive forgets about complex conjugation of mul 
objects containing roots.

Of course, the imaginary I in the example above is not relevant. Here is 
another way (and a good regression test, BTW) to see it fail. In ginsh:

 > subs(conjugate(a*sqrt(-2))-a*conjugate(sqrt(-2)), a==1);
-conjugate(sqrt(-2))+sqrt(-2)

> [1] http://trac.sagemath.org/sage_trac/ticket/10964
>
> The problem seems to be the expair::conjugate() method which is called
> from the conjugateepvector() function in expairseq.cpp. This function
> is called from the pseries class as well. So, moving the latter in the
> expairseq class to use the virtual functions recombine_pair_to_ex()
> etc. does not work.
>
> Any ideas for a clean solution to this?

Ah, I see that you already got very close to fixing it. Well, what 
remains to be done is to ensure that the code dispatches to the right 
recombine_pair_to_ex()/split_ex_to_pair() methods. For this, it needs 
the vptr of the expairseq object. It doesn't have to be a member 
function, though: We can pass it as an extra argument to 
conjugateepvector(), in order to retain binary compatibility.

I'ld propose to fix it similar to the patch attached. It passes GiNaC's 
regression tests and works as expected:

 > subs(conjugate(a*sqrt(-2))-a*conjugate(sqrt(-2)), a==1);
0

What do you think?

I'll clean it up a bit and push it to the GiNaC repository later, when 
I'm less sleepy.

(:|
   -richy.
-- 
Richard B. Kreckel
<http://www.ginac.de/~kreckel/>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: ginac.patch
Type: text/x-patch
Size: 2015 bytes
Desc: not available
URL: <http://www.ginac.de/pipermail/ginac-devel/attachments/20110511/1464f16c/attachment.bin>


More information about the GiNaC-devel mailing list