During the Hands-On Optics Calculations, we will use Python3 and Xsuite
.
Xsuite
is a collection of python packages for the simulation of the beam dynamics in particle accelerators.
Important: we kindly ask you to go through this document before coming to CAS, such as to prepare yourself for the course. We will explain in the following sections how to install all necessary software on your laptop. A basic knowledge of Python is assumed. If you are not familiar with Python, you can find a few resources to fill the gap in the following sections. Do not worry about the theory of Optics Calculations for the moment (it will be discussed in details during the school), just focus on Python and the installation.
After a short introduction, we will focus on the software setup. Finally, in appendix, you will find links and cheatsheets for the most common Python packages that will be used during the course.
You can find several nice courses, videos and resources on the internet. Here you have a couple of suggestions you can find on YouTube:
If you are not familiar with Python and you have not installed it on your laptop, you can start playing with simple python snippets on the web (e.g., CoLab, a Google account is needed).
You can test the following commands:
import numpy as np
# Matrix definition
Omega=np.array([[0, 1],[-1,0]])
M=np.array([[1, 0],[1,1]])
# Sum and multiplication of matrices
Omega - M.T @ Omega @ M
# M.T means the "traspose of M".
# Function definition
def Q(f=1):
return np.array([[1, 0],[-1/f,1]])
# Eigenvalues and eigenvectors
np.linalg.eig(M)
You can compare and check your output with the ones here.
In this section, we will explain how to install Python locally on your laptop.
We suggest not to use CoLab (or other remote servers) during the hands-on since there could be problem with the internet connection.
There are many ways to use Python on your laptop. You can use it from the terminal, from the browser with Jupyter/JupyterLab or in an Integrated Developer Environment, IDE. During the lectures and the Hands-on, we will use Python and JupyterLab.
JupyterLab is a user-friendly environment to work with Python. You can find an overview on JupyterLab here.
We suggest installing Xsuite following the instructions of the Basic Installation. There you will find the procedures to install it on Linux, Mac and Windows Operating Systems (OS). For Windows OS, please use the Windows Subsystem for Linux, WSL.
Then please install the additional packages with
pip install matplotlib ipywidgets jupyter jupyterlab sympy
After the installation, launch JupyterLab and then test that everything works.
-
Launch JupyterLab from your terminal:
jupyter lab
-
Follow the instructions given in the terminal. You should end-up on your default browser with a page similar to this image.
This will be your working directory.
- Start playing with Python! Please make sure to go throw all the 000_example.ipynb to familiarize with the typical Python concepts that will be used during the course, but also to verify your installation.
-
If you are not familiar with Python, you can start playing with simple python snippets. For example, have a look at the following examples/PythonBasic.ipynb (courtesy of Simon Albright).
-
Just before the start of the course, we will ask you to download the latest version of the hands-on lattice exercises (even better, the whole repository) in your working directory.
You can leverage python's capability by exploring a galaxy of packages. Below you can find the most useful for our course (focus mostly on numpy
and matplotlib
) and some very popular ones.
To get familiar with the numpy package, have a look at the following summary poster. You can google many other resources, but the one presented of the poster covers the set of instructions you should be familiar with.
To get familiar with the matplotlib package, have a look at the following summary poster.
To get familiar with the Linear Algebra (linalg) package, have a look at the following summary poster.
To get familiar with the pandas package, have a look at the following summary poster.
To get familiar with the seaborn package, have a look at the following summary poster.
To get familiar with the sympy package, have a look at the following summary poster.