Table of Contents
This is the first official Code Release of "Real-time Active Vision for a Humanoid Soccer Robot using Deep Reinforcement Learning" paper.
Also, hereby, a world model method is open-sourced. This world model method was introduced by Meisam Teimouri. It is converted to C++ by me, Soheil Khatibi, in order to reduce the run-time.
Unfortunately, the code, especially the world model section, is too messy. it is to be well documented and cleaned.
The project is built using Tensorflow, specifically Stable Baselines, and Webots Simulation.
In order to get started with this project, you need to use RoboCup-Humanoid-MRL-Webots-Simulation, which is the simulation of the MRL-HSL Humanoid Robot in a Kid-Size Humanoid Soccer League RoboCup 2019 environment.
To run this simulated environment, you need to install:
- Webots R2023b. (Instructions)
- Tensorflow (GPU) 1.15
- stable-baselines 2.10 (Link)
- gym 0.15.7
This code was developed and tested with Python 3.6 (using Miniconda) installed on Ubuntu 20.04
After installing Webots R2023b, You can open this environment as follows:
- Clone the RoboCup-Humanoid-MRL-Webots-Simulation repository and run it (instructions could be found here):
git clone https://github.com/SoheilKhatibi/RoboCup-Humanoid-MRL-Webots-Simulation.git cd RoboCup-Humanoid-MRL-Webots-Simulation /path/to/webots worlds/Rules_2019.wbt
- In another terminal, clone the repository:
git clone https://github.com/SoheilKhatibi/Humanoid-Robot-Active-Vision-DDQN.git
- Build the world model module:
cd Humanoid-Robot-Active-Vision-DDQN cd RobotWorldModel make
- Run the Code:
cd Humanoid-Robot-Active-Vision-DDQN cd DQNController python DQNController.py
- This ReadMe is created using this useful template, by othneildrew.
- In the Robot World Model section, The lua parser module for C++ is copied from the code of a blog post which unfortunately I can not find to reference here.
Soheil Khatibi - Soheil Khatibi - [email protected]
Project Link: https://github.com/SoheilKhatibi/RoboCup-Humanoid-MRL-Webots-Simulation
Special Thanks to:
- Meisam Teimouri for contributing in the project