-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconstructLossMatrix.m
87 lines (72 loc) · 2.5 KB
/
constructLossMatrix.m
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
function Gamma = constructLossMatrix(varargin)
%% constructs the loss matrix for the OBE
%% we suppose that all excited states have the same lifetime of 1
p = inputParser;
p.addRequired('lowFStates', @(x)isnumeric(x));
p.addRequired('upperFStates', @(x)isnumeric(x));
p.addRequired('normEl', @(x)isnumeric(x));
p.addOptional('J', 1/2, @(x)isnumeric(x));
p.addOptional('Jp', 1/2, @(x)isnumeric(x));
p.addParamValue('I', 3/2, @(x)isnumeric(x));
p.addParamValue('debug', 0, @(x)isnumeric(x));
parse(p,varargin{:});
lowFStates = p.Results.lowFStates;
upperFStates = p.Results.upperFStates;
normEl = p.Results.normEl;
J = p.Results.J;
Jp = p.Results.Jp;
I = p.Results.I;
debug = p.Results.debug;
NlowF = length(lowFStates);
NupperF = length(upperFStates);
NlowTotal = lowFStateEndInd(lowFStates,NlowF);
NupperTotal = upperFStateEndInd(upperFStates,NlowTotal,NupperF)-NlowTotal;
Nlevel = NlowTotal+NupperTotal;
Gamma = zeros(Nlevel^2);
% branching ratio
for lFInd=1:NlowF
F = lowFStates(lFInd);
sInd = lowFStateStartInd(lowFStates,lFInd);
eInd = lowFStateEndInd(lowFStates,lFInd);
for uFInd = 1:NupperF
Fp = upperFStates(uFInd);
sFInd = upperFStateStartInd(upperFStates,NlowTotal,uFInd);
eFInd = upperFStateEndInd(upperFStates,NlowTotal,uFInd);
for ii=sInd:eInd
mF = ii-(sInd-1)-(F+1);
for jj = sFInd:eFInd
mFp = jj-(sFInd-1)-(Fp+1);
lGind = returnDensityEvInd(ii,ii,Nlevel);
uGind = returnDensityEvInd(jj,jj,Nlevel);
amp = DecayAmplitude(F,Fp,mF,mFp,normEl,...
'J', J, 'Jp', Jp, 'I', I);
Gamma(lGind,uGind) = amp;
end
end
end
end
% lifetime of the upper states
for ii=NlowTotal+1:Nlevel
for jj=NlowTotal+1:Nlevel
ind1 = returnDensityEvInd(ii,jj,Nlevel);
ind2 = returnDensityEvInd(jj,ii,Nlevel);
Gamma(ind1,ind1) = -1;
Gamma(ind2,ind2) = -1;
end
end
% now the lifetime of the coherences between upper and lower dudes
for ii=1:NlowTotal
for jj=NlowTotal+1:Nlevel
ind1 = returnDensityEvInd(ii,jj,Nlevel);
ind2 = returnDensityEvInd(jj,ii,Nlevel);
Gamma(ind1,ind1) = -1/2;
Gamma(ind2,ind2) = -1/2;
end
end
if debug
for uFInd = 1:NupperF
sFInd = upperFStateStartInd(upperFStates,NlowTotal,uFInd);
invLT = -Gamma(returnDensityEvInd(sFInd,sFInd,Nlevel),returnDensityEvInd(sFInd,sFInd,Nlevel));
disp([ 'invLT =' num2str(invLT)]);
end
end