]> gitweb.michael.orlitzky.com - sage.d.git/blobdiff - mjo/hurwitz.py
mjo/**/*.py: drop obsolete set_random_seed().
[sage.d.git] / mjo / hurwitz.py
index e2800345cf550b3f6970fa62592c0d43a1e85531..ff84b51f8e3923ef7a8a93cb7d42ea1cfe6e3d32 100644 (file)
@@ -23,7 +23,6 @@ class Octonion(IndexedFreeModuleElement):
 
         Conjugating twice gets you the original element::
 
-            sage: set_random_seed()
             sage: O = Octonions()
             sage: x = O.random_element()
             sage: x.conjugate().conjugate() == x
@@ -58,7 +57,6 @@ class Octonion(IndexedFreeModuleElement):
 
         This method is idempotent::
 
-            sage: set_random_seed()
             sage: O = Octonions()
             sage: x = O.random_element()
             sage: x.real().real() == x.real()
@@ -91,7 +89,6 @@ class Octonion(IndexedFreeModuleElement):
 
         This method is idempotent::
 
-            sage: set_random_seed()
             sage: O = Octonions()
             sage: x = O.random_element()
             sage: x.imag().imag() == x.imag()
@@ -121,7 +118,6 @@ class Octonion(IndexedFreeModuleElement):
 
         The norm is nonnegative and belongs to the base field::
 
-            sage: set_random_seed()
             sage: O = Octonions()
             sage: n = O.random_element().norm()
             sage: n >= 0 and n in O.base_ring()
@@ -129,7 +125,6 @@ class Octonion(IndexedFreeModuleElement):
 
         The norm is homogeneous::
 
-            sage: set_random_seed()
             sage: O = Octonions()
             sage: x = O.random_element()
             sage: alpha = O.base_ring().random_element()
@@ -167,7 +162,6 @@ class Octonion(IndexedFreeModuleElement):
 
         TESTS::
 
-            sage: set_random_seed()
             sage: O = Octonions()
             sage: x = O.random_element()
             sage: x.is_zero() or ( x*x.inverse() == O.one() )
@@ -241,7 +235,6 @@ class Octonions(CombinatorialFreeModule):
 
         This gives the correct unit element::
 
-            sage: set_random_seed()
             sage: O = Octonions()
             sage: x = O.random_element()
             sage: x*O.one() == x and O.one()*x == x
@@ -312,19 +305,21 @@ class HurwitzMatrixAlgebraElement(MatrixAlgebraElement):
 
         SETUP::
 
-            sage: from mjo.hurwitz import HurwitzMatrixAlgebra
+            sage: from mjo.hurwitz import ComplexMatrixAlgebra
 
         EXAMPLES::
 
-            sage: A = HurwitzMatrixAlgebra(2, QQbar, ZZ)
+            sage: A = ComplexMatrixAlgebra(2, QQbar, ZZ)
             sage: M = A([ [ I,   2*I],
             ....:         [ 3*I, 4*I] ])
             sage: M.conjugate_transpose()
             +------+------+
-            | -1*I | -3*I |
+            | -I   | -3*I |
             +------+------+
             | -2*I | -4*I |
             +------+------+
+            sage: M.conjugate_transpose().to_vector()
+            (0, -1, 0, -3, 0, -2, 0, -4)
 
         """
         entries = [ [ self[j,i].conjugate()
@@ -337,16 +332,25 @@ class HurwitzMatrixAlgebraElement(MatrixAlgebraElement):
 
         SETUP::
 
-            sage: from mjo.hurwitz import HurwitzMatrixAlgebra
+            sage: from mjo.hurwitz import (ComplexMatrixAlgebra,
+            ....:                          HurwitzMatrixAlgebra)
 
         EXAMPLES::
 
-            sage: A = HurwitzMatrixAlgebra(2, QQbar, ZZ)
+            sage: A = ComplexMatrixAlgebra(2, QQbar, ZZ)
             sage: M = A([ [ 0,I],
             ....:         [-I,0] ])
             sage: M.is_hermitian()
             True
 
+        ::
+
+            sage: A = HurwitzMatrixAlgebra(2, AA, QQ)
+            sage: M = A([ [1, 1],
+            ....:         [1, 1] ])
+            sage: M.is_hermitian()
+            True
+
         """
         # A tiny bit faster than checking equality with the conjugate
         # transpose.
