/AIAgentplaying_ATARI

This project implements Deep Q-Network (DQN) agents for playing Atari games using reinforcement learning

Primary LanguagePython

AIAgentplaying_ATARI

This project implements Deep Q-Network (DQN) agents for playing Atari games using reinforcement learning. The repository contains different versions and modifications of DQN agents such as vanilla DQN, Duel DQN, and Episodic DQN.

Project Structure

.
├── agent.py                    # Core implementation of the DQN agent
├── agent_dqn_duel.py            # Dueling DQN implementation
├── agent_dqn.py                 # Vanilla DQN implementation
├── agent_dqn_epi.py             # Episodic DQN variant
├── argument.py                  # Command line argument parsing
├── atari_wrapper.py             # Environment wrappers for Atari games
├── dqn_model.py                 # Definition of the neural network model for DQN
├── environment.py               # Atari environment setup and initialization
├── main.py                      # Main script to train and run the DQN agents
├── test.py                      # Script for testing the trained DQN agent
└── README.md                    # Project overview and setup instructions

Results

Reward vs Epsiode Of Various DQN

Setup

Recommended IDE

  • Visual Studio Code (VS Code) is recommended for this project. Install VS Code.

Steps

  1. Install Miniconda: Follow the instructions here to install Miniconda.

  2. Create a virtual environment:
    Run the following to create a virtual environment with Python 3.11.4:

    conda create -n myenv python=3.11.4

    This creates an environment named myenv. Ensure that Gymnasium supports Python versions 3.8, 3.9, 3.10, or 3.11 on Linux and macOS.

  3. Activate your virtual environment:

    conda activate myenv
  4. Install Gymnasium:
    Install the necessary libraries:

    pip install opencv-python-headless gymnasium[atari] autorom[accept-rom-license]
  5. Install PyTorch:
    Install PyTorch based on your system configuration by following the instructions here.
    Alternatively, you can install PyTorch via pip:

    pip install torch torchvision torchaudio
  6. Install Ray for Atari wrapper:
    Install Ray for reinforcement learning and additional packages:

    pip install -U "ray[rllib]" ipywidgets
  7. Install additional dependencies:
    For successful execution of the code, install the following:

    pip install --upgrade scipy numpy
  8. Install video recording dependencies:
    To enable video recording during testing, install:

    pip install moviepy ffmpeg
  9. Install tqdm for progress visualization:
    For nice terminal output during testing:

    pip install tqdm

How to Run

Training DQN:

To start training a DQN agent, run:

python main.py --train_dqn

Testing DQN:

To test the performance of the trained DQN agent:

python main.py --test_dqn

Testing DQN with video recording:

For testing with video recording (this may slow down the execution, so it's recommended for small numbers of episodes):

python main.py --test_dqn --record_video

Goal

In this project, the goal is to implement Deep Q-Network (DQN) to play the Atari game Breakout. The task is to train the agent to achieve an average reward of over 40 points across 100 episodes. Each episode consists of 5 lives. The training must use OpenAI's Atari wrapper and a clipped reward system.

Requirements

  • Python 3.8, 3.9, 3.10, or 3.11
  • Gymnasium
  • PyTorch
  • NumPy
  • MoviePy (for video recording)
  • tqdm (for progress visualization)