Skip to main content

Python library to communicate with STM32 for loading FPGA and camera sensors (OpenMOTION).

Project description

Overview

This repository contains the code used to interface with an OpenMotion sensor module and OpenMotion Console. The sensor module runs the code contained in the motion-sensor-fw repository on an STM32H7 processor. The programs here communicates with the modules over a USB serial connection.

A library called omotion is imported in many of the python scripts listed here to aid communication with the Sensor Module.

Getting started

  1. Install requirements.txt (pip install -r requirements.txt)
  2. Install libusb for your system requires libusb to be installed, for windows install the dll to c:\windows\system32, download the correct dll from github libusb Releases
  3. Plug in your aggregator module. Please wait 10 seconds for it to boot up before continuing.
  4. Run python multicam_setup.py - this will flash each camera sensor one by one. Alternatively, you may flash just a single camera sensor by usising python flash_camera.py 1 - this will flash just camera 1
  5. Run python monitor.py 1 - this will flash the camera with a few parameters (test modes, exposure times, gain settings, etc), start the camera streaming, start the frame sync generating, and then put the cameras into streaming mode. It will then recieve the histogram data for the defined number of seconds then close down. Modify the parameters at the top of this file if you want to adjust the gain, exposure time, etc. Change the number in the command line arguments to change the camera you'd like to interrogate. Cameras are numbered 1-8 and correspond to J1-J8 on the aggregator board.

from repo root rebuild and install

python -m pip install --upgrade build twine python -m build # creates wheel + sdist under dist/ python -m pip install --force-reinstall dist/openmotion_pylib-1.3.3-py3-none-any.whl

quick runtime check (on Windows box with your device bound to WinUSB/libusbK)

python -c "import usb, omotion.usb_backend as ub; print(ub.get_libusb1_backend())"

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

openmotion_pylib-1.4.0.tar.gz (28.3 MB view details)

Uploaded Source

Built Distribution

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

openmotion_pylib-1.4.0-py3-none-any.whl (6.8 MB view details)

Uploaded Python 3

File details

Details for the file openmotion_pylib-1.4.0.tar.gz.

File metadata

  • Download URL: openmotion_pylib-1.4.0.tar.gz
  • Upload date:
  • Size: 28.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for openmotion_pylib-1.4.0.tar.gz
Algorithm Hash digest
SHA256 dbd2af76e6a2a9859ef35e6d14ce3285dc54564a7c83523d06033c28e38129e4
MD5 3bfbd16aa2ec72b2ddfe9720430e546f
BLAKE2b-256 9db90974231fb13764cc6a75757371c0e0923b02de7deedc105a75ca5769a12f

See more details on using hashes here.

Provenance

The following attestation bundles were made for openmotion_pylib-1.4.0.tar.gz:

Publisher: publish-pypi.yml on OpenwaterHealth/OpenMOTION-Pylib

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file openmotion_pylib-1.4.0-py3-none-any.whl.

File metadata

File hashes

Hashes for openmotion_pylib-1.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7f036e47447bc56f509859e41e20c1f8d9c8120f8b0e3901edea6119c0f4085c
MD5 0d28651dc3c5c478f0cc7b70fd896b60
BLAKE2b-256 08d989fe192e8e486bf2d9e65b9cd3a0aa29f02eba66028d06661498af14f659

See more details on using hashes here.

Provenance

The following attestation bundles were made for openmotion_pylib-1.4.0-py3-none-any.whl:

Publisher: publish-pypi.yml on OpenwaterHealth/OpenMOTION-Pylib

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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