Project 3
Contents
Project 3#
Practicalities#
Deadline: Wednesday, October 23, 23:59.
Format:
A scientific report, typeset in LaTeX, delivered as a pdf file on Canvas.
Use the report template we have provided here.
Code (with comments, of course) on a UiO GitHub repo (github.uio.no), with the URL to you repo written in the pdf document.
You must deliver via your group on Canvas (even if you are working alone).
A scientific report: In contrast to projects 1 and 2, we now require you to write a proper scientific report. The details of this is discussed during the lectures, and we provide you with a
.tex
file template – see this page.Collaboration: We strongly encourage you to collaborate with others, in groups of up to three students. The group hands in a single pdf. Remember to list everyone’s name in the pdf.
Reproducibility: Your code should be available on a GitHub repo. You can refer to relevant parts of your code in your answers. Make sure to include a README file in the repo that briefly explains how the code is organized, and how it should be compiled and run in order for others to reproduce your results.
Figures: Figures included in your LaTeX document should be made as vector graphics (e.g.
.pdf
files), rather than raster graphics (e.g..png
files). If you are making plots withmatplotlib.pyplot
in Python, this is as simple as callingplt.savefig("figure.pdf")
rather thanplt.savefig("figure.png")
.
Introduction#
In this project, you’ll study the effects of a device used to store charged particles. This device is known as a Penning trap and utilizes a static configuration of electric and magnetic fields to confine charged particles, so that they can be used for various types of measurements and experiments. In particular, experiments at CERN such as ALPHA, AEgIS and BASE use Penning traps to control the antimatter in their experiments.
Reminder on electrodynamics and classical mechanics#
Not everyone in this course study physics as their main subject. Therefore we’ll summarize the main equations from electrodynamics that you need to work on this project. Good old classical physics is sufficient to study the basics of Penning trap, so we won’t worry about quantum aspects.
The electric field (
) is related to the electric potential ( ) through the equation(7)#where
denotes the gradient operator.The electric field
at a point set up by point charges distributed at points is(8)#where
is Coulomb’s constant.The force
on a particle with charge from an electric field and magnetic field , known as the Lorentz force, is given by(9)#where
is the velocity of the particle.Finally, the time evolution of a particle is governed by Newton’s second law,
(10)#where
denotes the mass of the particle and .
Note
Moving particles will in reality also induce magnetic forces on each other, but these forces will be smaller than the Coulomb forces by a factor
The Penning trap#
A schematic of a Penning trap is shown in figure Fig. 3. Charged particles are confined using constant electric and magnetic fields. The electric field is set by three electrodes: the two end caps (a) and a ring (b) (only the ring cross-section is shown). The constant and homogenous magnetic field in the trap is set up by a cylinder magnet (c) (only cross-section shown). The red dot represents a (positively charged) trapped particle.
We will consider an ideal Penning trap in which the electric field is defined by the electric potential
Here
The electric field traps the particle in the
where
Problems#
The analytical part#
For now, assume that we’re dealing with a single particle with charge
Problem 1#
Starting from Newton’s second law, show that the differential equations governing the time evolution of the particle’s position (the equations of motion) can be written as
where we define
Write down the general solution for eq. (15). While the above equations of motion are of course equally valid for
Problem 2#
Eqs. (13) and (14) introduces a challenge because the two equations are coupled.
Introduce a complex function
Problem 3#
The general solution to eq. (16) is
where
The physical coordinates are then found as
What is the necessary constraint on
Problem 4#
Show that the upper and lower bounds on the particle’s distance from the origin in the
Specific analytical solution#
For later tests of the code you develop, you will need a specific analytical solution to use for comparison. For this we will consider the case of a single charged particle with charge
From eq. (15) and the initial values for
For the movement in the
With multiple particles#
We remind you that so far we have only been looking at the special case of a single particle. In a trap with more particles, the equations of motion for each particle are coupled to those of the other particles. Specifically, consider the case where we fill our Penning trap with a set of
Here
Note
While the above equations are the equations our simulation will solve, our code does not have to contain these equations as single, long mathematical formulas. First of all, the equations above are second-order differential equations, while we will use Forward Euler and Runge-Kutta as methods for solving first-order differential equations. So when approaching the numerical part of this project, the first step is to formulate the problem in terms of coupled, first-order differential equations:
This suggests that all the physics-specific details in the second-order differential equations above will effectively be contained in the function(s) you use to compute the total force
The code snippets we provide at the end will outline an approach where the contributions from different forces are specificed in separate functions in the code. This will allow us to write a quite general Penning trap simulator, for which the specific Penning trap configuration described by the equations above is just one special case.
Code development and numerical investigations#
In this part, you’ll develop a code to simulate a set of Particle
and PenningTrap
. The other aspects of your code you are
free to design in the way you think is best.
Numbers and units#
For this project we’ll work with the following set of base units:
Length: micrometre (
)Time: microseconds (
)Mass: atomic mass unit (
)Charge: the elementary charge (
)
In these units, the Coulomb constant takes the value
and the derived SI units for magnetic field strength (Tesla,
.
Our default Penning trap configuration will have
.
We note that
.
(Note that we have here used the precise
We’ll use singly-charged Calcium ions (Ca
Problem 5#
Create a class named Particle
that should at least store the following properties of a single particle:
Charge (
)Mass (
)Position (
)Velocity (
)
You are of course free to extend the class with more attributes (member variables) and/or methods (member functions) if you think it is useful.
Some advice:
The constructor should assign values to the member variables.
For the position and velocity, use
arma::vec
objects.Make all member variables public. This is just to ease the interplay between the
Particle
class and thePenningTrap
class. (Alternatively, a nice approach in this case would be to makePenningTrap
a friend class ofParticle
.)
Problem 6#
Create a class named PenningTrap
that should at least contain member variables for the following:
The magnetic field strength (
)The applied potential (
)The characteristic dimension (
)A
std::vector<Particle>
to contain all theParticle
objects in the Penning trap.
Further, the class should contain some member functions for evaluating
The external electric field
The external magnetic field
The force due to the interaction among the particles
Remember to run small tests during your code development. In particular, since the analytic solution we have found are for the case of a single particle, you can consider carrying out the single-particle tests in Problem 8 before implementing any of the code related to particle interactions.
Problem 7#
Now we need functionality for actually solving the equations of motion, i.e. evolving our system in time. Our main method will be the fourth-order Runge-Kutta (RK4) method, but for comparison (and debugging) we’ll also implement the simple forward Euler method.
So, write functions that can evolve your PenningTrap
system in time using
the forward Euler method
the RK4 method
You can implement these methods either
via regular functions, that take a reference to a
PenningTrap
object as input;via some type of “solver class” or “integrator class”, that contains/interacts with the
PenningTrap
object; orvia member functions implemented directly in the
PenningTrap
class.
The code snippets below outline the third approach, but feel free to choose the approach you prefer.
We will use RK4 in the problems below, unless specified otherwise. However, having the simple forward Euler method implemented is still very useful – for instance it can help you check if a problem in your results is due a problem in your RK4 code or some other part of the code.
Note
In the Runge-Kutta algorithm you have to compute a series of
In other words, your implementation of the Runge-Kutta algorithm for one timestep should probably go something like this:
Make a temporary copy of all the particles in the Penning trap, since we’ll need the original positions and velocities to perform the final RK4 update step.
For each particle, compute
and .For each particle, update the position and velocity using the corresponding
and .For each particle, compute
and .For each particle, update the position and velocity using the corresponding
and…
For each particle, compute
andFinal step: For each particle, perform the proper RK4 update of position and velocity using the original particle position and velocity, together with all the
and computed above.
Problem 8#
For the simulations in this problem we’ll consider only one or two particles. Use the following initial conditions for all these simulations:
Particle 1:
Particle 2:
It’s now time to test and explore your simulation:
Simulate the movement of a single particle in your Penning trap for a total time of
. Make a plot of the motion in the direction as a function of time. Does the result look as expected, given the value of ?Simulate two particles in your Penning trap and make a plot of their motion in the
-plane with and without particle interactions.Similarly, for the case of two particles, make plots of the trajectories in the (
and planes (i.e. phase space plots) for the cases with and without interactions. How do the trajectories change when you include interactions? Are the results reasonable from a physical point of view?Make a 3D plot of the trajectory of two particles in the
space with and without interactions.
Note
An example of 3D plotting with matplotlib can be found here.
Now consider the case of a single particle, which means we can easily compare to the analytical solution. Use the initial values for Particle 1 given above, and let the total simulation time be
. Run the simulation four times, using , , and timesteps. (Corresponding stepsizes: ). For each of the four simulations, make a graph showing the size of the relative error in at each time step . Present the four graphs in a single plot. Do the same using the forward Euler method.Using the simulation results for the four different stepsize values
, estimate the error convergence rate for forward Euler and RK4 with the expression
where
is the maximum error (taken over all timesteps
Note
When trying to interpret the plots from the simulations above, you may find it useful to also look at other plots, e.g. plots of the
Note
Plots with particle trajectories can be complicated to read. You may find it useful to use e.g. plt.scatter
to put some markers in your plot that show the start point and end point of each trajectory.
Note
To make sure that e.g. circular orbits actually look circular in your plots, the pyplot command plt.axis('equal')
might come in handy.
Note
If your simulation results look wrong, it can be useful to start the debugging by only simulating a few timesteps rather than running the full
Problem 9#
Now that we have explored the basics of our simulation setup it’s time to use it to explore some Penning trap physics.
In a system with complicated periodic motions we should expect the possibility for seeing resonance phenomena. In a Penning trap, this can be investigated by subjecting the system to a time-dependent electromagnetic field and study the loss of trapped particles as function of the applied frequency.
There are multiple ways of subjecting the system to a time-dependent field. Here we will do it by including a time-dependent perturbation to the applied potential, i.e. make the replacement
where
For this task you should implement (at least) the following extensions to your code:
A check that sets the external E- and B-fields to zero in the region outside the trap. We’ll use the characteristic distance
as a simple measure for the trap size, so what we need is a check that sets the external fields and to zero when .An extension of the code for the external E-field such that it can have a time dependence. (For the different steps in RK4, make sure you evaluate the now time-dependent force at the correct time steps.)
A small function (either as part of the
PenningTrap
class or outside it) that can count how many of the particles are still inside the trap region, i.e. the number of particles with .An option to switch the Coulomb interactions on/off.
Code for filling the
PenningTrap
with particles with randomly generated initial positions and velocities. Initial positions and velocities for each particle can be sampled from normal distributions, suitably scaled relative to the length scale of our Penning trap. Here’s a snippet illustrating this for a single particle, using thevec::randn()
function of Armadillo to sample a position and velocity (my_trap
is an instance ofPenningTrap
):vec r = vec(3).randn() * 0.1 * my_trap.d; // random initial position vec v = vec(3).randn() * 0.1 * my_trap.d; // random initial velocity
Note: To set the seed for Armadillo’s random number generator, you can use
arma_rng::set_seed(value)
orarma_rng::set_seed_random()
.
We want to use our simulation to search for resonance frequencies of the system. Starting from a system filled with 100 randomly initialized Ca
For each of the amplitudes
, produce a graph that shows the fraction of particles that are still trapped after as a function of the applied angular frequency . Plot the three graphs in the same figure. You should explore frequencies in the range . For this broad exploration of frequencies you can switch off the Coulomb interactions between the particles in the trap, as your code should then run much faster. Make sure you use sufficiently small steps along the axis – steps of can be a starting point. Comment on your results. Some suggested things to discusss:A qualitative explanation of what’s going on: Given the periodic / quasi-periodic nature of the Penning trap system, why is it that some frequencies can be particularly effective for pushing particles out of the trap? (Here we do not expect a detailed explanation of the physics behind why the resonances appear exactly where they do – the resonance structure of a many-particle Penning trap is a complicated topic beyond the scope of this project.)
How do the resonances change when the amplitude for the time-varying potential is increased?
Now we want to check if the Coulomb interactions have some impact on the structure of these resonances. To do this you should “zoom in” on one of the resonances you’ve uncovered by performing fine-grained frequency scans around that resonance.
Perform two such scans, one where you include Coulomb interactions in your simulation and one without. (If you have time, you can run multiple scans for each case and use the average results, to lower the statistical uncertainty coming from the fact that we only simulate 100 randomly initialized particles.)
Produce a plot that shows the fraction of trapped particles versus frequency for the two cases. Comment on noteworthy differences.
Note
Running a simulation with 100 particles is computationally quite demanding, and runtimes can vary greatly depending on how the code is written, the particular machine the code is run on, etc. Enabling compiler optimisation can have quite a big impact on the runtime. We recommend adding either -O2
or -O3
to your compilation command.
As a reference, for my (Anders) code and laptop, running a 100-particle simulation for 40,000 timesteps using RK4 and no Coulomb interactions takes ~10 seconds. This reduces to ~2 seconds when compiling with -O2
.
Note
Some of you may experience runtimes that are so long that you are unable to perform the series of 100-particle simulations for this problem. If you are unable to reduce the runtime by optimising your code, switching on compiler optimisation, etc, you can reduce the problem size by reducing the number of particles until you get workable runtimes. If you have to do this, please comment on it in your report.
Good luck!
Code snippets#
Here is a suggested starting point for member functions of the PenningTrap
class:
// Constructor
PenningTrap(double B0_in, double V0_in, double d_in);
// Add a particle to the trap
void add_particle(Particle p_in);
// External electric field at point r=(x,y,z)
arma::vec external_E_field(arma::vec r);
// External magnetic field at point r=(x,y,z)
arma::vec external_B_field(arma::vec r);
// Force on particle_i from particle_j
arma::vec force_particle(int i, int j);
// The total force on particle_i from the external fields
arma::vec total_force_external(int i);
// The total force on particle_i from the other particles
arma::vec total_force_particles(int i);
// The total force on particle_i from both external fields and other particles
arma::vec total_force(int i);
// Evolve the system one time step (dt) using Runge-Kutta 4th order
void evolve_RK4(double dt);
// Evolve the system one time step (dt) using Forward Euler
void evolve_forward_Euler(double dt);
Note that for Problem 9 you probably want to modify the declarations of some of these functions, as well as add some new ones.