2021-06-28 17:25:53 +02:00
|
|
|
from alr_envs import HoleReacherMPWrapper
|
|
|
|
from alr_envs.utils.make_env_helpers import make_dmp_env, make_env
|
|
|
|
|
|
|
|
|
2021-07-02 13:09:56 +02:00
|
|
|
def example_mp(env_name="alr_envs:HoleReacherDMP-v1", seed=1, iterations=1, render=True):
|
2021-06-28 17:25:53 +02:00
|
|
|
"""
|
|
|
|
Example for running a motion primitive based environment, which is already registered
|
|
|
|
Args:
|
|
|
|
env_name: DMP env_id
|
2021-07-02 13:09:56 +02:00
|
|
|
seed: seed for deterministic behaviour
|
|
|
|
iterations: Number of rollout steps to run
|
|
|
|
render: Render the episode
|
2021-06-28 17:25:53 +02:00
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
|
|
|
"""
|
|
|
|
# While in this case gym.make() is possible to use as well, we recommend our custom make env function.
|
|
|
|
# First, it already takes care of seeding and second enables the use of DMC tasks within the gym interface.
|
|
|
|
env = make_env(env_name, seed)
|
2021-06-29 16:17:18 +02:00
|
|
|
|
2021-07-02 13:09:56 +02:00
|
|
|
rewards = 0
|
|
|
|
# env.render(mode=None)
|
|
|
|
obs = env.reset()
|
|
|
|
|
|
|
|
# number of samples/full trajectories (multiple environment steps)
|
|
|
|
for i in range(iterations):
|
|
|
|
|
|
|
|
if render and i % 2 == 0:
|
|
|
|
# This renders the full MP trajectory
|
|
|
|
# It is only required to call render() once in the beginning, which renders every consecutive trajectory.
|
|
|
|
# Resetting to no rendering, can be achieved by render(mode=None).
|
|
|
|
# It is also possible to change the mode multiple times when
|
|
|
|
# e.g. only every second trajectory should be displayed, such as here
|
|
|
|
# Just make sure the correct mode is set before executing the step.
|
|
|
|
env.render(mode="human")
|
|
|
|
else:
|
|
|
|
env.render(mode=None)
|
|
|
|
|
|
|
|
ac = env.action_space.sample()
|
|
|
|
obs, reward, done, info = env.step(ac)
|
|
|
|
rewards += reward
|
|
|
|
|
|
|
|
if done:
|
|
|
|
print(rewards)
|
|
|
|
rewards = 0
|
|
|
|
obs = env.reset()
|
|
|
|
|
|
|
|
|
|
|
|
def example_custom_mp(env_name="alr_envs:HoleReacherDMP-v1", seed=1, iterations=1, render=True):
|
|
|
|
"""
|
|
|
|
Example for running a motion primitive based environment, which is already registered
|
|
|
|
Args:
|
|
|
|
env_name: DMP env_id
|
|
|
|
seed: seed for deterministic behaviour
|
|
|
|
iterations: Number of rollout steps to run
|
|
|
|
render: Render the episode
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
|
|
|
"""
|
2021-06-29 16:17:18 +02:00
|
|
|
# Changing the mp_kwargs is possible by providing them to gym.
|
|
|
|
# E.g. here by providing way to many basis functions
|
2021-07-02 13:09:56 +02:00
|
|
|
mp_kwargs = {
|
|
|
|
"num_dof": 5,
|
|
|
|
"num_basis": 1000,
|
|
|
|
"duration": 2,
|
|
|
|
"learn_goal": True,
|
|
|
|
"alpha_phase": 2,
|
|
|
|
"bandwidth_factor": 2,
|
|
|
|
"policy_type": "velocity",
|
|
|
|
"weights_scale": 50,
|
|
|
|
"goal_scale": 0.1
|
|
|
|
}
|
|
|
|
env = make_env(env_name, seed, mp_kwargs=mp_kwargs)
|
|
|
|
|
|
|
|
# This time rendering every trajectory
|
|
|
|
if render:
|
|
|
|
env.render(mode="human")
|
2021-06-29 16:17:18 +02:00
|
|
|
|
2021-06-28 17:25:53 +02:00
|
|
|
rewards = 0
|
|
|
|
obs = env.reset()
|
|
|
|
|
|
|
|
# number of samples/full trajectories (multiple environment steps)
|
2021-07-02 13:09:56 +02:00
|
|
|
for i in range(iterations):
|
2021-06-28 17:25:53 +02:00
|
|
|
ac = env.action_space.sample()
|
|
|
|
obs, reward, done, info = env.step(ac)
|
|
|
|
rewards += reward
|
|
|
|
|
|
|
|
if done:
|
|
|
|
print(rewards)
|
|
|
|
rewards = 0
|
|
|
|
obs = env.reset()
|
|
|
|
|
|
|
|
|
2021-07-02 13:09:56 +02:00
|
|
|
def example_fully_custom_mp(seed=1, iterations=1, render=True):
|
2021-06-28 17:25:53 +02:00
|
|
|
"""
|
|
|
|
Example for running a custom motion primitive based environments.
|
2021-06-29 16:17:18 +02:00
|
|
|
Our already registered environments follow the same structure.
|
|
|
|
Hence, this also allows to adjust hyperparameters of the motion primitives.
|
|
|
|
Yet, we recommend the method above if you are just interested in chaining those parameters for existing tasks.
|
2021-06-28 17:25:53 +02:00
|
|
|
We appreciate PRs for custom environments (especially MP wrappers of existing tasks)
|
|
|
|
for our repo: https://github.com/ALRhub/alr_envs/
|
|
|
|
Args:
|
|
|
|
seed: seed
|
2021-07-02 13:09:56 +02:00
|
|
|
iterations: Number of rollout steps to run
|
|
|
|
render: Render the episode
|
2021-06-28 17:25:53 +02:00
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
base_env = "alr_envs:HoleReacher-v1"
|
2021-07-02 13:09:56 +02:00
|
|
|
|
2021-06-28 17:25:53 +02:00
|
|
|
# Replace this wrapper with the custom wrapper for your environment by inheriting from the MPEnvWrapper.
|
|
|
|
# You can also add other gym.Wrappers in case they are needed.
|
|
|
|
wrappers = [HoleReacherMPWrapper]
|
|
|
|
mp_kwargs = {
|
|
|
|
"num_dof": 5,
|
|
|
|
"num_basis": 5,
|
|
|
|
"duration": 2,
|
|
|
|
"learn_goal": True,
|
|
|
|
"alpha_phase": 2,
|
|
|
|
"bandwidth_factor": 2,
|
|
|
|
"policy_type": "velocity",
|
|
|
|
"weights_scale": 50,
|
|
|
|
"goal_scale": 0.1
|
|
|
|
}
|
2021-06-30 15:00:36 +02:00
|
|
|
env = make_dmp_env(base_env, wrappers=wrappers, seed=seed, mp_kwargs=mp_kwargs)
|
2021-06-28 17:25:53 +02:00
|
|
|
# OR for a deterministic ProMP:
|
2021-07-02 13:09:56 +02:00
|
|
|
# env = make_detpmp_env(base_env, wrappers=wrappers, seed=seed, mp_kwargs=mp_kwargs)
|
|
|
|
|
|
|
|
if render:
|
|
|
|
env.render(mode="human")
|
2021-06-28 17:25:53 +02:00
|
|
|
|
|
|
|
rewards = 0
|
|
|
|
obs = env.reset()
|
|
|
|
|
|
|
|
# number of samples/full trajectories (multiple environment steps)
|
2021-07-02 13:09:56 +02:00
|
|
|
for i in range(iterations):
|
2021-06-28 17:25:53 +02:00
|
|
|
ac = env.action_space.sample()
|
|
|
|
obs, reward, done, info = env.step(ac)
|
|
|
|
rewards += reward
|
|
|
|
|
|
|
|
if done:
|
|
|
|
print(rewards)
|
|
|
|
rewards = 0
|
|
|
|
obs = env.reset()
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
2021-07-26 17:07:17 +02:00
|
|
|
render = False
|
2021-06-28 17:25:53 +02:00
|
|
|
# DMP
|
2021-07-26 17:07:17 +02:00
|
|
|
example_mp("alr_envs:HoleReacherDMP-v1", seed=10, iterations=1, render=render)
|
2021-06-28 17:25:53 +02:00
|
|
|
|
|
|
|
# DetProMP
|
2021-07-26 17:07:17 +02:00
|
|
|
example_mp("alr_envs:HoleReacherDetPMP-v1", seed=10, iterations=1, render=render)
|
2021-07-02 13:09:56 +02:00
|
|
|
|
|
|
|
# Altered basis functions
|
2021-07-26 17:07:17 +02:00
|
|
|
example_custom_mp("alr_envs:HoleReacherDMP-v1", seed=10, iterations=1, render=render)
|
2021-06-28 17:25:53 +02:00
|
|
|
|
2021-07-02 13:09:56 +02:00
|
|
|
# Custom MP
|
2021-07-26 17:07:17 +02:00
|
|
|
example_fully_custom_mp(seed=10, iterations=1, render=render)
|