QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 11703|回复: 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。不过在这篇文章里,我们并不用它来绘制各种婀娜多姿的曲面,而是尝试用它探索、绘制一些"多面体"。
    5 B) n  ]8 ?$ s3 J从最简单的开始
    1 F9 [4 W& ?( l/ m: r7 b让我们从最简单的,大家耳熟能详的球面方程开始:- u: s+ ]* t* R3 \# q# G" B2 V4 w
    11.jpg : s' ~4 P+ J; Z1 W; f7 U% d
    方程 x^2+y^2+z^2==1 的意义非常简单:每个点到原点的距离都是 1,这就形成了一个球面。相比较之下,球面的参数方程就不是这么简单了:$ Y$ G: w- i; W; n4 c! j8 m* n
    多面体
    7 O: N1 \3 X- F: }% c从球面方程出发,我们可以看一下更一般的形式,比如 x^n+y^n+z^n==1 的图形是什么样子的:
    ; S% |3 i) i5 g1 N 13.jpg $ q3 @/ f& ]% M" R9 g
    可以看到随着 n 的值不断增大,方程表示的曲面越来越接近一个立方体。这是为什么呢?我并不能完全解释,只能提出这么一个猜测。考虑如下表达式:
    2 r- c" Q5 X) P: o# u+ Z& L* w 02.png
    . s( c2 k( W; w! i1 `- A" N这是 Lp 范数的定义,当 p 趋向于正无穷时,上述表达式的极限是:
    ) _  {8 \2 F% r# j* c1 D8 E; H 03.png : s4 a1 T9 p& Y2 k% d3 D. W* t
    也就是 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 可定义求各种多面体法向量的函数如下:
    5 v. M, P1 v0 W) V
    14.jpg / l3 N2 Y9 k8 g% V
    接下来就让我们用实际计算来验证一下这个猜测吧:
    0 M5 J' D& D) `' ^& r7 {
    正八面体
    8 p, Y" ]+ J  J& l
    求正八面体的法向量:
    04.png / G8 W! e" |- y6 R. [1 ^
    化简并去除方向刚好相反的法向量,因为之前方程的常数项 ±1 可以由一个法向量得到两个相对的面的方程:4 L# Z$ o$ W! ?3 N; h
    05.png
    2 j. ]* y1 R$ p3 p6 a然后就可以根据这个求八面体渐近方程了:
    % s( Z/ L9 a& q7 ]; Q9 ?+ Z: ? 06.png 7 Q" i, t! f$ g- @4 b+ o( \
    15.jpg 1 G* _* Z5 p) O+ U
    正十二面体

    # b- a) M) P! v7 }
    正十二面体的法向量:
    07.png 9 p* m3 }3 I# L0 q  t
    % L/ `* {2 t9 m0 {4 o* d' G
    化简并去除方向刚好相反的:
    # A8 F, V* Z8 E5 F  \ 16.jpg 4 O/ w$ I6 g( U1 X3 G/ N8 y3 w! Z/ L
    隐函数表达式:  X) Q( T. P$ Z* x
    08.png ' O+ I4 ~* @+ w5 s+ ]* E- o

    * x  H5 m# T% I为了计算方便,我们用数值近似取代根号形式: 09.png 绘制图形,可以看到,随着次数 n 的不断升高,图形越来越接近正十二面体:
    / e4 l9 ?, {8 S 17.jpg / c& t3 b7 z% Q0 V7 V2 L+ y. x4 J
    十二面体
    5 c4 h# r* j  G4 v* m3 _$ p3 ~- V' f8 n
    计算各个面的法向量:! B1 k4 U% m$ {: i& l, ^5 Z! D' }' E# {
    10.png 2 T4 Y7 F- g8 Z
    化简并去除方向相反的:
    18.jpg # m) d7 x8 O' ?8 G. g: U

    8 _+ F: ^+ q- Z1 Q& K得到方程左侧表达式: 19.jpg
    # ^# R$ H+ Y4 [: F# h5 B- _为了计算方便,取近似值:
    ) H& p/ _5 K' k: { 20.jpg 5 D( w, T% ], D8 {+ Z" y
    绘制正二十面体的曲面方程:
    21.jpg % l: ^" k$ |( i) e6 G* v
    绘制正二十面体的曲面方程:
    22.jpg
    / r7 q; t: q1 ~9 ~
    复合多面体
    从上面的计算可以看到,根据猜测做的推论基本上是对的:确实据此得到了各种正多面体的渐近方程并成功绘制了出来。但同时也可以看到,这种方法有很多局限性。首先,所生成的多面体必须有平行的相对的面,这样采用的法向量才能一个顶俩,发挥应有的作用得到对应的多面体。五种正多面体里,只有四种满足这个条件,还剩下一个正四面体不能用这种方法表示。其次,用这种方法只能表示凸多面体,所谓凸多面体,就是内部任意两点的连线仍然落在内部的多面体。这两个问题都是可以解决的,解决方法是引入指数函数。8 P- d/ H# Q2 m! x* J4 V! j
    正四面体
    $ ~. l4 t# C" r0 o& ?3 d0 Q
    计算正四面体的法向量:
    & U; w! {# a7 v! E: _- w  ~4 ] 11.png
    化简:
    12.png 如果用之前的高次方程的方法,那么只能得到一个朝向比较特别的正八面体,因为每个法向量都生成了两个平面: 13.png
    1 E5 v- r/ G& ?# M, ] 23.jpg & A7 U. h3 m! L0 m" Y
    而改用指数,则可得到如下表达式:
    6 n% ^2 `% M$ z" K, h! Z; s; d 14.png $ {7 c- G1 m- k; [/ t
    以此作为隐函数果然可以画出正四面体:, m6 i+ n8 s- u7 K$ n6 `8 Y
    24.jpg ! }6 ]# o1 U) n& J% D) G  l# q! ^
    为什么这样可行?我也只能给个近似的猜测:对 E^(a x + by + c z)==C 这样的方程,两边取对数就是 a x+ b y+ c z==log C 这就是一个平面的方程,把几个这样的平面方程加起来,就"围成"了一个多面体。而指数的增长保证了每个方向上不会受其它项的影响,保持大体是个平面。

    + T7 \2 R8 e8 X  ~
    另外还值得指出的是,可以在指数上再加次数,让这样生成的多面体的边缘更加"锐利":
    : v- \3 M0 _5 J
    25.jpg
    ; h& F3 G. m: n2 U' W
    星形八面体
    在各种各样的多面体中,有一类多面体可以看作是若干基本的多面体彼此叠合组成,我们称之为复合多面体。比如下图所示的星形八面体,就可以看作两个正四面体彼此叠合而成。( U8 h1 X4 u8 M; U
    26.jpg
    + V+ w  Q+ t# C/ q: P1 J3 \观察这个复合多面体的面的组成指标可以发现,前四组只包含顶点 2、4、5、8,后四组只包含顶点 1、3、6、7。这恰好是各自组成两个正四面体。我们可以照样算出这八个面的法向量,然后分组各自生成两个正四面体曲面:
    : y5 Z: R6 Z& m! _$ w! h) Y 15.png
    , S/ c" y% X7 R! d! h0 O8 x求法向量,化简并分组:
      x/ R/ ~- d% S; x) E 16.png ) p3 y  z; Z- A
    得到两个指数和的表达式:# }0 f+ T8 T' Y* l
    17.png
    ( z, g& `" f- ^0 G分别绘制可以看到两个正四面体:& z, ^9 j+ r  Z, \: Y
    27.jpg
    7 _/ W" y9 N& I6 R如何从这两个四面体得到想要的星形八面体呢?直接相加肯定是不行的,那样得到的就是正八面体了。这里我们采用 The Nature of Mathematics and the Mathematics of Nature 一书中提到的一个小技巧:把两个方程表达式再次放到指数上。这个技巧称为 Exponential Scale:
    6 r! h6 ^( [- | 18.png
      ]% \  o( L4 j! Z1 {* ~2 ?/ J1 s2 c可以看到,这个方程确实可以绘制出星形八面体:  y! B1 u6 i4 I. k( t& }# Q3 d
    28.jpg % e5 {; ~' E3 r7 T
    可以把旋转观察这个星形八面体曲面的过程输出为动画:" s  D( n. z- W; g
    19.png
    9 w$ g# c0 P6 C0 [6 n: E2 m 20.png
    7 a% b3 @5 ^$ w; ` 微信图片_20200324153944.gif 9 z% G. M* y$ R- p- e2 p
    五复合正四面体
    8 b: o6 t+ ~. T+ m
    我们可以再举一个例子,五复合正四面体,这是由五个正四面体内接于一个正十二面体形成的复合多面体:
    29.jpg
    + B  z6 X, P8 i( h! D5 M" s( a6 f
    照例求面法向量,化简并分组:
    30.jpg
    6 e4 F. ?7 x- _' @  H* A; o- p4 v/ C4 g4 X9 v
    得到方程:- t1 Y5 d+ u! {+ d% F; I" |
    31.jpg ( G0 _9 F1 d7 \6 ]1 o0 Z: O
    绘制可以得到五复合正四面体的近似曲面(警告:由于项数太多,运行绘制速度很慢,运行时请耐心等待):
    32.jpg
    & y& L. x6 z0 ?9 O$ ?! h% H( C8 X0 ^9 S8 s! Q, @9 `
    我们也用它生成一个旋转观察的动图:
    33.jpg
      n" ]+ ?6 P) _
    + ?, F- I3 \" Z, b6 ]9 S/ J& r 微信图片_20200324154410.gif ; `  s7 l, S2 s* A0 g
    更多的复合多面体

    8 t3 Y6 v; \8 P7 M* b! D- j3 D只要是由凸多面体组成的复合多面体,理论上都可以用上面的方法,先求得各个多面体的方程,然后“抬升”到指数位置,得到复合多面体的方程。Mathematica 提供的PolyhedronData 函数里有许多复合多面体,我全部列在下面,感兴趣的读者可以自己实验生成想要的复合多面体曲面。  E  W9 B, g3 B6 D
    21.png
    7 H" v' R3 d! [ 34.jpg
    9 v! s# y) o5 k0 {5 h; U4 _对此有兴趣的,欢迎联系我们共同探讨。
    & v& ?( ]# p* K8 m/ }3 E  ]! smarket@asdoptics.com 0 Q" G* H9 F* E: a
    www.asdoptics.com " U& O- \9 E. X2 ]& L- n! m
    % E3 p! ]* p& b8 y: ^* y- @

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

    12.jpg

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

    51

    主题

    19

    听众

    8038

    积分

    升级  60.76%

  • TA的每日心情
    开心
    2026-6-14 07:06
  • 签到天数: 3638 天

    [LV.Master]伴坛终老

    超级版主

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

    使用道具 举报

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

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

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

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

    蒙公网安备 15010502000194号

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

    GMT+8, 2026-6-15 01:07 , Processed in 0.435708 second(s), 59 queries .

    回顶部