无标题文章

"""

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')

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容