QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 11691|回复: 1
打印 上一主题 下一主题

Mathematica-用 ContourPlot3D 绘制多面体

[复制链接]
字体大小: 正常 放大

18

主题

1

听众

234

积分

升级  67%

  • TA的每日心情
    开心
    2020-5-21 11:09
  • 签到天数: 24 天

    [LV.4]偶尔看看III

    自我介绍
    数和光的世界

    邮箱绑定达人

    跳转到指定楼层
    1#
    发表于 2020-3-24 15:49 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta |邮箱已经成功绑定
    曲面除了可以用参数方程的形式表示之外,还可以用隐函数的形式表达,即表示为 F(x, y, z) = 0 的解。这种曲面又称之为等值曲面,因为曲面上的每个点都满足 F(x, y, z) = 0 这一条件。Mathematica 提供了绘制等值曲面的函数 ContourPlot3D。不过在这篇文章里,我们并不用它来绘制各种婀娜多姿的曲面,而是尝试用它探索、绘制一些"多面体"。
      ?: H2 X. a1 ^9 b* N' \从最简单的开始: V/ Q8 `! c" R% I# @
    让我们从最简单的,大家耳熟能详的球面方程开始:
    : t! `! F2 Y0 ^) z7 {* j7 N 11.jpg 6 a) O; g& S/ E
    方程 x^2+y^2+z^2==1 的意义非常简单:每个点到原点的距离都是 1,这就形成了一个球面。相比较之下,球面的参数方程就不是这么简单了:0 r3 h& |: U, }1 o: O
    多面体
    & a7 u% L1 Z2 r9 R9 b2 r从球面方程出发,我们可以看一下更一般的形式,比如 x^n+y^n+z^n==1 的图形是什么样子的: 7 B- B. Z3 ?+ ~
    13.jpg ( Y7 |4 L0 U$ U7 i
    可以看到随着 n 的值不断增大,方程表示的曲面越来越接近一个立方体。这是为什么呢?我并不能完全解释,只能提出这么一个猜测。考虑如下表达式:; p" N$ d$ y) M5 S7 ]
    02.png
    * f  t9 ]6 x; s( n, n  V( n这是 Lp 范数的定义,当 p 趋向于正无穷时,上述表达式的极限是:" l: R6 A0 T( Q8 {8 R# I8 v) G9 m. _
    03.png
    & _# \0 C& H7 y7 O0 ?
    也就是 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 可定义求各种多面体法向量的函数如下:
    2 _4 q7 R, ^4 f8 `
    14.jpg
    * |/ s$ d0 v) t! S% f9 N接下来就让我们用实际计算来验证一下这个猜测吧:
    4 d3 u0 h/ a1 ~" V! q( q7 K
    正八面体
    8 o' S" Y8 ?5 T: k; C' E
    求正八面体的法向量:
    04.png
    ( ?5 P8 J2 Y' u2 N! G' P* A2 M  y化简并去除方向刚好相反的法向量,因为之前方程的常数项 ±1 可以由一个法向量得到两个相对的面的方程:
    " E* u% c: O+ u" ]) t8 Z: O 05.png 8 |* g5 i4 D$ N
    然后就可以根据这个求八面体渐近方程了:
    % A1 }' X+ ]/ l) P 06.png
    " x4 f" H! _6 f 15.jpg
    0 G/ P+ g! I) y: ^
    正十二面体

    7 v8 P6 \+ D- r6 r/ L1 r- L
    正十二面体的法向量:
    07.png : L, ]! ^$ q" p8 M7 _! v

    ( R6 E" q" v, w" m/ r& E化简并去除方向刚好相反的:$ `1 R/ A, H4 g$ O
    16.jpg 4 q" s9 }4 J% z  L
    隐函数表达式:
    # {- G& t1 D+ u5 w3 e1 r+ J
    08.png
    + q% v" r) E6 @" o
    $ Z) K2 K/ C! F* w8 @' ?8 h4 o% P为了计算方便,我们用数值近似取代根号形式: 09.png 绘制图形,可以看到,随着次数 n 的不断升高,图形越来越接近正十二面体:
    ) f4 N  |& A4 h4 t0 w+ V 17.jpg & W. u8 m" w* t+ {7 z7 @& l% N* ~
    十二面体

    9 w; D5 U0 K* [5 v4 D% ^! O计算各个面的法向量:  ^9 a/ _4 @' o4 D- g0 X9 P7 Q. z
    10.png 3 p( i% t" O  N# x
    化简并去除方向相反的:
    18.jpg & k+ b- Q6 l( j) T0 B' w

    6 `2 S" d& ~7 H7 [: l得到方程左侧表达式: 19.jpg 7 i4 r6 E8 i0 V+ V' L( d: L
    为了计算方便,取近似值:
    ) t) i, E  u1 q. X" G: } 20.jpg ' @- [  F! q! }" y( H0 n. H2 [
    绘制正二十面体的曲面方程:
    21.jpg 6 k# K: g3 y& y  l, J/ N
    绘制正二十面体的曲面方程:
    22.jpg   ]/ ^. ^6 c7 C4 ]* |
    复合多面体
    从上面的计算可以看到,根据猜测做的推论基本上是对的:确实据此得到了各种正多面体的渐近方程并成功绘制了出来。但同时也可以看到,这种方法有很多局限性。首先,所生成的多面体必须有平行的相对的面,这样采用的法向量才能一个顶俩,发挥应有的作用得到对应的多面体。五种正多面体里,只有四种满足这个条件,还剩下一个正四面体不能用这种方法表示。其次,用这种方法只能表示凸多面体,所谓凸多面体,就是内部任意两点的连线仍然落在内部的多面体。这两个问题都是可以解决的,解决方法是引入指数函数。
    + R1 \  S0 b2 i9 p: r8 Z
    正四面体

    0 d6 {3 B8 P5 P. s4 `! }计算正四面体的法向量:: a" w  d7 l8 V  ?3 T9 o! A) U
    11.png
    化简:
    12.png 如果用之前的高次方程的方法,那么只能得到一个朝向比较特别的正八面体,因为每个法向量都生成了两个平面: 13.png
    , x* v" o3 J  R: _ 23.jpg
    ) s0 Y, a8 q! A1 J; X+ _" V' Q2 y( G而改用指数,则可得到如下表达式:
    7 K: M; ]6 e* O! _  P! x9 t 14.png 4 B0 O# ^" c/ A% @& L: Y5 r
    以此作为隐函数果然可以画出正四面体:
    / ^. \5 ~$ _2 t$ g; z" W) f 24.jpg
    * L/ E% N  V" ]. c" G) E2 B
    为什么这样可行?我也只能给个近似的猜测:对 E^(a x + by + c z)==C 这样的方程,两边取对数就是 a x+ b y+ c z==log C 这就是一个平面的方程,把几个这样的平面方程加起来,就"围成"了一个多面体。而指数的增长保证了每个方向上不会受其它项的影响,保持大体是个平面。

    7 N: c5 K4 Z4 O6 h0 r* i
    另外还值得指出的是,可以在指数上再加次数,让这样生成的多面体的边缘更加"锐利":

    $ D6 }1 E6 I/ r  h! V+ u 25.jpg ; u5 `* M+ f- `$ c9 ?% X" D; k, J
    星形八面体
    在各种各样的多面体中,有一类多面体可以看作是若干基本的多面体彼此叠合组成,我们称之为复合多面体。比如下图所示的星形八面体,就可以看作两个正四面体彼此叠合而成。
    * z% d& l" h! G' S5 a 26.jpg
    . L: b- X+ T6 k+ k7 L. B* j观察这个复合多面体的面的组成指标可以发现,前四组只包含顶点 2、4、5、8,后四组只包含顶点 1、3、6、7。这恰好是各自组成两个正四面体。我们可以照样算出这八个面的法向量,然后分组各自生成两个正四面体曲面:
    ( |' D/ k% O7 N4 ?+ L 15.png
    : n6 f* e7 O# \3 d求法向量,化简并分组:
    ! ^' L* Q8 p1 g' j; q9 A$ ?2 ? 16.png
    & N8 E' @$ E2 U. d" r得到两个指数和的表达式:
    7 j4 q) E3 P& ~+ V* l: J 17.png ! C; `. G2 b5 ?/ I3 ~
    分别绘制可以看到两个正四面体:  l! @9 _; E! b, y
    27.jpg
    6 u/ v8 R) E, I( M$ y: P, G% i6 A如何从这两个四面体得到想要的星形八面体呢?直接相加肯定是不行的,那样得到的就是正八面体了。这里我们采用 The Nature of Mathematics and the Mathematics of Nature 一书中提到的一个小技巧:把两个方程表达式再次放到指数上。这个技巧称为 Exponential Scale:$ z9 V4 h1 I- }$ v
    18.png 3 M2 x8 D7 `' |; T/ F' t
    可以看到,这个方程确实可以绘制出星形八面体:
    . _& o9 G6 F* {+ |( f$ e! U 28.jpg
      O2 J3 z) z8 q, }可以把旋转观察这个星形八面体曲面的过程输出为动画:7 V: C6 V( C* D4 n
    19.png
    . D* g: l' i- d 20.png
    # l2 o2 n/ T/ B 微信图片_20200324153944.gif
    4 I. A2 G3 J; p! t* Z& T) p
    五复合正四面体
    . d: I; R4 [4 Q+ A& x: \5 a
    我们可以再举一个例子,五复合正四面体,这是由五个正四面体内接于一个正十二面体形成的复合多面体:
    29.jpg : y9 |' L5 m+ o" B" ?
    照例求面法向量,化简并分组:
    30.jpg ( A, q" d: Q* B

    : y- |: m9 k4 N9 L得到方程:& e- k- J' U+ o
    31.jpg
    5 D" M9 i9 S# P) q' {
    绘制可以得到五复合正四面体的近似曲面(警告:由于项数太多,运行绘制速度很慢,运行时请耐心等待):
    32.jpg ) d. ?' e; X" C

    4 J& g/ ]! [7 R# w9 L! J
    我们也用它生成一个旋转观察的动图:
    33.jpg   |) Q: R" H4 a+ L* v/ J1 _- V" C- v
    , n" W; d3 H8 M8 }9 ^
    微信图片_20200324154410.gif 6 s8 N% H: t. l
    更多的复合多面体
    6 y4 I( _' l! j5 n# }
    只要是由凸多面体组成的复合多面体,理论上都可以用上面的方法,先求得各个多面体的方程,然后“抬升”到指数位置,得到复合多面体的方程。Mathematica 提供的PolyhedronData 函数里有许多复合多面体,我全部列在下面,感兴趣的读者可以自己实验生成想要的复合多面体曲面。0 H( O& n$ Z( e2 b
    21.png & l; A: H3 ?; N8 }; V
    34.jpg
    6 p, \6 S6 K' s对此有兴趣的,欢迎联系我们共同探讨。( @6 ?% ]" \0 ^2 _
    market@asdoptics.com $ P& ]% z; N. M
    www.asdoptics.com
    # g. b0 a& T, T; W& Q  u& o$ h4 I- P

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

    12.jpg

    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    宏心        

    51

    主题

    19

    听众

    8027

    积分

    升级  60.54%

  • TA的每日心情
    开心
    2026-6-10 06:44
  • 签到天数: 3634 天

    [LV.Master]伴坛终老

    超级版主

    自我介绍
    数据分析,统计学的教学,数学建模的辅导
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-6-10 21:09 , Processed in 0.383637 second(s), 59 queries .

    回顶部