回上方

第15堂課

單擺程式碼:

 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
from vpython import *

g = 9.8

scene = canvas(center=vector(0,-1.0,0), background=vector(0.5,0.5,0))
ceiling = box(length=1, width=1, height = 0.01, color=color.blue)
ball = sphere(radius=0.1, color=color.red, make_trail=True)

ball.pos = vector(1,-1, 0)
ball.m = 0.5
ball.v = vector(0,0,0)

line = cylinder(radius = 0.01)
line.pos = ceiling.pos
line.axis = ball.pos - ceiling.pos
line.L = line.length
K = 100000.0

dt = 0.001

while True:
    rate(100)
    F = - K * (line.length-line.L) * line.axis.norm()
    ball.a = vector(0,-g,0) + F/ball.m
    ball.v = ball.v + ball.a * dt
    ball.pos = ball.pos + ball.v * dt
    line.axis = ball.pos - line.pos

作業:

(簡易牛頓擺)請修改以下程式碼,運用彈性碰撞讓右方單擺撞擊左方單擺,看看兩顆球運動情形。

 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
from vpython import *
g = 9.8

scene = canvas(center=vector(0,-1.0,0), background=vector(0.5,0.5,0))
ceiling = box(length=1, width=1, height=0.01, color=color.blue)

ball = sphere(radius=0.1, color=color.red, make_trail=True)
ball.pos = vector(0.6,-0.8, 0)
ball.m = 0.5
ball.v = vector(0,0,0)

ball2 = sphere(radius=0.1, color=color.red, make_trail=True)
ball2.pos = vector(-0.2,-1, 0)
ball2.m = 0.5
ball2.v = vector(0,0,0)

line = cylinder(radius = 0.01)
line.pos = ceiling.pos
line.axis = ball.pos - line.pos
line.L = line.length

line2 = cylinder(radius=0.01)
line2.pos = vector(-0.2,0,0)
line2.axis = ball2.pos - line2.pos
line2.L = line2.length

K = 100000.0

dt = 0.001

while True:
    rate(100)
    F = - K * (line.length-line.L) * line.axis.norm()
    ball.a = vector(0,-g,0) + F/ball.m
    ball.v = ball.v + ball.a * dt
    ball.pos = ball.pos + ball.v * dt
    line.axis = ball.pos - line.pos

本單元課程自2018.7.5日起已被瀏覽 287