forked from FriendsOfCADability/CADability
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathOffsetSurface.max.txt
More file actions
75 lines (63 loc) · 1.63 KB
/
OffsetSurface.max.txt
File metadata and controls
75 lines (63 loc) · 1.63 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
load("vect");
/* Definiere die allgemeine Vektorfunktion f(u, v) */
f(u, v) := [x(u, v), y(u, v), z(u, v)];
/* Definiere die partiellen Ableitungen */
dfdu : diff(f(u, v), u);
dfdv : diff(f(u, v), v);
dfduu : diff(f(u, v), u, 2);
dfdvv : diff(f(u, v), v, 2);
dfduv : diff(f(u, v), v, 1, u, 1);
dfduuu : diff(f(u, v), u, 3);
dfdvvv : diff(f(u, v), v, 3);
dfduvv : diff(f(u, v), v, 2, u, 1);
dfduuv : diff(f(u, v), v, 1, u, 2);
subst_d : [df_du=dfdu, df_dv=dfdv];
/* Berechne das Kreuzprodukt und normiere es */
n : dfdu ~ dfdv;
norm_n : sqrt(n[1]^2 + n[2]^2 + n[3]^2);
N : n / norm_n;
/* Definiere die neue Funktion o(u, v) */
o(u, v) := f(u, v) + d * N;
/* Berechne die partiellen Ableitungen von o(u, v) */
dod_u : diff(o(u, v), u);
dod_v : diff(o(u, v), v);
dod_uv: diff(o(u,v),u,1,v,1);
dod_uu: diff(o(u,v),u,2);
dod_vv: diff(o(u,v),v,2);
subst(df_du,dfdu,
subst(df_dv,dfdv,
subst(df_duu,dfduu,
subst(df_dvv,dfdvv,
subst(df_duv,dfduv,dod_u)))));
subst(df_du,dfdu,
subst(df_dv,dfdv,
subst(df_duu,dfduu,
subst(df_dvv,dfdvv,
subst(df_duv,dfduv,dod_v)))));
subst(df_du,dfdu,
subst(df_dv,dfdv,
subst(df_duu,dfduu,
subst(df_dvv,dfdvv,
subst(df_duv,dfduv,
subst(df_duuu,dfduuu,
subst(df_duuv,dfduuv,
subst(df_duvv,dfduvv,
subst(df_dvvv,dfdvvv,dod_uu)))))))));
subst(df_du,dfdu,
subst(df_dv,dfdv,
subst(df_duu,dfduu,
subst(df_dvv,dfdvv,
subst(df_duv,dfduv,
subst(df_duuu,dfduuu,
subst(df_duuv,dfduuv,
subst(df_duvv,dfduvv,
subst(df_dvvv,dfdvvv,dod_vv)))))))));
subst(df_du,dfdu,
subst(df_dv,dfdv,
subst(df_duu,dfduu,
subst(df_dvv,dfdvv,
subst(df_duv,dfduv,
subst(df_duuu,dfduuu,
subst(df_duuv,dfduuv,
subst(df_duvv,dfduvv,
subst(df_dvvv,dfdvvv,dod_uv)))))))));