Beam Telescope Analysis (BTA) is a testbeam analysis software written in Python (and C++).
BTA is intended for use with data from multiple particle detectors in a particle beam. One or more detectors may be the device under test (DUT). Any detectors can part of a beam telescope (or hodoscope) or can be a trigger plane (e.g., region of interest trigger) or timing reference (i.e., reference plane, usually of the same type as the DUT). The software allows a detailed analysis of each detector in the sub-micrometer range, if the resolution of the telescope allows it.
- Supporting any pixelated detectors, e.g., detectors with hexagonal pixels have been successfully investigated.
- Works even under harsh beam environments (i.e., high track densities, strong beam background) and delivers precise efficiencies.
- Alignment works even with limited information about the location of each detector (e.g., only z-position from the first and last telescope plane necessary).
- Providing Kalman-based estimates of particle tracks, especially for low-energy particle beams.
- Kalman Filter based alignment for fast and precise alignment of DUTs, even for low-energy particles and setups with high material budget.
BTA uses some novel approaches which have not yet been applied to data from beam telescopes:
- SVD-based method for suppressing un-correlated background in pre-alignment.
- SVD-based method for alignment of the detector planes.
Python 3.9 or higher must be used. There are many ways to install Python, though we recommend using Anaconda Python or Miniconda.
The following packages are required and can be obtained from PyPI (via pip install
) and/or from Anaconda (via conda install
):
- Cython
- PyTables
- NumPy
- SciPy
- Numba
- NumExpr
- Matplotlib
- PyYAML
- dill
- tqdm
- pixel_clusterizer
- PyLandau
If not already installed, install git lfs in order to download fixtures for testing:
sudo apt install git-lfs
Alternatively, manually install git lfs
using these instructions.
The setup.py
requires that cython
, numpy
and gcc
are already installed. Therefore, use e.g. conda
or pip
conda install -y cython numpy
Furthermore, if gcc
is not installed, run
sudo apt install build-essential
Clone the BTA repository:
git clone https://github.com/SiLab-Bonn/beam_telescope_analysis.git
If you want to modify the code without having to re-install the package every time, use the following command (from within the repository folder):
pip install -e .
If you just want to use BTA, run the following command:
pip install .
- Provide input data files (PyTables/HDF5) specified below.
- Write a BTA script which is specific to your telescope setup (see examples in
./beam_telescope_analysis/examples/
folder). - Run BTA script and wait for the output plots (PDF) to appear.
- Check output plots for validity and in case of failure modify the BTA script.
Optional:
- Modify the BTA source code according to your needs.
- Under some circumstances it might be necessary to add your detector specifications to BTA. For that, add your specification to
./beam_telescope_analysis/telescope/dut.py
.
The input data for BTA must be using the PyTables/HDF5 file format. No other file format is currently supported. A single file must be provided for each detector (i.e., telescope plane, timing reference, DUT, etc.).
Each input data file must contain a data table with the node name Hits
.
The hit data table must at least contain the following columns:
event_number
(long): unique event number (positive and monotonic increasing) for all events accross all detectors; starting from 0column
(ushort): pixel column index; starting from 1row
(ushort): pixel row index; starting from 1frame
(ushort): timing bin (only applicable to some detectors, can be used for cluster building); if not available, set to 0.charge
(float): charge seen by the detector (only applicable to some detectors, can be used for charge weighted clustering); if not available, set to 0.
Additional columns can be provided.
Note:
The columns column
and row
can be provided as float data type if x/y coordinates instead of indices are available.
The code is generally optimized for low memory footprint. For example, it reads data slices from the HDF5 file, processes the data chunk, adds results to histograms/arrays, and then goes to the next data slice.
The code rans on a local machine with 8 GB RAM. If you encounter problems, the easiest solution is to throw more RAM at the problem.
Please use GitHub's issue tracker.
- Fork the project.
- Clone your fork and/or get the latest changes from upstream.
- Create a topic branch.
- Modify the code and commit your changes in logical chunks.
- Locally rebase the upstream branch into your topic branch.
- Push your topic branch to your fork.
- Open a Pull Request (PR) with clear title and description about the modifications.
Testbeam Analysis (TBA) is the predecessor of Beam Telescope Analysis (BTA).
- J. Janssen (on behalf of the RD42 collaboration), Test Beam Results of ATLAS DBM pCVD Diamond Detectors Using a Novel Threshold Tuning Method, JINST. DOI: 10.1088/1748-0221/12/03/C03072
- N. Wermes, Pixel detectors ... where do we stand?, NIMA. DOI: 10.1016/j.nima.2018.07.003
- D.-L. Pohl et al., Radiation Hard Pixel Sensors Using High-Resistive Wafers in a 150nm CMOS Processing Line, JINST. DOI: 10.1088/1748-0221/12/06/P06020
- M. Reichmann (on behalf of the RD42 collaboration), New Test Beam Results of 3D and Pad Detectors Constructed with Poly-Crystalline CVD Diamond, NIMA. DOI: 10.1016/j.nima.2019.162675
- Y. Dieter et al., Radiation tolerant, thin, passive CMOS sensors read out with the RD53A chip, NIMA. DOI: 10.1016/j.nima.2021.165771
- Y. Dieter et al., Characterization of small-pixel passive CMOS sensors in 150 nm LFoundry technology using the RD53A readout chip, NIMA. DOI: 10.1016/j.nima.2020.164130
...more to come.
- J. Janssen (on behalf of the RD42 collaboration), Test Beam Results of ATLAS Diamond Beam Monitor poly-crystalline CVD Diamond Modules, Topical Seminar on Innovative Particle and Radiation Detectors (IPRD), 2016, Siena, Italy.
- D.-L. Pohl et al., Radiation-hard passive CMOS-sensors, 13th Trento Workshop on Advanced Silicon Radiation Detectors, 2018, Munich, Germany. https://indico.cern.ch/event/666427/contributions/2881132/
- H. Kagan (on behalf of the RD42 collaboration), Beam Test Results of 3D Pixel Detectors Constructed with pCVD Diamond, International Workshop on Semiconductor Pixel Detectors for Particles and Imaging (Pixel), 2018, Taipei, Taiwan. https://indico.cern.ch/event/669866/contributions/3245181/
- A. Oh (on behalf of the RD42 collaboration), Latest Results on Radiation Tolerance of Diamond Detectors & Status of 3D Diamond, Advanced Diamond Assemblies (ADAMAS), 2018, Vienna, Austria.
- M. Reichmann (on behalf of the RD42 collaboration), New Test Beam Results of 3D and Pad Detectors Constructed with Poly-Crystalline CVD Diamond, 15th Vienna Conference on Instrumentation (VCI), 2019, Vienna, Austria.
- D. Sanz (on behalf of the RD42 collaboration), Development of Polycrystalline Chemical Vapor Deposition Diamond Detectors for Radiation Monitoring, 7th International Conference on Radiation in Various Fields of Research (RAD), 2019, Herceg Novi, Montenegro.
- M. Reichmann (on behalf of the RD42 collaboration), New Beam Test Results of 3D Pixel Detectors Constructed with Poly-Crystalline CVD Diamond, 29th International Symposium on Lepton Photon Interactions at High Energies, 2019, Toronto, Canada. https://indico.cern.ch/event/688643/contributions/3427856/
...more to come.