| Size: 3650 Comment:  | Size: 4063 Comment: converted to 1.6 markup | 
| Deletions are marked like this. | Additions are marked like this. | 
| Line 1: | Line 1: | 
| To start, get a copy of Sage 2.10.1, install the latest cython spkg (available at http://sage.math.washington.edu/home/robertwb/cython/), pull from http://cython.org/coercion/hgwebdir.cgi/sage-coerce/ and build. | Merge up at http://cython.org/coercion/hgwebdir.cgi/sage-coerce-3.0.3/ (pull on top of 3.0.3 release candidate) Should build and start without problems. | 
| Line 3: | Line 3: | 
| Import [attachment:fix-random.patch] to sage-scripts to ignore random tests. | |
| Line 13: | Line 13: | 
| Line 16: | Line 17: | 
| * Integers, Rationals * complex, real | |
| Line 20: | Line 18: | 
| * monoids/modules | * calculus * catalogue, dsage, media, stats, server, logic, tests, misc | 
| Line 22: | Line 21: | 
| * monoids | |
| Line 23: | Line 23: | 
| * catalogue, dsage, media, stats, server, logic, tests, misc, numerical | |
| Line 26: | Line 25: | 
| * lfunctions | |
| Line 27: | Line 27: | 
| * lfunctions * plot | * databases * sets * rings/rational * rings/real_lazy * finite fields * structure/formal_sums * rings/padics * graphs | 
| Line 31: | Line 37: | 
| * databases * matrix (all tests pass except for one sage/matrix/matrix_modn_dense.pyx due to groups) | * complex, real * numerical * crypto * interfaces * qqbar * combinat * gsl * abelian_grps * geometry * groups * plot * structure * modules * coding * matrix * rings | 
| Line 34: | Line 54: | 
| In progress | In Progress * schemes (ncalexan, number field problems in elliptic_curves, padic problems in elliptic_curves, total mayhem in generic) * modular (craigcitro) * invalid free in self_orthogonal_binary_codes (robertwb) | 
| Line 36: | Line 59: | 
| * combinat (Mike) * rings/qqbar, polynomials (cwitty) * finite fields (robertwb) | To Do * rings/polynomial * many segfaults for mhansen, probably due to libsingular invalid read * [[http://trac.sagemath.org/sage_trac/ticket/3516|#3516]] libSingular segfault related to the new coercion code [causes segfaults on startup on sage.math] * categories (category_types.py -- 1 failure due to Spec in schemes) | 
| Line 40: | Line 65: | 
| Todo * misc (latex.py, functional.py, misc.py) * gsl ( dft.py -- group failures ) * coding * graphs (graph_isom.pyx) * calculus (calculus.py, desolvers.py, wester.py, equations.py) * number fields * sets (set.py) * geometry (lattice_polytope.py) * interfaces (done except for doctest failures caused elsewhere) * rings * schemes * crypto (classical.py, classical_cipher.py, lfsr.py, mq/mpolynomialsystem.py) * groups (permgroup_named.py, perm_group.py, perm_group_element.pyx) * modular (lots :-) ) * categories (homset.py, pushout.py, category_types.py) | {{{ This should fail: sage: x, y = var('x,y') sage: parent(ZZ[x][y](1)*vector(QQ[y],[1,2])) sage: parent(ZZ[x](1)*vector(QQ[y],[1,2])) }}} | 
| Line 61: | Line 75: | 
| Useful script to list all parents in a given module that still need work: [attachment:list_parents.sage] | Useful script to list all parents in a given module that still need work: [[attachment:list_parents.sage]] | 
| Line 69: | Line 83: | 
| * matrix [http://sage.math.washington.edu/home/robertwb/coerce/coerce-all.hg] * complex, real [http://sage.math.washington.edu/home/robertwb/coerce/coerce-real-complex.hg] * modules [attachment:coerce-free-module.patch] | * matrix [[http://sage.math.washington.edu/home/robertwb/coerce/coerce-all.hg]] * complex, real [[http://sage.math.washington.edu/home/robertwb/coerce/coerce-real-complex.hg]] * modules [[attachment:coerce-free-module.patch]] | 
| Line 125: | Line 139: | 
| === Old notes === To start, get a copy of Sage 2.10.1, install the latest cython spkg (available at http://sage.math.washington.edu/home/robertwb/cython/), pull from http://cython.org/coercion/hgwebdir.cgi/sage-coerce/ and build. Import [[attachment:fix-random.patch]] to sage-scripts to ignore random tests. | 
Merge up at http://cython.org/coercion/hgwebdir.cgi/sage-coerce-3.0.3/ (pull on top of 3.0.3 release candidate) Should build and start without problems.
Hint: If something doesn't work, try typing
sage: coercion_traceback()
which will give a listing of all errors caught in the coercion model.
Doctests
Done
- integer_mod
- calculus
- catalogue, dsage, media, stats, server, logic, tests, misc
- probability
- monoids
- games
- algebras
- libs
- lfunctions
- quadratic forms
- databases
- sets
- rings/rational
- rings/real_lazy
- finite fields
- structure/formal_sums
- rings/padics
- graphs
- ext
- functions
- complex, real
- numerical
- crypto
- interfaces
- qqbar
- combinat
- gsl
- abelian_grps
- geometry
- groups
- plot
- structure
- modules
- coding
- matrix
- rings
In Progress
- schemes (ncalexan, number field problems in elliptic_curves, padic problems in elliptic_curves, total mayhem in generic)
- modular (craigcitro)
- invalid free in self_orthogonal_binary_codes (robertwb)
To Do
- rings/polynomial - many segfaults for mhansen, probably due to libsingular invalid read
 
- #3516 libSingular segfault related to the new coercion code [causes segfaults on startup on sage.math] 
- categories (category_types.py -- 1 failure due to Spec in schemes)
This should fail: 
            sage: x, y = var('x,y')
            sage: parent(ZZ[x][y](1)*vector(QQ[y],[1,2]))
            sage: parent(ZZ[x](1)*vector(QQ[y],[1,2]))
Files to fix (Make all parents conform to the spec)
Useful script to list all parents in a given module that still need work: list_parents.sage
Nothing to do
- catalogue, dsage, databases, ext, games, media, stats, server, plot, logic, tests lfunctions, misc, numerical,gsl, quadratic_forms
Done
- coding, functions, graphs
- matrix http://sage.math.washington.edu/home/robertwb/coerce/coerce-all.hg 
- complex, real http://sage.math.washington.edu/home/robertwb/coerce/coerce-real-complex.hg 
- modules coerce-free-module.patch 
- quotient rings
- finite fields (including natural embeddings into each other when Conway polynomials are used)
- calculus
- number fields
- sets
- geometry
- libs
- probability
- interfaces
- combinat
- rings
- algebras
- monoids
- schemes (modulo some dependance on Groups)
- crypto
In progress
- groups
- modular
Little to do
- categories
Lots to do
Base classes
- structure
Coercion doctesting
Comment from William:
teragon:sage was$ sage -coverage categories/action.pyx structure/element.pyx structure/coerce.pyx |grep SCORE SCORE categories/action.pyx: 0% (0 of 22) SCORE structure/element.pyx: 18% (28 of 153) SCORE structure/coerce.pyx: 2% (1 of 39) I tried to understand and use the coercion model code to trac down the issue with #2079 and was amazed at how nonexistent the doctesting and documentation of functions is there. In order for people to write lots of coercion code all of Sage, it's critical that they can read the coercion model code so they can track down -- for themselves -- what is going wrong when they run into trouble. I would put getting the coverage of the above files (and whatever else is related to coercion) up to 100% as the first step in your coercion model stuff. Seriously. And don't say it can't be doctested, since even though there are a lot of things not easily accessible now from the interpreter, such as the coercion model
Categories to implement
Old notes
To start, get a copy of Sage 2.10.1, install the latest cython spkg (available at http://sage.math.washington.edu/home/robertwb/cython/), pull from http://cython.org/coercion/hgwebdir.cgi/sage-coerce/ and build.
Import fix-random.patch to sage-scripts to ignore random tests.
