-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathsb3_eval.py
140 lines (115 loc) · 4.49 KB
/
sb3_eval.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
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
import gym
import socnavgym
import torch
from socnavgym.wrappers import DiscreteActions
from stable_baselines3 import DQN
from stable_baselines3.common.torch_layers import BaseFeaturesExtractor
from agents.models import Transformer
import argparse
from tqdm import tqdm
from stable_baselines3.common.monitor import Monitor
def eval(model, num_episodes, env):
# intialising metrics
discomfort_sngnn = 0
discomfort_crowdnav = 0
timeout = 0
success_rate = 0
time_taken = 0
closest_human_dist = 0
closest_obstacle_dist = 0
collision_rate = 0
collision_rate_human = 0
collision_rate_object = 0
total_psc = 0
total_stl = 0
total_reward = 0
print(f"Evaluating model for {num_episodes} episodes")
for i in tqdm(range(num_episodes)):
obs, _ = env.reset()
done = False
episode_reward = 0
has_reached_goal = 0
has_collided = 0
has_collided_human = 0
has_collided_object = 0
has_timed_out = 0
steps = 0
episode_discomfort_sngnn = 0
episode_discomfort_crowdnav = 0
psc = 0
stl = 0
min_human_dist = float('inf')
min_obstacle_dist = float('inf')
while not done:
action, _states = model.predict(obs, deterministic=True)
new_state, reward, terminated, truncated, info = env.step(action)
done = terminated or truncated
total_reward += reward
# env.render()
steps += 1
# storing the rewards
episode_reward += reward
# storing discomforts
episode_discomfort_sngnn += info["sngnn_reward"]
episode_discomfort_crowdnav += info["DISCOMFORT_CROWDNAV"]
# storing whether the agent reached the goal
if info["REACHED_GOAL"]:
has_reached_goal = 1
stl = info["success_weighted_by_time_length"]
if info["COLLISION"]:
has_collided = 1
if info["COLLISION_HUMAN"]:
has_collided_human = 1
if info["COLLISION_OBJECT"]:
has_collided_object = 1
steps = env.EPISODE_LENGTH
if info["MAX_STEPS"]:
has_timed_out = 1
min_human_dist = min(min_human_dist, info["closest_human_dist"])
min_obstacle_dist = min(min_obstacle_dist, info["closest_obstacle_dist"])
episode_reward += reward
obs = new_state
if done:
psc = info["personal_space_compliance"]
discomfort_sngnn += episode_discomfort_sngnn
discomfort_crowdnav += episode_discomfort_crowdnav
timeout += has_timed_out
success_rate += has_reached_goal
time_taken += steps
closest_human_dist += min_human_dist
closest_obstacle_dist += min_obstacle_dist
collision_rate += has_collided
collision_rate_human += has_collided_human
collision_rate_object += has_collided_object
total_psc += psc
total_stl += stl
print(f"Average discomfort_sngnn: {discomfort_sngnn/num_episodes}")
print(f"Average discomfort_crowdnav: {discomfort_crowdnav/num_episodes}")
print(f"Average timeout: {timeout/num_episodes}")
print(f"Average success_rate: {success_rate/num_episodes}")
print(f"Average time_taken: {time_taken/num_episodes}")
print(f"Average closest_human_dist: {closest_human_dist/num_episodes}")
print(f"Average closest_obstacle_dist: {closest_obstacle_dist/num_episodes}")
print(f"Average collision_rate: {collision_rate/num_episodes}")
print(f"Average human_collision_rate: {collision_rate_human/num_episodes}")
print(f"Average object_collision_rate: {collision_rate_object/num_episodes}")
print(f"Average psc: {total_psc/num_episodes}")
print(f"Average stl: {total_stl/num_episodes}")
env = gym.make("SocNavGym-v1", config="./paper_configs/exp1_no_sngnn.yaml")
env = DiscreteActions(env)
try:
model = DQN.load("best models/sb3_dqn_exp1_no_sngnn_weights.zip")
except Exception as e:
print(e)
else:
print("Successfully loaded")
# print(model.policy)
# # eval(model, 100, env)
for _ in range(10):
done = False
obs, _ = env.reset()
while not done:
action, _states = model.predict(obs, deterministic=True)
obs, reward, terminated, truncated, info = env.step(action)
env.render()
done = terminated or truncated