stop-smooth

jdavis-nodes/fastaccelstepper/stop-smooth

Stop the running stepper with normal deceleration.
stop-smooth
@/stop-smooth
Stop the running stepper with normal deceleration.
DEV@/fastaccelstepper-device
DOpulse
stop-smooth
DEV
DO
DEV'
ACK
ACKpulse
DEV'@/fastaccelstepper-device
To use the node in your project you should have the jdavis-nodes/fastaccelstepper library installed. Use the “File → Add Library” menu item in XOD IDE if you don’t have it yet. See Using libraries for more info.

C++ implementation

#pragma XOD evaluate_on_pin disable
#pragma XOD evaluate_on_pin enable input_DO

node {
    void evaluate(Context ctx) {
        // Get the stepper instance
        auto stepper = getValue<input_DEV>(ctx);

        if (isSettingUp()) {
            // Short-circuit DEV and DEV'
            emitValue<output_DEVU0027>(ctx, stepper);
        }

        // Only proceed if the DO input is dirty (pulsed)
        if (!isInputDirty<input_DO>(ctx))
            return;

        // Validate the stepper instance
        if (!stepper) {
            raiseError(ctx); // Invalid stepper instance
            return;
        }

        // Stop the stepper
        stepper->stopMove();

        // Emit a pulse to indicate the action was successful
        emitValue<output_ACK>(ctx, 1);
    }
}