Skip to content

Commit

Permalink
Merge pull request #120 from richievos/master
Browse files Browse the repository at this point in the history
Use safer & faster min/max functions
  • Loading branch information
laurb9 authored Apr 4, 2023
2 parents be6a215 + 0a1fe7d commit a0bb844
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 4 deletions.
2 changes: 1 addition & 1 deletion library.properties
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
name=StepperDriver
version=1.4.0
version=1.4.1
author=Laurentiu Badea
maintainer=Laurentiu Badea
sentence=A4988, DRV8825 and generic two-pin stepper motor driver library.
Expand Down
3 changes: 3 additions & 0 deletions platformio.ini
Original file line number Diff line number Diff line change
Expand Up @@ -44,3 +44,6 @@ board = teensylc
[env:uno]
board = uno
platform = atmelavr

[env:native]
platform = native
23 changes: 20 additions & 3 deletions src/BasicStepperDriver.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,23 @@
*/
#include "BasicStepperDriver.h"


/*
* Min/Max functions which avoid evaluating the arguments multiple times.
* See also https://github.com/arduino/Arduino/issues/2069
*/
template<typename T>
constexpr const T& stepperMin(const T& a, const T& b)
{
return b < a ? b : a;
}

template<typename T>
constexpr const T& stepperMax(const T& a, const T& b)
{
return a < b ? b : a;
}

/*
* Basic connection: only DIR, STEP are connected.
* Microstepping controls should be hardwired.
Expand Down Expand Up @@ -138,7 +155,7 @@ void BasicStepperDriver::startMove(long steps, long time){
float a2 = 1.0 / profile.accel + 1.0 / profile.decel;
float sqrt_candidate = t*t - 2 * a2 * d; // in √b^2-4ac
if (sqrt_candidate >= 0){
speed = min(speed, (t - (float)sqrt(sqrt_candidate)) / a2);
speed = stepperMin(speed, (t - (float)sqrt(sqrt_candidate)) / a2);
};
}
// how many microsteps from 0 to target speed
Expand Down Expand Up @@ -177,7 +194,7 @@ void BasicStepperDriver::alterMove(long steps){
if (steps >= 0){
steps_remaining += steps;
} else {
steps_remaining = max(steps_to_brake, steps_remaining+steps);
steps_remaining = stepperMax(steps_to_brake, steps_remaining+steps);
};
break;
case DECELERATING:
Expand Down Expand Up @@ -228,7 +245,7 @@ long BasicStepperDriver::getTimeForMove(long steps){
startMove(steps);
cruise_steps = steps_remaining - steps_to_cruise - steps_to_brake;
speed = rpm * motor_steps / 60; // full steps/s
t = (cruise_steps / (microsteps * speed)) +
t = (cruise_steps / (microsteps * speed)) +
sqrt(2.0 * steps_to_cruise / profile.accel / microsteps) +
sqrt(2.0 * steps_to_brake / profile.decel / microsteps);
t *= (1e+6); // seconds -> micros
Expand Down

0 comments on commit a0bb844

Please sign in to comment.