-
Notifications
You must be signed in to change notification settings - Fork 11
Launching CARLA and Navigator on The Quad
Maintained by Connor Scally
Before demonstrating our codebase on the vehicle, in the real world, we must first test our stack in a virtual one. The following documentation outlines essential CARLA usage and syntax, to allow for simulating our stack in a virtual enviroment.
Nova utilizes CARLA for virtualization. For further information on CARLA, and to learn more about advanced usage, please see the following links:
-
Prerequisites: (if you are a member of Nova working on the Quad, disregard this section)
- CARLA Simulator: Please follow the instructions in the above links to install CARLA on your chosen operating system
- Navigator: Please see our GitHub page for the latest releases of Navigator
- RVIZ (Or an equivalent ROS visualizer: The download page for RVIZ is here: http://wiki.ros.org/rviz
- ROS2: The download page for ROS2 is here: https://docs.ros.org/en/foxy/index.html
- Dependencies for the above: Self-explanatory, Navigator comes with most of what you need, CARLA may not, do not forget to check!
- If you need to build Navigator:
- Clone your chosen branch anywhere you want to keep Navigator
- Go to the root directory of Navigator and run
colcon build
(If this is your first time building this instance, run the command with the--symlink-install
flag) - Wait for the build to finish
-
Launching CARLA:
- Your first step should be to navigate to your CARLA directory and launch CARLA with the CARLAUE4.sh script with the -RenderOffScreen flag:
$ /home/share/carla/CarlaUE4.sh -RenderOffscreen
- The "RenderOffscreen" flag hides the rendering window, which saves some resources. See here for more details
-
Launching RVIZ:
- Open a new terminal instance and source the setup script with
source /opt/ros/foxy/setup.bash
- Write: `rviz2' to terminal
- Select File followed by Open Config Select default.rviz from the share folder. It is recommended that you have your own copy of this as well for your own configuration.
- Open a new terminal instance and source the setup script with
-
Launching the stack:
-
Open a new terminal window.
-
Navigate to the root directory of Navigator.
-
Run
source /install/setup.bash
(if you have bash sourcing ROS automatically (see below), that works too) -
Run
ros2 launch carla.launch.py
-
Check RVIZ and terminal output. The sim_bridge will publish sensor data just as if you were driving on campus, and it will similarly accept commands from our standard topics. As of writing, our custom bridge publishes:
- GNSS (GPS)
- IMU
- Front and rear Lidar (not fully functional)
- Front RGB camera
- Front depth camera
- CARLA ground truths for
- Car's odometry (position, orientation, speed)
- CARLA virtual bird's-eye camera (/carla/birds_eye_rgb)
The most up-to-date information on our bridge's capabilities can be found [at the top of the script itself](https://github.com/Nova-UTD/navigator /blob/dev/src/interface/sim_bridge/sim_bridge/sim_bridge_node.py#L3).
-
- You can control our ego vehicle with
ros2 run manual_control manual_control_node
- At the moment, this only supports keyboard control through NoMachine or similar, not SSH.
- If you get a "pynput" error, try running
pip3 install pynput
.
- You can change a number of simulation settings by editing our script's contants (here).
- Don't forget to rebuild the package or use
colcon build --symlink-install
(recommended). - ROS param support in the works.
- Don't forget to rebuild the package or use
- If you get a "pynput" error, try running
pip3 install pynput
. - If you get a CARLA segmentation fault, it's likely you just need to restart CARLA. This will be fixed... eventually. This should only happen after starting the bridge 10 times or so, and should not happen while the bridge is running.
- If CARLA gives you a SIGFAULT error attach the -carla-rpc-port=N where N = your favorite (Not in use) port number.
- Open your terminal
- Write the command -->
gedit ~/.bashrc
(or nano, whatever really) - Go under the last line line and write -->
source /opt/ros/foxy/setup.bash
- Save and exit
- Now with every new shell you open, it will source automatically
General
- Papers for literature review
- Demo 2: Grand Tour (Overview)
- Our Team
- Learning resources
- Meeting notes
- Archived Pages
Development & Simulation
- Code Standards and Guidelines
- Writing and Running Tests
- Installation and usage
- Logging into the Quad Remote Simulator
- Running the Simulator
Software Design
Outdated or Uncategorized