170 lines
6.6 KiB
Mathematica
170 lines
6.6 KiB
Mathematica
|
classdef TwoDimensionalMOT < Simulator.MOTCaptureProcess & matlab.mixin.Copyable
|
||
|
|
||
|
properties (Access = private)
|
||
|
MagneticGradienDefault = 0.425; % T/m
|
||
|
ExitDivergenceDefault = 16e-3;
|
||
|
DistanceBetweenPushBeamAnd3DMOTCenterDefault = 0;
|
||
|
PushBeamDistanceDefault = 0.32;
|
||
|
end
|
||
|
|
||
|
properties (Access = public)
|
||
|
TotalPower;
|
||
|
LandegFactor;
|
||
|
MagneticSubLevel;
|
||
|
MagneticGradient;
|
||
|
CaptureVelocity;
|
||
|
ExitDivergence;
|
||
|
DistanceBetweenPushBeamAnd3DMOTCenter;
|
||
|
PushBeamDistance;
|
||
|
TimeSpentInInteractionRegion;
|
||
|
ParticleDynamicalQuantities;
|
||
|
InitialParameters;
|
||
|
end
|
||
|
|
||
|
methods
|
||
|
function this = TwoDimensionalMOT(varargin)
|
||
|
this@Simulator.MOTCaptureProcess('SimulationMode', '2D', varargin{:});
|
||
|
p = inputParser;
|
||
|
p.KeepUnmatched = true;
|
||
|
addParameter(p, 'TotalPower', 0.8,...
|
||
|
@(x) assert(isnumeric(x) && isscalar(x) && (x > 0)));
|
||
|
addParameter(p, 'LandegFactor', 1,...
|
||
|
@(x) assert(isnumeric(x) && isscalar(x) && (x > 0)));
|
||
|
addParameter(p, 'MagneticSubLevel', 1,...
|
||
|
@(x) assert(isnumeric(x) && isscalar(x)));
|
||
|
addParameter(p, 'MagneticGradient', 0.38,...
|
||
|
@(x) assert(isnumeric(x) && isscalar(x)));
|
||
|
|
||
|
p.parse(varargin{:});
|
||
|
|
||
|
this.TotalPower = p.Results.TotalPower;
|
||
|
this.LandegFactor = p.Results.LandegFactor;
|
||
|
this.MagneticSubLevel = p.Results.MagneticSubLevel;
|
||
|
this.MagneticGradient = p.Results.MagneticGradient;
|
||
|
this.ExitDivergence = this.ExitDivergenceDefault;
|
||
|
this.DistanceBetweenPushBeamAnd3DMOTCenter = this.DistanceBetweenPushBeamAnd3DMOTCenterDefault;
|
||
|
this.PushBeamDistance = this.PushBeamDistanceDefault;
|
||
|
this.InitialParameters = struct;
|
||
|
this.InitialParameters.TotalPower = this.TotalPower;
|
||
|
this.InitialParameters.LandegFactor = this.LandegFactor;
|
||
|
this.InitialParameters.MagneticSubLevel= this.MagneticSubLevel;
|
||
|
this.InitialParameters.MagneticGradient= this.MagneticGradient;
|
||
|
|
||
|
end
|
||
|
|
||
|
function restoreDefaults(this)
|
||
|
this.TotalPower = this.InitialParameters.TotalPower;
|
||
|
this.LandegFactor = this.InitialParameters.LandegFactor;
|
||
|
this.MagneticSubLevel = this.InitialParameters.MagneticSubLevel;
|
||
|
this.MagneticGradient = this.InitialParameters.MagneticGradient;
|
||
|
this.ExitDivergence = this.ExitDivergenceDefault;
|
||
|
this.DistanceBetweenPushBeamAnd3DMOTCenter = this.DistanceBetweenPushBeamAnd3DMOTCenterDefault;
|
||
|
this.PushBeamDistance = this.PushBeamDistanceDefault;
|
||
|
end
|
||
|
end % - lifecycle
|
||
|
|
||
|
methods
|
||
|
function set.TotalPower(this,val)
|
||
|
this.TotalPower = val;
|
||
|
end
|
||
|
function ret = get.TotalPower(this)
|
||
|
ret = this.TotalPower;
|
||
|
end
|
||
|
function set.LandegFactor(this,val)
|
||
|
this.LandegFactor = val;
|
||
|
end
|
||
|
function ret = get.LandegFactor(this)
|
||
|
ret = this.LandegFactor;
|
||
|
end
|
||
|
function set.MagneticSubLevel(this,val)
|
||
|
this.MagneticSubLevel = val;
|
||
|
end
|
||
|
function ret = get.MagneticSubLevel(this)
|
||
|
ret = this.MagneticSubLevel;
|
||
|
end
|
||
|
function set.MagneticGradient(this,val)
|
||
|
this.MagneticGradient = val;
|
||
|
end
|
||
|
function ret = get.MagneticGradient(this)
|
||
|
ret = this.MagneticGradient;
|
||
|
end
|
||
|
function set.CaptureVelocity(this,val)
|
||
|
this.CaptureVelocity = val;
|
||
|
end
|
||
|
function ret = get.CaptureVelocity(this)
|
||
|
ret = this.CaptureVelocity;
|
||
|
end
|
||
|
function set.ExitDivergence(this,val)
|
||
|
this.ExitDivergence = val;
|
||
|
end
|
||
|
function ret = get.ExitDivergence(this)
|
||
|
ret = this.ExitDivergence;
|
||
|
end
|
||
|
function set.DistanceBetweenPushBeamAnd3DMOTCenter(this,val)
|
||
|
this.DistanceBetweenPushBeamAnd3DMOTCenter = val;
|
||
|
end
|
||
|
function ret = get.DistanceBetweenPushBeamAnd3DMOTCenter(this)
|
||
|
ret = this.DistanceBetweenPushBeamAnd3DMOTCenter;
|
||
|
end
|
||
|
function set.PushBeamDistance(this,val)
|
||
|
this.PushBeamDistance = val;
|
||
|
end
|
||
|
function ret = get.PushBeamDistance(this)
|
||
|
ret = this.PushBeamDistance;
|
||
|
end
|
||
|
function set.TimeSpentInInteractionRegion(this,val)
|
||
|
this.TimeSpentInInteractionRegion = val;
|
||
|
end
|
||
|
function ret = get.TimeSpentInInteractionRegion(this)
|
||
|
ret = this.TimeSpentInInteractionRegion;
|
||
|
end
|
||
|
function set.ParticleDynamicalQuantities(this,val)
|
||
|
this.ParticleDynamicalQuantities = val;
|
||
|
end
|
||
|
function ret = get.ParticleDynamicalQuantities(this)
|
||
|
ret = this.ParticleDynamicalQuantities;
|
||
|
end
|
||
|
function set.InitialParameters(this,val)
|
||
|
this.InitialParameters = val;
|
||
|
end
|
||
|
function ret = get.InitialParameters(this)
|
||
|
ret = this.InitialParameters;
|
||
|
end
|
||
|
end % - setters and getters
|
||
|
|
||
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
||
|
%- Methods
|
||
|
|
||
|
methods(Access = protected)
|
||
|
function cp = copyElement(this)
|
||
|
% Shallow copy object
|
||
|
cp = copyElement@matlab.mixin.Copyable(this);
|
||
|
|
||
|
% Forces the setter to redefine the function handles to the new copied object
|
||
|
|
||
|
pl = properties(this);
|
||
|
for k = 1:length(pl)
|
||
|
sc = superclasses(this.(pl{k}));
|
||
|
if any(contains(sc,{'matlab.mixin.Copyable'}))
|
||
|
cp.(pl{k}) = this.(pl{k}).copy();
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
methods (Static)
|
||
|
|
||
|
% Creates an Instance of Class, ensures singleton behaviour (that there
|
||
|
% can only be one Instance of this class
|
||
|
function singleObj = getInstance(varargin)
|
||
|
% Creates an Instance of Class, ensures singleton behaviour
|
||
|
persistent localObj;
|
||
|
if isempty(localObj) || ~isvalid(localObj)
|
||
|
localObj = Simulator.TwoDimensionalMOT(varargin{:});
|
||
|
end
|
||
|
singleObj = localObj;
|
||
|
end
|
||
|
end
|
||
|
|
||
|
end
|