This repository is my playground to learn geometric algebra and to test code-snipsets. It is focussed on conformal geometry algebra only, because I work with this model in the context of robotics where it is very useful to have the round objects of CGA available to model inverse kinematics. The conformal group is the group of transformations that preserve angles. This includes the rigid (euclidean) transformations. The conformal group on
The project is not intended to be used in real world applications but is is helpful to learn about geometric algebra, especially definition of signs, conversion to euclidean vector algebra, ... If you have feedback or feature suggestions, please create a new GitHub Issue.
Changes in the API are planned e.g. to correct some object namings and there are still known but not fixed bugs and sign-definition problems. This software is implemented for learning purposes only. It is not recommended to use it as an GA-implementation for application development.
This repository contains two implementations of CGA in the Java programming language. One is based on code generated by ganja.js and a second is based on the geometric algebra reference implementation of the book Dorst2007.
ganja.js does is not yet able to generate code (for arbritray languages) for the inverse() function to calculate the inverse of an arbitrary multivector. The inverse-function is implemented in js only. That´s why an implementation is added based on this paper.
It is planed also to add an implementation based on the JClifford project. All implementations can be switched transparently for testing purposes. The API and its unit tests encapsulates the concrete underlaying implementation.
This repository includes code to decompose multivectors into geometric 3d-parameters like location, attitude, radius/size/squaredSize, weight etc. and specialized classes to represent Vectors, Bivectors, Trivectors etc.
The project is used to learn about different possibilities to implement CGA and to find a good CGA API as a basis to integrate CGA based on a DSL into the Java virtual machine (see here). The overall aim is to integrate CGA polyglott into the Java VM, supported by a complete development tool chain with syntax-highlighting and debugging etc. This work will be done based on the Netbeans IDE.
CGA can be implemented based on different metrics corresponding to different definitions of the origin and the point at infinity. Different metrics results in different formulas for composition of CGA-vectors and in the formulas for determining lenghts and angles. In this API the origin is defined as
The project depends on the vecmath library in the refactured version of jogamp. Unfortunately there is no maven repository available. That is why you need to download the jar file manually and add it as a local depency of the project. To do this in the nebeans ide: Right-click on the depencies of the project and add the dependency manually. The group id is "org.jogamp.java3d", the artifactId is "vecmath" and the type is "jar". If the dependency is already defined right-click on the dependency to manually add the needed jar-file.\ Alternatively clone it from GitHub, update the compiler version in it's pom.xml and build it.
Clone and checkout
and build those projects to have them available in your local Maven cache.
If you want to use the the default Visualizer, you have to clone and checkout Euclid3dView and add it to your runtime dependencies.
The GA imlemenntation can be switched by project configuration. In the Maven pom.xml file there is a property <cga.impl>. If the value is set to "default" then the reference implementation corresponding to the book Dorst2007 is used. With "ganja" you can switch to an implementation with the nondegenerate metric
description | formula | grade | class |
---|---|---|---|
Point pair from two conformal points (p1, p2) | p1∧p2 | 2 | round |
(Flat) Finite-infinite point pair or Flat point from one conformal point (p) | p∧εᵢ | 2 | flat |
Circle from three ipns Points (p1, p2, p3) | p1∧p2∧p3 | 3 | round |
Line from two conformal planes (p1, p2) | p1∧p2∧εᵢ | 3 | flat |
Sphere from four ipns points (p1, p2, p3, p4) | p1∧p2∧p3∧p4 | 4 | round |
Plane from three ipns points (p1, p2, p3) | p1∧p2∧p3∧εᵢ | 4 | flat |
Plane between two ipns points (p1, p2) | $ (\vec{p}_1\wedge\vec{p}2)*\wedge\epsilon\infinity $ | 4 | flat |
The conformal points in the table above have to be given in inner product null space represenation.
description | formula | grade |
---|---|---|
Point from euclidian vector (x) | x+0.5x²εᵢ+ε₀ | 1 |
Sphere from conformal point (P) and radius (r) | P-0.5r²εᵢ | 1 |
Plane from euclidian normal vector (n) and distance to origin (d) | n+dεᵢ | 1 |
Circle from two conformal spheres (s1, s2) | s1∧s2 | 2 |
Line from two conformal planes (p1, p2) | p1∧p2 | 2 |
Point pair from three conformal spheres (s1, s2, s3) | s1∧s2∧s3 | 3 |
description | formula |
---|---|
Backprojection of a conformal point (P) into an euclidian vector. The formula in the first bracket normalizes the point. Then this normalized point is rejected from the minkowski plane. | (P/(P⋅εᵢ))∧E₀E₀⁻¹ |
Location of a round (X) or a tangent (X) represented in 3d coordinates | -0.5(XεᵢX)/(εᵢ⋅X)² |
Direction vector (attitude) of a dual line (L*) represented as 3d coordinates of (ε₁, ε₂, ε₃). | (L*⋅ε₀)⋅εᵢ |
Radius (r) of a conformal sphere (S) | r² = (S*)² = S*⋅S* |
Distance (d) between the the center of a conformal sphere (S) and a conformal point (P) | d² = S⋅S-2S⋅P |
description | formula |
---|---|
Matrix free implementation of the inverse | x⁻¹ = (x† x^ x˜ negate14(x)(x x† x^ x˜))/(x x† x^ x˜ negate14(x) (x x† x^ x˜)) |
name | equation | description |
---|---|---|
anticommutivity | u ∧ v = - (v ∧ u) | |
distributivity | u ∧ (v + w) = u ∧ v + u ∧ w | |
associativity | u ∧ (v ∧ w) = (u ∧ v) ∧ w | |
(A ⌊ B)˜ = B˜ C∧ A˜ | ||
A ∧ B * C = A * (B ⌋ C) | ||
C * (B ∧ A) = (C ⌊ B) * A | ||
intersection | (A ∨ B)* = B* ∧ A* | Intersection = outer product in the ipns representation; B* ∧ A* means computing the union of everything which is not B and everything that is not A. The dual of that must be what have A and B in common. |
projection | (A ⌋ B) B⁻¹ | Projection of A onto B |
rejection | (A ∧ B) B⁻¹ | Rejection of A from B |
duality | (A ⌋ B)* = A ∧ B* | |
A ⌋ (B ⌋ C) = (A ∧ B) ⌋ C | ||
(A ⌋ B) ⌋ C = A ∧ (B ⌋ C) | if C contains A | |
down projection | (εᵢ ∧ ε₀) ⌋ (X ∧ (εᵢ ∧ ε₀)) | extracts the pure euclidean part of the given multivector |
Determines an arbitrary point |