]> anharmonic_oscillator.html anharmonic_oscillator.mws

The anharmonic oscillator

Marc R. Roussel

Department of Chemistry and Biochemistry

University of Lethbridge

We start by defining the harmonic-oscillator wavefunctions, which will be the zero-order wavefunctions in our perturbation treatment of the anharmonic oscillator.

>    A := n -> sqrt(beta/(2^n*n!*sqrt(Pi)));

A := proc (n) options operator, arrow; sqrt(beta/(2^n)/n!/sqrt(Pi)) end proc

>    with(orthopoly,H):

>    psi0 := (n,x) -> A(n)*H(n,beta*x)*exp(-beta^2*x^2/2);

psi0 := proc (n, x) options operator, arrow; A(n)*H(n,beta*x)*exp(-1/2*beta^2*x^2) end proc

>    assume(beta>0);

The energies of the unperturbed system are given by

>    E0 := n -> (n+1/2)*hbar*omega0;

E0 := proc (n) options operator, arrow; (n+1/2)*hbar*omega0 end proc

The perturbing Hamiltonian is

>    H1 := x -> 1/6*g*x^3;

H1 := proc (x) options operator, arrow; 1/6*g*x^3 end proc

The first-order correction to the ground-state energy is

>    E01 := int(psi0(0,x)*H1(x)*psi0(0,x),x=-infinity..infinity);

E01 := 0

The even coefficients of the corrected wavefunction expressed in terms of the zero-order wavefunctions are all zero. (Why?) The odd coefficients are

>    c01 := int(psi0(1,x)*H1(x)*psi0(0,x),x=-infinity..infinity)/(E0(0)-E0(1));

c01 := -1/8*2^(1/2)/beta^3*g/hbar/omega0

>    c03 := int(psi0(3,x)*H1(x)*psi0(0,x),x=-infinity..infinity)/(E0(0)-E0(3));

c03 := -1/36*3^(1/2)/beta^3*g/hbar/omega0

>    c05 := int(psi0(5,x)*H1(x)*psi0(0,x),x=-infinity..infinity)/(E0(0)-E0(5));

c05 := 0

>    c07 := int(psi0(7,x)*H1(x)*psi0(0,x),x=-infinity..infinity)/(E0(0)-E0(7));

c07 := 0

Apparently, the higher-order coefficients are all zero. This has nothing to do with any simple symmetry so is impossible to predict. However, we now have our corrected, but unnormalized wavefunction:

>    psi1_0u := x -> psi0(0,x) + c01*psi0(1,x) + c03*psi0(3,x);

psi1_0u := proc (x) options operator, arrow; psi0(0,x)+c01*psi0(1,x)+c03*psi0(3,x) end proc

To normalize this wavefunction, we look for a factor B 0 such that B 0 y  is normalized. This factor is

>    B0 := sqrt(1/simplify(int(psi1_0u(x)^2,x=-infinity..infinity)));

B0 := 12*6^(1/2)*beta^3*(1/(864*beta^6*hbar^2*omega0^2+29*g^2)*hbar^2*omega0^2)^(1/2)

The normalized wavefunction is therefore

>    psi1_0 := x -> B0*psi1_0u(x);

psi1_0 := proc (x) options operator, arrow; B0*psi1_0u(x) end proc

We now turn to the first excited state. Only even wavefunctions will couple to it through the perturbing Hamiltonian. The coefficients are

>    c10 := int(psi0(0,x)*H1(x)*psi0(1,x),x=-infinity..infinity)/(E0(1)-E0(0));

c10 := 1/8*2^(1/2)/beta^3*g/hbar/omega0

>    c12 := int(psi0(2,x)*H1(x)*psi0(1,x),x=-infinity..infinity)/(E0(1)-E0(2));

c12 := -1/2/beta^3*g/hbar/omega0

>    c14 := int(psi0(4,x)*H1(x)*psi0(1,x),x=-infinity..infinity)/(E0(1)-E0(4));

c14 := -1/18*3^(1/2)/beta^3*g/hbar/omega0

>    c16 := int(psi0(6,x)*H1(x)*psi0(1,x),x=-infinity..infinity)/(E0(1)-E0(6));

c16 := 0

>    c18 := int(psi0(8,x)*H1(x)*psi0(1,x),x=-infinity..infinity)/(E0(1)-E0(8));

c18 := 0

Again, it appears to be the case that the series terminates after a few terms. The unnormalized wavefunction is therefore

>    psi1_1u := x -> psi0(1,x) + c10*psi0(0,x) + c12*psi0(2,x) + c14*psi0(4,x);

psi1_1u := proc (x) options operator, arrow; psi0(1,x)+c10*psi0(0,x)+c12*psi0(2,x)+c14*psi0(4,x) end proc

We now normalize the wavefunction:

>    B1 := sqrt(1/simplify(int(psi1_1u(x)^2,x=-infinity..infinity)));

B1 := 12*6^(1/2)*beta^3*(1/(251*g^2+864*beta^6*hbar^2*omega0^2)*hbar^2*omega0^2)^(1/2)

>    psi1_1 := x -> B1*psi1_1u(x);

psi1_1 := proc (x) options operator, arrow; B1*psi1_1u(x) end proc

Now suppose that we want to plot our corrected wavefunctions. We first relate b and  w 0 to k  and m :

>    assign(beta=sqrt(sqrt(k*m)/hbar));

>    omega0 := sqrt(k/m);

omega0 := (k/m)^(1/2)

We now need to give values for the parameters which appear in the wavefunction. I will use SI units consistently throughout.

>    hbar := 1.1e-34;

hbar := .11e-33

Suppose that the particle at the end of the spring is a proton with

>    m := 1.7e-27;

m := .17e-26

We have to choose a value for k . Suppose that the proton is connected to a heavy molecule. Typical XH stretching frequencies are of the order of 5x10^{14}s^{-1}. Thus k  is typically a few hundred N/m for XH bonds.

>    k := 400;

k := 400

Finally, we need to choose a value for the anharmonicity g . The anharmonicity can be computed from the dissociation energy and bond stiffness using a formula which we will see later. Realistic anharmonicities are negative. A typical value would be

>    g := -2e13;

g := -.2e14

While this seems very large, we must consider the very small amplitude of molecular vibrations in interpreting this number. The classical turning points give us an order of magnitude estimate of the vibration amplitude. Thus, the vibration amplitude is ~1/ b , i.e.

>    amp:=1/beta;

amp := .1154965773e-10

The relative sizes of the harmonic and anharmonic terms of the potential near the turning points is

>    abs(H1(amp)/(k*amp^2/2));

.1924942955

so the anharmonic term is relatively small, growing to 20% of the harmonic term near the classical turning points. Let us confirm this back-of-the-envelope calculation by plotting the two potentials over a reasonable range of values of x :

>    plot([k*x^2/2,k*x^2/2+H1(x)],x=-5*amp..5*amp,color=[red,blue]);

[Maple Plot]

>    plot([psi0(0,x),psi1_0(x)],x=-5*amp..5*amp,color=[red,blue]);

[Maple Plot]

The lower value of the anharmonic potential at positive values of x  breaks the symmetry of the wavefunction. The wavefunction "leans" to the right. A similar effect is seen in the first excited state:

>    plot([psi0(1,x),psi1_1(x)],x=-5*amp..5*amp,color=[red,blue]);

[Maple Plot]

>