首先我们将theta作为横坐标,omega作为纵坐标,同时变化F_D的参数,比较这两种情况下摆的混沌效应.
data:image/s3,"s3://crabby-images/ad784/ad784e3db98d31c20a8c9b00df5c08de3daa54bc" alt=""-q\frac{d\theta}{dt}+F_Dsin(\Omega_D t))
data:image/s3,"s3://crabby-images/aea3f/aea3f284eed89d3ceb4f41f8240be85b09b24d1b" alt=""
data:image/s3,"s3://crabby-images/d353e/d353eba2301445ad21d28172be02a53d5d9dc67a" alt=""
Then we only plot omega versus theta only at times that are in phase with the driving force.
That is,we only display the point when
data:image/s3,"s3://crabby-images/31831/318311fd046f2850519b7522299c8c87b0b5cfa8" alt=""
where n is an integer.
- 也就是说,当满足
data:image/s3,"s3://crabby-images/79a4d/79a4d80bb41bccd800d0c9901192340fca5d1184" alt=""时,我们就将相应的点放置上去
代码实现
def Omega2Theta(self):
self.swing()
loop = True
i = 0
n = 0
while(loop):
# omega_D * t = 2 * pi * n
if (self.t[i] > (2*n+1)*math.pi/self.omega_d):
n += 1
if (abs(self.t[i] - 2 * n * math.pi/self.omega_d) < (self.dt/2)):
self.theta_ps.append(self.theta[i])
self.omega_ps.append(self.omega[i])
i += 1
if self.total_time < self.t[i]:
loop = False
data:image/s3,"s3://crabby-images/741b0/741b08a3cda992c6f9ac411c1752a0e5d375a145" alt=""
接下来让我们变化一下参数:
data:image/s3,"s3://crabby-images/c1bf0/c1bf0c749688b78242cffc087dfbcb1c9dd99bda" alt=""
data:image/s3,"s3://crabby-images/97600/9760092c18c3179f613ba4da97df14a0979a6c2c" alt=""
我们观察一下\theta与t在变化的驱动力下的关系图
data:image/s3,"s3://crabby-images/90eb0/90eb0d5ce0ad71f5c177d7ac52aa20037254eb78" alt=""
data:image/s3,"s3://crabby-images/a3e04/a3e04a47f682d45e53515854ddd1da3f37ebf46e" alt=""
data:image/s3,"s3://crabby-images/c4825/c482562924c33f30705a233ef5375182335f7f88" alt=""
- 致谢
卢江玮的代码助攻~
网友评论