Skip to main content

A python library for RCB4

Project description

rcb4

PyPI Build Status

Prerequisite

Linux users have to install udev <https://en.wikipedia.org/wiki/Udev>_ rules for rcb4 supported boards/devices. The latest version of the rules may be found at https://github.com/iory/rcb4/tree/master/rcb4/assets/system/99-rcb4-udev.rules

This file must be placed at /etc/udev/rules.d/99-rcb4-udev.rules (preferred location) or /lib/udev/rules.d/99-rcb4-udev.rules (required on some broken systems).

Please open the system Terminal and type

curl -fsSL https://raw.githubusercontent.com/iory/rcb4/master/rcb4/assets/system/99-rcb4-udev.rules | sudo tee /etc/udev/rules.d/99-rcb4-udev.rules
sudo udevadm control --reload-rules
sudo udevadm trigger

Or you can manually download and copy the file to a destination folder

sudo cp 99-rcb4-udev.rules /etc/udev/rules.d/99-rcb4-udev.rules
sudo udevadm control --reload-rules
sudo udevadm trigger

Ubuntu/Debian users may need to add own “username” to the “dialout” group if they are not “root”, doing this issuing

sudo usermod -a -G dialout $USER
sudo usermod -a -G plugdev $USER

Install

pip install rcb4

Write firmware

Connect st-link and run the following command.

rcb4-write-firmware

Change Servo ID

You can use ics-manager command to change servo id.

ics-manager

Contributing

Automatic Formatting

This repository uses ruff for both linting and formatting which is configured in pyproject.toml, you can run with:

pip install ruff
ruff format
ruff check --fix .

Clang-Format

To install clang-format, you can use the following command:

pip install clang-format

Once installed, you can format your files using a .clang-format configuration file. To format a file, run:

clang-format -i <filename>

Replace <filename> with the name of the file you want to format. The -i option tells clang-format to edit the file in place.

For JSK Users

Worm Gear Module Calibration Tool

armh7-tools provides a comprehensive solution for calibrating and managing worm gear modules connected via the ARMH7Interface. It facilitates the calibration of worm gears, reading of calibrated sensor data, and real-time display of sensor and worm gear values. Designed for flexibility, it supports operations like calibration data update and in-place modification of YAML configuration files.

YAML Configuration Format

The calibration tool requires an input YAML file for worm gear modules configuration. This file contains a list of worm gears with their associated parameters: worm_id, servo_id, sensor_id, and initial magnetic encoder value magenc_init. Each worm gear is represented by a line in the YAML file with its parameters encapsulated in curly braces and prefixed by a dash, indicating a list item in YAML syntax.

 - {worm_id: 0, servo_id: 0, sensor_id: 38, magenc_init: 6502}
 - {worm_id: 1, servo_id: 2, sensor_id: 40, magenc_init: 3039}
 - {worm_id: 3, servo_id: 6, sensor_id: 44, magenc_init: 9502}

Reading Worm Gear Modules's calibration data

armh7-tools read-calib [--device DEVICE] output_file_path

--device, -d: Specify the device port. (Default: None) output_file_path: Path to output the YAML file with calibration data.

Example
armh7-tools read-calib ./worm_calib.yaml

Calibrate Worm Gear Modules

armh7-tools calibrate [--device DEVICE] file_path [--inplace] [--update] [--output OUTPUT]

--device, -d: Specify the device port. (Default: None) file_path: Path to the input YAML file containing worm gear configurations. --inplace, -i: Overwrite the input YAML file with calibration results. (Optional) --update, -u: Ignore and overwrite the current magenc_init values in the input YAML. (Optional) --output, -o: Specify a path to save the calibrated data if not overwriting in-place. (Optional)

Example

When the update option is specified, the current posture of the robot will be modified, and upon pressing the Enter key, the angle at that moment will be set as the zero point. Consequently, the magenc_init value will be updated and written to the board,

armh7-tools calibrate ./worm_calib.yaml --update

Print Sensor Values

This command displays real-time sensor values in a table format.

armh7-tools print-sensor
+------|----------|--------------|--------------|--------------|--------------|----------|----------|----------|----------+
|   ID |   Magenc |   Proximity1 |   Proximity2 |   Proximity3 |   Proximity4 |   Force1 |   Force2 |   Force3 |   Force4 |
|------|----------|--------------|--------------|--------------|--------------|----------|----------|----------|----------|
|   19 |     7365 |            0 |            0 |            0 |            0 |     1240 |     1167 |     1083 |     1037 |
|   20 |     3042 |            0 |            0 |            0 |            0 |     1209 |     1106 |     1075 |     1025 |
|   21 |    13800 |            0 |            0 |            0 |            0 |     1230 |     1106 |     1064 |     1003 |
|   22 |     9512 |            0 |            0 |            0 |            0 |     1222 |     1144 |     1123 |     1085 |
|   23 |    14182 |            0 |            0 |            0 |            0 |     1238 |     1179 |     1083 |     1040 |
+------|----------|--------------|--------------|--------------|--------------|----------|----------|----------|----------+

Print Worm Values

Displays real-time worm gear values in a table format.

armh7-tools print-worm
+------------|-------------|---------------|------------------|-----------------+
|   servo_id |   sensor_id |   magenc_init |   magenc_present |   present_angle |
|------------|-------------|---------------|------------------|-----------------|
|          0 |          38 |          6502 |             7368 |      -19.0283   |
|          2 |          40 |          3039 |             3039 |       -0        |
|          6 |          44 |          9502 |             9513 |       -0.241699 |
|          8 |          46 |          9783 |            14170 |      -96.394    |
+------------|-------------|---------------|------------------|-----------------+

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

rcb4-0.0.9.tar.gz (44.6 kB view details)

Uploaded Source

Built Distribution

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

rcb4-0.0.9-py3-none-any.whl (44.5 kB view details)

Uploaded Python 3

File details

Details for the file rcb4-0.0.9.tar.gz.

File metadata

  • Download URL: rcb4-0.0.9.tar.gz
  • Upload date:
  • Size: 44.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.21

File hashes

Hashes for rcb4-0.0.9.tar.gz
Algorithm Hash digest
SHA256 c19ad37e529c211df1a6979a7a30db6906b9f82d35377f0351d2c07c0ff5276b
MD5 35bee122c789890d81e008700bbfefb6
BLAKE2b-256 c41e0485d0dcd20c157125777a2ab8e4101035a3b9ac364056d7dd03934cfc4d

See more details on using hashes here.

File details

Details for the file rcb4-0.0.9-py3-none-any.whl.

File metadata

  • Download URL: rcb4-0.0.9-py3-none-any.whl
  • Upload date:
  • Size: 44.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.9.21

File hashes

Hashes for rcb4-0.0.9-py3-none-any.whl
Algorithm Hash digest
SHA256 cb57f407fb8a3b942de68ed5ff4f4c9044f0ec594ce12dc80d16d48377efa985
MD5 f0fb5747e32d3c7a5066cfeb69af8293
BLAKE2b-256 c577b7034e83e0a833341740f5aea97cdd71c06694ef769e7d7fbe351832848f

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