-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtrain.py
110 lines (98 loc) · 2.73 KB
/
train.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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
from sim_env import SimEnv
import time
import numpy as np
import yaml
import ray
from ray import tune
from ray.tune.registry import register_env
np.random.seed(1)
# Can alternatively pass in p.DIRECT
def run():
cfg = {
'init': [0, 0, 1],
'goal_box': 5
}
env = SimEnv(cfg)
try:
env.reset()
time.sleep(2)
reached_goal = False
for i in range(1000):
goal_vec = env.goal - env.drone.pos
goal_vec /= np.abs(goal_vec).max()*100
obs, reward, done, _ = env.step(np.array([0,0,0] if reached_goal else goal_vec, dtype=float))
print(obs, reward, done)
time.sleep(1./240.)
if done:
reached_goal = True
print("DONE")
#break
except Exception as e:
del env
print("Exit", e)
if __name__ == '__main__':
#run()
#exit()
register_env("pybullet", lambda config: SimEnv(config))
#with open("cfg.yaml", "rb") as f:
# cfg = yaml.load(f)
ray.init()
tune.run(
"PPO",
#restore="/home/jb2270/ray_results/PPO/PPO_world_0_2020-04-04_23-01-16c532w9iy/checkpoint_100/checkpoint-100",
checkpoint_freq=10,
config={
"env": "pybullet",
"lambda": 0.95,
"kl_coeff": 0.5,
"clip_rewards": True,
"clip_param": 0.2,
"vf_clip_param": 10.0,
#"vf_share_layers": True,
#"vf_loss_coeff": 1e-4,
"entropy_coeff": 0.01,
"train_batch_size": 1000,
"sample_batch_size": 100,
"sgd_minibatch_size": 500,
"num_sgd_iter": 10,
"num_workers": 4,
"num_envs_per_worker": 5,
"lr": 1e-4,
"gamma": 0.99,
"batch_mode": "truncate_episodes",
"observation_filter": "NoFilter",
"num_gpus": 1,
"model": {
"fcnet_activation": "relu",
"fcnet_hiddens": [128, 256, 128, 32],
},
"env_config": {
'init': [0, 0, 1],
'render': False,
"waypoints": 4
}})
#tune.run(
# "SAC",
#restore="/home/jb2270/ray_results/PPO/PPO_world_0_2020-04-02_21-44-56vzulq1wd/checkpoint_190",
#checkpoint_freq=10,
# config=cfg)
'''
d = Drone()
d.set_speed([0,0,0.01])
for i in range(200):
d.step()
p.stepSimulation()
time.sleep(1./240.)
d.set_speed([0,0.01,0.0])
for i in range(1000):
d.step()
p.stepSimulation()
time.sleep(1./240.)
d.set_speed([0,0,-0.005])
for i in range(1000):
d.step()
p.stepSimulation()
time.sleep(1./240.)
#time.sleep(5)
p.disconnect()
'''