Orthogonal frame via gram schmidt or eigendecomposition
 Functions such as  :
: M→M require an orthonormal frame with respect to
M→M require an orthonormal frame with respect to  . We use the eigenvectors of
. We use the eigenvectors of  find a set of orthonormal vectors. We begin with a numerical treatment. The scalar product considered has index 1.
 find a set of orthonormal vectors. We begin with a numerical treatment. The scalar product considered has index 1.
 ![MF[ℊ = Τ[Array[Random[] &, {3, 3}]] + Diag[{1, 1, -2}]]](../HTMLFiles/index_102.gif) 
  
 ![{d, V} = Eigensystem[ℊ]](../HTMLFiles/index_104.gif) 
  
 ![MF[α = T[Inv[Diag[Abs[d]^(1/2)] . V]]]](../HTMLFiles/index_106.gif) 
 ![ListPlotVectorField3D[{{0, 0, 0}, #1} &/@α, ScaleFactor→.1, Frame→True, Axes→True] ;](../HTMLFiles/index_107.gif) 
  
 ![[Graphics:../HTMLFiles/index_109.gif]](../HTMLFiles/index_109.gif) 
An orthonormal vector is in the column of α.
 ![v = α[[1]]](../HTMLFiles/index_110.gif) 
  
 ![MF[Τα[ℊ, 0, T[α]]]](../HTMLFiles/index_112.gif) 
  
  
  
The above procedure is carried out by
 ![MF[ΜOrthNormalize[ℊ]]](../HTMLFiles/index_116.gif) 
  
An alternative way to orthonormalize vectors is via gram schmidt. However, a basis of vectors of length ≠0 is required.
 ![MF[Τα[ℊ, 0, T[ΜOrthNormalize[ℊ, Id[3]]]]]](../HTMLFiles/index_118.gif) 
  
Even in low dimensions, expressions get quite lengthy when solving the problem algebraically. As an example, a metric for a coordinate environment for the sphere.
  
  
 ![df = Μd[f, 1, 2] ;](../HTMLFiles/index_122.gif) 
 ![MF[ℊS2 = T[df] . df]](../HTMLFiles/index_123.gif) 
  
  
 ![ShowMat[{V = ΜOrthNormalize[ℊS2], Τα[ℊS2, 0, T[V]]}]](../HTMLFiles/index_126.gif) 
  
 ![ShowMat[{V = ΜOrthNormalize[ℊS2, Id[2]], Τα[ℊS2, 0, T[V]]}]](../HTMLFiles/index_128.gif) 
  
  
 ![α = Inv[Diag[Abs[d]^(1/2)] . myV]//S](../HTMLFiles/index_131.gif) 
 ![MF[Τα[ℊS2, 0, α]]//S](../HTMLFiles/index_132.gif) 
  
  
 Just for fun, we plot f( ,
, ) with emphasis on real and imaginary part.
) with emphasis on real and imaginary part.
  
 ![Plot3D[Evaluate[Re[f[[3]]/.r→1]], {x_1, -τ, τ}, {x_2, -τ, τ}, PlotPoints→40] ;](../HTMLFiles/index_138.gif) 
 ![Plot3D[Evaluate[-Im[f[[3]]/.r→1]], {x_1, -τ, τ}, {x_2, -τ, τ}, PlotPoints→40] ;](../HTMLFiles/index_139.gif) 
 ![[Graphics:../HTMLFiles/index_140.gif]](../HTMLFiles/index_140.gif) 
 ![[Graphics:../HTMLFiles/index_141.gif]](../HTMLFiles/index_141.gif) 
The two parts attached are
 ![Plot3D[Evaluate[Re[f[[3]]/.r→1] - Im[f[[3]]/.r→1]], {x_1, -τ, τ}, {x_2, -τ, τ}, PlotPoints→40] ;](../HTMLFiles/index_142.gif) 
 ![Plot[Evaluate[Re[f[[3]]/.{x_2→0, r→1}] - Im[f[[3]]/.{x_2→0, r→1}]], {x_1, -τ, τ}] ;](../HTMLFiles/index_143.gif) 
 ![[Graphics:../HTMLFiles/index_144.gif]](../HTMLFiles/index_144.gif) 
 ![[Graphics:../HTMLFiles/index_145.gif]](../HTMLFiles/index_145.gif) 
| Created by Mathematica (December 22, 2006) |  |