The Algebra of Complex Numbers Is Frobenius In Many Ways Linear operators over a 2-dimensional vector space representing the algebra of complex numbers Ref:
We need the Axiom LinearOperator library. fricas (1) -> )library CARTEN ARITY CMONAL CPROP CLOP CALEY Use the following macros for convenient notation fricas -- summation macro Σ(x, Type: Void
fricas -- list macro Ξ(f, Type: Void
fricas -- subscript and superscripts macro sb == subscript Type: Void
fricas macro sp == superscript Type: Void
𝐋 is the domain of 2-dimensional linear operators over the rational functions ℚ (Expression Integer), i.e. ratio of polynomials with integer coefficients. fricas dim:=2
Type: PositiveInteger?
fricas macro ℒ == List Type: Void
fricas macro ℂ == CaleyDickson Type: Void
fricas macro ℚ == Expression Integer Type: Void
fricas 𝐋 := ClosedLinearOperator(OVAR ['1,
Type: Type
fricas 𝐞:ℒ 𝐋 := basisOut()
fricas 𝐝:ℒ 𝐋 := basisIn()
fricas I:𝐋:=[1] -- identity for composition
fricas X:𝐋:=[2,
fricas V:𝐋:=ev(1) -- evaluation
fricas Λ:𝐋:=co(1) -- co-evaluation
fricas equate(eq)==map((x, Type: Void
Now generate structure constants for Complex Algebra The basis consists of the real and imaginary units. We use complex 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 can be specified by Caley-Dickson parameter (i2) fricas --i2:=sp('i,
Type: Integer
fricas QQ := ℂ(ℚ, Type: Type
Basis: Each B.i is a complex number fricas B:ℒ QQ := map(x +-> hyper x,
fricas -- Multiplication table: M:Matrix QQ := matrix Ξ(Ξ(B.i*B.j,
fricas -- Function to divide the matrix entries by a basis element S(y) == map(x +-> real(x/y), Type: Void
fricas -- The result is a nested list ѕ :=map(S, fricas Compiling function S with type CaleyDickson(Expression(Integer),
Type: List(List(List(Expression(Integer))))
fricas -- structure constants form a tensor operator Y := Σ(Σ(Σ(ѕ(i)(k)(j)*𝐞.i*𝐝.j*𝐝.k,
fricas arity Y
fricas matrix Ξ(Ξ((𝐞.i*𝐞.j)/Y,
Units fricas e:=𝐞.1; i:=𝐞.2; Multiplication of arbitrary ccomplex numbers and fricas a:=Σ(sb('a,
fricas b:=Σ(sb('b,
fricas (a*b)/Y
Multiplication is Associative fricas test( ( I Y ) / _ ( Y ) = _ ( Y I ) / _ ( Y ) )
Type: Boolean
A scalar product is denoted by the (2,0)-tensor fricas U:=Σ(Σ(script('u,
Definition 1We say that the scalar product is associative if the tensor equation holds: Y = Y U U In other words, if the (3,0)-tensor:
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
Definition 2An algebra with a non-degenerate associative scalar product is called a [Frobenius Algebra]?. The Cartan-Killing Trace fricas Ú:= ( Y Λ ) / _ ( Y I ) / _ V
fricas Ù:= ( Λ Y ) / _ ( I Y ) / _ V
fricas test(Ù=Ú)
Type: Boolean
forms a non-degenerate associative scalar product for Y fricas Ũ := Ù
fricas test ( Y I ) / Ũ = ( I Y ) / Ũ
Type: Boolean
fricas determinant Ξ(Ξ(retract((𝐞.i * 𝐞.j)/Ũ),
Type: Expression(Integer)
General Solution We may consider the problem where multiplication Y is given, and look for all associative scalar products This problem can be solved using linear algebra. fricas )expose MCALCFN Type: Matrix(Expression(Integer))
fricas nrows(J),
Type: Tuple(PositiveInteger?)
The matrix If the null space of the fricas Ñ:=nullSpace(J)
Type: List(Vector(Expression(Integer)))
fricas ℰ:=map((x,
Type: List(Equation(Expression(Integer)))
This defines a family of pre-Frobenius algebras: fricas zero? eval(ω,
Type: Boolean
fricas Ų:𝐋 := eval(U,
Frobenius Form (co-unit) fricas d:=ε1*𝐝.1+εi*𝐝.2
fricas 𝔇:=equate(d= ( e I ) / _ Ų ) fricas Compiling function equate with type Equation(ClosedLinearOperator( OrderedVariableList([1,
Type: List(Equation(Expression(Integer)))
Express scalar product in terms of Frobenius form fricas 𝔓:=solve(𝔇,
Type: List(Equation(Expression(Integer)))
fricas Ų:=eval(Ų,
fricas test Y / d = Ų
Type: Boolean
In general the pairing is not symmetric! fricas u1:=matrix Ξ(Ξ(retract((𝐞.i 𝐞.j)/Ų),
Type: Matrix(Expression(Integer))
The scalar product must be non-degenerate: fricas Ů:=determinant u1
Type: Expression(Integer)
fricas factor(numer Ů)/factor(denom Ů)
Type: Fraction(Factored(SparseMultivariatePolynomial?(Integer,
Cartan-Killing is a special case fricas ck:=solve(equate(eval(Ũ,
Type: List(Equation(Expression(Integer)))
Frobenius scalar product of complex numbers and fricas a:=sb('a,
fricas b:=sb('b,
fricas (a,
fricas (b,
fricas ab:=(a,
fricas solve(equate(ab=0*ab), Definition 3Co-scalar product Solve the Snake Relation as a system of linear equations. fricas Ω:𝐋:=Σ(Σ(script('u,
fricas ΩX:=Ω/X; fricas UXΩ:=(I*ΩX)/(Ų*I); fricas ΩXU:=(ΩX*I)/(I*Ų); 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, Type: List(List(Equation(Expression(Integer))))
fricas if #snake ~= 1 then error "no solution" Type: Void
fricas Ω:=eval(Ω,
fricas ΩX:=Ω/X; The common demoninator is fricas squareFreePart((factor denom Ů)::ℚ) / squareFreePart((factor numer Ů)::ℚ)
Type: Expression(Integer)
fricas matrix Ξ(Ξ(numer retract(Ω/(𝐝.i*𝐝.j)),
Type: Matrix(SparseMultivariatePolynomial?(Integer,
Check "dimension" and the snake relations. fricas O:𝐋:= Ω / Ų
fricas test ( I ΩX ) / ( Ų I ) = I
Type: Boolean
fricas test ( ΩX I ) / ( I Ų ) = I
Type: Boolean
Cartan-Killing co-scalar fricas eval(Ω,
Definition 4Co-algebra Compute the "three-point" function and use it to define co-multiplication. fricas W:= (Y I) / Ų
fricas λ:= ( ΩX I ΩX ) / ( I W I )
Cartan-Killing co-multiplication fricas eval(λ,
fricas test ( I ΩX ) / ( Y I ) = λ
Type: Boolean
fricas test ( ΩX I ) / ( I Y ) = λ
Type: Boolean
Co-associativity fricas test( ( λ ) / _ ( I λ ) = _ ( λ ) / _ ( λ I ) )
Type: Boolean
fricas test e / λ = ΩX
Type: Boolean
Frobenius Condition (fork) fricas H := Y / λ
fricas test ( λ I ) / ( I Y ) = H
Type: Boolean
fricas test ( I λ ) / ( Y I ) = H
Type: Boolean
The Cartan-Killing form makes H of the Frobenius condition idempotent fricas test( eval(H,
Type: Boolean
And it is unique. fricas h1:=map(numer, Type: List(Polynomial(Integer))
fricas h2:=groebner h1
Type: List(Polynomial(Integer))
fricas ck4:=solve(h2,
Type: List(List(Equation(Fraction(Polynomial(Integer)))))
fricas test( eval(H, Handle fricas Φ := λ / Y
The Cartan-Killing form makes Φ of the identity fricas test( eval(Φ,
Type: Boolean
and it can be the identity in only this one way. fricas solve(equate(Φ=I),
Type: List(List(Equation(Expression(Integer))))
If handle is identity then fork is idempotent but the converse is not true fricas Φ1:=map(numer, Type: List(Polynomial(Integer))
fricas Φ2:=groebner Φ1
Type: List(Polynomial(Integer))
fricas in?(ideal h2,
Type: Boolean
fricas in?(ideal Φ2,
Type: Boolean
Figure 12 fricas φφ:= _ ( Ω Ω ) / _ ( X I I ) / _ ( I X I ) / _ ( I I X ) / _ ( Y Y ); fricas φφ1:=map((x:ℚ):ℚ+->numer x,
fricas φφ2:=denom(ravel(φφ).1)
Type: SparseMultivariatePolynomial?(Integer,
fricas test(φφ=(1/φφ2)*φφ1)
Type: Boolean
For Cartan-Killing this is just the co-scalar fricas test(eval(φφ,
Type: Boolean
fricas test(eval((e,
Type: Boolean
Bi-algebra conditions fricas ΦΦ:= _ ( λ λ ) / _ ( I I X ) / _ ( I X I ) / _ ( I I X ) / _ ( Y Y ) ; fricas test((e,
Type: Boolean
fricas test(eval(ΦΦ,
Type: Boolean
fricas test(eval(ΦΦ/(d,
Type: Boolean
fricas test(eval(H/(d,
Type: Boolean
The Cartan Killing form is a bi-algebra fricas bi1:=map(numer, Type: List(Polynomial(Integer))
fricas bi2:=groebner bi1
Type: List(Polynomial(Integer))
fricas b:=solve( equate(ΦΦ=H),
Type: List(List(Equation(Expression(Integer))))
fricas test(eval(Ų,
Type: Boolean
|