-
Notifications
You must be signed in to change notification settings - Fork 197
/
Copy pathHOwavePacketMat.py
37 lines (30 loc) · 1.27 KB
/
HOwavePacketMat.py
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 "COMPUTATIONAL PHYSICS" & "COMPUTER PROBLEMS in PHYSICS"
by RH Landau, MJ Paez, and CC Bordeianu (deceased)
Copyright R Landau, Oregon State Unv, MJ Paez, Univ Antioquia,
C Bordeianu, Univ Bucharest, 2017.
Please respect copyright & acknowledge our work."""
# HOwavePacketMat.py: HO Wave Packet wi Matplotlib Animation
from numpy import *
import numpy as np
import matplotlib.pyplot as plt
from matplotlib import animation
# Initialization
a = 1; oneoverpi = 1.0/(sqrt(np.pi))
fig = plt.figure()
ax = fig.add_subplot(111, autoscale_on=False, xlim=(-5,5), ylim=(0, 1.5))
ax.grid() # Plot a grid
plt.title("Wave Packet in H. O. potential")
plt.xlabel("x")
plt.ylabel (" $|\psi(x,t)|^2$")
line, = ax.plot([],[], lw=2)
def init(): # base frame
line.set_data([],[])
return line,
def animate(t): # Called repeatedly
y=oneoverpi*np.exp(-(x-a*np.cos(0.01*t))**2) # function to plot every 0.01*t
line.set_data(x,y)
return line,
x = np.arange(-5,5,0.01) # range for x values
ani = animation.FuncAnimation(fig, animate,init_func=init,frames=10000,\
interval=10,blit=True)
plt.show()