2020-05-05 14:52:22 +00:00
|
|
|
import pytest
|
|
|
|
|
|
2020-07-16 14:12:16 +00:00
|
|
|
from stable_baselines3 import A2C, DQN, PPO, SAC, TD3
|
2020-05-05 14:52:22 +00:00
|
|
|
from stable_baselines3.common.noise import NormalActionNoise
|
|
|
|
|
|
|
|
|
|
N_STEPS_TRAINING = 3000
|
|
|
|
|
SEED = 0
|
|
|
|
|
|
|
|
|
|
|
2020-06-29 09:16:54 +00:00
|
|
|
@pytest.mark.parametrize("algo", [A2C, DQN, PPO, SAC, TD3])
|
2020-05-05 14:52:22 +00:00
|
|
|
def test_deterministic_training_common(algo):
|
|
|
|
|
results = [[], []]
|
|
|
|
|
rewards = [[], []]
|
|
|
|
|
# Smaller network
|
2020-07-16 14:12:16 +00:00
|
|
|
kwargs = {"policy_kwargs": dict(net_arch=[64])}
|
2020-05-05 14:52:22 +00:00
|
|
|
if algo in [TD3, SAC]:
|
2020-07-16 14:12:16 +00:00
|
|
|
env_id = "Pendulum-v0"
|
|
|
|
|
kwargs.update({"action_noise": NormalActionNoise(0.0, 0.1), "learning_starts": 100})
|
2020-05-05 14:52:22 +00:00
|
|
|
else:
|
2020-07-16 14:12:16 +00:00
|
|
|
env_id = "CartPole-v1"
|
2020-06-29 09:16:54 +00:00
|
|
|
if algo == DQN:
|
2020-07-16 14:12:16 +00:00
|
|
|
kwargs.update({"learning_starts": 100})
|
2020-05-05 14:52:22 +00:00
|
|
|
|
|
|
|
|
for i in range(2):
|
2020-07-16 14:12:16 +00:00
|
|
|
model = algo("MlpPolicy", env_id, seed=SEED, **kwargs)
|
2020-05-05 14:52:22 +00:00
|
|
|
model.learn(N_STEPS_TRAINING)
|
|
|
|
|
env = model.get_env()
|
|
|
|
|
obs = env.reset()
|
|
|
|
|
for _ in range(100):
|
|
|
|
|
action, _ = model.predict(obs, deterministic=False)
|
|
|
|
|
obs, reward, _, _ = env.step(action)
|
|
|
|
|
results[i].append(action)
|
|
|
|
|
rewards[i].append(reward)
|
|
|
|
|
assert sum(results[0]) == sum(results[1]), results
|
|
|
|
|
assert sum(rewards[0]) == sum(rewards[1]), rewards
|