Latest commit

This commit is contained in:
Karthik 2024-06-12 21:17:53 +02:00
parent 9d187540ad
commit a1e0ad544e
5 changed files with 29 additions and 52 deletions

View File

@ -7,10 +7,10 @@ classdef PhysicsConstants < handle
ElectronMass=9.10938291E-31; ElectronMass=9.10938291E-31;
GravitationalConstant=6.67384E-11; GravitationalConstant=6.67384E-11;
ProtonMass=1.672621777E-27; ProtonMass=1.672621777E-27;
AtomicMassUnit=1.66053878283E-27; AtomicMassUnit=1.660539066E-27;
BohrRadius=0.52917721092E-10; BohrRadius=5.2917721067E-11;
BohrMagneton=927.400968E-26; BohrMagneton=9.274009994E-24;
BoltzmannConstant=1.380649E-23; BoltzmannConstant=1.38064852E-23;
StandardGravityAcceleration=9.80665; StandardGravityAcceleration=9.80665;
SpeedOfLight=299792458; SpeedOfLight=299792458;
StefanBoltzmannConstant=5.670373E-8; StefanBoltzmannConstant=5.670373E-8;
@ -23,19 +23,8 @@ classdef PhysicsConstants < handle
GravitationalAcceleration = 9.80553; GravitationalAcceleration = 9.80553;
% Dy specific constants % Dy specific constants
Dy164Mass = 163.929174751*1.66053878283E-27; Dy164Mass = 163.929174751*1.660539066E-27;
Dy164IsotopicAbundance = 0.2826; Dy164IsotopicAbundance = 0.2826;
BlueWavelength = 421.291e-9;
BlueLandegFactor = 1.22;
BlueLifetime = 4.94e-9;
BlueLinewidth = 1/4.94e-9;
RedWavelength = 626.086e-9;
RedLandegFactor = 1.29;
RedLifetime = 1.2e-6;
RedLinewidth = 1/1.2e-6;
PushBeamWaveLength = 626.086e-9;
PushBeamLifetime = 1.2e-6;
PushBeamLinewidth = 1/1.2e-6;
end end
methods methods

View File

@ -6,11 +6,10 @@
OptionsStruct = struct; OptionsStruct = struct;
OptionsStruct.SimulationMode = 'ImaginaryTimeEvolution'; % 'ImaginaryTimeEvolution' | 'RealTimeEvolution' OptionsStruct.SimulationMode = 'ImaginaryTimeEvolution'; % 'ImaginaryTimeEvolution' | 'RealTimeEvolution'
OptionsStruct.ErrorEstimationMethod = 'bootstrap'; % 'jackknife' | 'bootstrap' OptionsStruct.CutoffType = 'Cylindrical';
OptionsStruct.NumberOfAtoms = 5000; OptionsStruct.PotentialType = 'Harmonic';
OptionsStruct.TimeStep = 50e-06; % in s OptionsStruct.TimeStep = 50e-06; % in s
OptionsStruct.SimulationTime = 4e-03; % in s OptionsStruct.SimulationTime = 4e-03; % in s
OptionsStruct.CutoffType = true;
OptionsStruct.SaveData = true; OptionsStruct.SaveData = true;
OptionsStruct.SaveDirectory = './Data'; OptionsStruct.SaveDirectory = './Data';
options = Helper.convertstruct2cell(OptionsStruct); options = Helper.convertstruct2cell(OptionsStruct);
@ -18,6 +17,7 @@ clear OptionsStruct
sim = Simulator.DipolarGas(options{:}); sim = Simulator.DipolarGas(options{:});
calc = Simulator.Calculator(options{:}); calc = Simulator.Calculator(options{:});
pot = Simulator.Potentials(options{:});
%-% Run Simulation %-% %-% Run Simulation %-%
[Params, Transf, psi, V, VDk] = sim.runSimulation(calc); [Params, Transf, psi, V, VDk] = sim.runSimulation(calc);

View File

@ -5,7 +5,12 @@ classdef DipolarGas < handle & matlab.mixin.Copyable
TimeStep; TimeStep;
SimulationTime; SimulationTime;
NumberOfAtoms; NumberOfAtoms;
ErrorEstimationMethod;
% Etol = 5e-10; % Tolerances
% rtol = 1e-5;
% cut_off = 2e6; % sometimes the imaginary time gets a little stuck
% even though the solution is good, this just stops it going on forever
% mindt = 1e-6; %Minimum size for a time step using adaptive dt
%Flags %Flags
@ -25,11 +30,9 @@ classdef DipolarGas < handle & matlab.mixin.Copyable
p.KeepUnmatched = true; p.KeepUnmatched = true;
addParameter(p, 'SimulationMode', 'ImaginaryTimeEvolution',... addParameter(p, 'SimulationMode', 'ImaginaryTimeEvolution',...
@(x) any(strcmpi(x,{'ImaginaryTimeEvolution','RealTimeEvolution'}))); @(x) any(strcmpi(x,{'ImaginaryTimeEvolution','RealTimeEvolution'})));
addParameter(p, 'ErrorEstimationMethod', 'bootstrap',...
@(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', 0.0005,...
@(x) assert(isnumeric(x) && isscalar(x) && (x > 0))); @(x) assert(isnumeric(x) && isscalar(x) && (x > 0)));
addParameter(p, 'SimulationTime', 3e-03,... addParameter(p, 'SimulationTime', 3e-03,...
@(x) assert(isnumeric(x) && isscalar(x) && (x > 0))); @(x) assert(isnumeric(x) && isscalar(x) && (x > 0)));

