#raspberry-pi #framework #iot

yanked stepper_lib

A library to control motors, components and IOT-devices with controllers like the raspberry pi

4 releases

0.11.7 Jun 6, 2023
0.11.6 Jun 1, 2023
0.11.5 May 22, 2023
0.11.3 Apr 20, 2023
0.10.6 Apr 15, 2023

#178 in #raspberry-pi

Download history 38/week @ 2024-07-24 10/week @ 2024-07-31 6/week @ 2024-09-25 15/week @ 2024-10-02

104 downloads per month
Used in sybot_lib

Custom license

785KB
4K SLoC

stepper_lib

Rust Crates.io version stepper_lib: rustc 1.68+

Note

Many aspects of the library (for example the documentation) are not fully finished yet! (Though I try to update it as frequent as possible)

A library for all types of components used in robots, including controlls for stepper motors, servo motors and more complex assemblies using said motors. Currently all implementations are made for the raspberry pi, though new implementations for more controllers are currently being made.

Basis library for the sybot_lib

Goal

  • Create an all-in-one library to control motors, read sensors and do basic calculations in rust.
  • Keep it as easy to use as possible
  • Specialize the library for hobbyists and tinkerers
  • Offer options for static aswell as dynamic typings

In Action

Let us assume we want to control a simple stepper motor (in this example a 17HE15_1504_S) with a PWM controller connected to the BCM pins 27 and 19.

Click to show Cargo.toml
# ...

[dependencies]
# Include the library configured for the raspberry pi
stepper_lib = { version = "0.11.6", features = [ "rasp" ] } 

# ...

use core::f32::consts::PI;

// Include the library
use stepper_lib::prelude::*;

// Pin declerations (BCM on raspberry pi)
const PIN_DIR : u8 = 27;
const PIN_STEP : u8 = 19;

// Define distance and max speed
const DELTA : Delta = Delta(2.0 * PI);
const OMEGA : Omega = Omega(10.0);

fn main() -> Result<(), stepper_lib::Error> {
    // Create the controls for a stepper motor
    let mut ctrl = StepperCtrl::new(StepperConst::MOT_17HE15_1504S, PIN_DIR, PIN_STEP);
    // Link the component to a system
    ctrl.write_link(LinkedData { 
        u: 12.0,    // System voltage in volts
        s_f: 1.5    // System safety factor, should be at least 1.0
    }); 
    ctrl.setup()?;

    // Apply some loads
    ctrl.apply_inertia(Inertia(0.2));
    ctrl.apply_force(Force(0.10));

    ctrl.set_omega_max(OMEGA);

    println!("Staring to move");
    ctrl.drive_rel(DELTA, 1.0)?;      // Move the motor
    println!("Distance {}rad with max speed {:?}rad/s done", DELTA, OMEGA);

    Ok(())
}

(Source: stepper_motor)

Features

  • Motors
  • Components
  • Tools
    • Tongs
    • Axial joint
  • Calculation
    • Complex acceleration curves
    • Overloads
    • Forces
    • Inertias
  • Measurements
    • Simple switch
    • Rotary resolver
    • Trait for custom measurements
  • Extendable
  • Unit system
  • Minimal
    • Fully supports no_std environment
    • Available for basic embedded systems
  • Platforms
    • Raspberry Pi and similar
    • Arduino

Issues and requests

If you encounter any issues or if you have any request for new features, feel free to create an issue at the GitHub repo.

Dependencies

~8–16MB
~202K SLoC