Axiom was most recently released in August, 2014. You can view the release notes for each release. The new release is available for different platforms on the downloads page. This TODO list represents abbreviated notes to categorize the work directions and note progress (completed items have a - prefix). Items are expanded as the work thread moves into that subject. There is no priority and no schedule. The ratio is (# of completed task per section)/(total completed tasks) and is a measure of the ratio of effort between areas. Completed tasks are marked with a - in column 1 (+ indicates changes since last update) There are approximately 285 tasks listed. These tasks are broken into the following groups: Literate sources is the main thread of developing Axiom Splits are pieces of work to give away Joins are pieces of work to incorporate or cooperate with New Development is a list of ideas for new directions or needed work Research is a list of ideas that need investigation Community is a list of supporting tasks for the algebra community ************************************************************************** LITERATE SOURCES Motivation: Axiom needs to be well documented to live. To achieve this end it is being rewritten into literate software form. rewrite src/interp into the current books and remove this directory - rewrite the machine-generated lisp into hand-generated form - flatten the many layers, using macros for inline efficiencies reorganize the interpreter (vol5) into high level chapters and sections - make the structure of the interpreter obvious reorganize the compiler (vol9) into high level chapters and sections - make the structure of the compiler obvious organize the algebra theory by topic (vol10) - design a rational layout make regression, help, and examples for all algebra (vol10.*) - a .input for every constructor - a )help file for every constructor and function - a )d op "example" for every function split src/input into parts and remove src/input - some full domain examples into vol10 - some function uses into vol10* tests - some files into a regression test suite recover numerics port to Windows ************************************************************************** SPLITS Motivation: several pieces of the system have nothing to do with algebra and either have old technology that needs to be rewritten or common technology that ought to be contributed to other efforts. FIREFOX BROWSER Motivation: We need a portable, useful front end to Axiom that combines the separate pieces of the Axiom command line, hyperdoc, and graphics into a unified way of working with pamphlet files. * Rewrite Hyperdoc Pages This task is to extract the information from the current hyperdoc system and make it available in the browser. rewrite all pages using AJAX add additional pages rearrange the order for clarity dynamically create category/domain/packages pages dynamically create operations pages allow ASQ style lookups * Integrate Graphics This task is to extract the functionality from the graphics and make it work within the browser. + collect the graphics into a book volume document the graphics refactor graphics to extract X11 API make API compatible version of graphics for CANVAS element enable dynamic drawing into CANVAS enable popup page with CANVAS and control menu elements * Write Notebook Front End This task is to make a new, browser-based front end to Axiom. create new API domain to expose history make new context sensitive menus make card/div/Record objects enable create/destroy/rearrange/import/export of card decks unify card decks and pamphlets AXIOM TEST SUITE->COMMON TEST SUITE Motivation: Algebra needs a hand-verified test suite which ought to be shared with other computer algebra systems. Needs a common syntax, could be a driver for previous item. rewrite regression test files with results from MMA, Maple, Maxima reformat files to use a common theory/practice format organize files into a useful taxonomy ************************************************************************** JOINS Motivation: there are several CA systems with very interesting features and/or algebra. Axiom needs to import these ideas or find ways to cooperate with these projects. GAP->AXIOM Motivation: GAP has much stronger facilities for manipulating groups. Axiom can do group manipulation but GAP needs to be studied. OCTAVE->AXIOM Motivation: Octave has the capability to be a replacement for the NAG numeric libraries. Either an interface has to be retargetted or the code has to be ported to Aldor or Lisp. - Test rewriting Fortran code into Aldor + BLAS converted to pamphlet form BLAS integrated into Axiom MAGNUS->AXIOM Motivation: Magnus is strong in infinite group theory. Like GAP it needs to be studied and imported. - Discussion and proposal for work in this area with CCNY + Magnus is being rebuilt as a literate program and will eventually be + merged with Axiom Rebuild Magnus as a literate program Extract and categorize the magnus algorithms Provide Axiom implementations of the algorithms ASTRONOMER->AXIOM Motivation: Internal representation of polynomials that can be scaled to ~250k terms needs to be imported. This task is dead. COMBINAT->AXIOM Motivation: External basis representation of large polynomials needs to be imported. This task is dead. MATHEMATICA->AXIOM Motivation: Workbooks need to be imported. This task has changed. Rather than focus on the mathematica workbooks we plan to create and use the new Axiom firefox browser as a notebook front end similar to Sage. ************************************************************************** NEW DEVELOPMENT EXTERNALS DOCUMENTATION Motivation: in order to allow users to use the system we need to collect and organize the documentation and help facilities. - The Axiom book was rewritten and is now available as part of the normal - distribution. - The Axiom tutorial book was published at Lulu.com - The firefox browser was created + Additional pages from hyperdoc need firefox rewrites The .dvi files need to be accessible in the firefox hyperdoc + )help files are needed for more domains + )display operation needs examples for operations INTERNALS DOCUMENTATION Motivation: in order to allow multiple developers to work on the system the structure of the system needs to be explained. - Directory structure - document shell script - Makefile structure - document how the makefile tree works - Lisp structure - src structure - algebra - boot - clef - doc - etc - graph - htex - hyper - include - input - interp - install - lib - lsp - noweb - paste - sman Motivation: restructure Axiom into literate book volumes - Volume 0: Jenks book - Volume 1: Tutorial Volume 2: User's Guide Volume 3: Programmer's Guide + Volume 4: Developer's Guide + Volume 5: Interpreter Volume 6: Axiom Command + Volume 7: Hyperdoc + Volume 8: Graphics Volume 9: Compiler Volume 10: Algebra Volume 11: Firefox Hyperdoc ALGEGRA DOCUMENTATION LITERATE PROGRAMMING Motivation: algebra code should be able to include research papers and documentation of design choices, space, time and complexity. Researchers should be encouraged to write literate programs. Literate programs should be easily turned into book sections or chapters. - seek appropriate tools - tangle, weave - cweb - noweb - seek feedback - create preliminary setup - create example pamphlet (DHMATRIX) - define doc structure - prototype - modify/rewrite noweb - make undefined chunks transparent - example generation test case generation - create booklet example (MATRIX) + define booklet structure + prototype - integrate into make - integrate into obj/mnt + integrate example (DHMATRIX2) into make + integrate book example into make write pamphlets for type hierarchy write SetCategory pamphlet integrate into make integrate into test write pamphlets for data structure hierarchy write aggregate pamphlet integrate into make integrate into test create example pamphlet from scratch (PRIMES is in P algorithm) recreate paper in tex write algorithm merge into build + create example pamphlet from planarity paper recreate paper in tex write algorithm merge into build create complex pamphlet (Barry Trager's Integration thesis) - recreate thesis in tex factor thesis into booklets factor booklets into pamphlets SINGLE-STEPPING Motivation: Users of algebra should be able to step thru algorithms at some "appropriate" level of detail. Hard to do as most algebra algorithms differ from hand methods. LIBRARY CLEANUP Motivation: FullyExplicitRingOver needs a better theory basis, etc. GCL BUILD Motivation: run on a popular common lisp - Download GCL - Build image in /spad/lsp/gcl - Build Axiom on image CMUCL BUILD Motivation: run on a popular common lisp Download CMUCL sources Build image in /spad/lsp/cmucl Build Axiom on image CCL BUILD Motivation: run on a popular common lisp - Get final CCL sources from Arthur - Build image in /spad/lsp/ccl - Build Axiom on image This effort is dead. ************************************************************************** RESEARCH AXIOM JOURNAL Motivation: Provide a motivation and place to publish Axiom algorithms in a literate programming style. Journal development will require refereed papers. - Discuss with Community Contact TOMS at ACM Create License for pamphlet submission - This is likely to be the creative commons license - Create Prototype online site (www.nongnu.org/axiom/Journal) Create Journal directory Structure pages similar to Journal Integrate into CVS Allow dynamic referee lists Research online/offline references to Axiom in literature Create citations bibliography Get permission to mirror/host published papers - Give presentation to Univ of Pisa re: literate journal - Worked with ACM to provide electronic ISSAC journal +CRYSTAL + Motivation: Soon it will be possible to have all prior published math + online and locally available. We need to design and build + a user interface model that supports researchers in math + by providing semantic searches, multi-faceted problem views, + real-time problem classification, and an "intensional stance" + assistant user interface. + Define model of interaction Prototype semantic markup Prototype semantic classification with KROPS Prototype facet viewer Prototype classifier Prototype intensional stance assisant COMPLEXITY Motivation: Axiom is fully layered. Research results in the lowest layers can be leveraged to generate results in higher layers. Use Axiom against itself to create towers of complexity. Insist on complexity results in documentation. TEXTBOOK OBJECT Motivation: Axiom interpreter objects don't have a standard name for their parts and do not have a manipulation language for rewriting parts. idea: have a "tree" primitive for each type idea: define a graph of tree to tree maps that label each edge with the transformation applied to the subtree TEXTBOOK CONTEXT Motivation: Equations are ambiguous when standing alone. Textbooks provide context in the surrounding text. This is not adequately captured by the type system. A new approach to this issue is required. OPEN PROBLEMS LIST Motivation: Magnus maintains a community agreed-upon list of "open problems" This is an excellent source of PhD work and a good focus mechanism. Create and maintain this. PROVISOS Motivation: Assume is a weak, global mechanism for capturing provisos. A new proviso object needs to exist that wraps existing objects, provides scope for provisos and provides an algebra of provisos based on type (arithmetic, boolean, typed, etc). - Review the literature to extract proviso forms. - Classify proviso forms. - Draft research paper Develop an arithmetic of proviso forms. INTERVAL ARITHMETIC Motivation: This is a fundamentally stronger way to represent uncertainty in results. It needs to be lifted from the numeric domain and defined symbolically. It needs to be integrated into the proviso algebra. Document interval.as algebra domain +INDEFINITES + Motivation: Research needs to be done on how to represent and compute + with indefinite objects from domains. An indefinite object + has a fixed type (such as Integer) but a non-specified value. + Thus it is possible to say that x+1 is of type Indefinite Integer + since 1 is an Integer and x is an Indefinite Integer. + Submit NSF grant proposal (awarded) + Conduct research on indefinites Construct domain examples +WEB ACCESS TO AXIOM + Motivation: There are several research efforts to make computer algebra + available on the web. Axiom needs to participate and lead. + Work with ORCCA rebuild OPENMATH support update to latest OPENMATH standards + Work with MathAction + integrate automatically running Axiom into web pages DOMAIN INTEGRATION Motivation: Axiom would be strongly useful in domains such as robotics. Areas such as backsolving of joint position can be fruitful areas of research. Deep integration in domains (DSP, Vision) needs to be pushed. + The Doyen effort is the current direction for this. Axiom will integrate + with the rest of the sciences thru this effort. SEMI-ANALYTIC SOLUTIONS Motivation: Axiom could provide parallel tasks that would continuously try to extract analytic solutions from incoming data. For example, in vision finding analytic edges to feed to a parallel recognizer algorithm. GAMES INTEGRATION Motivation: Axiom can be used to model games in novel ways. For example, flight games with pursuit curves that live in a non-uniform space (planet gravity, changing density across air/water). CONSTRAINED MODELS Motivation: Force motion that always remains analytic. Thus the final solution is known to be analytic. For example, constrain intersecting pipes to known boundary conditions. Computational geometry seems the most fruitful area. VALIDATION and VERIFICATION Motivation: Algebra systems need a high level of confidence in the results. Hand checking of the results is difficult and expensive. Automatically substituting results into the original equations could raise confidence. Auditing of boundaries of algebra algorithms. Precondition/Postcondition results for domains. Audited test suites used for regression testing. ALGEBRA MANIPULATION LANGUAGE Motivation: Algebra systems have interpreters that embody a lot of knowledge about the actions available to manipulate equations. This knowledge needs a language. The language needs to be crafted so that it can be added to domains and applied in symbolic form by a generalized simplification routine. Review the literature to extract manipulation sentences. Classify manipulation forms. Draft manipulation paper BOYER-MOORE THEOREM PROVER INTEGRATION Motivation: Computational logic is a branch of computer mathematics that is not currently available in Axiom. The Boyer-Moore theorem prover, written in common lisp, provides a good general purpose platform to study the interaction of the theorem proving systems with Axiom - Contact Boyer & Moore - Contact Chandy & Misra - Download ACL2 Build ACL2 Invoke ACL2 from Axiom Integrate ACL2 into Axiom Use Dijkstra's methods against SetCategory Draft research paper MetaPRL THEOREM PROVER Application Motivation: MetaPRL is a Higher-order Logic proof system that is well suited to proving Axiom-style languages. The proofs from this system would give higher confidence levels in the correctness of Axiom's algorithms. - Contact Artimov - Review nuprl - Review MetaPRL - Construct trial example - Collect all sorting routines in Axiom Model the required subset of Axiom's language Construct a proof of the sort algorithms ************************************************************************** COMMUNITY COLLECT AXIOM ALGEBRA DEVELOPERS Motivation: Work in Axiom has continued over the years but has not been integrated. Find this work and integrate it. COLLECT AXIOM KNOWN BUGS + Motivation: Axiom has known bugs. Create a known bug list. + Integrate fixes for catdef + Integrate fixes for pleqn TRAIN AXIOM INTERNAL DEVELOPERS Motivation: Many of the subtasks listed above can be split off, done in parallel and lead independently. Find people who are interested, especially external projects (eg work with Gnuplot to enhance it with Axiom's abilities). - Set up cvs on Tenkan - Set up accounts for developers - Import current Axiom tree into CVS - Try system builds on developers machines - Exchange code via CVS - Expand platforms - Cygwin - Mingw - FreeBSD SUPPORT FRENCH WORK Motivation: An organized community will help focus new Axiom development. - Lyon conference presentation - Set up OSCAS group - Announce OSCAS group - Moderate OSCAS group This is a dead branch of effort. SET UP GOLD REPOSITORIES Motivation: Community needs all the usual tools enabled like bug list, mailing list, cvs, etc. - savannah.nongnu.org (CVS) - sourceforge.net (CVS) - arch.axiom-developer.org (ARCH) + github (GIT) SET UP SILVER REPOSITORIES Motivation: Expose leading edge work - sourceforge.net (SVN) - git.axiom-developer.org (GIT) savannah.nongnu.org (GIT) ROSETTA Motivation: the community needs to see and use the many open source computer algebra systems so they can compare and contrast the various systems. This will help focus the issues of what is currently possible and how hard it is to develop a large, general purpose system. Also useful for teaching. - Build Rosetta CD - collect open source systems - build them on a common subtree - write Rosetta document - write them to CD such that they can be run with installation - distribute CD to conferences, teachers, etc + Update Rosetta CD + add Axiom + fix mistakes + add paragraph per table + update Rosetta document for Giac + update Rosetta document for DoCon + update Rosetta document for Macsyma + write Meta-Rosetta document to expound on differences + integrate systems with browser front-end + build broken systems + feed back diffs to original projects + add new systems + find new customers + The Rosetta effort is joining with the Quantian effort and the result + will be known as Doyen. This work is in process. Build Doyen Create live CD Create standalone MathAction Integrate Axiom into standalone MathAction Build coordination tools between daughter Doyen and mother Doyen site AXIOM WEBSITE Motivation: maintain a website so that progress on making Axiom open-source is made visible and the community has a place to discuss issues and ideas (not necessarily related to Axiom but to the community in general). - create website - build interest list - create and maintain update schedule EXPLORE FUNDING MODELS Motivation: Find creative ways to pay people who work on Axiom. Everybody wants free developers but paid work will motivate development. Academic degree (BA in open source? BA in computer algebra?) - Developed an open source lab at City College of NY. Lab is up and running - Lab is part of the capstone projects for CS undergrads Grant model by line of code - contact IBM - contact SUN + contact NSF contact INRIA contact DARPA + explore other contacts Award Model - Schelter Award - contact UTexas - contact FSF develop plan define award type and frequency find sponsor organization - Efraim Armendariz- Brad Kuhn find volunteers to judge award Oscars/Emmy/Tony award model for CA at ISSAC? - Jenks Award Pay for support model + Pay for travel model + Contact Google + Contact IBM + Contact SUN + Contact Sage + Contact NSF
Completed, dead, or abandoned tasks
HYPERTEX->BROWSER/TEX Motivation: hypertex was pre-browser technology. It should be rewritten to fit into today's technology. At least HTML, possibly XML. - This work has forked into two paths. The first path is to recreate the - browser from the hypertex sources. The second path is to rebuild the - whole effort into a standard browser-based tool. Ultimately this will - probably get merged with the Doyen science platform effort - Recreate Hypertex - Create standard browser - create standalone browser version - merge into Doyen ASQ->JAVADOC/DOC++ Motivation: asq is pre-javadoc. It should be rewritten to fit into the browser/tex new world of docs - The ASQ tool needs to get redone so that standard html pages get built - during system build and made available. They should have a javadoc-like - look and feel. - Create ASQ-HTML page generator This task is complete. PLOT->GNUPLOT Motivation: plot has nothing to do with algebra but has some nice features such as data feedback from graph manipulation. These facilities should be moved to Gnuplot and the plot function retargetted. The graphics have been rebuilt and currently work. The graphics can only be run from a file at the moment because the connecting process, called sman, which manages all of the axiom processes is not yet working again. Rebuild sman Connect sman to graphics Connect graphics to gnuplot This task was abandoned. The 2D I/O direction has changed. The current plan is to use the firefox browser as a universal front-end to Axiom. READ-EVAL-PRINT->TeXmacs Motivation: the time has come for 2d input. TeXmacs provides this. There needs to be a much tighter integration of TeXmacs and Axiom. Connect to TeXmacs community - Build TeXmacs on Linux - Build TexMacs on Cygwin Build TexMacs on Windows pick up the notebook interface ideas from Sage AXIOM I/O->COMMON SYNTAX Motivation: Rosetta should not exist. Algebra syntax should standardize. Existing committee work needs feedback from Axiom. The Rosetta effort is complete.