Red Pitaya is a low cost multipurpose circuit board with high-speed dual-channel ADC/DAC, an FPGA, an ARM linux system with USB and ethernet. The beta version of the Red Pitaya image has a built in Streaming Server (instructions). The Streaming Server is capable of acquiring data at rates of up to 125 MSPS and bit depths of 10,14 or 16 bits depending on the hardware, and streaming it to a client over ethernet. Red Pitaya provides a sample client called rpsa_client.exe, but this saves data to a wav file or a tpms file.
This repo provides utilities that can:
- Remote start the RP streaming manager and set the ADC options (so you don't have to use the web interface to the Red Pitaya)
- Receive and unpack the data
- (alternate) Receive, unpack and display the data in a GUI
As of 6/18/2020, I'm getting a maximum of ~40 MB/s data transfer rate using two channels at 14 bit, acquired by direct ethernet connection. This will allow me to decode video streams, or other high data rate applications.
The rpsa_client.exe was insufficient for data streaming.
In theory, this should work on most operating systems, however it was tested on Windows 10 using Python 3.7
Need to update
pip install ...
copy files and run
to start the Streaming Server either: Edit the ip address in the file: start_streamserver_websocket.py. You can edit some of the streaming options in the file to set the data rate, number of channels acquired, and bit depth acquired
python start_streamserver_websocket.py ###Note: If this program stops running, the websocket will be closed, and the streaming server will stop
(option 1) to start streaming data: Edit the ip address in the file: rp_stream_threaded.py
python rp_stream_threaded.py
(option 2) to start streaming data in a gui: Edit the ip address in the file: QT_pyqtgraph_stream2.1.py
python QT_pyqtgraph_stream2.1.py
rp_stream_threaded is a package that has two classes that implement threaded data receiving and unpacking. In the main section is a sample implementation of its use. Running the program from the command line, receives the data stream and prints diagnostic messsages such as the data rate, and the packets 'lost' (a parameter included by the streaming server code). I flagged the section where the data is available('DATA AVAILABLE HERE!!!'). If this code stops running, check that the streaming server hasn't restarted itself.
QT_pyqtgraph_stream2.1.py calls rp_steam_threaded and displays the streaming data in a pyqtgraph. There are some options for the data display. The gui was created in QT designer and can be edited. If this code stops running, check that the streaming server hasn't restarted itself.
OMG so much (throws up hands). Feedback welcome.
Alan Lee LongWave Photonics