forked from subangstrom/superAngle
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsingle_spot.m
53 lines (46 loc) · 2.76 KB
/
single_spot.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
function [ output, output_omega ] = single_spot( TiltX, TiltY, tot_Det_num, sample_para, holder_para, holder_frame_para, angle_search, SpuriousX)
%Omega calculation at single spot.
%Weizong Xu, Feb. 2015, [email protected]
sample_para(1,3)=TiltX;
sample_para(1,4)=TiltY;
A_Pout=zeros(tot_Det_num,1);
B_Pout=zeros(tot_Det_num,1);
Pratio=zeros(tot_Det_num,1);
output=zeros(tot_Det_num+1,4);
output_omega=zeros(tot_Det_num+1,4);
output_omega_deteff=zeros(tot_Det_num+1,4);
EleA_num = sample_para(13);
EleA_shell = sample_para(14);
EleB_num = sample_para(15);
EleB_shell = sample_para(16);
%Get detector efficiency;
temp = Excel_input ('Atomic_info.xlsx');
Xray_table (:,:,1) = temp(1:3,:); % K-shell xray energy, crossection, flurence yield
Xray_table (:,:,2) = temp(4:6,:); % L-shell xray energy, crossection, flurence yield
Xray_table (:,:,3) = temp(7:9,:); % M-shell xray energy, crossection, flurence yield
EleA_energy = Xray_table(1,EleA_num,EleA_shell); %keV
EleB_energy = Xray_table(1,EleB_num,EleB_shell); %keV
[ Det_eff_A, Det_eff_B ] = get_Det_eff( EleA_energy, EleB_energy, 'SDD_windowless_efficiency.xlsx' );
for i=1:tot_Det_num;
[A_Pout(i), B_Pout(i)] = Point_search(sample_para, holder_para, holder_frame_para, angle_search(:,:,i), SpuriousX(:,i));
Pratio(i)= A_Pout(i)/B_Pout(i); %A - Al; B - Ni;
output (i,:) = [i, A_Pout(i)/sum(angle_search(:,5,i)),B_Pout(i)/sum(angle_search(:,5,i)),Pratio(i)]; % counts*1e3;
output_omega (i,:) = [i, A_Pout(i),B_Pout(i),Pratio(i)]; % counts*1e3;
output_omega_deteff (i,:) = [i, A_Pout(i)*Det_eff_A,B_Pout(i)*Det_eff_B,Pratio(i)*Det_eff_A/Det_eff_B];
end
sym_A = get_element_name(EleA_num,EleA_shell);
sym_B = get_element_name(EleB_num,EleB_shell);
output (i+1,:) = [0.1234, sum(A_Pout)/sum(angle_search(:,5,i)),sum(B_Pout)/sum(angle_search(:,5,i)),sum(A_Pout)/sum(B_Pout)]; %all detectors
output_omega (i+1,:) = [0.1234, sum(A_Pout),sum(B_Pout),sum(A_Pout)/sum(B_Pout)]; %all detectors
disp(['TiltX: ',num2str(TiltX),' degree TiltY: ',num2str(TiltY), ' degree'])
disp('___________________________________________')
disp('Effective Solid angle reaching to detectors')
disp(['detector# ',sym_A,' ',sym_B, ' ', sym_A,'/', sym_B,' ratio'])
disp(num2str(output_omega));
disp(' ')
disp('___________________________________________')
output_omega_deteff (i+1,:) = [0.1234, sum(A_Pout)*Det_eff_A,sum(B_Pout)*Det_eff_B,sum(A_Pout)/sum(B_Pout)*Det_eff_A/Det_eff_B]; %all detectors
disp('Effective Solid angle * detector efficiency')
disp(['detector# ',sym_A,' ',sym_B, ' ', sym_A,'/', sym_B,' ratio'])
disp(num2str(output_omega_deteff));
end