login  home  contents  what's new  discussion  bug reports     help  links  subscribe  changes  refresh  edit

Quaternion Algebra Is Frobenius In Many Ways

Linear operators over a 4-dimensional vector space representing quaternion algebra

Ref:

We need the Axiom LinearOperator library.

fricas
)library CARTEN ARITY CMONAL CPROP CLOP CALEY
CartesianTensor is now explicitly exposed in frame initial CartesianTensor will be automatically loaded when needed from /var/aw/var/LatexWiki/CARTEN.NRLIB/CARTEN Arity is now explicitly exposed in frame initial Arity will be automatically loaded when needed from /var/aw/var/LatexWiki/ARITY.NRLIB/ARITY ClosedMonoidal is now explicitly exposed in frame initial ClosedMonoidal will be automatically loaded when needed from /var/aw/var/LatexWiki/CMONAL.NRLIB/CMONAL ClosedProp is now explicitly exposed in frame initial ClosedProp will be automatically loaded when needed from /var/aw/var/LatexWiki/CPROP.NRLIB/CPROP ClosedLinearOperator is now explicitly exposed in frame initial ClosedLinearOperator will be automatically loaded when needed from /var/aw/var/LatexWiki/CLOP.NRLIB/CLOP CaleyDickson is now explicitly exposed in frame initial CaleyDickson will be automatically loaded when needed from /var/aw/var/LatexWiki/CALEY.NRLIB/CALEY

Use the following macros for convenient notation

fricas
-- summation
macro Σ(x,i,n)==reduce(+,[x for i in n])
Type: Void
fricas
-- subscript and superscripts
macro sb == subscript
Type: Void
fricas
macro sp == superscript
Type: Void

ℒ is the domain of 4-dimensional linear operators over the rational functions ℚ (Expression Integer), i.e. ratio of polynomials with integer coefficients.

fricas
dim:=4

\label{eq1}4(1)
Type: PositiveInteger?
fricas
macro ℂ == CaleyDickson
Type: Void
fricas
macro ℚ == Expression Integer
Type: Void
fricas
ℒ := ClosedLinearOperator(OVAR ['1,'i,'j,'k], ℚ)

\label{eq2}\hbox{\axiomType{ClosedLinearOperator}\ } (\hbox{\axiomType{OrderedVariableList}\ } ([ 1, i , j , k ]) , \hbox{\axiomType{Expression}\ } (\hbox{\axiomType{Integer}\ }))(2)
Type: Type
fricas
ⅇ:List ℒ      := basisOut()

\label{eq3}\left[{|_{\  1}}, \:{|_{\  i}}, \:{|_{\  j}}, \:{|_{\  k}}\right](3)
Type: List(ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer)))
fricas
ⅆ:List ℒ      := basisIn()

\label{eq4}\left[{|^{\  1}}, \:{|^{\  i}}, \:{|^{\  j}}, \:{|^{\  k}}\right](4)
Type: List(ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer)))
fricas
I:ℒ:=[1]   -- identity for composition

\label{eq5}{|_{\  1}^{\  1}}+{|_{\  i}^{\  i}}+{|_{\  j}^{\  j}}+{|_{\  k}^{\  k}}(5)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
X:ℒ:=[2,1] -- twist

\label{eq6}\begin{array}{@{}l}
\displaystyle
{|_{\  1 \  1}^{\  1 \  1}}+{|_{\  i \  1}^{\  1 \  i}}+{|_{\  j \  1}^{\  1 \  j}}+{|_{\  k \  1}^{\  1 \  k}}+{|_{\  1 \  i}^{\  i \  1}}+ 
\
\
\displaystyle
{|_{\  i \  i}^{\  i \  i}}+{|_{\  j \  i}^{\  i \  j}}+{|_{\  k \  i}^{\  i \  k}}+{|_{\  1 \  j}^{\  j \  1}}+{|_{\  i \  j}^{\  j \  i}}+{|_{\  j \  j}^{\  j \  j}}+ 
\
\
\displaystyle
{|_{\  k \  j}^{\  j \  k}}+{|_{\  1 \  k}^{\  k \  1}}+{|_{\  i \  k}^{\  k \  i}}+{|_{\  j \  k}^{\  k \  j}}+{|_{\  k \  k}^{\  k \  k}}
(6)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
V:ℒ:=ev(1) -- evaluation

\label{eq7}{|^{\  1 \  1}}+{|^{\  i \  i}}+{|^{\  j \  j}}+{|^{\  k \  k}}(7)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
Λ:ℒ:=co(1) -- co-evaluation

\label{eq8}{|_{\  1 \  1}}+{|_{\  i \  i}}+{|_{\  j \  j}}+{|_{\  k \  k}}(8)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
equate(eq)==map((x,y)+->(x=y),ravel lhs eq, ravel rhs eq);
Type: Void

Now generate structure constants for Quaternion Algebra

The basis consists of the real and imaginary units. We use quaternion multiplication to form the "multiplication table" as a matrix. Then the structure constants can be obtained by dividing each matrix entry by the list of basis vectors.

Split-complex and co-quaternions can be specified by Caley-Dickson parameters (i2, j2)

fricas
i2:=sp('i,[2])

\label{eq9}i^{2}(9)
Type: Symbol
fricas
--i2:= -1  -- complex
j2:=sp('j,[2])

\label{eq10}j^{2}(10)
Type: Symbol
fricas
--j2:= -1  -- quaternion
k2:=-i2*j2;
Type: Polynomial(Integer)
fricas
QQ := ℂ(ℂ(ℚ,'i,-i2),'j,-j2);
Type: Type

Basis: Each B.i is a quaternion number

fricas
B:List QQ := map(x +-> hyper x,1$SQMATRIX(dim,ℚ)::List List ℚ)

\label{eq11}\left[ 1, \: i , \: j , \:{ij}\right](11)
Type: List(CaleyDickson(CaleyDickson(Expression(Integer),i,-(i[;2])),j,-(j[;2])))
fricas
-- Multiplication table:
M:Matrix QQ := matrix [[B.i*B.j for i in 1..dim] for j in 1..dim]

\label{eq12}\left[ 
\begin{array}{cccc}
1 & i & j &{ij}
\
i &{i^{2}}& -{ij}&{-{i^{2}}j}
\
j &{ij}&{j^{2}}&{{j^{2}}i}
\
{ij}&{{i^{2}}j}&{-{j^{2}}i}& -{{i^{2}}\ {j^{2}}}
(12)
Type: Matrix(CaleyDickson(CaleyDickson(Expression(Integer),i,-(i[;2])),j,-(j[;2])))
fricas
-- Function to divide the matrix entries by a basis element
S(y) == map(x +-> real real(x/y),M)
Type: Void
fricas
-- The result is a nested list
ѕ :=map(S,B)::List List List ℚ
fricas
Compiling function S with type CaleyDickson(CaleyDickson(Expression(
      Integer),i,-(i[;2])),j,-(j[;2])) -> Matrix(Expression(Integer))

\label{eq13}\begin{array}{@{}l}
\displaystyle
\left[{\left[{\left[ 1, \: 0, \: 0, \: 0 \right]}, \:{\left[ 0, \:{i^{2}}, \: 0, \: 0 \right]}, \:{\left[ 0, \: 0, \:{j^{2}}, \: 0 \right]}, \:{\left[ 0, \: 0, \: 0, \: -{{i^{2}}\ {j^{2}}}\right]}\right]}, \: \right.
\
\
\displaystyle
\left.{\left[{\left[ 0, \:{{i^{2}}\over{\overline{i^{2}}}}, \: 0, \: 0 \right]}, \:{\left[{{i^{2}}\over{\overline{i^{2}}}}, \: 0, \: 0, \: 0 \right]}, \:{\left[ 0, \: 0, \: 0, \:{{{i^{2}}\ {j^{2}}}\over{\overline{i^{2}}}}\right]}, \:{\left[ 0, \: 0, \: -{{{i^{2}}\ {j^{2}}}\over{\overline{i^{2}}}}, \: 0 \right]}\right]}, \: \right.
\
\
\displaystyle
\left.{\left[{\left[ 0, \: 0, \:{{j^{2}}\over{\overline{j^{2}}}}, \: 0 \right]}, \:{\left[ 0, \: 0, \: 0, \: -{{{i^{2}}\ {j^{2}}}\over{\overline{j^{2}}}}\right]}, \:{\left[{{j^{2}}\over{\overline{j^{2}}}}, \: 0, \: 0, \: 0 \right]}, \:{\left[ 0, \:{{{i^{2}}\ {j^{2}}}\over{\overline{j^{2}}}}, \: 0, \: 0 \right]}\right]}, \right.
\
\
\displaystyle
\left.\:{\left[{\left[ 0, \: 0, \: 0, \: 1 \right]}, \:{\left[ 0, \: 0, \: - 1, \: 0 \right]}, \:{\left[ 0, \: 1, \: 0, \: 0 \right]}, \:{\left[ 1, \: 0, \: 0, \: 0 \right]}\right]}\right] (13)
Type: List(List(List(Expression(Integer))))
fricas
-- structure constants form a tensor operator
Y := Σ(Σ(Σ(ѕ(i)(k)(j)*ⅇ.i*ⅆ.j*ⅆ.k, i,1..dim), j,1..dim), k,1..dim)

\label{eq14}\begin{array}{@{}l}
\displaystyle
{|_{\  1}^{\  1 \  1}}+{{{i^{2}}\over{\overline{i^{2}}}}\ {|_{\  i}^{\  1 \  i}}}+{{{j^{2}}\over{\overline{j^{2}}}}\ {|_{\  j}^{\  1 \  j}}}+{|_{\  k}^{\  1 \  k}}+{{{i^{2}}\over{\overline{i^{2}}}}\ {|_{\  i}^{\  i \  1}}}+ 
\
\
\displaystyle
{{i^{2}}\ {|_{\  1}^{\  i \  i}}}+{|_{\  k}^{\  i \  j}}+{{{{i^{2}}\ {j^{2}}}\over{\overline{j^{2}}}}\ {|_{\  j}^{\  i \  k}}}+{{{j^{2}}\over{\overline{j^{2}}}}\ {|_{\  j}^{\  j \  1}}}-{|_{\  k}^{\  j \  i}}+ 
\
\
\displaystyle
{{j^{2}}\ {|_{\  1}^{\  j \  j}}}-{{{{i^{2}}\ {j^{2}}}\over{\overline{i^{2}}}}\ {|_{\  i}^{\  j \  k}}}+{|_{\  k}^{\  k \  1}}-{{{{i^{2}}\ {j^{2}}}\over{\overline{j^{2}}}}\ {|_{\  j}^{\  k \  i}}}+ 
\
\
\displaystyle
{{{{i^{2}}\ {j^{2}}}\over{\overline{i^{2}}}}\ {|_{\  i}^{\  k \  j}}}-{{i^{2}}\ {j^{2}}\ {|_{\  1}^{\  k \  k}}}
(14)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
arity Y

\label{eq15}{{+}^{2}}\over +(15)
Type: ClosedProp?(ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer)))
fricas
matrix [[(ⅇ.i*ⅇ.j)/Y for i in 1..dim] for j in 1..dim]

\label{eq16}\left[ 
\begin{array}{cccc}
{|_{\  1}}&{{{i^{2}}\over{\overline{i^{2}}}}\ {|_{\  i}}}&{{{j^{2}}\over{\overline{j^{2}}}}\ {|_{\  j}}}&{|_{\  k}}
\
{{{i^{2}}\over{\overline{i^{2}}}}\ {|_{\  i}}}&{{i^{2}}\ {|_{\  1}}}& -{|_{\  k}}& -{{{{i^{2}}\ {j^{2}}}\over{\overline{j^{2}}}}\ {|_{\  j}}}
\
{{{j^{2}}\over{\overline{j^{2}}}}\ {|_{\  j}}}&{|_{\  k}}&{{j^{2}}\ {|_{\  1}}}&{{{{i^{2}}\ {j^{2}}}\over{\overline{i^{2}}}}\ {|_{\  i}}}
\
{|_{\  k}}&{{{{i^{2}}\ {j^{2}}}\over{\overline{j^{2}}}}\ {|_{\  j}}}& -{{{{i^{2}}\ {j^{2}}}\over{\overline{i^{2}}}}\ {|_{\  i}}}& -{{i^{2}}\ {j^{2}}\ {|_{\  1}}}
(16)
Type: Matrix(ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer)))

Units

fricas
q:=ⅇ.1; i:=ⅇ.2; j:=ⅇ.3; k:=ⅇ.4;
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))

