QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 11636|回复: 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。不过在这篇文章里,我们并不用它来绘制各种婀娜多姿的曲面,而是尝试用它探索、绘制一些"多面体"。; z! l, G2 z: k0 B
    从最简单的开始
    4 D7 J" C& z# B" ~让我们从最简单的,大家耳熟能详的球面方程开始:0 d7 H- S( }1 D9 d9 {
    11.jpg % g' Q  D& A9 L8 q% V& L( [
    方程 x^2+y^2+z^2==1 的意义非常简单:每个点到原点的距离都是 1,这就形成了一个球面。相比较之下,球面的参数方程就不是这么简单了:- t" K5 B! a: e4 D
    多面体% P# Y" ?# W. A3 a, V, o% O& ?! r+ {
    从球面方程出发,我们可以看一下更一般的形式,比如 x^n+y^n+z^n==1 的图形是什么样子的:
    # B% a' |; s- @1 w6 N; v, K 13.jpg 4 ]2 q9 U3 Q4 V
    可以看到随着 n 的值不断增大,方程表示的曲面越来越接近一个立方体。这是为什么呢?我并不能完全解释,只能提出这么一个猜测。考虑如下表达式:6 ~. D2 }) M7 o! g) n7 T" U
    02.png * u! b' M+ s* Q: F& g
    这是 Lp 范数的定义,当 p 趋向于正无穷时,上述表达式的极限是:2 u( [% T/ J, e% n
    03.png
    0 ?# M5 o9 f' E3 W* 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 可定义求各种多面体法向量的函数如下:

    ! i% o2 }  c4 t 14.jpg   F2 [$ G0 o  r6 g; M  A+ Y
    接下来就让我们用实际计算来验证一下这个猜测吧:
    & o7 \4 G4 t8 v0 a- O. F
    正八面体

    + i5 L" C% U& Y$ b
    求正八面体的法向量:
    04.png $ o$ @2 |) `5 s, b( y  O6 X
    化简并去除方向刚好相反的法向量,因为之前方程的常数项 ±1 可以由一个法向量得到两个相对的面的方程:
    # y7 _% g4 m+ {7 [6 p& \ 05.png 4 u# B  t: O* T6 U! x( p3 m
    然后就可以根据这个求八面体渐近方程了:
    : T* w' W( l) L 06.png
    ' T) F8 u/ c; @' l9 E" \* E6 E 15.jpg 9 i  z* q" O: S8 D; U
    正十二面体
    8 ~* w& a* x% j5 _! u4 ~
    正十二面体的法向量:
    07.png
    ; W( [2 t. Q) [6 ~; b: S4 {8 c; F% F
    + X/ ?$ l, w$ c- b5 f化简并去除方向刚好相反的:
    6 W6 a7 k* c1 s$ G0 i: { 16.jpg ! n& p, @' Y- v/ Z
    隐函数表达式:, L1 e2 Y% E1 m( Y4 H1 u
    08.png , T. j- b# U6 G5 d, V! M

    * m! r0 S, z6 Z5 F- u为了计算方便,我们用数值近似取代根号形式: 09.png 绘制图形,可以看到,随着次数 n 的不断升高,图形越来越接近正十二面体:& D7 b9 A# u2 Q2 X0 d& V, y  q
    17.jpg / e3 ?( k- t8 q4 B
    十二面体
    $ C: N( |" w2 K+ D% ?" P& t( v
    计算各个面的法向量:
    8 y! y1 @" d. `- p+ p 10.png 3 f4 ]3 ], M$ y7 l/ E
    化简并去除方向相反的:
    18.jpg
    + n7 a. T* G  s
    ( L, ^8 G. H; e5 q/ E3 |得到方程左侧表达式: 19.jpg
    % t2 i" t  W" a. f6 }, z/ w为了计算方便,取近似值:
    ! H6 l* k0 Z9 V( r. S- {9 S 20.jpg
    ! d) j7 G0 v5 `1 U# T* d" M. A: Z
    绘制正二十面体的曲面方程:
    21.jpg
    , @* q3 ~" k6 s$ m% B
    绘制正二十面体的曲面方程:
    22.jpg 6 f; S! }1 k1 }6 O7 {1 t) Z' w
    复合多面体
    从上面的计算可以看到,根据猜测做的推论基本上是对的:确实据此得到了各种正多面体的渐近方程并成功绘制了出来。但同时也可以看到,这种方法有很多局限性。首先,所生成的多面体必须有平行的相对的面,这样采用的法向量才能一个顶俩,发挥应有的作用得到对应的多面体。五种正多面体里,只有四种满足这个条件,还剩下一个正四面体不能用这种方法表示。其次,用这种方法只能表示凸多面体,所谓凸多面体,就是内部任意两点的连线仍然落在内部的多面体。这两个问题都是可以解决的,解决方法是引入指数函数。; |- T2 ^/ p' Q' s2 c3 W3 V) u
    正四面体

    & j% |' B. h, W- p! k: i* _, _计算正四面体的法向量:2 v$ k$ s1 _+ z
    11.png
    化简:
    12.png 如果用之前的高次方程的方法,那么只能得到一个朝向比较特别的正八面体,因为每个法向量都生成了两个平面: 13.png
    $ [/ z7 A8 \& p5 t5 |5 F6 I$ ]+ b 23.jpg , R% Q+ Q/ i4 L5 ^$ B
    而改用指数,则可得到如下表达式:
    & I' j0 }% W( m 14.png
    ( C$ K6 {' T$ \, a: v以此作为隐函数果然可以画出正四面体:
    6 s' X, e2 b! m5 E5 C 24.jpg
    / t2 M. y/ g! Q1 U# B
    为什么这样可行?我也只能给个近似的猜测:对 E^(a x + by + c z)==C 这样的方程,两边取对数就是 a x+ b y+ c z==log C 这就是一个平面的方程,把几个这样的平面方程加起来,就"围成"了一个多面体。而指数的增长保证了每个方向上不会受其它项的影响,保持大体是个平面。
    . A2 h- M+ m9 f( E8 s
    另外还值得指出的是,可以在指数上再加次数,让这样生成的多面体的边缘更加"锐利":

    3 e  ~) O: ?- r" A 25.jpg - r4 G# U2 D" I* y
    星形八面体
    在各种各样的多面体中,有一类多面体可以看作是若干基本的多面体彼此叠合组成,我们称之为复合多面体。比如下图所示的星形八面体,就可以看作两个正四面体彼此叠合而成。5 _1 ]3 g( O0 g
    26.jpg
    ( I7 w. M4 R+ j2 W+ B2 f- z观察这个复合多面体的面的组成指标可以发现,前四组只包含顶点 2、4、5、8,后四组只包含顶点 1、3、6、7。这恰好是各自组成两个正四面体。我们可以照样算出这八个面的法向量,然后分组各自生成两个正四面体曲面:
    : O8 {$ r& O3 [) E. ? 15.png 4 `2 T: ^  _( X( |* l6 i1 G
    求法向量,化简并分组:
    1 [( O% |9 S/ r' R% j+ f 16.png
    1 b1 f, s3 x% G得到两个指数和的表达式:
    # V1 x0 L* Q; i 17.png
    , o% F5 I& u5 O; B* l分别绘制可以看到两个正四面体:
    : x* O3 \8 v! ~, G 27.jpg 9 j5 c3 H' x: C2 Q
    如何从这两个四面体得到想要的星形八面体呢?直接相加肯定是不行的,那样得到的就是正八面体了。这里我们采用 The Nature of Mathematics and the Mathematics of Nature 一书中提到的一个小技巧:把两个方程表达式再次放到指数上。这个技巧称为 Exponential Scale:" D0 h* D$ K' |: |
    18.png
    % }6 M% S" ?, ^5 v可以看到,这个方程确实可以绘制出星形八面体:1 i& W, h, G& L' ?0 y
    28.jpg
    6 H6 z4 N* ^; V' k! n可以把旋转观察这个星形八面体曲面的过程输出为动画:) z- A* s& i. \6 x
    19.png
    $ V. A; [- o2 }) n1 G2 M 20.png
    ) r) @. s8 B5 i/ R5 j' [0 k) k 微信图片_20200324153944.gif 2 Z3 D- ?- Z+ A( L1 o( ]* q/ @  t
    五复合正四面体
    6 r* ?! s7 Y/ d4 I
    我们可以再举一个例子,五复合正四面体,这是由五个正四面体内接于一个正十二面体形成的复合多面体:
    29.jpg 7 k4 h8 _3 q3 v
    照例求面法向量,化简并分组:
    30.jpg # n# H1 k. |' i0 w0 W$ @. F8 `3 E
    3 u, ?; C7 ^$ o
    得到方程:0 F9 f! o; }' {4 i
    31.jpg 1 j7 O, g- A7 G9 Z2 X' e; W& L
    绘制可以得到五复合正四面体的近似曲面(警告:由于项数太多,运行绘制速度很慢,运行时请耐心等待):
    32.jpg ( N: @/ L, ?- d( K" ~  ~. D) \
    2 t, t4 r$ E- J6 R. c  R
    我们也用它生成一个旋转观察的动图:
    33.jpg . E, L+ g  g7 H& u% E/ d

    / Q8 j0 I2 G+ U  E3 k( ^ 微信图片_20200324154410.gif 3 D& d4 T0 m2 j; z; ]; Y7 p$ t$ t( S
    更多的复合多面体
    ! @4 ?9 Z1 z: U: ^0 [
    只要是由凸多面体组成的复合多面体,理论上都可以用上面的方法,先求得各个多面体的方程,然后“抬升”到指数位置,得到复合多面体的方程。Mathematica 提供的PolyhedronData 函数里有许多复合多面体,我全部列在下面,感兴趣的读者可以自己实验生成想要的复合多面体曲面。# r7 c) }. A9 d2 g2 Y3 B' s; J
    21.png
    " b3 h/ J8 M# K+ e0 K/ C  N 34.jpg $ H- o% X/ R8 s! N
    对此有兴趣的,欢迎联系我们共同探讨。. C  Z* d, e5 h/ k2 G
    market@asdoptics.com 9 V( y* h3 ^8 w+ @4 Q3 F, D( T
    www.asdoptics.com
    ' ~9 ^, i+ t* }; U) Z+ ?5 T! a1 _' b+ J6 g

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

    12.jpg

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

    51

    主题

    19

    听众

    7866

    积分

    升级  57.32%

  • TA的每日心情
    开心
    2026-4-17 16:11
  • 签到天数: 3582 天

    [LV.Master]伴坛终老

    超级版主

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

    使用道具 举报

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

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

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

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

    蒙公网安备 15010502000194号

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

    GMT+8, 2026-4-17 16:46 , Processed in 0.641654 second(s), 59 queries .

    回顶部