Compare commits
No commits in common. "27fe40068ed213bf227c4f08c02dc84ae9461e7e" and "2628e7c8bc51b8c8bc18a16087930c9212264be7" have entirely different histories.
27fe40068e
...
2628e7c8bc
@ -5,12 +5,12 @@ classdef MOTCaptureProcess < handle & matlab.mixin.Copyable
|
|||||||
TimeStep;
|
TimeStep;
|
||||||
SimulationTime;
|
SimulationTime;
|
||||||
NumberOfAtoms;
|
NumberOfAtoms;
|
||||||
ErrorEstimationMethod;
|
|
||||||
|
|
||||||
%Flags
|
%Flags
|
||||||
SpontaneousEmission;
|
SpontaneousEmission;
|
||||||
SidebandBeam;
|
Sideband;
|
||||||
PushBeam;
|
PushBeam;
|
||||||
|
ZeemanSlowerBeam;
|
||||||
Gravity;
|
Gravity;
|
||||||
BackgroundCollision;
|
BackgroundCollision;
|
||||||
|
|
||||||
@ -34,8 +34,6 @@ classdef MOTCaptureProcess < handle & matlab.mixin.Copyable
|
|||||||
p.KeepUnmatched = true;
|
p.KeepUnmatched = true;
|
||||||
addParameter(p, 'SimulationMode', '2D',...
|
addParameter(p, 'SimulationMode', '2D',...
|
||||||
@(x) any(strcmpi(x,{'2D','3D', 'Full'})));
|
@(x) any(strcmpi(x,{'2D','3D', 'Full'})));
|
||||||
addParameter(p, 'ErrorEstimationMethod', 'jackknife',...
|
|
||||||
@(x) any(strcmpi(x,{'jackknife','bootstrap'})));
|
|
||||||
addParameter(p, 'NumberOfAtoms', 5000,...
|
addParameter(p, 'NumberOfAtoms', 5000,...
|
||||||
@(x) assert(isnumeric(x) && isscalar(x) && (x > 0)));
|
@(x) assert(isnumeric(x) && isscalar(x) && (x > 0)));
|
||||||
addParameter(p, 'TimeStep', 10e-06,...
|
addParameter(p, 'TimeStep', 10e-06,...
|
||||||
@ -44,10 +42,12 @@ classdef MOTCaptureProcess < handle & matlab.mixin.Copyable
|
|||||||
@(x) assert(isnumeric(x) && isscalar(x) && (x > 0)));
|
@(x) assert(isnumeric(x) && isscalar(x) && (x > 0)));
|
||||||
addParameter(p, 'SpontaneousEmission', false,...
|
addParameter(p, 'SpontaneousEmission', false,...
|
||||||
@islogical);
|
@islogical);
|
||||||
addParameter(p, 'SidebandBeam', false,...
|
addParameter(p, 'Sideband', false,...
|
||||||
@islogical);
|
@islogical);
|
||||||
addParameter(p, 'PushBeam', false,...
|
addParameter(p, 'PushBeam', false,...
|
||||||
@islogical);
|
@islogical);
|
||||||
|
addParameter(p, 'ZeemanSlowerBeam', false,...
|
||||||
|
@islogical);
|
||||||
addParameter(p, 'Gravity', false,...
|
addParameter(p, 'Gravity', false,...
|
||||||
@islogical);
|
@islogical);
|
||||||
addParameter(p, 'BackgroundCollision', false,...
|
addParameter(p, 'BackgroundCollision', false,...
|
||||||
@ -62,15 +62,15 @@ classdef MOTCaptureProcess < handle & matlab.mixin.Copyable
|
|||||||
p.parse(varargin{:});
|
p.parse(varargin{:});
|
||||||
|
|
||||||
this.SimulationMode = p.Results.SimulationMode;
|
this.SimulationMode = p.Results.SimulationMode;
|
||||||
this.ErrorEstimationMethod= p.Results.ErrorEstimationMethod;
|
|
||||||
|
|
||||||
this.NumberOfAtoms = p.Results.NumberOfAtoms;
|
this.NumberOfAtoms = p.Results.NumberOfAtoms;
|
||||||
this.TimeStep = p.Results.TimeStep;
|
this.TimeStep = p.Results.TimeStep;
|
||||||
this.SimulationTime = p.Results.SimulationTime;
|
this.SimulationTime = p.Results.SimulationTime;
|
||||||
|
|
||||||
this.SpontaneousEmission = p.Results.SpontaneousEmission;
|
this.SpontaneousEmission = p.Results.SpontaneousEmission;
|
||||||
this.SidebandBeam = p.Results.SidebandBeam;
|
this.Sideband = p.Results.Sideband;
|
||||||
this.PushBeam = p.Results.PushBeam;
|
this.PushBeam = p.Results.PushBeam;
|
||||||
|
this.ZeemanSlowerBeam = p.Results.ZeemanSlowerBeam;
|
||||||
this.Gravity = p.Results.Gravity;
|
this.Gravity = p.Results.Gravity;
|
||||||
this.BackgroundCollision = p.Results.BackgroundCollision;
|
this.BackgroundCollision = p.Results.BackgroundCollision;
|
||||||
|
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
function ret = initialVelocitySampling(this, MOTObj)
|
function ret = initialVelocitySampling(this, MOTObj)
|
||||||
n = this.NumberOfAtoms;
|
n = this.NumberOfAtoms;
|
||||||
% Calculate Calculate Capture velocity --> Introduce velocity cutoff
|
% Calculate Calculate Capture velocity --> Introduce velocity cutoff
|
||||||
MOTObj.CaptureVelocity = MOTObj.calculateCaptureVelocity(this, [-this.OvenDistance,0,0], [1,0,0]);
|
MOTObj.CaptureVelocity = 1.05 * MOTObj.calculateCaptureVelocity(this, [-this.OvenDistance,0,0], [1,0,0]);
|
||||||
this.VelocityCutoff = 1.05 * MOTObj.CaptureVelocity(1); % Should be the magnitude of the 3-D velocity vector but since here the obtained capture
|
this.VelocityCutoff = MOTObj.CaptureVelocity(1); % Should be the magnitude of the 3-D velocity vector but since here the obtained capture
|
||||||
% velocity is only along the x-axis, we take the first term which is the x-component of the velocity.
|
% velocity is only along the x-axis, we take the first term which is the x-component of the velocity.
|
||||||
|
|
||||||
[ReducedClausingFactor, NormalizationConstantForAngularDistribution] = this.calculateReducedClausingFactor();
|
[ReducedClausingFactor, NormalizationConstantForAngularDistribution] = this.calculateReducedClausingFactor();
|
||||||
|
@ -19,7 +19,6 @@ classdef TwoDimensionalMOT < Simulator.MOTCaptureProcess & matlab.mixin.Copyable
|
|||||||
TimeSpentInInteractionRegion;
|
TimeSpentInInteractionRegion;
|
||||||
ParticleDynamicalQuantities;
|
ParticleDynamicalQuantities;
|
||||||
InitialParameters;
|
InitialParameters;
|
||||||
Results;
|
|
||||||
end
|
end
|
||||||
|
|
||||||
methods
|
methods
|
||||||
@ -131,12 +130,6 @@ classdef TwoDimensionalMOT < Simulator.MOTCaptureProcess & matlab.mixin.Copyable
|
|||||||
function ret = get.InitialParameters(this)
|
function ret = get.InitialParameters(this)
|
||||||
ret = this.InitialParameters;
|
ret = this.InitialParameters;
|
||||||
end
|
end
|
||||||
function set.Results(this, val)
|
|
||||||
this.Results = val;
|
|
||||||
end
|
|
||||||
function ret = get.Results(this)
|
|
||||||
ret = this.Results;
|
|
||||||
end
|
|
||||||
end % - setters and getters
|
end % - setters and getters
|
||||||
|
|
||||||
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
||||||
|
@ -9,20 +9,20 @@ function [LoadingRate, StandardError, ConfidenceInterval] = bootstrapErrorEstima
|
|||||||
if ~isnan(CorrelationFactor)
|
if ~isnan(CorrelationFactor)
|
||||||
SampleLength = floor(CorrelationFactor);
|
SampleLength = floor(CorrelationFactor);
|
||||||
NumberOfBootsrapSamples = 1000;
|
NumberOfBootsrapSamples = 1000;
|
||||||
MeanCaptureRatioInEachSample = zeros(1,NumberOfBootsrapSamples);
|
MeanLoadingRatioInEachSample = zeros(1,NumberOfBootsrapSamples);
|
||||||
for SampleNumber = 1:NumberOfBootsrapSamples
|
for SampleNumber = 1:NumberOfBootsrapSamples
|
||||||
BoostrapSample = datasample(NumberOfLoadedAtoms, SampleLength); % Sample with replacement
|
BoostrapSample = datasample(NumberOfLoadedAtoms, SampleLength); % Sample with replacement
|
||||||
MeanCaptureRatioInEachSample(SampleNumber) = mean(BoostrapSample) / n; % Empirical bootstrap distribution of sample means
|
MeanLoadingRatioInEachSample(SampleNumber) = mean(BoostrapSample) / n; % Empirical bootstrap distribution of sample means
|
||||||
end
|
end
|
||||||
|
|
||||||
LoadingRate = mean(MeanCaptureRatioInEachSample) * ovenObj.ReducedFlux;
|
LoadingRate = mean(MeanLoadingRatioInEachSample) * ovenObj.ReducedFlux;
|
||||||
|
|
||||||
Variance = 0; % Bootstrap Estimate of Variance
|
Variance = 0; % Bootstrap Estimate of Variance
|
||||||
for SampleNumber = 1:NumberOfBootsrapSamples
|
for SampleNumber = 1:NumberOfBootsrapSamples
|
||||||
Variance = Variance + (MeanCaptureRatioInEachSample(SampleNumber) - mean(MeanCaptureRatioInEachSample))^2;
|
Variance = Variance + (MeanLoadingRatioInEachSample(SampleNumber) - mean(MeanLoadingRatioInEachSample))^2;
|
||||||
end
|
end
|
||||||
|
|
||||||
StandardError = sqrt((1 / (NumberOfBootsrapSamples-1)) * Variance) * ovenObj.ReducedFlux;
|
StandardError = sqrt((1 / (NumberOfBootsrapSamples-1)) * Variance) * ovenObj.ReducedFlux;
|
||||||
|
|
||||||
ts = tinv([0.025 0.975],NumberOfBootsrapSamples-1); % T-Score
|
ts = tinv([0.025 0.975],NumberOfBootsrapSamples-1); % T-Score
|
||||||
ConfidenceInterval = LoadingRate + ts*StandardError; % 95% Confidence Intervals
|
ConfidenceInterval = LoadingRate + ts*StandardError; % 95% Confidence Intervals
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
function [LoadingRate, StandardError, ConfidenceInterval] = calculateLoadingRate(this, ovenObj)
|
function [LoadingRate, StandardError, ConfidenceInterval] = calculateLoadingRate(this, ovenObj)
|
||||||
n = this.NumberOfAtoms;
|
n = this.NumberOfAtoms;
|
||||||
DynamicalQuantities = this.ParticleDynamicalQuantities;
|
DynamicalQuantities = this.ParticleDynamicalQuantities;
|
||||||
|
NumberOfTimeSteps = int64(this.SimulationTime/this.TimeStep);
|
||||||
|
NumberOfLoadedAtoms = zeros(1, NumberOfTimeSteps);
|
||||||
CollisionEvents = zeros(1, n);
|
CollisionEvents = zeros(1, n);
|
||||||
NumberOfLoadedAtoms = zeros(1, n);
|
|
||||||
|
|
||||||
|
|
||||||
% Include the stochastic process of background collisions
|
% Include the stochastic process of background collisions
|
||||||
for AtomIndex = 1:n
|
for AtomIndex = 1:n
|
||||||
@ -12,42 +12,17 @@ function [LoadingRate, StandardError, ConfidenceInterval] = calculateLoadingRate
|
|||||||
end
|
end
|
||||||
|
|
||||||
% Count the number of loaded atoms subject to conditions
|
% Count the number of loaded atoms subject to conditions
|
||||||
|
for TimeIndex = 1:NumberOfTimeSteps
|
||||||
switch this.ErrorEstimationMethod
|
if TimeIndex ~= 1
|
||||||
case 'bootstrap'
|
NumberOfLoadedAtoms(TimeIndex) = NumberOfLoadedAtoms(TimeIndex-1);
|
||||||
NumberOfTimeSteps = int64(this.SimulationTime/this.TimeStep);
|
end
|
||||||
NumberOfLoadedAtoms = zeros(1, NumberOfTimeSteps);
|
for AtomIndex = 1:n
|
||||||
LoadedAtomIndices = [];
|
Position = squeeze(DynamicalQuantities(AtomIndex, TimeIndex, 1:3))';
|
||||||
for TimeIndex = 1:NumberOfTimeSteps
|
if this.exitCondition(Position, CollisionEvents(AtomIndex))
|
||||||
if TimeIndex ~= 1
|
NumberOfLoadedAtoms(TimeIndex) = NumberOfLoadedAtoms(TimeIndex) + 1;
|
||||||
NumberOfLoadedAtoms(TimeIndex) = NumberOfLoadedAtoms(TimeIndex-1);
|
|
||||||
end
|
|
||||||
for AtomIndex = 1:n
|
|
||||||
Position = squeeze(DynamicalQuantities(AtomIndex, TimeIndex, 1:3))';
|
|
||||||
if this.exitCondition(Position, CollisionEvents(AtomIndex))
|
|
||||||
if ~ismember(AtomIndex, LoadedAtomIndices)
|
|
||||||
NumberOfLoadedAtoms(TimeIndex) = NumberOfLoadedAtoms(TimeIndex) + 1;
|
|
||||||
LoadedAtomIndices(end+1) = AtomIndex;
|
|
||||||
end
|
|
||||||
else
|
|
||||||
if ismember(AtomIndex, LoadedAtomIndices)
|
|
||||||
NumberOfLoadedAtoms(TimeIndex) = NumberOfLoadedAtoms(TimeIndex) - 1;
|
|
||||||
LoadedAtomIndices(LoadedAtomIndices==AtomIndex) = [];
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
[LoadingRate, StandardError, ConfidenceInterval] = this.bootstrapErrorEstimation(ovenObj, NumberOfLoadedAtoms);
|
end
|
||||||
case 'jackknife'
|
|
||||||
for AtomIndex = 1:n
|
|
||||||
if AtomIndex ~= 1
|
|
||||||
NumberOfLoadedAtoms(AtomIndex) = NumberOfLoadedAtoms(AtomIndex-1);
|
|
||||||
end
|
|
||||||
Position = squeeze(DynamicalQuantities(AtomIndex, end, 1:3))';
|
|
||||||
if this.exitCondition(Position, CollisionEvents(AtomIndex))
|
|
||||||
NumberOfLoadedAtoms(AtomIndex) = NumberOfLoadedAtoms(AtomIndex) + 1;
|
|
||||||
end
|
|
||||||
end
|
|
||||||
[LoadingRate, StandardError, ConfidenceInterval] = jackknifeErrorEstimation(this, ovenObj, NumberOfLoadedAtoms);
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
[LoadingRate, StandardError, ConfidenceInterval] = this.bootstrapErrorEstimation(ovenObj, NumberOfLoadedAtoms);
|
||||||
end
|
end
|
||||||
|
@ -47,7 +47,7 @@ function ret = calculateTotalAcceleration(this, PositionVector, VelocityVector)
|
|||||||
Delta_Cooling(i*2-1) = CoolingBeamDetuning + DopplerShift + (ZeemanShift * Sigma(i));
|
Delta_Cooling(i*2-1) = CoolingBeamDetuning + DopplerShift + (ZeemanShift * Sigma(i));
|
||||||
Delta_Cooling(i*2) = CoolingBeamDetuning - DopplerShift - (ZeemanShift * Sigma(i));
|
Delta_Cooling(i*2) = CoolingBeamDetuning - DopplerShift - (ZeemanShift * Sigma(i));
|
||||||
|
|
||||||
if this.SidebandBeam
|
if this.Sideband
|
||||||
Delta_Sideband(i*2-1) = SidebandDetuning + DopplerShift + (ZeemanShift * Sigma(i));
|
Delta_Sideband(i*2-1) = SidebandDetuning + DopplerShift + (ZeemanShift * Sigma(i));
|
||||||
Delta_Sideband(i*2) = SidebandDetuning - DopplerShift - (ZeemanShift * Sigma(i));
|
Delta_Sideband(i*2) = SidebandDetuning - DopplerShift - (ZeemanShift * Sigma(i));
|
||||||
end
|
end
|
||||||
@ -58,7 +58,7 @@ function ret = calculateTotalAcceleration(this, PositionVector, VelocityVector)
|
|||||||
for i = 1:2
|
for i = 1:2
|
||||||
SaturationParameter(2*i-1) = CoolingBeamLocalSaturationIntensity(i) /(1 + 4 * (Delta_Cooling(2*i-1)/CoolingBeamLinewidth)^2);
|
SaturationParameter(2*i-1) = CoolingBeamLocalSaturationIntensity(i) /(1 + 4 * (Delta_Cooling(2*i-1)/CoolingBeamLinewidth)^2);
|
||||||
SaturationParameter(2*i) = CoolingBeamLocalSaturationIntensity(i) /(1 + 4 * (Delta_Cooling(2*i) /CoolingBeamLinewidth)^2);
|
SaturationParameter(2*i) = CoolingBeamLocalSaturationIntensity(i) /(1 + 4 * (Delta_Cooling(2*i) /CoolingBeamLinewidth)^2);
|
||||||
if this.SidebandBeam
|
if this.Sideband
|
||||||
SaturationParameter(2*i-1+4) = SidebandLocalSaturationIntensity(i) /(1 + 4 * (Delta_Sideband(2*i-1)/CoolingBeamLinewidth)^2);
|
SaturationParameter(2*i-1+4) = SidebandLocalSaturationIntensity(i) /(1 + 4 * (Delta_Sideband(2*i-1)/CoolingBeamLinewidth)^2);
|
||||||
SaturationParameter(2*i+4) = SidebandLocalSaturationIntensity(i) /(1 + 4 * (Delta_Sideband(2*i)/CoolingBeamLinewidth)^2);
|
SaturationParameter(2*i+4) = SidebandLocalSaturationIntensity(i) /(1 + 4 * (Delta_Sideband(2*i)/CoolingBeamLinewidth)^2);
|
||||||
end
|
end
|
||||||
@ -79,7 +79,7 @@ function ret = calculateTotalAcceleration(this, PositionVector, VelocityVector)
|
|||||||
a_scattering = [0,0,0];
|
a_scattering = [0,0,0];
|
||||||
end
|
end
|
||||||
|
|
||||||
if this.SidebandBeam
|
if this.Sideband
|
||||||
a_1 = a_1 + a_sat .* (SaturationParameter(2*i-1+4)/(1 + TotalSaturationParameter));
|
a_1 = a_1 + a_sat .* (SaturationParameter(2*i-1+4)/(1 + TotalSaturationParameter));
|
||||||
a_2 = a_2 + a_sat .* (SaturationParameter(2*i+4) /(1 + TotalSaturationParameter));
|
a_2 = a_2 + a_sat .* (SaturationParameter(2*i+4) /(1 + TotalSaturationParameter));
|
||||||
|
|
||||||
|
@ -1,50 +0,0 @@
|
|||||||
function [LoadingRate, StandardError, ConfidenceInterval] = jackknifeErrorEstimation(this, ovenObj, NumberOfLoadedAtoms)
|
|
||||||
n = this.NumberOfAtoms;
|
|
||||||
Autocorrelation = zeros(1, n);
|
|
||||||
|
|
||||||
for i = 1:n-1
|
|
||||||
FirstTerm = 0;
|
|
||||||
SecondTerm = 0;
|
|
||||||
for j = 1:n-i
|
|
||||||
FirstTerm = FirstTerm + NumberOfLoadedAtoms(j) / j;
|
|
||||||
SecondTerm = SecondTerm + (NumberOfLoadedAtoms(i+j)) / (i+j);
|
|
||||||
Autocorrelation(i) = Autocorrelation(i) + ((NumberOfLoadedAtoms(j) / j) .*(NumberOfLoadedAtoms(i+j) / (i+j)));
|
|
||||||
end
|
|
||||||
Autocorrelation(i) = (1/(n-i)) * (Autocorrelation(i) - ((1/(n-i)) * FirstTerm * SecondTerm));
|
|
||||||
end
|
|
||||||
|
|
||||||
if Autocorrelation(1)~=0
|
|
||||||
|
|
||||||
Autocorrelation = Autocorrelation./Autocorrelation(1);
|
|
||||||
|
|
||||||
x = linspace(1,n,n);
|
|
||||||
|
|
||||||
[FitParams,~] = fit(x',Autocorrelation',"exp(-x/tau)", 'Startpoint', 100);
|
|
||||||
CorrelationFactor = FitParams.tau;
|
|
||||||
|
|
||||||
SampleLength = 2*CorrelationFactor+1;
|
|
||||||
NumberOfJackknifeSamples = floor(n/SampleLength);
|
|
||||||
CaptureRatioInEachSample = zeros(1,NumberOfJackknifeSamples);
|
|
||||||
SampleNumberLimit = min(NumberOfJackknifeSamples-1,5);
|
|
||||||
for i=1:NumberOfJackknifeSamples-SampleNumberLimit
|
|
||||||
CaptureRatioInEachSample(i) = NumberOfLoadedAtoms(n-ceil((i-1)*SampleLength))/(n-ceil((i-1)*SampleLength));
|
|
||||||
end
|
|
||||||
|
|
||||||
MeanCaptureRatio = sum(CaptureRatioInEachSample) / (NumberOfJackknifeSamples-SampleNumberLimit);
|
|
||||||
|
|
||||||
LoadingRate = MeanCaptureRatio * ovenObj.ReducedFlux;
|
|
||||||
|
|
||||||
Variance=0;
|
|
||||||
for i=1:NumberOfJackknifeSamples-SampleNumberLimit
|
|
||||||
Variance=Variance+(CaptureRatioInEachSample(i) - MeanCaptureRatio)^2;
|
|
||||||
end
|
|
||||||
StandardError = sqrt(Variance/(NumberOfJackknifeSamples-SampleNumberLimit));
|
|
||||||
|
|
||||||
ConfidenceInterval = LoadingRate + 1.96*StandardError; % 95% Confidence Intervals
|
|
||||||
|
|
||||||
else
|
|
||||||
LoadingRate = nan;
|
|
||||||
StandardError = nan;
|
|
||||||
ConfidenceInterval = [nan nan];
|
|
||||||
end
|
|
||||||
end
|
|
@ -6,7 +6,6 @@
|
|||||||
% - Create MOTCaptureProcess object with specified options
|
% - Create MOTCaptureProcess object with specified options
|
||||||
% - Automatically creates Beams objects
|
% - Automatically creates Beams objects
|
||||||
OptionsStruct = struct;
|
OptionsStruct = struct;
|
||||||
OptionsStruct.ErrorEstimationMethod = 'bootstrap'; % 'jackknife' | 'bootstrap'
|
|
||||||
OptionsStruct.NumberOfAtoms = 10000;
|
OptionsStruct.NumberOfAtoms = 10000;
|
||||||
OptionsStruct.TimeStep = 50e-06; % in s
|
OptionsStruct.TimeStep = 50e-06; % in s
|
||||||
OptionsStruct.SimulationTime = 4e-03; % in s
|
OptionsStruct.SimulationTime = 4e-03; % in s
|
||||||
@ -25,17 +24,21 @@ MOT2D = Simulator.TwoDimensionalMOT(options{:});
|
|||||||
Beams = MOT2D.Beams;
|
Beams = MOT2D.Beams;
|
||||||
|
|
||||||
%% - Run Simulation
|
%% - Run Simulation
|
||||||
MOT2D.NumberOfAtoms = 5000;
|
% poolobj = gcp('nocreate'); % Check if pool is open
|
||||||
MOT2D.SidebandBeam = false;
|
% if isempty(poolobj)
|
||||||
CoolingBeam = Beams{cellfun(@(x) strcmpi(x.Alias, 'Blue'), Beams)};
|
% parpool;
|
||||||
CoolingBeam.Power = 0.4;
|
% end
|
||||||
CoolingBeam.Waist = 13.3e-03;
|
MOT2D.NumberOfAtoms = 5000;
|
||||||
CoolingBeam.Detuning = -1.67*Helper.PhysicsConstants.BlueLinewidth;
|
MOT2D.Sideband = false;
|
||||||
PushBeam = Beams{cellfun(@(x) strcmpi(x.Alias, 'Push'), Beams)};
|
CoolingBeam = Beams{cellfun(@(x) strcmpi(x.Alias, 'Blue'), Beams)};
|
||||||
|
CoolingBeam.Power = 0.4;
|
||||||
|
CoolingBeam.Waist = 13.3e-03;
|
||||||
|
CoolingBeam.Detuning = -1.67*Helper.PhysicsConstants.BlueLinewidth;
|
||||||
|
PushBeam = Beams{cellfun(@(x) strcmpi(x.Alias, 'Push'), Beams)};
|
||||||
PushBeam.Power = 0.025;
|
PushBeam.Power = 0.025;
|
||||||
PushBeam.Waist = 0.81e-03;
|
PushBeam.Waist = 0.81e-03;
|
||||||
PushBeam.Detuning = 0;
|
PushBeam.Detuning = 0;
|
||||||
[LoadingRate, ~] = MOT2D.runSimulation(Oven);
|
[LoadingRate, ~] = MOT2D.runSimulation(Oven);
|
||||||
%% - Plot initial distribution
|
%% - Plot initial distribution
|
||||||
% - sampling the position distribution
|
% - sampling the position distribution
|
||||||
InitialPositions = Oven.initialPositionSampling();
|
InitialPositions = Oven.initialPositionSampling();
|
||||||
@ -70,7 +73,7 @@ Plotter.plotAngularDistributionForDifferentBeta(Oven, Beta)
|
|||||||
Plotter.plotCaptureVelocityVsAngle(Oven, MOT2D); % Takes a long time to plot!
|
Plotter.plotCaptureVelocityVsAngle(Oven, MOT2D); % Takes a long time to plot!
|
||||||
|
|
||||||
%% - Plot Phase Space with Acceleration Field
|
%% - Plot Phase Space with Acceleration Field
|
||||||
MOT2D.SidebandBeam = false;
|
MOT2D.Sideband = false;
|
||||||
MOT2D.NumberOfAtoms = 50;
|
MOT2D.NumberOfAtoms = 50;
|
||||||
MinimumVelocity = 0;
|
MinimumVelocity = 0;
|
||||||
MaximumVelocity = 150;
|
MaximumVelocity = 150;
|
||||||
@ -125,13 +128,13 @@ QuantityOfInterestArray = LoadingRateArray;
|
|||||||
OptionsStruct = struct;
|
OptionsStruct = struct;
|
||||||
OptionsStruct.RescalingFactorForParameter = 1000;
|
OptionsStruct.RescalingFactorForParameter = 1000;
|
||||||
OptionsStruct.XLabelString = 'Cooling Beam Power (mW)';
|
OptionsStruct.XLabelString = 'Cooling Beam Power (mW)';
|
||||||
OptionsStruct.RescalingFactorForYQuantity = 1e-10;
|
OptionsStruct.RescalingFactorForYQuantity = 1e-11;
|
||||||
OptionsStruct.ErrorsForYQuantity = true;
|
OptionsStruct.ErrorsForYQuantity = true;
|
||||||
OptionsStruct.ErrorsArray = StandardErrorArray;
|
OptionsStruct.ErrorsArray = StandardErrorArray;
|
||||||
OptionsStruct.CIForYQuantity = true;
|
OptionsStruct.CIForYQuantity = true;
|
||||||
OptionsStruct.CIArray = ConfidenceIntervalArray;
|
OptionsStruct.CIArray = ConfidenceIntervalArray;
|
||||||
OptionsStruct.RemoveOutliers = true;
|
OptionsStruct.RemoveOutliers = true;
|
||||||
OptionsStruct.YLabelString = 'Loading rate (x 10^{10} atoms/s)';
|
OptionsStruct.YLabelString = 'Loading rate (x 10^{11} atoms/s)';
|
||||||
OptionsStruct.TitleString = sprintf('Magnetic Gradient = %.0f (G/cm)', MOT2D.MagneticGradient * 100);
|
OptionsStruct.TitleString = sprintf('Magnetic Gradient = %.0f (G/cm)', MOT2D.MagneticGradient * 100);
|
||||||
|
|
||||||
options = Helper.convertstruct2cell(OptionsStruct);
|
options = Helper.convertstruct2cell(OptionsStruct);
|
||||||
@ -140,24 +143,11 @@ Plotter.plotResultForOneParameterScan(ParameterArray, QuantityOfInterestArray, o
|
|||||||
|
|
||||||
clear OptionsStruct
|
clear OptionsStruct
|
||||||
|
|
||||||
if MOT2D.DoSave
|
|
||||||
LoadingRate = struct;
|
|
||||||
LoadingRate.Values = LoadingRateArray;
|
|
||||||
LoadingRate.Errors = StandardErrorArray;
|
|
||||||
LoadingRate.CI = ConfidenceIntervalArray;
|
|
||||||
MOT2D.Results = LoadingRate;
|
|
||||||
SaveFolder = [MOT2D.SaveDirectory filesep 'Results'];
|
|
||||||
Filename = ['OneParameterScan_' datestr(now,'yyyymmdd_HHMM')];
|
|
||||||
eval([sprintf('%s_Object', Filename) ' = MOT2D;']);
|
|
||||||
mkdir(SaveFolder);
|
|
||||||
save([SaveFolder filesep Filename], sprintf('%s_Object', Filename));
|
|
||||||
end
|
|
||||||
|
|
||||||
%% - Scan parameters: Two-Parameter Scan
|
%% - Scan parameters: Two-Parameter Scan
|
||||||
|
|
||||||
MOT2D.NumberOfAtoms = 50;
|
MOT2D.NumberOfAtoms = 50;
|
||||||
MOT2D.TotalPower = 0.6;
|
MOT2D.TotalPower = 0.6;
|
||||||
MOT2D.SidebandBeam = false;
|
MOT2D.Sideband = false;
|
||||||
SidebandBeam = Beams{cellfun(@(x) strcmpi(x.Alias, 'BlueSideband'), Beams)};
|
SidebandBeam = Beams{cellfun(@(x) strcmpi(x.Alias, 'BlueSideband'), Beams)};
|
||||||
|
|
||||||
NumberOfPointsForFirstParam = 10; %iterations of the simulation
|
NumberOfPointsForFirstParam = 10; %iterations of the simulation
|
||||||
@ -206,17 +196,4 @@ options = Helper.convertstruct2cell(
|
|||||||
|
|
||||||
Plotter.plotResultForTwoParameterScan(FirstParameterArray, SecondParameterArray, QuantityOfInterestArray, options{:})
|
Plotter.plotResultForTwoParameterScan(FirstParameterArray, SecondParameterArray, QuantityOfInterestArray, options{:})
|
||||||
|
|
||||||
clear OptionsStruct
|
clear OptionsStruct
|
||||||
|
|
||||||
if MOT2D.DoSave
|
|
||||||
LoadingRate = struct;
|
|
||||||
LoadingRate.Values = LoadingRateArray;
|
|
||||||
LoadingRate.Errors = StandardErrorArray;
|
|
||||||
LoadingRate.CI = ConfidenceIntervalArray;
|
|
||||||
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
|
|
Loading…
Reference in New Issue
Block a user