Skip to main content

moteus brushless controller library and tools

Project description

Python bindings for moteus brushless controller

These bindings permit communication and control of moteus brushless controllers.

To use

pip3 install moteus  # or 'moteus-pi3hat' on a pi3hat

See a simple example of the API in use at: simple.py

Theory

Interactions with a controller are mediated through the moteus.Controller object. When constructed with the constructor argument transport=None (the default) it attempts to find some suitable link on your host system, typically the first fdcanusb or socketcan bus it locates.

Single controller imperative operation can be conducted by using await Controller.set_stop(), await Controller.set_position(), and await Controller.query().

Bus-optimized usage

To optimize bus usage, it is possible to command multiple controllers simultaneously. In this mode, a "transport" must be manually constructed.

import asyncio
import math
import moteus

async def main():
    transport = moteus.Fdcanusb()
    c1 = moteus.Controller(id = 1)
    c2 = moteus.Controller(id = 2)

    while True:
        print(await transport.cycle([
          c1.make_position(position=math.nan, query=True),
          c2.make_position(position=math.nan, query=True),
        ]))

asyncio.run(main())

All of the "set_" methods have a "make_" variant which is suitable to pass to a Transport's cycle method.

This mechanism only improves performance for non-fdcanusb links, such as a pi3hat.

An example use of this mechanism can be found at: pi3hat_multiservo.py

Position mode commands

Controller.set_position and Controller.make_position have arguments which exactly mirror the fields documented in docs/reference.md. Omitting them (or specifying None), results in them being omitted from the resulting register based command.

  • position
  • velocity
  • feedforward_torque
  • kp_scale
  • maximum_torque
  • stop_position
  • watchdog_timeout

Finally, the query argument controls whether information is queried from the controller or not.

Controlling resolution

The resolution of commands, and of returned query data, is controlled by optional constructor arguments to Controller. By default, the commands are all F32, and the query requests a subset of fields as INT16. Here is an example of setting those.

pr = moteus.PositionResolution()
pr.position = moteus.INT16
pr.velocity = moteus.INT16
pr.kp_scale = moteus.F32
pr.kd_scale = moteus.F32

qr = moteus.QueryResolution()
qr.mode = moteus.INT8
qr.position = moteus.F32
qr.velocity = moteus.F32
qr.torque = moteus.F32

c = moteus.Controller(position_resolution=pr, query_resolution=qr)

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

moteus-1.0.0rc4.tar.gz (92.3 kB view details)

Uploaded Source

Built Distribution

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

moteus-1.0.0rc4-py3-none-any.whl (107.4 kB view details)

Uploaded Python 3

File details

Details for the file moteus-1.0.0rc4.tar.gz.

File metadata

  • Download URL: moteus-1.0.0rc4.tar.gz
  • Upload date:
  • Size: 92.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for moteus-1.0.0rc4.tar.gz
Algorithm Hash digest
SHA256 5cad523b49e7497803cb0377431d11bb9963992f5233eba41aa45fded61108a4
MD5 f4513385dd9115f5775ea180debd0d6b
BLAKE2b-256 f1162c1278ed608c8eb791e8f57a747a3a282ed31962e197d5c398a6ff0ed52e

See more details on using hashes here.

Provenance

The following attestation bundles were made for moteus-1.0.0rc4.tar.gz:

Publisher: publish-python-pypi.yml on mjbots/moteus

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

File details

Details for the file moteus-1.0.0rc4-py3-none-any.whl.

File metadata

  • Download URL: moteus-1.0.0rc4-py3-none-any.whl
  • Upload date:
  • Size: 107.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for moteus-1.0.0rc4-py3-none-any.whl
Algorithm Hash digest
SHA256 1bb3454900a4fde95b8ce0692dc69fb0763ef23beabc2eac54029c385284427e
MD5 ba249918bcd94c89a53c7c3935101712
BLAKE2b-256 d2da796296ef1ff4007fe0addc740223b5b7bb289df7f452594025682ec6dab4

See more details on using hashes here.

Provenance

The following attestation bundles were made for moteus-1.0.0rc4-py3-none-any.whl:

Publisher: publish-python-pypi.yml on mjbots/moteus

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