| Size: 463 Comment:  | Size: 3503 Comment:  | 
| Deletions are marked like this. | Additions are marked like this. | 
| Line 1: | Line 1: | 
| === Files to fix === | 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. | 
| Line 3: | Line 3: | 
| * algebras * calculus * catalogue * categories * coding * combinat * crypto * databases * dsage * ext * functions * games * geometry * graphs * groups * gsl * interfaces * lfunctions * libs * logic * matrix * media * misc * modular * modules * monoids * numerical * plot * probability * quadratic_forms * rings * schemes * server * sets * stats * structure * tests | Import [attachment:fix-random.patch] to sage-scripts to ignore random tests. 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 * Integers, Rationals * complex, real * qqbar * integer_mod * monoids/modules * probability * games * catalogue, dsage, media, stats, server, logic, tests, misc, numerical * algebras * libs * quadratic forms * lfunctions * plot * ext * functions * databases * matrix (all tests pass except for one sage/matrix/matrix_modn_dense.pyx due to groups) * finite fields * coding * crypto * geometry * groups * interfaces * sets In progress * combinat (Mike) * rings/polynomial (cwitty) * misc (latex.py, functional.py, misc.py) (ncalexan) * rings/padics (roed) Todo * schemes * gsl ( dft.py -- abelian group failures ) * graphs (graph_isom.pyx) * calculus (calculus.py) * rings/number_field * rings (homset.py, integer_ring.pyx, J-Z?) * modular (lots :-) ) * categories (homset.py, pushout.py, category_types.py) * abelian_gps (after merge) | 
| Line 42: | Line 61: | 
| === Files to fix (Make all parents conform to the spec) === Useful script to list all parents in a given module that still need work: [attachment: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 [attachment: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 }}} | 
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.
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
- Integers, Rationals
- complex, real
- qqbar
- integer_mod
- monoids/modules
- probability
- games
- catalogue, dsage, media, stats, server, logic, tests, misc, numerical
- algebras
- libs
- quadratic forms
- lfunctions
- plot
- ext
- functions
- databases
- matrix (all tests pass except for one sage/matrix/matrix_modn_dense.pyx due to groups)
- finite fields
- coding
- crypto
- geometry
- groups
- interfaces
- sets
In progress
- combinat (Mike)
- rings/polynomial (cwitty)
- misc (latex.py, functional.py, misc.py) (ncalexan)
- rings/padics (roed)
Todo
- schemes
- gsl ( dft.py -- abelian group failures )
- graphs (graph_isom.pyx)
- calculus (calculus.py)
- rings/number_field
- rings (homset.py, integer_ring.pyx, J-Z?)
- modular (lots  ) )
- categories (homset.py, pushout.py, category_types.py)
- abelian_gps (after merge)
Files to fix (Make all parents conform to the spec)
Useful script to list all parents in a given module that still need work: [attachment: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 [attachment: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
