Wigner functions of mixed states#
Here, we will explore the Wigner quasiprobability distributions of “mixed states” (or, more accurately, of mixed ensembles).
Example: Cat state vs. mixture of coherent states#
First: a reminder of what the Wigner function of two coherent states at \(x=0\) with opposite momentum look like:
Show code cell source
N=30
rho1 = coherent_dm(N,3j)
rho2 = coherent_dm(N,-3j)
fig,ax = plt.subplots(1,2, figsize=(12,6))
plot_wigner(rho1, fig=fig, ax=ax[0])
ax[0].set_title(r"Coherent state $\alpha = 3i$")
plot_wigner(rho2, fig=fig, ax=ax[1])
ax[1].set_title(r"Coherent state $\alpha = -3i$")
plt.show()
data:image/s3,"s3://crabby-images/fe3bb/fe3bb4dd78e92a09781be45a75aa53e9ad348008" alt="../_images/eb18f6f5cbbb1f3f1f8ac9ab1a8741900e51dae96b28e083642dc57a065c2343.png"
Now, let’s compare a cat state and a mixed state.
Reminder
A cat state is a superposition of the wave functions:
whereas a 50/50 “mixed” state is defined by the sum of the density matrices:
Show code cell source
N=30
rho1 = coherent_dm(N,3j)
rho2 = coherent_dm(N,-3j)
mixed = rho1 + rho2
psi1 = coherent(N,3j)
psi2 = coherent(N,-3j)
cat = psi1 + psi2
fig,ax = plt.subplots(1,2, figsize=(12,6))
plot_wigner(cat, fig=fig, ax=ax[0])
ax[0].set_title(r"Wigner function of a cat state of $\alpha$ and $-\alpha$")
plot_wigner(mixed, fig=fig, ax=ax[1])
ax[1].set_title(r"Wigner function of a mixed state of $\alpha$ and $-\alpha$")
plt.show()
data:image/s3,"s3://crabby-images/df4ff/df4ff6b350ff3afce804d8762bb6a89ddbb659c7" alt="../_images/76ae7c83439ce69a21860ec33eda1eef78c3c429937a0978a31012c0416e1c61.png"
What is the difference? The “fringes” are gone! Similar to the coherences in the off-diagonal entries of the density matrix, the fringes of the cat state above are an indication of the “coherence” of the quantum superposition.
Without this “coherence”, the two “wave packets” do not interfere, as you can see if we plot \(|\psi(x)|^2\):
Show code cell source
# A hack to calculate the probability distribution
x = np.linspace(-7.5,7.5,500)
wigner_mixed = wigner(mixed,x,x)
wigner_cat = wigner(cat,x,x)
prob_mixed = np.sum(wigner_mixed,axis=0)
prob_cat = np.sum(wigner_cat,axis=0)
# Now the plot
fig,ax = plt.subplots(1,2, figsize=(12,4))
ax[0].plot(x,prob_cat)
ax[0].set_title("Cat state")
ax[1].plot(x,prob_mixed)
ax[1].set_title("Mixed state")
ax[0].set_yticks([])
ax[1].set_yticks([])
ax[0].axhline(0,ls=':', c='grey')
ax[1].axhline(0,ls=':', c='grey')
ax[0].set_xlabel("$x$")
ax[1].set_xlabel("$x$")
ax[0].set_ylabel(r"$|\psi(x)|^2$")
ax[1].set_ylabel(r"$|\psi(x)|^2$")
plt.show()
data:image/s3,"s3://crabby-images/69930/69930979bb5f6ea120f5318aa6676a90b26c173e" alt="../_images/6d86c2be1e17a0b080875c4a5c0142f9ee23486b3f4f6ce3351fddd9f0725c7d.png"
Of course, the proper interpretation of the lack of interference is, of course, that in the experiment there are not two wave-packets, but instead just one, and then we repeat the experiment over and over again, each time with only one coherent state of either \(\alpha\) or \(-\alpha\).
Example: Superposition vs. mixture of 0 and 1 photons#
Show code cell source
N=30
rho1 = fock_dm(N,0)
rho2 = fock_dm(N,1)
mixed = rho1 + rho2
psi1 = fock(N,0)
psi2 = fock(N,1)
sup = psi1 + psi2
fig,ax = plt.subplots(1,2, figsize=(12,6))
plot_wigner(sup, fig=fig, ax=ax[0])
ax[0].set_title("Superposition of 0 and 1 photons")
plot_wigner(mixed, fig=fig, ax=ax[1])
ax[1].set_title("Mixed state of 0 and 1 photons")
plt.show()
data:image/s3,"s3://crabby-images/048bd/048bd7a495b0319aff9d825d4ac6d2e9eb8c6b09" alt="../_images/a9550f8db7983f2604f28e89d48224b2c8ede8f6ed5fe992eb735d24a8370b17.png"
And now the “wave function” of the photon.
Reminder: What is the “wave function” of a photon?
A classical electromagnetic wave is a standing wave whose electric field oscillates in time: for example, for a given mode, we may have at a given fixed position in space an electric field with the following component in the z-direction:
where \(\hat{z}\) is a unit vector in the \(z\) direction. Note the similarity to the mass-on-a-spring, which oscillates in position:
In the mass-spring harmonic oscillator, we have a momentum \(p(t)\) that oscillates out of phase with the position:
In electromagnetism, there is also a magnetic field that also oscillates out of phase with the electric field :
(Note that if the \(E_z\) above belongs to a wave propagating in the \(x\) direction, then the magnetic field points in the \(y\) direction…)
The mapping from the mass-spring harmonic oscillator to the photon harmonic oscillator in this case is then:
position \(\rightarrow\) electric field
momentum \(\rightarrow\) magnetic field
Using this logic, for a photon, one can interpret the axes of the Wigner plots above as:
Real part of \(\alpha\) \(\rightarrow\) \(E_z\)
Imaginary part of \(\alpha\) \(\rightarrow\) \(B_y\)
The probability distributions of position \(|\psi(x)|^2\) and momentum \(|\phi(p)|^2\) are then replaced with probability distributions of \(E_z\) and \(B_y\):
\(|\psi(x)|^2 \rightarrow |\psi(E_z)|^2\)
\(|\phi(p)|^2 \rightarrow |\phi(B_y)|^2\)
Show code cell source
# A hack to calculate the probability distribution
x = np.linspace(-7.5,7.5,500)
wigner_mixed = wigner(mixed,x,x)
wigner_sup = wigner(sup,x,x)
prob_mixed = np.sum(wigner_mixed,axis=0)
prob_cat = np.sum(wigner_sup,axis=0)
# Now the plot
fig,ax = plt.subplots(1,2, figsize=(12,4))
ax[0].plot(x,prob_cat)
ax[0].set_ylabel(r"$|\psi(E_z)|^2$")
ax[0].set_title("Superposition of 0 and 1 photons")
ax[1].plot(x,prob_mixed)
ax[1].set_ylabel(r"Probability density of measuring $E_z$")
ax[1].set_title(r"Mixture of 0 and 1 photons")
ax[0].set_yticks([])
ax[1].set_yticks([])
ax[0].set_xlabel("$E_z$")
ax[1].set_xlabel("$E_z$")
ax[0].axhline(0,ls=':', c='grey')
ax[1].axhline(0,ls=':', c='grey')
plt.show()
data:image/s3,"s3://crabby-images/b6a32/b6a32b9ab4360c7f4c5a77701120902043efb2f2" alt="../_images/c7551d6a11b216598006aa5fd6f04b904d696d8975f90fab53c13f3dd2070db6.png"
Demonstration: Thermal state of a harmonic oscillator (or a large spin)#
Probability distributions for different temperatures:
Show code cell source
N = 30
Ntemp = 10
Npts = 100
Px = np.zeros([Npts,Ntemp])
T = np.linspace(0,5,Ntemp)
alpha_max = 7.5
x = np.linspace(-alpha_max,alpha_max,Npts)
fig, ax = plt.subplots()
line, = ax.plot(x, Px[:,0])
def update(i):
wig = wigner(thermal_dm(N,T[i]),x,x)
line.set_ydata(np.sum(wig,axis=0))
plt.ylabel("Probability density")
plt.xlabel("x")
plt.title("Thermal occupation from 0 to 5 quanta")
plt.ylim(-0.25, 4) # Set the y-axis limits
anim = animation.FuncAnimation(fig, update, frames=Ntemp)
plt.close(fig)
HTML(anim.to_jshtml())