2017-09-06 06:28:31 -05:00
|
|
|
/**
|
|
|
|
* Marlin 3D Printer Firmware
|
|
|
|
* Copyright (C) 2016 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 <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2017-09-17 00:36:30 -05:00
|
|
|
#include "../../inc/MarlinConfig.h"
|
|
|
|
|
|
|
|
#include "../gcode.h"
|
|
|
|
#include "../../module/motion.h"
|
|
|
|
#include "../../module/stepper.h"
|
|
|
|
|
2017-11-14 00:03:17 -06:00
|
|
|
#if ENABLED(M114_DETAIL)
|
2017-09-06 06:28:31 -05:00
|
|
|
|
2017-12-09 02:10:54 -06:00
|
|
|
void report_xyze(const float pos[], const uint8_t n = 4, const uint8_t precision = 3) {
|
2017-09-06 06:28:31 -05:00
|
|
|
char str[12];
|
|
|
|
for (uint8_t i = 0; i < n; i++) {
|
|
|
|
SERIAL_CHAR(' ');
|
|
|
|
SERIAL_CHAR(axis_codes[i]);
|
|
|
|
SERIAL_CHAR(':');
|
2018-11-29 16:58:58 -06:00
|
|
|
SERIAL_ECHO(dtostrf(pos[i], 8, precision, str));
|
2017-09-06 06:28:31 -05:00
|
|
|
}
|
|
|
|
SERIAL_EOL();
|
|
|
|
}
|
|
|
|
|
2017-12-09 02:10:54 -06:00
|
|
|
inline void report_xyz(const float pos[]) { report_xyze(pos, 3); }
|
2017-09-06 06:28:31 -05:00
|
|
|
|
|
|
|
void report_current_position_detail() {
|
|
|
|
|
2018-11-29 16:58:58 -06:00
|
|
|
SERIAL_ECHOPGM("\nLogical:");
|
2017-11-02 23:59:42 -05:00
|
|
|
const float logical[XYZ] = {
|
|
|
|
LOGICAL_X_POSITION(current_position[X_AXIS]),
|
|
|
|
LOGICAL_Y_POSITION(current_position[Y_AXIS]),
|
|
|
|
LOGICAL_Z_POSITION(current_position[Z_AXIS])
|
|
|
|
};
|
2018-01-23 18:50:37 -06:00
|
|
|
report_xyz(logical);
|
2017-09-06 06:28:31 -05:00
|
|
|
|
2018-11-29 16:58:58 -06:00
|
|
|
SERIAL_ECHOPGM("Raw: ");
|
2017-11-02 23:59:42 -05:00
|
|
|
report_xyz(current_position);
|
2017-09-06 06:28:31 -05:00
|
|
|
|
2017-11-14 02:13:38 -06:00
|
|
|
float leveled[XYZ] = { current_position[X_AXIS], current_position[Y_AXIS], current_position[Z_AXIS] };
|
|
|
|
|
2018-09-16 22:24:15 -04:00
|
|
|
#if HAS_LEVELING
|
2018-11-29 16:58:58 -06:00
|
|
|
SERIAL_ECHOPGM("Leveled:");
|
2017-11-12 23:03:38 -06:00
|
|
|
planner.apply_leveling(leveled);
|
|
|
|
report_xyz(leveled);
|
2017-09-06 06:28:31 -05:00
|
|
|
|
2018-11-29 16:58:58 -06:00
|
|
|
SERIAL_ECHOPGM("UnLevel:");
|
2017-11-12 23:03:38 -06:00
|
|
|
float unleveled[XYZ] = { leveled[X_AXIS], leveled[Y_AXIS], leveled[Z_AXIS] };
|
|
|
|
planner.unapply_leveling(unleveled);
|
|
|
|
report_xyz(unleveled);
|
|
|
|
#endif
|
2017-09-06 06:28:31 -05:00
|
|
|
|
|
|
|
#if IS_KINEMATIC
|
|
|
|
#if IS_SCARA
|
2018-11-29 16:58:58 -06:00
|
|
|
SERIAL_ECHOPGM("ScaraK: ");
|
2017-09-06 06:28:31 -05:00
|
|
|
#else
|
2018-11-29 16:58:58 -06:00
|
|
|
SERIAL_ECHOPGM("DeltaK: ");
|
2017-09-06 06:28:31 -05:00
|
|
|
#endif
|
|
|
|
inverse_kinematics(leveled); // writes delta[]
|
|
|
|
report_xyz(delta);
|
|
|
|
#endif
|
|
|
|
|
2018-05-12 01:38:02 -05:00
|
|
|
planner.synchronize();
|
2018-05-03 20:51:10 -05:00
|
|
|
|
2018-11-29 16:58:58 -06:00
|
|
|
SERIAL_ECHOPGM("Stepper:");
|
2017-12-10 19:12:00 -06:00
|
|
|
LOOP_XYZE(i) {
|
|
|
|
SERIAL_CHAR(' ');
|
|
|
|
SERIAL_CHAR(axis_codes[i]);
|
|
|
|
SERIAL_CHAR(':');
|
2018-11-29 16:58:58 -06:00
|
|
|
SERIAL_ECHO(stepper.position((AxisEnum)i));
|
2017-12-10 19:12:00 -06:00
|
|
|
}
|
|
|
|
SERIAL_EOL();
|
2017-09-06 06:28:31 -05:00
|
|
|
|
|
|
|
#if IS_SCARA
|
|
|
|
const float deg[XYZ] = {
|
2018-05-12 09:59:11 -05:00
|
|
|
planner.get_axis_position_degrees(A_AXIS),
|
|
|
|
planner.get_axis_position_degrees(B_AXIS)
|
2017-09-06 06:28:31 -05:00
|
|
|
};
|
2018-11-29 16:58:58 -06:00
|
|
|
SERIAL_ECHOPGM("Degrees:");
|
2017-09-06 06:28:31 -05:00
|
|
|
report_xyze(deg, 2);
|
|
|
|
#endif
|
|
|
|
|
2018-11-29 16:58:58 -06:00
|
|
|
SERIAL_ECHOPGM("FromStp:");
|
2017-09-06 06:28:31 -05:00
|
|
|
get_cartesian_from_steppers(); // writes cartes[XYZ] (with forward kinematics)
|
2018-05-12 09:59:11 -05:00
|
|
|
const float from_steppers[XYZE] = { cartes[X_AXIS], cartes[Y_AXIS], cartes[Z_AXIS], planner.get_axis_position_mm(E_AXIS) };
|
2017-09-06 06:28:31 -05:00
|
|
|
report_xyze(from_steppers);
|
|
|
|
|
|
|
|
const float diff[XYZE] = {
|
|
|
|
from_steppers[X_AXIS] - leveled[X_AXIS],
|
|
|
|
from_steppers[Y_AXIS] - leveled[Y_AXIS],
|
|
|
|
from_steppers[Z_AXIS] - leveled[Z_AXIS],
|
|
|
|
from_steppers[E_AXIS] - current_position[E_AXIS]
|
|
|
|
};
|
2018-11-29 16:58:58 -06:00
|
|
|
SERIAL_ECHOPGM("Differ: ");
|
2017-09-06 06:28:31 -05:00
|
|
|
report_xyze(diff);
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif // M114_DETAIL
|
|
|
|
|
|
|
|
/**
|
|
|
|
* M114: Report current position to host
|
|
|
|
*/
|
2017-09-17 00:36:30 -05:00
|
|
|
void GcodeSuite::M114() {
|
2017-09-06 06:28:31 -05:00
|
|
|
|
2017-11-14 00:03:17 -06:00
|
|
|
#if ENABLED(M114_DETAIL)
|
2017-09-06 06:28:31 -05:00
|
|
|
if (parser.seen('D')) {
|
|
|
|
report_current_position_detail();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2018-05-12 01:38:02 -05:00
|
|
|
planner.synchronize();
|
2017-09-06 06:28:31 -05:00
|
|
|
report_current_position();
|
|
|
|
}
|