第14堂課
兩自由落體球間的彈性碰撞
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 | # -*- coding: utf8 -*-
# 匯入視覺化套件
from vpython import *
# 1. 參數設定
# 重力加速度
g = -9.8
# 時間間隔
dt = 0.0001
# 經過時間
t=0
# 2. 畫面設定
# 畫布
scene = canvas(width=600, height=600, background=vector(0.5,0.6,0.5), center=vector(0,2,0))
# 地板
floor = box(pos=vector(0,-0.2,0), length=5, height=0.1, width=5, texture=textures.wood)
# 兩球高度時間圖
gd = graph(title='y vs t', xtitle='t', ytitle='y', ymax=13, xmax=10, background=vector(0.3,0.3,0.3))
yt1 = gcurve(graph=gd, color=color.cyan)
yt2 = gcurve(graph=gd, color=color.red)
# 3. 球的設定
ball1 = sphere(radius=0.05, color=color.white, v=0, m=0.2)
ball2 = sphere(radius=0.1, color=color.white, v=0, m=0.6)
ball2.pos = vector(0,2,0)
ball1.pos=vector(0,2+ball1.radius+ball2.radius+0.05,0)
# 4. 函數定義
def collide(v1,v2,m1,m2):
v1f = v1*(m1-m2)/(m1+m2) + v2*2*m2/(m1+m2)
v2f = v1*2*m1/(m2+m1) + v2*(m2-m1)/(m2+m1)
return v1f, v2f
# 5. 運動部分
while t<=10:
rate(2000)
t = t + dt
ball1.v = ball1.v + g * dt
ball1.pos.y = ball1.pos.y + ball1.v * dt
if ball1.pos.y <= 0:
ball1.v = -ball1.v
yt1.plot( pos = (t, ball1.pos.y))
ball2.v = ball2.v + g * dt
ball2.pos.y = ball2.pos.y + ball2.v * dt
if ball2.pos.y <= 0:
ball2.v = -ball2.v
yt2.plot( pos = (t, ball2.pos.y))
# 兩球碰撞
if mag(ball1.pos-ball2.pos) <= ball1.radius + ball2.radius :
ball1.v, ball2.v = collide(m1=ball1.m, v1=ball1.v, v2=ball2.v, m2=ball2.m)
|
作業:
三顆球從高空自由落下互相追撞。
本單元課程自2018.7.5日起已被瀏覽 244 次