]> gitweb.michael.orlitzky.com - sage.d.git/commitdiff
eja: use fuzzy equality test with inexact base rings.
authorMichael Orlitzky <michael@orlitzky.com>
Mon, 9 Nov 2020 12:44:59 +0000 (07:44 -0500)
committerMichael Orlitzky <michael@orlitzky.com>
Mon, 9 Nov 2020 12:44:59 +0000 (07:44 -0500)
mjo/eja/eja_algebra.py

index 3846b83ad6d76674f9f82e5f3a662ea5a2aeea4c..7f7b1f9f1c09703a2d8f48e295b203604fa5556c 100644 (file)
@@ -296,14 +296,26 @@ class FiniteDimensionalEuclideanJordanAlgebra(CombinatorialFreeModule):
         this algebra was constructed with ``check=False`` and passed
         an invalid multiplication table.
         """
+
+        # Used to check whether or not something is zero in an inexact
+        # ring. This number is sufficient to allow the construction of
+        # QuaternionHermitianEJA(2, RDF) with check=True.
+        epsilon = 1e-16
+
         for i in range(self.dimension()):
             for j in range(self.dimension()):
                 for k in range(self.dimension()):
                     x = self.monomial(i)
                     y = self.monomial(j)
                     z = self.monomial(k)
-                    if (x*y).inner_product(z) != x.inner_product(y*z):
-                        return False
+                    diff = (x*y).inner_product(z) - x.inner_product(y*z)
+
+                    if self.base_ring().is_exact():
+                        if diff != 0:
+                            return False
+                    else:
+                        if diff.abs() > epsilon:
+                            return False
 
         return True