Hi Florent,

On 2012-05-08, Florent Hivert <florent.hiv...@lri.fr> wrote:
> But it is never called. I'd like to have confirmation that adding to all
> vectors classes (following sage/structure/element.pyx line 881 (5.0.rc0))
>
>     def __richcmp__(left, right, int op):
>         return (<Element>left)._richcmp(right, op)
>
> is the correct solution.

Yes, the following advices given in some comment in
sage/structure/element.pyx are still valid (and, I agree, difficult
to keep in mind):

    ####################################################################
    # For a derived Cython class, you **must** put the following in
    # your subclasses, in order for it to take advantage of the
    # above generic comparison code.  You must also define
    # either _cmp_c_impl (if your subclass is totally ordered),
    # _richcmp_c_impl (if your subclass is partially ordered), or both
    # (if your class has both a total order and a partial order;
    # then the total order will be available with cmp(), and the partial
    # order will be available with the relation operators; in this case
    # you must also define __cmp__ in your subclass).
    # This is simply how Python works.
    #
    # For a *Python* class just define __cmp__ as always.
    # But note that when this gets called you can assume that
    # both inputs have identical parents. 
    #
    # If your __cmp__ methods are not getting called, verify that the 
    # canonical_coercion(x,y) is not throwing errors. 
    #
    ####################################################################

IIRC, the problem is that (by design of Cython) it is not possible to
inherit __(rich)cmp__  if there is also a __hash__ method. Anyway,
copying the code for __(rich)cmp__ from sage/structure/element.pyx is
necessary, inheritance wouldn't work, as I've learnt the hard way...

And then, _cmp_c_impl or _richcmp_c_impl are supposed to provide the
actual implementation of comparison.

> Removing the offending __richcmp__ in
> FreeModuleElement seems to solve the problem once for all for all rings but
> introduce a lot of other problems.

What other problems emerge? Given the comment from sage/structure/element.pyx, 
I think
that method should be renamed into _richcmp_c_impl.

> Also it is very likely that the same problem is occuring in different places
> (not only the various vector classes) and I'm not completely sure where to
> look. I'd rather have an automatic way to find all the places where this fails
> and also add the check to TestSuite if possible. Does anyone have a suggestion
> for that ?

I am not sure what you are trying to do. Do you want to detect Cython
classes that inherit from sage.structure.element.Element and do not copy
their __cmp__ method as they should? I am not sure how this could be
done without source inspection.

Cheers,
Simon


-- 
To post to this group, send an email to sage-devel@googlegroups.com
To unsubscribe from this group, send an email to 
sage-devel+unsubscr...@googlegroups.com
For more options, visit this group at http://groups.google.com/group/sage-devel
URL: http://www.sagemath.org

Reply via email to