無標題文章

"""

Created on Wed Nov 16 21:04:04 2016

@author: TanMingjun

"""

import matplotlib.pyplot as plt

import numpy as np

class billiard_circle():

def init(self,x_0,y_0,vx_0,vy_0,N,dt):

self.x_0 = x_0

self.y_0 = y_0

self.vx_0 = vx_0

self.vy_0 = vy_0

self.N = N

self.dt = dt

def motion_calculate(self):

self.x = []

self.y = []

self.vx = []

self.vy = []

self.t = [0]

self.x.append(self.x_0)

self.y.append(self.y_0)

self.vx.append(self.vx_0)

self.vy.append(self.vy_0)

for i in range(1,self.N):

self.x.append(self.x[i - 1] + self.vx[i - 1]*self.dt)

self.y.append(self.y[i - 1] + self.vy[i - 1]*self.dt)

self.vx.append(self.vx[i - 1])

self.vy.append(self.vy[i - 1])

if (np.sqrt( self.x[i]2+(self.y[i]-0.01)2 ) > 1.0) and self.y[i]>0.01:

self.x[i],self.y[i] = self.correct('np.sqrt(x2+(y-0.01)2) < 1.0',self.x[i - 1], self.y[i - 1], self.vx[i - 1], self.vy[i - 1])

self.vx[i],self.vy[i] = self.reflect1(self.x[i],self.y[i],self.vx[i - 1], self.vy[i - 1])

elif (np.sqrt( self.x[i]2+(self.y[i]+0.01)2 ) > 1.0) and self.y[i]<-0.01:

self.x[i],self.y[i] = self.correct('np.sqrt(x2+(y+0.01)2) < 1.0',self.x[i - 1], self.y[i - 1], self.vx[i - 1], self.vy[i - 1])

self.vx[i],self.vy[i] = self.reflect2(self.x[i],self.y[i],self.vx[i - 1], self.vy[i - 1])

elif (self.x[i] < -1.0) and self.y[i]>-0.01 and self.y[i]<0.01:

self.x[i],self.y[i] = self.correct('x>-1.0',self.x[i - 1], self.y[i - 1], self.vx[i - 1], self.vy[i - 1])

self.vx[i] = - self.vx[i]

elif (self.x[i] > 1.0) and self.y[i]>-0.01 and self.y[i]<0.01:

self.x[i],self.y[i] = self.correct('x<1.0',self.x[i - 1], self.y[i - 1], self.vx[i - 1], self.vy[i - 1])

self.vx[i] = - self.vx[i]

self.t.append(self.t[i - 1] + self.dt)

return self.x, self.y, self.t

def correct(self,condition,x,y,vx,vy):

vx_c = vx/100.0

vy_c = vy/100.0

while eval(condition):

x = x + vx_c*self.dt

y = y + vy_c*self.dt

return x-vx_cself.dt,y-vy_cself.dt

def reflect1(self,x,y,vx,vy):

module = np.sqrt(x2+(y-0.01)2) ### normalization

x = x/module

y = (y-0.01)/module+0.01

v = np.sqrt(vx2+vy2)

cos1 = (vxx+vy(y-0.01))/v

cos2 = (vx(y-0.01)-vyx)/v

vt = -v*cos1

vc = v*cos2

vx_n = vtx+vc(y-0.01)

vy_n = vt(y-0.01)-vcx

return vx_n,vy_n

def reflect2(self,x,y,vx,vy):

module = np.sqrt(x2+(y+0.01)2) ### normalization

x = x/module

y = (y+0.01)/module-0.01

v = np.sqrt(vx2+vy2)

cos1 = (vxx+vy(y+0.01))/v

cos2 = (vx(y+0.01)-vyx)/v

vt = -v*cos1

vc = v*cos2

vx_n = vtx+vc(y+0.01)

vy_n = vt(y+0.01)-vcx

return vx_n,vy_n

def plot(self):

plt.figure(figsize = (8,8))

plt.xlim(-1,1)

