Skip to content

SAIL-Labs/pyrpl

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2,219 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

PyRPL GitHub Actions CI code coverage Python versions Documentation Status join chat on gitter License GitHub downloads GitHub release

PyRPL (Python RedPitaya Lockbox) turns your RedPitaya into a powerful DSP device, especially suitable as a digital lockbox and measurement device in quantum optics experiments. A detailed scientific article describing PyRPL's architecture and functions can be found here:

Python Red Pitaya Lockbox (PyRPL): An open source software package for digital feedback control in quantum optics experiments

Website

The official PyRPL website address is http://pyrpl.readthedocs.io/.

Installation

The easiest and fastest way to get PyRPL is to download and execute the precompiled executable for windows, mac and linux. This option requires no extra programs to be installed on the computer.

If instead you would like to use and/or modify the source code, make sure you have an installation of Python (3.7 to 3.13). The easiest way to install the PyRPL python module cleanly is to run

pip install "git+https://github.com/pyrpl-fpga/pyrpl.git#egg=pyrpl[qt-pyqt5]"

This will pull the most recent code from Github and install the needed module. It is recommended to use a new environment. DO NOT USE pip install pyrpl ! The code hosted on pypi is outdated.

If you are new to Python or unexperienced with fighting installation issues, it is recommended to install the Anaconda Python distribution, which allows to install all PyRPL dependencies via

conda install numpy paramiko nose pip pyqt qtpy pyqtgraph pyyaml scp qasync

Check this documentation section for hints if you are unable to execute conda in a terminal. Alternatively, if you prefer creating a virtual environment for pyrpl, do so with the following two commands

conda create -y -n pyrpl-env numpy paramiko nose pip pyqt qtpy pyqtgraph pyyaml scp qasync
conda activate pyrpl-env

Next, clone (if you have a git client installed - recommended option) the pyrpl repository to your computer with

git clone https://github.com/pyrpl-fpga/pyrpl.git

or download and extract (if you do not want to install git on your computer) the repository.

If you are using pip, you can just navigate to the pyrpl directory and run

pip install -e .[qt-pyqt5]

if you want an editable installation of pyrpl or

pip install .[qt-pyqt5]

for a regular installation (if you have no instention of modifying the code). I recommend using pip as conda tends to become very slow at solving environments. Note that pyrpl requires a Qt binding but it is compatible with PyQt5, PyQt6, PySide2 and PySide6 so you can also run :

pip install -e .[qt-pyqt6]
pip install -e .[qt-pyside2]  
pip install -e .[qt-pyside6]

If you want to use conda, you can run :

conda create -y -n pyrpl-env numpy paramiko pip pyqt qtpy pyqtgraph pyyaml scp qasync
conda activate pyrpl-env

This will create an new conda environment named "pyrpl-env" and install all the needed modules inside.

You can also use the environment config file "environment_pyrpl.yml"

conda env create -f environment_pyrpl.yml
conda activate pyrpl-env

Installation with Optional Dependencies

For Testing

pip install -e .[test]

For IPython/Jupyter Support

pip install -e .[ipython]

For Development (all dependencies)

pip install -e .[dev]

Quick start

First, hook up your Red Pitaya / STEMlab to a LAN accessible from your computer (follow the instructions for this on redpitya.com and make sure you can access your Red Pitaya with a web browser by typing its ip-address / hostname into the address bar). In a command line terminal, type

python -m pyrpl your_configuration_name

A GUI should open, let you configure the RedPitaya device you would like to use, and you can start playing around with pyrpl. Different strings for 'your_configuration_name' create different configurations that will be automatically remembered by PyRPL, for example if you have several different redpitayas. Different RedPitayas with different configuration names can be run simultaneously in separate terminals. A GUI should open, let you configure the RedPitaya device you would like to use, and you can start playing around with pyrpl. Different strings for 'your_configuration_name' create different configurations that will be automatically remembered by PyRPL, for example if you have several different redpitayas. Different RedPitayas with different configuration names can be run simultaneously in separate terminals.

Issues

We collect a list of common problems on the documentation website. If you do not find your problem listed there, please report all problems or wishes as new issues on this page, so we can fix it and improve the future user experience.

Unit test

If you want to check whether PyRPL works correctly on your machine, navigate with a command line terminal into the pyrpl root directory and type the following commands (by substituting the ip-address / hostname of your Red Pitaya, of course)

pip install pytest pytest-cov matplotlib nbconvert
set REDPITAYA_HOSTNAME=your_redpitaya_ip_address
pytest

All tests should take about 3 minutes and finish without failures or errors. If there are errors, please report the console output as an issue (see the section "Issues" below for detailed explanations).

Next steps / documentation

The full html documentation is hosted at http://pyrpl-fpga.github.io/pyrpl/. Alternatively, you can download a .pdf version at https://media.readthedocs.org/pdf/pyrpl/latest/pyrpl.pdf. We are still in the process of creating an fully up-to-date version of the documentation of the current code. If the current documentation is wrong or insufficient, please post an issue and we will prioritize documenting the part of code you need.

Updates

Since PyRPL is continuously improved, you should install upgrades if you expect bugfixes. If you have cloned the GitHub repository (recommended for bleeding-edge updates), navigate into the pyrpl root directory on your local harddisk computer and type

git pull

FPGA bitfile generation (only for developers)

In case you would like to modify the logic running on the FPGA, you should make sure that you are able to generate a working bitfile on your machine. In short, to do so, you must install Vivado 2024.2 [(64-bit windows](windows web-installer](https://www.xilinx.com/member/forms/download/xef.html?filename=Xilinx_Vivado_SDK_2024.2_1118_2_Win64.exe&akdm=1) or Linux) together with a working license. Next, with a terminal in the pyrpl root directory, type

cd pyrpl/fpga
make

Compilation should take between 10 and 30 minutes, depending on your machine. If there are no errors during compilation, the new bitfile will be in the (pyrpl/fpga/out) repository. If you replace the (pyrpl/fpga/red_pitaya.bin), it will be automatically used at the next restart of PyRPL. The best way to getting started is to skim through the very short Makefile in the fpga directory and to continue by reading the files mentioned in the makefile and the refences therein. All verilog source code is located in the subdirectory pyrpl/fpga/rtl/.

License

Please read our license file LICENSE for more information.

About

pyrpl turns your RedPitaya into a powerful DSP device, especially suitable as a lockbox in quantum optics experiments.

Resources

License

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors

Languages

  • HTML 65.6%
  • Python 23.3%
  • Verilog 8.0%
  • Tcl 1.8%
  • Jupyter Notebook 0.3%
  • C 0.2%
  • Other 0.8%