frankcholula's picture
Initial commit
97a88f0 verified
metadata
library_name: stable-baselines3
tags:
  - CarRacing-v3
  - deep-reinforcement-learning
  - reinforcement-learning
  - stable-baselines3
model-index:
  - name: RecurrentPPO
    results:
      - task:
          type: reinforcement-learning
          name: reinforcement-learning
        dataset:
          name: CarRacing-v3
          type: CarRacing-v3
        metrics:
          - type: mean_reward
            value: 384.92 +/- 161.14
            name: mean_reward
            verified: false

RecurrentPPO Agent playing CarRacing-v3

This is a trained model of a RecurrentPPO agent playing CarRacing-v3 using the stable-baselines3 library and the RL Zoo.

The RL Zoo is a training framework for Stable Baselines3 reinforcement learning agents, with hyperparameter optimization and pre-trained agents included.

Usage (with SB3 RL Zoo)

RL Zoo: https://github.com/DLR-RM/rl-baselines3-zoo
SB3: https://github.com/DLR-RM/stable-baselines3
SB3 Contrib: https://github.com/Stable-Baselines-Team/stable-baselines3-contrib SBX (SB3 + Jax): https://github.com/araffin/sbx

Install the RL Zoo (with SB3 and SB3-Contrib):

pip install rl_zoo3
# Download model and save it into the logs/ folder
python -m rl_zoo3.load_from_hub --algo ppo_lstm --env CarRacing-v3 -orga frankcholula -f logs/
python -m rl_zoo3.enjoy --algo ppo_lstm --env CarRacing-v3  -f logs/

If you installed the RL Zoo3 via pip (pip install rl_zoo3), from anywhere you can do:

python -m rl_zoo3.load_from_hub --algo ppo_lstm --env CarRacing-v3 -orga frankcholula -f logs/
python -m rl_zoo3.enjoy --algo ppo_lstm --env CarRacing-v3  -f logs/

Training (with the RL Zoo)

python -m rl_zoo3.train --algo ppo_lstm --env CarRacing-v3 -f logs/
# Upload the model and generate video (when possible)
python -m rl_zoo3.push_to_hub --algo ppo_lstm --env CarRacing-v3 -f logs/ -orga frankcholula

Hyperparameters

OrderedDict([('batch_size', 128),
             ('clip_range', 0.2),
             ('ent_coef', 0.0),
             ('env_wrapper',
              [{'rl_zoo3.wrappers.YAMLCompatResizeObservation': {'shape': [64,
                                                                           64]}},
               {'gymnasium.wrappers.transform_observation.GrayscaleObservation': {'keep_dim': True}}]),
             ('frame_stack', 2),
             ('gae_lambda', 0.95),
             ('gamma', 0.99),
             ('learning_rate', 'lin_1e-4'),
             ('max_grad_norm', 0.5),
             ('n_envs', 8),
             ('n_epochs', 10),
             ('n_steps', 512),
             ('n_timesteps', 4000000.0),
             ('normalize', "{'norm_obs': False, 'norm_reward': True}"),
             ('policy', 'CnnLstmPolicy'),
             ('policy_kwargs',
              'dict(log_std_init=-2, ortho_init=False, '
              'enable_critic_lstm=False, activation_fn=nn.GELU, '
              'lstm_hidden_size=128, )'),
             ('sde_sample_freq', 4),
             ('use_sde', True),
             ('vf_coef', 0.5),
             ('normalize_kwargs', {'norm_obs': False, 'norm_reward': False})])

Environment Arguments

{'render_mode': 'rgb_array'}