G34 Mechanical Gantry Calibration (like Prusa M915) (#18972)
Co-authored-by: Scott Lahteine <thinkyhead@users.noreply.github.com>
This commit is contained in:
		
				
					committed by
					
						 Scott Lahteine
						Scott Lahteine
					
				
			
			
				
	
			
			
			
						parent
						
							faae900747
						
					
				
				
					commit
					8b060a3902
				
			| @@ -3377,6 +3377,25 @@ | |||||||
|   //#define JOYSTICK_DEBUG |   //#define JOYSTICK_DEBUG | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * Mechanical Gantry Calibration | ||||||
|  |  * Modern replacement for the Prusa TMC_Z_CALIBRATION. | ||||||
|  |  * Adds capability to work with any adjustable current drivers. | ||||||
|  |  * Implemented as G34 because M915 is deprecated. | ||||||
|  |  */ | ||||||
|  | //#define MECHANICAL_GANTRY_CALIBRATION | ||||||
|  | #if ENABLED(MECHANICAL_GANTRY_CALIBRATION) | ||||||
|  |   #define GANTRY_CALIBRATION_CURRENT          600     // Default calibration current in ma | ||||||
|  |   #define GANTRY_CALIBRATION_EXTRA_HEIGHT      15     // Extra distance in mm past Z_###_POS to move | ||||||
|  |   #define GANTRY_CALIBRATION_FEEDRATE         500     // Feedrate for correction move | ||||||
|  |   //#define GANTRY_CALIBRATION_TO_MIN                 // Enable to calibrate Z in the MIN direction | ||||||
|  |  | ||||||
|  |   //#define GANTRY_CALIBRATION_SAFE_POSITION  { X_CENTER, Y_CENTER } // Safe position for nozzle | ||||||
|  |   //#define GANTRY_CALIBRATION_XY_PARK_FEEDRATE 3000  // XY Park Feedrate - MMM | ||||||
|  |   //#define GANTRY_CALIBRATION_COMMANDS_PRE   "" | ||||||
|  |   #define GANTRY_CALIBRATION_COMMANDS_POST  "G28"     // G28 highly recommended to ensure an accurate position | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * MAX7219 Debug Matrix |  * MAX7219 Debug Matrix | ||||||
|  * |  * | ||||||
|   | |||||||
							
								
								
									
										153
									
								
								Marlin/src/gcode/calibrate/G34.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										153
									
								
								Marlin/src/gcode/calibrate/G34.cpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,153 @@ | |||||||
|  | /** | ||||||
|  |  * Marlin 3D Printer Firmware | ||||||
|  |  * Copyright (c) 2020 MarlinFirmware [https://github.com/MarlinFirmware/Marlin] | ||||||
|  |  * | ||||||
|  |  * Based on Sprinter and grbl. | ||||||
|  |  * Copyright (c) 2011 Camiel Gubbels / Erik van der Zalm | ||||||
|  |  * | ||||||
|  |  * This program is free software: you can redistribute it and/or modify | ||||||
|  |  * it under the terms of the GNU General Public License as published by | ||||||
|  |  * the Free Software Foundation, either version 3 of the License, or | ||||||
|  |  * (at your option) any later version. | ||||||
|  |  * | ||||||
|  |  * This program is distributed in the hope that it will be useful, | ||||||
|  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  |  * GNU General Public License for more details. | ||||||
|  |  * | ||||||
|  |  * You should have received a copy of the GNU General Public License | ||||||
|  |  * along with this program.  If not, see <https://www.gnu.org/licenses/>. | ||||||
|  |  * | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | #include "../../inc/MarlinConfigPre.h" | ||||||
|  |  | ||||||
|  | #if ENABLED(MECHANICAL_GANTRY_CALIBRATION) | ||||||
|  |  | ||||||
|  | #include "../gcode.h" | ||||||
|  | #include "../../module/motion.h" | ||||||
|  | #include "../../module/stepper.h" | ||||||
|  | #include "../../module/endstops.h" | ||||||
|  |  | ||||||
|  | #if HAS_LEVELING | ||||||
|  |   #include "../../feature/bedlevel/bedlevel.h" | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #define DEBUG_OUT ENABLED(DEBUG_LEVELING_FEATURE) | ||||||
|  | #include "../../core/debug_out.h" | ||||||
|  |  | ||||||
|  | void GcodeSuite::G34() { | ||||||
|  |  | ||||||
|  |   if (homing_needed()) return; | ||||||
|  |  | ||||||
|  |   TEMPORARY_SOFT_ENDSTOP_STATE(false); | ||||||
|  |   TEMPORARY_BED_LEVELING_STATE(false); | ||||||
|  |   TemporaryGlobalEndstopsState unlock_z(false); | ||||||
|  |  | ||||||
|  |   #ifdef GANTRY_CALIBRATION_COMMANDS_PRE | ||||||
|  |     gcode.process_subcommands_now_P(PSTR(GANTRY_CALIBRATION_COMMANDS_PRE)); | ||||||
|  |     if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("Sub Commands Processed"); | ||||||
|  |   #endif | ||||||
|  |  | ||||||
|  |   #ifdef GANTRY_CALIBRATION_SAFE_POSITION | ||||||
|  |     // Move XY to safe position | ||||||
|  |     if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("Parking XY"); | ||||||
|  |     const xy_pos_t safe_pos = GANTRY_CALIBRATION_SAFE_POSITION; | ||||||
|  |     do_blocking_move_to(safe_pos, MMM_TO_MMS(GANTRY_CALIBRATION_XY_PARK_FEEDRATE)); | ||||||
|  |   #endif | ||||||
|  |  | ||||||
|  |   const float move_distance = parser.intval('Z', GANTRY_CALIBRATION_EXTRA_HEIGHT), | ||||||
|  |               zbase = ENABLED(GANTRY_CALIBRATION_TO_MIN) ? Z_MIN_POS : Z_MAX_POS, | ||||||
|  |               zpounce = zbase - move_distance, zgrind = zbase + move_distance; | ||||||
|  |  | ||||||
|  |   // Move Z to pounce position | ||||||
|  |   if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("Setting Z Pounce"); | ||||||
|  |   do_blocking_move_to_z(zpounce, MMM_TO_MMS(HOMING_FEEDRATE_Z)); | ||||||
|  |  | ||||||
|  |   // Store current motor settings, then apply reduced value | ||||||
|  |  | ||||||
|  |   #define _REDUCE_CURRENT ANY(HAS_MOTOR_CURRENT_SPI, HAS_MOTOR_CURRENT_PWM, HAS_MOTOR_CURRENT_DAC, HAS_MOTOR_CURRENT_I2C, HAS_TRINAMIC_CONFIG) | ||||||
|  |   #if _REDUCE_CURRENT | ||||||
|  |     if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("Reducing Current"); | ||||||
|  |   #endif | ||||||
|  |  | ||||||
|  |   #if HAS_MOTOR_CURRENT_SPI | ||||||
|  |     const uint16_t target_current = parser.intval('S', GANTRY_CALIBRATION_CURRENT); | ||||||
|  |     const uint32_t previous_current = stepper.motor_current_setting[Z_AXIS]; | ||||||
|  |     stepper.set_digipot_current(Z_AXIS, target_current); | ||||||
|  |   #elif HAS_MOTOR_CURRENT_PWM | ||||||
|  |     const uint16_t target_current = parser.intval('S', GANTRY_CALIBRATION_CURRENT); | ||||||
|  |     const uint32_t previous_current = stepper.motor_current_setting[Z_AXIS]; | ||||||
|  |     stepper.set_digipot_current(1, target_current); | ||||||
|  |   #elif HAS_MOTOR_CURRENT_DAC | ||||||
|  |     const float target_current = parser.floatval('S', GANTRY_CALIBRATION_CURRENT); | ||||||
|  |     const float previous_current = dac_amps(Z_AXIS, target_current); | ||||||
|  |     stepper_dac.set_current_value(Z_AXIS, target_current); | ||||||
|  |   #elif ENABLED(HAS_MOTOR_CURRENT_I2C) | ||||||
|  |     const uint16_t target_current = parser.intval('S', GANTRY_CALIBRATION_CURRENT); | ||||||
|  |     previous_current = dac_amps(Z_AXIS); | ||||||
|  |     digipot_i2c.set_current(Z_AXIS, target_current) | ||||||
|  |   #elif HAS_TRINAMIC_CONFIG | ||||||
|  |     const uint16_t target_current = parser.intval('S', GANTRY_CALIBRATION_CURRENT); | ||||||
|  |     static uint16_t previous_current_arr[NUM_Z_STEPPER_DRIVERS]; | ||||||
|  |     #if AXIS_IS_TMC(Z) | ||||||
|  |       previous_current_arr[0] = stepperZ.getMilliamps(); | ||||||
|  |       stepperZ.rms_current(target_current); | ||||||
|  |     #endif | ||||||
|  |     #if AXIS_IS_TMC(Z2) | ||||||
|  |       previous_current_arr[1] = stepperZ2.getMilliamps(); | ||||||
|  |       stepperZ2.rms_current(target_current); | ||||||
|  |     #endif | ||||||
|  |     #if AXIS_IS_TMC(Z3) | ||||||
|  |       previous_current_arr[2] = stepperZ3.getMilliamps(); | ||||||
|  |       stepperZ3.rms_current(target_current); | ||||||
|  |     #endif | ||||||
|  |     #if AXIS_IS_TMC(Z4) | ||||||
|  |       previous_current_arr[3] = stepperZ4.getMilliamps(); | ||||||
|  |       stepperZ4.rms_current(target_current); | ||||||
|  |     #endif | ||||||
|  |   #endif | ||||||
|  |  | ||||||
|  |   // Do Final Z move to adjust | ||||||
|  |   if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("Final Z Move"); | ||||||
|  |   do_blocking_move_to_z(zgrind, MMM_TO_MMS(GANTRY_CALIBRATION_FEEDRATE)); | ||||||
|  |  | ||||||
|  |   // Back off end plate, back to normal motion range | ||||||
|  |   if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("Z Backoff"); | ||||||
|  |   do_blocking_move_to_z(zpounce, MMM_TO_MMS(GANTRY_CALIBRATION_FEEDRATE)); | ||||||
|  |  | ||||||
|  |   #if _REDUCE_CURRENT | ||||||
|  |     // Reset current to original values | ||||||
|  |     if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("Restore Current"); | ||||||
|  |   #endif | ||||||
|  |  | ||||||
|  |   #if HAS_MOTOR_CURRENT_SPI | ||||||
|  |     stepper.set_digipot_current(Z_AXIS, previous_current); | ||||||
|  |   #elif HAS_MOTOR_CURRENT_PWM | ||||||
|  |     stepper.set_digipot_current(1, previous_current); | ||||||
|  |   #elif HAS_MOTOR_CURRENT_DAC | ||||||
|  |     stepper_dac.set_current_value(Z_AXIS, previous_current); | ||||||
|  |   #elif ENABLED(HAS_MOTOR_CURRENT_I2C) | ||||||
|  |     digipot_i2c.set_current(Z_AXIS, previous_current) | ||||||
|  |   #elif HAS_TRINAMIC_CONFIG | ||||||
|  |     #if AXIS_IS_TMC(Z) | ||||||
|  |       stepperZ.rms_current(previous_current_arr[0]); | ||||||
|  |     #endif | ||||||
|  |     #if AXIS_IS_TMC(Z2) | ||||||
|  |       stepperZ2.rms_current(previous_current_arr[1]); | ||||||
|  |     #endif | ||||||
|  |     #if AXIS_IS_TMC(Z3) | ||||||
|  |       stepperZ3.rms_current(previous_current_arr[2]); | ||||||
|  |     #endif | ||||||
|  |     #if AXIS_IS_TMC(Z4) | ||||||
|  |       stepperZ4.rms_current(previous_current_arr[3]); | ||||||
|  |     #endif | ||||||
|  |   #endif | ||||||
|  |  | ||||||
|  |   #ifdef GANTRY_CALIBRATION_COMMANDS_POST | ||||||
|  |     if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("Running Post Commands"); | ||||||
|  |     gcode.process_subcommands_now_P(PSTR(GANTRY_CALIBRATION_COMMANDS_POST)); | ||||||
|  |   #endif | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #endif // MECHANICAL_GANTRY_CALIBRATION | ||||||
| @@ -20,28 +20,29 @@ | |||||||
|  * |  * | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #include "../../inc/MarlinConfig.h" | #include "../../inc/MarlinConfigPre.h" | ||||||
|  |  | ||||||
| #if ENABLED(Z_STEPPER_AUTO_ALIGN) | #if ENABLED(Z_STEPPER_AUTO_ALIGN) | ||||||
|  |  | ||||||
| #include "../../feature/z_stepper_align.h" | #include "../../feature/z_stepper_align.h" | ||||||
|  |  | ||||||
| #include "../gcode.h" | #include "../gcode.h" | ||||||
| #include "../../module/planner.h" |  | ||||||
| #include "../../module/stepper.h" |  | ||||||
| #include "../../module/motion.h" | #include "../../module/motion.h" | ||||||
|  | #include "../../module/stepper.h" | ||||||
|  | #include "../../module/planner.h" | ||||||
| #include "../../module/probe.h" | #include "../../module/probe.h" | ||||||
|  | #include "../../lcd/ultralcd.h" // for LCD_MESSAGEPGM | ||||||
| #if HAS_MULTI_HOTEND |  | ||||||
|   #include "../../module/tool_change.h" |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #if HAS_LEVELING | #if HAS_LEVELING | ||||||
|   #include "../../feature/bedlevel/bedlevel.h" |   #include "../../feature/bedlevel/bedlevel.h" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #if HAS_MULTI_HOTEND | ||||||
|  |   #include "../../module/tool_change.h" | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #if ENABLED(Z_STEPPER_ALIGN_KNOWN_STEPPER_POSITIONS) | #if ENABLED(Z_STEPPER_ALIGN_KNOWN_STEPPER_POSITIONS) | ||||||
|    #include "../../libs/least_squares_fit.h" |   #include "../../libs/least_squares_fit.h" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #define DEBUG_OUT ENABLED(DEBUG_LEVELING_FEATURE) | #define DEBUG_OUT ENABLED(DEBUG_LEVELING_FEATURE) | ||||||
| @@ -117,7 +118,7 @@ void GcodeSuite::G34() { | |||||||
|     // In BLTOUCH HS mode, the probe travels in a deployed state. |     // In BLTOUCH HS mode, the probe travels in a deployed state. | ||||||
|     // Users of G34 might have a badly misaligned bed, so raise Z by the |     // Users of G34 might have a badly misaligned bed, so raise Z by the | ||||||
|     // length of the deployed pin (BLTOUCH stroke < 7mm) |     // length of the deployed pin (BLTOUCH stroke < 7mm) | ||||||
|     #define Z_BASIC_CLEARANCE Z_CLEARANCE_BETWEEN_PROBES + 7.0f * BOTH(BLTOUCH, BLTOUCH_HS_MODE) |     #define Z_BASIC_CLEARANCE (Z_CLEARANCE_BETWEEN_PROBES + 7.0f * BOTH(BLTOUCH, BLTOUCH_HS_MODE)) | ||||||
|  |  | ||||||
|     // Compute a worst-case clearance height to probe from. After the first |     // Compute a worst-case clearance height to probe from. After the first | ||||||
|     // iteration this will be re-calculated based on the actual bed position |     // iteration this will be re-calculated based on the actual bed position | ||||||
| @@ -154,21 +155,29 @@ void GcodeSuite::G34() { | |||||||
|           z_maxdiff = 0.0f, |           z_maxdiff = 0.0f, | ||||||
|           amplification = z_auto_align_amplification; |           amplification = z_auto_align_amplification; | ||||||
|  |  | ||||||
|     // These are needed after the for-loop |  | ||||||
|     uint8_t iteration; |  | ||||||
|     bool err_break = false; |  | ||||||
|     float z_measured_min; |  | ||||||
|  |  | ||||||
|     #if DISABLED(Z_STEPPER_ALIGN_KNOWN_STEPPER_POSITIONS) |     #if DISABLED(Z_STEPPER_ALIGN_KNOWN_STEPPER_POSITIONS) | ||||||
|       bool adjustment_reverse = false; |       bool adjustment_reverse = false; | ||||||
|     #endif |     #endif | ||||||
|  |  | ||||||
|     // 'iteration' is declared above and is also used after the for-loop. |     #if HAS_DISPLAY | ||||||
|     // *not* the same as LOOP_L_N(iteration, z_auto_align_iterations) |       PGM_P const msg_iteration = GET_TEXT(MSG_ITERATION); | ||||||
|     for (iteration = 0; iteration < z_auto_align_iterations; ++iteration) { |       const uint8_t iter_str_len = strlen_P(msg_iteration); | ||||||
|  |     #endif | ||||||
|  |  | ||||||
|  |     // Final z and iteration values will be used after breaking the loop | ||||||
|  |     float z_measured_min; | ||||||
|  |     uint8_t iteration = 0; | ||||||
|  |     bool err_break = false; // To break out of nested loops | ||||||
|  |     while (iteration < z_auto_align_iterations) { | ||||||
|       if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("> probing all positions."); |       if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("> probing all positions."); | ||||||
|  |  | ||||||
|       SERIAL_ECHOLNPAIR("\nITERATION: ", int(iteration + 1)); |       const int iter = iteration + 1; | ||||||
|  |       SERIAL_ECHOLNPAIR("\nG34 Iteration: ", iter); | ||||||
|  |       #if HAS_DISPLAY | ||||||
|  |         char str[iter_str_len + 2 + 1]; | ||||||
|  |         sprintf_P(str, msg_iteration, iter); | ||||||
|  |         ui.set_status(str); | ||||||
|  |       #endif | ||||||
|  |  | ||||||
|       // Initialize minimum value |       // Initialize minimum value | ||||||
|       z_measured_min =  100000.0f; |       z_measured_min =  100000.0f; | ||||||
| @@ -190,7 +199,8 @@ void GcodeSuite::G34() { | |||||||
|         // current_position.z has been manually altered in the "dirty trick" above. |         // current_position.z has been manually altered in the "dirty trick" above. | ||||||
|         const float z_probed_height = probe.probe_at_point(z_stepper_align.xy[iprobe], raise_after, 0, true, false); |         const float z_probed_height = probe.probe_at_point(z_stepper_align.xy[iprobe], raise_after, 0, true, false); | ||||||
|         if (isnan(z_probed_height)) { |         if (isnan(z_probed_height)) { | ||||||
|           SERIAL_ECHOLNPGM("Probing failed."); |           SERIAL_ECHOLNPGM("Probing failed"); | ||||||
|  |           LCD_MESSAGEPGM(MSG_LCD_PROBING_FAILED); | ||||||
|           err_break = true; |           err_break = true; | ||||||
|           break; |           break; | ||||||
|         } |         } | ||||||
| @@ -249,8 +259,39 @@ void GcodeSuite::G34() { | |||||||
|           , " Z3-Z1=", ABS(z_measured[2] - z_measured[0]) |           , " Z3-Z1=", ABS(z_measured[2] - z_measured[0]) | ||||||
|         #endif |         #endif | ||||||
|       ); |       ); | ||||||
|  |       #if HAS_DISPLAY | ||||||
|  |         char fstr1[10]; | ||||||
|  |         #if NUM_Z_STEPPER_DRIVERS == 2 | ||||||
|  |           char msg[6 + (6 + 5) * 1 + 1]; | ||||||
|  |         #else | ||||||
|  |           char msg[6 + (6 + 5) * 3 + 1], fstr2[10], fstr3[10]; | ||||||
|  |         #endif | ||||||
|  |         sprintf_P(msg, | ||||||
|  |           PSTR("Diffs Z1-Z2=%s" | ||||||
|  |             #if NUM_Z_STEPPER_DRIVERS == 3 | ||||||
|  |               " Z2-Z3=%s" | ||||||
|  |               " Z3-Z1=%s" | ||||||
|  |             #endif | ||||||
|  |           ), dtostrf(ABS(z_measured[0] - z_measured[1]), 1, 3, fstr1) | ||||||
|  |           #if NUM_Z_STEPPER_DRIVERS == 3 | ||||||
|  |             , dtostrf(ABS(z_measured[1] - z_measured[2]), 1, 3, fstr2) | ||||||
|  |             , dtostrf(ABS(z_measured[2] - z_measured[0]), 1, 3, fstr3) | ||||||
|  |           #endif | ||||||
|  |         ); | ||||||
|  |         ui.set_status(msg); | ||||||
|  |       #endif | ||||||
|  |  | ||||||
|  |       auto decreasing_accuracy = [](const float &v1, const float &v2){ | ||||||
|  |         if (v1 < v2 * 0.7f) { | ||||||
|  |           SERIAL_ECHOLNPGM("Decreasing Accuracy Detected."); | ||||||
|  |           LCD_MESSAGEPGM(MSG_DECREASING_ACCURACY); | ||||||
|  |           return true; | ||||||
|  |         } | ||||||
|  |         return false; | ||||||
|  |       }; | ||||||
|  |  | ||||||
|       #if ENABLED(Z_STEPPER_ALIGN_KNOWN_STEPPER_POSITIONS) |       #if ENABLED(Z_STEPPER_ALIGN_KNOWN_STEPPER_POSITIONS) | ||||||
|  |  | ||||||
|         // Check if the applied corrections go in the correct direction. |         // Check if the applied corrections go in the correct direction. | ||||||
|         // Calculate the sum of the absolute deviations from the mean of the probe measurements. |         // Calculate the sum of the absolute deviations from the mean of the probe measurements. | ||||||
|         // Compare to the last iteration to ensure it's getting better. |         // Compare to the last iteration to ensure it's getting better. | ||||||
| @@ -266,11 +307,8 @@ void GcodeSuite::G34() { | |||||||
|           z_align_level_indicator += ABS(z_measured[zstepper] - z_measured_mean); |           z_align_level_indicator += ABS(z_measured[zstepper] - z_measured_mean); | ||||||
|  |  | ||||||
|         // If it's getting worse, stop and throw an error |         // If it's getting worse, stop and throw an error | ||||||
|         if (last_z_align_level_indicator < z_align_level_indicator * 0.7f) { |         err_break = decreasing_accuracy(last_z_align_level_indicator, z_align_level_indicator); | ||||||
|           SERIAL_ECHOLNPGM("Decreasing accuracy detected."); |         if (err_break) break; | ||||||
|           err_break = true; |  | ||||||
|           break; |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         last_z_align_level_indicator = z_align_level_indicator; |         last_z_align_level_indicator = z_align_level_indicator; | ||||||
|       #endif |       #endif | ||||||
| @@ -290,8 +328,7 @@ void GcodeSuite::G34() { | |||||||
|           if (z_align_abs) amplification = (iteration == 1) ? _MIN(last_z_align_move[zstepper] / z_align_abs, 2.0f) : z_auto_align_amplification; |           if (z_align_abs) amplification = (iteration == 1) ? _MIN(last_z_align_move[zstepper] / z_align_abs, 2.0f) : z_auto_align_amplification; | ||||||
|  |  | ||||||
|           // Check for less accuracy compared to last move |           // Check for less accuracy compared to last move | ||||||
|           if (last_z_align_move[zstepper] < z_align_abs * 0.7f) { |           if (decreasing_accuracy(last_z_align_move[zstepper], z_align_abs)) { | ||||||
|             SERIAL_ECHOLNPGM("Decreasing accuracy detected."); |  | ||||||
|             if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR("> Z", int(zstepper + 1), " last_z_align_move = ", last_z_align_move[zstepper]); |             if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR("> Z", int(zstepper + 1), " last_z_align_move = ", last_z_align_move[zstepper]); | ||||||
|             if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR("> Z", int(zstepper + 1), " z_align_abs = ", z_align_abs); |             if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR("> Z", int(zstepper + 1), " z_align_abs = ", z_align_abs); | ||||||
|             adjustment_reverse = !adjustment_reverse; |             adjustment_reverse = !adjustment_reverse; | ||||||
| @@ -329,9 +366,14 @@ void GcodeSuite::G34() { | |||||||
|  |  | ||||||
|       if (err_break) break; |       if (err_break) break; | ||||||
|  |  | ||||||
|       if (success_break) { SERIAL_ECHOLNPGM("Target accuracy achieved."); break; } |       if (success_break) { | ||||||
|  |         SERIAL_ECHOLNPGM("Target accuracy achieved."); | ||||||
|  |         LCD_MESSAGEPGM(MSG_ACCURACY_ACHIEVED); | ||||||
|  |         break; | ||||||
|  |       } | ||||||
|  |  | ||||||
|     } // for (iteration) |       iteration++; | ||||||
|  |     } // while (iteration < z_auto_align_iterations) | ||||||
|  |  | ||||||
|     if (err_break) |     if (err_break) | ||||||
|       SERIAL_ECHOLNPGM("G34 aborted."); |       SERIAL_ECHOLNPGM("G34 aborted."); | ||||||
|   | |||||||
| @@ -327,7 +327,7 @@ void GcodeSuite::process_parsed_command(const bool no_ok/*=false*/) { | |||||||
|         case 33: G33(); break;                                    // G33: Delta Auto-Calibration |         case 33: G33(); break;                                    // G33: Delta Auto-Calibration | ||||||
|       #endif |       #endif | ||||||
|  |  | ||||||
|       #if ENABLED(Z_STEPPER_AUTO_ALIGN) |       #if EITHER(Z_STEPPER_AUTO_ALIGN, MECHANICAL_GANTRY_CALIBRATION) | ||||||
|         case 34: G34(); break;                                    // G34: Z Stepper automatic alignment using probe |         case 34: G34(); break;                                    // G34: Z Stepper automatic alignment using probe | ||||||
|       #endif |       #endif | ||||||
|  |  | ||||||
|   | |||||||
| @@ -465,11 +465,12 @@ private: | |||||||
|  |  | ||||||
|   TERN_(DELTA_AUTO_CALIBRATION, static void G33()); |   TERN_(DELTA_AUTO_CALIBRATION, static void G33()); | ||||||
|  |  | ||||||
|   #if ENABLED(Z_STEPPER_AUTO_ALIGN) |   #if EITHER(Z_STEPPER_AUTO_ALIGN, MECHANICAL_GANTRY_CALIBRATION) | ||||||
|     static void G34(); |     static void G34(); | ||||||
|     static void M422(); |  | ||||||
|   #endif |   #endif | ||||||
|  |  | ||||||
|  |   TERN_(Z_STEPPER_AUTO_ALIGN, static void M422()); | ||||||
|  |  | ||||||
|   TERN_(ASSISTED_TRAMMING, static void G35()); |   TERN_(ASSISTED_TRAMMING, static void G35()); | ||||||
|  |  | ||||||
|   TERN_(G38_PROBE_TARGET, static void G38(const int8_t subcode)); |   TERN_(G38_PROBE_TARGET, static void G38(const int8_t subcode)); | ||||||
|   | |||||||
| @@ -422,7 +422,7 @@ | |||||||
| #elif defined(CHAMBER_HEATER_PIN) | #elif defined(CHAMBER_HEATER_PIN) | ||||||
|   #error "CHAMBER_HEATER_PIN is now HEATER_CHAMBER_PIN. Please update your configuration and/or pins." |   #error "CHAMBER_HEATER_PIN is now HEATER_CHAMBER_PIN. Please update your configuration and/or pins." | ||||||
| #elif defined(TMC_Z_CALIBRATION) | #elif defined(TMC_Z_CALIBRATION) | ||||||
|   #error "TMC_Z_CALIBRATION has been deprecated in favor of Z_STEPPER_AUTO_ALIGN. Please update your configuration." |   #error "TMC_Z_CALIBRATION has been deprecated in favor of MECHANICAL_GANTRY_CALIBRATION. Please update your configuration." | ||||||
| #elif defined(Z_MIN_PROBE_ENDSTOP) | #elif defined(Z_MIN_PROBE_ENDSTOP) | ||||||
|   #error "Z_MIN_PROBE_ENDSTOP is no longer required. Please remove it from Configuration.h." |   #error "Z_MIN_PROBE_ENDSTOP is no longer required. Please remove it from Configuration.h." | ||||||
| #elif defined(DUAL_NOZZLE_DUPLICATION_MODE) | #elif defined(DUAL_NOZZLE_DUPLICATION_MODE) | ||||||
| @@ -2788,6 +2788,21 @@ static_assert(   _ARR_TEST(3,0) && _ARR_TEST(3,1) && _ARR_TEST(3,2) | |||||||
|   #endif |   #endif | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #if ENABLED(MECHANICAL_GANTRY_CALIBRATION) | ||||||
|  |   #if NONE(HAS_MOTOR_CURRENT_DAC, HAS_MOTOR_CURRENT_SPI, HAS_MOTOR_CURRENT_DAC, HAS_TRINAMIC_CONFIG, HAS_MOTOR_CURRENT_PWM) | ||||||
|  |     #error "It is highly recommended to have adjustable current drivers to prevent damage. Disable this line to continue anyway." | ||||||
|  |   #elif !defined(GANTRY_CALIBRATION_CURRENT) | ||||||
|  |     #error "MECHANICAL_GANTRY_CALIBRATION Requires GANTRY_CALIBRATION_CURRENT to be set." | ||||||
|  |   #elif !defined(GANTRY_CALIBRATION_EXTRA_HEIGHT) | ||||||
|  |     #error "MECHANICAL_GANTRY_CALIBRATION Requires GANTRY_CALIBRATION_EXTRA_HEIGHT to be set." | ||||||
|  |   #elif !defined(GANTRY_CALIBRATION_FEEDRATE) | ||||||
|  |     #error "MECHANICAL_GANTRY_CALIBRATION Requires GANTRY_CALIBRATION_FEEDRATE to be set." | ||||||
|  |   #endif | ||||||
|  |   #if defined(GANTRY_CALIBRATION_SAFE_POSITION) && !defined(GANTRY_CALIBRATION_XY_PARK_FEEDRATE) | ||||||
|  |     #error "GANTRY_CALIBRATION_SAFE_POSITION Requires GANTRY_CALIBRATION_XY_PARK_FEEDRATE to be set." | ||||||
|  |   #endif | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #if ENABLED(PRINTCOUNTER) && DISABLED(EEPROM_SETTINGS) | #if ENABLED(PRINTCOUNTER) && DISABLED(EEPROM_SETTINGS) | ||||||
|   #error "PRINTCOUNTER requires EEPROM_SETTINGS. Please update your Configuration." |   #error "PRINTCOUNTER requires EEPROM_SETTINGS. Please update your Configuration." | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -67,6 +67,9 @@ namespace Language_en { | |||||||
|   PROGMEM Language_Str MSG_AUTO_HOME_Z                     = _UxGT("Home Z"); |   PROGMEM Language_Str MSG_AUTO_HOME_Z                     = _UxGT("Home Z"); | ||||||
|   PROGMEM Language_Str MSG_AUTO_Z_ALIGN                    = _UxGT("Auto Z-Align"); |   PROGMEM Language_Str MSG_AUTO_Z_ALIGN                    = _UxGT("Auto Z-Align"); | ||||||
|   PROGMEM Language_Str MSG_ASSISTED_TRAMMING               = _UxGT("Assisted Tramming"); |   PROGMEM Language_Str MSG_ASSISTED_TRAMMING               = _UxGT("Assisted Tramming"); | ||||||
|  |   PROGMEM Language_Str MSG_ITERATION                       = _UxGT("G34 Iteration: %i"); | ||||||
|  |   PROGMEM Language_Str MSG_DECREASING_ACCURACY             = _UxGT("Accuracy Decreasing!"); | ||||||
|  |   PROGMEM Language_Str MSG_ACCURACY_ACHIEVED               = _UxGT("Accuracy Achieved"); | ||||||
|   PROGMEM Language_Str MSG_LEVEL_BED_HOMING                = _UxGT("Homing XYZ"); |   PROGMEM Language_Str MSG_LEVEL_BED_HOMING                = _UxGT("Homing XYZ"); | ||||||
|   PROGMEM Language_Str MSG_LEVEL_BED_WAITING               = _UxGT("Click to Begin"); |   PROGMEM Language_Str MSG_LEVEL_BED_WAITING               = _UxGT("Click to Begin"); | ||||||
|   PROGMEM Language_Str MSG_LEVEL_BED_NEXT_POINT            = _UxGT("Next Point"); |   PROGMEM Language_Str MSG_LEVEL_BED_NEXT_POINT            = _UxGT("Next Point"); | ||||||
|   | |||||||
| @@ -358,7 +358,7 @@ void menu_motion() { | |||||||
|   // |   // | ||||||
|   // Auto Z-Align |   // Auto Z-Align | ||||||
|   // |   // | ||||||
|   #if ENABLED(Z_STEPPER_AUTO_ALIGN) |   #if EITHER(Z_STEPPER_AUTO_ALIGN, MECHANICAL_GANTRY_CALIBRATION) | ||||||
|     GCODES_ITEM(MSG_AUTO_Z_ALIGN, PSTR("G34")); |     GCODES_ITEM(MSG_AUTO_Z_ALIGN, PSTR("G34")); | ||||||
|   #endif |   #endif | ||||||
|  |  | ||||||
|   | |||||||
| @@ -61,7 +61,7 @@ opt_set MOTHERBOARD BOARD_COHESION3D_REMIX | |||||||
| opt_set X_DRIVER_TYPE TMC2130 | opt_set X_DRIVER_TYPE TMC2130 | ||||||
| opt_set Y_DRIVER_TYPE TMC2130 | opt_set Y_DRIVER_TYPE TMC2130 | ||||||
| opt_set Z_DRIVER_TYPE TMC2130 | opt_set Z_DRIVER_TYPE TMC2130 | ||||||
| opt_enable AUTO_BED_LEVELING_BILINEAR EEPROM_SETTINGS EEPROM_CHITCHAT \ | opt_enable AUTO_BED_LEVELING_BILINEAR EEPROM_SETTINGS EEPROM_CHITCHAT MECHANICAL_GANTRY_CALIBRATION \ | ||||||
|            TMC_USE_SW_SPI MONITOR_DRIVER_STATUS STEALTHCHOP_XY STEALTHCHOP_Z HYBRID_THRESHOLD \ |            TMC_USE_SW_SPI MONITOR_DRIVER_STATUS STEALTHCHOP_XY STEALTHCHOP_Z HYBRID_THRESHOLD \ | ||||||
|            SENSORLESS_PROBING Z_SAFE_HOMING X_STALL_SENSITIVITY Y_STALL_SENSITIVITY Z_STALL_SENSITIVITY TMC_DEBUG \ |            SENSORLESS_PROBING Z_SAFE_HOMING X_STALL_SENSITIVITY Y_STALL_SENSITIVITY Z_STALL_SENSITIVITY TMC_DEBUG \ | ||||||
|            EXPERIMENTAL_I2CBUS |            EXPERIMENTAL_I2CBUS | ||||||
|   | |||||||
| @@ -110,6 +110,7 @@ default_src_filter = +<src/*> -<src/config> -<src/HAL> +<src/HAL/shared> | |||||||
|   -<src/gcode/bedlevel/G42.cpp> |   -<src/gcode/bedlevel/G42.cpp> | ||||||
|   -<src/gcode/bedlevel/M420.cpp> |   -<src/gcode/bedlevel/M420.cpp> | ||||||
|   -<src/gcode/calibrate/G33.cpp> |   -<src/gcode/calibrate/G33.cpp> | ||||||
|  |   -<src/gcode/calibrate/G34.cpp> | ||||||
|   -<src/gcode/calibrate/G34_M422.cpp> |   -<src/gcode/calibrate/G34_M422.cpp> | ||||||
|   -<src/gcode/calibrate/G76_M192_M871.cpp> |   -<src/gcode/calibrate/G76_M192_M871.cpp> | ||||||
|   -<src/gcode/calibrate/G425.cpp> |   -<src/gcode/calibrate/G425.cpp> | ||||||
| @@ -309,6 +310,7 @@ MK2_MULTIPLEXER         = src_filter=+<src/feature/snmm.cpp> | |||||||
| EXT_SOLENOID|MANUAL_SOLENOID_CONTROL = src_filter=+<src/feature/solenoid.cpp> +<src/gcode/control/M380_M381.cpp> | EXT_SOLENOID|MANUAL_SOLENOID_CONTROL = src_filter=+<src/feature/solenoid.cpp> +<src/gcode/control/M380_M381.cpp> | ||||||
| HAS_CUTTER              = src_filter=+<src/feature/spindle_laser.cpp> +<src/gcode/control/M3-M5.cpp> | HAS_CUTTER              = src_filter=+<src/feature/spindle_laser.cpp> +<src/gcode/control/M3-M5.cpp> | ||||||
| EXPERIMENTAL_I2CBUS     = src_filter=+<src/feature/twibus.cpp> +<src/gcode/feature/i2c> | EXPERIMENTAL_I2CBUS     = src_filter=+<src/feature/twibus.cpp> +<src/gcode/feature/i2c> | ||||||
|  | MECHANICAL_GANTRY_CAL.+ = src_filter=+<src/gcode/calibrate/G34.cpp> | ||||||
| Z_STEPPER_AUTO_ALIGN    = src_filter=+<src/feature/z_stepper_align.cpp> +<src/gcode/calibrate/G34_M422.cpp> | Z_STEPPER_AUTO_ALIGN    = src_filter=+<src/feature/z_stepper_align.cpp> +<src/gcode/calibrate/G34_M422.cpp> | ||||||
| G26_MESH_VALIDATION     = src_filter=+<src/gcode/bedlevel/G26.cpp> | G26_MESH_VALIDATION     = src_filter=+<src/gcode/bedlevel/G26.cpp> | ||||||
| ASSISTED_TRAMMING       = src_filter=+<src/gcode/bedlevel/G35.cpp> | ASSISTED_TRAMMING       = src_filter=+<src/gcode/bedlevel/G35.cpp> | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user