Skip to content

Roadmap 1.0 and beyond #3054

Open
Open
@fieker

Description

@fieker

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)

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 and residue_ring, residue_field constructors to return proper fields, not generic ones
  • Hecke CrvEll and relation to PlaceCrv and Scheme
  • unify automorphism_group_generators and friends
    • automorphism_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)
  • 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 and tensor_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)
  • replace some (many) MapFromFunc by proper types?
  • CalciumQQBar vs qqbar 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
  • nmod_poly_factor and friends: should be useless and unreachable
  • Nemo.GaussianIntegers and Nemo.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

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions