metric3calc.red 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. % calculation of metric tensor (3-dim space-time)
  2. off echo;
  3. on revpri;
  4. n:=3;
  5. operator x$
  6. x(0):=t; x(1):=lambda0; x(2):=lambda1;
  7. % rules
  8. trig1:={sin(~x)^2=>(1-cos(x)^2)}$ let trig1$
  9. % procedures
  10. procedure scalprod(a,b); begin
  11. integer n; n:=first(length(a))-1;
  12. result:=for i:=0:n-1 sum a(i)*b(i);
  13. return result end;
  14. procedure showmatrix(mm);begin integer m,n;l:=length(mm);m:=first(l)-1;n:=second(l)-1;matrix hm(m,n);for i:=0:m-1 do for j:=0:n-1 do hm(i+1,j+1):=mm(i,j); write hm end;
  15. procedure showvector(vv);begin scalar n;n:=first(length(vv))-1;matrix hv(n,1);for i:=0:n-1 do hv(i+1,1):=vv(i);write hv end;
  16. array f(n+1), dfdt(n+1), dfdl0(n+1), dfdl1(n+1)$
  17. % current radius
  18. a:=a0*sqrt(1-t^2);
  19. % surface of hyper sphere in t and lambda
  20. f(0):=a*cos(lambda0)*cos(lambda1);
  21. f(1):=a*cos(lambda0)*sin(lambda1);
  22. f(2):=a*sin(lambda0);
  23. f(3):=a0*t;
  24. for i:=0:n do dfdt(i):=df(f(i),x(0))$
  25. for i:=0:n do dfdl0(i):=df(f(i),x(1))$
  26. for i:=0:n do dfdl1(i):=df(f(i),x(2))$
  27. array g(n,n)$
  28. g(0,0):=scalprod(dfdt,dfdt)$
  29. g(0,1):=scalprod(dfdt,dfdl0)$
  30. g(0,2):=scalprod(dfdt,dfdl1)$
  31. g(1,0):=scalprod(dfdl0,dfdt)$
  32. g(1,1):=scalprod(dfdl0,dfdl0)$
  33. g(1,2):=scalprod(dfdl0,dfdl1)$
  34. g(2,0):=scalprod(dfdl1,dfdt)$
  35. g(2,1):=scalprod(dfdl1,dfdl0)$
  36. g(2,2):=scalprod(dfdl1,dfdl1)$
  37. write "f = "; showvector(f);
  38. write "df/dt = "; showvector(dfdt);
  39. write "g = "; showmatrix(g);
  40. off revpri;
  41. on echo;
  42. end;