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

Don't apply hotend_offset.z to Z soft endstops #20675

Merged

Conversation

zeleps
Copy link
Contributor

@zeleps zeleps commented Jan 4, 2021

Description

Setting the 2nd tool's z-offset to a positive value, results in the tool not being able to reach bed level. This is because zmin soft endstop is translated and the new endstop value for the tool becomes its z-offset. Since tools in a PARKING_EXTRUDER configuration are all carried on the X-axis, their nozzles' height difference must be compensated by moving the lowest tool lower than zmin, and zmin endstop value for all tools should be 0 (untranslated). This is typically not an issue, since tools are parked outside the hotbed area. If tools are parked within the bed area (in which case useful bed space is consumed, so not a typical configuration), they must be perfectly aligned in height in order to avoid the lowest tool from crashing on the bed.

This solution allows both tools reach the bed by skipping the change to the z-min soft endstop value (which typically happens on tool change). All other endstop values are translated accordingly.

E0 active:

___________X-AXIS__________
        |||             |||
        |||             |||
        |||              V
         V               
      ------BED-------
	  
E1 active, before the fix:

___________X-AXIS__________
|||                |||     
|||                |||     
|||                 V     
 V                       
      ------BED-------

E1 active after the fix:
	  
___________X-AXIS__________
|||                |||     
|||                |||     
|||                 V     
 V    ------BED-------

Benefits

2nd tools with a positive z-offset can work properly.

Configurations

Enable PARKING_EXTRUDER, create a 2nd extruder with a positive z-offset value.

Related Issues

This is complementary to pull request #20473

@zeleps
Copy link
Contributor Author

zeleps commented Jan 4, 2021

Hm. Should have created a new branch instead of using the last pull request's. Hope that's not an issue...

@thinkyhead
Copy link
Member

The only reason that apply_motion_limits is called from the tool-change function is to prevent a tool-change from causing the X axis to try to move outside the assumed bed area. I don't think we're worrying about the Z axis here, so it might be best to simply remove the call to apply_motion_limits and apply limits in a more liberal manner, maybe only worrying about the physical MIN/MAX boundaries instead of the soft limits.

@thinkyhead
Copy link
Member

Should have created a new branch instead of using the last pull request's.

GitHub won't let you use the same branch for two open PRs at the same time, so it's not a worry. If you are concerned it might be out of date, just do a quick git fetch upstream ; git merge upstream/bugfix-2.0.x and you'll be back in sync.

thinkyhead added a commit that referenced this pull request Jan 5, 2021
Followups to #20473 ahead of #20675
@thinkyhead thinkyhead changed the title Fix for PARKING_EXTRUDER tool z-offset Fix Z misalignment after PARKING_EXTRUDER tool-change Jan 5, 2021
@thinkyhead
Copy link
Member

Meanwhile… I would advise generally that for tool-changing machines (and maybe all common machines) just disable MIN_SOFTWARE_ENDSTOP_Z or disable both MIN_SOFTWARE_ENDSTOPS and MAX_SOFTWARE_ENDSTOPS altogether. Who bloody needs 'em, right?

@thinkyhead
Copy link
Member

Okay… After much rumination I think it's safe to go on the assumption that it's never a good idea to modify the Z soft endstops in response to a hotend offset. The current Z position should indeed be changed, but since we know hotend_offset.z has nothing to do with real constraints on motion, and we know it will be a very small number, it's most appropriate to just leave it untouched.

@thinkyhead thinkyhead merged commit 2f17f22 into MarlinFirmware:bugfix-2.0.x Jan 5, 2021
@thinkyhead thinkyhead changed the title Fix Z misalignment after PARKING_EXTRUDER tool-change Don't apply hotend_offset.z to Z soft endstops Jan 5, 2021
@zeleps
Copy link
Contributor Author

zeleps commented Jan 5, 2021

Okay… After much rumination I think it's safe to go on the assumption that it's never a good idea to modify the Z soft endstops in response to a hotend offset. The current Z position should indeed be changed, but since we know hotend_offset.z has nothing to do with real constraints on motion, and we know it will be a very small number, it's most appropriate to just leave it untouched.

It seemed obvious to me when looking into it (why the hell would any tool need to translate zmin?), at least for cartesian machines, but I don't have much experience with tool changing (this is my first take on the subject) to imagine all the possible tool changing configurations and their specific intricacies. The zmax translation is still relevant though, in my configuration I've installed two hard stops on the z-axis to auto align it (MECHANICAL_GANTRY_CALIBRATION). The difference in height is of course negligible, but then again it's a difference (not that I'd perform the alignment with the 2nd gantry, but still it's a possibility).

@zeleps
Copy link
Contributor Author

zeleps commented Jan 5, 2021

The soft endstops are meant to apply to the physical space that the physical machine can move around in safely. So if you have a setup which needs to be able to physically move the nozzle below the "tool-zero-relative" minimum Z endstop, then you must set your Z min endstop to a negative value with a magnitude large enough to allow for the free movement below the bed in that spatial context.

In other words, I'm not sure we want to skip modifying the Z min software endstop, since it is being applied correctly and the issue can be addressed simply by changing the configuration.

I tried that (negative zmin, -2) before applying my solution, and the result was -not surprisingly- bad, since the endstop value logically represents the probe's (bltouch in my case) trigger point during homing, both tools would stop 2mm from the bed and refused to go lower :) of course I could have changed my probe z-offset to a larger negative value (-.5 -> -2.5), but that would be just translating the whole z system 2mm lower, and my second tool would still not reach the bed. I think leaving soft_endstop.min[Z_AXIS] untranslated is the right way to go.

