QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 10795|回复: 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。不过在这篇文章里,我们并不用它来绘制各种婀娜多姿的曲面,而是尝试用它探索、绘制一些"多面体"。
    ' K5 w; R" f% Z$ s- |从最简单的开始) r8 Z$ a+ Q# V7 ]  J4 v% m" J
    让我们从最简单的,大家耳熟能详的球面方程开始:
    ; ?% s/ R; |9 A( b8 p3 |: U 11.jpg 3 _# s0 e* `# P8 o) g4 x7 {
    方程 x^2+y^2+z^2==1 的意义非常简单:每个点到原点的距离都是 1,这就形成了一个球面。相比较之下,球面的参数方程就不是这么简单了:9 r5 x- t; [8 ~# j4 F' z
    多面体: R- O( I0 m1 ~) ^/ I
    从球面方程出发,我们可以看一下更一般的形式,比如 x^n+y^n+z^n==1 的图形是什么样子的:
    & j: @$ y* `# x 13.jpg ( F( B6 v- L/ t. v
    可以看到随着 n 的值不断增大,方程表示的曲面越来越接近一个立方体。这是为什么呢?我并不能完全解释,只能提出这么一个猜测。考虑如下表达式:
      o  \1 T% l% Q: [. T! j- M) y 02.png - Y" z  E+ F4 f" ^; e
    这是 Lp 范数的定义,当 p 趋向于正无穷时,上述表达式的极限是:
    - L7 q) a6 K* S; c  \, `7 v/ N, o 03.png
    / x4 B! q' Z: Z. _, I; u
    也就是 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 可定义求各种多面体法向量的函数如下:

    # u) F3 \: t# ?  ] 14.jpg
    * g; N2 B+ r# h3 P) Y% @* S接下来就让我们用实际计算来验证一下这个猜测吧:) H3 }" S6 m/ {9 Y
    正八面体
    1 ^9 |( v( u- s
    求正八面体的法向量:
    04.png
    % f# t9 d3 i+ W化简并去除方向刚好相反的法向量,因为之前方程的常数项 ±1 可以由一个法向量得到两个相对的面的方程:
    ' t+ i4 ^& p) V& u& s  O# x 05.png
    3 B3 l9 F( x# O8 Y然后就可以根据这个求八面体渐近方程了:
    8 y1 Q% t' ]. ? 06.png % Y& ^- C; k4 M+ G* c) o
    15.jpg 4 d1 N4 I, V5 k8 _
    正十二面体

    ( k# }, n' ^& T  e8 U
    正十二面体的法向量:
    07.png
    * Y4 B& R8 S% m+ L+ U* p" @5 h& O8 v/ A% D- N! E! M& m
    化简并去除方向刚好相反的:8 y' w3 u5 g0 F% ~8 |
    16.jpg
    ) f, m1 w: W, Y; _+ ~* \) c' }# Z! U7 B
    隐函数表达式:
    1 i2 z8 N# ?1 f2 t, c; a
    08.png # ?' w4 d# A" N# Y1 O
    ) a+ N2 K8 X0 Z( k. k- K, G6 q0 F
    为了计算方便,我们用数值近似取代根号形式: 09.png 绘制图形,可以看到,随着次数 n 的不断升高,图形越来越接近正十二面体:
    & m' H5 k) j, g5 G8 f 17.jpg
    + u" l" |4 Y8 L' {& e
    十二面体
    ' I# j. I( M( D2 H
    计算各个面的法向量:
    $ a% F* `0 Q, _  ~ 10.png / V7 }7 I1 u. G7 l
    化简并去除方向相反的:
    18.jpg
    $ U# I; z: l% u2 U  Z1 W( T9 j! A5 d% m+ i) `* L2 U3 q0 M
    得到方程左侧表达式: 19.jpg
    ! G5 a3 V. \! z2 a为了计算方便,取近似值:
    % [  o7 x4 N; r2 X1 Y8 h. r( w 20.jpg
    * v% @9 w7 }1 s3 K' x
    绘制正二十面体的曲面方程:
    21.jpg ! M4 m5 t2 ?; f/ i- v, I( n
    绘制正二十面体的曲面方程:
    22.jpg / G/ ^6 i) Q8 k4 r" N% L& F
    复合多面体
    从上面的计算可以看到,根据猜测做的推论基本上是对的:确实据此得到了各种正多面体的渐近方程并成功绘制了出来。但同时也可以看到,这种方法有很多局限性。首先,所生成的多面体必须有平行的相对的面,这样采用的法向量才能一个顶俩,发挥应有的作用得到对应的多面体。五种正多面体里,只有四种满足这个条件,还剩下一个正四面体不能用这种方法表示。其次,用这种方法只能表示凸多面体,所谓凸多面体,就是内部任意两点的连线仍然落在内部的多面体。这两个问题都是可以解决的,解决方法是引入指数函数。
    ! y# I9 n9 B( S5 ~: W
    正四面体
    9 S. T# R4 c+ j0 t& A9 ~+ z
    计算正四面体的法向量:+ O5 }+ j5 s$ f* v
    11.png
    化简:
    12.png 如果用之前的高次方程的方法,那么只能得到一个朝向比较特别的正八面体,因为每个法向量都生成了两个平面: 13.png
    * v9 D0 ]7 D( l! z1 P 23.jpg " V% s9 U9 d: [
    而改用指数,则可得到如下表达式:; _+ l6 `4 B- {' j6 B0 [
    14.png
    ' }  B+ j, I' u* Z$ u9 c' e) O0 z以此作为隐函数果然可以画出正四面体:
    / k1 c- S8 @9 A( n, |$ C- N* l2 S 24.jpg
    # f/ ?0 k5 b! y% k6 v
    为什么这样可行?我也只能给个近似的猜测:对 E^(a x + by + c z)==C 这样的方程,两边取对数就是 a x+ b y+ c z==log C 这就是一个平面的方程,把几个这样的平面方程加起来,就"围成"了一个多面体。而指数的增长保证了每个方向上不会受其它项的影响,保持大体是个平面。

    ! I- R! \7 I# |/ t7 p
    另外还值得指出的是,可以在指数上再加次数,让这样生成的多面体的边缘更加"锐利":
    . l6 Y/ h: R7 w* L
    25.jpg : i; O' X% }3 h6 F
    星形八面体
    在各种各样的多面体中,有一类多面体可以看作是若干基本的多面体彼此叠合组成,我们称之为复合多面体。比如下图所示的星形八面体,就可以看作两个正四面体彼此叠合而成。
    % n+ q( ]7 p7 q! E! y$ g% f% ^ 26.jpg
    + E1 J2 T8 n9 y观察这个复合多面体的面的组成指标可以发现,前四组只包含顶点 2、4、5、8,后四组只包含顶点 1、3、6、7。这恰好是各自组成两个正四面体。我们可以照样算出这八个面的法向量,然后分组各自生成两个正四面体曲面:
    , ?8 G/ `* U( ?! h 15.png
    * B6 o, E7 Z5 M7 D1 W, R求法向量,化简并分组:
    0 K7 x1 H; o4 [! L$ O0 i; M4 z 16.png 1 o# u6 @7 M5 K5 N8 V
    得到两个指数和的表达式:
    + Y7 }1 o' P1 z2 h  a3 v( P 17.png 3 d+ m% ^0 e$ y& U0 X3 T1 y
    分别绘制可以看到两个正四面体:
    + Y  X( K8 Z9 v2 D3 {5 b 27.jpg
      o- e' I% n& u0 e9 K# r3 F5 n如何从这两个四面体得到想要的星形八面体呢?直接相加肯定是不行的,那样得到的就是正八面体了。这里我们采用 The Nature of Mathematics and the Mathematics of Nature 一书中提到的一个小技巧:把两个方程表达式再次放到指数上。这个技巧称为 Exponential Scale:) ^7 Q5 p7 d5 f) `+ P8 K
    18.png
    ; r8 ?( l) s8 Y& u5 l可以看到,这个方程确实可以绘制出星形八面体:
    ) p1 T0 ~, D, L% l 28.jpg
    ) N0 [* Z1 }. y- Z可以把旋转观察这个星形八面体曲面的过程输出为动画:
    ; B. M# v% u, l. C" h8 b 19.png ) \' m9 [6 L$ R# M, E
    20.png + S) t7 |+ }9 \, k; Y
    微信图片_20200324153944.gif % r* l" O" ^  E0 `9 `" M$ {
    五复合正四面体
    # o* B: B/ A7 b% ]
    我们可以再举一个例子,五复合正四面体,这是由五个正四面体内接于一个正十二面体形成的复合多面体:
    29.jpg 6 c4 ^+ v( H2 m# [2 e" i% P
    照例求面法向量,化简并分组:
    30.jpg 6 i# d) N  b+ M

    6 A* J  m! [3 t得到方程:; p0 \+ H: [; l  u
    31.jpg
    % ^. g  {9 m7 s. O
    绘制可以得到五复合正四面体的近似曲面(警告:由于项数太多,运行绘制速度很慢,运行时请耐心等待):
    32.jpg
    ( {! b6 r! E4 z6 t; J/ Y6 a; d1 Z) x. j. j9 p8 ^$ h6 j4 K
    我们也用它生成一个旋转观察的动图:
    33.jpg
    1 N) x( T8 K( y8 L$ e( R& Z5 J+ r* K+ ~; e* w  a9 y
    微信图片_20200324154410.gif   B7 Y7 y( r2 ?+ R
    更多的复合多面体
    : r3 n) b! n' s
    只要是由凸多面体组成的复合多面体,理论上都可以用上面的方法,先求得各个多面体的方程,然后“抬升”到指数位置,得到复合多面体的方程。Mathematica 提供的PolyhedronData 函数里有许多复合多面体,我全部列在下面,感兴趣的读者可以自己实验生成想要的复合多面体曲面。& R- o  s% N6 F5 r( h+ F8 X( p/ [
    21.png
    0 l4 M- M# q1 B: F 34.jpg
      }: M- G2 V9 y% w+ ]对此有兴趣的,欢迎联系我们共同探讨。
    ; x) `' b( d, U' n1 }5 Rmarket@asdoptics.com
    : w  ?6 |* T, }1 W  Jwww.asdoptics.com
    3 C8 Y0 y2 i& o) U9 ^. D
    ' Y8 s+ ^( ~6 c" b3 `

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

    12.jpg

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

    51

    主题

    19

    听众

    7219

    积分

    升级  44.38%

  • TA的每日心情
    开心
    2025-5-2 07:59
  • 签到天数: 3340 天

    [LV.Master]伴坛终老

    超级版主

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

    使用道具 举报

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

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

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

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

    蒙公网安备 15010502000194号

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

    GMT+8, 2025-5-2 15:05 , Processed in 0.643699 second(s), 58 queries .

    回顶部