Multiplication of arbitrary quaternions a and b

fricas
a:=Σ(sb('a,[i])*ⅇ.i, i,1..dim)

\label{eq17}{{a_{1}}\ {|_{\  1}}}+{{a_{2}}\ {|_{\  i}}}+{{a_{3}}\ {|_{\  j}}}+{{a_{4}}\ {|_{\  k}}}(17)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
b:=Σ(sb('b,[i])*ⅇ.i, i,1..dim)

\label{eq18}{{b_{1}}\ {|_{\  1}}}+{{b_{2}}\ {|_{\  i}}}+{{b_{3}}\ {|_{\  j}}}+{{b_{4}}\ {|_{\  k}}}(18)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
(a*b)/Y

\label{eq19}\begin{array}{@{}l}
\displaystyle
{{\left(-{{i^{2}}\ {j^{2}}\ {a_{4}}\ {b_{4}}}+{{j^{2}}\ {a_{3}}\ {b_{3}}}+{{i^{2}}\ {a_{2}}\ {b_{2}}}+{{a_{1}}\ {b_{1}}}\right)}\ {|_{\  1}}}+ 
\
\
\displaystyle
{{{-{{i^{2}}\ {j^{2}}\ {a_{3}}\ {b_{4}}}+{{i^{2}}\ {j^{2}}\ {a_{4}}\ {b_{3}}}+{{i^{2}}\ {a_{1}}\ {b_{2}}}+{{i^{2}}\ {a_{2}}\ {b_{1}}}}\over{\overline{i^{2}}}}\ {|_{\  i}}}+ 
\
\
\displaystyle
{{{{{i^{2}}\ {j^{2}}\ {a_{2}}\ {b_{4}}}+{{j^{2}}\ {a_{1}}\ {b_{3}}}-{{i^{2}}\ {j^{2}}\ {a_{4}}\ {b_{2}}}+{{j^{2}}\ {a_{3}}\ {b_{1}}}}\over{\overline{j^{2}}}}\ {|_{\  j}}}+ 
\
\
\displaystyle
{{\left({{a_{1}}\ {b_{4}}}+{{a_{2}}\ {b_{3}}}-{{a_{3}}\ {b_{2}}}+{{a_{4}}\ {b_{1}}}\right)}\ {|_{\  k}}}
(19)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))

Multiplication is Associative

fricas
test(
  ( I Y ) / _
  (  Y  ) = _
  ( Y I ) / _
  (  Y  ) )

\label{eq20} \mbox{\rm false} (20)
Type: Boolean

A scalar product is denoted by the (2,0)-tensor U = \{ u_{ij} \}

fricas
U:=Σ(Σ(script('u,[[],[i,j]])*ⅆ.i*ⅆ.j, i,1..dim), j,1..dim)

\label{eq21}\begin{array}{@{}l}
\displaystyle
{{u^{1, \: 1}}\ {|^{\  1 \  1}}}+{{u^{1, \: 2}}\ {|^{\  1 \  i}}}+{{u^{1, \: 3}}\ {|^{\  1 \  j}}}+{{u^{1, \: 4}}\ {|^{\  1 \  k}}}+ 
\
\
\displaystyle
{{u^{2, \: 1}}\ {|^{\  i \  1}}}+{{u^{2, \: 2}}\ {|^{\  i \  i}}}+{{u^{2, \: 3}}\ {|^{\  i \  j}}}+{{u^{2, \: 4}}\ {|^{\  i \  k}}}+{{u^{3, \: 1}}\ {|^{\  j \  1}}}+ 
\
\
\displaystyle
{{u^{3, \: 2}}\ {|^{\  j \  i}}}+{{u^{3, \: 3}}\ {|^{\  j \  j}}}+{{u^{3, \: 4}}\ {|^{\  j \  k}}}+{{u^{4, \: 1}}\ {|^{\  k \  1}}}+ 
\
\
\displaystyle
{{u^{4, \: 2}}\ {|^{\  k \  i}}}+{{u^{4, \: 3}}\ {|^{\  k \  j}}}+{{u^{4, \: 4}}\ {|^{\  k \  k}}}
(21)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))

Definition 1

We say that the scalar product is associative if the tensor equation holds:

    Y   =   Y
     U     U

In other words, if the (3,0)-tensor:


\scalebox{1} % Change this value to rescale the drawing.
{
\begin{pspicture}(0,-0.92)(4.82,0.92)
\psbezier[linewidth=0.04](2.2,0.9)(2.2,0.1)(2.6,0.1)(2.6,0.9)
\psline[linewidth=0.04cm](2.4,0.3)(2.4,-0.1)
\psbezier[linewidth=0.04](2.4,-0.1)(2.4,-0.9)(3.0,-0.9)(3.0,-0.1)
\psline[linewidth=0.04cm](3.0,-0.1)(3.0,0.9)
\psbezier[linewidth=0.04](4.8,0.9)(4.8,0.1)(4.4,0.1)(4.4,0.9)
\psline[linewidth=0.04cm](4.6,0.3)(4.6,-0.1)
\psbezier[linewidth=0.04](4.6,-0.1)(4.6,-0.9)(4.0,-0.9)(4.0,-0.1)
\psline[linewidth=0.04cm](4.0,-0.1)(4.0,0.9)
\usefont{T1}{ptm}{m}{n}
\rput(3.4948437,0.205){-}
\psline[linewidth=0.04cm](0.6,-0.7)(0.6,0.9)
\psbezier[linewidth=0.04](0.0,-0.1)(0.0,-0.9)(1.2,-0.9)(1.2,-0.1)
\psline[linewidth=0.04cm](0.0,-0.1)(0.0,0.9)
\psline[linewidth=0.04cm](1.2,-0.1)(1.2,0.9)
\usefont{T1}{ptm}{m}{n}
\rput(1.6948438,0.205){=}
\end{pspicture} 
}
 


\label{eq22}
  \Phi = \{ \phi^{ijk} = {y^e}_{ij} u_{ek} - u_{ie} {y_e}^{jk} \}
  (22)
(three-point function) is zero.

Using the LinearOperator domain in Axiom and some carefully chosen symbols we can easily enter expressions that are both readable and interpreted by Axiom as "graphical calculus" diagrams describing complex products and compositions of linear operators.

fricas
ω:ℒ :=
     (    Y I    )  /
           U        -
     (    I Y    )  /
           U

\label{eq23}\begin{array}{@{}l}
\displaystyle
{{{{{u^{1, \: 2}}\ {\overline{i^{2}}}}-{{i^{2}}\ {u^{1, \: 2}}}}\over{\overline{i^{2}}}}\ {|^{\  1 \  1 \  i}}}+{{{{{u^{1, \: 3}}\ {\overline{j^{2}}}}-{{j^{2}}\ {u^{1, \: 3}}}}\over{\overline{j^{2}}}}\ {|^{\  1 \  1 \  j}}}+ 
\
\
\displaystyle
{{{{{i^{2}}\ {u^{2, \: 1}}}-{{i^{2}}\ {u^{1, \: 2}}}}\over{\overline{i^{2}}}}\ {|^{\  1 \  i \  1}}}+{{{-{{i^{2}}\ {u^{1, \: 1}}\ {\overline{i^{2}}}}+{{i^{2}}\ {u^{2, \: 2}}}}\over{\overline{i^{2}}}}\ {|^{\  1 \  i \  i}}}+ 
\
\
\displaystyle
{{{-{{u^{1, \: 4}}\ {\overline{i^{2}}}}+{{i^{2}}\ {u^{2, \: 3}}}}\over{\overline{i^{2}}}}\ {|^{\  1 \  i \  j}}}+ 
\
\
\displaystyle
{{{{{i^{2}}\ {u^{2, \: 4}}\ {\overline{j^{2}}}}-{{i^{2}}\ {j^{2}}\ {u^{1, \: 3}}\ {\overline{i^{2}}}}}\over{{\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|^{\  1 \  i \  k}}}+ 
\
\
\displaystyle
{{{{{j^{2}}\ {u^{3, \: 1}}}-{{j^{2}}\ {u^{1, \: 3}}}}\over{\overline{j^{2}}}}\ {|^{\  1 \  j \  1}}}+{{{{{u^{1, \: 4}}\ {\overline{j^{2}}}}+{{j^{2}}\ {u^{3, \: 2}}}}\over{\overline{j^{2}}}}\ {|^{\  1 \  j \  i}}}+ 
\
\
\displaystyle
{{{-{{j^{2}}\ {u^{1, \: 1}}\ {\overline{j^{2}}}}+{{j^{2}}\ {u^{3, \: 3}}}}\over{\overline{j^{2}}}}\ {|^{\  1 \  j \  j}}}+ \
\
\displaystyle
{{{{{i^{2}}\ {j^{2}}\ {u^{1, \: 2}}\ {\overline{j^{2}}}}+{{j^{2}}\ {u^{3, \: 4}}\ {\overline{i^{2}}}}}\over{{\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|^{\  1 \  j \  k}}}+{{\left({u^{4, \: 1}}-{u^{1, \: 4}}\right)}\ {|^{\  1 \  k \  1}}}+ 
\
\
\displaystyle
{{{{{u^{4, \: 2}}\ {\overline{j^{2}}}}+{{i^{2}}\ {j^{2}}\ {u^{1, \: 3}}}}\over{\overline{j^{2}}}}\ {|^{\  1 \  k \  i}}}+{{{{{u^{4, \: 3}}\ {\overline{i^{2}}}}-{{i^{2}}\ {j^{2}}\ {u^{1, \: 2}}}}\over{\overline{i^{2}}}}\ {|^{\  1 \  k \  j}}}+ 
\
\
\displaystyle
{{\left({u^{4, \: 4}}+{{i^{2}}\ {j^{2}}\ {u^{1, \: 1}}}\right)}\ {|^{\  1 \  k \  k}}}+{{{-{{u^{2, \: 1}}\ {\overline{i^{2}}}}+{{i^{2}}\ {u^{2, \: 1}}}}\over{\overline{i^{2}}}}\ {|^{\  i \  1 \  1}}}+ 
\
\
\displaystyle
{{{{{i^{2}}\ {u^{2, \: 3}}\ {\overline{j^{2}}}}-{{j^{2}}\ {u^{2, \: 3}}\ {\overline{i^{2}}}}}\over{{\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|^{\  i \  1 \  j}}}+ 
\
\
\displaystyle
{{{-{{u^{2, \: 4}}\ {\overline{i^{2}}}}+{{i^{2}}\ {u^{2, \: 4}}}}\over{\overline{i^{2}}}}\ {|^{\  i \  1 \  k}}}+{{{{{i^{2}}\ {u^{1, \: 1}}\ {\overline{i^{2}}}}-{{i^{2}}\ {u^{2, \: 2}}}}\over{\overline{i^{2}}}}\ {|^{\  i \  i \  1}}}+ 
\
\
\displaystyle
{{\left(-{{i^{2}}\ {u^{2, \: 1}}}+{{i^{2}}\ {u^{1, \: 2}}}\right)}\ {|^{\  i \  i \  i}}}+{{\left(-{u^{2, \: 4}}+{{i^{2}}\ {u^{1, \: 3}}}\right)}\ {|^{\  i \  i \  j}}}+ 
\
\
\displaystyle
{{{{{i^{2}}\ {u^{1, \: 4}}\ {\overline{j^{2}}}}-{{i^{2}}\ {j^{2}}\ {u^{2, \: 3}}}}\over{\overline{j^{2}}}}\ {|^{\  i \  i \  k}}}+{{{{{u^{4, \: 1}}\ {\overline{j^{2}}}}-{{j^{2}}\ {u^{2, \: 3}}}}\over{\overline{j^{2}}}}\ {|^{\  i \  j \  1}}}+ 
\
\
\displaystyle
{{\left({u^{4, \: 2}}+{u^{2, \: 4}}\right)}\ {|^{\  i \  j \  i}}}+{{\left({u^{4, \: 3}}-{{j^{2}}\ {u^{2, \: 1}}}\right)}\ {|^{\  i \  j \  j}}}+ 
\
\
\displaystyle
{{{{{u^{4, \: 4}}\ {\overline{i^{2}}}}+{{i^{2}}\ {j^{2}}\ {u^{2, \: 2}}}}\over{\overline{i^{2}}}}\ {|^{\  i \  j \  k}}}+ \
\
\displaystyle
{{{-{{u^{2, \: 4}}\ {\overline{j^{2}}}}+{{i^{2}}\ {j^{2}}\ {u^{3, \: 1}}}}\over{\overline{j^{2}}}}\ {|^{\  i \  k \  1}}}+ \
\
\displaystyle
{{{{{i^{2}}\ {j^{2}}\ {u^{3, \: 2}}}+{{i^{2}}\ {j^{2}}\ {u^{2, \: 3}}}}\over{\overline{j^{2}}}}\ {|^{\  i \  k \  i}}}+ 
\
\
\displaystyle
{{{-{{i^{2}}\ {j^{2}}\ {u^{2, \: 2}}\ {\overline{j^{2}}}}+{{i^{2}}\ {j^{2}}\ {u^{3, \: 3}}\ {\overline{i^{2}}}}}\over{{\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|^{\  i \  k \  j}}}+ 
\
\
\displaystyle
{{{{{i^{2}}\ {j^{2}}\ {u^{2, \: 1}}\ {\overline{j^{2}}}}+{{i^{2}}\ {j^{2}}\ {u^{3, \: 4}}}}\over{\overline{j^{2}}}}\ {|^{\  i \  k \  k}}}+ 
\
\
\displaystyle
{{{-{{u^{3, \: 1}}\ {\overline{j^{2}}}}+{{j^{2}}\ {u^{3, \: 1}}}}\over{\overline{j^{2}}}}\ {|^{\  j \  1 \  1}}}+ 
\
\
\displaystyle
{{{-{{i^{2}}\ {u^{3, \: 2}}\ {\overline{j^{2}}}}+{{j^{2}}\ {u^{3, \: 2}}\ {\overline{i^{2}}}}}\over{{\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|^{\  j \  1 \  i}}}+ 
\
\
\displaystyle
{{{-{{u^{3, \: 4}}\ {\overline{j^{2}}}}+{{j^{2}}\ {u^{3, \: 4}}}}\over{\overline{j^{2}}}}\ {|^{\  j \  1 \  k}}}+{{{-{{u^{4, \: 1}}\ {\overline{i^{2}}}}-{{i^{2}}\ {u^{3, \: 2}}}}\over{\overline{i^{2}}}}\ {|^{\  j \  i \  1}}}+ 
\
\
\displaystyle
{{\left(-{u^{4, \: 2}}-{{i^{2}}\ {u^{3, \: 1}}}\right)}\ {|^{\  j \  i \  i}}}+{{\left(-{u^{4, \: 3}}-{u^{3, \: 4}}\right)}\ {|^{\  j \  i \  j}}}+ 
\
\
\displaystyle
{{{-{{u^{4, \: 4}}\ {\overline{j^{2}}}}-{{i^{2}}\ {j^{2}}\ {u^{3, \: 3}}}}\over{\overline{j^{2}}}}\ {|^{\  j \  i \  k}}}+ \
\
\displaystyle
{{{{{j^{2}}\ {u^{1, \: 1}}\ {\overline{j^{2}}}}-{{j^{2}}\ {u^{3, \: 3}}}}\over{\overline{j^{2}}}}\ {|^{\  j \  j \  1}}}+{{\left({u^{3, \: 4}}+{{j^{2}}\ {u^{1, \: 2}}}\right)}\ {|^{\  j \  j \  i}}}+ 
\
\
\displaystyle
{{\left(-{{j^{2}}\ {u^{3, \: 1}}}+{{j^{2}}\ {u^{1, \: 3}}}\right)}\ {|^{\  j \  j \  j}}}+ 
\
\
\displaystyle
{{{{{j^{2}}\ {u^{1, \: 4}}\ {\overline{i^{2}}}}+{{i^{2}}\ {j^{2}}\ {u^{3, \: 2}}}}\over{\overline{i^{2}}}}\ {|^{\  j \  j \  k}}}+ 
\
\
\displaystyle
{{{-{{u^{3, \: 4}}\ {\overline{i^{2}}}}-{{i^{2}}\ {j^{2}}\ {u^{2, \: 1}}}}\over{\overline{i^{2}}}}\ {|^{\  j \  k \  1}}}+ \
\
\displaystyle
{{{-{{i^{2}}\ {j^{2}}\ {u^{2, \: 2}}\ {\overline{j^{2}}}}+{{i^{2}}\ {j^{2}}\ {u^{3, \: 3}}\ {\overline{i^{2}}}}}\over{{\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|^{\  j \  k \  i}}}+ 
\
\
\displaystyle
{{{-{{i^{2}}\ {j^{2}}\ {u^{3, \: 2}}}-{{i^{2}}\ {j^{2}}\ {u^{2, \: 3}}}}\over{\overline{i^{2}}}}\ {|^{\  j \  k \  j}}}+ 
\
\
\displaystyle
{{{{{i^{2}}\ {j^{2}}\ {u^{3, \: 1}}\ {\overline{i^{2}}}}-{{i^{2}}\ {j^{2}}\ {u^{2, \: 4}}}}\over{\overline{i^{2}}}}\ {|^{\  j \  k \  k}}}+ 
\
\
\displaystyle
{{{{{u^{4, \: 2}}\ {\overline{i^{2}}}}-{{i^{2}}\ {u^{4, \: 2}}}}\over{\overline{i^{2}}}}\ {|^{\  k \  1 \  i}}}+{{{{{u^{4, \: 3}}\ {\overline{j^{2}}}}-{{j^{2}}\ {u^{4, \: 3}}}}\over{\overline{j^{2}}}}\ {|^{\  k \  1 \  j}}}+ 
\
\
\displaystyle
{{{-{{i^{2}}\ {u^{4, \: 2}}\ {\overline{j^{2}}}}-{{i^{2}}\ {j^{2}}\ {u^{3, \: 1}}\ {\overline{i^{2}}}}}\over{{\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|^{\  k \  i \  1}}}+ 
\
\
\displaystyle
{{{-{{i^{2}}\ {u^{4, \: 1}}\ {\overline{j^{2}}}}-{{i^{2}}\ {j^{2}}\ {u^{3, \: 2}}}}\over{\overline{j^{2}}}}\ {|^{\  k \  i \  i}}}+ 
\
\
\displaystyle
{{{-{{u^{4, \: 4}}\ {\overline{j^{2}}}}-{{i^{2}}\ {j^{2}}\ {u^{3, \: 3}}}}\over{\overline{j^{2}}}}\ {|^{\  k \  i \  j}}}+ \
\
\displaystyle
{{{-{{i^{2}}\ {j^{2}}\ {u^{4, \: 3}}}-{{i^{2}}\ {j^{2}}\ {u^{3, \: 4}}}}\over{\overline{j^{2}}}}\ {|^{\  k \  i \  k}}}+ 
\
\
\displaystyle
{{{{{i^{2}}\ {j^{2}}\ {u^{2, \: 1}}\ {\overline{j^{2}}}}-{{j^{2}}\ {u^{4, \: 3}}\ {\overline{i^{2}}}}}\over{{\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|^{\  k \  j \  1}}}+ 
\
\
\displaystyle
{{{{{u^{4, \: 4}}\ {\overline{i^{2}}}}+{{i^{2}}\ {j^{2}}\ {u^{2, \: 2}}}}\over{\overline{i^{2}}}}\ {|^{\  k \  j \  i}}}+ \
\
\displaystyle
{{{-{{j^{2}}\ {u^{4, \: 1}}\ {\overline{i^{2}}}}+{{i^{2}}\ {j^{2}}\ {u^{2, \: 3}}}}\over{\overline{i^{2}}}}\ {|^{\  k \  j \  j}}}+ 
\
\
\displaystyle
{{{{{i^{2}}\ {j^{2}}\ {u^{4, \: 2}}}+{{i^{2}}\ {j^{2}}\ {u^{2, \: 4}}}}\over{\overline{i^{2}}}}\ {|^{\  k \  j \  k}}}+ 
\
\
\displaystyle
{{\left(-{u^{4, \: 4}}-{{i^{2}}\ {j^{2}}\ {u^{1, \: 1}}}\right)}\ {|^{\  k \  k \  1}}}+ 
\
\
\displaystyle
{{{-{{i^{2}}\ {j^{2}}\ {u^{1, \: 2}}\ {\overline{j^{2}}}}+{{i^{2}}\ {j^{2}}\ {u^{4, \: 3}}}}\over{\overline{j^{2}}}}\ {|^{\  k \  k \  i}}}+ 
\
\
\displaystyle
{{{-{{i^{2}}\ {j^{2}}\ {u^{1, \: 3}}\ {\overline{i^{2}}}}-{{i^{2}}\ {j^{2}}\ {u^{4, \: 2}}}}\over{\overline{i^{2}}}}\ {|^{\  k \  k \  j}}}+ 
\
\
\displaystyle
{{\left({{i^{2}}\ {j^{2}}\ {u^{4, \: 1}}}-{{i^{2}}\ {j^{2}}\ {u^{1, \: 4}}}\right)}\ {|^{\  k \  k \  k}}}
(23)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))

Definition 2

An algebra with a non-degenerate associative scalar product is called a [Frobenius Algebra]?.

The Cartan-Killing Trace

fricas
Ú:=
   (  Y Λ  ) / _
   (   Y I ) / _
        V

\label{eq24}\begin{array}{@{}l}
\displaystyle
{{{{{\left({2 \ {\overline{i^{2}}}}+{i^{2}}\right)}\ {\overline{j^{2}}}}+{{j^{2}}\ {\overline{i^{2}}}}}\over{{\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|^{\  1 \  1}}}+ 
\
\
\displaystyle
{{{{{\left({2 \ {i^{2}}\ {\overline{i^{2}}}}+{{i^{2}}^{2}}\right)}\ {\overline{j^{2}}}}+{{i^{2}}\ {j^{2}}\ {\overline{i^{2}}}}}\over{{\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|^{\  i \  i}}}+ 
\
\
\displaystyle
{{{{{\left({2 \ {j^{2}}\ {\overline{i^{2}}}}+{{i^{2}}\ {j^{2}}}\right)}\ {\overline{j^{2}}}}+{{{j^{2}}^{2}}\ {\overline{i^{2}}}}}\over{{\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|^{\  j \  j}}}+ 
\
\
\displaystyle
{{{{{\left(-{2 \ {i^{2}}\ {j^{2}}\ {\overline{i^{2}}}}-{{{i^{2}}^{2}}\ {j^{2}}}\right)}\ {\overline{j^{2}}}}-{{i^{2}}\ {{j^{2}}^{2}}\ {\overline{i^{2}}}}}\over{{\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|^{\  k \  k}}}
(24)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
Ù:=
   (  Λ Y  ) / _
   ( I Y   ) / _
      V

\label{eq25}\begin{array}{@{}l}
\displaystyle
{{{{{\left({2 \ {\overline{i^{2}}}}+{i^{2}}\right)}\ {\overline{j^{2}}}}+{{j^{2}}\ {\overline{i^{2}}}}}\over{{\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|^{\  1 \  1}}}+ 
\
\
\displaystyle
{{{{{\left({2 \ {i^{2}}\ {\overline{i^{2}}}}+{{i^{2}}^{2}}\right)}\ {\overline{j^{2}}}}+{{i^{2}}\ {j^{2}}\ {\overline{i^{2}}}}}\over{{\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|^{\  i \  i}}}+ 
\
\
\displaystyle
{{{{{\left({2 \ {j^{2}}\ {\overline{i^{2}}}}+{{i^{2}}\ {j^{2}}}\right)}\ {\overline{j^{2}}}}+{{{j^{2}}^{2}}\ {\overline{i^{2}}}}}\over{{\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|^{\  j \  j}}}+ 
\
\
\displaystyle
{{{{{\left(-{2 \ {i^{2}}\ {j^{2}}\ {\overline{i^{2}}}}-{{{i^{2}}^{2}}\ {j^{2}}}\right)}\ {\overline{j^{2}}}}-{{i^{2}}\ {{j^{2}}^{2}}\ {\overline{i^{2}}}}}\over{{\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|^{\  k \  k}}}
(25)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
test(Ù=Ú)

\label{eq26} \mbox{\rm true} (26)
Type: Boolean

forms a non-degenerate associative scalar product for Y

fricas
Ũ := Ù

\label{eq27}\begin{array}{@{}l}
\displaystyle
{{{{{\left({2 \ {\overline{i^{2}}}}+{i^{2}}\right)}\ {\overline{j^{2}}}}+{{j^{2}}\ {\overline{i^{2}}}}}\over{{\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|^{\  1 \  1}}}+ 
\
\
\displaystyle
{{{{{\left({2 \ {i^{2}}\ {\overline{i^{2}}}}+{{i^{2}}^{2}}\right)}\ {\overline{j^{2}}}}+{{i^{2}}\ {j^{2}}\ {\overline{i^{2}}}}}\over{{\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|^{\  i \  i}}}+ 
\
\
\displaystyle
{{{{{\left({2 \ {j^{2}}\ {\overline{i^{2}}}}+{{i^{2}}\ {j^{2}}}\right)}\ {\overline{j^{2}}}}+{{{j^{2}}^{2}}\ {\overline{i^{2}}}}}\over{{\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|^{\  j \  j}}}+ 
\
\
\displaystyle
{{{{{\left(-{2 \ {i^{2}}\ {j^{2}}\ {\overline{i^{2}}}}-{{{i^{2}}^{2}}\ {j^{2}}}\right)}\ {\overline{j^{2}}}}-{{i^{2}}\ {{j^{2}}^{2}}\ {\overline{i^{2}}}}}\over{{\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|^{\  k \  k}}}
(27)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
test
     (    Y I    )  /
           Ũ        =
     (    I Y    )  /
           Ũ

\label{eq28} \mbox{\rm false} (28)
Type: Boolean
fricas
determinant [[retract((ⅇ.i * ⅇ.j)/Ũ) for j in 1..dim] for i in 1..dim]

\label{eq29}{\left(
\begin{array}{@{}l}
\displaystyle
{{\left({
\begin{array}{@{}l}
\displaystyle
-{{16}\ {{i^{2}}^{2}}\ {{j^{2}}^{2}}\ {{\overline{i^{2}}}^{4}}}-{{32}\ {{i^{2}}^{3}}\ {{j^{2}}^{2}}\ {{\overline{i^{2}}}^{3}}}- 
\
\
\displaystyle
{{24}\ {{i^{2}}^{4}}\ {{j^{2}}^{2}}\ {{\overline{i^{2}}}^{2}}}-{8 \ {{i^{2}}^{5}}\ {{j^{2}}^{2}}\ {\overline{i^{2}}}}-{{{i^{2}}^{6}}\ {{j^{2}}^{2}}}
(29)
Type: Expression(Integer)

General Solution

We may consider the problem where multiplication Y is given, and look for all associative scalar products U = U(Y)

This problem can be solved using linear algebra.

fricas
)expose MCALCFN
MultiVariableCalculusFunctions is now explicitly exposed in frame initial J := jacobian(ravel ω,concat map(variables,ravel U)::List Symbol);
Type: Matrix(Expression(Integer))
fricas
nrows(J),ncols(J)

\label{eq30}\left[{64}, \:{16}\right](30)
Type: Tuple(PositiveInteger?)

The matrix J transforms the coefficients of the tensor U into coefficients of the tensor \Phi. We are looking for the general linear family of tensors U=U(Y,p_i) such that J transforms U into \Phi=0 for any such U.

If the null space of the J matrix is not empty we can use the basis to find all non-trivial solutions for U:

fricas
Ñ:=nullSpace(J)

\label{eq31}\begin{array}{@{}l}
\displaystyle
\left[ \left[ -{1 \over{{i^{2}}\ {j^{2}}}}, \: 0, \: 0, \: 0, \: 0, \: -{{\overline{i^{2}}}\over{{i^{2}}\ {j^{2}}}}, \: 0, \: 0, \: 0, \: 0, \: -{{\overline{j^{2}}}\over{{i^{2}}\ {j^{2}}}}, \: 0, \: 0, \: 0, \: 0, \: 1 \right] \right] 
(31)
Type: List(Vector(Expression(Integer)))
fricas
ℰ:=map((x,y)+->x=y, concat
       map(variables,ravel U), entries Σ(sb('p,[i])*Ñ.i, i,1..#Ñ) )

\label{eq32}\begin{array}{@{}l}
\displaystyle
\left[{{u^{1, \: 1}}= -{{p_{1}}\over{{i^{2}}\ {j^{2}}}}}, \:{{u^{1, \: 2}}= 0}, \:{{u^{1, \: 3}}= 0}, \:{{u^{1, \: 4}}= 0}, \:{{u^{2, \: 1}}= 0}, \: \right.
\
\
\displaystyle
\left.{{u^{2, \: 2}}= -{{{p_{1}}\ {\overline{i^{2}}}}\over{{i^{2}}\ {j^{2}}}}}, \:{{u^{2, \: 3}}= 0}, \:{{u^{2, \: 4}}= 0}, \:{{u^{3, \: 1}}= 0}, \:{{u^{3, \: 2}}= 0}, \: \right.
\
\
\displaystyle
\left.{{u^{3, \: 3}}= -{{{p_{1}}\ {\overline{j^{2}}}}\over{{i^{2}}\ {j^{2}}}}}, \:{{u^{3, \: 4}}= 0}, \:{{u^{4, \: 1}}= 0}, \:{{u^{4, \: 2}}= 0}, \:{{u^{4, \: 3}}= 0}, \: \right.
\
\
\displaystyle
\left.{{u^{4, \: 4}}={p_{1}}}\right] 
(32)
Type: List(Equation(Expression(Integer)))

This defines a family of pre-Frobenius algebras:

fricas
zero? eval(ω,ℰ)

\label{eq33} \mbox{\rm true} (33)
Type: Boolean
fricas
Ų:ℒ := eval(U,ℰ)

\label{eq34}-{{{p_{1}}\over{{i^{2}}\ {j^{2}}}}\ {|^{\  1 \  1}}}-{{{{p_{1}}\ {\overline{i^{2}}}}\over{{i^{2}}\ {j^{2}}}}\ {|^{\  i \  i}}}-{{{{p_{1}}\ {\overline{j^{2}}}}\over{{i^{2}}\ {j^{2}}}}\ {|^{\  j \  j}}}+{{p_{1}}\ {|^{\  k \  k}}}(34)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))

Frobenius Form (co-unit)

fricas
d:=ε1*ⅆ.1+εi*ⅆ.2+εj*ⅆ.3+εk*ⅆ.4

\label{eq35}{�� 1 \ {|^{\  1}}}+{�� i \ {|^{\  i}}}+{�� j \ {|^{\  j}}}+{�� k \ {|^{\  k}}}(35)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
equate(d=
    (    q I   ) / _
          Ų    )
fricas
Compiling function equate with type Equation(ClosedLinearOperator(
      OrderedVariableList([1,i,j,k]),Expression(Integer))) -> List(
      Equation(Expression(Integer)))

\label{eq36}\left[{�� 1 = -{{p_{1}}\over{{i^{2}}\ {j^{2}}}}}, \:{�� i = 0}, \:{�� j = 0}, \:{�� k = 0}\right](36)
Type: List(Equation(Expression(Integer)))

Express scalar product in terms of Frobenius form

fricas
Ξ:=solve(%,[sb('p,[i]) for i in 1..#Ñ]).1
>> System error: Cannot take first of an empty list

In general the pairing is not symmetric!

fricas
u1:=matrix [[retract((ⅇ.i ⅇ.j)/Ų) for i in 1..dim] for j in 1..dim]

\label{eq37}\left[ 
\begin{array}{cccc}
-{{p_{1}}\over{{i^{2}}\ {j^{2}}}}& 0 & 0 & 0 
\
0 & -{{{p_{1}}\ {\overline{i^{2}}}}\over{{i^{2}}\ {j^{2}}}}& 0 & 0 
\
0 & 0 & -{{{p_{1}}\ {\overline{j^{2}}}}\over{{i^{2}}\ {j^{2}}}}& 0 
\
0 & 0 & 0 &{p_{1}}
(37)
Type: Matrix(Expression(Integer))

The scalar product must be non-degenerate:

fricas
Ů:=determinant u1

\label{eq38}-{{{{p_{1}}^{4}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}\over{{{i^{2}}^{3}}\ {{j^{2}}^{3}}}}(38)
Type: Expression(Integer)
fricas
factor(numer Ů)/factor(denom Ů)

\label{eq39}-{{{{p_{1}}^{4}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}\over{{{i^{2}}^{3}}\ {{j^{2}}^{3}}}}(39)
Type: Fraction(Factored(SparseMultivariatePolynomial?(Integer,Kernel(Expression(Integer)))))

Cartan-Killing is a special case

fricas
ck:=solve(equate(eval(Ũ,Ξ)=Ų),[ε1,εi,εj,εk]).1
There are 12 exposed and 6 unexposed library operations named eval having 2 argument(s) but none was determined to be applicable. Use HyperDoc Browse, or issue )display op eval to learn more about the available operations. Perhaps package-calling the operation or using coercions on the arguments will allow you to apply the operation.
Cannot find a definition or applicable library operation named eval with argument type(s) ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer)) Variable(Ξ)
Perhaps you should use "@" to indicate the required return type, or "$" to specify which version of the function you need.

Frobenius scalar product of "vector" quaternions a and b

fricas
a:=sb('a,[1])*i+sb('a,[2])*j

\label{eq40}{{a_{1}}\ {|_{\  i}}}+{{a_{2}}\ {|_{\  j}}}(40)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
b:=sb('b,[1])*i+sb('b,[2])*j

\label{eq41}{{b_{1}}\ {|_{\  i}}}+{{b_{2}}\ {|_{\  j}}}(41)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
(a,a)/Ų

\label{eq42}{-{{{a_{2}}^{2}}\ {p_{1}}\ {\overline{j^{2}}}}-{{{a_{1}}^{2}}\ {p_{1}}\ {\overline{i^{2}}}}}\over{{i^{2}}\ {j^{2}}}(42)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
(b,b)/Ų

\label{eq43}{-{{{b_{2}}^{2}}\ {p_{1}}\ {\overline{j^{2}}}}-{{{b_{1}}^{2}}\ {p_{1}}\ {\overline{i^{2}}}}}\over{{i^{2}}\ {j^{2}}}(43)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
(a,b)/Ų

\label{eq44}{-{{a_{2}}\ {b_{2}}\ {p_{1}}\ {\overline{j^{2}}}}-{{a_{1}}\ {b_{1}}\ {p_{1}}\ {\overline{i^{2}}}}}\over{{i^{2}}\ {j^{2}}}(44)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))

Definition 3

Co-scalar product

Solve the Snake Relation as a system of linear equations.

fricas
Ω:ℒ:=Σ(Σ(script('u,[[i,j]])*ⅇ.i*ⅇ.j, i,1..dim), j,1..dim)

\label{eq45}\begin{array}{@{}l}
\displaystyle
{{u_{1, \: 1}}\ {|_{\  1 \  1}}}+{{u_{1, \: 2}}\ {|_{\  1 \  i}}}+{{u_{1, \: 3}}\ {|_{\  1 \  j}}}+{{u_{1, \: 4}}\ {|_{\  1 \  k}}}+ 
\
\
\displaystyle
{{u_{2, \: 1}}\ {|_{\  i \  1}}}+{{u_{2, \: 2}}\ {|_{\  i \  i}}}+{{u_{2, \: 3}}\ {|_{\  i \  j}}}+{{u_{2, \: 4}}\ {|_{\  i \  k}}}+{{u_{3, \: 1}}\ {|_{\  j \  1}}}+ 
\
\
\displaystyle
{{u_{3, \: 2}}\ {|_{\  j \  i}}}+{{u_{3, \: 3}}\ {|_{\  j \  j}}}+{{u_{3, \: 4}}\ {|_{\  j \  k}}}+{{u_{4, \: 1}}\ {|_{\  k \  1}}}+ 
\
\
\displaystyle
{{u_{4, \: 2}}\ {|_{\  k \  i}}}+{{u_{4, \: 3}}\ {|_{\  k \  j}}}+{{u_{4, \: 4}}\ {|_{\  k \  k}}}
(45)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
ΩX:=Ω/X;
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
UXΩ:=(I*ΩX)/(Ų*I);
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
ΩXU:=(ΩX*I)/(I*Ų);
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
eq1:=equate(UXΩ=I);
Type: List(Equation(Expression(Integer)))
fricas
eq2:=equate(ΩXU=I);
Type: List(Equation(Expression(Integer)))
fricas
snake:=solve(concat(eq1,eq2),concat [[script('u,[[i,j]]) for i in 1..dim] for j in 1..dim]);
Type: List(List(Equation(Expression(Integer))))
fricas
if #snake ~= 1 then error "no solution"
Type: Void
fricas
Ω:=eval(Ω,snake(1))

\label{eq46}-{{{{i^{2}}\ {j^{2}}}\over{p_{1}}}\ {|_{\  1 \  1}}}-{{{{i^{2}}\ {j^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}}}\ {|_{\  i \  i}}}-{{{{i^{2}}\ {j^{2}}}\over{{p_{1}}\ {\overline{j^{2}}}}}\ {|_{\  j \  j}}}+{{1 \over{p_{1}}}\ {|_{\  k \  k}}}(46)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
ΩX:=Ω/X;
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))

The common demoninator is 1/\sqrt{\mathring{U}}

fricas
squareFreePart factor denom Ů / squareFreePart factor numer Ů
Function: squareFree : % -> Factored(%) is missing from domain: Factored(SparseMultivariatePolynomial(Integer,Kernel(Expression(Integer)))) Internal Error The function squareFree with signature (Factored $)$ is missing from domain Factored (SparseMultivariatePolynomial (Integer) (Kernel (Expression (Integer))))

Check "dimension" and the snake relations.

fricas
O:ℒ:=
       Ω    /
       Ų

\label{eq47}4(47)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
test
    (    I ΩX     )  /
    (     Ų I     )  =  I

\label{eq48} \mbox{\rm true} (48)
Type: Boolean
fricas
test
    (     ΩX I    )  /
    (    I Ų      )  =  I

\label{eq49} \mbox{\rm true} (49)
Type: Boolean

Cartan-Killing co-scalar

fricas
eval(Ω,ck)
There are 12 exposed and 6 unexposed library operations named eval having 2 argument(s) but none was determined to be applicable. Use HyperDoc Browse, or issue )display op eval to learn more about the available operations. Perhaps package-calling the operation or using coercions on the arguments will allow you to apply the operation.
Cannot find a definition or applicable library operation named eval with argument type(s) ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer)) Variable(ck)
Perhaps you should use "@" to indicate the required return type, or "$" to specify which version of the function you need.

Definition 4

Co-algebra

Compute the "three-point" function and use it to define co-multiplication.

fricas
W:=
  (Y I) /
    Ų

\label{eq50}\begin{array}{@{}l}
\displaystyle
-{{{p_{1}}\over{{i^{2}}\ {j^{2}}}}\ {|^{\  1 \  1 \  1}}}-{{{p_{1}}\over{j^{2}}}\ {|^{\  1 \  i \  i}}}-{{{p_{1}}\over{i^{2}}}\ {|^{\  1 \  j \  j}}}+{{p_{1}}\ {|^{\  1 \  k \  k}}}- 
\
\
\displaystyle
{{{p_{1}}\over{j^{2}}}\ {|^{\  i \  1 \  i}}}-{{{p_{1}}\over{j^{2}}}\ {|^{\  i \  i \  1}}}+{{p_{1}}\ {|^{\  i \  j \  k}}}-{{p_{1}}\ {|^{\  i \  k \  j}}}-{{{p_{1}}\over{i^{2}}}\ {|^{\  j \  1 \  j}}}- 
\
\
\displaystyle
{{p_{1}}\ {|^{\  j \  i \  k}}}-{{{p_{1}}\over{i^{2}}}\ {|^{\  j \  j \  1}}}+{{p_{1}}\ {|^{\  j \  k \  i}}}+{{p_{1}}\ {|^{\  k \  1 \  k}}}+{{p_{1}}\ {|^{\  k \  i \  j}}}- 
\
\
\displaystyle
{{p_{1}}\ {|^{\  k \  j \  i}}}+{{p_{1}}\ {|^{\  k \  k \  1}}}
(50)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
λ:=
  (  ΩX I ΩX  ) /
  (  I  W  I  )

\label{eq51}\begin{array}{@{}l}
\displaystyle
-{{{{i^{2}}\ {j^{2}}}\over{p_{1}}}\ {|_{\  1 \  1}^{\  1}}}-{{{{{i^{2}}^{2}}\ {j^{2}}}\over{{p_{1}}\ {{\overline{i^{2}}}^{2}}}}\ {|_{\  i \  i}^{\  1}}}-{{{{i^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {{\overline{j^{2}}}^{2}}}}\ {|_{\  j \  j}^{\  1}}}+ 
\
\
\displaystyle
{{1 \over{p_{1}}}\ {|_{\  k \  k}^{\  1}}}-{{{{{i^{2}}^{2}}\ {j^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}}}\ {|_{\  1 \  i}^{\  i}}}-{{{{{i^{2}}^{2}}\ {j^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}}}\ {|_{\  i \  1}^{\  i}}}+{{{{i^{2}}\ {j^{2}}}\over{{p_{1}}\ {\overline{j^{2}}}}}\ {|_{\  j \  k}^{\  i}}}- 
\
\
\displaystyle
{{{{i^{2}}\ {j^{2}}}\over{{p_{1}}\ {\overline{j^{2}}}}}\ {|_{\  k \  j}^{\  i}}}-{{{{i^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {\overline{j^{2}}}}}\ {|_{\  1 \  j}^{\  j}}}-{{{{i^{2}}\ {j^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}}}\ {|_{\  i \  k}^{\  j}}}- 
\
\
\displaystyle
{{{{i^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {\overline{j^{2}}}}}\ {|_{\  j \  1}^{\  j}}}+{{{{i^{2}}\ {j^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}}}\ {|_{\  k \  i}^{\  j}}}-{{{{i^{2}}\ {j^{2}}}\over{p_{1}}}\ {|_{\  1 \  k}^{\  k}}}- 
\
\
\displaystyle
{{{{{i^{2}}^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  i \  j}^{\  k}}}+{{{{{i^{2}}^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  j \  i}^{\  k}}}-{{{{i^{2}}\ {j^{2}}}\over{p_{1}}}\ {|_{\  k \  1}^{\  k}}}
(51)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))

Cartan-Killing co-multiplication

fricas
eval(λ,ck)
There are 12 exposed and 6 unexposed library operations named eval having 2 argument(s) but none was determined to be applicable. Use HyperDoc Browse, or issue )display op eval to learn more about the available operations. Perhaps package-calling the operation or using coercions on the arguments will allow you to apply the operation.
Cannot find a definition or applicable library operation named eval with argument type(s) ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer)) Variable(ck)
Perhaps you should use "@" to indicate the required return type, or "$" to specify which version of the function you need.

fricas
test
     (    I ΩX     )  /
     (     Y I     )  =  λ

\label{eq52} \mbox{\rm true} (52)
Type: Boolean
fricas
test
     (     ΩX I    )  /
     (    I  Y     )  =  λ

\label{eq53} \mbox{\rm true} (53)
Type: Boolean

Co-associativity

fricas
test(
  (  λ  ) / _
  ( I λ ) = _
  (  λ  ) / _
  ( λ I ) )

\label{eq54} \mbox{\rm false} (54)
Type: Boolean

fricas
test
         q     /
         λ     =    ΩX

\label{eq55} \mbox{\rm false} (55)
Type: Boolean

Frobenius Condition (fork)

fricas
H :=
         Y    /
         λ

\label{eq56}\begin{array}{@{}l}
\displaystyle
-{{{{i^{2}}\ {j^{2}}}\over{p_{1}}}\ {|_{\  1 \  1}^{\  1 \  1}}}-{{{{{i^{2}}^{2}}\ {j^{2}}}\over{{p_{1}}\ {{\overline{i^{2}}}^{2}}}}\ {|_{\  i \  i}^{\  1 \  1}}}-{{{{i^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {{\overline{j^{2}}}^{2}}}}\ {|_{\  j \  j}^{\  1 \  1}}}+ 
\
\
\displaystyle
{{1 \over{p_{1}}}\ {|_{\  k \  k}^{\  1 \  1}}}-{{{{{i^{2}}^{3}}\ {j^{2}}}\over{{p_{1}}\ {{\overline{i^{2}}}^{2}}}}\ {|_{\  1 \  i}^{\  1 \  i}}}-{{{{{i^{2}}^{3}}\ {j^{2}}}\over{{p_{1}}\ {{\overline{i^{2}}}^{2}}}}\ {|_{\  i \  1}^{\  1 \  i}}}+ 
\
\
\displaystyle
{{{{{i^{2}}^{2}}\ {j^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  j \  k}^{\  1 \  i}}}-{{{{{i^{2}}^{2}}\ {j^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  k \  j}^{\  1 \  i}}}-{{{{i^{2}}\ {{j^{2}}^{3}}}\over{{p_{1}}\ {{\overline{j^{2}}}^{2}}}}\ {|_{\  1 \  j}^{\  1 \  j}}}- 
\
\
\displaystyle
{{{{i^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  i \  k}^{\  1 \  j}}}-{{{{i^{2}}\ {{j^{2}}^{3}}}\over{{p_{1}}\ {{\overline{j^{2}}}^{2}}}}\ {|_{\  j \  1}^{\  1 \  j}}}+{{{{i^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  k \  i}^{\  1 \  j}}}- 
\
\
\displaystyle
{{{{i^{2}}\ {j^{2}}}\over{p_{1}}}\ {|_{\  1 \  k}^{\  1 \  k}}}-{{{{{i^{2}}^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  i \  j}^{\  1 \  k}}}+{{{{{i^{2}}^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  j \  i}^{\  1 \  k}}}- 
\
\
\displaystyle
{{{{i^{2}}\ {j^{2}}}\over{p_{1}}}\ {|_{\  k \  1}^{\  1 \  k}}}-{{{{{i^{2}}^{3}}\ {j^{2}}}\over{{p_{1}}\ {{\overline{i^{2}}}^{2}}}}\ {|_{\  1 \  i}^{\  i \  1}}}-{{{{{i^{2}}^{3}}\ {j^{2}}}\over{{p_{1}}\ {{\overline{i^{2}}}^{2}}}}\ {|_{\  i \  1}^{\  i \  1}}}+ 
\
\
\displaystyle
{{{{{i^{2}}^{2}}\ {j^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  j \  k}^{\  i \  1}}}-{{{{{i^{2}}^{2}}\ {j^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  k \  j}^{\  i \  1}}}-{{{{{i^{2}}^{2}}\ {j^{2}}}\over{p_{1}}}\ {|_{\  1 \  1}^{\  i \  i}}}- 
\
\
\displaystyle
{{{{{i^{2}}^{3}}\ {j^{2}}}\over{{p_{1}}\ {{\overline{i^{2}}}^{2}}}}\ {|_{\  i \  i}^{\  i \  i}}}-{{{{{i^{2}}^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {{\overline{j^{2}}}^{2}}}}\ {|_{\  j \  j}^{\  i \  i}}}+{{{i^{2}}\over{p_{1}}}\ {|_{\  k \  k}^{\  i \  i}}}- 
\
\
\displaystyle
{{{{i^{2}}\ {j^{2}}}\over{p_{1}}}\ {|_{\  1 \  k}^{\  i \  j}}}-{{{{{i^{2}}^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  i \  j}^{\  i \  j}}}+{{{{{i^{2}}^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  j \  i}^{\  i \  j}}}- 
\
\
\displaystyle
{{{{i^{2}}\ {j^{2}}}\over{p_{1}}}\ {|_{\  k \  1}^{\  i \  j}}}-{{{{{i^{2}}^{2}}\ {{j^{2}}^{3}}}\over{{p_{1}}\ {{\overline{j^{2}}}^{2}}}}\ {|_{\  1 \  j}^{\  i \  k}}}-{{{{{i^{2}}^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  i \  k}^{\  i \  k}}}- 
\
\
\displaystyle
{{{{{i^{2}}^{2}}\ {{j^{2}}^{3}}}\over{{p_{1}}\ {{\overline{j^{2}}}^{2}}}}\ {|_{\  j \  1}^{\  i \  k}}}+{{{{{i^{2}}^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  k \  i}^{\  i \  k}}}-{{{{i^{2}}\ {{j^{2}}^{3}}}\over{{p_{1}}\ {{\overline{j^{2}}}^{2}}}}\ {|_{\  1 \  j}^{\  j \  1}}}- 
\
\
\displaystyle
{{{{i^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  i \  k}^{\  j \  1}}}-{{{{i^{2}}\ {{j^{2}}^{3}}}\over{{p_{1}}\ {{\overline{j^{2}}}^{2}}}}\ {|_{\  j \  1}^{\  j \  1}}}+{{{{i^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  k \  i}^{\  j \  1}}}+ 
\
\
\displaystyle
{{{{i^{2}}\ {j^{2}}}\over{p_{1}}}\ {|_{\  1 \  k}^{\  j \  i}}}+{{{{{i^{2}}^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  i \  j}^{\  j \  i}}}-{{{{{i^{2}}^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  j \  i}^{\  j \  i}}}+ 
\
\
\displaystyle
{{{{i^{2}}\ {j^{2}}}\over{p_{1}}}\ {|_{\  k \  1}^{\  j \  i}}}-{{{{i^{2}}\ {{j^{2}}^{2}}}\over{p_{1}}}\ {|_{\  1 \  1}^{\  j \  j}}}-{{{{{i^{2}}^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {{\overline{i^{2}}}^{2}}}}\ {|_{\  i \  i}^{\  j \  j}}}- 
\
\
\displaystyle
{{{{i^{2}}\ {{j^{2}}^{3}}}\over{{p_{1}}\ {{\overline{j^{2}}}^{2}}}}\ {|_{\  j \  j}^{\  j \  j}}}+{{{j^{2}}\over{p_{1}}}\ {|_{\  k \  k}^{\  j \  j}}}+{{{{{i^{2}}^{3}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {{\overline{i^{2}}}^{2}}}}\ {|_{\  1 \  i}^{\  j \  k}}}+ 
\
\
\displaystyle
{{{{{i^{2}}^{3}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {{\overline{i^{2}}}^{2}}}}\ {|_{\  i \  1}^{\  j \  k}}}-{{{{{i^{2}}^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  j \  k}^{\  j \  k}}}+{{{{{i^{2}}^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  k \  j}^{\  j \  k}}}- 
\
\
\displaystyle
{{{{i^{2}}\ {j^{2}}}\over{p_{1}}}\ {|_{\  1 \  k}^{\  k \  1}}}-{{{{{i^{2}}^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  i \  j}^{\  k \  1}}}+{{{{{i^{2}}^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  j \  i}^{\  k \  1}}}- 
\
\
\displaystyle
{{{{i^{2}}\ {j^{2}}}\over{p_{1}}}\ {|_{\  k \  1}^{\  k \  1}}}+{{{{{i^{2}}^{2}}\ {{j^{2}}^{3}}}\over{{p_{1}}\ {{\overline{j^{2}}}^{2}}}}\ {|_{\  1 \  j}^{\  k \  i}}}+{{{{{i^{2}}^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  i \  k}^{\  k \  i}}}+ 
\
\
\displaystyle
{{{{{i^{2}}^{2}}\ {{j^{2}}^{3}}}\over{{p_{1}}\ {{\overline{j^{2}}}^{2}}}}\ {|_{\  j \  1}^{\  k \  i}}}-{{{{{i^{2}}^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  k \  i}^{\  k \  i}}}-{{{{{i^{2}}^{3}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {{\overline{i^{2}}}^{2}}}}\ {|_{\  1 \  i}^{\  k \  j}}}- 
\
\
\displaystyle
{{{{{i^{2}}^{3}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {{\overline{i^{2}}}^{2}}}}\ {|_{\  i \  1}^{\  k \  j}}}+{{{{{i^{2}}^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  j \  k}^{\  k \  j}}}-{{{{{i^{2}}^{2}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  k \  j}^{\  k \  j}}}+ 
\
\
\displaystyle
{{{{{i^{2}}^{2}}\ {{j^{2}}^{2}}}\over{p_{1}}}\ {|_{\  1 \  1}^{\  k \  k}}}+{{{{{i^{2}}^{3}}\ {{j^{2}}^{2}}}\over{{p_{1}}\ {{\overline{i^{2}}}^{2}}}}\ {|_{\  i \  i}^{\  k \  k}}}+{{{{{i^{2}}^{2}}\ {{j^{2}}^{3}}}\over{{p_{1}}\ {{\overline{j^{2}}}^{2}}}}\ {|_{\  j \  j}^{\  k \  k}}}- 
\
\
\displaystyle
{{{{i^{2}}\ {j^{2}}}\over{p_{1}}}\ {|_{\  k \  k}^{\  k \  k}}}
(56)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
test
     (   λ I   )  /
     (  I Y    )  =  H

\label{eq57} \mbox{\rm false} (57)
Type: Boolean
fricas
test
     (   I λ   )  /
     (    Y I  )  =  H

\label{eq58} \mbox{\rm false} (58)
Type: Boolean

The Cartan-Killing form makes H of the Frobenius condition idempotent

fricas
test( eval(H,ck)=eval(H/H,ck) )
There are 12 exposed and 6 unexposed library operations named eval having 2 argument(s) but none was determined to be applicable. Use HyperDoc Browse, or issue )display op eval to learn more about the available operations. Perhaps package-calling the operation or using coercions on the arguments will allow you to apply the operation.
Cannot find a definition or applicable library operation named eval with argument type(s) ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer)) Variable(ck)
Perhaps you should use "@" to indicate the required return type, or "$" to specify which version of the function you need.

But it is not unique. E.g. other idempots

fricas
h1:=map(numer,ravel(H-H/H)::List FRAC POLY INT);
Cannot convert the value from type List(Expression(Integer)) to List (Fraction(Polynomial(Integer))) .

Handle and handle element

fricas
Φ :=
         λ     /
         Y

\label{eq59}\begin{array}{@{}l}
\displaystyle
{{{{{\left(-{2 \ {i^{2}}\ {j^{2}}\ {{\overline{i^{2}}}^{2}}}-{{{i^{2}}^{3}}\ {j^{2}}}\right)}\ {{\overline{j^{2}}}^{2}}}-{{i^{2}}\ {{j^{2}}^{3}}\ {{\overline{i^{2}}}^{2}}}}\over{{p_{1}}\ {{\overline{i^{2}}}^{2}}\ {{\overline{j^{2}}}^{2}}}}\ {|_{\  1}^{\  1}}}+ 
\
\
\displaystyle
{{{-{2 \ {{i^{2}}^{3}}\ {j^{2}}\ {\overline{j^{2}}}}-{2 \ {{i^{2}}^{2}}\ {{j^{2}}^{2}}\ {\overline{i^{2}}}}}\over{{p_{1}}\ {{\overline{i^{2}}}^{2}}\ {\overline{j^{2}}}}}\ {|_{\  i}^{\  i}}}+ 
\
\
\displaystyle
{{{-{2 \ {{i^{2}}^{2}}\ {{j^{2}}^{2}}\ {\overline{j^{2}}}}-{2 \ {i^{2}}\ {{j^{2}}^{3}}\ {\overline{i^{2}}}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {{\overline{j^{2}}}^{2}}}}\ {|_{\  j}^{\  j}}}+ 
\
\
\displaystyle
{{{-{2 \ {i^{2}}\ {j^{2}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}-{2 \ {{i^{2}}^{2}}\ {{j^{2}}^{2}}}}\over{{p_{1}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}}\ {|_{\  k}^{\  k}}}
(59)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
Φ1 :=    q     /
         Φ

\label{eq60}{{{{\left(-{2 \ {i^{2}}\ {j^{2}}\ {{\overline{i^{2}}}^{2}}}-{{{i^{2}}^{3}}\ {j^{2}}}\right)}\ {{\overline{j^{2}}}^{2}}}-{{i^{2}}\ {{j^{2}}^{3}}\ {{\overline{i^{2}}}^{2}}}}\over{{p_{1}}\ {{\overline{i^{2}}}^{2}}\ {{\overline{j^{2}}}^{2}}}}\ {|_{\  1}}(60)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))

The Cartan-Killing form makes Φ into the identity

fricas
test( eval(Φ,ck)=I )
There are 12 exposed and 6 unexposed library operations named eval having 2 argument(s) but none was determined to be applicable. Use HyperDoc Browse, or issue )display op eval to learn more about the available operations. Perhaps package-calling the operation or using coercions on the arguments will allow you to apply the operation.
Cannot find a definition or applicable library operation named eval with argument type(s) ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer)) Variable(ck)
Perhaps you should use "@" to indicate the required return type, or "$" to specify which version of the function you need.

but it can be the identity in many ways. For example,

fricas
solve(equate(eval(Φ,[ε1=1,εi=1,εj=1,j2=-1])=I),[εk])

\label{eq61}\left[ \right](61)
Type: List(List(Equation(Expression(Integer))))

If handle is identity then fork is idempotent but the converse is not true

fricas
Φ1:=map(numer,ravel(Φ-I)::List FRAC POLY INT);
Cannot convert the value from type List(Expression(Integer)) to List (Fraction(Polynomial(Integer))) .

Figure 12

fricas
φφ:=          _
  ( Ω  Ω  ) / _
  ( X I I ) / _
  ( I X I ) / _
  ( I I X ) / _
  (  Y  Y );
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
φφ1:=map((x:ℚ):ℚ+->numer x,φφ)

\label{eq62}\begin{array}{@{}l}
\displaystyle
{{\left({{\left({2 \ {{i^{2}}^{2}}\ {{j^{2}}^{2}}\ {{\overline{i^{2}}}^{2}}}+{{{i^{2}}^{4}}\ {{j^{2}}^{2}}}\right)}\ {{\overline{j^{2}}}^{2}}}+{{{i^{2}}^{2}}\ {{j^{2}}^{4}}\ {{\overline{i^{2}}}^{2}}}\right)}\ {|_{\  1 \  1}}}+ 
\
\
\displaystyle
{{\left({2 \ {{i^{2}}^{4}}\ {{j^{2}}^{2}}\ {\overline{j^{2}}}}+{2 \ {{i^{2}}^{3}}\ {{j^{2}}^{3}}\ {\overline{i^{2}}}}\right)}\ {|_{\  i \  i}}}+ 
\
\
\displaystyle
{{\left({2 \ {{i^{2}}^{3}}\ {{j^{2}}^{3}}\ {\overline{j^{2}}}}+{2 \ {{i^{2}}^{2}}\ {{j^{2}}^{4}}\ {\overline{i^{2}}}}\right)}\ {|_{\  j \  j}}}+ 
\
\
\displaystyle
{{\left(-{2 \ {i^{2}}\ {j^{2}}\ {\overline{i^{2}}}\ {\overline{j^{2}}}}-{2 \ {{i^{2}}^{2}}\ {{j^{2}}^{2}}}\right)}\ {|_{\  k \  k}}}
(62)
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
φφ2:=denom(ravel(φφ).1)

\label{eq63}{{p_{1}}^{2}}\ {{\overline{i^{2}}}^{2}}\ {{\overline{j^{2}}}^{2}}(63)
Type: SparseMultivariatePolynomial?(Integer,Kernel(Expression(Integer)))
fricas
test(φφ=(1/φφ2)*φφ1)

\label{eq64} \mbox{\rm false} (64)
Type: Boolean

For Cartan-Killing this is just the co-scalar

fricas
test(eval(φφ,ck)=eval(Ω,ck))
There are 12 exposed and 6 unexposed library operations named eval having 2 argument(s) but none was determined to be applicable. Use HyperDoc Browse, or issue )display op eval to learn more about the available operations. Perhaps package-calling the operation or using coercions on the arguments will allow you to apply the operation.
Cannot find a definition or applicable library operation named eval with argument type(s) ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer)) Variable(ck)
Perhaps you should use "@" to indicate the required return type, or "$" to specify which version of the function you need.

Bi-algebra conditions

fricas
ΦΦ:=          _
  (  λ λ  ) / _
  ( I I X ) / _
  ( I X I ) / _
  ( I I X ) / _
  (  Y  Y ) ;
Type: ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer))
fricas
test((q,q)/ΦΦ=φφ)

\label{eq65} \mbox{\rm false} (65)
Type: Boolean
fricas
test(eval(ΦΦ,ck)=eval(H,ck))
There are 12 exposed and 6 unexposed library operations named eval having 2 argument(s) but none was determined to be applicable. Use HyperDoc Browse, or issue )display op eval to learn more about the available operations. Perhaps package-calling the operation or using coercions on the arguments will allow you to apply the operation.
Cannot find a definition or applicable library operation named eval with argument type(s) ClosedLinearOperator(OrderedVariableList([1,i,j,k]),Expression(Integer)) Variable(ck)
Perhaps you should use "@" to indicate the required return type, or "$" to specify which version of the function you need.

Theorem 8.3

fricas
u2:=map(retract,matrix [ _
        [q/d,     i/d,    j/d,     k/d], _
        [i/d,  i2*q/d,    k/d,  i2*j/d], _
        [j/d,    -k/d, j2*q/d, -j2*i/d], _
        [k/d, -i2*j/d, j2*i/d, k2*q/d]])

\label{eq66}\left[ 
\begin{array}{cccc}
�� 1 & �� i & �� j & �� k 
\
�� i &{{i^{2}}\  �� 1}& �� k &{{i^{2}}\  �� j}
\
�� j & - �� k &{{j^{2}}\  �� 1}& -{{j^{2}}\  �� i}
\
�� k & -{{i^{2}}\  �� j}&{{j^{2}}\  �� i}& -{{i^{2}}\ {j^{2}}\  �� 1}
(66)
Type: Matrix(Expression(Integer))
fricas
test(u2=transpose(u1))

\label{eq67} \mbox{\rm false} (67)
Type: Boolean
fricas
Ů2 := -retract( k2*(q/d)^2 + j2*(i/d)^2 + i2*(j/d)^2 - (k/d)^2 )^2

\label{eq68}\begin{array}{@{}l}
\displaystyle
-{{�� k}^{4}}+{{\left({2 \ {i^{2}}\ {{�� j}^{2}}}+{2 \ {j^{2}}\ {{�� i}^{2}}}-{2 \ {i^{2}}\ {j^{2}}\ {{�� 1}^{2}}}\right)}\ {{�� k}^{2}}}-{{{i^{2}}^{2}}\ {{�� j}^{4}}}+ 
\
\
\displaystyle
{{\left(-{2 \ {i^{2}}\ {j^{2}}\ {{�� i}^{2}}}+{2 \ {{i^{2}}^{2}}\ {j^{2}}\ {{�� 1}^{2}}}\right)}\ {{�� j}^{2}}}-{{{j^{2}}^{2}}\ {{�� i}^{4}}}+{2 \ {i^{2}}\ {{j^{2}}^{2}}\ {{�� 1}^{2}}\ {{�� i}^{2}}}- 
\
\
\displaystyle
{{{i^{2}}^{2}}\ {{j^{2}}^{2}}\ {{�� 1}^{4}}}
(68)
Type: Expression(Integer)
fricas
factor(numer Ů2)/factor(denom Ů2)

\label{eq69}-{{\left({{�� k}^{2}}-{{i^{2}}\ {{�� j}^{2}}}-{{j^{2}}\ {{�� i}^{2}}}+{{i^{2}}\ {j^{2}}\ {{�� 1}^{2}}}\right)}^{2}}(69)
Type: Fraction(Factored(SparseMultivariatePolynomial?(Integer,Kernel(Expression(Integer)))))
fricas
test(Ů=Ů2)

\label{eq70} \mbox{\rm false} (70)
Type: Boolean




  Subject:   Be Bold !!
  ( 14 subscribers )  
Please rate this page: