#trajectory #curve #motion

s_curve

Package to generate S-Curve trajectories for robotics and similar applications

8 releases

0.1.7 May 2, 2023
0.1.6 May 1, 2021
0.1.5 Dec 10, 2020
0.1.4 Oct 12, 2020

#45 in Robotics


Used in cartesian_trajectories

MIT/Apache

41KB
996 lines

crates.io GitHub Workflow Status crates.io crates.io docs.rs codecov

A library to compute S-Curve trajectories. It can be used to generate motion profiles for robotics.

What is an S-Curve?

An S-Curve is a trajectory which is constrained to maximum jerk, acceleration and velocity. An S-Curve consists of 7 phases:

  • constant maximum jerk until the desired acceleration is reached
  • constant maximum acceleration phase
  • constant minimum jerk until the desired velocity is reached with an acceleration of zero
  • constant velocity phase
  • constant minimum jerk until the minimum acceleration is reached
  • constant minimum acceleration phase
  • constant maximum jerk until the acceleration is zero and the desired position and end velocity is reached

In the picture below you can see an S-Curve Profile which goes from Position 0 to position 10 within 5.5 seconds with a start and end velocity of 0 , a maximum jerk of 3, a maximum acceleration of 2 and a maximum velocity of 3. image

Example

use s_curve::*;
let constraints = SCurveConstraints {
            max_jerk: 3.,
            max_acceleration: 2.0,
            max_velocity: 3.};
let  start_conditions = SCurveStartConditions {
    q0: 0., // start position
    q1: 10., // end position
    v0: 0., // start velocity
    v1: 0. // end velocity
};
let input  =  SCurveInput{constraints, start_conditions};
let (params,s_curve) = s_curve_generator( & input,Derivative::Velocity);
for i in 0..101 {
    println!("{}", s_curve(i as f64 * params.time_intervals.total_duration() / 100.));
}

License

Copyright (c) 2020 Marco Boneberger Licensed under either of Apache License, Version 2.0 or MIT license at your option.

No runtime deps