はじめに
matplotlibのFuncAnimationで自由落下と反発係数を考慮したバウンドのアニメーションを表示する。
コード
解説
モジュールのインポートなど
バージョン
時間データの作成
np.arangeで15sまで0.05刻みで時間データを作成する。配列のサイズは300となる。
重力加速度は9.8 m/sとした。
自由落下時の位置変化
初期位置を100とした場合、地面に到着する時間はt_posi0となる。
地面に到着する時間のときのtにおけるインデックスを求める。
np.argmin(np.abs(t-t_posi0))で求められる。
自由落下の位置変化を表示すると以下のようになる。
data:image/s3,"s3://crabby-images/ba217/ba21759a20c0ce67d51c458642e805079e5e359a" alt=""
バウンド時の位置変化
反発係数を0.8として、衝突前のスピードと衝突後のスピードを求める。
位置変化は以下のようになる。
data:image/s3,"s3://crabby-images/eda3d/eda3d40a7f1164a89cbc5d6449fc35bf79423936" alt=""
np.where(b1_z>0)[0][-1]で位置が正の値の位置の最後のインデックスを求めて、位置データをスライスして表示すると下記のようになる。
data:image/s3,"s3://crabby-images/e5a0a/e5a0a17969b4d93855cbe18c58ff3dfeb7b1fbd4" alt=""
2回目のバウンド
data:image/s3,"s3://crabby-images/55309/55309f6ae8eaccadd3556e4aff608489b2f408f6" alt=""
3回目のバウンド
data:image/s3,"s3://crabby-images/9b5ac/9b5ac053a1de2214569a86a44dac8fed7a5e1b49" alt=""
4回目のバウンド
data:image/s3,"s3://crabby-images/8c724/8c72430e2d4034e51c1a54fcb7598e44fed192e9" alt=""
5回目のバウンド
data:image/s3,"s3://crabby-images/d7593/d759331e2ba81a77fd1925ce0e7f1eef0705a3d9" alt=""
6回目のバウンド
data:image/s3,"s3://crabby-images/ec369/ec3693dac644ff1a5b6663c68d8325fdaa782cf9" alt=""
位置データの連結
np.concatenate()で全ての位置データを連結する。図示すると以下のようになる。
data:image/s3,"s3://crabby-images/60560/6056067519f8ad6f60c07f0ef5fc70880de680ec" alt=""
データの大きさは627となる。
アニメーションで表示
ax.hlines(0,-.25,.25)でy=0の位置に平行線を表示する。
ax.spines[‘right’].set_visible(False)などで左以外の軸を消す。
アニメーション関数の設定
set_ydataでplot(ball1)のydataをセットする。
アニメーションの表示
FuncAnimationでアニメーションを表示する。frame数を627、intervalを10msとし、6秒少々のアニメーションとする。 HTML(ani.to_html5_video())
により、jupyter notebook またはjupyter lab上にアニメーションを表示できる。
ani.save(‘ファイル名’, writer=”ffmpeg”,dpi=100)でアニメーションをMP4形式で保存することができる。
反発係数を0.5とした場合
反発係数を0.95とした場合
参考
data:image/s3,"s3://crabby-images/fa19b/fa19bcc3a6adf131ff59d9dc69b9bedd8eae6b76" alt=""
data:image/s3,"s3://crabby-images/bd5a2/bd5a2fd9a7626dbc484f7b3bdf92459bf70992e9" alt=""
コメント