plt.ylim(-1,1)

plt.xlabel('x')

plt.ylabel('y')

plt.title('Stadium billiard $\alpha$=0.01')

self.plot_boundary()

plt.plot(self.x,self.y,'y')

#plt.savefig('chapter3_3.31.png',dpi = 144)

plt.show()

def plot_boundary(self):

theta = 0

x = []

y = []

while theta < np.pi:

x.append(np.cos(theta))

y.append(np.sin(theta)+0.01)

theta+= 0.01

plt.plot(x,y,'g.')

while theta > np.pi and theta< 2*np.pi:

x.append(np.cos(theta))

y.append(np.sin(theta)-0.01)

theta+= 0.01

plt.plot(x,y,'g.')

A1=billiard_circle(0,0,1,0.6,4000,0.01)

x1,y1,t1=A1.motion_calculate()

A2=billiard_circle(0.00001,0,1,0.6,4000,0.01)

x2,y2,t2=A2.motion_calculate()

delta=[]

for i in range(len(x1)):

x1[i]=np.sqrt((x1[i]-x2[i])2+(y1[i]-y2[i])2)

plt.semilogy(t1,x1)

plt.title('Stadium with $\alpha$=0.01 - divergence of two trajectories')

plt.xlabel('time')

plt.ylabel('separation')

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末揭绑,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,183評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡惜犀,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,850評論 3 399
  • 文/潘曉璐 我一進店門狠裹,熙熙樓的掌柜王于貴愁眉苦臉地迎上來虽界,“玉大人,你說我怎么就攤上這事涛菠±蛴” “怎么了?”我有些...
    開封第一講書人閱讀 168,766評論 0 361
  • 文/不壞的土叔 我叫張陵碗暗,是天一觀的道長颈将。 經常有香客問我,道長言疗,這世上最難降的妖魔是什么晴圾? 我笑而不...
    開封第一講書人閱讀 59,854評論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮噪奄,結果婚禮上死姚,老公的妹妹穿的比我還像新娘。我一直安慰自己勤篮,他們只是感情好都毒,可當我...
    茶點故事閱讀 68,871評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著碰缔,像睡著了一般账劲。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上金抡,一...
    開封第一講書人閱讀 52,457評論 1 311
  • 那天瀑焦,我揣著相機與錄音,去河邊找鬼梗肝。 笑死榛瓮,一個胖子當著我的面吹牛,可吹牛的內容都是我干的巫击。 我是一名探鬼主播禀晓,決...
    沈念sama閱讀 40,999評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼精续,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了粹懒?” 一聲冷哼從身側響起重付,我...
    開封第一講書人閱讀 39,914評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎凫乖,沒想到半個月后堪夭,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經...
    沈念sama閱讀 46,465評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡拣凹,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,543評論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了恨豁。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片嚣镜。...
    茶點故事閱讀 40,675評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖橘蜜,靈堂內的尸體忽然破棺而出菊匿,到底是詐尸還是另有隱情,我是刑警寧澤计福,帶...
    沈念sama閱讀 36,354評論 5 351
  • 正文 年R本政府宣布跌捆,位于F島的核電站,受9級特大地震影響象颖,放射性物質發(fā)生泄漏佩厚。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 42,029評論 3 335
  • 文/蒙蒙 一说订、第九天 我趴在偏房一處隱蔽的房頂上張望抄瓦。 院中可真熱鬧,春花似錦陶冷、人聲如沸钙姊。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,514評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽煞额。三九已至,卻和暖如春沾谜,著一層夾襖步出監(jiān)牢的瞬間膊毁,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,616評論 1 274
  • 我被黑心中介騙來泰國打工类早, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留媚媒,地道東北人。 一個月前我還...
    沈念sama閱讀 49,091評論 3 378
  • 正文 我出身青樓涩僻,卻偏偏與公主長得像缭召,于是被迫代替她去往敵國和親栈顷。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,685評論 2 360

推薦閱讀更多精彩內容