QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 11634|回复: 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。不过在这篇文章里,我们并不用它来绘制各种婀娜多姿的曲面,而是尝试用它探索、绘制一些"多面体"。
    ( E* S5 g0 Y5 P: {5 {) w9 j从最简单的开始# C, e: U( D7 V; k( ~0 l; c
    让我们从最简单的,大家耳熟能详的球面方程开始:1 U# U" p2 Z1 S+ F6 u
    11.jpg # w( O, k( g; P  e7 ?. C5 B
    方程 x^2+y^2+z^2==1 的意义非常简单:每个点到原点的距离都是 1,这就形成了一个球面。相比较之下,球面的参数方程就不是这么简单了:, H  ?' E- Z0 }& D
    多面体
    ; w' r8 m$ V$ _9 j) C4 Z  y从球面方程出发,我们可以看一下更一般的形式,比如 x^n+y^n+z^n==1 的图形是什么样子的: # _5 C- ?" W* o$ b) G, O4 e% i" X
    13.jpg + L0 X1 j5 k0 V2 P' i, v: I+ D  s1 C
    可以看到随着 n 的值不断增大,方程表示的曲面越来越接近一个立方体。这是为什么呢?我并不能完全解释,只能提出这么一个猜测。考虑如下表达式:
    8 r2 Q* O6 V6 W6 `3 H2 _$ x, X 02.png $ |/ T" p4 y& Y) D3 _7 W
    这是 Lp 范数的定义,当 p 趋向于正无穷时,上述表达式的极限是:
    ) s2 E$ w! z/ d1 t0 k 03.png 4 F  w6 [/ K% M- [. O
    也就是 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 可定义求各种多面体法向量的函数如下:
    + C2 G* ]5 H1 j1 F1 `( m$ F3 l
    14.jpg
    ( q% f! B/ W& j3 K% R( z* f/ ?接下来就让我们用实际计算来验证一下这个猜测吧:
    8 [; b, a. k) U; G/ t# H+ C
    正八面体

    - X9 I# B, N* j6 l9 N, {. \  \0 J* f
    求正八面体的法向量:
    04.png % v. S) V9 J. d# R
    化简并去除方向刚好相反的法向量,因为之前方程的常数项 ±1 可以由一个法向量得到两个相对的面的方程:
    8 i. y  A$ X% K1 u* q 05.png
    7 E- [; R- Q4 `; F  q: ~7 [然后就可以根据这个求八面体渐近方程了:0 d" C( K$ R2 J
    06.png
    7 K8 {0 |2 X% A/ g# v2 q$ d; w 15.jpg
    2 b4 Y& Q! ]: ?+ b4 V: T  K: ]) G4 U
    正十二面体
    ; z9 S# n) m) \+ b
    正十二面体的法向量:
    07.png
    ) [' m. K9 N1 G* g4 p
    ' s. U2 b8 D. s' x. ?3 I化简并去除方向刚好相反的:8 ?% [8 E/ w0 D- B8 g+ z& i
    16.jpg * Z% o1 T6 c. s
    隐函数表达式:5 @+ N7 `, b( n6 H
    08.png * v% Y, ?8 [/ F- _$ q

    # e! W1 U. O4 B8 H0 A" r& w4 z为了计算方便,我们用数值近似取代根号形式: 09.png 绘制图形,可以看到,随着次数 n 的不断升高,图形越来越接近正十二面体:
    ; o' v/ f7 f+ c 17.jpg
    : H& }; f- g/ j- ^; C
    十二面体

    5 o5 [5 D% F& Y  Q* r计算各个面的法向量:% V9 t/ `1 m" u( b
    10.png
    1 z- c- l" O' {
    化简并去除方向相反的:
    18.jpg
    $ z- K: F3 ~7 r- P+ F
    : J4 M! j- ?# K' p得到方程左侧表达式: 19.jpg $ f9 x" G2 D! g' O9 x; a
    为了计算方便,取近似值:
    ! `/ K6 G6 \( P5 i0 F. d' e& K 20.jpg ! d+ l$ d7 B0 h! |; i: j# w: E% W
    绘制正二十面体的曲面方程:
    21.jpg - e" W4 B& O: s6 v& \
    绘制正二十面体的曲面方程:
    22.jpg
    7 c  A) ?$ |5 P/ Z4 R0 }7 |1 ^' J1 l
    复合多面体
    从上面的计算可以看到,根据猜测做的推论基本上是对的:确实据此得到了各种正多面体的渐近方程并成功绘制了出来。但同时也可以看到,这种方法有很多局限性。首先,所生成的多面体必须有平行的相对的面,这样采用的法向量才能一个顶俩,发挥应有的作用得到对应的多面体。五种正多面体里,只有四种满足这个条件,还剩下一个正四面体不能用这种方法表示。其次,用这种方法只能表示凸多面体,所谓凸多面体,就是内部任意两点的连线仍然落在内部的多面体。这两个问题都是可以解决的,解决方法是引入指数函数。/ x: ~2 k4 z+ K: f
    正四面体

    . w4 G0 I6 F+ K" L: ]5 G& K: `计算正四面体的法向量:
    ; ?( v( F* {# A  i 11.png
    化简:
    12.png 如果用之前的高次方程的方法,那么只能得到一个朝向比较特别的正八面体,因为每个法向量都生成了两个平面: 13.png
    $ k' P1 ?* E& `# }/ X: A. E% m 23.jpg % s- R# N' U: C* r1 f
    而改用指数,则可得到如下表达式:
    : Y9 m: N0 e! p: [ 14.png
    ' h' A$ D  ]' F% b8 Z以此作为隐函数果然可以画出正四面体:
    9 I7 J' h( n& s6 j) H 24.jpg
    . F- E. q/ L9 R, Q" V6 C, ^5 w4 `
    为什么这样可行?我也只能给个近似的猜测:对 E^(a x + by + c z)==C 这样的方程,两边取对数就是 a x+ b y+ c z==log C 这就是一个平面的方程,把几个这样的平面方程加起来,就"围成"了一个多面体。而指数的增长保证了每个方向上不会受其它项的影响,保持大体是个平面。

    . o" X, y9 z/ O" z* U, |& W
    另外还值得指出的是,可以在指数上再加次数,让这样生成的多面体的边缘更加"锐利":
    5 F% V; t' r+ p! }* {- V6 R
    25.jpg
    % `+ Q1 q% G! U1 [' n# j
    星形八面体
    在各种各样的多面体中,有一类多面体可以看作是若干基本的多面体彼此叠合组成,我们称之为复合多面体。比如下图所示的星形八面体,就可以看作两个正四面体彼此叠合而成。( Q  t) x- I( M& w
    26.jpg ( u8 ?* {- u& Q5 ?% D$ Z
    观察这个复合多面体的面的组成指标可以发现,前四组只包含顶点 2、4、5、8,后四组只包含顶点 1、3、6、7。这恰好是各自组成两个正四面体。我们可以照样算出这八个面的法向量,然后分组各自生成两个正四面体曲面:
    8 L$ n3 |0 {# G9 \+ P 15.png
    ( m& E/ J: S6 G求法向量,化简并分组:
    4 P7 j, M) I& T6 s7 z) o& j1 E 16.png 1 f( {8 y! \  l' i" V* e
    得到两个指数和的表达式:
    / X7 F8 B$ Y+ V3 _ 17.png
    : h' _! V$ o6 U1 ^7 D3 \分别绘制可以看到两个正四面体:
    , R% z  P, t+ C: {4 I; u 27.jpg * w4 V: M+ U5 _# b
    如何从这两个四面体得到想要的星形八面体呢?直接相加肯定是不行的,那样得到的就是正八面体了。这里我们采用 The Nature of Mathematics and the Mathematics of Nature 一书中提到的一个小技巧:把两个方程表达式再次放到指数上。这个技巧称为 Exponential Scale:
    + r4 ?! l& o8 J 18.png
    0 {) k3 {+ t( b6 n1 q& h可以看到,这个方程确实可以绘制出星形八面体:
    ( p& @' ~% g/ ` 28.jpg
    : l  H) G5 j1 ?+ g+ _$ Q可以把旋转观察这个星形八面体曲面的过程输出为动画:5 c% E$ _; P. W  U
    19.png ) Y! @& ]8 j7 n- _$ ~* S
    20.png
    4 V! f, N$ i2 ~& w* T 微信图片_20200324153944.gif
    9 J" E1 Q& W' v7 a
    五复合正四面体
    * x; P$ S* y8 c$ Y0 N& |
    我们可以再举一个例子,五复合正四面体,这是由五个正四面体内接于一个正十二面体形成的复合多面体:
    29.jpg
    8 w/ V; P. o! U5 q& k2 P
    照例求面法向量,化简并分组:
    30.jpg
    + ]( r2 t$ R/ Q- z9 _1 U1 }' n( w$ t/ Y* ?, F
    得到方程:
    + a8 G8 w) r4 Y! L! \9 v; @* G 31.jpg
    2 ^: ~( V( S2 s4 M4 g% Q# ?, O
    绘制可以得到五复合正四面体的近似曲面(警告:由于项数太多,运行绘制速度很慢,运行时请耐心等待):
    32.jpg
    - ]* }, o( X3 I7 l$ r! Y( R2 j2 I' D7 e2 N% T5 E3 Q
    我们也用它生成一个旋转观察的动图:
    33.jpg 7 h! U3 o$ d* Z3 u

    ' t7 S8 S& E6 v 微信图片_20200324154410.gif $ Z: Z9 {( z( n( a  Z8 k# T1 @0 Z
    更多的复合多面体
    5 W0 j: T$ z: g9 `# J+ _0 S: r
    只要是由凸多面体组成的复合多面体,理论上都可以用上面的方法,先求得各个多面体的方程,然后“抬升”到指数位置,得到复合多面体的方程。Mathematica 提供的PolyhedronData 函数里有许多复合多面体,我全部列在下面,感兴趣的读者可以自己实验生成想要的复合多面体曲面。' B9 e8 q  s/ b0 ?& x$ k9 }; O
    21.png
    . \+ I) x; `& m) x7 A9 w; v# i 34.jpg 8 L# |7 Z+ N3 e
    对此有兴趣的,欢迎联系我们共同探讨。! R/ q% }2 R- V7 a: A$ ]: L& T# P
    market@asdoptics.com
    2 X: C, q; V* [3 Owww.asdoptics.com 3 {1 ~4 V8 q2 _0 d; `

    " @; z+ z3 c0 u/ q

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

    12.jpg

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

    51

    主题

    19

    听众

    7864

    积分

    升级  57.28%

  • TA的每日心情
    开心
    2026-4-14 07:07
  • 签到天数: 3581 天

    [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 08:32 , Processed in 0.439175 second(s), 59 queries .

    回顶部