-
Notifications
You must be signed in to change notification settings - Fork 127
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
Allow aborting Docking/Undocking #141
base: main
Are you sure you want to change the base?
Conversation
The GUI still needs updating, but the buttons on the mower work in my brief test. I just wanted to check that this would be the sort of thing you would merge. I find it very frustrating that a lot of the time it's impossible to get the mower into IDLE, since DOCKING and UNDOCKING are uninterruptible. Even MOWING you can't actually interrupt, you can only send it to DOCKING, which is no better. I have to restart the openmower container to get it back into idle. This PR is pretty straightforward. The only thing that was up to my preference was I chose the Home button to stop undocking and the Play button to stop docking. |
759fdda
to
09218b1
Compare
This is something that is definitely needed. While this is right now a workaround, by using existing buttons, I think in the future it would make sense to add a stop button. This is something that other robot mowers have and I miss. If you are mowing and want to record an area - no chance to stop it unless you dock. Same if it is mowing and gets stuck, you have to wait until it tries to dock and fails and only then can you do other operations remotely. |
I think the best UI for this would be that Play/Run and Home should abort and immediately do their thing, while pause should pause in either case and cancel when pressed again (in the UI visually replaced with a stop button) Alternatively we could just replace pause with cancel/abort, or does pause offer any benefit over cancel? |
With just this PR there is no way in the GUI to cancel. You either have to physically press the buttons on your mower, or run a script over ssh to send the message. However the GUI could be updated to trigger the cancellation with whatever UI is desirable. The reason I chose the home and play buttons for the physical buttons, is because those are the only physical buttons that work on my Yardforce 500B running Mowgli. But if Cedric wants to rationalize the behavior of the buttons to make them more consistent, I would be fine with that. |
I skimmed over your commit and it looks quite good to me. Not sure if the logging and Apart from that, replacing |
Yeah I am not familiar with the code style for ROS. It does seem like something cross-cutting could be added to allow aborting (e.g. another thread interrupting it, or exception throwing to easily abort execution). I do like the idea of waitForResultOrAborted(), as the state can be checked and handled after the waiting is done in an independent way. |
Yeah, that could easily go into mower_logic.cpp and should return the full result as before - then it's up to the caller to evaluate why the goal failed. Will need some fiddling to get the parameter/return types magic correct, actionlib relies on templates for that. If you need help with that, I can give it a try tomorrow evening. |
Okay, I added a new helper function to do the waiting and the code is a bit simpler now (also removed the double logging of aborting). |
bb50a57
to
e4a0492
Compare
Hmm it seems like there are background abort attempts on the docking behavior which are now causing the docking to abort randomly. I will need to investigate this more before we merge. |
Yes, indeed, I like that 😉 Thanks for implementing the suggestion!
I created this overview a few days ago: https://wiki.openmower.de/index.php?title=Why_is_the_mower_not_mowing%3F |
6d789f9
to
5ecf4f5
Compare
@@ -86,7 +88,7 @@ class Behavior { | |||
requested_pause_flag |= reason; | |||
} | |||
|
|||
void start(mower_logic::MowerLogicConfig &c, std::shared_ptr<sSharedState> s) { | |||
void start(mower_logic::MowerLogicConfig& c, std::shared_ptr<sSharedState> s) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Was this code style change intended? I thought this should be denied by the .clang-format
file.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This was done by /pre-commit run --all-files
, I didn't touch it.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That's strange 😲 I just modified the file as in your commit and ran that exact command, it complained and corrected it back to what it was before:
clang-format.............................................................Failed
- hook id: clang-format
- exit code: 1
- files were modified by this hook
src/mower_logic/src/mower_logic/behaviors/Behavior.h
====================
--- original
+++ formatted
@@ -83,7 +83,7 @@
requested_pause_flag |= reason;
}
- void start(mower_logic::MowerLogicConfig& c, std::shared_ptr<sSharedState> s) {
+ void start(mower_logic::MowerLogicConfig &c, std::shared_ptr<sSharedState> s) {
ROS_INFO_STREAM("");
ROS_INFO_STREAM("");
ROS_INFO_STREAM("--------------------------------------");
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Oof, conflicting clang-format versions maybe?
$ clang-format --version
Debian clang-format version 14.0.6
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Exact same for me. Did you try clang-format -n src/mower_logic/src/mower_logic/behaviors/Behavior.h
? It emits two warnings for me with MowerLogicConfig& c
, and changes it to MowerLogicConfig &c
with -i
instead of -n
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
clang-format -n src/mower_logic/src/mower_logic/behaviors/Behavior.h
gives no warning for me 🤦
src/mower_logic/src/mower_logic/behaviors/UndockingBehavior.cpp
Outdated
Show resolved
Hide resolved
@rovo89 Still getting the behavior where it quits docking... based on the log messages it looks like the goal is failing rather than getting aborted. Poked around a bit in the code... the only thing I could find that might be a lead is that the original code (sendGoalAndWait) was ultimately checking SimpleGoalState (a 3 choice enum) https://docs.ros.org/en/diamondback/api/actionlib/html/classactionlib_1_1SimpleGoalState.html and now we are instead checking simpleclientgoalstate (a 5 choice enum) https://docs.ros.org/en/diamondback/api/actionlib/html/classactionlib_1_1SimpleClientGoalState.html However in dock_straight, we use the same approach... but with a slightly different client:
|
Strange... did you find a pattern when this occurs, so you can reproduce it? |
Some more logging would help to verify that the goal state isn't success. With some special settings in rosconsole.config, you can enable debug logs for actionlib, maybe that would give more insights. |
It's quite reliably reproducible for me. I see the error message "Error during docking approach." which implies it was not aborted, since the function would have returned before that point:
Likewise I do not see the message "Executing Docking Approach", so I know it was failing in the first part of I probably need extensive logging, which is annoying since I don't have a good setup for editing-compiling-running on my mower without waiting for docker images to build 🤦 |
It's definitely worth investing some time into a more development-friendly setup. I build my own container with just the dependencies and mount /opt/open_mower_ros from the host. That way I can build incrementally (within the container) and use the same container to run it. Super easy and fast to have my specialized build and keep it in sync with upstream. I went one step further and switched to Docker Compose to run nginx and mosquitto in separate containers with their official images. My scripts are here, unfortunately I didn't get around to write a README yet: https://github.com/rovo89/open_mower_bare_container |
eheh, so it was just a me being stupid problem. I needed to run |
So does it work now for you? Or still seeing spurious failed actions? |
It works for me now, I was just running an outdated version of the code. |
Nice! I'll also try it then. One thought: The actions are named differently depending on the current behavior. Would that be a problem for clients, would it make it much easier for them if there was a "mower_logic/abort" alias? Maybe now would be a good time to prepare the app to show the stop button also for docking and undocking, that will show whether it's complicated or not. |
Yeah, I wasn't sure how much I should change the existing style of things, but that sounds more logical to me. Additionally, I need to add support for interrupting the "paused" mode when it loses a GPS fix. |
|
I think the issue is in MowingBehavior, technically not related to docking/undocking aborting, but really the goal of this pr was to be able to get to idle from ANY state. |
Ah sorry, I misread. I thought you were talking about the initial wait for a GPS fix. |
6ed7c6c
to
8747fee
Compare
8747fee
to
debf216
Compare
1. Add sudo support for the user 2. Add setup.bash to bashrc 3. Add cpp-tools-extension-pack vscode extension 4. Switch to host networking mode
Pressing "Home" when undocking aborts it, and pressing "play" when docking aborts it. Uninterruptable docking can be a real problem if your mower is stuck trying to return to the dock and you want to tele-operate it. This adds button controls, as well as actions which can be used from the GUI.
Previously the mower would have to become unpaused before it would recognize that mowing had been aborted.
debf216
to
6083ed9
Compare
Pressing "Home" when undocking aborts it, and pressing "play" when docking aborts it.
Uninterruptable docking can be a real problem if your mower is stuck trying to return to the dock and you want to tele-operate it. This adds button controls, as well as actions which can be used from the GUI.