View File

@ -1,27 +1,16 @@
function [Params] = setupParameters(this) function [Params] = setupParameters(this)
%%--%% Parameters %%--%%
%========= Simulation =========%
pert = 0; % 0 = no perturbation during real-time, 1=perturbation
%method=1; % 0 = normal dipolar potential, 1=spherical cut-off, 2=cylindrical cut-off
% Tolerances
Params.Etol = 5e-10;
Params.rtol = 1e-5;
Params.cut_off = 2e6; % sometimes the imaginary time gets a little stuck
% even though the solution is good, this just stops it going on forever
%========= Constants =========% %========= Constants =========%
hbar = 1.0545718e-34; % Planck constant [J.s] CONSTANTS = Helper.PhysicsConstants;
kbol = 1.38064852e-23; % Boltzmann Constant [J/K] hbar = CONSTANTS.PlanckConstantReduced; % [J.s]
mu0 = 1.25663706212e-6; % Vacuum Permeability [N/A^2] -- kbol = CONSTANTS.BoltzmannConstant; % [J/K]
muB = 9.274009994e-24; % Bohr Magneton [J/T] mu0 = CONSTANTS.VacuumPermeability; % [N/A^2]
a0 = 5.2917721067e-11; % Bohr radius [m] muB = CONSTANTS.BohrMagneton; % [J/T]
m0 = 1.660539066e-27; % Atomic mass [kg] a0 = CONSTANTS.BohrRadius; % [m]
w0 = 2*pi*100; % Angular frequency unit [s^-1] m0 = CONSTANTS.AtomicMassUnit; % [kg]
mu0factor = 0.3049584233607396; % =(m0/me)*pi*alpha^2 -- me=mass of electron, alpha=fine struct. const. w0 = 2*pi*100; % Angular frequency unit [s^-1]
% mu0=mu0factor *hbar^2*a0/(m0*muB^2) mu0factor = 0.3049584233607396; % =(m0/me)*pi*alpha^2 -- me=mass of electron, alpha=fine struct. const.
% mu0=mu0factor *hbar^2*a0/(m0*muB^2)
%=============================% %=============================%
% Number of points in each direction % Number of points in each direction
@ -35,7 +24,7 @@ Params.Ly = 40;
Params.Lz = 20; Params.Lz = 20;
% Masses % Masses
Params.m = 164*m0; Params.m = CONSTANTS.Dy164Mass;
l0 = sqrt(hbar/(Params.m*w0)); % Defining a harmonic oscillator length l0 = sqrt(hbar/(Params.m*w0)); % Defining a harmonic oscillator length
% Atom numbers % Atom numbers
@ -57,10 +46,6 @@ Params.wx = 2*pi*125;
Params.wy = 2*pi*125; Params.wy = 2*pi*125;
Params.wz = 2*pi*250; Params.wz = 2*pi*250;
% Time step
Params.dt = 0.0005;
Params.mindt = 1e-6; %Minimum size for a time step using adaptive dt
% Stochastic GPE % Stochastic GPE
Params.gamma_S = 7.5*10^(-3); % gamma for the stochastic GPE Params.gamma_S = 7.5*10^(-3); % gamma for the stochastic GPE
Params.muchem = 12.64*Params.wz/w0; % fixing the chemical potential for the stochastic GPE Params.muchem = 12.64*Params.wz/w0; % fixing the chemical potential for the stochastic GPE
@ -81,7 +66,7 @@ Params.gx=(Params.wx/w0)^2;
Params.gy=(Params.wy/w0)^2; Params.gy=(Params.wy/w0)^2;
Params.gz=(Params.wz/w0)^2; Params.gz=(Params.wz/w0)^2;
% == Calculating quantum fluctuations == % % == Calculate LHY correction == %
eps_dd = Params.add/Params.as; eps_dd = Params.add/Params.as;
if eps_dd == 0 if eps_dd == 0
Q5 = 1; Q5 = 1;

View File

@ -3,7 +3,7 @@ function [psi] = solver(this,psi,Params,Transf,VDk,V,njob,t_idx,Observ)
set(0,'defaulttextInterpreter','latex') set(0,'defaulttextInterpreter','latex')
set(groot, 'defaultAxesTickLabelInterpreter','latex'); set(groot, 'defaultLegendInterpreter','latex'); set(groot, 'defaultAxesTickLabelInterpreter','latex'); set(groot, 'defaultLegendInterpreter','latex');
dt=-1j*abs(Params.dt); dt=-1j*abs(this.TimeStep);
KEop= 0.5*(Transf.KX.^2+Transf.KY.^2+Transf.KZ.^2); KEop= 0.5*(Transf.KX.^2+Transf.KY.^2+Transf.KZ.^2);
Observ.residual = 1; Observ.res = 1; Observ.residual = 1; Observ.res = 1;