// Cartesian kinematics stepper pulse time generation // // Copyright (C) 2018 Kevin O'Connor <kevin@koconnor.net> // // This file may be distributed under the terms of the GNU GPLv3 license. #include <stdlib.h> // malloc #include <string.h> // memset #include "compiler.h" // __visible #include "itersolve.h" // move_get_coord #include "pyhelper.h" // errorf static double cart_stepper_x_calc_position(struct stepper_kinematics *sk, struct move *m , double move_time) { return move_get_coord(m, move_time).x; } static double cart_stepper_y_calc_position(struct stepper_kinematics *sk, struct move *m , double move_time) { return move_get_coord(m, move_time).y; } static double cart_stepper_z_calc_position(struct stepper_kinematics *sk, struct move *m , double move_time) { return move_get_coord(m, move_time).z; } struct stepper_kinematics * __visible cartesian_stepper_alloc(char axis) { struct stepper_kinematics *sk = malloc(sizeof(*sk)); memset(sk, 0, sizeof(*sk)); if (axis == 'x') sk->calc_position = cart_stepper_x_calc_position; else if (axis == 'y') sk->calc_position = cart_stepper_y_calc_position; else if (axis == 'z') sk->calc_position = cart_stepper_z_calc_position; return sk; }