数学建模社区-数学中国
标题: Mathematica-用 ContourPlot3D 绘制多面体 [打印本页]
作者: Asdmath2020 时间: 2020-3-24 15:49
标题: Mathematica-用 ContourPlot3D 绘制多面体
曲面除了可以用参数方程的形式表示之外,还可以用隐函数的形式表达,即表示为 F(x, y, z) = 0 的解。这种曲面又称之为等值曲面,因为曲面上的每个点都满足 F(x, y, z) = 0 这一条件。Mathematica 提供了绘制等值曲面的函数 ContourPlot3D。不过在这篇文章里,我们并不用它来绘制各种婀娜多姿的曲面,而是尝试用它探索、绘制一些"多面体"。. {7 Z8 E& _% B3 M
从最简单的开始( V t( B' n- O6 M( w& {8 B! U
让我们从最简单的,大家耳熟能详的球面方程开始:2 w( o0 }4 K+ S$ |/ E
7 d7 O3 w1 K7 x/ f方程 x^2+y^2+z^2==1 的意义非常简单:每个点到原点的距离都是 1,这就形成了一个球面。相比较之下,球面的参数方程就不是这么简单了:0 r# w; {4 Q+ |; r% G
多面体' z& b6 t% L% K2 ?/ ] v
从球面方程出发,我们可以看一下更一般的形式,比如 x^n+y^n+z^n==1 的图形是什么样子的:
9 B; _) S5 Z' ~3 t9 }
& s7 J7 m8 A4 ]9 [- x可以看到随着 n 的值不断增大,方程表示的曲面越来越接近一个立方体。这是为什么呢?我并不能完全解释,只能提出这么一个猜测。考虑如下表达式:2 t, {7 E$ w4 N2 u6 t
% P+ W; w; i6 r1 b+ @1 k这是 Lp 范数的定义,当 p 趋向于正无穷时,上述表达式的极限是:
+ B2 u, h" ?) x$ N: \- g
' P+ b* R: T3 \
也就是 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 可定义求各种多面体法向量的函数如下:
; q. q V3 r; P. E5 B* v! i. k+ S
+ M0 `: |. }! L" a, w接下来就让我们用实际计算来验证一下这个猜测吧:8 J5 _; ?( G6 t/ D5 s0 X; M# G
正八面体
5 L$ h" e& ~! @2 f求正八面体的法向量:
; V- ~8 F1 [9 l; y' Z化简并去除方向刚好相反的法向量,因为之前方程的常数项 ±1 可以由一个法向量得到两个相对的面的方程:
; B8 l0 o) U3 d' W) X* X- B3 m
# C1 J" G8 p( T% H$ o
然后就可以根据这个求八面体渐近方程了:
; D* f8 V! h* M& O% u$ K
8 p& f3 P- ^6 v5 Y* T
w& g* B! x. v% D正十二面体
* C4 s- |% Y# ?+ Z/ v9 R正十二面体的法向量:
$ g3 J0 T) I1 p1 w
( ?" X& C7 y( S8 S. i. Q1 S" Y化简并去除方向刚好相反的:
$ h& G Y' a" H/ d2 |' d" o' n
0 O3 L0 |- v! y2 B隐函数表达式:$ ?% K* H6 B1 b- y! n" _
, }4 { u9 [) s3 G$ k9 ?, l: z9 c) h- r' m- o
为了计算方便,我们用数值近似取代根号形式:
绘制图形,可以看到,随着次数 n 的不断升高,图形越来越接近正十二面体:# f5 g' h7 `1 [7 [+ e/ X7 ^
" L. N. D' F( {/ O' L: _, ?十二面体
5 B9 t+ d1 J) m( `! l) H
计算各个面的法向量:
, F$ j0 e5 e1 ?* _: [
3 V1 n; T' i9 _. r% p
化简并去除方向相反的:
2 S8 L( k$ Z! V6 h% @+ [9 |& O- n" F6 c, n
得到方程左侧表达式:
8 V! [4 q! O$ I( j6 Y( e) m
为了计算方便,取近似值:% o' V, ^! u1 `7 Q7 W i2 \
% a/ ^3 D/ j2 B# V3 {
绘制正二十面体的曲面方程:
/ `: w7 q8 A. K4 z) C
绘制正二十面体的曲面方程:
1 B% ^, S, ?2 }3 }/ @: i
复合多面体
从上面的计算可以看到,根据猜测做的推论基本上是对的:确实据此得到了各种正多面体的渐近方程并成功绘制了出来。但同时也可以看到,这种方法有很多局限性。首先,所生成的多面体必须有平行的相对的面,这样采用的法向量才能一个顶俩,发挥应有的作用得到对应的多面体。五种正多面体里,只有四种满足这个条件,还剩下一个正四面体不能用这种方法表示。其次,用这种方法只能表示凸多面体,所谓凸多面体,就是内部任意两点的连线仍然落在内部的多面体。这两个问题都是可以解决的,解决方法是引入指数函数。. o' C6 c% |( A- d/ {( a0 l, B
正四面体
5 X; d$ s2 n1 S& q u- F! g- Z% r计算正四面体的法向量:
3 u! w8 `/ c; R, L
化简:
如果用之前的高次方程的方法,那么只能得到一个朝向比较特别的正八面体,因为每个法向量都生成了两个平面:
- @, `* E9 i/ t# Q' x5 W% |/ c# U
4 M5 I( G! K. [" y/ h) S d
而改用指数,则可得到如下表达式:# O" ^: Z7 h/ r9 K. {: y
% V# S6 ~- B9 S% M8 }" g K6 c以此作为隐函数果然可以画出正四面体:5 e: ?& q/ c# b: g7 R
1 B$ j& z7 c% D& a2 q
为什么这样可行?我也只能给个近似的猜测:对 E^(a x + by + c z)==C 这样的方程,两边取对数就是 a x+ b y+ c z==log C 这就是一个平面的方程,把几个这样的平面方程加起来,就"围成"了一个多面体。而指数的增长保证了每个方向上不会受其它项的影响,保持大体是个平面。
, t) b( g* Q0 y# V% w) _5 ]! }
另外还值得指出的是,可以在指数上再加次数,让这样生成的多面体的边缘更加"锐利":
6 v/ {5 v8 X# N0 R; h$ r
( U* [7 p! C5 E5 O1 Y8 A6 q+ I
星形八面体
在各种各样的多面体中,有一类多面体可以看作是若干基本的多面体彼此叠合组成,我们称之为复合多面体。比如下图所示的星形八面体,就可以看作两个正四面体彼此叠合而成。
* |2 U+ b/ h* ]6 c: f+ y( b2 G& _
. j6 s |" K2 N8 U5 t9 f* C, |观察这个复合多面体的面的组成指标可以发现,前四组只包含顶点 2、4、5、8,后四组只包含顶点 1、3、6、7。这恰好是各自组成两个正四面体。我们可以照样算出这八个面的法向量,然后分组各自生成两个正四面体曲面:0 s8 h/ h5 u Z7 @/ e1 c: ^2 F
( ? j. V! l, u8 C求法向量,化简并分组:
. D, n" Q3 j" Y& z' ~
6 O! Q0 S$ |3 B0 t/ @得到两个指数和的表达式:7 m9 K1 X* i6 t5 C6 G: Y4 a1 l/ i
3 p l) p' k1 j# w0 J; s( @( P分别绘制可以看到两个正四面体:
& ]/ C4 I% q7 J8 c9 P9 ^
0 O! N- [; G& |3 r @; Z8 F
如何从这两个四面体得到想要的星形八面体呢?直接相加肯定是不行的,那样得到的就是正八面体了。这里我们采用 The Nature of Mathematics and the Mathematics of Nature 一书中提到的一个小技巧:把两个方程表达式再次放到指数上。这个技巧称为 Exponential Scale:
' a1 ~4 C4 E+ u1 p& N- v2 {+ N; Z; ~
6 R9 M+ ? g- K$ v4 e可以看到,这个方程确实可以绘制出星形八面体:7 B( Y' E) L" [& C; e* k
' A8 b+ Y1 n9 L4 [; E0 H可以把旋转观察这个星形八面体曲面的过程输出为动画:
# U( E; J& ~6 @- T3 v$ u
8 h3 V. d a& X \2 q
; U. q5 |& u" ^1 _; n
! b4 }1 i, y6 c) I
五复合正四面体
: u5 Y! R' P! ?0 V
我们可以再举一个例子,五复合正四面体,这是由五个正四面体内接于一个正十二面体形成的复合多面体:
: J7 ^+ W" q& B$ z照例求面法向量,化简并分组:
! l# k2 t! t+ ]% E' @7 A& E) T, j. w* B3 S5 P- v$ r: v
得到方程:# w% u! Y, |9 h4 w$ P' w2 U9 |
1 p5 I; F `/ y5 G! u, J3 c
绘制可以得到五复合正四面体的近似曲面(警告:由于项数太多,运行绘制速度很慢,运行时请耐心等待):
( D+ R4 R! o) w- ]
: A$ J. Q9 ?: W* d) [( c& a
我们也用它生成一个旋转观察的动图:
B+ |" C5 F8 i( `" L2 V& |, x+ A# S" h
% F- m p, s* F! K5 a
更多的复合多面体
1 u5 o' c% u9 g8 F只要是由凸多面体组成的复合多面体,理论上都可以用上面的方法,先求得各个多面体的方程,然后“抬升”到指数位置,得到复合多面体的方程。Mathematica 提供的PolyhedronData 函数里有许多复合多面体,我全部列在下面,感兴趣的读者可以自己实验生成想要的复合多面体曲面。+ y, P3 K4 q) {) b1 U
- V9 I( i" S& }3 x9 y
1 F' S# c( ^/ S8 ^* H) i对此有兴趣的,欢迎联系我们共同探讨。
: z/ y; Q3 t: M( smarket@asdoptics.com $ T a; c! @1 x) k( c' ~8 m
www.asdoptics.com
1 R. C% S2 w+ c6 |( s8 F9 @& m. C! f, Y# [9 N5 D& y" ?" Q" l/ v7 ]' D
-
12.jpg
(7.97 KB, 下载次数: 415)
作者: 宏心 时间: 2020-5-14 13:27
变幻无穷,无穷* _! ^/ o8 G, Z' }4 e
| 欢迎光临 数学建模社区-数学中国 (http://www.madio.net/) |
Powered by Discuz! X2.5 |