@@ -518,7 +522,6 @@ class OctonionMatrixAlgebra(HurwitzMatrixAlgebra):
 
     TESTS::
 
-        sage: set_random_seed()
         sage: A = OctonionMatrixAlgebra(ZZ.random_element(10))
         sage: x = A.random_element()
         sage: x*A.one() == x and A.one()*x == x
@@ -611,7 +614,6 @@ class QuaternionMatrixAlgebra(HurwitzMatrixAlgebra):
 
     TESTS::
 
-        sage: set_random_seed()
         sage: A = QuaternionMatrixAlgebra(ZZ.random_element(10))
         sage: x = A.random_element()
         sage: x*A.one() == x and A.one()*x == x
@@ -627,6 +629,32 @@ class QuaternionMatrixAlgebra(HurwitzMatrixAlgebra):
             entry_algebra = QuaternionAlgebra(scalars,-1,-1)
         super().__init__(n, entry_algebra, scalars, **kwargs)
 
+    def _entry_algebra_element_to_vector(self, entry):
+        r"""
+
+        SETUP::
+
+            sage: from mjo.hurwitz import QuaternionMatrixAlgebra
+
+        EXAMPLES::
+
+            sage: A = QuaternionMatrixAlgebra(2)
+            sage: u = A.entry_algebra().one()
+            sage: A._entry_algebra_element_to_vector(u)
+            (1, 0, 0, 0)
+            sage: i,j,k = A.entry_algebra().gens()
+            sage: A._entry_algebra_element_to_vector(i)
+            (0, 1, 0, 0)
+            sage: A._entry_algebra_element_to_vector(j)
+            (0, 0, 1, 0)
+            sage: A._entry_algebra_element_to_vector(k)
+            (0, 0, 0, 1)
+
+        """
+        from sage.modules.free_module import FreeModule
+        d = len(self.entry_algebra_gens())
+        V = FreeModule(self.entry_algebra().base_ring(), d)
+        return V(entry.coefficient_tuple())
 
 class ComplexMatrixAlgebra(HurwitzMatrixAlgebra):
     r"""
@@ -678,11 +706,11 @@ class ComplexMatrixAlgebra(HurwitzMatrixAlgebra):
         sage: (I,) = A.entry_algebra().gens()
         sage: A([ [1+I, 1],
         ....:     [-1, -I] ])
-        +-------+----+
-        | I + 1 | 1  |
-        +-------+----+
-        | -1    | -I |
-        +-------+----+
+        +---------+------+
+        | 1 + 1*I | 1    |
+        +---------+------+
+        | -1      | -1*I |
+        +---------+------+
 
     ::
 
@@ -695,7 +723,6 @@ class ComplexMatrixAlgebra(HurwitzMatrixAlgebra):
 
     TESTS::
 
-        sage: set_random_seed()
         sage: A = ComplexMatrixAlgebra(ZZ.random_element(10))
         sage: x = A.random_element()
         sage: x*A.one() == x and A.one()*x == x
@@ -707,3 +734,24 @@ class ComplexMatrixAlgebra(HurwitzMatrixAlgebra):
             from sage.rings.all import QQbar
             entry_algebra = QQbar
         super().__init__(n, entry_algebra, scalars, **kwargs)
+
+    def _entry_algebra_element_to_vector(self, entry):
+        r"""
+
+        SETUP::
+
+            sage: from mjo.hurwitz import ComplexMatrixAlgebra
+
+        EXAMPLES::
+
+            sage: A = ComplexMatrixAlgebra(2, QQbar, QQ)
+            sage: A._entry_algebra_element_to_vector(QQbar(1))
+            (1, 0)
+            sage: A._entry_algebra_element_to_vector(QQbar(I))
+            (0, 1)
+
+        """
+        from sage.modules.free_module import FreeModule
+        d = len(self.entry_algebra_gens())
+        V = FreeModule(self.entry_algebra().base_ring(), d)
+        return V((entry.real(), entry.imag()))