Skip to content

Latest commit

 

History

History
291 lines (188 loc) · 12.6 KB

README.rst

File metadata and controls

291 lines (188 loc) · 12.6 KB

Thor

Author: Johan Bengtsson

Self-Consistent Symplectic Integrator for Charged Particle Beam Dynamics

Having implemented DA-Pascal in the early 1990s, see ref. below, based on a recursive approach – i.e., automatable by an universal Turing machine (any modern digital computer) – for nonlinear beam dynamics analysis by utilizing Lie series on a beam line object; automated to arbitrary order by Truncated Power Serias Algegra (TPSA). In particular, implemented as a Pascal module/software library by extending the standard procedures & functions for N. Wirth's Pascal-S compiler/interpreter. Hence, in 1992, rather than participating in a "talkshop" for the CLASSIC collaboration, we instead prototyped & implemented a C++ beam line class based on a polymorphic number object with reference counting. For which the latter mechism provides for garbage collection; since it is not provided by C++, vs. e.g. Lisp & Smalltalk.

To quote Forest in:

E. Forest, F. Schmidt, E. McIntosh Introduction to the Polymorphic Tracking Code CERN-SL-2002-044 (AP), KEK-Report 2002-3 (2002).

Therefore the proper implementation of a fibre bundle was a sine qua non, non-negotiable point, which Forest and Bengtsson insisted upon in the early days of pre-CLASSIC C++ collaborations. A quick look at CLASSIC (MAD9) shows that the CLASSIC structure does not satisfy this condition. In particular, patches are derived from the beam element class and are thus of the same nature as the element. Patches are generally a figment of one’s mathematical imagination, useful tools, but they are not physical elements which can be ordered from a factory. We believe this is a major flaw in the CLASSIC design. It is perhaps the result of placing too much emphasis on implementation using C++ capabilities, rather than the basic mathematical framework. We believe this accounts for the excessive number of classes and the complexity of CLASSIC (MAD9).

...

Here, in PTC, as well as in the original C++ classes that Bengtsson dreamt up in collaboration with Forest, the geometrical nature of the fibre reigns supreme. The next step is to introduce a magnet, namely EL and/or ELP. The propagator of the full fibre, if well-defined, inherits properties from the chart itself. In other words a magnet exists first as a piece of material junk. It can be rotated, translated and drawn. The chart provides the connection between this magnet/junk and the external three dimensional space. Obviously this exists independently of the existence of single particle propagators associated to EL and/or ELP. It is a remarkable mathematical feature that these propagators, under certain conditions, inherit the transformational properties of the chart. Of course PTC is set up to take advantage of this.

...

TRACYII was based on the belief that a dumb user interface should be built on the foundation of a smart user interface. In this way complex situations could always be handled. This was so successful that, in the 2 years of the PEPB design (SLAC), Robin and Bengtsson recompiled TRACYII no more than 2 or 3 times.

...

In the case of TRACYII, this was realized by separating the lattice input file (dumb user) from the command input file (smart user). This idea, originally from Nishimura, was turned into an uncompromising product by Bengtsson. In PTC the same can be achieved by stripping all the core routines from any dumb user idiosyncracies. One example common to TRACYII and PTC is the absence of quadrupoles in the core.

...

In addition, as we shall see, if some user’s algorithm uses PTC extended definition of the ray to compute the equivalent of the “synchrotron integrals,” then it will be correctly computed under any possible mispowering and misaligning of the elements. PTC is a faithful representation of a part of nature, just as Seurat’s painting is a faithful representation of some aspect of a scene. In addition, just as pointillism adds to the natural setting a seemingly unnatural element, PTC adds properties to the ray being tracked which do not exist in nature. In the case of PTC, thanks to a polymorphic type first dreamt up by Bengtsson, the electron carries with itself a potential Taylor Series whose variable space is nearly infinite.

...

My views have been, at least since the C++ business got underway, that the flow through the magnet must be elevated to the status of a mathematical object. And then, it must find its counterpart on the silicon canvas, whether painted in C++ or any other language. Polymorphism, Bengtsson’s pointillism, will take care of the rest. This is achieved by a local “s” -dependent theory which is shaped around individual magnets. The global system is then patched together. The mathematicians gave us the tools to manipulate this object: the fibre bundle. PTC simply creates a restricted fibre bundle on the computer, one which is relevant to particle accelerators. This structure is incompatible with standard Courant-Snyder theory and other similar constructs like Sand’s integrals.

...

Besides the two individuals whose names appear on this paper and Aimin Xiao who collaborated on the very first prototype, I would like to thank Johan Bengtsson (of parts unknown) for convincing me that, at least in C++, one could go ahead and make a reasonable job of polymorphism and fibre bundles.

images/seurat.png

I.e., eventually, he re-implemented the strategy/approach in Fortran-90; since by then that grammar had been extended to support operator overloading.

Tracy-2

