Skip to main content

Command and Real-time Acquisition in Parallelized Python

Project description

Command and Real-time Acquisition in Parallelized PYthon (CRAPPY)

Downloads Documentation Status PyPi version Python version

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.10 to 3.14, 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 (2.0.0 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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

crappy-2.0.8.tar.gz (700.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

crappy-2.0.8-py3-none-any.whl (828.8 kB view details)

Uploaded Python 3

File details

Details for the file crappy-2.0.8.tar.gz.

File metadata

  • Download URL: crappy-2.0.8.tar.gz
  • Upload date:
  • Size: 700.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.12

File hashes

Hashes for crappy-2.0.8.tar.gz
Algorithm Hash digest
SHA256 699a3a06b04b75dfe03c9197228772c032f862016bc6621c8a02ea3e8d62bca3
MD5 5489f2bff90800baff46187e02329dfa
BLAKE2b-256 d250f8b3df003c5f4196a12efbeafe902f06ed0ea1b9ac21d4350c677e502ff5

See more details on using hashes here.

File details

Details for the file crappy-2.0.8-py3-none-any.whl.

File metadata

  • Download URL: crappy-2.0.8-py3-none-any.whl
  • Upload date:
  • Size: 828.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.12

File hashes

Hashes for crappy-2.0.8-py3-none-any.whl
Algorithm Hash digest
SHA256 0e7c9148a4c5eb8035c7e306adc12930b4021d1c01730db6b671188526d42baa
MD5 bf9fe448e85850b0331bad2dafbf9ac8
BLAKE2b-256 80a71977b49beeaecedbf511d128684c95054ba97f0a797da00fa2c04257ee85

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page