itersolve: Improve numerical stability of itersolve_generate_steps() loop
Minor rework of the loop to reduce the chance that numerical stability could cause an infinite loop. Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
0bfb655f66
commit
bdc7383e51
|
@ -147,20 +147,17 @@ itersolve_generate_steps(struct stepper_kinematics *sk, double flush_time)
|
||||||
if (!sk->tq || list_empty(&sk->tq->moves))
|
if (!sk->tq || list_empty(&sk->tq->moves))
|
||||||
return 0;
|
return 0;
|
||||||
struct move *m = list_first_entry(&sk->tq->moves, struct move, node);
|
struct move *m = list_first_entry(&sk->tq->moves, struct move, node);
|
||||||
for (;;) {
|
while (last_flush_time >= m->print_time + m->move_t) {
|
||||||
double move_print_time = m->print_time;
|
|
||||||
double move_end_time = move_print_time + m->move_t;
|
|
||||||
if (last_flush_time >= move_end_time) {
|
|
||||||
if (list_is_last(&m->node, &sk->tq->moves))
|
if (list_is_last(&m->node, &sk->tq->moves))
|
||||||
break;
|
return 0;
|
||||||
m = list_next_entry(m, node);
|
m = list_next_entry(m, node);
|
||||||
continue;
|
|
||||||
}
|
}
|
||||||
double start = move_print_time, end = move_end_time;
|
for (;;) {
|
||||||
|
double start = m->print_time, end = start + m->move_t;
|
||||||
if (start < last_flush_time)
|
if (start < last_flush_time)
|
||||||
start = last_flush_time;
|
start = last_flush_time;
|
||||||
if (start >= flush_time)
|
if (start >= flush_time)
|
||||||
break;
|
return 0;
|
||||||
if (end > flush_time)
|
if (end > flush_time)
|
||||||
end = flush_time;
|
end = flush_time;
|
||||||
if (check_active(sk, m)) {
|
if (check_active(sk, m)) {
|
||||||
|
@ -169,8 +166,10 @@ itersolve_generate_steps(struct stepper_kinematics *sk, double flush_time)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
last_flush_time = end;
|
last_flush_time = end;
|
||||||
}
|
if (list_is_last(&m->node, &sk->tq->moves))
|
||||||
return 0;
|
return 0;
|
||||||
|
m = list_next_entry(m, node);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check if the given stepper is likely to be active in the given time range
|
// Check if the given stepper is likely to be active in the given time range
|
||||||
|
|
Loading…
Reference in New Issue