/sapphire

SAPPHiRE, a framework for HiSPARC

Primary LanguagePythonGNU General Public License v3.0GPL-3.0

SAPPHiRE — A Framework for HiSPARC

Introduction

image

image

image

SAPPHiRE is a Simulation and Analysis Program Package for HiSPARC Research and Education. It was created in the process of completing the PhD research of David Fokkema. The history of this repository contains the complete simulation, analysis and plot generation code that formed the basis for David's thesis. Arne de Laat took over development of SAPPHiRE while working on his own PhD research.

This repository is created with a sole purpose in mind: to enable HiSPARC students, teachers and researchers to easily gain access to the data and perform common simulation and analysis tasks. Historically, starting work on the data, or extending an existing analysis code, has involved elaborate installation instructions, heavy customizations to the software, countless hours going over opaque parts of code and a general feeling of anguish and despair. SAPPHiRE's ultimate goal: no more of that.

Installation

Required: Python. pip will take care of dependencies, but installing numpy, scipy and pytables from a python distribution is preferred. We use miniconda, which includes the conda package manager.

First, install conda and optionally create a virtualenv:

$ conda create --name hisparc python numpy scipy pytables
$ source activate hisparc

or alternatively just install the dependencies:

$ conda install numpy scipy pytables sphinx

Then, using pip:

$ pip install hisparc-sapphire

This should install sapphire with all requirements. More extensive installation instructions are available in the documentation in the doc/ directory. You can compile them using Sphinx, or you can follow this link: https://docs.hisparc.nl/sapphire/.

To check if it worked start Python and load the package:

You're done!

Development

Install python (preferably using conda) as described above but clone the sapphire repo instead of installing using pip:

$ git clone https://github.com/HiSPARC/sapphire.git
$ cd sapphire
$ pip install -e .[dev]

Version release

Important: First check if the last commit passes the tests on GitHub Actions!

To release a new version modify the version number in setup.py. Then create a commit for the new release with a title like 'Bump version to vX.Y.Z' and a message that contains a summary of the most important changes since the last release. Then tag the commit and push it to GitHub:

$ git tag vX.Y.Z
$ git push --tags

Then upload the new version to PyPI (this requires the build, wheel and twine packages):

$ python -m build
$ twine upload dist/hisparc-sapphire-X.Y.Z.tar.gz
$ twine upload dist/hisparc_sapphire-X.Y.Z-py3-none-any.whl

The latest version is then available from PyPI.