My Marlin configs for Fabrikator Mini and CTC i3 Pro B
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

x_twist.cpp 2.0KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. /**
  2. * Marlin 3D Printer Firmware
  3. * Copyright (c) 2021 MarlinFirmware [https://github.com/MarlinFirmware/Marlin]
  4. *
  5. * Based on Sprinter and grbl.
  6. * Copyright (c) 2011 Camiel Gubbels / Erik van der Zalm
  7. *
  8. * This program is free software: you can redistribute it and/or modify
  9. * it under the terms of the GNU General Public License as published by
  10. * the Free Software Foundation, either version 3 of the License, or
  11. * (at your option) any later version.
  12. *
  13. * This program is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. * GNU General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU General Public License
  19. * along with this program. If not, see <https://www.gnu.org/licenses/>.
  20. *
  21. */
  22. #include "../inc/MarlinConfig.h"
  23. #if ENABLED(X_AXIS_TWIST_COMPENSATION)
  24. #include "x_twist.h"
  25. #include "../module/probe.h"
  26. XATC xatc;
  27. bool XATC::enabled;
  28. float XATC::spacing, XATC::start;
  29. xatc_array_t XATC::z_offset; // Initialized by settings.load()
  30. void XATC::reset() {
  31. constexpr float xzo[] = XATC_Z_OFFSETS;
  32. static_assert(COUNT(xzo) == XATC_MAX_POINTS, "XATC_Z_OFFSETS is the wrong size.");
  33. COPY(z_offset, xzo);
  34. start = probe.min_x();
  35. spacing = (probe.max_x() - start) / (XATC_MAX_POINTS - 1);
  36. enabled = true;
  37. }
  38. void XATC::print_points() {
  39. SERIAL_ECHOLNPGM(" X-Twist Correction:");
  40. LOOP_L_N(x, XATC_MAX_POINTS) {
  41. SERIAL_CHAR(' ');
  42. if (!isnan(z_offset[x]))
  43. serial_offset(z_offset[x]);
  44. else
  45. LOOP_L_N(i, 6) SERIAL_CHAR(i ? '=' : ' ');
  46. }
  47. SERIAL_EOL();
  48. }
  49. float lerp(const_float_t t, const_float_t a, const_float_t b) { return a + t * (b - a); }
  50. float XATC::compensation(const xy_pos_t &raw) {
  51. if (!enabled) return 0;
  52. if (NEAR_ZERO(spacing)) return 0;
  53. float t = (raw.x - start) / spacing;
  54. const int i = constrain(FLOOR(t), 0, XATC_MAX_POINTS - 2);
  55. t -= i;
  56. return lerp(t, z_offset[i], z_offset[i + 1]);
  57. }
  58. #endif // X_AXIS_TWIST_COMPENSATION