Hi Nils,

I've been looking at

        http://www.sagetrac.org/sage_trac/ticket/1482

and approximately diagnosed the problem (see comments on the ticket),  
but it's not clear to me exactly how to proceed.

The new underlying gcd code produces quite inscrutable output, for  
example:

sage: xgcd(3, 3)
(3, 0, 1)
sage: xgcd(3, 6)
(3, -3, 2)
sage: xgcd(3, 9)
(3, -8, 3)
sage: xgcd(3, 12)
(3, -3, 1)
sage: xgcd(3, 15)
(3, -14, 3)
sage: xgcd(3, 18)
(3, -17, 3)
sage: xgcd(3, 21)
(3, -20, 3)
sage: xgcd(3, 24)
(3, -15, 2)
sage: xgcd(3, 27)
(3, -26, 3)
sage: xgcd(3, 30)
(3, -29, 3)
sage: xgcd(3, 33)
(3, -32, 3)
sage: xgcd(3, 36)
(3, -35, 3)
sage: xgcd(3, 39)
(3, -38, 3)
sage: xgcd(3, 42)
(3, -41, 3)
sage: xgcd(3, 45)
(3, -44, 3)
sage: xgcd(3, 48)
(3, -15, 1)
sage: xgcd(3, 51)
(3, -50, 3)

It's very hard to see any rhyme or reason in that. Certainly the GMP  
documentation doesn't guarantee any properties of the cofactors,  
apart from bezout, either at the mpz or mpn levels, so it's not a bug.

I'm inclined to do the following in Sage. Provide a "fast" flag which  
just calls GMP and doesn't provide any guarantees about the output  
(apart from satisfying bezout). If "fast" is False (default), then we  
convert to a "standard" form, which should be unique, mathematically  
sensible, and carefully documented.

But having thought about it for a while, it's not even clear to me  
what exactly the right definition of "standard" should be. I don't  
quite understand the minimality condition you proposed.

Apart from the kind of special case listed above, GMP does seem to  
follow some "rules", but I'm not sure they are always satisfied, and  
we can't rely on them since the GMP documentation doesn't promise  
anything.

For example, if 0 < a < b, then xgcd(a, b)[1] always seems to be  
negative and xgcd(a, b)[2] always positive, but it swaps around if 0  
< b < a:

sage: xgcd(11, 17)
(1, -3, 2)
sage: xgcd(17, 11)
(1, 2, -3)

i.e. it looks like it swaps them to make a < b, and then swaps the  
cofactors at the end.

It generally seems to handle input signs in the same way, i.e. it  
first does xgcd(|a|, |b|), then throws the signs back in at the end:

sage: xgcd(11, 17)
(1, -3, 2)
sage: xgcd(-11, 17)
(1, 3, 2)
sage: xgcd(11, -17)
(1, -3, -2)
sage: xgcd(-11, -17)
(1, 3, -2)

But none of this is particularly canonical.

What's the "right" way to do this?

david


--~--~---------~--~----~------------~-------~--~----~
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://sage.scipy.org/sage/ and http://modular.math.washington.edu/sage/
-~----------~----~----~----~------~----~------~--~---

Reply via email to