-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathSoftModeTISH.jl
98 lines (78 loc) · 3.6 KB
/
SoftModeTISH.jl
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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
module SoftModeTISH
using PyPlot
export TISH,TISHplot, BE, BEWeightedDensity, kBeV
# Following: http://www.cond-mat.de/teaching/DFT/qm1d.html
# # 1D numeric Shrodinger equation solver, by discretisation to an Eigenvalue problem
# # $f''(x_i) \approx (f(x_{i-1})-2*f(x_i)+f(x_{i+1}))/dx^2$
# V -> anonymous function generating the potential
# N -> number of points in
# dx -> Kinetic Energy operator; goes on the offdiagonal elements in real-space
function TISH(V,N=99,dx=1E2/(N-1),range=1.0)
# PE terms on the trace
diagonal = [(2.0/dx^2 + V(r))::Float64 for r in -range:2*range/N:range]
# KE terms on the tridiagonals
updiagonal = [(-1/dx^2)::Float64 for r in 1:N]
H =diagm(diagonal,0) + diagm(updiagonal,1) + diagm(updiagonal,-1)
# And solve with dense eigensolvers
evals,evecs=eig(H)
return evals,evecs
end
# n -> number of states to plot (all N states are calculated)
function TISHplot(V,evals,evecs, n=3,range=1.0)
N=length(evals)
#xlabel("Q")
xlabel(L"$Q_0$ [amu$^{\frac{1}{2}}$ $\AA$]")
ylabel("Energy (eV)") # (+ Psi^2)")
xrange=collect(-range:2*range/(N-1):range)
print(length(xrange))
plot(xrange,[V(r) for r in -range:2*range/(N-1):range],color="black") # Potential energy curve
# This many eigenenergies
for i in 1:n
# Ψ ; the wavefunction, offset by the eigenvalue
plot(xrange,(1.0/N).*evecs[:,i]+evals[i])
# Ψ^2 , the Prob. density, plotted grey, offset by the eigenvalues
plot(xrange,sqrt(1.0/N).*evecs[:,i].^2+evals[i],color="grey")
# Ψ^2, the prob density, filled curve in semi-tranparent grey, offset + to the eigenvalues
fill_between(xrange,evals[i],evals[i]+sqrt(1.0/N).*evecs[:,i].^2,color="grey",alpha=0.3)
end
end
# Right - very well! We have a 1D TISH solver.
# Now we're going to set up a function to generate a Bose-Einstein
# distribution, to be able to calculate the occupation of these states in a
# Quantum Harmonic Oscillator (i.e. phonon
# populations)
kBeV=8.6173324E-5 # in units of eV
#T=300 # Temperature; Kelvin
#μ=0.0 # Chemical potential; eV
function BE(E,μ=0.0,T=300.0)
# System specifics + derived quantities
β=1/(kBeV*T) # Thermodynamic Beta; units
1/(exp((E-μ)*β)-1)
end
# So now, let's get our `evals` and `evecs` from the TISH solver, then
# integrate over the set of eigenvalues, multiplying each probability density
# function ($\Psi^2$) with a Bose-Einstein (BE) occupation factor.
#
# We'll set the internal $\mu$ in the BE distribution to a value kbT below the
# lowest energy level to make it much less infinity, and roughly integrate out
# to give ~1, but then explicitly normalise the total density to exactly 1. I'm
# not quite sure what value should be used for $\mu$, it acts as
# a normalisation constant for the DoS. I assume it is explicitly a chemical
# potential, but as the population of Phonons changes, this confuses me.
function BEWeightedDensity(evals, evecs, T=300)
totaldensity=0.0
for i in 1:length(evals)
BEweight=BE(evals[i],evals[1]-kBeV*T,T)
# alpha set to kbT below the lowest energy level, ~ unitary summation
# if (BEweight>0.001)
# @printf("T: %03d State: %d : %f eV BE=%f \n",T,i,evals[i],BEweight)
# end
# Plot of weighted ψ^2 probability densities
# plot(BEweight * evecs[:,i].^2)
# Sum up density
totaldensity+= (BEweight * evecs[:,i].^2) # Density of this structure
end
totaldensity/=sum(totaldensity) # renormalise probability density to ∫ dx =1
return(totaldensity)
end
end