Open
Description
Deadlines
- Oscar book needs to be ready 31 January 2024 (or maybe even earlier)
- anything relevant for the book (and examples in it) should be settled before
- the proposal is submitted 1 May 2024, so 1.0 should be out before that
- some improvements can be done afterwards but still should be done ASAP so that referees will see them
Plan
Kaiserslautern: two regular meetings:
- triage: Wednesday 11:30-12:20 (planning; review and resolve issues and PRs on Oscar, Nemo, AA, ...)
- code sprint: TBD (possibly Wednesday or Thursday 13:30-16:00)
- it will be possible to join either via Zoom
Things critical for the book (end of January!!)
Examples in the book should match what we get in 1.0 even though 1.0 won't be finished in time for the book deadline. That means a few items should be done before; and if we can't do them, then we may have to "lie" in the book in a few examples (i.e. edit output to match what it is supposed to be in 1.0, not what it is right now)
- NEW HackMD for renaming
- finalize type and function names (at least any user facing)
- relevant issues:
Abs..
in type names can indicate "abstract" or "absolute". It should be only one- there are many abstract types without the Abs, what is the plan?
- abstract type
ProjSpc
, but abstract typeAbsAffineAlgebraicSet
- abstract type
ModuleFP
, abstract typeAbstractFreeModElem
- abstract type
OscarMap
AbstractLat
- abstract type
- concrete types
AbstractVariety
etc.
- there are many abstract types without the Abs, what is the plan?
acb
,arb
and friends and relatives in Nemo need proper namesCoveringMorphism
->CoveringMor
? rules for Mor(phism)?- Inv and Invar in type names
- _dec vs Dec
- Mod and Module
FPModule
vsModuleFP
- GrpAb -> AbGroup? and other Grp in Hecke and below
- improve printing for groups Print group generators in detailed printing #2878
- printing of modules etc., Adjust printing of modules and related stuff to follow OSCAR printing guidelines #2891 (@jankoboehm @wdecker @HechtiDerLachs @simonbrandhorst )
sub
/quo
/etc. dispatches should be consistent in the return values (with/without map, order, etc.)
Things critical for 1.0 (e.g. to avoid breaking semver in 1.1)
- Hecke and Oscars GModules and their relation
- sanitize exported vs non-exported stuff
- if you are aware of things that are not exported but should be (or vice-versa), please report it
- never export a function starting with an underscore (if user should use it, give it a proper name)
- if in doubt, don't export it (it is easy to add export; but hard to remove them again; people will expect that anything exported is official and here to stay)
- remove large code blocks in comments?
- turn more structs into immutable ones?
- various
quo
andresidue_ring
,residue_field
constructors to return proper fields, not generic ones - Hecke
CrvEll
and relation toPlaceCrv
and Scheme - unify
automorphism_group_generators
and friendsautomorphism_list
automorphism_group
automorphisms
- revisit Lie theory
- come up with a plan for future extensions now so that things will at least have a chance of fitting together
- talk with Uli T, Lars G. and others in Aachen, Laura, ...
- Dynkin diagrams as graphs, visualization, ...
- (applications in many places, e.g. in F-Theory, ....)
- representation theory
- finish the G-module stuff, migrate it from Experimental, ...
- e.g. extension of scalars etc. etc.
- PcGroup vs FpGroup and their relation and definition (see also PcGroups as FPGroups #952, Rename FPGroups resp. clarify documentation #1139, Add
SubPcGroup
type #2672) graphs (Lars K)- better mpoly interface (dynamic polynomial interface for universal polynomials)
- see e.g. https://github.com/JuliaAlgebra/DynamicPolynomials.jl:
- promote UniversalPolynomialRing more, make it easy to find/use
- "nicer" substitution syntax, e.g.:
subs(p, y=>x^2)
p((x, y)=>(y, x))
- lin alg interface: revise them
- (Tommy started a document on this)
- (more) functions for efficient base operations (addrow, swaprow, etc. etc.)
- standard names for certain operations that cover all cases
- consistent behavior
- decide things like result as matrix vs. result as vector space object
- sparse stuff....
- Streamline methods for
direct_sum
andtensor_product
throughout Oscar #3059 - ... more to be added here
Important for 1.0 in the sense of "should be there to look good", but not in a technical sense (not breaking semver)
These are things we want for the grant application reviewers, but technically they are separate from 1.0
- AbstractAlgebra documentation:
- mention Oscar
- mention limitations
- precompile on installation or install via Aaruni's toolkit
- documentation
- QQbar
- ... in general, improve, proof read, criticize...
- state definitions in more places
- ideally every function docstring has at least one example
- but not everything needs a docstring (e.g. no need for 1 million
+
docstrings) - ring arithmetic etc. is better showcased (if at all) in a docstring for the ring type and/or in the manual section for that ring; or even not at all
- Oscar web-site
- news
- publications
- tutorials -> Martin Bies
- ref to book
- identify existing data sets within OSCAR and bring their metadata to the MaRDI portal
Important but could be deferred to 1.x:
- POSets
- some more vprint, hassert throughout the system
- document and use some of the exception types
- e.g. Hecke provides
BadPrime
- also use those provided by Julia (e.g.
InexactError
)
- e.g. Hecke provides
- replace some (many)
MapFromFunc
by proper types? CalciumQQBar
vsqqbar
vs.Nemo.QQBar
- decide how to expose this (e.g.
algebraic_closure(QQ)
) - rename?
- AlgClosure(QQ) as QQbar and some support and docu for it
- provide conversion between QQBar elements and genuine number fields
- decide how to expose this (e.g.
nmod_poly_factor
and friends: should be useless and unreachableNemo.GaussianIntegers
andNemo.GaussianRationals
- should we just get rid of them? (they don't fit into the number field hierarchy)
- serialization immediate in memory: test case (parallelization)
- serialization:
- group theory types missing
- in some cases that's caused by missing serialization features
- allow "easy" attribute serialization... ? but warn about dangers
- docstrings for more (all?) types, at least concrete types
- ideally including examples showing how to produce instances of that type
Metadata
Metadata
Assignees
Labels
No labels