-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathplay_franka.py
83 lines (67 loc) · 2.37 KB
/
play_franka.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
import os
import sys
py_path = os.path.split(os.getcwd())[0]
if py_path not in sys.path:
sys.path.append(py_path)
import click
import numpy as np
import pickle
from src.utils import logger
from src.utils.util import set_global_seeds
import src.config as config
from src.data.episode_rollout import EpisodeRollout
from carbongym import gymapi
@click.command()
@click.argument('policy_file', type=str)
@click.option('--seed', type=int, default=10)
@click.option('--n_test_rollouts', type=int, default=1000)
@click.option('--render', type=int, default=1)
def main(policy_file, seed, n_test_rollouts, render):
set_global_seeds(seed)
# Load policy.
with open(policy_file, 'rb') as f:
policy = pickle.load(f)
env_name = policy.info['env_name']
# Prepare params.
params = config.DEFAULT_PARAMS
if env_name in config.DEFAULT_ENV_PARAMS:
params.update(config.DEFAULT_ENV_PARAMS[env_name]) # merge env-specific parameters in
params['env_name'] = env_name
params = config.prepare_params(params)
config.log_params(params, logger=logger)
dims = config.configure_dims(params)
eval_params = {
'exploit': True,
'use_target_net': params['test_with_polyak'],
'compute_Q': True,
'rollout_batch_size': 1,
'render': bool(render)
}
for name in ['max_episode_steps', 'gamma', 'noise_eps', 'random_eps']:
eval_params[name] = params[name]
evaluator = EpisodeRollout(params['make_env'], policy, dims, logger, **eval_params)
evaluator.seed(seed)
gym = evaluator.envs._gym
sim = evaluator.envs._sim
viewer = gym.create_viewer(sim, gymapi.DEFAULT_VIEWER_WIDTH, gymapi.DEFAULT_VIEWER_HEIGHT)
evaluator.viewer = viewer
evaluator.viewer = viewer
# Run evaluation.
evaluator.clear_history()
all_episodes = []
for _ in range(n_test_rollouts):
# if friction_idx == len(friction_arr):
# friction_idx = 0
# if _ % 5 == 0:
# evaluator.seed(seed)
# friction = friction_arr[friction_idx]
# friction_idx += 1
# evaluator.set_physics(param=friction)
episode = evaluator.generate_rollouts()
all_episodes.append(episode)
# record logs
for key, val in evaluator.logs('test'):
logger.record_tabular(key, np.mean(val))
logger.dump_tabular()
if __name__ == '__main__':
main()