Cosmetic changes only, changed a few variable names, dynamical quantities for all atoms across the full simulation time are now returned instead of just the final values.
This commit is contained in:
parent
bc10c207f6
commit
a41ae74cb7
@ -1,22 +1,16 @@
|
|||||||
function [ParticleTrajectory, FinalDynamicalQuantities] = solver(this, InitialPosition, InitialVelocity)
|
function ParticleDynamicalQuantities = solver(this, InitialPosition, InitialVelocity)
|
||||||
|
|
||||||
if this.Gravity
|
if this.Gravity
|
||||||
g = [0,0,-Helper.PhysicsConstants.GravitationalAcceleration];
|
g = [0,0,-Helper.PhysicsConstants.GravitationalAcceleration];
|
||||||
else
|
else
|
||||||
g = 0;
|
g = 0;
|
||||||
end
|
end
|
||||||
|
|
||||||
% Probability of Background Collisions
|
ParticleDynamicalQuantities = zeros(int64(this.SimulationTime/this.TimeStep),6);
|
||||||
collision = rand(1);
|
|
||||||
CollisionProbability = 1 - exp(-this.SimulationTime/this.CollisionTime);
|
|
||||||
|
|
||||||
if collision >= CollisionProbability || this.AtomicBeamCollision == false %flag for skipping the background collision
|
|
||||||
|
|
||||||
ParticleTrajectory = zeros(int64(this.SimulationTime/this.TimeStep),9);
|
|
||||||
|
|
||||||
for i=1:int64(this.SimulationTime/this.TimeStep)
|
for i=1:int64(this.SimulationTime/this.TimeStep)
|
||||||
|
|
||||||
ParticleTrajectory(i,1:3) = InitialPosition;
|
ParticleDynamicalQuantities(i,1:3) = InitialPosition;
|
||||||
ParticleTrajectory(i,4:6) = InitialVelocity;
|
ParticleDynamicalQuantities(i,4:6) = InitialVelocity;
|
||||||
|
|
||||||
rt = InitialPosition;
|
rt = InitialPosition;
|
||||||
vt = InitialVelocity;
|
vt = InitialVelocity;
|
||||||
@ -41,14 +35,7 @@ function [ParticleTrajectory, FinalDynamicalQuantities] = solver(this, InitialPo
|
|||||||
|
|
||||||
InitialPosition = InitialPosition + (gv1+2*(gv2+gv3)+gv4)./6;
|
InitialPosition = InitialPosition + (gv1+2*(gv2+gv3)+gv4)./6;
|
||||||
InitialVelocity = InitialVelocity + this.TimeStep*(ga1+2*(ga2+ga3)+ga4)./6;
|
InitialVelocity = InitialVelocity + this.TimeStep*(ga1+2*(ga2+ga3)+ga4)./6;
|
||||||
ParticleTrajectory(i,7:9) = (ga1+2*(ga2+ga3)+ ga4)./6;
|
%Acceleration = (ga1+2*(ga2+ga3)+ ga4)./6;
|
||||||
end
|
|
||||||
|
|
||||||
FinalDynamicalQuantities = ParticleTrajectory(end,:);
|
|
||||||
|
|
||||||
else
|
|
||||||
ParticleTrajectory = zeros(int64(this.SimulationTime/this.TimeStep),9);
|
|
||||||
FinalDynamicalQuantities = -500*ones(1,9); % -500 is a flag for giving up this trajectory
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user