28 lines
1.5 KiB
Python
28 lines
1.5 KiB
Python
import gymnasium as gym
|
|
import pytest
|
|
|
|
from metastable_baselines2 import TRPL
|
|
|
|
PROJECTIONS = ["Frobenius", "Wasserstein"] # KL
|
|
|
|
@pytest.mark.parametrize("env_id", ["LunarLanderContinuous-v2", "MountainCarContinuous-v0"])
|
|
@pytest.mark.parametrize("projection", PROJECTIONS)
|
|
def test_trpl(env_id, projection):
|
|
model = TRPL("MlpPolicy", env_id, n_steps=128, seed=0, policy_kwargs=dict(net_arch=[16]), projection_class=projection, verbose=1)
|
|
model.learn(total_timesteps=500)
|
|
|
|
@pytest.mark.parametrize("env_id", ["LunarLanderContinuous-v2"])
|
|
@pytest.mark.parametrize("projection", PROJECTIONS)
|
|
@pytest.mark.parametrize("mean_bound", [0.03, 0.06])
|
|
@pytest.mark.parametrize("cov_bound", [1.0e-3, 2.0e-3])
|
|
def test_trpl_params(env_id, projection, mean_bound, cov_bound):
|
|
model = TRPL("MlpPolicy", env_id, n_steps=128, seed=0, policy_kwargs=dict(net_arch=[16]), projection_class=projection, projection_kwargs={'mean_bound': mean_bound, 'cov_bound': cov_bound}, verbose=1)
|
|
model.learn(total_timesteps=100)
|
|
|
|
@pytest.mark.parametrize("env_id", ["LunarLanderContinuous-v2"])
|
|
@pytest.mark.parametrize("projection", PROJECTIONS)
|
|
@pytest.mark.parametrize("par_strength", ['DIAG', 'FULL', 'CONT_DIAG', 'CONT_FULL'])
|
|
def test_trpl_pca(env_id, projection, par_strength):
|
|
model = TRPL("MlpPolicy", env_id, n_steps=128, seed=0, use_pca=True, policy_kwargs=dict(net_arch=[16], dist_kwargs={'par_strength': par_strength, 'skip_conditioning': True}), projection_class=projection, verbose=1)
|
|
model.learn(total_timesteps=100)
|