|  | @@ -20,7 +20,7 @@ float   world2machine_shift[2];
 | 
												
													
														
															|  |  #define WEIGHT_FIRST_ROW_Y_LOW  (0.0f)
 |  |  #define WEIGHT_FIRST_ROW_Y_LOW  (0.0f)
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |  #define BED_ZERO_REF_X (- 22.f + X_PROBE_OFFSET_FROM_EXTRUDER) // -22 + 23 = 1
 |  |  #define BED_ZERO_REF_X (- 22.f + X_PROBE_OFFSET_FROM_EXTRUDER) // -22 + 23 = 1
 | 
												
													
														
															|  | -#define BED_ZERO_REF_Y (- 0.6f + Y_PROBE_OFFSET_FROM_EXTRUDER) // -0.6 + 5 = 4.4
 |  | 
 | 
												
													
														
															|  | 
 |  | +#define BED_ZERO_REF_Y (- 0.6f + Y_PROBE_OFFSET_FROM_EXTRUDER + 4.f) // -0.6 + 5 + 4 = 8.4
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |  // Scaling of the real machine axes against the programmed dimensions in the firmware.
 |  |  // Scaling of the real machine axes against the programmed dimensions in the firmware.
 | 
												
													
														
															|  |  // The correction is tiny, here around 0.5mm on 250mm length.
 |  |  // The correction is tiny, here around 0.5mm on 250mm length.
 | 
												
											
												
													
														
															|  | @@ -56,10 +56,10 @@ const float bed_skew_angle_extreme = (0.25f * M_PI / 180.f);
 | 
												
													
														
															|  |  // Positions of the bed reference points in the machine coordinates, referenced to the P.I.N.D.A sensor.
 |  |  // Positions of the bed reference points in the machine coordinates, referenced to the P.I.N.D.A sensor.
 | 
												
													
														
															|  |  // The points are the following: center front, center right, center rear, center left.
 |  |  // The points are the following: center front, center right, center rear, center left.
 | 
												
													
														
															|  |  const float bed_ref_points_4[] PROGMEM = {
 |  |  const float bed_ref_points_4[] PROGMEM = {
 | 
												
													
														
															|  | -	13.f - BED_ZERO_REF_X,   10.4f - 4.f - BED_ZERO_REF_Y,
 |  | 
 | 
												
													
														
															|  | -	221.f - BED_ZERO_REF_X,  10.4f - 4.f - BED_ZERO_REF_Y,
 |  | 
 | 
												
													
														
															|  | -	221.f - BED_ZERO_REF_X, 202.4f - 4.f - BED_ZERO_REF_Y,
 |  | 
 | 
												
													
														
															|  | -	13.f - BED_ZERO_REF_X, 202.4f - 4.f - BED_ZERO_REF_Y
 |  | 
 | 
												
													
														
															|  | 
 |  | +	13.f - BED_ZERO_REF_X,   10.4f - BED_ZERO_REF_Y,
 | 
												
													
														
															|  | 
 |  | +	221.f - BED_ZERO_REF_X,  10.4f - BED_ZERO_REF_Y,
 | 
												
													
														
															|  | 
 |  | +	221.f - BED_ZERO_REF_X, 202.4f - BED_ZERO_REF_Y,
 | 
												
													
														
															|  | 
 |  | +	13.f - BED_ZERO_REF_X, 202.4f - BED_ZERO_REF_Y
 | 
												
													
														
															|  |  };
 |  |  };
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  |  const float bed_ref_points[] PROGMEM = {
 |  |  const float bed_ref_points[] PROGMEM = {
 | 
												
											
												
													
														
															|  | @@ -711,14 +711,22 @@ void world2machine_reset()
 | 
												
													
														
															|  |      world2machine_update(vx, vy, cntr);
 |  |      world2machine_update(vx, vy, cntr);
 | 
												
													
														
															|  |  }
 |  |  }
 | 
												
													
														
															|  |  
 |  |  
 | 
												
													
														
															|  | 
 |  | +static void world2machine_default()
 | 
												
													
														
															|  | 
 |  | +{
 | 
												
													
														
															|  | 
 |  | +#ifdef DEFAULT_Y_OFFSET
 | 
												
													
														
															|  | 
 |  | +    const float vx[] = { 1.f, 0.f };
 | 
												
													
														
															|  | 
 |  | +    const float vy[] = { 0.f, 1.f };
 | 
												
													
														
															|  | 
 |  | +    const float cntr[] = { 0.f, DEFAULT_Y_OFFSET };
 | 
												
													
														
															|  | 
 |  | +    world2machine_update(vx, vy, cntr);
 | 
												
													
														
															|  | 
 |  | +#else
 | 
												
													
														
															|  | 
 |  | +    world2machine_reset();
 | 
												
													
														
															|  | 
 |  | +#endif
 | 
												
													
														
															|  | 
 |  | +}
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  |  void world2machine_revert_to_uncorrected()
 |  |  void world2machine_revert_to_uncorrected()
 | 
												
													
														
															|  |  {
 |  |  {
 | 
												
													
														
															|  |      if (world2machine_correction_mode != WORLD2MACHINE_CORRECTION_NONE) {
 |  |      if (world2machine_correction_mode != WORLD2MACHINE_CORRECTION_NONE) {
 | 
												
													
														
															|  | -        // Reset the machine correction matrix.
 |  | 
 | 
												
													
														
															|  | -        const float vx[] = { 1.f, 0.f };
 |  | 
 | 
												
													
														
															|  | -        const float vy[] = { 0.f, 1.f };
 |  | 
 | 
												
													
														
															|  | -        const float cntr[] = { 0.f, 0.f };
 |  | 
 | 
												
													
														
															|  | -        world2machine_update(vx, vy, cntr);
 |  | 
 | 
												
													
														
															|  | 
 |  | +        world2machine_reset();
 | 
												
													
														
															|  |          // Wait for the motors to stop and update the current position with the absolute values.
 |  |          // Wait for the motors to stop and update the current position with the absolute values.
 | 
												
													
														
															|  |          st_synchronize();
 |  |          st_synchronize();
 | 
												
													
														
															|  |          current_position[X_AXIS] = st_get_position_mm(X_AXIS);
 |  |          current_position[X_AXIS] = st_get_position_mm(X_AXIS);
 | 
												
											
												
													
														
															|  | @@ -789,7 +797,7 @@ void world2machine_initialize()
 | 
												
													
														
															|  |      if (reset) {
 |  |      if (reset) {
 | 
												
													
														
															|  |  //        SERIAL_ECHOLNPGM("Invalid bed correction matrix. Resetting to identity.");
 |  |  //        SERIAL_ECHOLNPGM("Invalid bed correction matrix. Resetting to identity.");
 | 
												
													
														
															|  |          reset_bed_offset_and_skew();
 |  |          reset_bed_offset_and_skew();
 | 
												
													
														
															|  | -        world2machine_reset();
 |  | 
 | 
												
													
														
															|  | 
 |  | +        world2machine_default();
 | 
												
													
														
															|  |      } else {
 |  |      } else {
 | 
												
													
														
															|  |          world2machine_update(vec_x, vec_y, cntr);
 |  |          world2machine_update(vec_x, vec_y, cntr);
 | 
												
													
														
															|  |          /*
 |  |          /*
 |