QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 11705|回复: 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。不过在这篇文章里,我们并不用它来绘制各种婀娜多姿的曲面,而是尝试用它探索、绘制一些"多面体"。
    , G6 Y3 c! P7 M* |* X, j: J' O2 B+ T从最简单的开始& y$ f+ F% }* L5 A  n
    让我们从最简单的,大家耳熟能详的球面方程开始:
    ) C/ G! X( b$ G1 [5 J2 d2 \ 11.jpg
    $ Z8 C+ |2 ~% z/ k2 `方程 x^2+y^2+z^2==1 的意义非常简单:每个点到原点的距离都是 1,这就形成了一个球面。相比较之下,球面的参数方程就不是这么简单了:$ s1 U! E9 l* X5 m! h2 x  D1 x2 K
    多面体
    : X& A+ m# [8 W6 J从球面方程出发,我们可以看一下更一般的形式,比如 x^n+y^n+z^n==1 的图形是什么样子的: 6 t: m' ]& W+ L# {
    13.jpg * ^9 O  q3 B, r3 B+ {& V
    可以看到随着 n 的值不断增大,方程表示的曲面越来越接近一个立方体。这是为什么呢?我并不能完全解释,只能提出这么一个猜测。考虑如下表达式:
    : e1 W6 s# r/ |9 ?$ R 02.png 2 @8 W2 H7 ~; m
    这是 Lp 范数的定义,当 p 趋向于正无穷时,上述表达式的极限是:
    " |) J3 d, E" a 03.png
    ( A& H' x9 Y4 L+ ]
    也就是 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 可定义求各种多面体法向量的函数如下:

    % X* Y7 c3 z4 f 14.jpg
    ! z# \* |4 @7 a1 m接下来就让我们用实际计算来验证一下这个猜测吧:) @7 D/ V5 f; A
    正八面体

    % `5 E  n% n% p0 f* S6 |
    求正八面体的法向量:
    04.png
    9 _" _7 K  @  n1 m9 G( E3 H化简并去除方向刚好相反的法向量,因为之前方程的常数项 ±1 可以由一个法向量得到两个相对的面的方程:
    " i, d2 u8 b9 f% \ 05.png
    2 v! p# ?6 C. z' l5 Y然后就可以根据这个求八面体渐近方程了:
    2 t2 Q6 \9 U4 ^4 W 06.png % R* e7 N0 `0 o8 q: e
    15.jpg
    0 M9 j! N& g7 g3 m! l: `: B- r
    正十二面体
    ( R6 v6 [' g  ~" t! h# g
    正十二面体的法向量:
    07.png 0 D1 G5 k! Z. j+ b  d
    + N  q8 C  t! A/ _7 m  ]
    化简并去除方向刚好相反的:
    ( c' s; ]8 B9 t1 g! ^+ N 16.jpg 4 |# e$ `: w! R; Z
    隐函数表达式:+ J' O% D8 r' `& u" a
    08.png
    % H4 Y8 @/ O$ G; n1 O) o: O, J1 q! s  v( [! V8 Z. Q4 [# t& `
    为了计算方便,我们用数值近似取代根号形式: 09.png 绘制图形,可以看到,随着次数 n 的不断升高,图形越来越接近正十二面体:
      a2 l7 @) n0 s* H! M$ P* n. W 17.jpg
    ; {# v6 t7 |/ t+ I
    十二面体
    ' n6 |5 F) g' X& Q& ~7 k$ S/ D, E+ W
    计算各个面的法向量:2 q2 s( O4 q, M
    10.png
    . u: c/ S6 ]* W3 f7 ~% ]
    化简并去除方向相反的:
    18.jpg 3 e: B, i4 b) z8 `7 f0 B9 c

    ! H% t" D9 Q( F得到方程左侧表达式: 19.jpg
    ; k$ }: Q( q* a为了计算方便,取近似值:! y1 v3 k/ [# I- j# A; k, g
    20.jpg . x. f) l0 H# |7 l
    绘制正二十面体的曲面方程:
    21.jpg ; _" F$ ]2 f7 w& O) e
    绘制正二十面体的曲面方程:
    22.jpg ' N4 J1 B4 I1 w: T1 u. H
    复合多面体
    从上面的计算可以看到,根据猜测做的推论基本上是对的:确实据此得到了各种正多面体的渐近方程并成功绘制了出来。但同时也可以看到,这种方法有很多局限性。首先,所生成的多面体必须有平行的相对的面,这样采用的法向量才能一个顶俩,发挥应有的作用得到对应的多面体。五种正多面体里,只有四种满足这个条件,还剩下一个正四面体不能用这种方法表示。其次,用这种方法只能表示凸多面体,所谓凸多面体,就是内部任意两点的连线仍然落在内部的多面体。这两个问题都是可以解决的,解决方法是引入指数函数。+ l* f" c- K9 p1 {- o( ], E: m( Q& q
    正四面体

    " N  ^# X! ~, A2 M计算正四面体的法向量:
    2 u" f# X% B: {! Q3 d) i 11.png
    化简:
    12.png 如果用之前的高次方程的方法,那么只能得到一个朝向比较特别的正八面体,因为每个法向量都生成了两个平面: 13.png
    & Z; M1 n% }5 e* G4 S: c0 f 23.jpg 4 A2 q0 P7 o; W, X
    而改用指数,则可得到如下表达式:
    ! c3 g. L- z2 [+ z" O 14.png , |9 X) |4 ]& h6 v& ^6 b
    以此作为隐函数果然可以画出正四面体:# M0 B. G% i' ^: H
    24.jpg 7 L+ ~7 L+ j7 m( E& [0 m0 t
    为什么这样可行?我也只能给个近似的猜测:对 E^(a x + by + c z)==C 这样的方程,两边取对数就是 a x+ b y+ c z==log C 这就是一个平面的方程,把几个这样的平面方程加起来,就"围成"了一个多面体。而指数的增长保证了每个方向上不会受其它项的影响,保持大体是个平面。
    + L4 T- u: E; r2 i1 c! E- ]  i2 H
    另外还值得指出的是,可以在指数上再加次数,让这样生成的多面体的边缘更加"锐利":

    6 L5 s5 r" I, u' B0 H4 d 25.jpg
    2 C. e# M' I$ Z9 }5 E; }5 k+ [, j
    星形八面体
    在各种各样的多面体中,有一类多面体可以看作是若干基本的多面体彼此叠合组成,我们称之为复合多面体。比如下图所示的星形八面体,就可以看作两个正四面体彼此叠合而成。
    3 ?; e! E( y5 f! J3 I3 R8 O3 \ 26.jpg : ~) |( ^$ ]7 H! Y; |- u
    观察这个复合多面体的面的组成指标可以发现,前四组只包含顶点 2、4、5、8,后四组只包含顶点 1、3、6、7。这恰好是各自组成两个正四面体。我们可以照样算出这八个面的法向量,然后分组各自生成两个正四面体曲面:
    7 m' m7 T7 d7 b! a; h 15.png
    4 [1 q% u7 [5 c; c9 j& @求法向量,化简并分组:8 l7 y' K4 @) ~8 S6 [% \
    16.png - d3 ]. M. @) [1 g: }% f3 x
    得到两个指数和的表达式:% E: F2 R) {8 r  k+ V
    17.png
    ! G! U: Y" @- k# t2 ^2 }+ f分别绘制可以看到两个正四面体:  j! ?2 R# T& W& {' O% l
    27.jpg 9 q; D) k; p* u7 W
    如何从这两个四面体得到想要的星形八面体呢?直接相加肯定是不行的,那样得到的就是正八面体了。这里我们采用 The Nature of Mathematics and the Mathematics of Nature 一书中提到的一个小技巧:把两个方程表达式再次放到指数上。这个技巧称为 Exponential Scale:* Q. J) ]8 p: I3 l
    18.png
    2 y6 c& i$ z1 q. R( a可以看到,这个方程确实可以绘制出星形八面体:
    : }1 D" X( Z! o3 m 28.jpg
    , Q% ~' h6 b7 |可以把旋转观察这个星形八面体曲面的过程输出为动画:
    . d" Q9 e' A) Z- c 19.png 1 [  l6 G0 i; [& f/ X
    20.png 7 o7 o" a3 k( R3 o# ]9 a* w
    微信图片_20200324153944.gif 1 f7 A" y8 Y& E2 C1 B" S; s
    五复合正四面体
    * R& T9 z: \1 n
    我们可以再举一个例子,五复合正四面体,这是由五个正四面体内接于一个正十二面体形成的复合多面体:
    29.jpg ; T* _  |% d) C6 g$ p
    照例求面法向量,化简并分组:
    30.jpg
    ) E; M/ v- ^  _
    2 J; e) {( t8 n* X( a0 L" Z得到方程:
      c4 g4 K" x& j' d" o 31.jpg # G: `# H6 W- G: T3 N" {
    绘制可以得到五复合正四面体的近似曲面(警告:由于项数太多,运行绘制速度很慢,运行时请耐心等待):
    32.jpg
    6 k8 N% L2 B0 `% |/ D! s- ~# I. r  x$ u
    我们也用它生成一个旋转观察的动图:
    33.jpg
    4 `9 F: f& K" x3 ^' x5 a2 W  ^
    5 d8 w  \/ j' M9 D7 Y 微信图片_20200324154410.gif
      @! s; l5 Y1 a# Z" [  L$ I
    更多的复合多面体
    : w* n$ K( C* w" D" H3 R
    只要是由凸多面体组成的复合多面体,理论上都可以用上面的方法,先求得各个多面体的方程,然后“抬升”到指数位置,得到复合多面体的方程。Mathematica 提供的PolyhedronData 函数里有许多复合多面体,我全部列在下面,感兴趣的读者可以自己实验生成想要的复合多面体曲面。
    : A: D! f9 u8 ~. u 21.png
    & b5 t! w4 T" D7 H4 u5 p5 h# S 34.jpg ) t3 e/ Z- X" K( S
    对此有兴趣的,欢迎联系我们共同探讨。- {( e0 [/ _; G  e
    market@asdoptics.com
    8 A& |) m- T6 q4 G1 Swww.asdoptics.com / V/ C' d1 @! l  w2 M& c* X$ Y

    & P- l& Q6 m, G

    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 06:01 , Processed in 0.480141 second(s), 58 queries .

    回顶部