Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

First pass at laser control including dynamic power control #431

Open
wants to merge 3 commits into
base: edge
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Next Next commit
First pass at laser control including dynamic power control
  • Loading branch information
mhlong10 committed Nov 23, 2019
commit f178ba835c314443622021e396a1de2854de8a89
7 changes: 7 additions & 0 deletions g2core/canonical_machine.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1370,6 +1370,13 @@ stat_t cm_change_tool(const uint8_t tool_change)
return (STAT_OK);
}

bool cm_is_laser_tool(void)
{
// Tool 32 is always a laser. Later we can use a different qualified.
justinclift marked this conversation as resolved.
Show resolved Hide resolved
return (32 == cm->gm.tool_select);
}


/****************************************************************************************
**** Miscellaneous Functions (4.3.9) ***************************************************
****************************************************************************************/
Expand Down
2 changes: 2 additions & 0 deletions g2core/canonical_machine.h
Original file line number Diff line number Diff line change
Expand Up @@ -463,6 +463,8 @@ stat_t cm_arc_feed(const float target[], const bool target_f[], // G
stat_t cm_select_tool(const uint8_t tool); // T parameter
stat_t cm_change_tool(const uint8_t tool); // M6

bool cm_is_laser_tool(void); // True if tool is a laser

// Miscellaneous Functions (4.3.9)
// see coolant.h for coolant functions - which would go right here

Expand Down
4 changes: 4 additions & 0 deletions g2core/plan_exec.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -917,6 +917,10 @@ static stat_t _exec_aline_segment()
}
}

if (cm_is_laser_tool() && spindle.direction == SPINDLE_CCW) {
spindle_update_laser_override(mr->segment_velocity);
}

// Convert target position to steps
// Bucket-brigade the old target down the chain before getting the new target from kinematics
//
Expand Down
27 changes: 25 additions & 2 deletions g2core/spindle.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -215,7 +215,7 @@ static void _exec_spindle_control(float *value, bool *flag)
}
pwm_set_duty(PWM_1, _get_spindle_pwm(spindle, pwm));

if (spinup_delay) {
if (spinup_delay && !cm_is_laser_tool()) {
mp_request_out_of_band_dwell(spindle.spinup_delay);
}
}
Expand Down Expand Up @@ -261,7 +261,7 @@ static void _exec_spindle_speed(float *value, bool *flag)
spindle.speed = value[0];
pwm_set_duty(PWM_1, _get_spindle_pwm(spindle, pwm));

if (fp_ZERO(previous_speed)) {
if (fp_ZERO(previous_speed) && !cm_is_laser_tool()) {
mp_request_out_of_band_dwell(spindle.spinup_delay);
}
}
Expand Down Expand Up @@ -318,6 +318,12 @@ static float _get_spindle_pwm (spSpindle_t &_spindle, pwmControl_t &_pwm)
}
// normalize speed to [0..1]
float speed = (_spindle.speed - speed_lo) / (speed_hi - speed_lo);
if (cm_is_laser_tool() && spindle.direction == SPINDLE_CCW) {
// We are in dynamic laser mode (M4) + Laser tool. Adjust
// speed based on override_factor which is updated based on
// current velocity.
speed *= spindle.override_factor;
}
return ((speed * (phase_hi - phase_lo)) + phase_lo);
} else {
return (_pwm.c[PWM_1].phase_off);
Expand Down Expand Up @@ -369,6 +375,23 @@ void spindle_end_override(const float ramp_time)
return;
}

// Called in ISR so be careful and fast
void spindle_update_laser_override(float current_velocity) {
float spindle_override = 0.0;
float feed_rate = cm_get_feed_rate(ACTIVE_MODEL);

if (feed_rate > 0.0) {
spindle_override = current_velocity / feed_rate;
if (spindle_override > 1.0) spindle_override = 1.0;
else if (spindle_override < 0.0) spindle_override = 0.0;
}
// if (fabs(spindle_override - spindle.override_factor) >= 0.01) {
justinclift marked this conversation as resolved.
Show resolved Hide resolved
// Only update if the change is worth while (at least 1%)
spindle.override_factor = spindle_override;
pwm_set_duty(PWM_1, _get_spindle_pwm(spindle, pwm));
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Note: This is where I would adjust the i2c code if we were controlling a digital pot for plasma power settings.

// }
justinclift marked this conversation as resolved.
Show resolved Hide resolved
}

/****************************
* END OF SPINDLE FUNCTIONS *
****************************/
Expand Down
1 change: 1 addition & 0 deletions g2core/spindle.h
Original file line number Diff line number Diff line change
Expand Up @@ -120,6 +120,7 @@ stat_t spindle_speed_sync(float speed); // S parameter
stat_t spindle_override_control(const float P_word, const bool P_flag); // M51
void spindle_start_override(const float ramp_time, const float override_factor);
void spindle_end_override(const float ramp_time);
void spindle_update_laser_override(float current_velocity);

stat_t sp_get_spmo(nvObj_t *nv);
stat_t sp_set_spmo(nvObj_t *nv);
Expand Down