Skip to content

Automatic parking with Reinforcement Learning (Q learning with epsilon greedy algorithm) in simulation. A parking environment is created in both Matplotlib and Gazebo.

Notifications You must be signed in to change notification settings

zqw-hooper/Automatic-Parking

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Automatic Parking in simulation

This project utilized reinforcement learning algorithm (Q-learning with epsilon greedy algorithm)

Installation

Requirements:

After you installed these libraries and ROS, follow the following steps:

sudo apt-get install ros-kinetic-gazebo-ros-pkgs ros-kinetic-gazebo-ros-control
sudo apt-get install ros-kinetic-ros-control ros-kinetic-ros-controllers ros-kinetic-controller-manager

mkdir ~/parking
cd ~/parking
git clone https://github.com/CTTC/Automatic-Parking.git

mkdir -p ~/catkin_ws/src
mv ackermann_model/* ~/catkin_ws/src
cd ~/catkin_ws/src
catkin_init_workspace
cd ..
catkin_make

echo "source ~/catkin_ws/devel/setup.bash" >> ~/.bashrc
source ~/.bashrc

Done! Now you can play with the ackermann car in Gazebo by:

roslaunch ackermann_vehicle_gazebo ackermann_vehicle.launch
roslaunch ackermann_drive_teleop ackermann_drive_keyop.launch

Run Demos

Demo in Matplotlib

cd ~/parking/q_learning/matplotlib_sim/demo
python agent.py

Demo in Gazebo

Start running the agent in Gazebo first:

roslaunch ackermann_vehicle_gazebo ackermann_vehicle.launch

Then run the demo

cd ~/parking/q_learning/gazebo_sim/demo
python agent.py

A presentation report is available. Demo videos are available at here and here

About

Automatic parking with Reinforcement Learning (Q learning with epsilon greedy algorithm) in simulation. A parking environment is created in both Matplotlib and Gazebo.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 97.2%
  • TeX 2.5%
  • Other 0.3%