On Oct 29, 2012, at 4:39 PM, Marco Streng wrote:
> 2012/10/28 Charles Bouillaguet <charles.bouillag...@gmail.com>: >> Hi all, >> >> While playing with the quotient of a polynomial ring with an ideal, I >> encountered several glitches. >> >> *) Trying to compute the inverse of something which is not invertible. >> >> I know it is kind of weird to try this. However, it raises a >> NotImplementedError exception, instead of something more informative such as >> NonInvertible or whatever. I am willing to patch this, but could someone >> tell me what is the correct exception to raise? > > Based on http://docs.python.org/2/library/exceptions.html, it should > be ValueError (unless Sage has a more precise error for this > situation, but I don't think so). > > But in order to be able to raise a ValueError, you need to first > decide whether your element is invertible or not. If such a decision > mechanism is not implemented, then NotImplementedError is the only > possibility. And I guess that is the current situation here. Actually, I beg to differ. What is currently implemented is the following. Let R be a polynomial ring, I be an ideal of R, and f be a non-zero element of R/I. To check whether f is invertible in R/I, we check whether 1 belongs to the ideal (I + <f>). If it is the case, then an inverse exist. Indeed, in this case, there exist g in R such that 1 = [something in I] + g*f. It follows that the class of g in R/I is the inverse of f. But this test in fact **decides** whether an inverse exist. If there exist a g such that f*g = 1 mod I, then by definition there exist two polynomials of R, say f' and g', such that f is the class of f' and g is the class of g' modulo I. Then in R we have f*g = 1 + [something in I]. This automatically implies that 1 belongs to the ideal (I + <f>). Thus, the current implementation should not return "ErrorNotImplemented", it should return "NonInvertible", because we KNOW that it is the case... This is now #13670. However, presently this test uses p.lift(…), and as you pointed out the answer becomes bogus as soon as one tries to invert something non-invertible…. This one is now #13671 . Cheers, --- Charles Bouillaguet http://www.lifl.fr/~bouillaguet/ >> *) Non-deterministic output of some (presumably deterministic) functions >> >> Here is an example : >> >> sage: R.<x1,x2> = QQ[] >> sage: I = R.ideal(x2**2 + x1 - 2, x1**2 - 1) >> sage: test = I.gen(0) + x2*I.gen(1) >> sage: (test).lift( I ) >> [1, x2] # this is correct >> >> sage: R.<x1,x2> = QQ[] >> sage: I = R.ideal(x2**2 + x1 - 2, x1**2 - 1) >> sage: test = I.gen(0) + x2*I.gen(1) >> sage: (test + 1).lift( I ) >> [0, 0] # this is correct > > No it isn't, the correct output would be ValueError, as (test+1) is > not in I. So this is a bug in the "lift" method. > >> >> sage: R.<x1,x2> = QQ[] >> sage: I = R.ideal(x2**2 + x1 - 2, x1**2 - 1) >> sage: test = I.gen(0) + x2*I.gen(1) >> sage: (test).lift( I ) >> [0, 0] # this is WRONG !!! should be [1, x2] >> >> It looks like this could be a caching issue, so I am not sure whether I need >> to open a new ticket for this, or if it is already "catch" by an >> already-opened ticket. > > It is some kind of corruption triggered by the abovementioned bug, so > it may vanish when that bug is fixed. > > Here is a shortened version of your input: > > sage: R.<x1,x2> = QQ[] > sage: I = R.ideal(x2**2 + x1 - 2, x1**2 - 1) > sage: test = I.gen(0) + x2*I.gen(1) > sage: test.lift(I) # correct > [1, x2] > sage: (test+1).lift(I) # invalid input, should give error > [0, 0] > sage: test.lift(I) # incorrect > [0, 0] > > > >> >> *) Segfault >> >> The same kind of problem allows a small piece of code to cause segfaults in >> SAGE (apparently in singular-related stuff) : >> >> sage: R.<x1,x2> = QQ[] >> sage: S = R.quotient_ring( R.ideal(x2**2 + x1 - 2, x1**2 - 1) ) >> sage: 1 / S(x1 + x2) # should raise NotImplementedError >> sage: >> sage: R.<x1,x2> = QQ[] >> sage: S = R.quotient_ring( R.ideal(x2**2 + x1 - 2, x1**2 - 1) ) >> sage: S.is_integral_domain() >> >> ---> BOOM >> >> *) bizarre output of p.lift(….) >> >> When R is a Polynomial Ring, I is an ideal of R, and p is a polynomial of I, >> then p.lift( I ) returns a polynomial combination of a (groebner) basis of I >> which is equal to p. However, when p is not in I, then p.lift( I ) returns >> [0,0,…,0]. I find this a bit strange. Should p.lift(…) raise an exception >> instead? This would be a change of specification, so I guess it should be >> discussed first… >> >> >> >> >> --- >> Charles Bouillaguet >> http://www.lifl.fr/~bouillaguet/ >> >> >> >> -- >> You received this message because you are subscribed to the Google Groups >> "sage-devel" group. >> To post to this group, send email to sage-devel@googlegroups.com. >> To unsubscribe from this group, send email to >> sage-devel+unsubscr...@googlegroups.com. >> Visit this group at http://groups.google.com/group/sage-devel?hl=en. >> >> > > -- > You received this message because you are subscribed to the Google Groups > "sage-devel" group. > To post to this group, send email to sage-devel@googlegroups.com. > To unsubscribe from this group, send email to > sage-devel+unsubscr...@googlegroups.com. > Visit this group at http://groups.google.com/group/sage-devel?hl=en. > > -- You received this message because you are subscribed to the Google Groups "sage-devel" group. To post to this group, send email to sage-devel@googlegroups.com. To unsubscribe from this group, send email to sage-devel+unsubscr...@googlegroups.com. Visit this group at http://groups.google.com/group/sage-devel?hl=en.