openpilot is an open source driver assistance system. openpilot performs the functions of Automated Lane Centering and Adaptive Cruise Control for over 200 supported car makes and models.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Vehicle Researcher b4f4b92ecf Merge opendbc subtree 6 years ago
.github openpilot v0.6.5 release 6 years ago
apk openpilot v0.6.5 release 6 years ago
cereal Merge cereal subtree 6 years ago
common Allow to lock safety mode to keep gm/tesla cars supported (#844) 6 years ago
installer/updater openpilot v0.6.5 release 6 years ago
models openpilot v0.6.5 release 6 years ago
opendbc Merge opendbc subtree 6 years ago
panda Merge panda subtree 6 years ago
phonelibs openpilot v0.6.4 release 6 years ago
pyextra Merge pyextra subtree 6 years ago
selfdrive Adds 2019 Lexus ES (non hybrid) (#866) 6 years ago
.gitignore openpilot v0.6.5 release 6 years ago
.pylintrc Add pylint to travis-ci (#595) 7 years ago
.travis.yml Fix run_docker_tests.sh (#730) 6 years ago
CONTRIBUTING.md openpilot v0.5.12 release 7 years ago
Dockerfile.openpilot openpilot v0.6.5 release 6 years ago
LICENSE openpilot v0.4.3 release 8 years ago
Makefile openpilot v0.3.8.2 release 8 years ago
Pipfile openpilot v0.6.5 release 6 years ago
Pipfile.lock openpilot v0.6.5 release 6 years ago
README.md Squashed 'panda/' changes from 30c7ca8a5..256d274e7 6 years ago
README_chffrplus.md openpilot v0.4.3 release 8 years ago
RELEASES.md openpilot v0.6.5 release 6 years ago
SAFETY.md openpilot v0.5.11 release 7 years ago
check_code_quality.sh openpilot v0.5.12 release 7 years ago
launch_chffrplus.sh openpilot v0.6.5 release 6 years ago
launch_openpilot.sh openpilot v0.4.3 release 8 years ago
run_docker_tests.sh openpilot v0.6.5 release 6 years ago

README.md

Welcome to openpilot

openpilot is an open source driver assistance system. Currently, it performs the functions of Adaptive Cruise Control (ACC) and Lane Keeping Assist System (LKAS) for selected Honda, Toyota, Acura, Lexus, Chevrolet, Hyundai, Kia. It's about on par with Tesla Autopilot and GM Super Cruise, and better than all other manufacturers.

The openpilot codebase has been written to be concise and to enable rapid prototyping. We look forward to your contributions - improving real vehicle automation has never been easier.

Table of Contents


Community

openpilot is developed by comma.ai and users like you.

We have a Twitter you should follow.

Also, we have a several thousand people community on Discord.

Hardware

At the moment openpilot supports the EON Dashcam DevKit. A panda and a giraffe are recommended tools to interface the EON with the car. We'd like to support other platforms as well.

Install openpilot on a neo device by entering https://openpilot.comma.ai during NEOS setup.

Supported Cars

Make Model (US Market Reference) Supported Package Lateral Longitudinal No Accel Below No Steer Below Giraffe
Acura ILX 2016-18 AcuraWatch Plus Yes Yes 25mph1 25mph Nidec
Acura RDX 2016-18 AcuraWatch Plus Yes Yes 25mph1 12mph Nidec
Buick3 Regal 2018 Adaptive Cruise Yes Yes 0mph 7mph Custom6
Chevrolet3 Malibu 2017 Adaptive Cruise Yes Yes 0mph 7mph Custom6
Chevrolet3 Volt 2017-18 Adaptive Cruise Yes Yes 0mph 7mph Custom6
Cadillac3 ATS 2018 Adaptive Cruise Yes Yes 0mph 7mph Custom6
Chrysler Pacifica 2017-18 Adaptive Cruise Yes Stock 0mph 9mph FCA
Chrysler Pacifica Hybrid 2017-18 Adaptive Cruise Yes Stock 0mph 9mph FCA
Chrysler Pacifica Hybrid 2019 Adaptive Cruise Yes Stock 0mph 39mph FCA
GMC3 Acadia Denali 2018 Adaptive Cruise Yes Yes 0mph 7mph Custom6
Holden3 Astra 2017 Adaptive Cruise Yes Yes 0mph 7mph Custom6
Honda Accord 2018-19 All Yes Stock 0mph 3mph Bosch
Honda Accord Hybrid 2018-19 All Yes Stock 0mph 3mph Bosch
Honda Civic Sedan/Coupe 2016-18 Honda Sensing Yes Yes 0mph 12mph Nidec
Honda Civic Sedan/Coupe 2019 Honda Sensing Yes Stock 0mph 2mph Bosch
Honda Civic Hatchback 2017-19 Honda Sensing Yes Stock 0mph 12mph Bosch
Honda CR-V 2015-16 Touring Yes Yes 25mph1 12mph Nidec
Honda CR-V 2017-19 Honda Sensing Yes Stock 0mph 12mph Bosch
Honda CR-V Hybrid 2017-2019 Honda Sensing Yes Stock 0mph 12mph Bosch
Honda Fit 2018-19 Honda Sensing Yes Yes 25mph1 12mph Inverted Nidec
Honda Odyssey 2018-19 Honda Sensing Yes Yes 25mph1 0mph Inverted Nidec
Honda Passport 2019 All Yes Yes 25mph1 12mph Inverted Nidec
Honda Pilot 2016-18 Honda Sensing Yes Yes 25mph1 12mph Nidec
Honda Pilot 2019 All Yes Yes 25mph1 12mph Inverted Nidec
Honda Ridgeline 2017-19 Honda Sensing Yes Yes 25mph1 12mph Nidec
Hyundai Santa Fe 2019 All Yes Stock 0mph 0mph Custom5
Hyundai Elantra 2017-19 SCC + LKAS Yes Stock 19mph 34mph Custom5
Hyundai Genesis 2018 All Yes Stock 19mph 34mph Custom5
Jeep Grand Cherokee 2016-18 Adaptive Cruise Yes Stock 0mph 9mph FCA
Jeep Grand Cherokee 2019 Adaptive Cruise Yes Stock 0mph 39mph FCA
Kia Optima 2019 SCC + LKAS Yes Stock 0mph 0mph Custom5
Kia Sorento 2018 All Yes Stock 0mph 0mph Custom5
Kia Stinger 2018 SCC + LKAS Yes Stock 0mph 0mph Custom5
Lexus CT Hybrid 2017-18 All Yes Yes2 0mph 0mph Toyota
Lexus ES 2019 All Yes Yes 0mph 0mph Toyota
Lexus ES Hybrid 2019 All Yes Yes 0mph 0mph Toyota
Lexus RX Hybrid 2016-19 All Yes Yes2 0mph 0mph Toyota
Lexus IS 2017-2019 All Yes Stock 22mph 0mph Toyota
Lexus IS Hybrid 2017 All Yes Stock 0mph 0mph Toyota
Subaru Crosstrek 2018-19 EyeSight Yes Stock 0mph 0mph Subaru
Subaru Impreza 2019-20 EyeSight Yes Stock 0mph 0mph Subaru
Toyota Avalon 2016 TSS-P Yes Yes2 20mph1 0mph Toyota
Toyota Avalon 2017-18 All Yes Yes2 20mph1 0mph Toyota
Toyota Camry 2018-19 All Yes Stock 0mph4 0mph Toyota
Toyota Camry Hybrid 2018-19 All Yes Stock 0mph4 0mph Toyota
Toyota C-HR 2017-19 All Yes Stock 0mph 0mph Toyota
Toyota C-HR Hybrid 2017-19 All Yes Stock 0mph 0mph Toyota
Toyota Corolla 2017-19 All Yes Yes2 20mph1 0mph Toyota
Toyota Corolla 2020 All Yes Yes 0mph 0mph Toyota
Toyota Corolla Hatchback 2019 All Yes Yes 0mph 0mph Toyota
Toyota Corolla Hybrid 2019 All Yes Yes 0mph 0mph Toyota
Toyota Highlander 2017-19 All Yes Yes2 0mph 0mph Toyota
Toyota Highlander Hybrid 2017-19 All Yes Yes2 0mph 0mph Toyota
Toyota Prius 2016 TSS-P Yes Yes2 0mph 0mph Toyota
Toyota Prius 2017-19 All Yes Yes2 0mph 0mph Toyota
Toyota Prius Prime 2017-20 All Yes Yes2 0mph 0mph Toyota
Toyota Rav4 2016 TSS-P Yes Yes2 20mph1 0mph Toyota
Toyota Rav4 2017-18 All Yes Yes2 20mph1 0mph Toyota
Toyota Rav4 2019 All Yes Yes 0mph 0mph Toyota
Toyota Rav4 Hybrid 2016 TSS-P Yes Yes2 0mph 0mph Toyota
Toyota Rav4 Hybrid 2017-18 All Yes Yes2 0mph 0mph Toyota
Toyota Sienna 2018 All Yes Yes2 0mph 0mph Toyota

1Comma Pedal is used to provide stop-and-go capability to some of the openpilot-supported cars that don't currently support stop-and-go. Here is how to build a Comma Pedal. NOTE: The Comma Pedal is not officially supported by comma.ai.
2When disconnecting the Driver Support Unit (DSU), otherwise longitudinal control is stock ACC. For DSU locations, see Toyota Wiki page. NOTE: disconnecting the DSU disables Automatic Emergency Braking (AEB).
3GM installation guide. NOTE: disconnecting the ASCM disables Automatic Emergency Braking (AEB).
428mph for Camry 4CYL L, 4CYL LE and 4CYL SE which don't have Full-Speed Range Dynamic Radar Cruise Control.
5Open sourced Hyundai Giraffe is designed for the 2019 Sante Fe; pinout may differ for other Hyundais.
6Community built Giraffe, find more information here.

Community Maintained Cars

Make Model Supported Package Lateral Longitudinal No Accel Below No Steer Below Giraffe
Tesla Model S 2012-13 All Yes Not yet Not applicable 0mph Custom7

[Tesla Model S Pull Request]
7Community built Giraffe, find more information here Community Tesla Giraffe

Community Maintained Cars are not confirmed by comma.ai to meet our safety model. Be extra cautious using them.

In Progress Cars

  • All TSS-P Toyota with Steering Assist and LSS-P Lexus with Steering Assist or Lane Keep Assist.
  • All Hyundai with SmartSense.
  • All Kia, Genesis with SCC and LKAS.
  • All Chrysler, Jeep, Fiat with Adaptive Cruise Control and LaneSense.
  • All Subaru with EyeSight.

How can I add support for my car?

If your car has adaptive cruise control and lane keep assist, you are in luck. Using a panda and cabana, you can understand how to make your car drive by wire.

We've written guides for Brand and Model ports. These guides might help you after you have the basics figured out.

  • BMW, Audi, Volvo, and Mercedes all use FlexRay and can be supported after FlexRay support is merged.
  • We put time into a Ford port, but the steering has a 10 second cutout limitation that makes it unusable.
  • The 2016-2017 Honda Accord uses a custom signaling protocol for steering that's unlikely to ever be upstreamed.

Directory structure

.
├── apk                 # The apk files used for the UI
├── cereal              # The messaging spec used for all logs on EON
├── common              # Library like functionality we've developed here
├── installer/updater   # Manages auto-updates of openpilot
├── opendbc             # Files showing how to interpret data from cars
├── panda               # Code used to communicate on CAN and LIN
├── phonelibs           # Libraries used on EON
├── pyextra             # Libraries used on EON
└── selfdrive           # Code needed to drive the car
    ├── assets          # Fonts and images for UI
    ├── athena          # Allows communication with the app
    ├── boardd          # Daemon to talk to the board
    ├── can             # Helpers for parsing CAN messages
    ├── car             # Car specific code to read states and control actuators
    ├── common          # Shared C/C++ code for the daemons
    ├── controls        # Perception, planning and controls
    ├── debug           # Tools to help you debug and do car ports
    ├── locationd       # Soon to be home of precise location
    ├── logcatd         # Android logcat as a service
    ├── loggerd         # Logger and uploader of car data
    ├── proclogd        # Logs information from proc
    ├── sensord         # IMU / GPS interface code
    ├── test            # Car simulator running code through virtual maneuvers
    ├── ui              # The UI
    └── visiond         # Vision pipeline

To understand how the services interact, see selfdrive/service_list.yaml

User Data / chffr Account / Crash Reporting

By default, openpilot creates an account and includes a client for chffr, our dashcam app. We use your data to train better models and improve openpilot for everyone.

It's open source software, so you are free to disable it if you wish.

It logs the road facing camera, CAN, GPS, IMU, magnetometer, thermal sensors, crashes, and operating system logs. The user facing camera is only logged if you explicitly opt-in in settings. It does not log the microphone.

By using it, you agree to our privacy policy. You understand that use of this software or its related services will generate certain types of user data, which may be logged and stored at the sole discretion of comma.ai. By accepting this agreement, you grant an irrevocable, perpetual, worldwide right to comma.ai for the use of this data.

Testing on PC

Check out openpilot-tools: lots of tools you can use to replay driving data, test and develop openpilot from your pc.

Also, within openpilot there is a rudimentary infrastructure to run a basic simulation and generate a report of openpilot's behavior in different longitudinal control scenarios.

# Requires working docker
./run_docker_tests.sh

Contributing

We welcome both pull requests and issues on github. Bug fixes and new car ports encouraged.

We also have a bounty program.

Want to get paid to work on openpilot? comma.ai is hiring

Licensing

openpilot is released under the MIT license. Some parts of the software are released under other licenses as specified.

Any user of this software shall indemnify and hold harmless Comma.ai, Inc. and its directors, officers, employees, agents, stockholders, affiliates, subcontractors and customers from and against all allegations, claims, actions, suits, demands, damages, liabilities, obligations, losses, settlements, judgments, costs and expenses (including without limitation attorneys’ fees and costs) which arise out of, relate to or result from any use of this software by user.

THIS IS ALPHA QUALITY SOFTWARE FOR RESEARCH PURPOSES ONLY. THIS IS NOT A PRODUCT. YOU ARE RESPONSIBLE FOR COMPLYING WITH LOCAL LAWS AND REGULATIONS. NO WARRANTY EXPRESSED OR IMPLIED.