This rep is a branch of Apollo 8.0, in which the controller is particularly optimized for co-simulation with Carla, for a better co-simulation performance.
Demo: turn left - 90-degree sharp left turn, Town01
Demo: turn right - 90-degree sharp right turn, Town01
The above demo is using the tuned MPC controller with turning ratio (in bridge) tuned. This is the default co-simulation control performance that this project aims to provide.
To achieve the above performance, turning ratio is set as the following:
self.right_turn_ratio = 0.7
self.left_turn_ratio = 0.85
The MPC controller parameters:
matrix_q: 3.0
matrix_q: 0.0
matrix_q: 18.45
matrix_q: 0.0
matrix_q: 30.0
matrix_q: 10.0
matrix_r: 3.25
matrix_r: 1.75
This project is expected to replace the original Apollo 8.0 for Apollo-Carla co-simulation. You should set up the co-simulation environment according to the bridge official: Apollo-Carla official bridge.
In the meantime, you should use this project to replace the original Apollo 8.0.
Details about environment setup: Apollo-Carla co-simulation setup
Additionally, you can install the original Apollo 8.0, and replace the following files with the ones in this repo:
modules/control/conf/control_conf.pb.txt
modules/control/controller/mpc_controller.cc
modules/control/controller/mpc_controller.h
Compared with original Apollo 8.0 code (Apollo 8.0), this repo applied the following improvements:
modules/control/conf/control_conf.pb.txt
The above file is the key configuration file for setting up the controller, including the relation of how the acceleration can be transformed to throttle or brake signal. However, the original configuration has several bugs including the too low acceleration, incorrect acc-to-throttle mapping, etc.
modules/control/controller/mpc_controller.cc
modules/control/controller/mpc_controller.h
The above file is the implementation of the Model Predicted Control (MPC) in Apollo, which is an advanced controller. Several bugs have been discovered in the original MPC controller, and they were fixed in this repo. These bugs include the inconsistent choice of planning point, lack of look-ahead time for planning query, redundant feedback on final control signal, etc.
If you are interested, the following page can be helpful for understanding the Apollo controller (It is Apollo 9.0, but key ideas are identical to 8.0).
Apollo Control Module Introduction
Following are the detailed report of discoverd bugs:
Due to the complexity of this co-simulation (e.g, complexity of the Apollo ADS, complex dynamics in Carla), the current controller is still far from being perfect. If you find the controller unsatisfying, you are encouraged to tune the controller as well. Following are some suggestions:
-
Directly tune the percentage of the steering signal that is actually applied by Carla. By default, the left turn and right turn signal is tuned with 70% and 85% weight, respectively (the default steer signal tends to overshoot at turns).
-
Modify the configuration file (control_conf.pb.txt) based on your experimental results.
-
Try different controllers: change active_controllers in control_conf.pb.txt from MPC_CONTROLLER to LAT_CONTROLLER, LON_CONTROLLER, then Apollo will apply MPC controller instead.
-
Modify the controller code (e.g., fixing more bugs). These codes include lat_controller.cc, lon_controller.cc, mpc_controller.cc
It is very challenging to get a good controller in co-simulation. The Apollo code can be buggy, not to mention the implementation problems and new challenes brought by Carla. It would be very helpful for the community if you can also contribute to this co-simulation project.
We choose to go to the moon in this decade and do the other things,
not because they are easy, but because they are hard.
-- John F. Kennedy, 1962
Welcome to Apollo's GitHub page!
Apollo is a high performance, flexible architecture which accelerates the development, testing, and deployment of Autonomous Vehicles.
For business and partnership, please visit our website.
Apollo is loaded with new modules and features but needs to be calibrated and configured perfectly before you take it for a spin. Please review the prerequisites and installation steps in detail to ensure that you are well equipped to build and launch Apollo. You could also check out Apollo's architecture overview for a greater understanding of Apollo's core technology and platforms.
[New 2021-01] The Apollo platform (stable version) is now upgraded with software packages and library dependencies of newer versions including:
- CUDA upgraded to version 11.1 to support Nvidia Ampere (30x0 series) GPUs, with NVIDIA driver >= 455.32
- LibTorch (both CPU and GPU version) bumped to version 1.7.0 accordingly.
We do not expect a disruption to your current work, but to ease your life of migration, you would need to:
- Update NVIDIA driver on your host to version >= 455.32. (Web link)
- Pull latest code and run the following commands after restarting and logging into Apollo Development container:
# Remove Bazel output of previous builds
rm -rf /apollo/.cache/{bazel,build,repos}
# Re-configure bazelrc.
./apollo.sh config --noninteractive
-
The vehicle equipped with the by-wire system, including but not limited to brake-by-wire, steering-by-wire, throttle-by-wire and shift-by-wire (Apollo is currently tested on Lincoln MKZ)
-
A machine with a 8-core processor and 16GB memory minimum
-
NVIDIA Turing GPU is strongly recommended
-
Ubuntu 18.04
-
NVIDIA driver version 455.32.00 and above (Web link)
-
Docker-CE version 19.03 and above (Official doc)
-
NVIDIA Container Toolkit (Official doc)
Please note, it is recommended that you install the versions of Apollo in the following order: 1.0 -> whichever version you would like to test out. The reason behind this recommendation is that you need to confirm whether individual hardware components and modules are functioning correctly, and clear various version test cases before progressing to a higher and more capable version for your safety and the safety of those around you.
The following diagram highlights the scope and features of each Apollo release:
Apollo 1.0, also referred to as the Automatic GPS Waypoint Following, works in an enclosed venue such as a test track or parking lot. This installation is necessary to ensure that Apollo works perfectly with your vehicle. The diagram below lists the various modules in Apollo 1.0.
Apollo 1.5 is meant for fixed lane cruising. With the addition of LiDAR, vehicles with this version now have better perception of its surroundings and can better map its current position and plan its trajectory for safer maneuvering on its lane. Please note, the modules highlighted in Yellow are additions or upgrades for version 1.5.
Apollo 2.0 supports vehicles autonomously driving on simple urban roads. Vehicles are able to cruise on roads safely, avoid collisions with obstacles, stop at traffic lights, and change lanes if needed to reach their destination. Please note, the modules highlighted in Red are additions or upgrades for version 2.0.
Apollo 2.5 allows the vehicle to autonomously run on geo-fenced highways with a camera for obstacle detection. Vehicles are able to maintain lane control, cruise and avoid collisions with vehicles ahead of them.
Please note, if you need to test Apollo 2.5; for safety purposes, please seek the help of the
Apollo Engineering team. Your safety is our #1 priority,
and we want to ensure Apollo 2.5 was integrated correctly with your vehicle before you hit the road.
Apollo 3.0's primary focus is to provide a platform for developers to build upon in a closed venue low-speed environment. Vehicles are able to maintain lane control, cruise and avoid collisions with vehicles ahead of them.
Apollo 3.5 is capable of navigating through complex driving scenarios such as residential and downtown areas. The car now has 360-degree visibility, along with upgraded perception algorithms to handle the changing conditions of urban roads, making the car more secure and aware. Scenario-based planning can navigate through complex scenarios, including unprotected turns and narrow streets often found in residential areas and roads with stop signs.
Apollo 5.0 is an effort to support volume production for Geo-Fenced Autonomous Driving. The car now has 360-degree visibility, along with upgraded perception deep learning model to handle the changing conditions of complex road scenarios, making the car more secure and aware. Scenario-based planning has been enhanced to support additional scenarios like pull over and crossing bare intersections.
Apollo 5.5 enhances the complex urban road autonomous driving capabilities of previous Apollo releases, by introducing curb-to-curb driving support. With this new addition, Apollo is now a leap closer to fully autonomous urban road driving. The car has complete 360-degree visibility, along with upgraded perception deep learning model and a brand new prediction model to handle the changing conditions of complex road and junction scenarios, making the car more secure and aware.
Apollo 6.0 incorporates new deep learning models to enhance the capabilities for certain Apollo modules. This version works seamlessly with new additions of data pipeline services to better serve Apollo developers. Apollo 6.0 is also the first version to integrate certain features as a demonstration of our continuous exploration and experimentation efforts towards driverless technology.
Apollo 7.0:
Apollo 7.0 incorporates 3 brand new deep learning models to enhance the capabilities for Apollo Perception and Prediction modules. Apollo Studio is introduced in this version, combining with Data Pipeline, to provide a one-stop online development platform to better serve Apollo developers. Apollo 7.0 also publishes the PnC reinforcement learning model training and simulation evaluation service based on previous simulation service.
Apollo 8.0 is an effort to provide an extensible software framework and complete development cycle for Autonomous Driving developer. Apollo 8.0 introduces easily-reused “Package” to organize software modules. Apollo 8.0 integrates the whole process of perception development ,by combining model training service, model deployment tool and end-to-end visual validation tool . And another 3 new deep learning models are incorporated in Apollo 8.0 for perception module. Simulation service is upgraded by integrating local simulator in Dreamview to provide powerful debug tool for PnC developer.
- Hardware/ Vehicle Overview
- Hardware Connection Overview
- Software Overview
- Hardware installation guide
- Software installation guide - This step is required
- Launch and run Apollo
Congratulations! You have successfully built out Apollo without Hardware. If you do have a vehicle and hardware setup for a particular version, please pick the Quickstart guide most relevant to your setup:
You are welcome to submit questions and bug reports as GitHub Issues.
Apollo is provided under the Apache-2.0 license.
Apollo open source platform only has the source code for models, algorithms and processes, which will be integrated with cybersecurity defense strategy in the deployment for commercialization and productization.
Please refer to the Disclaimer of Apollo in Apollo's official website.
- Have suggestions for our GitHub page?
- YouTube
- Blog
- Newsletter
- Interested in our turnKey solutions or partnering with us Mail us at: [email protected]