itersolve: Reset bounds search on a direction change
If the stepper changes direction then the average velocity since the last step pulse isn't a good indicator of the next step pulse. Instead, reset the bounds checking to use a low starting guess. Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
271e412ae6
commit
8f8c1e2c58
|
@ -54,6 +54,8 @@ itersolve_find_step(struct stepper_kinematics *sk, struct move *m
|
||||||
return best_guess;
|
return best_guess;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define SEEK_TIME_RESET 0.000100
|
||||||
|
|
||||||
// Generate step times for a portion of a move
|
// Generate step times for a portion of a move
|
||||||
static int32_t
|
static int32_t
|
||||||
itersolve_gen_steps_range(struct stepper_kinematics *sk, struct move *m
|
itersolve_gen_steps_range(struct stepper_kinematics *sk, struct move *m
|
||||||
|
@ -63,8 +65,8 @@ itersolve_gen_steps_range(struct stepper_kinematics *sk, struct move *m
|
||||||
double half_step = .5 * sk->step_dist;
|
double half_step = .5 * sk->step_dist;
|
||||||
double start = move_start - m->print_time, end = move_end - m->print_time;
|
double start = move_start - m->print_time, end = move_end - m->print_time;
|
||||||
struct timepos last = { start, sk->commanded_pos }, low = last, high = last;
|
struct timepos last = { start, sk->commanded_pos }, low = last, high = last;
|
||||||
double seek_time_delta = 0.000100;
|
double seek_time_delta = SEEK_TIME_RESET;
|
||||||
int sdir = !!stepcompress_get_step_dir(sk->sc);
|
int sdir = !!stepcompress_get_step_dir(sk->sc), is_dir_change = 0;
|
||||||
for (;;) {
|
for (;;) {
|
||||||
double diff = high.position - last.position, dist = sdir ? diff : -diff;
|
double diff = high.position - last.position, dist = sdir ? diff : -diff;
|
||||||
if (dist >= half_step) {
|
if (dist >= half_step) {
|
||||||
|
@ -79,6 +81,9 @@ itersolve_gen_steps_range(struct stepper_kinematics *sk, struct move *m
|
||||||
seek_time_delta = next.time - last.time;
|
seek_time_delta = next.time - last.time;
|
||||||
if (seek_time_delta < .000000001)
|
if (seek_time_delta < .000000001)
|
||||||
seek_time_delta = .000000001;
|
seek_time_delta = .000000001;
|
||||||
|
if (is_dir_change && seek_time_delta > SEEK_TIME_RESET)
|
||||||
|
seek_time_delta = SEEK_TIME_RESET;
|
||||||
|
is_dir_change = 0;
|
||||||
last.position = target + (sdir ? half_step : -half_step);
|
last.position = target + (sdir ? half_step : -half_step);
|
||||||
last.time = next.time;
|
last.time = next.time;
|
||||||
low = next;
|
low = next;
|
||||||
|
@ -87,6 +92,9 @@ itersolve_gen_steps_range(struct stepper_kinematics *sk, struct move *m
|
||||||
continue;
|
continue;
|
||||||
} else if (unlikely(dist < -(half_step + .000000001))) {
|
} else if (unlikely(dist < -(half_step + .000000001))) {
|
||||||
// Found direction change
|
// Found direction change
|
||||||
|
is_dir_change = 1;
|
||||||
|
if (seek_time_delta > SEEK_TIME_RESET)
|
||||||
|
seek_time_delta = SEEK_TIME_RESET;
|
||||||
if (low.time > last.time) {
|
if (low.time > last.time) {
|
||||||
// Update direction and retry
|
// Update direction and retry
|
||||||
sdir = !sdir;
|
sdir = !sdir;
|
||||||
|
|
Loading…
Reference in New Issue