Fix NAN mesh entries with ABL_BILINEAR_SUBDIVISION (#20143)
This commit is contained in:
parent
18869c666f
commit
7848096acb
|
@ -161,6 +161,14 @@ void print_bilinear_leveling_grid() {
|
||||||
#define LINEAR_EXTRAPOLATION(E, I) ((E) * 2 - (I))
|
#define LINEAR_EXTRAPOLATION(E, I) ((E) * 2 - (I))
|
||||||
float bed_level_virt_coord(const uint8_t x, const uint8_t y) {
|
float bed_level_virt_coord(const uint8_t x, const uint8_t y) {
|
||||||
uint8_t ep = 0, ip = 1;
|
uint8_t ep = 0, ip = 1;
|
||||||
|
if (x > GRID_MAX_POINTS_X + 1 || y > GRID_MAX_POINTS_Y + 1) {
|
||||||
|
// The requested point requires extrapolating two points beyond the mesh.
|
||||||
|
// These values are only requested for the edges of the mesh, which are always an actual mesh point,
|
||||||
|
// and do not require interpolation. When interpolation is not needed, this "Mesh + 2" point is
|
||||||
|
// cancelled out in bed_level_virt_cmr and does not impact the result. Return 0.0 rather than
|
||||||
|
// making this function more complex by extrapolating two points.
|
||||||
|
return 0.0;
|
||||||
|
}
|
||||||
if (!x || x == ABL_TEMP_POINTS_X - 1) {
|
if (!x || x == ABL_TEMP_POINTS_X - 1) {
|
||||||
if (x) {
|
if (x) {
|
||||||
ep = GRID_MAX_POINTS_X - 1;
|
ep = GRID_MAX_POINTS_X - 1;
|
||||||
|
|
Loading…
Reference in a new issue