-
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
Ability to toggle automatic point collection during recording #56
Ability to toggle automatic point collection during recording #56
Conversation
(cherry picked from commit 4ba6c4d)
// use RB button for manual point collecting | ||
// enable/disable auto point collecting with LB+RB | ||
if (joy_msg.buttons[5] && !last_joy.buttons[5]) { | ||
if (joy_msg.buttons[4] && !last_joy.buttons[4]) { |
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 if will likely never happen as there is no separate state for joy buttons, so all four conditions will be not met (?)
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.
yes, that would require pressing both buttons in the same loop
Currently the slicer algorithm (especially the switch-between-outlines) part of the algorithm advances a fixed number of points while switching from an inner outline to the next one. This is done because otherwise, the robot would turn on the spot and try to drive If the points are sparse, then this advancing might cause the robot to skip many meters instead of just skipping a few cm. If unlucky, the robot will traverse diagonally through the lawn ignoring all obstacles. I.e. before we can do sparse recording, we need to think about the algorithm. The outline swapping logic has some issues in complex outlines anyways and should be looked at. |
@ClemensElflein I think I have noticed the behavior you mention here, but in general, haven't found any issues with sparse lines. Thanks for the explanation. What if we feed the slicer and prefill the area with more dense points?
Would that work? |
(cherry picked from commit ce4f101)
Today I observed mower behaviour when mowing the area with a few points only. I became more aware of the issue you explained. I implemented additional logic that makes sure points are enough dense. Please have a look if that does make sense: |
@ClemensElflein what do we do about it? I can change this PR to include ROS changes only. We can keep UI not modified and follow up. |
Thank you for the updated function. The logic looks good to me. Does it work stable for you? If so, we can merge to main. In the beginning you mentioned "Draft as it might require further testing. Joy support is 99% broken." is this still relevant or was this resolved? |
Also regarding the app, does it work? If so I think we can also merge this. Is the default still "auto collection" or manual? We should do auto so that the docs don't need to change |
I have this code running for a while in my mower. UI is a bit broken on mobile unfortunately :) I will not work on further app updates. Perhaps it's enough to merge. |
Could you publish your fork of the app source code though? I would like to test these changes, but meanwhile the app had some other changes upstream. |
I rebased the three commits (except for the app) on main and tested them today. Used these commands to toggle manual mode and add points: rostopic pub -1 /record_auto_point_collecting std_msgs/Bool false
rostopic pub -1 /record_auto_point_collecting std_msgs/Bool true
rostopic pub -1 /record_collect_point std_msgs/Bool true Worked quite well! In one part of the map, a few points were missing, but I might have missed to execute the command or maybe had lost the connection or something. For that some feedback would be helpful - not sure if that would be possible with a service instead of messages? Apart from that, I think it added the first point when I hit "Start recording". But didn't verify that later. |
Here's the (again rebased) branch in case someone else wants to test: https://github.com/rovo89/open_mower_ros/tree/manual_points |
Verified that in the code and will work on a fix in the next days. Apart from that, I'm wondering whether it would make sense to average the position of manual points over a few seconds, hoping that it will improve accuracy. Not sure though whether that makes sense and whether something like 5 or 10 seconds would be sufficient. Finally, might consider mowing the dense point logic to slic3r_coverage_planner as suggested by @olliewalsh. |
@jkaflik published his changes here: https://github.com/jkaflik/OpenMowerApp/compare/feature/auto-point-collection And updated https://github.com/rovo89/open_mower_ros/tree/manual_points with the compiled version. Will test this tomorrow if the weather agrees. |
Recorded a new area today - most as sparse points, non-straight parts with auto collection, so I toggled the new feature off and on several times and added points using the UI. It worked very well! However, the plan looked like there were some small glitches in the outline. I'll probably have to check that in the simulator, maybe the function to add additional points has some error. |
I just spent the last 1.5 hours looking at the slicer, because I thought that the proper fix would be to just follow the polygon for a certain distance instead of skipping two points. I found the code already uses And we need the same logic also for obstacles. |
IIRC equally_spaced_points is a method on the the polyline i.e the polygon after it has been split |
Yes - but it's almost trivial to split that polyline (or the points array) again after finding the correct index. |
Even better would be to inspect the angle instead of just skipping ahead 2 points, as that isn't necessarily a good path |
Maybe - but I wouldn't really know what to do for that, and there are so many other improvements I'd like to work on in very limited time. Two points is only 20 cm, so I assume it can't go that much wrong?!? |
As far as I remember |
Looks like it does interpolate: https://github.com/ClemensElflein/Slic3r/blob/026c1380e0ad12176dd2fc8cdf8f6f181deeb071/xs/src/libslic3r/Polyline.cpp#L122-L126 What it doesn't seem to do is ensuring that all original points are returned, so it might cut corners short. But the worst case would be that one point is 5 cm before the corner, so the next one is 5 cm after it, and I think the mower would drive a diagonal line between them. So it will create slightly "round corners" - not dramatic though. Here's the PR based on my idea: ClemensElflein/slic3r_coverage_planner#11 |
…d) (#137) This supersedes PR #56. The first two commits are the same as over there, just rebased on the latest main branch and re-formatted with the new rules. The slicer has been updated with ClemensElflein/slic3r_coverage_planner#11 and #135, so no need for the fourth commit. The app enhancements are in ClemensElflein/OpenMowerApp#5. I didn't include the rebuilt assets here - let me know if I should do that or if you'll take care (in case you have special build requirements). I have recorded my map using these commits and have been mowing it with the slicer fix for a few weeks, all working very nicely. --------- Co-authored-by: Kuba Kaflik <kuba.kaflik@clickhouse.com>
this is included in #137 |
Draft as it might require further testing. Joy support is 99% broken.
Currently during area recording,
mower_logic
adds points if the distance to the previous point was below value0.1
. When trying to map a straight line, recording will add a bunch of lines - not necessarily pretty.This PR introduces the ability to:
automatic point collection can be confusing. Any ideas for better naming?
Usage via MQTT:
mqtt publish /action mower_logic:area_recording/start_recording
mqtt publish /action mower_logic:area_recording/auto_point_collecting_disable
mqtt publish mower_logic:area_recording/collect_point
for every pointmqtt publish /action mower_logic:area_recording/auto_point_collecting_enable
(cherry picked from commit 4ba6c4d)