The Nature of Code閱讀心得與Python實作:3.6 Properties of...

閱讀時間約 3 分鐘
這一節的標題是
3.6 Properties of Oscillation
因為方格子標題字數限制,所以沒完整顯現

這一節談的是振盪(oscillation),也就是在兩個點之間來回的週期性運動。日常生活中,隨處都可見到振盪的現象。例如,彈奏弦樂器時,弦的振動、盪鞦韆時的來回擺動、音叉的振動、單擺的來回擺動、彈簧的振動等。除了這些眼睛看得到的之外,麥克風、交流電、收音機、手機等許許多多的電子產品,也都是利用振盪的原理來運作的。

要談振盪,就免不了要來看一下正弦函數sin的圖形。

raw-image

從圖中可以看出來,sin的值會在-1到1之間來回改變。利用sin的這個特性,我們可以寫個程式,讓一個球在螢幕上,從左到右,再從右到左,不斷地來回擺盪。這種不斷來回擺盪的運動方式,叫做簡諧運動(simple harmonic motion, SHM)。這個程式很容易寫,不過在開始寫之前,要先熟悉一下振盪的相關術語。

一個進行簡諧運動的物體,它的位置會是時間的函數,而且可以用下列兩個性質來描述:

  • 振幅(amplitude):從運動中心點到端點的距離。
  • 週期(period):一個完整運動循環所需的時間。

當我們知道簡諧運動的振幅和週期之後,就可以造出能描述該簡諧運動的函數。有了能描述簡諧運動的函數之後,要寫程式來模擬它,就是水到渠成的事了。

根據上述振幅和週期的定義,可以很容易就從sin的圖形看出來,它的振幅是1,週期是2π。

知道振幅和週期所代表的意義之後,接下來就要來看看,那個讓一個球在螢幕上左右來回擺盪的程式要怎麼寫。

要想寫出讓一個球在螢幕上左右來回擺盪的程式,第一件要做的事,是要先確定:那個球擺盪的幅度有多大?速度又有多快?這兩個問題,其實也就是在問:振幅有多大?週期是多少?既然那個球是模擬世界中的球,要回答這兩個問題,就必須要知道,在模擬世界中,是怎麼衡量振幅和週期的。

既然振幅指的是距離,而週期指的是時間,那一直以來,我們用來衡量模擬世界中的距離和時間的方法,也就順理成章可以直接套用。這也就是說,我們會用像素和幀,當成衡量振幅和週期的單位。所以,如果有個振盪運動,中心點到端點的距離是100個像素,而且每隔120幀就會重複一次,那它的振幅就是100個像素,而週期則是120幀。

現在假設我們要讓那顆球以振幅A,週期T的方式擺盪,這時如果有個函數具有相同的振幅和週期,那我們不就可以利用它來計算,在不同的時間點球的位置了嗎?很幸運的,我們可以很容易的就用正弦函數sin,造出這樣子的函數來。

假設有個正弦函數長這樣

sin(ωt)

那它的週期會是

/ ω

這個其實也不難理解,把sin(ωt)稍微換個樣子就可以看出來了。令t'=ωt,則sin(ωt)=sint'。因為sint'的週期是2π,而這是以t'來衡量的,也就是畫圖時,橫軸是t'。所以把橫軸由t'=ωt還原成t,也就是改回用t來衡量時,週期會是2π/ω。

利用sin的這個特性,可以很容易就造出週期是T的sin函數。因為

/ ω = T

所以

ω = / T

也就是說

sin(2πt / T)

就是我們要的,週期為T的sin函數。

至於在振幅部分,因為sin函數的振幅是1,所以

A sin(2πt / T)

的振幅就會是A。

利用這個造出來的sin函數,那顆以振幅A週期T的方式擺盪的球的位置,就可以寫成下列程式

amplitude = A
period = T
x = amplitude*math.sin(2*math.pi*frame_count/period)

這裡的frame_count指的是已經執行的幀的數量。

下面是完整的程式。

Example 3.5: Simple Harmonic Motion I

# python version 3.10.9
import math
import sys

import pygame # version 2.3.0

pygame.init()