@InsanityAutomation
Copy link
Contributor

We had a very similar discussion a long time ago, and the conclusion reached was to set the Z_MIN (-3 in my case) to the maximum potential positive offset as the safety, then to use the MANUAL_Z_HOME_POS value to set home to still be 0. The clamping in my opinion should be done to the positioning after the offset is applied for anything aside from 2 fixed nozzles (eg e3d chimera).

@zeleps
Copy link
Contributor Author

zeleps commented Jan 5, 2021

Ok, I wasn't aware of MANUAL_Z_HOME_POS. I'll try it out and see how it works in my case.

@zeleps zeleps deleted the bugfix-2.0.x-ParkingExtruderFix branch January 5, 2021 17:14
@zeleps
Copy link
Contributor Author

zeleps commented Jan 5, 2021

I just tested MANUAL_Z_HOME_POS. If I knew about it, I wouldn't have really gotten into the trouble of finding another solution to my problem, BUT it's not imho a proper solution. Moving Z_MIN_POS lower than the bed (i.e. -2mm) does not really prevent my tools from crashing on it, even if it is for 2mm. The proposed solution does, and it does it for the specific tool that is active at the moment. The other tools might actually crash on the bed, if they are not at their respective parking positions, but that's not a normal scenario. Typically, in a tool changing configuration, inactive tools are parked somewhere outside the bed area, so that's not an issue.

I think Z-axis configuration has become a bit more complicated than it should be. We have the Z_MIN_POS, which is a soft endstop, optionally MANUAL_Z_HOME_POS which is actually the position where the probe is activated (otherwise it's the Z_MIN_POS), NOZZLE_TO_PROBE_OFFSET[Z_AXIS] which is the offset of E0 from MANUAL_Z_HOME_POS and the HOTEND_OFFSET_Z matrix which is the offset of all other tools from E0. I feel that their significance, position in the configuration.h file and transitive relation, makes them more obscure and hard to configure than they should be. Typically I'd start with a baseline, which is the probing position (and should be named accordingly), have a different z-offset for each tool relative to the baseline (and not to each other), and optionally a software endstop, exclusively lower than the baseline, in case it's needed (for calibration purposes maybe?). Which brings up another major issue (I'm sure @thinkyhead has spent countless hours thinking about it), the tool-less state. Most toolchanging systems can be at a state that the toolhead has no tool attached. And that's a real state, that is not represented in any way in Marlin. There's always a tool selected, and that makes it hard to write code for operations that can and in some configurations should be tool-less, like bed levelling).

I'm just thinking loudly here, I know it's not the right place for this discussion.

tharts pushed a commit to tharts/Marlin that referenced this pull request Jan 6, 2021
tharts pushed a commit to tharts/Marlin that referenced this pull request Jan 6, 2021
susisstrolch pushed a commit to susisstrolch/Marlin that referenced this pull request Jan 8, 2021
… into bugfix-2.0.x

* 'bugfix-2.0.x' of https://github.com/MarlinFirmware/Marlin: (105 commits)
  [cron] Bump distribution date (2021-01-08)
  Fix M48 output (MarlinFirmware#20713)
  Improved MKS Robin support (MarlinFirmware#19333)
  Preheat before Power Loss Recovery homing (MarlinFirmware#20697)
  [cron] Bump distribution date (2021-01-07)
  Custom build_flags by feature (MarlinFirmware#20692)
  [cron] Bump distribution date (2021-01-06)
  Multi-Z stepper inverting (MarlinFirmware#20678)
  Fix Azteeg X3 macro typo (MarlinFirmware#20681)
  Define SANGUINOLOLU 1.1 enable pins (MarlinFirmware#20682)
  No BTN_ENC_EN on Anet 10 (MarlinFirmware#20684)
  Temperature report followup (MarlinFirmware#20687)
  Adjustable precision in M105 temperature report (MarlinFirmware#20602)
  Don't apply hotend_offset.z to Z soft endstops (MarlinFirmware#20675)
  Indent tool_change_prime
  Clarify solenoid active / magnet-on state
  Defer "quiet probing" till the last Z bump (MarlinFirmware#20610)
  Solenoid cleanups
  [cron] Bump distribution date (2021-01-05)
  Remove untranslated strings
  ...
dpreed pushed a commit to dpreed/Marlin_2.0.x that referenced this pull request Feb 5, 2021
dpreed pushed a commit to dpreed/Marlin_2.0.x that referenced this pull request Feb 5, 2021
kpishere pushed a commit to kpishere/Marlin that referenced this pull request Feb 19, 2021
kpishere pushed a commit to kpishere/Marlin that referenced this pull request Feb 19, 2021
zillarob pushed a commit to zillarob/Marlin that referenced this pull request Feb 25, 2021
zillarob pushed a commit to zillarob/Marlin that referenced this pull request Feb 25, 2021
W4tel-BiDi pushed a commit to W4tel-BiDi/Marlin that referenced this pull request Apr 5, 2021
W4tel-BiDi pushed a commit to W4tel-BiDi/Marlin that referenced this pull request Apr 5, 2021
thinkyhead added a commit to thinkyhead/Marlin that referenced this pull request Apr 29, 2021
thinkyhead added a commit to thinkyhead/Marlin that referenced this pull request Apr 29, 2021
thinkyhead added a commit that referenced this pull request Apr 30, 2021
Followups to #20473 ahead of #20675
thinkyhead added a commit that referenced this pull request Apr 30, 2021
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.

3 participants