-1. Add CartesianProductEJA.
+1. Add references and start citing them.
-2. Check the axioms in the constructor when check != False?
+2. Profile (and fix?) any remaining slow operations.
-3. Add references and start citing them.
-
-4. Implement the octonion simple EJA.
-
-5. Factor out the unit-norm basis (and operator symmetry) tests once
- all of the algebras pass.
-
-6. Refactor the current ungodly fast charpoly hack (relies on the
- theory to ensure that the charpolys are equal.)
-
-7. If we factor out a "matrix algebra" class, then it would make sense
- to replace the custom embedding/unembedding functions with static
- _real_embedding() and _real_unembedding() methods.
-
-8. Implement random_instance() for the main EJA class.
-
-9. Implement random_instance() for the subalgebra class.
+3. When we take a Cartesian product involving a trivial algebra, we
+ could easily cache the identity and charpoly coefficients using
+ the nontrivial factor. On the other hand, it's nice that we can
+ test out some alternate code paths...