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

Add multi-robot sim ISAAC13 scenario instructions #146

Merged
merged 3 commits into from
Feb 22, 2024
Merged
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
140 changes: 139 additions & 1 deletion astrobee/survey_manager/survey_planner/readme.md
Original file line number Diff line number Diff line change
Expand Up @@ -26,4 +26,142 @@ Don't forget to change the commands to use the target robot's name (bumble is wh

If the survey_planner crashes sometimes the simulation has to be restarted for it to restart in a good state.

\subpage action_testing
\subpage action_testing

## Running a full JEM survey scenario in multi-robot simulation

Unfortunately, this scenario is currently only available for
NASA-internal users because it requires access to configuration files
stored in the non-public `astrobee_ops` repo.

### Set up ops configuration

These instructions assume you've followed the native install
instructions for NASA-internal users both for
[`astrobee`](https://github.com/nasa/astrobee/blob/develop/doc/general_documentation/NASA_INSTALL.md)
and [`isaac`](https://github.com/nasa/isaac/blob/develop/INSTALL.md).

Set up GDS and `astrobee_ops` per [this NASA-internal wiki
page](https://babelfish.arc.nasa.gov/confluence/display/FFFSW/Running+GDS+in+Linux). You
can stop when you get to the "Setup Sci Cam Streaming" section.

### Environment variables to define in all terminals below

These could be added to `~/.bashrc` if you prefer:
```bash
OPS_REPO="${HOME}/astrobee/ops" # Or wherever you put this
ISAAC_WS="${HOME}/isaac" # Or wherever you put this
source "${ISAAC_WS}/devel/setup.bash"
```

### Running the scenario

1. Clean up any lingering processes from previous runs:
```bash
# === In terminal 1 ===
ps auxww | grep -P 'ros|survey|astrobee|gzserver|gazebo|inspection_tool'
# If you see processes that look relevant, you can kill them with
# 'killall <name>' or 'killall -9 <name>' if needed. Failing to clean
# up any lingering processes seems to cause unpredictable faults like
# robots not moving when commanded.
```

2. Start the simulator:
```bash
# === In terminal 1 ===
roslaunch isaac sim.launch honey:=true dds:=true gds:=true robot:=sim_pub
# roslaunch will run indefinitely. Press Ctrl-C to shut down the system.
```

3. Configure the Astrobees, using one of these options:
1. Using the Astrobee Workbench (a.k.a. "GDS") graphical interface:
1. Configure the recording profile. Go to the "Engineering" tab
and do the following for each robot:
1. Use the "Select Bee..." menu at the top left to select the robot.
2. Click "Grab Control".
3. In the "Data to Disk" panel, select "SurveyNoDepth.json" in the
leftmost drop-down menu. If this option is not available,
review the "Setup GDS" section of the wiki page referenced
above and restart.
4. Click the leftmost "Configure Data" button next to the menu.
2. Turn off face-forward motion. Go to the "Teleoperate" tab and do
the following for each robot:
1. Use the "Select Bee..." menu at the top left to select the robot.
2. Click "Grab Control".
3. In the "Bee Commanding" tab, in the "Options" column,
uncheck the purple checkmark to the left of "Face Forward"
4. Click "Apply Options". You should see the green checkmark to
the right of "Face Forward" turn into a black "X".

2. Using command-line tools:
```bash
# === In terminal 2 ===
cat <<EOF >/tmp/configure_cmds.txt
# Configure the recording profile
for prefix in "" "/honey"; do
Copy link
Contributor Author

Choose a reason for hiding this comment

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

This is not working yet pending a PR on the astrobee_ops repo that adds $TOPIC_PREFIX support.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

The relevant PR is now merged. (But remember to update astrobee_ops!)

TOPIC_PREFIX="\${prefix}" "${OPS_REPO}/dock_scripts/hsc/cmd" -c bagger -config "${OPS_REPO}/gds/ControlStationConfig/DataToDisk-ISAAC/SurveyNoDepth.json"
done
# Turn off face-forward motion
for ns in "" "-ns honey"; do
rosrun executive teleop_tool \$ns -set_face_forward off
done
EOF

# Note: On repeated runs you can just run this command again; the
# temp file doesn't change.
source /tmp/configure_cmds.txt
```

4. Start the survey manager:
```bash
# === In terminal 2 ===
roslaunch survey_planner survey.launch
# roslaunch will run indefinitely. Press Ctrl-C to shut down the system.

# Note: This launch is fairly unreliable at startup so it's purposefully
# kept separate from the main roslaunch, allowing us to manually
# restart as needed without impacting the other ROS nodes. To add
# here when it's better understood: how can an operator check that
# this startup succeeded? It pretty much always raises lots of
# errors, but some of them seem benign.
```

5. Generate and run a plan using the PlanSys2 terminal:
```bash
# === In terminal 3 ===
cat <<EOF >/tmp/term_commands.txt
source $ISAAC_WS/src/astrobee/survey_manager/survey_planner/pddl/problem_jem_survey.ps2.pddl
get plan
run
EOF

# Note: On repeated runs you can just run this command again; the
# temp file doesn't change.
cat /tmp/term_commands.txt | rosrun plansys2_terminal plansys2_terminal
# The plansys2_terminal will run until the plan completes, providing status
# feedback. You can exit the terminal by pressing Ctrl-C and execution will
# continue.
```

6. Wait for the scenario to complete. Some execution monitoring tips:
- Use the Astrobee Workbench window "Overview" tab for a graphical
view of robot state and progress.
- The `plansys2_terminal` should display which survey manager actions
are currently executing, along with how long they have taken so far
relative to their estimated duration. Example: If an action was
supposed to take 10 minutes but has taken 15 minutes so far, it is
marked as "150%".
- The survey manager `roslaunch` terminal should display more
detailed console output. Note that this is interleaved console
output from several processes running in parallel, so it can be
confusing to interpret.
- You can interact with the terminal interfaces of individual
commands that are currently executing. This allows retrying or
skipping failed actions without triggering overall plan failure, as
well as more detailed management of the `inspection_tool` that
executes panoramas, like retrying or skipping individual panorama
frames. To connect to the action running on a robot, choose the
robot and run like this:
```bash
rosrun survey_planner monitor_astrobee bumble # or honey
```
Loading