QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 11708|回复: 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。不过在这篇文章里,我们并不用它来绘制各种婀娜多姿的曲面,而是尝试用它探索、绘制一些"多面体"。" @( g/ G* c1 ^+ `+ d' R, H" T
    从最简单的开始
    # k. J$ _$ x3 s  c让我们从最简单的,大家耳熟能详的球面方程开始:
      o4 M$ Q- n$ R, T! | 11.jpg / u" q$ H7 T. Z* V
    方程 x^2+y^2+z^2==1 的意义非常简单:每个点到原点的距离都是 1,这就形成了一个球面。相比较之下,球面的参数方程就不是这么简单了:
    * }: ?# u: z4 x8 ]4 n( L: P多面体
    & e4 t: \7 g# Q& B从球面方程出发,我们可以看一下更一般的形式,比如 x^n+y^n+z^n==1 的图形是什么样子的:   n4 I- {( M% s9 X8 [' w2 X
    13.jpg
    - I! D7 I, Q+ U/ r可以看到随着 n 的值不断增大,方程表示的曲面越来越接近一个立方体。这是为什么呢?我并不能完全解释,只能提出这么一个猜测。考虑如下表达式:
    + b; n% ]* S% a4 y* J& f# r 02.png 8 \, S4 @, O, X; u4 N; O. r; _* Q9 u$ A( @
    这是 Lp 范数的定义,当 p 趋向于正无穷时,上述表达式的极限是:4 `* i7 V( k6 @& i# M3 ~
    03.png ! S1 S1 D- A2 Y- Q
    也就是 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 可定义求各种多面体法向量的函数如下:
    / v3 X7 ~8 i# o0 t: k, v
    14.jpg 9 k6 {- Z+ M3 \4 R
    接下来就让我们用实际计算来验证一下这个猜测吧:
    / i* S; A. X5 Q6 C3 O' D& j
    正八面体
    - C/ t' v9 ~! c
    求正八面体的法向量:
    04.png ; q$ d- I; w5 w& u# A# {4 \
    化简并去除方向刚好相反的法向量,因为之前方程的常数项 ±1 可以由一个法向量得到两个相对的面的方程:
    ' `4 R6 y5 P- l, z) z 05.png 3 K, N7 c1 Y9 T  z
    然后就可以根据这个求八面体渐近方程了:% ]5 C: |9 Z* {# c0 K- r0 v
    06.png
    ' m/ B: T6 ~# L+ a9 d; g, L 15.jpg # S4 j' K7 D% k% n! I' g
    正十二面体

    0 y' a9 W, F% C# o1 U  y
    正十二面体的法向量:
    07.png
      ]% ~& C# k! O' \. i
    * L( N, V* e, L6 }化简并去除方向刚好相反的:3 |/ h% k: U; N8 Q6 D" j! G
    16.jpg ' y; D) L" Y3 e# D$ P5 s0 I7 W8 ^
    隐函数表达式:3 L; E( F2 z! K6 k# \2 n
    08.png 8 r8 x5 ~* I5 P0 E  ~

    3 c. J6 A# ]* p$ R" \2 i0 v' |6 n为了计算方便,我们用数值近似取代根号形式: 09.png 绘制图形,可以看到,随着次数 n 的不断升高,图形越来越接近正十二面体:
    ) K2 T; w5 K. X7 K& X, z7 O9 ~$ c 17.jpg 8 P- t5 h: M# v# o2 f
    十二面体
    2 J+ U0 d# @; ^/ A
    计算各个面的法向量:& C& u& B$ Y! E
    10.png " D0 L& H, i! m9 I0 b. w
    化简并去除方向相反的:
    18.jpg 6 ]6 f6 c" X; E

    5 b) i* l  C) l; s8 V3 C得到方程左侧表达式: 19.jpg
    6 j3 t$ W+ H8 s3 [* w2 v# I% y) I为了计算方便,取近似值:# v0 c, T% t( h7 T3 v, `
    20.jpg ) Z! T1 J! l3 K2 W% C
    绘制正二十面体的曲面方程:
    21.jpg
    + g7 b+ _$ Y7 P' R0 L
    绘制正二十面体的曲面方程:
    22.jpg
    + s0 R' Q# P- D: M$ e
    复合多面体
    从上面的计算可以看到,根据猜测做的推论基本上是对的:确实据此得到了各种正多面体的渐近方程并成功绘制了出来。但同时也可以看到,这种方法有很多局限性。首先,所生成的多面体必须有平行的相对的面,这样采用的法向量才能一个顶俩,发挥应有的作用得到对应的多面体。五种正多面体里,只有四种满足这个条件,还剩下一个正四面体不能用这种方法表示。其次,用这种方法只能表示凸多面体,所谓凸多面体,就是内部任意两点的连线仍然落在内部的多面体。这两个问题都是可以解决的,解决方法是引入指数函数。
    4 d+ o  ?3 R, B4 [+ ~
    正四面体

    5 M% D; s# ^" f! B( ~% B计算正四面体的法向量:( ^5 R" u- m1 Z0 r
    11.png
    化简:
    12.png 如果用之前的高次方程的方法,那么只能得到一个朝向比较特别的正八面体,因为每个法向量都生成了两个平面: 13.png 4 [, D3 |1 }, Z7 Z. l- L$ j
    23.jpg
      a, O& |& t( @) w! d而改用指数,则可得到如下表达式:
    0 _. x: s" G4 ^, D! x2 C9 N 14.png
    2 T- t8 E% r7 n! E8 T  @* P, Z以此作为隐函数果然可以画出正四面体:
    5 r5 l9 _5 S  c 24.jpg
    ) |1 h/ P% B: e8 B& j
    为什么这样可行?我也只能给个近似的猜测:对 E^(a x + by + c z)==C 这样的方程,两边取对数就是 a x+ b y+ c z==log C 这就是一个平面的方程,把几个这样的平面方程加起来,就"围成"了一个多面体。而指数的增长保证了每个方向上不会受其它项的影响,保持大体是个平面。
    6 T+ h  O* T" N* c- }2 Q
    另外还值得指出的是,可以在指数上再加次数,让这样生成的多面体的边缘更加"锐利":
    # m" v+ ^2 w8 ]) V) |
    25.jpg
    $ n/ e, `, s4 u; d0 h
    星形八面体
    在各种各样的多面体中,有一类多面体可以看作是若干基本的多面体彼此叠合组成,我们称之为复合多面体。比如下图所示的星形八面体,就可以看作两个正四面体彼此叠合而成。4 s' L0 w! \6 u. M
    26.jpg
    4 {6 O0 q3 Y" Q. m0 n+ Q观察这个复合多面体的面的组成指标可以发现,前四组只包含顶点 2、4、5、8,后四组只包含顶点 1、3、6、7。这恰好是各自组成两个正四面体。我们可以照样算出这八个面的法向量,然后分组各自生成两个正四面体曲面:. ^" ~, H: Q# W* A2 t. _0 y
    15.png
    ' p5 x: i- K: ~  D& C+ R求法向量,化简并分组:
    * j& f3 U! Q: o2 V9 [! O 16.png
    - D, W; N) ]! Y. q  C( G. t得到两个指数和的表达式:7 _9 F! e6 K. R! g4 f
    17.png   e3 n/ n* O; H" _+ H! u. n9 q
    分别绘制可以看到两个正四面体:
    ) s1 g1 }7 t  g 27.jpg
    5 Z  K' m7 J  ~, q. Y; N如何从这两个四面体得到想要的星形八面体呢?直接相加肯定是不行的,那样得到的就是正八面体了。这里我们采用 The Nature of Mathematics and the Mathematics of Nature 一书中提到的一个小技巧:把两个方程表达式再次放到指数上。这个技巧称为 Exponential Scale:
    5 W7 |# ~- w' c 18.png
    ' R5 Y3 D# s3 E9 M9 b, A$ g; _可以看到,这个方程确实可以绘制出星形八面体:
    ! }' J/ W" s7 H/ A 28.jpg
    " y/ U/ t; U3 {3 u6 z. a! Q可以把旋转观察这个星形八面体曲面的过程输出为动画:
    6 W8 ~* `" t2 S: T2 z9 l 19.png , h( z  F/ c0 L5 E: `+ }5 i
    20.png , E' J" H# O! z  j2 @
    微信图片_20200324153944.gif
    : b1 v; D  ^1 ^7 L* _/ R9 ~
    五复合正四面体
    4 p% a1 L* k* j' q8 @5 l
    我们可以再举一个例子,五复合正四面体,这是由五个正四面体内接于一个正十二面体形成的复合多面体:
    29.jpg & E* F6 m! O: Z0 X
    照例求面法向量,化简并分组:
    30.jpg
    : y6 a4 S# n3 h0 G3 i
    + m" c, H0 d% s2 H, B: e) T得到方程:8 m8 J* L1 u3 w
    31.jpg % C% U5 J+ V/ g: Q& Q* F* O
    绘制可以得到五复合正四面体的近似曲面(警告:由于项数太多,运行绘制速度很慢,运行时请耐心等待):
    32.jpg ) j6 {4 H# _! l* m  N

    , F1 k+ @/ f' y0 U0 R. ]+ O
    我们也用它生成一个旋转观察的动图:
    33.jpg / X+ D1 O, y+ N0 M) i( g
    0 a; l5 y3 i- z+ J" x# l& |
    微信图片_20200324154410.gif
    : |$ Z: E; U; W$ X
    更多的复合多面体
    * X, j1 f. A+ l* e" H1 S  d
    只要是由凸多面体组成的复合多面体,理论上都可以用上面的方法,先求得各个多面体的方程,然后“抬升”到指数位置,得到复合多面体的方程。Mathematica 提供的PolyhedronData 函数里有许多复合多面体,我全部列在下面,感兴趣的读者可以自己实验生成想要的复合多面体曲面。. C- H- y4 R1 |; v9 z  Q; }
    21.png - i7 T, c( @. y5 U, C! v; L/ f! o
    34.jpg
    - I. k1 ~9 x" J9 a& @对此有兴趣的,欢迎联系我们共同探讨。$ @  |/ F0 h: M! r$ j3 `4 v- ?% W, I
    market@asdoptics.com
    1 u! n5 i7 c0 B/ B2 n$ f3 @0 z2 ?www.asdoptics.com
    ) g1 K, T& ^* X! }, u# w$ s, k# p3 V# O) ^$ j% t# E9 W$ E1 {( e

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

    12.jpg

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

    51

    主题

    19

    听众

    8045

    积分

    升级  60.9%

  • TA的每日心情
    开心
    2026-6-16 06:21
  • 签到天数: 3640 天

    [LV.Master]伴坛终老

    超级版主

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

    使用道具 举报

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

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

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

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

    蒙公网安备 15010502000194号

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

    GMT+8, 2026-6-16 09:04 , Processed in 0.483877 second(s), 59 queries .

    回顶部