数学建模社区-数学中国

标题: Mathematica-用 ContourPlot3D 绘制多面体 [打印本页]

作者: Asdmath2020    时间: 2020-3-24 15:49
标题: Mathematica-用 ContourPlot3D 绘制多面体
曲面除了可以用参数方程的形式表示之外,还可以用隐函数的形式表达,即表示为 F(x, y, z) = 0 的解。这种曲面又称之为等值曲面,因为曲面上的每个点都满足 F(x, y, z) = 0 这一条件。Mathematica 提供了绘制等值曲面的函数 ContourPlot3D。不过在这篇文章里,我们并不用它来绘制各种婀娜多姿的曲面,而是尝试用它探索、绘制一些"多面体"。4 Z( f/ v& `$ ?
从最简单的开始
+ y5 h- O+ ^. r* d  U8 V让我们从最简单的,大家耳熟能详的球面方程开始:
2 p" k2 n7 _2 |- ~6 q+ ]2 E) Q! g 11.jpg 0 T. ?0 d8 ^( L( G; Z
方程 x^2+y^2+z^2==1 的意义非常简单:每个点到原点的距离都是 1,这就形成了一个球面。相比较之下,球面的参数方程就不是这么简单了:7 O; Z* Y) L/ ~1 u7 |
多面体
1 ~3 o# v+ Z3 p2 _) h从球面方程出发,我们可以看一下更一般的形式,比如 x^n+y^n+z^n==1 的图形是什么样子的:
1 {! {; V7 }! O# I6 b: B$ p 13.jpg
- D% x& Y+ t5 _# R7 Q# \# @可以看到随着 n 的值不断增大,方程表示的曲面越来越接近一个立方体。这是为什么呢?我并不能完全解释,只能提出这么一个猜测。考虑如下表达式:
0 m( k' x" E+ ? 02.png . z# ?- O" ^) L. i) \
这是 Lp 范数的定义,当 p 趋向于正无穷时,上述表达式的极限是:
+ t: C0 |7 V: d; Y 03.png % Z8 q, N! a( s3 X
也就是 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 可定义求各种多面体法向量的函数如下:
; o8 ~7 B: _0 \+ z9 `* e
14.jpg
: K1 C* f! t5 s" I接下来就让我们用实际计算来验证一下这个猜测吧:8 J6 `! |+ @5 x' f$ o, n0 z3 o) s
正八面体

0 h8 w8 N& K2 V  _8 M' c8 H% P
求正八面体的法向量:
04.png
6 `3 [. o9 c- d* O1 t* S; P化简并去除方向刚好相反的法向量,因为之前方程的常数项 ±1 可以由一个法向量得到两个相对的面的方程:
6 i/ f9 `$ I3 E  _  J 05.png
* h8 q$ g4 Z2 z- J4 w然后就可以根据这个求八面体渐近方程了:
% j& Q6 C9 M& k: [ 06.png
% u. ^& }5 |# h; K- l 15.jpg
# ]) k8 V$ W% d; v3 s8 b4 l. p) L
正十二面体
. \0 x4 `9 n, o1 v# M2 e8 l0 H( m
正十二面体的法向量:
07.png
# b4 T/ K7 `( X6 r1 [; i
# w! w$ m' W0 x# t. T化简并去除方向刚好相反的:
7 a! u) C, j5 h% U9 n 16.jpg
2 S  f7 M$ L5 I4 l1 D# v( ^7 ?$ x1 l
隐函数表达式:5 ^- z; H7 W+ H0 h
08.png
% H; v# n5 [0 B' D1 d7 t/ r' I7 L4 {  X* V$ B" V
为了计算方便,我们用数值近似取代根号形式: 09.png 绘制图形,可以看到,随着次数 n 的不断升高,图形越来越接近正十二面体:5 V# ~2 M1 J/ j& O7 W7 u6 F
17.jpg
: D+ s+ p  f+ @4 E, B9 ?5 Z1 A
十二面体
0 V9 z  E# }# x& Y- h) F& k) c
计算各个面的法向量:
# }+ H7 S9 `* O  [7 l4 A 10.png
! p& F( h. a9 S7 E* E( i" m
化简并去除方向相反的:
18.jpg 3 V, E; H0 I( e; a
, v4 @% W9 a+ q4 _
得到方程左侧表达式: 19.jpg
2 L5 |3 g% V7 h' |为了计算方便,取近似值:9 W1 S  S4 s- Q) `7 i
20.jpg & B% e. I0 b6 h' Q$ [7 s: j# [! }
绘制正二十面体的曲面方程:
21.jpg
9 Q8 h' A$ s7 W6 t2 W1 L# e: T
绘制正二十面体的曲面方程:
22.jpg 3 p+ Q: P. B7 y1 T
复合多面体
从上面的计算可以看到,根据猜测做的推论基本上是对的:确实据此得到了各种正多面体的渐近方程并成功绘制了出来。但同时也可以看到,这种方法有很多局限性。首先,所生成的多面体必须有平行的相对的面,这样采用的法向量才能一个顶俩,发挥应有的作用得到对应的多面体。五种正多面体里,只有四种满足这个条件,还剩下一个正四面体不能用这种方法表示。其次,用这种方法只能表示凸多面体,所谓凸多面体,就是内部任意两点的连线仍然落在内部的多面体。这两个问题都是可以解决的,解决方法是引入指数函数。
- A/ P7 I) y/ u
正四面体

: d5 q0 o7 `4 ]1 |计算正四面体的法向量:
6 [! {: J1 C; C. n  k 11.png
化简:
12.png 如果用之前的高次方程的方法,那么只能得到一个朝向比较特别的正八面体,因为每个法向量都生成了两个平面: 13.png
' S, f8 ]/ V- }; k* {4 E  O 23.jpg ; M- Z' ^( V4 K6 N3 b" ~; ]  k
而改用指数,则可得到如下表达式:
/ {& q0 x( q5 N+ Q* A9 X; B; w 14.png / u  Z6 }2 D; [# s  I
以此作为隐函数果然可以画出正四面体:" h+ p  Q+ |% ^5 ?; @
24.jpg , I' f; l1 P; o& n- l) P
为什么这样可行?我也只能给个近似的猜测:对 E^(a x + by + c z)==C 这样的方程,两边取对数就是 a x+ b y+ c z==log C 这就是一个平面的方程,把几个这样的平面方程加起来,就"围成"了一个多面体。而指数的增长保证了每个方向上不会受其它项的影响,保持大体是个平面。

$ p- e5 {7 _: X- {# O: w& j
另外还值得指出的是,可以在指数上再加次数,让这样生成的多面体的边缘更加"锐利":
1 j2 N- Q/ a1 O2 l
25.jpg
% c$ C( D1 Q  c; _' Y' n5 U
星形八面体
在各种各样的多面体中,有一类多面体可以看作是若干基本的多面体彼此叠合组成,我们称之为复合多面体。比如下图所示的星形八面体,就可以看作两个正四面体彼此叠合而成。! N, T: t) Z0 f$ Z& q
26.jpg 9 o' ^* d* ]% a; V
观察这个复合多面体的面的组成指标可以发现,前四组只包含顶点 2、4、5、8,后四组只包含顶点 1、3、6、7。这恰好是各自组成两个正四面体。我们可以照样算出这八个面的法向量,然后分组各自生成两个正四面体曲面:$ {, T0 v1 j) [% Q, j8 G. `0 ]
15.png
1 X8 D3 b" R1 [; M& f: ?: N+ Z( E求法向量,化简并分组:4 o7 w2 M+ O- m
16.png 8 _+ k: p$ @4 G6 l' L& j
得到两个指数和的表达式:+ N# c/ @/ d: G* \6 `
17.png : \' i2 H+ o, @. D* ?  V
分别绘制可以看到两个正四面体:9 m' ?3 K" R1 e: n' O* \' ^
27.jpg 3 ]1 H) Y" Y/ J
如何从这两个四面体得到想要的星形八面体呢?直接相加肯定是不行的,那样得到的就是正八面体了。这里我们采用 The Nature of Mathematics and the Mathematics of Nature 一书中提到的一个小技巧:把两个方程表达式再次放到指数上。这个技巧称为 Exponential Scale:$ u+ B" N. z" ^6 l+ s
18.png % S: n5 u2 ]5 M, Z% P
可以看到,这个方程确实可以绘制出星形八面体:
1 r/ y7 C$ z: m( Q$ X 28.jpg   v8 `+ M9 U4 ], p- ^
可以把旋转观察这个星形八面体曲面的过程输出为动画:: F2 M) F8 K6 D
19.png
! S3 e7 _. [3 o4 h, @ 20.png $ q: M; g+ g9 f8 i
微信图片_20200324153944.gif
+ k# F: w% ^+ L2 _
五复合正四面体
, b7 f+ _- Y2 ]" J
我们可以再举一个例子,五复合正四面体,这是由五个正四面体内接于一个正十二面体形成的复合多面体:
29.jpg
/ g' A. g# }9 L. U, g2 |
照例求面法向量,化简并分组:
30.jpg
& B: E! @5 H  y& _; ^
% i+ @- {8 h7 ?. C, R! q& R得到方程:- G  ~4 k1 [+ O$ h8 D: Q3 b2 o& `
31.jpg ( Z' L) ~6 F+ A$ j+ L* A
绘制可以得到五复合正四面体的近似曲面(警告:由于项数太多,运行绘制速度很慢,运行时请耐心等待):
32.jpg
( [# s/ O2 a. k3 Q0 D
$ o* ]1 i5 j) b: p
我们也用它生成一个旋转观察的动图:
33.jpg
: H  O3 g( P/ }* P
: ~! b7 z( e! z3 C% ]7 W; A' k 微信图片_20200324154410.gif
) U3 n; ^8 }0 `3 V7 `3 P/ x
更多的复合多面体

! e" b4 }+ @4 X$ Z只要是由凸多面体组成的复合多面体,理论上都可以用上面的方法,先求得各个多面体的方程,然后“抬升”到指数位置,得到复合多面体的方程。Mathematica 提供的PolyhedronData 函数里有许多复合多面体,我全部列在下面,感兴趣的读者可以自己实验生成想要的复合多面体曲面。. n' ]1 j- `! q: y& _' Q
21.png % l. v$ r1 W; J
34.jpg + \9 b) B: D+ w& G5 Q
对此有兴趣的,欢迎联系我们共同探讨。
+ y, L) @" P4 h& c8 D$ T/ ~) [( Imarket@asdoptics.com
5 K& ]% Z+ D* j9 Y# m: y( I4 Iwww.asdoptics.com
" @. H; |/ w5 W! }
8 a! f: O( }# {. P

12.jpg (7.97 KB, 下载次数: 377)

12.jpg


作者: 宏心    时间: 2020-5-14 13:27
变幻无穷,无穷/ i/ i3 t' p" a* Y3 N





欢迎光临 数学建模社区-数学中国 (http://www.madio.net/) Powered by Discuz! X2.5