288 lines
8.3 KiB
C++
288 lines
8.3 KiB
C++
#ifndef slic3r_GCodeTimeEstimator_hpp_
|
|
#define slic3r_GCodeTimeEstimator_hpp_
|
|
|
|
#include "libslic3r.h"
|
|
#include "GCodeReader.hpp"
|
|
|
|
#define USE_CURA_JUNCTION_VMAX 0
|
|
#define ENABLE_BLOCKS_PRE_PROCESSING 1
|
|
|
|
namespace Slic3r {
|
|
|
|
class GCodeTimeEstimator
|
|
{
|
|
public:
|
|
enum EUnits : unsigned char
|
|
{
|
|
Millimeters,
|
|
Inches
|
|
};
|
|
|
|
enum EAxis : unsigned char
|
|
{
|
|
X,
|
|
Y,
|
|
Z,
|
|
E,
|
|
Num_Axis
|
|
};
|
|
|
|
enum EDialect : unsigned char
|
|
{
|
|
Unknown,
|
|
Marlin,
|
|
Repetier,
|
|
Smoothieware,
|
|
RepRapFirmware,
|
|
Teacup,
|
|
Num_Dialects
|
|
};
|
|
|
|
enum EPositioningType
|
|
{
|
|
Absolute,
|
|
Relative
|
|
};
|
|
|
|
private:
|
|
struct Axis
|
|
{
|
|
float position; // mm
|
|
float max_feedrate; // mm/s
|
|
float max_acceleration; // mm/s^2
|
|
float max_jerk; // mm/s
|
|
};
|
|
|
|
struct Feedrates
|
|
{
|
|
float feedrate; // mm/s
|
|
float axis_feedrate[Num_Axis]; // mm/s
|
|
float abs_axis_feedrate[Num_Axis]; // mm/s
|
|
float safe_feedrate; // mm/s
|
|
|
|
void reset();
|
|
};
|
|
|
|
struct State
|
|
{
|
|
EDialect dialect;
|
|
EUnits units;
|
|
EPositioningType positioningType;
|
|
Axis axis[Num_Axis];
|
|
float feedrate; // mm/s
|
|
float acceleration; // mm/s^2
|
|
float additional_time; // s
|
|
float minimum_feedrate; // mm/s
|
|
};
|
|
|
|
public:
|
|
struct Block
|
|
{
|
|
struct FeedrateProfile
|
|
{
|
|
float entry; // mm/s
|
|
float cruise; // mm/s
|
|
float exit; // mm/s
|
|
};
|
|
|
|
struct Trapezoid
|
|
{
|
|
float distance; // mm
|
|
float accelerate_until; // mm
|
|
float decelerate_after; // mm
|
|
FeedrateProfile feedrate;
|
|
|
|
float acceleration_time(float acceleration) const;
|
|
float cruise_time() const;
|
|
float deceleration_time(float acceleration) const;
|
|
float cruise_distance() const;
|
|
|
|
// This function gives the time needed to accelerate from an initial speed to reach a final distance.
|
|
static float acceleration_time_from_distance(float initial_feedrate, float distance, float acceleration);
|
|
|
|
// This function gives the final speed while accelerating at the given constant acceleration from the given initial speed along the given distance.
|
|
static float speed_from_distance(float initial_feedrate, float distance, float acceleration);
|
|
};
|
|
|
|
#if ENABLE_BLOCKS_PRE_PROCESSING
|
|
struct Flags
|
|
{
|
|
bool recalculate;
|
|
bool nominal_length;
|
|
};
|
|
|
|
Flags flags;
|
|
#endif // ENABLE_BLOCKS_PRE_PROCESSING
|
|
|
|
float delta_pos[Num_Axis]; // mm
|
|
float acceleration; // mm/s^2
|
|
#if ENABLE_BLOCKS_PRE_PROCESSING
|
|
float max_entry_speed; // mm/s
|
|
float safe_feedrate; // mm/s
|
|
#endif // ENABLE_BLOCKS_PRE_PROCESSING
|
|
|
|
FeedrateProfile feedrate;
|
|
Trapezoid trapezoid;
|
|
|
|
// Returns the length of the move covered by this block, in mm
|
|
float move_length() const;
|
|
|
|
// Returns the time spent accelerating toward cruise speed, in seconds
|
|
float acceleration_time() const;
|
|
|
|
// Returns the time spent at cruise speed, in seconds
|
|
float cruise_time() const;
|
|
|
|
// Returns the time spent decelerating from cruise speed, in seconds
|
|
float deceleration_time() const;
|
|
|
|
// Returns the distance covered at cruise speed, in mm
|
|
float cruise_distance() const;
|
|
|
|
// Calculates this block's trapezoid
|
|
void calculate_trapezoid();
|
|
|
|
// Calculates the maximum allowable speed at this point when you must be able to reach target_velocity using the
|
|
// acceleration within the allotted distance.
|
|
static float max_allowable_speed(float acceleration, float target_velocity, float distance);
|
|
|
|
// Calculates the distance (not time) it takes to accelerate from initial_rate to target_rate using the given acceleration:
|
|
static float estimate_acceleration_distance(float initial_rate, float target_rate, float acceleration);
|
|
|
|
// This function gives you the point at which you must start braking (at the rate of -acceleration) if
|
|
// you started at speed initial_rate and accelerated until this point and want to end at the final_rate after
|
|
// a total travel of distance. This can be used to compute the intersection point between acceleration and
|
|
// deceleration in the cases where the trapezoid has no plateau (i.e. never reaches maximum speed)
|
|
static float intersection_distance(float initial_rate, float final_rate, float acceleration, float distance);
|
|
};
|
|
|
|
typedef std::vector<Block> BlocksList;
|
|
|
|
private:
|
|
GCodeReader _parser;
|
|
State _state;
|
|
Feedrates _curr;
|
|
Feedrates _prev;
|
|
BlocksList _blocks;
|
|
float _time; // s
|
|
|
|
public:
|
|
GCodeTimeEstimator();
|
|
|
|
// Calculates the time estimate from the given gcode in string format
|
|
void calculate_time_from_text(const std::string& gcode);
|
|
|
|
// Calculates the time estimate from the gcode contained in the file with the given filename
|
|
void calculate_time_from_file(const std::string& file);
|
|
|
|
// Adds the given gcode line
|
|
void add_gcode_line(const std::string& gcode_line);
|
|
|
|
// Calculates the time estimate from gcode lines added using add_gcode_line()
|
|
void calculate_time();
|
|
|
|
void set_axis_position(EAxis axis, float position);
|
|
void set_axis_max_feedrate(EAxis axis, float feedrate_mm_sec);
|
|
void set_axis_max_acceleration(EAxis axis, float acceleration);
|
|
void set_axis_max_jerk(EAxis axis, float jerk);
|
|
|
|
float get_axis_position(EAxis axis) const;
|
|
float get_axis_max_feedrate(EAxis axis) const;
|
|
float get_axis_max_acceleration(EAxis axis) const;
|
|
float get_axis_max_jerk(EAxis axis) const;
|
|
|
|
void set_feedrate(float feedrate_mm_sec);
|
|
float get_feedrate() const;
|
|
|
|
void set_acceleration(float acceleration);
|
|
float get_acceleration() const;
|
|
|
|
void set_minimum_feedrate(float feedrate_mm_sec);
|
|
float get_minimum_feedrate() const;
|
|
|
|
void set_dialect(EDialect dialect);
|
|
EDialect get_dialect() const;
|
|
|
|
void set_units(EUnits units);
|
|
EUnits get_units() const;
|
|
|
|
void set_positioningType(EPositioningType type);
|
|
EPositioningType get_positioningType() const;
|
|
|
|
void add_additional_time(float timeSec);
|
|
void set_additional_time(float timeSec);
|
|
float get_additional_time() const;
|
|
|
|
void set_default();
|
|
|
|
// Call this method before to start adding lines using add_gcode_line() when reusing an instance of GCodeTimeEstimator
|
|
void reset();
|
|
|
|
// Returns the estimated time, in seconds
|
|
float get_time() const;
|
|
|
|
// Returns the estimated time, in format HH:MM:SS
|
|
std::string get_time_hms() const;
|
|
|
|
private:
|
|
void _reset();
|
|
|
|
// Calculates the time estimate
|
|
void _calculate_time();
|
|
|
|
// Processes GCode line
|
|
void _process_gcode_line(GCodeReader&, const GCodeReader::GCodeLine& line);
|
|
|
|
// Move
|
|
void _processG1(const GCodeReader::GCodeLine& line);
|
|
|
|
// Dwell
|
|
void _processG4(const GCodeReader::GCodeLine& line);
|
|
|
|
// Set Units to Inches
|
|
void _processG20(const GCodeReader::GCodeLine& line);
|
|
|
|
// Set Units to Millimeters
|
|
void _processG21(const GCodeReader::GCodeLine& line);
|
|
|
|
// Move to Origin (Home)
|
|
void _processG28(const GCodeReader::GCodeLine& line);
|
|
|
|
// Set to Absolute Positioning
|
|
void _processG90(const GCodeReader::GCodeLine& line);
|
|
|
|
// Set to Relative Positioning
|
|
void _processG91(const GCodeReader::GCodeLine& line);
|
|
|
|
// Set Position
|
|
void _processG92(const GCodeReader::GCodeLine& line);
|
|
|
|
// Set Extruder Temperature and Wait
|
|
void _processM109(const GCodeReader::GCodeLine& line);
|
|
|
|
// Set maximum feedrate
|
|
void _processM203(const GCodeReader::GCodeLine& line);
|
|
|
|
// Set default acceleration
|
|
void _processM204(const GCodeReader::GCodeLine& line);
|
|
|
|
// Advanced settings
|
|
void _processM205(const GCodeReader::GCodeLine& line);
|
|
|
|
// Set allowable instantaneous speed change
|
|
void _processM566(const GCodeReader::GCodeLine& line);
|
|
|
|
#if ENABLE_BLOCKS_PRE_PROCESSING
|
|
void forward_pass();
|
|
void reverse_pass();
|
|
|
|
void planner_forward_pass_kernel(Block* prev, Block* curr);
|
|
void planner_reverse_pass_kernel(Block* curr, Block* next);
|
|
|
|
void recalculate_trapezoids();
|
|
#endif // ENABLE_BLOCKS_PRE_PROCESSING
|
|
};
|
|
|
|
} /* namespace Slic3r */
|
|
|
|
#endif /* slic3r_GCodeTimeEstimator_hpp_ */
|