pygame.display.set_caption("Example 3.5: Simple Harmonic Motion I")

BLACK = (0, 0, 0)
WHITE = (255, 255, 255)

WIDTH, HEIGHT = screen_size = (640, 360)
screen = pygame.display.set_mode(screen_size)
screen_center = (WIDTH//2, HEIGHT//2)

FPS = 60
frame_rate = pygame.time.Clock()

amplitude = 150
period = 120

frame_count = 0

while True:
for event in pygame.event.get():
if event.type == pygame.QUIT:
pygame.quit()
sys.exit()

screen.fill(WHITE)

# 球的位置
x = amplitude*math.sin(2*math.pi*frame_count/period)
position = (x+WIDTH//2, HEIGHT//2)

pygame.draw.circle(screen, BLACK, position, 20)
pygame.draw.line(screen, BLACK, position, screen_center, 3)

frame_count += 1

pygame.display.update()
frame_rate.tick(FPS)

振盪的術語,除了振幅和週期這兩個之外,還有一個是頻率(frequency)。頻率指的是,單位時間內循環的次數,所以頻率會等於週期的倒數。例如,週期是120幀,那麼在1幀的時間內,會完成1/120個循環,所以頻率是1/120。從這裡可以看出來,週期和頻率,其實是一體兩面,都可以用來描述振盪的速度。那到底要用哪個比較好呢?其實青菜蘿蔔各有所好,覺得哪個好用,就用哪個囉!

Exercise 3.7

# python version 3.10.9
import math
import sys

import pygame # version 2.3.0

pygame.init()

pygame.display.set_caption("Exercise 3.7")

BLACK = (0, 0, 0)
WHITE = (255, 255, 255)

WIDTH, HEIGHT = screen_size = (640, 360)
screen = pygame.display.set_mode(screen_size)

FPS = 60
frame_rate = pygame.time.Clock()

amplitude = 100
period = 120

frame_count = 0

while True:
for event in pygame.event.get():
if event.type == pygame.QUIT:
pygame.quit()
sys.exit()

screen.fill(WHITE)

# 球的位置
y = amplitude*math.sin(2*math.pi*frame_count/period)
position = (WIDTH//2, y+HEIGHT//2)

pygame.draw.circle(screen, BLACK, position, 20)
pygame.draw.line(screen, BLACK, position, (WIDTH//2, 0), 3)

frame_count += 1

pygame.display.update()
frame_rate.tick(FPS)


avatar-img
15會員
131內容數
寫點東西自娛娛人
留言0
查看全部
avatar-img
發表第一個留言支持創作者!
ysf的沙龍 的其他內容
除了直角座標系統外,極座標(polar coordinate)系統是另一種相當有用的座標系統。
在模擬運動中的物體時,如果物體是圓形,那就不需要考慮旋轉的問題,畢竟不管怎麼轉,圓還是圓,看起來都一樣。但是,如果物體不是圓形而是其他形狀呢?
這一節主要在談三角函數和向量的分量、角度間的關聯性。這個關聯性在向量的應用上,非常重要。
角運動(angular motion)指的是物體的旋轉運動。物體進行直線運動時,可以用速度和加速度來描述它的運動。同樣的做法也可以運用在描述角運動上,我們可以用角速度(angular velocity)和角加速度(angular acceleration)來描述角運動。
角度有兩種單位,一個就是大家耳熟能詳的「度」(degree),記做 °;另一個是「弳度」(radian),也翻譯成「弧度」,記做rad。當使用弳度來度量角度的大小時,通常會把rad省略,不寫出來。
這一章主要在探討,如何模擬震盪(oscillation)相關的物理現象如波、單擺、彈簧等。
除了直角座標系統外,極座標(polar coordinate)系統是另一種相當有用的座標系統。
在模擬運動中的物體時,如果物體是圓形,那就不需要考慮旋轉的問題,畢竟不管怎麼轉,圓還是圓,看起來都一樣。但是,如果物體不是圓形而是其他形狀呢?
這一節主要在談三角函數和向量的分量、角度間的關聯性。這個關聯性在向量的應用上,非常重要。
角運動(angular motion)指的是物體的旋轉運動。物體進行直線運動時,可以用速度和加速度來描述它的運動。同樣的做法也可以運用在描述角運動上,我們可以用角速度(angular velocity)和角加速度(angular acceleration)來描述角運動。
角度有兩種單位,一個就是大家耳熟能詳的「度」(degree),記做 °;另一個是「弳度」(radian),也翻譯成「弧度」,記做rad。當使用弳度來度量角度的大小時,通常會把rad省略,不寫出來。
這一章主要在探討,如何模擬震盪(oscillation)相關的物理現象如波、單擺、彈簧等。
你可能也想看
Google News 追蹤
到目前為止,我們所模擬的萬有引力,是一個物體吸引另一個物體,或者是一個物體吸引多個物體。然而,在真實世界中,每個物體都會互相吸引,所以在這一節中,就來把模擬的情境,擴展成多個物體互相吸引。
Thumbnail
模擬世界是我們寫程式造出來的,我們就是模擬世界的主宰,所以各種作用力要長什麼樣子、要怎麼個作用法,都由我們決定。不過,如果希望這些作用力看起來像真實世界的作用力一樣,那在寫程式的時候,套用這些作用力在真實世界中的物理公式,會是比較省時省力的做法。
這一節談的是牛頓的三大運動定律,以及力對於物體運動狀態的影響。
介紹以物件導向的方式,以向量來實作物體運動的模擬程式。
介紹如何在模擬物體運動時,引入加速度這個物理量。
Thumbnail
這一節談的是向量的定義,以及如何運用向量來建立模擬物體運動時,關於位置和速度間的關係式。
Thumbnail
1.0 從函數到函算語法 1.2 函數概念小史 1.2.1 中譯的來源 1.2.2 一個速度問題 1.2.3 幾何的方法 1.2.4 微積分的記法 1.2.5 弦的振動 四 在這個背景下,法國物理學家達朗貝爾 (見貼文 32) 是論爭成員中發表振動弦運動的第一人,因此也是將這
Thumbnail
這篇要來分享關於「頻率」這件事,談到頻率,不免就要順便談談「吸引力法則」,現在訪間已經有多書籍、影片都有詳細描述吸引力法則的運行方式。它並不是什麼怪力亂神也不是什麼偽科學,實則吸引力法則是個再科學不過的量子力學,同頻相吸的概念而已。
到目前為止,我們所模擬的萬有引力,是一個物體吸引另一個物體,或者是一個物體吸引多個物體。然而,在真實世界中,每個物體都會互相吸引,所以在這一節中,就來把模擬的情境,擴展成多個物體互相吸引。
Thumbnail
模擬世界是我們寫程式造出來的,我們就是模擬世界的主宰,所以各種作用力要長什麼樣子、要怎麼個作用法,都由我們決定。不過,如果希望這些作用力看起來像真實世界的作用力一樣,那在寫程式的時候,套用這些作用力在真實世界中的物理公式,會是比較省時省力的做法。
這一節談的是牛頓的三大運動定律,以及力對於物體運動狀態的影響。
介紹以物件導向的方式,以向量來實作物體運動的模擬程式。
介紹如何在模擬物體運動時,引入加速度這個物理量。
Thumbnail
這一節談的是向量的定義,以及如何運用向量來建立模擬物體運動時,關於位置和速度間的關係式。
Thumbnail
1.0 從函數到函算語法 1.2 函數概念小史 1.2.1 中譯的來源 1.2.2 一個速度問題 1.2.3 幾何的方法 1.2.4 微積分的記法 1.2.5 弦的振動 四 在這個背景下,法國物理學家達朗貝爾 (見貼文 32) 是論爭成員中發表振動弦運動的第一人,因此也是將這
Thumbnail
這篇要來分享關於「頻率」這件事,談到頻率,不免就要順便談談「吸引力法則」,現在訪間已經有多書籍、影片都有詳細描述吸引力法則的運行方式。它並不是什麼怪力亂神也不是什麼偽科學,實則吸引力法則是個再科學不過的量子力學,同頻相吸的概念而已。