toolhead: Remove unneeded forward pass in MoveQueue.flush()
Simplify the code now that the extruder lookahead is separate from the main lookahead code. Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
e14d86d8b8
commit
074495a13a
|
@ -87,41 +87,41 @@ class MoveQueue:
|
||||||
def __init__(self, extruder_lookahead):
|
def __init__(self, extruder_lookahead):
|
||||||
self.extruder_lookahead = extruder_lookahead
|
self.extruder_lookahead = extruder_lookahead
|
||||||
self.queue = []
|
self.queue = []
|
||||||
|
self.leftover = 0
|
||||||
self.junction_flush = 0.
|
self.junction_flush = 0.
|
||||||
def reset(self):
|
def reset(self):
|
||||||
del self.queue[:]
|
del self.queue[:]
|
||||||
|
self.leftover = 0
|
||||||
def flush(self, lazy=False):
|
def flush(self, lazy=False):
|
||||||
update_flush_count = lazy
|
update_flush_count = lazy
|
||||||
queue = self.queue
|
queue = self.queue
|
||||||
flush_count = len(queue)
|
flush_count = len(queue)
|
||||||
move_info = [None] * flush_count
|
|
||||||
# Traverse queue from last to first move and determine maximum
|
# Traverse queue from last to first move and determine maximum
|
||||||
# junction speed assuming the robot comes to a complete stop
|
# junction speed assuming the robot comes to a complete stop
|
||||||
# after the last move.
|
# after the last move.
|
||||||
next_end_v2 = 0.
|
next_end_v2 = 0.
|
||||||
for i in range(flush_count-1, -1, -1):
|
for i in range(flush_count-1, self.leftover-1, -1):
|
||||||
move = queue[i]
|
move = queue[i]
|
||||||
reachable_start_v2 = next_end_v2 + move.delta_v2
|
reachable_start_v2 = next_end_v2 + move.delta_v2
|
||||||
start_v2 = min(move.max_start_v2, reachable_start_v2)
|
start_v2 = min(move.max_start_v2, reachable_start_v2)
|
||||||
cruise_v2 = min((start_v2 + reachable_start_v2) * .5
|
cruise_v2 = min((start_v2 + reachable_start_v2) * .5
|
||||||
, move.max_cruise_v2)
|
, move.max_cruise_v2)
|
||||||
move_info[i] = (move, start_v2, cruise_v2, next_end_v2)
|
if not update_flush_count:
|
||||||
if update_flush_count and reachable_start_v2 > start_v2:
|
move.set_junction(start_v2, cruise_v2, next_end_v2)
|
||||||
|
elif reachable_start_v2 > start_v2:
|
||||||
flush_count = i
|
flush_count = i
|
||||||
update_flush_count = False
|
update_flush_count = False
|
||||||
next_end_v2 = start_v2
|
next_end_v2 = start_v2
|
||||||
if update_flush_count:
|
if update_flush_count:
|
||||||
flush_count = 0
|
flush_count = 0
|
||||||
# Traverse queue in forward direction propagating final values
|
|
||||||
for move, start_v2, cruise_v2, end_v2 in move_info[:flush_count]:
|
|
||||||
move.set_junction(start_v2, cruise_v2, end_v2)
|
|
||||||
# Allow extruder to do its lookahead
|
# Allow extruder to do its lookahead
|
||||||
flush_count = self.extruder_lookahead(queue, flush_count, lazy)
|
move_count = self.extruder_lookahead(queue, flush_count, lazy)
|
||||||
# Generate step times for all moves ready to be flushed
|
# Generate step times for all moves ready to be flushed
|
||||||
for move in queue[:flush_count]:
|
for move in queue[:move_count]:
|
||||||
move.move()
|
move.move()
|
||||||
# Remove processed moves from the queue
|
# Remove processed moves from the queue
|
||||||
del queue[:flush_count]
|
self.leftover = flush_count - move_count
|
||||||
|
del queue[:move_count]
|
||||||
if queue:
|
if queue:
|
||||||
self.junction_flush = 2. * queue[-1].max_cruise_v2
|
self.junction_flush = 2. * queue[-1].max_cruise_v2
|
||||||
def add_move(self, move):
|
def add_move(self, move):
|
||||||
|
|
Loading…
Reference in New Issue