Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in
Toggle navigation
M
MarlinKimbra
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
machinery
MarlinKimbra
Commits
b97aff98
Commit
b97aff98
authored
Aug 09, 2015
by
MagoKimbra
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
update
parent
ca17a689
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
93 additions
and
106 deletions
+93
-106
Marlin_main.cpp
MarlinKimbra/Marlin_main.cpp
+84
-96
cardreader.cpp
MarlinKimbra/cardreader.cpp
+8
-9
dogm_bitmaps.h
MarlinKimbra/dogm_bitmaps.h
+1
-1
No files found.
MarlinKimbra/Marlin_main.cpp
View file @
b97aff98
...
@@ -3279,11 +3279,11 @@ inline void gcode_G28() {
...
@@ -3279,11 +3279,11 @@ inline void gcode_G28() {
}
}
bool
dryrun
=
code_seen
(
'D'
)
||
code_seen
(
'd'
),
bool
dryrun
=
code_seen
(
'D'
)
||
code_seen
(
'd'
),
deploy_probe_for_each_reading
=
code_seen
(
'E'
)
||
code_seen
(
'e'
)
;
deploy_probe_for_each_reading
=
code_seen
(
'E'
);
#ifdef AUTO_BED_LEVELING_GRID
#ifdef AUTO_BED_LEVELING_GRID
bool
do_topography_map
=
verbose_level
>
2
||
code_seen
(
'T'
)
||
code_seen
(
't'
)
;
bool
do_topography_map
=
verbose_level
>
2
||
code_seen
(
'T'
);
if
(
verbose_level
>
0
)
{
if
(
verbose_level
>
0
)
{
ECHO_LM
(
DB
,
"G29 Auto Bed Leveling"
);
ECHO_LM
(
DB
,
"G29 Auto Bed Leveling"
);
...
@@ -3306,8 +3306,8 @@ inline void gcode_G28() {
...
@@ -3306,8 +3306,8 @@ inline void gcode_G28() {
bool
left_out_l
=
left_probe_bed_position
<
MIN_PROBE_X
,
bool
left_out_l
=
left_probe_bed_position
<
MIN_PROBE_X
,
left_out
=
left_out_l
||
left_probe_bed_position
>
right_probe_bed_position
-
MIN_PROBE_EDGE
,
left_out
=
left_out_l
||
left_probe_bed_position
>
right_probe_bed_position
-
MIN_PROBE_EDGE
,
right_out_r
=
right_probe_bed_position
>
MAX_PROBE_X
,
right_out_r
=
right_probe_bed_position
>
MAX_PROBE_X
,
right_out
=
right_out_r
||
right_probe_bed_position
<
left_probe_bed_position
+
MIN_PROBE_EDGE
;
right_out
=
right_out_r
||
right_probe_bed_position
<
left_probe_bed_position
+
MIN_PROBE_EDGE
,
bool
front_out_f
=
front_probe_bed_position
<
MIN_PROBE_Y
,
front_out_f
=
front_probe_bed_position
<
MIN_PROBE_Y
,
front_out
=
front_out_f
||
front_probe_bed_position
>
back_probe_bed_position
-
MIN_PROBE_EDGE
,
front_out
=
front_out_f
||
front_probe_bed_position
>
back_probe_bed_position
-
MIN_PROBE_EDGE
,
back_out_b
=
back_probe_bed_position
>
MAX_PROBE_Y
,
back_out_b
=
back_probe_bed_position
>
MAX_PROBE_Y
,
back_out
=
back_out_b
||
back_probe_bed_position
<
front_probe_bed_position
+
MIN_PROBE_EDGE
;
back_out
=
back_out_b
||
back_probe_bed_position
<
front_probe_bed_position
+
MIN_PROBE_EDGE
;
...
@@ -3393,7 +3393,7 @@ inline void gcode_G28() {
...
@@ -3393,7 +3393,7 @@ inline void gcode_G28() {
xInc
=
-
1
;
xInc
=
-
1
;
}
}
// If
topo_flag
is set then don't zig-zag. Just scan in one direction.
// If
do_topography_map
is set then don't zig-zag. Just scan in one direction.
// This gets the probe points in more readable order.
// This gets the probe points in more readable order.
if
(
!
do_topography_map
)
zig
=
!
zig
;
if
(
!
do_topography_map
)
zig
=
!
zig
;
for
(
int
xCount
=
xStart
;
xCount
!=
xStop
;
xCount
+=
xInc
)
{
for
(
int
xCount
=
xStart
;
xCount
!=
xStop
;
xCount
+=
xInc
)
{
...
@@ -3433,72 +3433,50 @@ inline void gcode_G28() {
...
@@ -3433,72 +3433,50 @@ inline void gcode_G28() {
clean_up_after_endstop_move
();
clean_up_after_endstop_move
();
// solve lsq problem
// solve lsq problem
double
*
plane_equation_coefficients
=
qr_solve
(
abl2
,
3
,
eqnAMatrix
,
eqnBVector
);
double
plane_equation_coefficients
[
3
];
qr_solve
(
plane_equation_coefficients
,
abl2
,
3
,
eqnAMatrix
,
eqnBVector
);
mean
/=
abl2
;
if
(
verbose_level
)
{
if
(
verbose_level
)
{
ECHO_SMV
(
DB
,
"Eqn coefficients: a: "
,
plane_equation_coefficients
[
0
],
8
);
ECHO_SMV
(
DB
,
"Eqn coefficients: a: "
,
plane_equation_coefficients
[
0
],
8
);
ECHO_MV
(
" b: "
,
plane_equation_coefficients
[
1
],
8
);
ECHO_MV
(
" b: "
,
plane_equation_coefficients
[
1
],
8
);
ECHO_EMV
(
" d: "
,
plane_equation_coefficients
[
2
],
8
);
ECHO_EMV
(
" d: "
,
plane_equation_coefficients
[
2
],
8
);
if
(
verbose_level
>
2
)
{
ECHO_LMV
(
DB
,
"Mean of sampled points: "
,
mean
,
8
);
}
}
}
if
(
!
dryrun
)
set_bed_level_equation_lsq
(
plane_equation_coefficients
);
if
(
!
dryrun
)
set_bed_level_equation_lsq
(
plane_equation_coefficients
);
free
(
plane_equation_coefficients
);
free
(
plane_equation_coefficients
);
matrix_3x3
inverse_bed_level_matrix
=
matrix_3x3
::
transpose
(
plan_bed_level_matrix
);
// inverse bed level matrix
// search minimum and maximum point on bed in rotated coordinates
float
rot_diff
=
0
,
rot_min_diff
=
Z_MAX_POS
,
rot_max_diff
=
-
Z_MAX_POS
;
for
(
int
ProbeCount
=
0
;
ProbeCount
<
abl2
;
ProbeCount
++
)
{
vector_3
probe_point
=
vector_3
(
eqnAMatrix
[
ProbeCount
+
0
*
abl2
],
eqnAMatrix
[
ProbeCount
+
1
*
abl2
],
eqnBVector
[
ProbeCount
]);
probe_point
.
apply_rotation
(
inverse_bed_level_matrix
);
float
rot_diff
=
probe_point
.
z
;
if
(
rot_diff
<
rot_min_diff
)
rot_min_diff
=
rot_diff
;
if
(
rot_diff
>
rot_max_diff
)
rot_max_diff
=
rot_diff
;
}
//ECHO_LMV(DB, "rot_min_diff=", rot_min_diff, 5);
//ECHO_LMV(DB, "rot_max_diff=", rot_max_diff, 5);
//ECHO_LMV(DB, "difference=", rot_max_diff - rot_min_diff, 5);
// Show the Topography map if enabled
// Show the Topography map if enabled
if
(
do_topography_map
)
{
if
(
do_topography_map
)
{
// search minimum measured Z
float
diff
=
0
,
min_diff
=
Z_MAX_POS
;
for
(
int
ProbeCount
=
0
;
ProbeCount
<
abl2
;
ProbeCount
++
)
{
diff
=
eqnBVector
[
ProbeCount
];
if
(
diff
<
min_diff
)
min_diff
=
diff
;
}
//ECHO_LMV(DB, "min_diff=", min_diff, 5);
ECHO_LM
(
DB
,
"Bed Height Topography:
\n
"
);
ECHO_LM
(
DB
,
"+-----------+
\n
"
);
ECHO_LM
(
DB
,
"+-----------+
\n
"
);
ECHO_LM
(
DB
,
"|...Back....|
\n
"
);
ECHO_LM
(
DB
,
"|...Back....|
\n
"
);
ECHO_LM
(
DB
,
"|Left..Right|
\n
"
);
ECHO_LM
(
DB
,
"|Left..Right|
\n
"
);
ECHO_LM
(
DB
,
"|...Front...|
\n
"
);
ECHO_LM
(
DB
,
"|...Front...|
\n
"
);
ECHO_LM
(
DB
,
"+-----------+
\n
"
);
ECHO_LM
(
DB
,
"+-----------+
\n
"
);
ECHO_LM
(
DB
,
"Bed Height Topography:
\n
"
);
for
(
int
yy
=
auto_bed_leveling_grid_points
-
1
;
yy
>=
0
;
yy
--
)
{
float
min_diff
=
999
;
ECHO_S
(
DB
);
for
(
int
xx
=
0
;
xx
<
auto_bed_leveling_grid_points
;
xx
++
)
{
int
ind
=
yy
*
auto_bed_leveling_grid_points
+
xx
;
float
diff
=
eqnBVector
[
ind
];
if
(
diff
>=
0.0
)
ECHO_M
(
" +"
);
// Include + for column alignment
else
ECHO_M
(
" "
);
ECHO_V
(
diff
,
5
);
}
// xx
ECHO_E
;
}
// yy
ECHO_E
;
ECHO_LM
(
DB
,
" Corrected Bed Topography:
\n
"
);
for
(
int
yy
=
auto_bed_leveling_grid_points
-
1
;
yy
>=
0
;
yy
--
)
{
for
(
int
yy
=
auto_bed_leveling_grid_points
-
1
;
yy
>=
0
;
yy
--
)
{
ECHO_S
(
DB
);
ECHO_S
(
DB
);
for
(
int
xx
=
0
;
xx
<
auto_bed_leveling_grid_points
;
xx
++
)
{
for
(
int
xx
=
0
;
xx
<
auto_bed_leveling_grid_points
;
xx
++
)
{
int
ind
=
yy
*
auto_bed_leveling_grid_points
+
xx
;
int
ind
=
yy
*
auto_bed_leveling_grid_points
+
xx
;
float
diff
=
eqnBVector
[
ind
]
-
min_diff
;
float
diff
=
eqnBVector
[
ind
]
-
mean
;
float
x_tmp
=
eqnAMatrix
[
ind
+
0
*
abl2
],
y_tmp
=
eqnAMatrix
[
ind
+
1
*
abl2
],
z_tmp
=
0
;
apply_rotation_xyz
(
plan_bed_level_matrix
,
x_tmp
,
y_tmp
,
z_tmp
);
if
(
eqnBVector
[
ind
]
-
z_tmp
<
min_diff
)
min_diff
=
eqnBVector
[
ind
]
-
z_tmp
;
if
(
diff
>=
0.0
)
if
(
diff
>=
0.0
)
ECHO_M
(
" +"
);
// Include + for column alignment
ECHO_M
(
" +"
);
// Include + for column alignment
else
else
...
@@ -3508,38 +3486,21 @@ inline void gcode_G28() {
...
@@ -3508,38 +3486,21 @@ inline void gcode_G28() {
ECHO_E
;
ECHO_E
;
}
// yy
}
// yy
ECHO_E
;
ECHO_E
;
if
(
verbose_level
>
3
)
{
ECHO_SM
(
DB
,
" Corrected Bed Topography in new coordinates:
\n
"
);
ECHO_LM
(
DB
,
" Corrected Bed Height vs. Bed Topology:
\n
"
);
for
(
int
yy
=
auto_bed_leveling_grid_points
-
1
;
yy
>=
0
;
yy
--
)
{
for
(
int
yy
=
auto_bed_leveling_grid_points
-
1
;
yy
>=
0
;
yy
--
)
{
ECHO_S
(
DB
);
ECHO_S
(
DB
);
for
(
int
xx
=
0
;
xx
<
auto_bed_leveling_grid_points
;
xx
++
)
{
for
(
int
xx
=
0
;
xx
<
auto_bed_leveling_grid_points
;
xx
++
)
{
int
ind
=
yy
*
auto_bed_leveling_grid_points
+
xx
;
int
ind
=
yy
*
auto_bed_leveling_grid_points
+
xx
;
vector_3
probe_point
=
vector_3
(
eqnAMatrix
[
ind
+
0
*
abl2
],
eqnAMatrix
[
ind
+
1
*
abl2
],
eqnBVector
[
ind
]);
float
x_tmp
=
eqnAMatrix
[
ind
+
0
*
abl2
],
probe_point
.
apply_rotation
(
inverse_bed_level_matrix
);
y_tmp
=
eqnAMatrix
[
ind
+
1
*
abl2
],
float
diff
=
probe_point
.
z
-
rot_min_diff
;
z_tmp
=
0
;
if
(
diff
>=
0.0
)
ECHO_M
(
" +"
);
// Include + for column alignment
else
ECHO_M
(
" "
);
ECHO_V
(
diff
,
5
);
}
// xx
ECHO_E
;
}
// yy
ECHO_E
;
ECHO_LM
(
DB
,
" Height from Bed to Nozzle :
\n
"
);
apply_rotation_xyz
(
plan_bed_level_matrix
,
x_tmp
,
y_tmp
,
z_tmp
);
ECHO_LM
(
DB
,
" (+) is airprinting, (-) is touch under bed surface
\n
"
);
for
(
int
yy
=
auto_bed_leveling_grid_points
-
1
;
yy
>=
0
;
yy
--
)
{
float
diff
=
eqnBVector
[
ind
]
-
z_tmp
-
min_diff
;
ECHO_S
(
DB
);
for
(
int
xx
=
0
;
xx
<
auto_bed_leveling_grid_points
;
xx
++
)
{
int
ind
=
yy
*
auto_bed_leveling_grid_points
+
xx
;
vector_3
probe_point
=
vector_3
(
eqnAMatrix
[
ind
+
0
*
abl2
],
eqnAMatrix
[
ind
+
1
*
abl2
],
eqnBVector
[
ind
]);
probe_point
.
apply_rotation
(
inverse_bed_level_matrix
);
float
diff
=
-
(
probe_point
.
z
-
rot_max_diff
);
if
(
diff
>=
0.0
)
if
(
diff
>=
0.0
)
ECHO_M
(
" +"
);
ECHO_M
(
" +"
);
// Include + for column alignment
// Include + for column alignment
else
else
ECHO_M
(
" "
);
ECHO_M
(
" "
);
ECHO_V
(
diff
,
5
);
ECHO_V
(
diff
,
5
);
...
@@ -3548,7 +3509,7 @@ inline void gcode_G28() {
...
@@ -3548,7 +3509,7 @@ inline void gcode_G28() {
}
// yy
}
// yy
ECHO_E
;
ECHO_E
;
}
}
}
//do_topography_map
#else // !AUTO_BED_LEVELING_GRID
#else // !AUTO_BED_LEVELING_GRID
// Actions for each probe
// Actions for each probe
...
@@ -3571,21 +3532,48 @@ inline void gcode_G28() {
...
@@ -3571,21 +3532,48 @@ inline void gcode_G28() {
plan_bed_level_matrix
.
debug
(
"Bed Level Correction Matrix:"
);
plan_bed_level_matrix
.
debug
(
"Bed Level Correction Matrix:"
);
if
(
!
dryrun
)
{
if
(
!
dryrun
)
{
int
ind
=
abl2
-
1
;
// last point probe = current point
// Correct the Z height difference from z-probe position and hotend tip position.
vector_3
probe_point
=
vector_3
(
eqnAMatrix
[
ind
+
0
*
abl2
],
eqnAMatrix
[
ind
+
1
*
abl2
],
eqnBVector
[
ind
]);
// The Z height on homing is measured by Z-Probe, but the probe is quite far from the hotend.
probe_point
.
apply_rotation
(
inverse_bed_level_matrix
);
// When the bed is uneven, this height must be corrected.
current_position
[
Z_AXIS
]
=
probe_point
.
z
-
rot_max_diff
-
zprobe_zoffset
;
float
x_tmp
=
current_position
[
X_AXIS
]
+
X_PROBE_OFFSET_FROM_EXTRUDER
,
y_tmp
=
current_position
[
Y_AXIS
]
+
Y_PROBE_OFFSET_FROM_EXTRUDER
,
z_tmp
=
current_position
[
Z_AXIS
],
real_z
=
st_get_position_mm
(
Z_AXIS
);
//get the real Z (since plan_get_position is now correcting the plane)
apply_rotation_xyz
(
plan_bed_level_matrix
,
x_tmp
,
y_tmp
,
z_tmp
);
// Apply the correction sending the probe offset
// Get the current Z position and send it to the planner.
//
// >> (z_tmp - real_z) : The rotated current Z minus the uncorrected Z (most recent plan_set_position/sync_plan_position)
//
// >> zprobe_zoffset : Z distance from nozzle to probe (set by default, M851, EEPROM, or Menu)
//
// >> Z_RAISE_AFTER_PROBING : The distance the probe will have lifted after the last probe
//
// >> Should home_offset[Z_AXIS] be included?
//
// Discussion: home_offset[Z_AXIS] was applied in G28 to set the starting Z.
// If Z is not tweaked in G29 -and- the Z probe in G29 is not actually "homing" Z...
// then perhaps it should not be included here. The purpose of home_offset[] is to
// adjust for inaccurate endstops, not for reasonably accurate probes. If it were
// added here, it could be seen as a compensating factor for the Z probe.
//
current_position
[
Z_AXIS
]
=
-
zprobe_zoffset
+
(
z_tmp
-
real_z
)
#if HAS_SERVO_ENDSTOPS || ENABLED(Z_PROBE_SLED)
+
Z_RAISE_AFTER_PROBING
#endif
;
// current_position[Z_AXIS] += home_offset[Z_AXIS]; // The probe determines Z=0, not "Z home"
sync_plan_position
();
sync_plan_position
();
//ECHO_LMV(DB, "current_position[Z_AXIS]=", current_position[Z_AXIS], 5);
}
}
#ifdef Z_PROBE_SLED
#ifdef Z_PROBE_SLED
dock_sled
(
true
,
-
SLED_DOCKING_OFFSET
);
// dock the probe, correcting for over-travel
dock_sled
(
true
);
// dock the probe
#endif
#endif
}
}
#if
ndef Z_PROBE_SLED
#if
DISABLED(Z_PROBE_SLED)
inline
void
gcode_G30
()
{
inline
void
gcode_G30
()
{
deploy_z_probe
();
// Engage Z Servo endstop if available
deploy_z_probe
();
// Engage Z Servo endstop if available
st_synchronize
();
st_synchronize
();
...
...
MarlinKimbra/cardreader.cpp
View file @
b97aff98
...
@@ -56,22 +56,21 @@ void CardReader::lsDive(const char *prepend, SdFile parent, const char * const m
...
@@ -56,22 +56,21 @@ void CardReader::lsDive(const char *prepend, SdFile parent, const char * const m
// If the entry is a directory and the action is LS_SerialPrint
// If the entry is a directory and the action is LS_SerialPrint
if
(
DIR_IS_SUBDIR
(
&
p
)
&&
lsAction
!=
LS_Count
&&
lsAction
!=
LS_GetFilename
)
{
if
(
DIR_IS_SUBDIR
(
&
p
)
&&
lsAction
!=
LS_Count
&&
lsAction
!=
LS_GetFilename
)
{
// Allocate enough stack space for the full path to a folder
int
len
=
strlen
(
prepend
)
+
FILENAME_LENGTH
+
1
;
char
path
[
len
];
// Get the short name for the item, which we know is a folder
// Get the short name for the item, which we know is a folder
char
lfilename
[
FILENAME_LENGTH
];
char
lfilename
[
FILENAME_LENGTH
];
createFilename
(
lfilename
,
p
);
createFilename
(
lfilename
,
p
);
// Allocate enough stack space for the full path to a folder, trailing slash, and nul
boolean
prepend_is_empty
=
(
prepend
[
0
]
==
'\0'
);
int
len
=
(
prepend_is_empty
?
1
:
strlen
(
prepend
))
+
strlen
(
lfilename
)
+
1
+
1
;
char
path
[
len
];
// Append the FOLDERNAME12/ to the passed string.
// Append the FOLDERNAME12/ to the passed string.
// It contains the full path to the "parent" argument.
// It contains the full path to the "parent" argument.
// We now have the full path to the item in this folder.
// We now have the full path to the item in this folder.
path
[
0
]
=
'\0'
;
strcpy
(
path
,
prepend_is_empty
?
"/"
:
prepend
);
// root slash if prepend is empty
if
(
prepend
[
0
]
==
'\0'
)
strcat
(
path
,
"/"
);
// a root slash if prepend is empty
strcat
(
path
,
lfilename
);
// FILENAME_LENGTH-1 characters maximum
strcat
(
path
,
prepend
);
strcat
(
path
,
"/"
);
// 1 character
strcat
(
path
,
lfilename
);
strcat
(
path
,
"/"
);
// Serial.print(path);
// Serial.print(path);
...
...
MarlinKimbra/dogm_bitmaps.h
View file @
b97aff98
// BitMap for splashscreen
// BitMap for splashscreen
// Generated with: http://www.digole.com/tools/PicturetoC_Hex_converter.php
// Generated with: http://www.digole.com/tools/PicturetoC_Hex_converter.php
// Please note that using the high-res version takes 402Bytes of PROGMEM.
// Please note that using the high-res version takes 402Bytes of PROGMEM.
//
#define START_BMPHIGH
#define START_BMPHIGH
#if ENABLED(START_BMPHIGH)
#if ENABLED(START_BMPHIGH)
#define START_BMPWIDTH 112
#define START_BMPWIDTH 112
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment