2021-07-19 12:55:17 +02:00
|
|
|
OptionsStruct = struct;
|
|
|
|
OptionsStruct.ErrorEstimationMethod = 'bootstrap'; % 'jackknife' | 'bootstrap'
|
|
|
|
OptionsStruct.NumberOfAtoms = 5000;
|
|
|
|
OptionsStruct.TimeStep = 50e-06; % in s
|
2021-08-19 12:39:10 +02:00
|
|
|
OptionsStruct.SimulationTime = 5e-03; % in s
|
2021-07-19 12:55:17 +02:00
|
|
|
OptionsStruct.SpontaneousEmission = true;
|
2021-08-30 10:36:42 +02:00
|
|
|
OptionsStruct.SidebandBeam = true;
|
2021-07-19 12:55:17 +02:00
|
|
|
OptionsStruct.PushBeam = true;
|
|
|
|
OptionsStruct.Gravity = true;
|
2021-08-30 10:36:42 +02:00
|
|
|
OptionsStruct.BackgroundCollision = true;
|
2021-07-19 12:55:17 +02:00
|
|
|
OptionsStruct.SaveData = true;
|
|
|
|
% OptionsStruct.SaveDirectory = '';
|
|
|
|
options = Helper.convertstruct2cell(OptionsStruct);
|
|
|
|
clear OptionsStruct
|
|
|
|
|
|
|
|
Oven = Simulator.Oven(options{:});
|
|
|
|
MOT2D = Simulator.TwoDimensionalMOT(options{:});
|
2021-08-19 12:39:10 +02:00
|
|
|
Beams = MOT2D.Beams;
|
2021-07-19 12:55:17 +02:00
|
|
|
|
|
|
|
%%
|
2021-08-19 12:39:10 +02:00
|
|
|
MOT2D.NumberOfAtoms = 10000;
|
|
|
|
MOT2D.TotalPower = 0.8;
|
|
|
|
MOT2D.MagneticGradient = 0.4; 0;
|
|
|
|
CoolingBeam = Beams{cellfun(@(x) strcmpi(x.Alias, 'Blue'), Beams)};
|
|
|
|
CoolingBeam.Waist = 15e-03;
|
|
|
|
CoolingBeam.Detuning = -1.67*Helper.PhysicsConstants.BlueLinewidth;
|
|
|
|
SidebandBeam = Beams{cellfun(@(x) strcmpi(x.Alias, 'BlueSideband'), Beams)};
|
|
|
|
SidebandBeam.Waist = 15e-03;
|
|
|
|
|
|
|
|
NumberOfPointsForFirstParam = 20; %iterations of the simulation
|
|
|
|
NumberOfPointsForSecondParam = 20;
|
|
|
|
DetuningArray = linspace(-1.0, -6.0, NumberOfPointsForFirstParam) * Helper.PhysicsConstants.BlueLinewidth;
|
|
|
|
PowerArray = linspace(0, 0.8, NumberOfPointsForSecondParam) * MOT2D.TotalPower;
|
|
|
|
|
|
|
|
tStart = tic;
|
|
|
|
[LoadingRateArray, ~, ~] = Scripts.scanForSidebandEnhancement(Oven, MOT2D, 'Blue', 'BlueSideband', DetuningArray, PowerArray);
|
|
|
|
tEnd = toc(tStart);
|
|
|
|
fprintf('Total Computational Time: %0.1f seconds. \n', tEnd);
|
|
|
|
|
|
|
|
if MOT2D.DoSave
|
|
|
|
LoadingRate = struct;
|
|
|
|
LoadingRate.Values = LoadingRateArray;
|
|
|
|
MOT2D.Results = LoadingRate;
|
|
|
|
SaveFolder = [MOT2D.SaveDirectory filesep 'Results'];
|
|
|
|
Filename = ['TwoParameterScan_' datestr(now,'yyyymmdd_HHMM')];
|
|
|
|
eval([sprintf('%s_Object', Filename) ' = MOT2D;']);
|
|
|
|
mkdir(SaveFolder);
|
|
|
|
save([SaveFolder filesep Filename], sprintf('%s_Object', Filename));
|
|
|
|
end
|
|
|
|
|
|
|
|
MOT2D.SidebandBeam = false;
|
|
|
|
MOT2D.PushBeam = false;
|
|
|
|
CoolingBeam.Power = MOT2D.TotalPower;
|
|
|
|
[LoadingRate, ~] = MOT2D.runSimulation(Oven);
|
|
|
|
|
|
|
|
EnhancementFactorArray = LoadingRateArray ./ LoadingRate;
|
|
|
|
|
|
|
|
% - Plot results
|
|
|
|
|
|
|
|
OptionsStruct = struct;
|
|
|
|
OptionsStruct.RescalingFactorForFirstParameter = (Helper.PhysicsConstants.BlueLinewidth)^-1;
|
|
|
|
OptionsStruct.XLabelString = 'Sideband Beam Detuning (\Delta/\Gamma)';
|
|
|
|
OptionsStruct.RescalingFactorForSecondParameter = 1000;
|
|
|
|
OptionsStruct.YLabelString = 'Sideband Beam Power (mW)';
|
|
|
|
OptionsStruct.RescalingFactorForQuantityOfInterest = 1;
|
|
|
|
OptionsStruct.ZLabelString = 'Enhancement Factor (\eta)';
|
|
|
|
% OptionsStruct.ZLabelString = 'Loading rate (x 10^{9} atoms/s)';
|
|
|
|
OptionsStruct.TitleString = sprintf('Magnetic Gradient = %.0f (G/cm)', MOT2D.MagneticGradient * 100);
|
|
|
|
|
|
|
|
options = Helper.convertstruct2cell(OptionsStruct);
|
|
|
|
Plotter.plotResultForTwoParameterScan(DetuningArray, PowerArray, EnhancementFactorArray, options{:})
|
|
|
|
|
|
|
|
%% Magnetic gradient scan
|
|
|
|
|
|
|
|
MOT2D.NumberOfAtoms = 10000;
|
2021-07-19 12:55:17 +02:00
|
|
|
MOT2D.TotalPower = 0.4;
|
|
|
|
MOT2D.SidebandBeam = true;
|
|
|
|
NumberOfPointsForFirstParam = 10; %iterations of the simulation
|
|
|
|
NumberOfPointsForSecondParam = 10;
|
2021-08-19 12:39:10 +02:00
|
|
|
NumberOfPointsForThirdParam = 6;
|
2021-07-19 12:55:17 +02:00
|
|
|
DetuningArray = linspace(-0.5, -5.0, NumberOfPointsForFirstParam) * Helper.PhysicsConstants.BlueLinewidth;
|
|
|
|
PowerArray = linspace(0.1, 1.0, NumberOfPointsForSecondParam) * MOT2D.TotalPower;
|
2021-08-19 12:39:10 +02:00
|
|
|
MagneticGradientArray = linspace(30, 50, NumberOfPointsForThirdParam) * 1e-02;
|
|
|
|
Beams = MOT2D.Beams;
|
|
|
|
CoolingBeam = Beams{cellfun(@(x) strcmpi(x.Alias, 'Blue'), Beams)};
|
|
|
|
SidebandBeam = Beams{cellfun(@(x) strcmpi(x.Alias, 'BlueSideband'), Beams)};
|
|
|
|
LoadingRateArray = {};
|
2021-07-19 12:55:17 +02:00
|
|
|
|
|
|
|
tStart = tic;
|
2021-08-19 12:39:10 +02:00
|
|
|
for k=1:NumberOfPointsForThirdParam
|
|
|
|
eval(sprintf('MOT2D.%s = %d;', 'MagneticGradient', MagneticGradientArray(k)));
|
|
|
|
lrmatrix = zeros(NumberOfPointsForFirstParam, NumberOfPointsForSecondParam);
|
|
|
|
for i=1:NumberOfPointsForFirstParam
|
|
|
|
eval(sprintf('SidebandBeam.%s = %d;', 'Detuning', DetuningArray(i)));
|
|
|
|
for j=1:NumberOfPointsForSecondParam
|
|
|
|
eval(sprintf('SidebandBeam.%s = %d;', 'Power', PowerArray(j)));
|
|
|
|
eval(sprintf('CoolingBeam.%s = %d;', 'Power', MOT2D.TotalPower - PowerArray(j)));
|
|
|
|
[lrmatrix(i,j), ~, ~] = MOT2D.runSimulation(Oven);
|
|
|
|
end
|
|
|
|
end
|
|
|
|
LoadingRateArray{end+1} = lrmatrix;
|
|
|
|
end
|
|
|
|
|
2021-07-19 12:55:17 +02:00
|
|
|
tEnd = toc(tStart);
|
|
|
|
fprintf('Total Computational Time: %0.1f seconds. \n', tEnd);
|
|
|
|
|
|
|
|
% - Plot results
|
|
|
|
|
|
|
|
OptionsStruct = struct;
|
|
|
|
OptionsStruct.RescalingFactorForFirstParameter = (Helper.PhysicsConstants.BlueLinewidth)^-1;
|
|
|
|
OptionsStruct.XLabelString = 'Sideband Beam Detuning (\Delta/\Gamma)';
|
|
|
|
OptionsStruct.RescalingFactorForSecondParameter = 1000;
|
2021-08-19 12:39:10 +02:00
|
|
|
OptionsStruct.YLabelString = 'Sideband Beam Waist (mm)';
|
|
|
|
OptionsStruct.RescalingFactorForThirdParameter = 100;
|
2021-07-19 12:55:17 +02:00
|
|
|
OptionsStruct.RescalingFactorForQuantityOfInterest = 1e-9;
|
|
|
|
OptionsStruct.ZLabelString = 'Loading rate (x 10^{9} atoms/s)';
|
2021-08-19 12:39:10 +02:00
|
|
|
OptionsStruct.PlotTitleString = 'Magnetic Gradient = %.0f (G/cm)';
|
|
|
|
OptionsStruct.FigureTitleString = sprintf('Oven-2DMOT Distance = %.1f (mm); Total Beam Power = %d (mW)', Oven.OvenDistance * 1000, MOT2D.TotalPower*1000);
|
2021-07-19 12:55:17 +02:00
|
|
|
|
|
|
|
options = Helper.convertstruct2cell(OptionsStruct);
|
|
|
|
|
2021-08-19 12:39:10 +02:00
|
|
|
Plotter.plotResultForThreeParameterScan(DetuningArray, PowerArray, MagneticGradientArray, LoadingRateArray, options{:})
|
2021-07-19 12:55:17 +02:00
|
|
|
|
2021-08-30 10:36:42 +02:00
|
|
|
clear OptionsStruct
|
|
|
|
|
|
|
|
%%
|
|
|
|
MOT2D.NumberOfAtoms = 10000;
|
|
|
|
MOT2D.TotalPower = 0.4;
|
|
|
|
MOT2D.MagneticGradient = 0.4; 0;
|
|
|
|
CoolingBeam = Beams{cellfun(@(x) strcmpi(x.Alias, 'Blue'), Beams)};
|
|
|
|
CoolingBeam.Power = 0.2;
|
|
|
|
CoolingBeam.Detuning = -1.3*Helper.PhysicsConstants.BlueLinewidth;
|
|
|
|
SidebandBeam = Beams{cellfun(@(x) strcmpi(x.Alias, 'BlueSideband'), Beams)};
|
|
|
|
SidebandBeam.Power = 0.2;
|
|
|
|
NumberOfPointsForFirstParam = 20; %iterations of the simulation
|
|
|
|
NumberOfPointsForSecondParam = 20;
|
|
|
|
DetuningArray = linspace(-1.0, -6.0, NumberOfPointsForFirstParam) * Helper.PhysicsConstants.BlueLinewidth;
|
|
|
|
BeamWaistArray = linspace(10, 25, NumberOfPointsForSecondParam) * 1e-03;
|
|
|
|
|
|
|
|
tStart = tic;
|
|
|
|
LoadingRateArray = zeros(NumberOfPointsForFirstParam, NumberOfPointsForSecondParam);
|
|
|
|
StandardErrorArray = zeros(NumberOfPointsForFirstParam, NumberOfPointsForSecondParam);
|
|
|
|
ConfidenceIntervalArray = zeros(NumberOfPointsForFirstParam, NumberOfPointsForSecondParam, 2);
|
|
|
|
|
|
|
|
for i=1:NumberOfPointsForFirstParam
|
|
|
|
eval(sprintf('SidebandBeam.Detuning = %d;', DetuningArray(i)));
|
|
|
|
for j=1:NumberOfPointsForSecondParam
|
|
|
|
eval(sprintf('CoolingBeam.Waist = %d;', BeamWaistArray(j)));
|
|
|
|
eval(sprintf('SidebandBeam.Waist = %d;', BeamWaistArray(j)));
|
|
|
|
[LoadingRateArray(i,j), StandardErrorArray(i,j), ConfidenceIntervalArray(i,j,:)] = MOT2D.runSimulation(Oven);
|
|
|
|
end
|
|
|
|
end
|
|
|
|
tEnd = toc(tStart);
|
|
|
|
fprintf('Total Computational Time: %0.1f seconds. \n', tEnd);
|
|
|
|
|
|
|
|
if MOT2D.DoSave
|
|
|
|
LoadingRate = struct;
|
|
|
|
LoadingRate.Values = LoadingRateArray;
|
|
|
|
MOT2D.Results = LoadingRate;
|
|
|
|
SaveFolder = [MOT2D.SaveDirectory filesep 'Results'];
|
|
|
|
Filename = ['TwoParameterScan_' datestr(now,'yyyymmdd_HHMM')];
|
|
|
|
eval([sprintf('%s_Object', Filename) ' = MOT2D;']);
|
|
|
|
mkdir(SaveFolder);
|
|
|
|
save([SaveFolder filesep Filename], sprintf('%s_Object', Filename));
|
|
|
|
end
|
|
|
|
|
|
|
|
% - Plot results
|
|
|
|
|
|
|
|
OptionsStruct = struct;
|
|
|
|
OptionsStruct.RescalingFactorForFirstParameter = (Helper.PhysicsConstants.BlueLinewidth)^-1;
|
|
|
|
OptionsStruct.XLabelString = 'Sideband Beam Detuning (\Delta/\Gamma)';
|
|
|
|
OptionsStruct.RescalingFactorForSecondParameter = 1000;
|
|
|
|
OptionsStruct.YLabelString = 'Beam Waist (mW)';
|
|
|
|
OptionsStruct.RescalingFactorForQuantityOfInterest = 1e-10;
|
|
|
|
% OptionsStruct.ZLabelString = 'Enhancement Factor (\eta)';
|
|
|
|
OptionsStruct.ZLabelString = 'Loading rate (x 10^{9} atoms/s)';
|
|
|
|
OptionsStruct.TitleString = sprintf('Magnetic Gradient = %.0f (G/cm)', MOT2D.MagneticGradient * 100);
|
|
|
|
|
|
|
|
options = Helper.convertstruct2cell(OptionsStruct);
|
|
|
|
Plotter.plotResultForTwoParameterScan(DetuningArray, BeamWaistArray, LoadingRateArray, options{:})
|
|
|
|
|
|
|
|
%%
|
|
|
|
MOT2D.NumberOfAtoms = 10000;
|
|
|
|
MOT2D.TotalPower = 0.4;
|
|
|
|
MOT2D.MagneticGradient = 0.4; 0;
|
|
|
|
CoolingBeam = Beams{cellfun(@(x) strcmpi(x.Alias, 'Blue'), Beams)};
|
|
|
|
CoolingBeam.Power = 0.2;
|
|
|
|
SidebandBeam = Beams{cellfun(@(x) strcmpi(x.Alias, 'BlueSideband'), Beams)};
|
|
|
|
SidebandBeam.Power = 0.2;
|
|
|
|
NumberOfPointsForFirstParam = 20; %iterations of the simulation
|
|
|
|
NumberOfPointsForSecondParam = 20;
|
|
|
|
DetuningArray = linspace(-1.0, -5.0, NumberOfPointsForFirstParam) * Helper.PhysicsConstants.BlueLinewidth;
|
|
|
|
BeamWaistArray = linspace(10, 25, NumberOfPointsForSecondParam) * 1e-03;
|
|
|
|
|
|
|
|
tStart = tic;
|
|
|
|
LoadingRateArray = zeros(NumberOfPointsForFirstParam, NumberOfPointsForSecondParam);
|
|
|
|
StandardErrorArray = zeros(NumberOfPointsForFirstParam, NumberOfPointsForSecondParam);
|
|
|
|
ConfidenceIntervalArray = zeros(NumberOfPointsForFirstParam, NumberOfPointsForSecondParam, 2);
|
|
|
|
|
|
|
|
for i=1:NumberOfPointsForFirstParam
|
|
|
|
eval(sprintf('CoolingBeam.Detuning = %d;', DetuningArray(i)));
|
|
|
|
eval(sprintf('SidebandBeam.Detuning = %d;', DetuningArray(i) - (1.0 * Helper.PhysicsConstants.BlueLinewidth)));
|
|
|
|
for j=1:NumberOfPointsForSecondParam
|
|
|
|
eval(sprintf('CoolingBeam.Waist = %d;', BeamWaistArray(j)));
|
|
|
|
eval(sprintf('SidebandBeam.Waist = %d;', BeamWaistArray(j)));
|
|
|
|
[LoadingRateArray(i,j), StandardErrorArray(i,j), ConfidenceIntervalArray(i,j,:)] = MOT2D.runSimulation(Oven);
|
|
|
|
end
|
|
|
|
end
|
|
|
|
tEnd = toc(tStart);
|
|
|
|
fprintf('Total Computational Time: %0.1f seconds. \n', tEnd);
|
|
|
|
|
|
|
|
if MOT2D.DoSave
|
|
|
|
LoadingRate = struct;
|
|
|
|
LoadingRate.Values = LoadingRateArray;
|
|
|
|
MOT2D.Results = LoadingRate;
|
|
|
|
SaveFolder = [MOT2D.SaveDirectory filesep 'Results'];
|
|
|
|
Filename = ['TwoParameterScan_' datestr(now,'yyyymmdd_HHMM')];
|
|
|
|
eval([sprintf('%s_Object', Filename) ' = MOT2D;']);
|
|
|
|
mkdir(SaveFolder);
|
|
|
|
save([SaveFolder filesep Filename], sprintf('%s_Object', Filename));
|
|
|
|
end
|
|
|
|
|
|
|
|
% - Plot results
|
|
|
|
|
|
|
|
OptionsStruct = struct;
|
|
|
|
OptionsStruct.RescalingFactorForFirstParameter = (Helper.PhysicsConstants.BlueLinewidth)^-1;
|
|
|
|
OptionsStruct.XLabelString = 'Beam Detuning (\Delta/\Gamma)';
|
|
|
|
OptionsStruct.RescalingFactorForSecondParameter = 1000;
|
|
|
|
OptionsStruct.YLabelString = 'Beam Waist (mW)';
|
|
|
|
OptionsStruct.RescalingFactorForQuantityOfInterest = 1e-10;
|
|
|
|
% OptionsStruct.ZLabelString = 'Enhancement Factor (\eta)';
|
|
|
|
OptionsStruct.ZLabelString = 'Loading rate (x 10^{9} atoms/s)';
|
|
|
|
OptionsStruct.TitleString = sprintf('Magnetic Gradient = %.0f (G/cm)', MOT2D.MagneticGradient * 100);
|
|
|
|
|
|
|
|
options = Helper.convertstruct2cell(OptionsStruct);
|
|
|
|
Plotter.plotResultForTwoParameterScan(DetuningArray, BeamWaistArray, LoadingRateArray, options{:})
|