Skip to content
Steven De Keninck edited this page Sep 24, 2017 · 10 revisions

Ganja.js Wiki

Read on for some background information, motivation on design choices, roadmap and as I get to it perhaps some extra generic GA information or a guide to available literature.

Roadmap

  • 0.4 : Prototype - extend on PGA2D, PGA3D, CGA2D and CGA3D examples and adjust features and API as required.
  • 0.5 : Optimization - test mixed mode (several subalgebra's interoperating) - allows space reduction for e.g. vector lists.
  • 0.6 : Optimization - Basic optimisations on AST (avoid creating to many inbetween multivectors)
  • 0.7 : Optimization - GPU and Threading

Architecture

Ganja.js differs greatly in architecture when compared to other Geometric Algebra implementations (like for example versor.js). These other implementations (typically originaly modeled for c++) often provide in many classes, strictly typed multivectors, and heaps of generated code. These choices are imho not ideal for a JIT language like javascript, and as a result ganja.js provides a different and unified approach counting on current (and future) JIT optimisation techniques to select, compile and optimize specific code as required by a given application or even data-set.

As a result, Ganja.js provides in a very compact (yet complete) implementation that is well suited for use on the web. A large part of ganja.js internals are doing symbolic math resulting in javascript code that ultimately provides in the desired (Numerical) Algebra implementation.

The design of Ganja.js is top-down and reflects as such the ideology behind Geometric Algebra itself. One ring to rule them all.

Degenerate Metric.

Correct handling of the degenerate metric (enabling Euclidean PGA) was one of the prerequisites for ganja.js. As a result, it's duality operator is non-metric, and GA formulas dependant on an invertible pseudo scalar are modified to work without, afaik, ganja.js is the only javascript GA implementation that provides this functionality.

Classic texts in the area of GA have typically ignored the degenrate metric as inconvenient, but it's use for PGA is an absolute must. We refer the reader to the excellent work of Charles Gunn for further details.

Matrix Free inverses.

Ganja.js provides in matrix-free inverses for all metric signatures up to 5D. (I'm not aware of any other javascript GA implementations that have this feature). Inverses are good to have. Not having to go over 8x8 or 16x16 or 32x32 matrices is desirable.

Syntax over Performance

Ganja.js primary focus is enabling programmers and engineers to adapt to this new, easier and unified mathematical language. As such, a clean and accessible syntax is the primary motivation behind ganja.js. In those places where syntax and performance are conflicting interests, the clean and minimal syntax will take precedence.

Clone this wiki locally