Allgemeine Relativitätstheorie mit dem Computer
General Theory of Relativity on the Computer
Vorlesung gehalten an der J.W.Goethe-Universität in Frankfurt am Main (Sommersemester 2016)
von Dr.phil.nat. Dr.rer.pol. Matthias Hanauske
Frankfurt am Main 11.04.2016
Erster Vorlesungsteil: Allgemeine Relativitätstheorie mit Maple
Einführung in Maple
Getting started
data:image/s3,"s3://crabby-images/d6f60/d6f60e97fb282f51b7a705c50f7e69d8ccdb98f0" alt="`+`(`*`(3, `*`(exp(5))), `*`(sqrt(7)))" |
(1.1) |
> |
evalf(3*exp(5)+sqrt(7)); |
data:image/s3,"s3://crabby-images/65381/653810fb3e066b4b6fc235a192936b594afbcb14" alt="447.8852286" |
(1.2) |
> |
Digits := 20:
evalf(3*exp(5)+sqrt(7)); |
data:image/s3,"s3://crabby-images/3cc4c/3cc4c2ecad46f23fbc6edd4fbf00469d0ca4aea1" alt="447.88522861879440085" |
(1.3) |
Symbolic Calculations
Definition of Variables and Functions
data:image/s3,"s3://crabby-images/28ca9/28ca9feb26e9469242b0134b199259f605602cec" alt="`:=`(A, 3)" |
(2.1.1) |
data:image/s3,"s3://crabby-images/38952/38952b31d77b859ee76c89f525422b3845b6c25e" alt="5" |
(2.1.2) |
data:image/s3,"s3://crabby-images/873ca/873ca46a2b6d5e16a1233aa19eb556a464cb0f51" alt="`:=`(f, sqrt)" |
(2.1.3) |
data:image/s3,"s3://crabby-images/d5a16/d5a16b5cd4f11ca64e5641d32afa9350275ddbb2" alt="2" |
(2.1.4) |
> |
g:=(x,y)->sin(x)+cos(y); |
data:image/s3,"s3://crabby-images/5ad84/5ad84e7e84faffa17ba28676c0e005e157431a6c" alt="`:=`(g, proc (x, y) options operator, arrow; `+`(sin(x), cos(y)) end proc)" |
(2.1.5) |
data:image/s3,"s3://crabby-images/38e30/38e309953d3a2f9f0850077ae9dd635f78173478" alt="2" |
(2.1.6) |
Simplification of expressions
> |
Exp1:=f(x)*(x^(5/2)+x^(3/2)); |
data:image/s3,"s3://crabby-images/f8a43/f8a435c8d34ada6ee755537055c645973ad3e031" alt="`:=`(Exp1, `*`(sqrt(x), `*`(`+`(`*`(`^`(x, `/`(5, 2))), `*`(`^`(x, `/`(3, 2)))))))" |
(2.2.1) |
data:image/s3,"s3://crabby-images/1f7d6/1f7d6fbd8aa57c99922ca15eb51f849dcfcc21b6" alt="`+`(`*`(`^`(x, 3)), `*`(`^`(x, 2)))" |
(2.2.2) |
> |
Exp2:=sin(x)^2+cos(x)^2; |
data:image/s3,"s3://crabby-images/1fd1a/1fd1a4aefeea2d68511897e5252401e6e0766d50" alt="`:=`(Exp2, `+`(`*`(`^`(sin(x), 2)), `*`(`^`(cos(x), 2))))" |
(2.2.3) |
data:image/s3,"s3://crabby-images/7a936/7a93632632d849f13370f62a2f64d2125efb839c" alt="1" |
(2.2.4) |
Symbolic differentiation and integration
data:image/s3,"s3://crabby-images/801f8/801f8021655d22b41bf228bdc329bf9bb0bc50a8" alt="`+`(`/`(`*`(`/`(1, 2)), `*`(`*`(sqrt(x)))))" |
(2.3.1) |
data:image/s3,"s3://crabby-images/4b444/4b44411b8cec3458e4b86204f4c1851e78da7659" alt="`+`(`*`(`/`(2, 3), `*`(`^`(x, `/`(3, 2)))))" |
(2.3.2) |
data:image/s3,"s3://crabby-images/0027f/0027fd43bb6be892dacd72fc34b230a07a300c0d" alt="`+`(`*`(`/`(10, 3), `*`(sqrt(5))))" |
(2.3.3) |
data:image/s3,"s3://crabby-images/b1d91/b1d912e463025942f184a6988bcac31b740b7098" alt="cos(x)" |
(2.3.4) |
> |
int(int(g(x,y),x=0..Pi),y=0..Pi); |
data:image/s3,"s3://crabby-images/fa790/fa7905f1ca8da6a2f7652313ec7e3292950d87d6" alt="`+`(`*`(2, `*`(Pi)))" |
(2.3.5) |
> |
Int(Int(g(x,y),x=0..Pi),y=0..Pi)=
int(int(g(x,y),x=0..Pi),y=0..Pi); |
data:image/s3,"s3://crabby-images/4b2aa/4b2aa480e0aa91ec90def5295aa3500ffecf7d24" alt="Int(Int(`+`(sin(x), cos(y)), x = 0 .. Pi), y = 0 .. Pi) = `+`(`*`(2, `*`(Pi)))" |
(2.3.6) |
Solving algebraic equations
data:image/s3,"s3://crabby-images/7fecd/7fecd202c237989a47480554b5a7081c2d629287" alt="`+`(`*`(`^`(x, 2)), `-`(`*`(3, `*`(x))), 1) = 0" |
(2.4.1) |
data:image/s3,"s3://crabby-images/7c155/7c15544a2e489a92f00cee4fc09ce0a2b27455b9" alt="`+`(`/`(3, 2), `*`(`/`(1, 2), `*`(`^`(5, `/`(1, 2))))), `+`(`/`(3, 2), `-`(`*`(`/`(1, 2), `*`(`^`(5, `/`(1, 2))))))" |
(2.4.2) |
data:image/s3,"s3://crabby-images/81288/81288e0569d0e7fb6eb2cc3635c4738b6d24be0e" alt="2.618033988, .381966012" |
(2.4.3) |
Solving ordinary differential equations
> |
DGL1:=diff(x(t),t)=3*x(t); |
data:image/s3,"s3://crabby-images/e91fc/e91fccf203a649ed9cacf7267093cbd454fa8fc5" alt="diff(x(t), t) = `+`(`*`(3, `*`(x(t))))" |
(2.5.1) |
data:image/s3,"s3://crabby-images/3830d/3830d2bbef6d8a7f9ab2fb4a88e1be7858d19703" alt="x(t) = `*`(_C1, `*`(exp(`+`(`*`(3, `*`(t))))))" |
(2.5.2) |
> |
dsolve({DGL1,x(0)=10},x(t)); |
data:image/s3,"s3://crabby-images/98ad8/98ad8c43b8155af75d54ff21e492220c0330b7ca" alt="x(t) = `+`(`*`(10, `*`(exp(`+`(`*`(3, `*`(t)))))))" |
(2.5.3) |
Numerical Calculations
Limit finding
> |
Limit(sin(x)/x,x=0)=limit(sin(x)/x,x=0); |
data:image/s3,"s3://crabby-images/7aa19/7aa19ed118fc56278dae5ee07bcbb53e47fb9a04" alt="Limit(`/`(`*`(sin(x)), `*`(x)), x = 0) = 1" |
(3.1.1) |
Minimum (maximum) of lists
data:image/s3,"s3://crabby-images/c986b/c986b8e16ac157dedb0f77dec35694ba1911e687" alt="{2, 7, 13, 32}" |
(3.2.1) |
data:image/s3,"s3://crabby-images/0bd38/0bd380bc737d1072b00acfae20b30f18b95b60a7" alt="2" |
(3.2.2) |
data:image/s3,"s3://crabby-images/6b5d8/6b5d8181b0d9ea2407aa70ff5dffc0917155b4bb" alt="32" |
(3.2.3) |
Interpolation
![[0, 1, 2, 3, 4]](images/MapleTutorium_30.gif) |
(3.3.1) |
> |
Yvalues:=[0.2,0.98,4.1,8.8,17]; |
![[.2, .98, 4.1, 8.8, 17]](images/MapleTutorium_31.gif) |
(3.3.2) |
> |
Fit(a+b*x^2, Xvalues, Yvalues, x); |
data:image/s3,"s3://crabby-images/5c3e2/5c3e267dc0429d5cefa61397d11d330590b0c343" alt="`+`(`-`(0.633103448275848246e-1), `*`(1.04655172413793096, `*`(`^`(x, 2))))" |
(3.3.3) |
Numerical integration
> |
int(1/exp(x*ln(x)), x=1..infinity); |
data:image/s3,"s3://crabby-images/944c4/944c4fbc92b157d0ec746a4d89ee5a8c9d481074" alt="int(`/`(1, `*`(exp(`*`(x, `*`(ln(x)))))), x = 1 .. infinity)" |
(3.4.1) |
> |
evalf(int(1/exp(x*ln(x)), x=1..infinity)); |
data:image/s3,"s3://crabby-images/3a347/3a34774afa0d579cd147863b98d8d25fc79d008d" alt=".7041699604" |
(3.4.2) |
Solving ordinary differential equations
> |
DGL2:=(t+1)^2*(diff(x(t),t,t))+(t+1)*(diff(x(t),t))+((t+1)^2-0.25)*x(t) = 0; |
data:image/s3,"s3://crabby-images/59e35/59e35809e0117756c3300c6404b45713ee96d22b" alt="`+`(`*`(`^`(`+`(t, 1), 2), `*`(diff(diff(x(t), t), t))), `*`(`+`(t, 1), `*`(diff(x(t), t))), `*`(`+`(`*`(`^`(`+`(t, 1), 2)), `-`(.25)), `*`(x(t)))) = 0" |
(3.5.1) |
> |
Ergebnis:=dsolve({DGL2, x(0) = 1, (D(x))(0) = 2}, type=numeric,output=listprocedure); |
> |
odeplot(Ergebnis,[t,x(t)],0..20,numpoints=1000); |
Visualisation of Data
2D plots
> |
f:=(x)->x^4-12*x^2;
plot(f(x),x=-4..4,color=blue); |
Contour plots
> |
with(plots):
f:=(x,y)->sin(x)+cos(y);
contourplot(f(x,y),x=-6..6,y=-6..6,filledregions = true); |
3D surface plots
> |
plot3d(f(x,y),x=-6..6,y=-6..6,axes=boxed,numpoints=1500); |
Spacecurves
> |
spacecurve([cos(t), sin(t), t], t = 0 .. 15,axes=boxed,thickness=3); |
Animations
> |
f:=(x,a)->x^4-a*x^2;
animate(f(x,a),x=-4..4,a=5..12,view=[-4..4,-40..100]); |
> |
f:=(x,y,t)->sin(x)+cos(t*y);
animate3d(f(x,y,t),x=-6..6,y=-6..6,t=1..2,axes=boxed,numpoints=2000); |
data:image/s3,"s3://crabby-images/b6458/b6458b529c1fc49653ee3bd465de4c418a1935b5" alt="proc (x, y, t) options operator, arrow; `+`(sin(x), cos(`*`(t, `*`(y)))) end proc" |
(4.5.1) |
data:image/s3,"s3://crabby-images/aebbd/aebbdd58a2080cf28e4feedca05a4a891658e0f1" alt="Plot" |
(4.5.1) |
Programming tools
Loops
> |
a:=1:
for i from 1 by 1 to 10 do
a:=a*i:
od:
a; |
data:image/s3,"s3://crabby-images/d9629/d9629bea55e9004dc2b7532dbaa860716eca1545" alt="3628800" |
(5.1.1) |
data:image/s3,"s3://crabby-images/fed62/fed62d06cd0feaa50727b912fcbbc709b39115f3" alt="3628800" |
(5.1.2) |
If procedures
> |
a:=12:
b:=34:
if b < a then
print("a is greater than b") else print("a is not greater than b")
end if: |
data:image/s3,"s3://crabby-images/667de/667deeaef2534bf98690422302d9f0534b8f1533" alt="a is not greater than b" |
(5.2.1) |
Examples
> |
Further Examples can be downloaded on the following internet page:
http://www.fias.uni-frankfurt.de/~hanauske/new/maple/ |