曲面除了可以用参数方程的形式表示之外,还可以用隐函数的形式表达,即表示为 F(x, y, z) = 0 的解。这种曲面又称之为等值曲面,因为曲面上的每个点都满足 F(x, y, z) = 0 这一条件。Mathematica 提供了绘制等值曲面的函数 ContourPlot3D。不过在这篇文章里,我们并不用它来绘制各种婀娜多姿的曲面,而是尝试用它探索、绘制一些"多面体"。
( a8 j+ }- f2 \3 k& T从最简单的开始
V6 o2 p' f5 J让我们从最简单的,大家耳熟能详的球面方程开始:, \+ H/ P/ ^( Q( P+ P& o9 q
$ h* f" J, X3 ^方程 x^2+y^2+z^2==1 的意义非常简单:每个点到原点的距离都是 1,这就形成了一个球面。相比较之下,球面的参数方程就不是这么简单了:
; t" J; N" `- w! t: Z. S; }# f多面体2 Z) Y( ^3 ]' Z! @1 K4 I) Q
从球面方程出发,我们可以看一下更一般的形式,比如 x^n+y^n+z^n==1 的图形是什么样子的: : [4 R9 o+ z! }; S( \
5 @2 T/ n. s. N8 v( K) d
可以看到随着 n 的值不断增大,方程表示的曲面越来越接近一个立方体。这是为什么呢?我并不能完全解释,只能提出这么一个猜测。考虑如下表达式:
) ~* e% @$ ?8 g
/ q4 _" D( q& b& {
这是 Lp 范数的定义,当 p 趋向于正无穷时,上述表达式的极限是:
/ w ]3 d R- k6 T+ W7 C# r
3 h& H" |+ `& k+ ]也就是 n 个绝对值中的最大值。把这个结论放到我们的方程 x^n+y^n+z^n==1 上,当 n 不断变大时,在不同方向上就不断接近 | x | == 1、| y | == 1、| z | == 1 三个方程,而这三个方程恰恰是立方体的六个面:x = ±1、y= ±1、z= ±1。根据这个猜测,我们只要能知道多面体各个面的平面方程,就能类比的求得类似上述立方体的“多面体渐近方程”。更进一步的,多面体各个面的平面方程,只要知道面法向量就可以确定平面方程了,如果面法向量是 (a, b, c),则成对的平面方程就是 a x+b y+ c z = ±1。 利用 PolyhedronData 可定义求各种多面体法向量的函数如下: - }# o) s+ i7 }" z8 M% x* N
9 ~1 A' a8 ?; g9 q) ~8 V/ D7 S
接下来就让我们用实际计算来验证一下这个猜测吧:! \' g( f1 l0 ], ?* L# D% |1 \
正八面体
2 |" l$ _% U5 k0 U- z: I, y* t求正八面体的法向量:
' q" `, Q" b3 c2 w- N9 w化简并去除方向刚好相反的法向量,因为之前方程的常数项 ±1 可以由一个法向量得到两个相对的面的方程:: {5 w" [* I$ z2 y: b! {' A3 Q5 [
% W. w; T6 P$ b* @2 o然后就可以根据这个求八面体渐近方程了:
, Z7 P/ f& Y2 X$ Y: w# O
% r1 L( h! C3 r' z' E9 ]& Q
+ \# y' U! b! H# q4 W正十二面体 3 C9 a+ f( Y: P4 J h. b
正十二面体的法向量:
1 V' U! T: h" N0 z
1 _; @7 q& p8 G) R0 L
化简并去除方向刚好相反的:
4 z3 a( a- w- }$ z! x3 L, }4 ]
; \" a" d9 x6 ^隐函数表达式:7 A! h; N5 l2 d& g# G
$ x, R2 k# q2 \
0 i/ ^ D( h( D: k- d5 V1 G
为了计算方便,我们用数值近似取代根号形式:
绘制图形,可以看到,随着次数 n 的不断升高,图形越来越接近正十二面体:
) C0 w: x; I- ^5 z7 X
7 w# |4 n# K. U$ ^( c8 t! i
十二面体 # D1 E6 J5 _! a* l. z' ~& l( \
计算各个面的法向量:3 U* S0 @) J- c6 J
" H. z& [1 ~% N2 G化简并去除方向相反的:
K: S, B- i- c9 C+ o z0 H7 X$ x" Q1 \0 Q4 p2 A
得到方程左侧表达式:
, {/ r0 `1 p$ u5 U5 e为了计算方便,取近似值:. U1 D c+ R. {/ O- M; n
. u' ]7 F# V8 Y m2 N, W
绘制正二十面体的曲面方程:
7 z4 ^. g# _7 t K" G& Q) z
绘制正二十面体的曲面方程:
' h3 b' k* b9 P: C4 {: l复合多面体 从上面的计算可以看到,根据猜测做的推论基本上是对的:确实据此得到了各种正多面体的渐近方程并成功绘制了出来。但同时也可以看到,这种方法有很多局限性。首先,所生成的多面体必须有平行的相对的面,这样采用的法向量才能一个顶俩,发挥应有的作用得到对应的多面体。五种正多面体里,只有四种满足这个条件,还剩下一个正四面体不能用这种方法表示。其次,用这种方法只能表示凸多面体,所谓凸多面体,就是内部任意两点的连线仍然落在内部的多面体。这两个问题都是可以解决的,解决方法是引入指数函数。5 D/ Y; l6 x' Z" O" R/ `5 i# f4 e
正四面体 " _+ x o. A& ?0 P' v3 U2 E
计算正四面体的法向量:
3 N9 I" M' k. Q
化简:
如果用之前的高次方程的方法,那么只能得到一个朝向比较特别的正八面体,因为每个法向量都生成了两个平面:
0 H1 T" r- }7 \6 R! [0 q, O
# {! Y' ?2 F6 T! J/ j( M5 [/ D
而改用指数,则可得到如下表达式:6 H& F) ^3 I1 W. |/ h4 i# r
P; l8 I& [! K! p, K; C! Y9 A
以此作为隐函数果然可以画出正四面体:% \0 z4 N9 ~% U% m* l, T
3 Z+ o" N4 _6 s为什么这样可行?我也只能给个近似的猜测:对 E^(a x + by + c z)==C 这样的方程,两边取对数就是 a x+ b y+ c z==log C 这就是一个平面的方程,把几个这样的平面方程加起来,就"围成"了一个多面体。而指数的增长保证了每个方向上不会受其它项的影响,保持大体是个平面。 0 V+ e6 H+ r: Y/ Y& j0 z
另外还值得指出的是,可以在指数上再加次数,让这样生成的多面体的边缘更加"锐利":
+ X) V% {, \8 R8 w9 z/ e* c
8 t* f$ \+ [; e! D0 O5 p星形八面体 在各种各样的多面体中,有一类多面体可以看作是若干基本的多面体彼此叠合组成,我们称之为复合多面体。比如下图所示的星形八面体,就可以看作两个正四面体彼此叠合而成。
8 j7 y3 `& _4 f
8 d! N A- w/ I! Y6 Q: z观察这个复合多面体的面的组成指标可以发现,前四组只包含顶点 2、4、5、8,后四组只包含顶点 1、3、6、7。这恰好是各自组成两个正四面体。我们可以照样算出这八个面的法向量,然后分组各自生成两个正四面体曲面:
+ q1 o, a0 ^" R, _ S
2 a5 q3 T; s. X8 J/ O
求法向量,化简并分组:
( o& d& S6 \4 K% ?0 a m
$ |7 W* N2 A/ ~. o5 G1 v- V
得到两个指数和的表达式:
; t+ f2 t& N% U, W# F
% n6 J' j; z5 F' H" v
分别绘制可以看到两个正四面体: `# b" O- G" p+ c: t" r& C6 {
/ B% C4 r# d% d$ r7 ^( f
如何从这两个四面体得到想要的星形八面体呢?直接相加肯定是不行的,那样得到的就是正八面体了。这里我们采用 The Nature of Mathematics and the Mathematics of Nature 一书中提到的一个小技巧:把两个方程表达式再次放到指数上。这个技巧称为 Exponential Scale:4 f# M) L' h6 y2 k
. {+ X. D$ F3 E4 B o可以看到,这个方程确实可以绘制出星形八面体:% x5 T( w! ?! o' i3 W
# ^8 h! w5 \0 [* n7 ^1 ], g8 K& v
可以把旋转观察这个星形八面体曲面的过程输出为动画:
" e- \, g1 Y3 _! x
: ?: |' r4 H" M) f( Y) R7 U% a2 W7 M5 C
8 u# i6 L6 x% L. O, ^; E
: L+ L) X: E) F& g0 \4 x/ J* z五复合正四面体 ( V. }( o2 C! c4 ?; k
我们可以再举一个例子,五复合正四面体,这是由五个正四面体内接于一个正十二面体形成的复合多面体:
( Y" o& n7 E2 j% D$ J2 I$ h3 T
照例求面法向量,化简并分组:
: G: A! G6 Q# N k1 e8 {- I# q% c- E
得到方程:& E* u/ m; B" c" K- z5 M1 T
8 u# O2 u4 x" j+ q8 j- T2 O绘制可以得到五复合正四面体的近似曲面(警告:由于项数太多,运行绘制速度很慢,运行时请耐心等待):
0 y, |/ q: \* x# s
; H: }9 F! [2 @/ K; h% V7 B% W我们也用它生成一个旋转观察的动图:
1 d+ V2 A V- ]" {8 d% m
9 Z" g8 t7 d+ X6 S) j2 w
A$ r( @( y) P X
更多的复合多面体 : ?, a3 [3 V M5 L; t4 B! i
只要是由凸多面体组成的复合多面体,理论上都可以用上面的方法,先求得各个多面体的方程,然后“抬升”到指数位置,得到复合多面体的方程。Mathematica 提供的PolyhedronData 函数里有许多复合多面体,我全部列在下面,感兴趣的读者可以自己实验生成想要的复合多面体曲面。
- S5 V& N3 j, g1 \
8 L( t9 V" O2 c3 r5 R, B+ r! R
: Z. v7 r% e; k. k' I
对此有兴趣的,欢迎联系我们共同探讨。1 A$ H) H6 K+ Z1 K- g
market@asdoptics.com
3 b9 Q5 D8 B% ~$ J% R# g. Twww.asdoptics.com
: Q6 s' j1 b9 [2 v7 m7 C- @
, ^$ A% R1 R5 e. H |