【FreeCAD初心者ガイド】FreeCAD付属のmatplotlibを使って3次元モデリングに便利なプロトタイプ関数を思索する
※ 当ページには【広告/PR】を含む場合があります。
2023/10/06
data:image/s3,"s3://crabby-images/a02aa/a02aaa4af556726de09d0a88d8460396a75b8ba9" alt="蛸壺の中の工作室|FreeCAD付属のmatplotlibを使って3次元モデリングに便利なプロトタイプ関数を思索する"
FreeCADでmatplotlibを使うための基本操作
data:image/s3,"s3://crabby-images/8ce05/8ce059aa7160694549bb18a915afc5e5c3d87502" alt="合同会社タコスキングダム|蛸壺の中の工作室"
[マクロ]
[マクロの実行]
[ユーザーマクロの場所]
[作成]
[OK]
import numpy as np
import matplotlib.pyplot as plt
x = np.linspace(-2*np.pi, 2*np.pi, 100)
y = np.sin(x)
plt.plot(x,y)
plt.show()
data:image/s3,"s3://crabby-images/2a7c6/2a7c692b3f4e898ddc8c82faa581cdf9c3f7c4b8" alt="合同会社タコスキングダム|蛸壺の中の工作室"
FreeCADで2次元グラフを描く〜Plotワークベンチ編
Plotワークベンチのインストール
data:image/s3,"s3://crabby-images/83944/839444a0c67d6b58a18c43fb37fb3495dcc700bc" alt="合同会社タコスキングダム|蛸壺の中の工作室"
data:image/s3,"s3://crabby-images/9c5d4/9c5d4739a96677be10dc6118d417094d9e33b1ff" alt="合同会社タコスキングダム|蛸壺の中の工作室"
data:image/s3,"s3://crabby-images/41fd5/41fd5a5b1e6974d59b79e3224de8b27d7302c71c" alt="合同会社タコスキングダム|蛸壺の中の工作室"
Plotワークベンチを利用して関数を描画する
data:image/s3,"s3://crabby-images/28c0d/28c0de39b42a1d13980e41053940e45e9be54155" alt="合同会社タコスキングダム|蛸壺の中の工作室"
[表示] > [パネル] > [Pythonコンソール]
from FreeCAD.Plot import Plot
from freecad.plot import Plot
Plot.plot([0, 1], [0, 2])
data:image/s3,"s3://crabby-images/706e1/706e16050b5cef64b917690aeebacf2b3f61cca4" alt="合同会社タコスキングダム|蛸壺の中の工作室"
plot☓
Plotワークベンチでグラフを装飾する
from FreeCAD.Plot import Plot
import numpy as np
t = np.linspace(0, 1, 101)
s = np.sin(2.0*np.pi*t)
c = np.cos(2.0*np.pi*t)
Plot.plot(t,s)
Plot.plot(t,c)
data:image/s3,"s3://crabby-images/e2b71/e2b7144a10bd67c187b391a8e547a5d559dec6ee" alt="合同会社タコスキングダム|蛸壺の中の工作室"
data:image/s3,"s3://crabby-images/7b776/7b7762b8f1788e2df866cd71ee4864d00cf3a7be" alt="合同会社タコスキングダム|蛸壺の中の工作室"
1. 横軸/縦軸の表示範囲を調整
2. ブロットの線種・点種・配色
3. ラベル(タイトル・x軸・y軸)の文字・フォントサイズ
4. ラベル・レジェンドの表示位置を修正
FreeCADで3次元グラフを描く
from mpl_toolkits.mplot3d import Axes3D
import matplotlib.pyplot as plt
import numpy as np
fig = plt.figure()
ax = fig.add_subplot(projection="3d")
z = np.linspace(0, 10, 2)
theta = np.linspace(-np.pi, np.pi, 5)
Theta, Z = np.meshgrid(theta, z)
r0 = 10
X = r0 * np.cos(Theta)
Y = r0 * np.sin(Theta)
ax.plot_wireframe(X, Y, Z, color='darkblue')
plt.show()
data:image/s3,"s3://crabby-images/c7931/c7931d3a9dcb16c2cd76ae9f0adde4fbdb7caae0" alt="合同会社タコスキングダム|蛸壺の中の工作室"
from mpl_toolkits.mplot3d import Axes3D
import matplotlib.pyplot as plt
import numpy as np
fig = plt.figure()
ax = fig.add_subplot(projection="3d")
z = np.linspace(0, 10, 5)
theta = np.linspace(-np.pi, np.pi, 100)
Theta, Z = np.meshgrid(theta, z)
r0 = 10
X = r0 * np.cos(Theta)
Y = r0 * np.sin(Theta)
ax.plot_wireframe(X, Y, Z, color='darkblue')
plt.show()
data:image/s3,"s3://crabby-images/bfb24/bfb24147a2cb603e600fdd86355b9fb281c48788" alt="合同会社タコスキングダム|蛸壺の中の工作室"
まとめ
記事を書いた人
ナンデモ系エンジニア
電子工作を身近に知っていただけるように、材料調達からDIYのハウツーまで気になったところをできるだけ細かく記事にしてブログ配信してます。
カテゴリー