Command and Real-time Acquisition in Parallelized Python
Project description
Command and Real-time Acquisition in Parallelized PYthon (CRAPPY)
CRAPPY aims to provide a free and open-source software canvas for driving experimental setups in a versatile and accessible way.
Presentation
Setups in experimental research tend to get increasingly complex, and require to drive a variety of actuators, sensors, and cameras from various suppliers. However, as researchers are one step ahead of industrials, the commercially available testing solutions are not always well-suited to their objectives. Developing a custom software interface is also not always an option, as the synchronization of the devices and the optimization of the computer resources can prove challenging even to experienced developers.
The purpose of CRAPPY is to provide a framework for driving experimental setups, in which even the most complex designs can be controlled in usually less than a hundred lines of code. CRAPPY is:
- A free and open source Python module
- Written in pure Python, to make it easily understandable and editable by a large audience
- Highly modular and versatile, and can adapt to almost any setup
- Distributed with a wide collection of ready-to-run examples
- Heavily optimized, to make the most of your computer's resources
- Distributed with a collection of powerful tools for performing real-time data and image processing
Crappy is developed at the LaMCube, a mechanical research laboratory based in Lille, France, where it is used mainly for materials testing.
Requirements
CRAPPY can run with Python 3.7 to 3.10, and has been tested on Windows, Linux, Raspberry Pi and macOS. It can probably run on other operating systems supporting the required Python versions.
CRAPPY has only one requirement: Numpy (1.21 or higher). In addition, other modules can be necessary depending on which features you want to use. The main ones are Matplotlib, openCV, pyserial and Pillow.
Installation
CRAPPY is distributed on PyPI, and can be installed on the supported operating systems simply by running the following command in a terminal:
python -m pip install crappy
You'll find more details in the dedicated installation section of the documentation, as well as alternative installation methods.
Citing Crappy
If Crappy has been of help in your research, please reference it in your academic publications by citing one or both of the following articles:
- Couty V., Witz J-F., Martel C. et al., Command and Real-Time Acquisition in Parallelized Python, a Python module for experimental setups, SoftwareX 16, 2021, DOI: 10.1016/j.softx.2021.100848. (link to Couty et al.)
- Weisrock A., Couty V., Witz J-F. et al., CRAPPY goes embedded: Including low-cost hardware in experimental setups, SoftwareX 22, 2023, DOI: 10.1016/j.softx.2023.101348. (link to Weisrock et al.)
Documentation
The latest versions of the documentation can be accessed on our ReadTheDocs page. It contains a description of Crappy's features, tutorials, and other useful information.
License
GNU GPLv2 © 2015, Laboratoire Mécanique de Lille & contributors
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file crappy-2.0.6.tar.gz
.
File metadata
- Download URL: crappy-2.0.6.tar.gz
- Upload date:
- Size: 700.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1c7e26caa0bfb801cc4bbc63f6af603cfe4eea3bad089a3441582a02c50deb8a |
|
MD5 | 4a4dca4c014d6549df87cf590325e2aa |
|
BLAKE2b-256 | 7db7a7be93106fae4b7a9c42f36c2a0a4a5378bbb8a89aa4741551fa61494d9f |
File details
Details for the file crappy-2.0.6-py3-none-any.whl
.
File metadata
- Download URL: crappy-2.0.6-py3-none-any.whl
- Upload date:
- Size: 824.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.12
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9b6848b38baf3c0fb876bb2a1286666bc439e78f0261eea2e5fc8e4c66693fac |
|
MD5 | 23edd0069fe4dcbd9b700a01c22da3e0 |
|
BLAKE2b-256 | 4eb0b7f4c44c6fcb886bda4b6b2e580e19a5dc8700c85b16344b82e516b77881 |