Skip to content

We are trying to combine reinforcement learning and trajectory optimization to win in F 1/10 racing.

Notifications You must be signed in to change notification settings

christopher-hsu/rl-path-racing

 
 

Repository files navigation

Racing Using SQN Reinforcement Learning

We are trying to combine reinforcement learning and trajectory optimization to win in F 1/10 racing. This repository is under heavy development and is not yet stable for any use-case.

Soft Q Network training of RL agent for high level decision making. https://github.com/christopher-hsu/f1tenth-spinningup

Milestone 1 Proposal:

You can read our proposal here: Proposal

Milestone 2 (Race one):

The only purpose is to complete going around the race track in the shortest time possible. There are not any other competitors in the race. We found the shortest path around the track (using b-spline) and are using a pure pursuit algorithm to track the path around the track. Using the old f110 simulator you can see the performance of our method around the track (the optimized path is pink):

Milestone 3 (Race two):

The main goal is to drive safely around the track by avoiding obstacles. The method we used to approach this problem is with a high-level Time-To-Collision (TTC) style calculation to decide on which path provides the most space. We follow the waypoint associated with the best TTC using Pure Pursuit:

Milestone 4 (Final race):

Our solution tries to combine safety of formal methods with performance of learning based methods, given a set of spline paths, the RL-based high-level decision maker learns to choose a path to follow based on the current observations of the race Then our controller uses the action (decided path), confirms with TTC for availability of the path and uses pure pursuit to follow the decision. In the gif below you can see how we perfrom against an opponent agent (Our agent is blue).

Structure of SQN policy -- state to action

Modified from Soft Actor Critic from OpenAI SpinningUp https://spinningup.openai.com/en/latest/

  • Based on Clipped Double Q-learning - Fujimoto 2018
  • Outputs discrete actions
  • Using entropy regularized exploration

Overall Reinforcement Learning Training Strategy (self play, adversarial style learning)

  • Train ego agent against pure-pursuit opponent agent without notion of obstacles

    • Did not learn a good policy because opponent agent doesn’t react
    • Therefore...
  • Train ego agent against opponent agent following a path with TTC reaction

  • Train ego agent against the previously learned policy

  • Repeat

  • Some additional things

    • Cosine learning rate schedule
    • Randomly initialize agents to be in first or second position at start

Logistics

We have included both the new and old f110 simulators in this repository. Make sure that the new simulator pre requisites are properly installed (docker,etc.).

To run our code:

  • Clone this repositpory in src folder of your ROS workspace and catkin_make the workspace (make sure you dont have a duplicate new or old F110 simulator in your workspace since that might cause issues when making the workspace)

Then run the following depending on which simulator you are planning on using:

Race one: single car, no obstacles

For the old simulator:

  • Run the following in a new terminal: roslaunch first_race race_old.launch

For the new simulator:

  • Go to f1tenth_gym_ros folder and run the following in a new terminal: sudo ./docker.sh
  • Run the following in a new terminal: roslaunch first_race race_new.launch

Race two: single car, obstacles

For the old simulator:

  • Run the following in a new terminal: roslaunch second_race race_old.launch

For the new simulator:

  • Go to f1tenth_gym_ros folder and run the following in a new terminal: sudo ./docker.sh
  • Run the following in a new terminal: roslaunch second_race race_new.launch

Final Race: moving opponent, no obstacles

For the new simulator:

  • Go to f1tenth_gym_ros folder and run the following in a new terminal: sudo ./docker.sh
  • Run the following in a new terminal: roslaunch final_race race_new.launch

Progress updates

In addition to finishing the prerequisites for the first race, we have completed the following milestones preparing for the final race:

  • We created 10 lanes that go around the track (used for the action space of our RL) and you can see them below:

  • We then created more lanes in order to cover more of the track.

  • We Implemented the foundation/structure of SQN for training. This includes defining appropriate observation state and possible reward structure
  • We are done with integrating pure pursuit with RL structure so that we can take RL output and act on it and control the car appropritely
  • We are shifting to a local coordinate frame and including all sensor reading for the RL observation state.
  • We will integrate the TTC path selector into the RL framework
  • Reward shaping

About

We are trying to combine reinforcement learning and trajectory optimization to win in F 1/10 racing.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 48.3%
  • C++ 44.3%
  • CMake 6.2%
  • Dockerfile 1.1%
  • Shell 0.1%