はじめに
matplotlibのmplot3dの3Dボクセルグラフで立体的なハートを表示する。
コード
ハート
data:image/s3,"s3://crabby-images/dbbf8/dbbf82a5b0492f68275744ccd888ab946f53dbbc" alt=""
回転アニメーション
解説
モジュールのインポート
データの生成
データの生成については、下記のトーラスと同様にして生成した。
data:image/s3,"s3://crabby-images/d5cad/d5cad26e202773db5bf059e06f9b9ffe3f53da9d" alt=""
[matplotlib 3D] 31. voxels_torus
matplotlib mplot3dのvoxelでトーラスを表示。
heartの3D形状は以下の式で表される。[1]
$$(x^2 + \frac{4}{9}y^2+z^2-1)^3 -x^2z^3+ -\frac{9}{80}y^2z^3 = 0$$<0とすることでハートの部分だけボクセルを表示することができる。
ハートの表示
アニメーションの表示
アニメーションのコードは下記のwireframeの回転アニメーションとおなじコードとなっている。
data:image/s3,"s3://crabby-images/ff312/ff312379bbbc41e34e62044656f344b3ea61ca41" alt=""
[matplotlib 3D] 14. 3Dグラフの回転アニメーション
matplotlib mplot3d のグラフの回転アニメーション
参考
data:image/s3,"s3://crabby-images/97d35/97d3579e79d4089f846a5558ef448323d16d3a5e" alt=""
Heart Surface -- from Wolfram MathWorld
A heart-shaped surface given by the sextic equation (x^2+9/4y^2+z^2-1)^3-x^2z^3-9/(80)y^2z^3=0 (Taubin 1993, 1994). The ...
コメント