The symplectic integrator for realistic modeling of magnetic lattices for ring-based synchrotrons was initially implemented as a Pascal module/beam dynamics software library, by the author 1990, as an on-line model to guide the ALS commissioning. In particular, care was taken for the software architecture & resulting records/modules – akin to objects although not explicitly supported by the grammar – to reflect the structure of the mathematical objects describing the underlying beam dynamics model.

Hence, the code was also benchmarked & calibrated as part of the ALS commissioning:

J. Bengtsson, M. Meddahi Modeling of Beam Dynamics and Comparison with Measurements for the Advanced Light Source (ALS) EPAC 1994.

The resulting C code, see below, has now been re-factored by introducing a C++ beam line class; i.e., to recover the transparency & simplicity of the original beam dynamics model.

Nota Bene: Although the beam dynamics model had to be replaced & the model/code re-architectured & structured – for a reusable approach – as a Pascal beam dynamics libary (standard practise in software engineering), the code was named Tracy-2, i.e., inspired by the demo/prototype Tracy:

H. Nishimura "TRACY, A Tool for Accelerator Design and Analysis" EPAC 1988.

for which the beam dynamics model was based on the linearized quadratic Hamiltonian:

images/H_2.png

for linear optics design; i.e., for a bare lattice with mid-plane symmetry. Hence, the one thing we found useful & adopted was the implementation of the prototype model/code as an extension of the standard procedures & functions for the Pascal-S compiler/interpreter by N. Wirth:

N. Wirth PASCAL-S: A Subset and its Implementation Institut für Informatik (1975).

In other words, since 1992 our toolkit – althout it based on one model: the Hamiltonian for a charged particle in an external electromagnetic field & a symplectic intrator for magnetic multipoles & insertion devices for ditto – it was implemented as two different codes: Tracy-2 & Thor. Hence, eventually, these were consolidated by using C++ templates for the polymorphich number object and beam line class; aka Tracy-2,3.

Contributions

  • The symplectic integrator for RADIA kick maps:

    P. Elleaume A New Approach to the Electron Beam Dynamics in Undulators and Wigglers” EPAC 1992.

    was implemented by Laurent Nadolski, SOLEIL, 2002.

  • The original •Pascal library/code• was machine translated to C and re-used to implement a model server for the SLS commissioning:

    M. Böge Update on TRACY-2 Documentation SLS Tech Note SLS-TME-TA-1999-0002 (1999).

    M. Böge, J. Chrin A CORBA Based Client-Server Model for Beam Dynamics Applications ICALEPS 1999.

    with p2c.

  • Similarly, James Rowland re-used the C version to implement a Virtual Accelerator interfaced to EPICS as a Virtual Input Output Controller (VIOC):

    M. Heron, J. Rowland, et al Progress on the Implementation of the DIAMOND Control System ICALEPCS 2005.

  • Besides, the internal numerical engine was manually translated to C and re-used for:

    A. Terebilo Accelerator Toolbox for MATLAB SLAC-PUB-8732 (2001).

  • Python interface:

    Initial demo/prototype & guidelines by Jan Chrin, PSI, 2017:

    J. Chrin Channel Access from Cython (and other Cython use cases) EPICS Collaboration Meeting 2017.

    Guidelines & automated regression testing bootstrapped by Pierre Schnizer.

Requirements

The library uses the range checking inmplementation of e.g. std::vector as provided by GNU C++; thus its dependency on the GNU compiler collections.

To install

Setup of repository

Dowload the repository and checkout the proper branch. Here it's assumed you will use the directoy git_repos/tracy-3.5 in your home directory for the tracy code tree.

For this use the following commands to create the directoy git_repos and to clone the tree into the tracy-3.5 directory.

mkdir git_repos
cd git_repos
git clone [email protected]:jbengtsson/Thor_scsi.git
cd Thor_scsi

Then select the proper tree by

git checkout Thor_scsi

C++ library

First create environment variable $TRACY_LIB. This will be the prefix where the built library and include files will be installed later on e.g:

export TRACY_LIB=$HOME/git_repos/Thor_scsi

To build the library use:

cd Thor_scsi
(g)libtoolize
./bootstrap
./configure --prefix=$Thor_scsi_LIB
make
make install

Please note: using the dynamic library in non standard location will require proper set up of the environment later on (e.g. adding the directory where the library is located to LD_LIBRARY_PATH environment variable).

Python interface

The python interface is based on https://github.com/pybind/pybind11. Building this interface requires to select the proper directory

cd git_repos
cd Thor_scsi/python

Install proper dependencies

pip3 install -r requirements.txt

And build the extension e.g.

python3 setup.py build
python3 setup.py install

For further details of the build system see https://pypi.org/project/setuptools/

To run the regression tests

All regression tests can be run using

pip3 install nose
python3 setup.py nosetests

To run the demo/test program

python3 examples/tst.py