On Sunday, June 10, 2018 at 12:12:46 AM UTC+10, vdelecroix wrote:
>
> On 09/06/2018 04:00, Travis Scrimshaw wrote: 
> > What Vincent has neglected to mention is the reasoning why I am 
> suggesting 
> > to keep the current behavior for Laurent polynomials. A casual user will 
> > almost certainly do 
> > 
> > 1 / x^k 
> > 
> > and then try to do a method on Laurent polynomials (say, iterate over 
> such 
> > element). The rational functions code does not have many of the methods 
> and 
> > features that Laurent polynomials have. 
> > 
> > Also, they (or at least I) would be quite surprised when x^-1 does not 
> > behave the same as 1/x as they are mathematically equivalent. Also, what 
> > about ~x, should that be the same as 1/x or x^-1? You now have to choose 
> > the correct inverse to get working code. I think this inconsistency is 
> far 
> > worse. 
>
> Mathematically equivalent is first of all vague


Can I frame that quote? :P
 

> and secondly not 
> relevant within most CAS since there are tons of different 0 that behave 
> very differently. 
>

I agree that for a CAS, we sometimes need to sacrifice mathematical 
statements for programming reasons (0 is good, plus things like ==, RR).

>
> I agree that having x^-1 and 1/x being different is confusing. I will 
> update the branch at #25524 to make them identically return a rational 
> fraction. 
>

I think this is even worse than the confusion. I would suspect we will get 
a ton of AskSage questions asking how do we construct x^-1 in the Laurent 
polynomial ring (maybe efficiently). At least, upon seeing this behavior, 
my first approach would be L(1/x) because I know I would leave the ring, 
but then need to come right back (well, if I didn't know that x // y was 
suppose to always return a result in the ring you started).

>
> > I think that any comparison to the integers is a bit unfair given that 
> ZZ 
> > and QQ are generally very good with ducktyping and there is no natural 
> way 
> > to create the inverse of the variables (i.e., what makes them Laurent 
> > polynomials) other than by division or exponentiation. 
>
> "natural" sounds strange in that context. As already mentioned there is 
>
>    1 // x 
>
> to get the inverse of x. And x.inverse_of_unit() also does the job.  
>

Nobody is going to want to type inverse_of_unit() when they want x^-1; plus 
I would never have thought of that to get x^-1.

I had the same first thought as Jeroen with 1 // x == 0, but then I thought 
in terms of quo_rem, and 1 // x should return the quotient, which in this 
case is x^-1. However, it would take a little bit for me to realize this is 
what I have to do.

>
> Though, close to what Nils talked about, there is no straight 
> method for "internal division or raise error".


I thought inverse_of_unit() did this?

Best,
Travis

-- 
You received this message because you are subscribed to the Google Groups 
"sage-devel" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to sage-devel+unsubscr...@googlegroups.com.
To post to this group, send email to sage-devel@googlegroups.com.
Visit this group at https://groups.google.com/group/sage-devel.
For more options, visit https://groups.google.com/d/optout.

Reply via email to