Releasing Tianshou's SOTA benchmark of 9 out of 13 environments from the MuJoCo Gym task suite.
Tianshou's Mujoco Benchmark
We benchmarked Tianshou algorithm implementations in 9 out of 13 environments from the MuJoCo Gym task suite[1].
For each supported algorithm and supported mujoco environments, we provide:
- Default hyperparameters used for benchmark and scripts to reproduce the benchmark;
- A comparison of performance (or code level details) with other open source implementations or classic papers;
- Graphs and raw data that can be used for research purposes[2];
- Log details obtained during training[2];
- Pretrained agents[2];
- Some hints on how to tune the algorithm.
Supported algorithms are listed below:
- Deep Deterministic Policy Gradient (DDPG), commit id
- Twin Delayed DDPG (TD3), commit id
- Soft Actor-Critic (SAC), commit id
Offpolicy algorithms
Usage
Run
$ python mujoco_sac.py --task Ant-v3
Logs is saved in ./log/ and can be monitored with tensorboard.
$ tensorboard --logdir log
You can also reproduce the benchmark (e.g. SAC in Ant-v3) with the example script we provide under examples/mujoco/:
$ ./run_experiments.sh Ant-v3
This will start 10 experiments with different seeds.
Example benchmark
 
Other graphs can be found under /examples/mujuco/benchmark/
Hints
In offpolicy algorithms(DDPG, TD3, SAC), the shared hyperparameters are almost the same[8], and most hyperparameters are consistent with those used for benchmark in SpinningUp's implementations[9].
By comparison to both classic literature and open source implementations (e.g., SpinningUp)[1][2], Tianshou's implementations of DDPG, TD3, and SAC are roughly at-parity with or better than the best reported results for these algorithms.
DDPG
| Environment | Tianshou | SpinningUp (PyTorch) | TD3 paper (DDPG) | TD3 paper (OurDDPG) | 
|---|---|---|---|---|
| Ant | 990.4±4.3 | ~840 | 1005.3 | 888.8 | 
| HalfCheetah | 11718.7±465.6 | ~11000 | 3305.6 | 8577.3 | 
| Hopper | 2197.0±971.6 | ~1800 | 2020.5 | 1860.0 | 
| Walker2d | 1400.6±905.0 | ~1950 | 1843.6 | 3098.1 | 
| Swimmer | 144.1±6.5 | ~137 | N | N | 
| Humanoid | 177.3±77.6 | N | N | N | 
| Reacher | -3.3±0.3 | N | -6.51 | -4.01 | 
| InvertedPendulum | 1000.0±0.0 | N | 1000.0 | 1000.0 | 
| InvertedDoublePendulum | 8364.3±2778.9 | N | 9355.5 | 8370.0 | 
TD3
| Environment | Tianshou | SpinningUp (Pytorch) | TD3 paper | 
|---|---|---|---|
| Ant | 5116.4±799.9 | ~3800 | 4372.4±1000.3 | 
| HalfCheetah | 10201.2±772.8 | ~9750 | 9637.0±859.1 | 
| Hopper | 3472.2±116.8 | ~2860 | 3564.1±114.7 | 
| Walker2d | 3982.4±274.5 | ~4000 | 4682.8±539.6 | 
| Swimmer | 104.2±34.2 | ~78 | N | 
| Humanoid | 5189.5±178.5 | N | N | 
| Reacher | -2.7±0.2 | N | -3.6±0.6 | 
| InvertedPendulum | 1000.0±0.0 | N | 1000.0±0.0 | 
| InvertedDoublePendulum | 9349.2±14.3 | N | 9337.5±15.0 | 
SAC
| Environment | Tianshou | SpinningUp (Pytorch) | SAC paper | 
|---|---|---|---|
| Ant | 5850.2±475.7 | ~3980 | ~3720 | 
| HalfCheetah | 12138.8±1049.3 | ~11520 | ~10400 | 
| Hopper | 3542.2±51.5 | ~3150 | ~3370 | 
| Walker2d | 5007.0±251.5 | ~4250 | ~3740 | 
| Swimmer | 44.4±0.5 | ~41.7 | N | 
| Humanoid | 5488.5±81.2 | N | ~5200 | 
| Reacher | -2.6±0.2 | N | N | 
| InvertedPendulum | 1000.0±0.0 | N | N | 
| InvertedDoublePendulum | 9359.5±0.4 | N | N | 
Hints for SAC
- DO NOT share the same network with two critic networks.
- The sigma (of the Gaussian policy) should be conditioned on input.
- The network size should not be less than 256.
- The deterministic evaluation helps a lot :)
Onpolicy Algorithms
TBD
Note
[1] Supported environments include HalfCheetah-v3, Hopper-v3, Swimmer-v3, Walker2d-v3, Ant-v3, Humanoid-v3, Reacher-v2, InvertedPendulum-v2 and InvertedDoublePendulum-v2. Pusher, Thrower, Striker and HumanoidStandup are not supported because they are not commonly seen in literatures.
[2] Pretrained agents, detailed graphs (single agent, single game) and log details can all be found here.
[3] We used the latest version of all mujoco environments in gym (0.17.3 with mujoco==2.0.2.13), but it's not often the case with other benchmarks. Please check for details yourself in the original paper. (Different version's outcomes are usually similar, though)
[4] We didn't compare offpolicy algorithms to OpenAI baselines benchmark, because for now it seems that they haven't provided benchmark for offpolicy algorithms, but in SpinningUp docs they stated that "SpinningUp implementations of DDPG, TD3, and SAC are roughly at-parity with the best-reported results for these algorithms", so we think lack of comparisons with OpenAI baselines is okay.
[5] ~ means the number is approximated from the graph because accurate numbers is not provided in the paper. N means graphs not provided.
[6] Reward metric: The meaning of the table value is the max average return over 10 trails (different seeds) ± a single standard deviation over trails. Each trial is averaged on another 10 test seeds. Only the first 1M steps data will be considered. The shaded region on the graph also represents a single standard deviation. It is the same as TD3 evaluation method.
[7] In TD3 paper, shaded region represents only half of standard deviation.
[8] SAC's start-timesteps is set to 10000 by default while it is 25000 is DDPG/TD3. TD3's learning rate is set to 3e-4 while it is 1e-3 for DDPG/SAC. However, there is NO enough evidence to support our choice of such hyperparameters (we simply choose them because of SpinningUp) and you can try playing with those hyperparameters to see if you can improve performance. Do tell us if you can!
[9]  We use batchsize of 256 in DDPG/TD3/SAC while SpinningUp use 100. Minor difference also lies with start-timesteps, data loop method step_per_collect, method to deal with/bootstrap truncated steps because of timelimit and unfinished/collecting episodes (contribute to performance improvement), etc.