# Kapitel 2_a: 
# Berechnung des Versors bei Vorgabe der Drehachse und des Drehwinkels
#  2015 Friedrich U. Mathiak, 
# mathiak@mechanik-info.de
# 
> interface(displayprecision=4): restart: with(LinearAlgebra):
# Beispiel 2-2:
# Es wird eine Maple-Prozedur zur Berechnung der Matrix des Versors R bei Vorgabe des Drehachse n und des Drehwinkels  bereitgestellt. Die Drehachse hat die Orientierung des Vektors n, der programmintern auf die Lnge 1 normiert wird. 
> Proc_Calc_02:=proc(nv::Vector,phi::anything,flag::integer)
> #----------------------------------------------------------------------------
# #  Eingabe:
# #     nv : Vektor der Drehachse(wird programmintern auf die Lnge 1 normiert)
# #     phi: Drehwinkel im Bogenma um die positive Drehachse
> 
> #    flag: 
> #          flag = 0: Eigenwertberechnung wird nicht durchgefhrt
> #          flag = 1: Eigenwertberechnung wird       durchgefhrt
> #  Ausgabe:
> #       R:       Versor
> #   Lamba: Eigenwerte    von R (wenn flag = 1)
> #     Phi: Eigenvektoren von R (wenn flag = 1)
> #----------------------------------------------------------------------------
> local  ndn,id,ekn,n,i,j; 
> global R,Lambda,Phi;
> description "Berechnung des Versors R bei Vorgabe der Drehachse  n und des Drehwinkels phi, Lsung des Eigenwertproblems";
> n  := LinearAlgebra[Normalize](nv,Euclidean);
> ndn:= n.LinearAlgebra[Transpose](n):
> id := Matrix(3,3,shape=identity):
> ekn:= Matrix(3,3,shape=antisymmetric);
> ekn[1,2]:=-n[3];
> ekn[1,3]:= n[2];
> ekn[2,3]:=-n[1];
> R:=ndn + (id-ndn)*cos(phi) + ekn*sin(phi);
> if flag = 1 then
> #Berechnung der Eigenwerte und Eigenvektoren des Versors R
> (Lambda,Phi):=LinearAlgebra[Eigenvectors](R);
> for i to 3 do
>   Lambda[i]:=simplify(evalc(Lambda[i]),trig)    assuming phi::real;
>    for j to 3 do
>      Phi[i,j] :=simplify(evalc(Phi[i,j]), trig) assuming phi::real;
>    end do:
> end do;
> print(`Eigenwerte `, Lambda);
> print(`Eigenvektoren `, Phi);
> end if;
> end proc:
# Um die obige Prozedur fr folgende Arbeitsbltter anwendbar zu machen, speichern wir diese ab.
> save Proc_Calc_02, "Proc_Calc_02.m";
# Berechnung der Elementardrehungen
> n1 := UnitVector(1,3); Proc_Calc_02(n1,alpha,1): #Drehung um die raumfeste 1-Achse
;
> print(`Versor R =`, R);
> n2 := UnitVector(2,3); Proc_Calc_02(n2, beta,1): #Drehung um die raumfeste 2-Achse
;
> print(`Versor R =`, R);
> n3 := UnitVector(3,3); Proc_Calc_02(n3,gamma,1): #Drehung um die raumfeste 3-Achse
;
> print(`Versor R =`, R);
# Als Drehachse wird im nchsten Schritt die Raumdiagonale gewhlt. Der Drehwinkel ist :
> n:=Vector([1,1,1]): Proc_Calc_02(n, phi, 0): 
# Mit der Raumdiagonale als Drehachse und dem Drehwinkel   = /2 folgt:
> Proc_Calc_02(n, Pi/2, 1):
> print(`Versor R =`, R);
# Mit der Raumdiagonale als Drehachse und dem Drehwinkel   =  (Umklappung) folgt:
> Proc_Calc_02(n, Pi, 1):
# Der linearisierte Versor (cos H 1, sin H ) fr kleine Drehwinkel  ist
> Rlin:=subs(cos(phi)=1,sin(phi)=phi,R);
> 
;
