Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Implement CLEAR for SET_KINEMATIC_POSITION #6262

Merged
merged 5 commits into from
Jan 10, 2025

Conversation

twelho
Copy link
Contributor

@twelho twelho commented Jun 18, 2023

SET_KINEMATIC_POSITION CLEAR=<[X][Y][Z]> clears the homing status (resets the axis limits) without turning off motors. This is particularly useful when implementing safe Z homing in [homing_override] on printers with multiple independent Z steppers (where FORCE_MOVE can't be used):

# Forcibly move Z up (Z hop)
{% set homed = printer.toolhead.homed_axes | upper | list %}
{% set not_homed = ['X', 'Y', 'Z'] | reject('in', homed) %}
{% if not 'X' in homed or not 'Y' in homed %}
  SET_KINEMATIC_POSITION Z=0
  G0 Z{z_hop} F{bltouch_speed}
  SET_KINEMATIC_POSITION CLEAR={not_homed | join}
{% endif %}

This functionality was already available to the safe Z homing module via note_z_not_homed. As a bonus, the _motor_off implementations across various kinematics are also simplified.

I'm not 100% sure whether this should send the toolhead:set_position event since it only modifies the limits and not the position itself. The current consumer (singular, GCodeMove) of that event doesn't seem to need it, but maybe you have some other future plans?

@twelho twelho force-pushed the clear-kinematic-position branch from becefb4 to cf3b637 Compare June 18, 2023 11:55
@twelho twelho force-pushed the clear-kinematic-position branch 2 times, most recently from 03fa371 to 8ebb27b Compare June 28, 2023 21:02
@twelho
Copy link
Contributor Author

twelho commented Jun 28, 2023

Rebased on top of master and implemented a fix for KEEP=XYZ not keeping anything (bug with falsy values)

@twelho twelho force-pushed the clear-kinematic-position branch from 8ebb27b to fd012fc Compare July 2, 2023 22:03
@twelho twelho force-pushed the clear-kinematic-position branch from fd012fc to 264ffce Compare July 12, 2023 11:55
@KevinOConnor
Copy link
Collaborator

Thanks. As high-level feedback the change seems fine to me. I do have a couple of minor comments.

I'm not sure about adding a new CLEAR_KINEMATIC_POSITION command. I wonder if adding some kind of CLEAR=XYZ type of parameter to the existing SET_KINEMATIC_POSITION may be more appropriate. (Limiting builtin commands reduces possible conflicts with user macros.)

Is there a reason that clear_position() takes a list of axes numbers instead of a string of axes (eg, "xyz")?

If clear_positions() is to be a mandatory method of the kinematic classes it would be good to update docs/Code_Overview.md to include it in the "Adding new kinematics" section (bullet 5).

If you're rebasing this PR it would be nice to have the kinematic clear_position() change in a separate commit from the XXX_KINEMATIC_POSITION command. Though if you're not super familiar with git then it's not a requirement.

-Kevin

@KevinOConnor KevinOConnor added the pending feedback Topic is pending feedback from submitter label Jul 17, 2023
@KevinOConnor
Copy link
Collaborator

Also, to your earlier question - I don't think the code should call printer.send_event("toolhead:set_position") on a clearing of homing state. That event is intended to inform the gcode parsing code that it has to resynchronize its position with the toolhead code.

In general, I don't think the toolhead needs to be involved in a "clear homing state" request - the low-level code can just directly instruct the kinematic class of the change in state (as was done for note_z_home()). It is not necessary to flush the step generation either.

Along those same lines, maybe clear_homing_state() would be a better name than clear_position()?

-Kevin

@github-actions github-actions bot added the inactive Not currently being worked on label Aug 7, 2023
@github-actions
Copy link

github-actions bot commented Aug 7, 2023

It looks like this GitHub Pull Request has become inactive. If there are any further updates, you can add a comment here or open a new ticket.

Best regards,
~ Your friendly GitIssueBot

PS: I'm just an automated script, not a human being.

@github-actions github-actions bot closed this Aug 7, 2023
@Sineos
Copy link
Collaborator

Sineos commented Aug 7, 2023

@twelho any updates?

@Sineos Sineos reopened this Aug 7, 2023
@twelho
Copy link
Contributor Author

twelho commented Aug 25, 2023

I'm not sure about adding a new CLEAR_KINEMATIC_POSITION command. I wonder if adding some kind of CLEAR=XYZ type of parameter to the existing SET_KINEMATIC_POSITION may be more appropriate. (Limiting builtin commands reduces possible conflicts with user macros.)

That works as well, I can expose the functionality through CLEAR for SET_KINEMATIC_POSITION.

Is there a reason that clear_position() takes a list of axes numbers instead of a string of axes (eg, "xyz")?

set_position for kinematics takes in homing_axes as numerical values, so I copied that pattern for consistency.

If clear_positions() is to be a mandatory method of the kinematic classes it would be good to update docs/Code_Overview.md to include it in the "Adding new kinematics" section (bullet 5).

Thanks for the pointer, I'll update the the the docs as well.

If you're rebasing this PR it would be nice to have the kinematic clear_position() change in a separate commit from the XXX_KINEMATIC_POSITION command. Though if you're not super familiar with git then it's not a requirement.

Sure, I can do that.

@KevinOConnor KevinOConnor removed inactive Not currently being worked on pending feedback Topic is pending feedback from submitter labels Aug 26, 2023
@github-actions
Copy link

Thank you for your contribution to Klipper. Unfortunately, a reviewer has not assigned themselves to this GitHub Pull Request. All Pull Requests are reviewed before merging, and a reviewer will need to volunteer. Further information is available at: https://www.klipper3d.org/CONTRIBUTING.html

There are some steps that you can take now:

  1. Perform a self-review of your Pull Request by following the steps at: https://www.klipper3d.org/CONTRIBUTING.html#what-to-expect-in-a-review
    If you have completed a self-review, be sure to state the results of that self-review explicitly in the Pull Request comments. A reviewer is more likely to participate if the bulk of a review has already been completed.
  2. Consider opening a topic on the Klipper Discourse server to discuss this work. The Discourse server is a good place to discuss development ideas and to engage users interested in testing. Reviewers are more likely to prioritize Pull Requests with an active community of users.
  3. Consider helping out reviewers by reviewing other Klipper Pull Requests. Taking the time to perform a careful and detailed review of others work is appreciated. Regular contributors are more likely to prioritize the contributions of other regular contributors.

Unfortunately, if a reviewer does not assign themselves to this GitHub Pull Request then it will be automatically closed. If this happens, then it is a good idea to move further discussion to the Klipper Discourse server. Reviewers can reach out on that forum to let you know if they are interested and when they are available.

Best regards,
~ Your friendly GitIssueBot

PS: I'm just an automated script, not a human being.

@twelho twelho force-pushed the clear-kinematic-position branch 2 times, most recently from 44b54a6 to 6e8c10e Compare September 12, 2023 11:50
@twelho twelho changed the title Implement CLEAR_KINEMATIC_POSITION Implement CLEAR for SET_KINEMATIC_POSITION Sep 12, 2023
@twelho twelho force-pushed the clear-kinematic-position branch 2 times, most recently from 82aab98 to bb64a34 Compare September 12, 2023 13:09
@twelho
Copy link
Contributor Author

twelho commented Sep 12, 2023

The changes are now implemented and I've tested that it works as intended on my hardware, so it's ready for review.

@b00gie-dev
Copy link

@twelho Awesome! Thank you for your work on that!

@github-actions
Copy link

Unfortunately a reviewer has not assigned themselves to this GitHub Pull Request and it is therefore being closed. It is a good idea to move further discussion to the Klipper Discourse server. Reviewers can reach out on that forum to let you know if they are interested and when they are available.

Best regards,
~ Your friendly GitIssueBot

PS: I'm just an automated script, not a human being.

@github-actions github-actions bot closed this Sep 27, 2023
@twelho
Copy link
Contributor Author

twelho commented Sep 28, 2023

Not stale, could someone please take a look at this?

@KevinOConnor KevinOConnor reopened this Sep 29, 2023
@austinrdennis
Copy link

I'm dying for this to be integrated! It's been tricky to work around this in my homing override and this addition would fix my only remaining problem with that setup.

@Surion79
Copy link

i would love to get this implemented

@twelho twelho force-pushed the clear-kinematic-position branch from bb64a34 to a0ff9b4 Compare December 26, 2023 23:43
@b00gie-dev
Copy link

So what we need to do to get this feature? Someone has to accept it or what's the issue right now?

@twelho
Copy link
Contributor Author

twelho commented Mar 25, 2024

I believe it is in need of a reviewer. Should there be more changes requested, I'm happy to work on them to get this PR merged.

@twelho twelho force-pushed the clear-kinematic-position branch from a0ff9b4 to a9154d2 Compare May 22, 2024 18:16
@twelho twelho force-pushed the clear-kinematic-position branch from a9154d2 to 259afc0 Compare August 18, 2024 16:41
@pciavald
Copy link

pciavald commented Dec 3, 2024

Hi, i've managed to apply this PR.

However i'm observing the following behavior:

Recv: // printer['toolhead'].homed_axes =

G28 X

Recv: // printer['toolhead'].homed_axes = x

SET_KINEMATIC_POSITION CLEAR=X

Recv: // printer['toolhead'].homed_axes = yz

@twelho
Copy link
Contributor Author

twelho commented Dec 17, 2024

Hi, i've managed to apply this PR.

However i'm observing the following behavior:

Recv: // printer['toolhead'].homed_axes =

G28 X

Recv: // printer['toolhead'].homed_axes = x

SET_KINEMATIC_POSITION CLEAR=X

Recv: // printer['toolhead'].homed_axes = yz

Now that I look at this, this is intended behavior. SET_KINEMATIC_POSITION will always set the full kinematic position (for backwards compatibility), the CLEAR option just allows you to discard specific axis after everything has been set. If you want to ensure that un-homed axes remain un-homed, you need to add them to CLEAR, see the not_homed variable in the example in the description.

CLEAR is implemented this way for two reasons: backwards compatibility and to retain the declarative and atomic nature of SET_KINEMATIC_POSITION (i.e., after running the command, you will always end up in a predicable and repeatable kinematic state). This reduces the chances of catastrophic mistakes (crashing the gantry etc.). It also allows combining operations like SET_KINEMATIC_POSITION X=150 Y=150 CLEAR=Z. If you omit an axis, SET_KINEMATIC_POSITION will simply use the current position for it (which is the existing behavior).

@twelho twelho force-pushed the clear-kinematic-position branch from 259afc0 to 98efefe Compare December 18, 2024 12:16
Copy link
Collaborator

@KevinOConnor KevinOConnor left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for working on this. In general it seems fine to me. Sorry for the delay in responding.

I have a couple of minor comments - see below.

-Kevin

Comment on lines 43 to 44
if hasattr(toolhead.get_kinematics(), "note_z_not_homed"):
toolhead.get_kinematics().note_z_not_homed()
if hasattr(toolhead.get_kinematics(), "clear_homing_state"):
toolhead.get_kinematics().clear_homing_state((2,))
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If we're making clear_homing_state() required for all kinematics, then I think it should be called unconditionally here (that is, no hasattr() check).

klippy/toolhead.py Outdated Show resolved Hide resolved
@twelho twelho force-pushed the clear-kinematic-position branch 2 times, most recently from f4eeb6b to f81fc3a Compare January 9, 2025 12:40
@twelho twelho force-pushed the clear-kinematic-position branch 2 times, most recently from f8988a2 to 9176489 Compare January 9, 2025 17:08
@twelho
Copy link
Contributor Author

twelho commented Jan 9, 2025

There's now an additional clarification commit in for the docs to prevent confusion like #6262 (comment) wrt. the functionality of CLEAR.

Apparently I also just managed to hit the cutoff of the v3 artifact actions, so the tests will no longer run. I can fix that here, or rebase on top of master if it's to be fixed in a separate PR.

@twelho twelho force-pushed the clear-kinematic-position branch from 9176489 to b6626a8 Compare January 9, 2025 17:13
@KevinOConnor
Copy link
Collaborator

Try rebasing to the lastest master branch - as I've updated to the latest "uploads-artifact" code there.

Thanks,
-Kevin

Signed-off-by: Dennis Marttinen <[email protected]>
`CLEAR` clears the homing status (resets the axis limits) without turning off
the motors. This is particularly useful when implementing safe Z homing in
`[homing_override]` on printers with multiple independent Z steppers (where
`FORCE_MOVE` can't be used).

Signed-off-by: Dennis Marttinen <[email protected]>
@twelho twelho force-pushed the clear-kinematic-position branch from b6626a8 to b3f2e75 Compare January 10, 2025 12:10
@KevinOConnor KevinOConnor merged commit 7083879 into Klipper3d:master Jan 10, 2025
1 check passed
@KevinOConnor
Copy link
Collaborator

Thanks.

-Kevin

@b00gie-dev
Copy link

b00gie-dev commented Jan 10, 2025

It finally happened 🎉
Big thanks for this to you all!

pellcorp pushed a commit to pellcorp/klipper that referenced this pull request Jan 11, 2025
`CLEAR` clears the homing status (resets the axis limits) without turning off
the motors. This is particularly useful when implementing safe Z homing in
`[homing_override]` on printers with multiple independent Z steppers (where
`FORCE_MOVE` can't be used).

Signed-off-by: Dennis Marttinen <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

7 participants