This commit is contained in:
QuanyiLi
2023-05-06 16:00:17 +01:00
parent 792a11d513
commit 5d536819c7
7 changed files with 89 additions and 88 deletions

View File

@@ -1,15 +1,13 @@
import math
from collections import defaultdict
import numpy as np
from metadrive.scenario import ScenarioDescription as SD
def nuplan_to_metadrive_vector(vector, nuplan_center=(0, 0)):
"All vec in nuplan should be centered in (0,0) to avoid numerical explosion"
vector = np.array(vector)
# if len(vector.shape) == 1:
# vector[1] *= -1
# else:
# vector[:, 1] *= -1
vector -= np.asarray(nuplan_center)
return vector
@@ -47,6 +45,57 @@ def dict_recursive_remove_array(d):
d[k] = dict_recursive_remove_array(d[k])
return d
def mph_to_kmh(speed_in_mph: float):
speed_in_kmh = speed_in_mph * 1.609344
return speed_in_kmh
return speed_in_kmh
def get_agent_summary(state_dict, id, type):
track = state_dict["position"]
valid_track = track[state_dict["valid"], :2]
distance = float(sum(np.linalg.norm(valid_track[i] - valid_track[i + 1]) for i in range(valid_track.shape[0] - 1)))
valid_length = int(sum(state_dict["valid"]))
continuous_valid_length = 0
for v in state_dict["valid"]:
if v:
continuous_valid_length += 1
if continuous_valid_length > 0 and not v:
break
return {
"type": type,
"object_id": str(id),
"track_length": int(len(track)),
"distance": float(distance),
"valid_length": int(valid_length),
"continuous_valid_length": int(continuous_valid_length)
}
def get_number_summary(scenario):
number_summary_dict = {}
number_summary_dict["object"] = len(scenario[SD.TRACKS])
number_summary_dict["dynamic_object_states"] = len(scenario[SD.DYNAMIC_MAP_STATES])
number_summary_dict["map_features"] = len(scenario[SD.MAP_FEATURES])
number_summary_dict["object_types"] = set(v["type"] for v in scenario[SD.TRACKS].values())
object_types_counter = defaultdict(int)
for v in scenario[SD.TRACKS].values():
object_types_counter[v["type"]] += 1
number_summary_dict["object_types_counter"] = dict(object_types_counter)
# Number of different dynamic object states
dynamic_object_states_types = set()
dynamic_object_states_counter = defaultdict(int)
for v in scenario[SD.DYNAMIC_MAP_STATES].values():
for step_state in v["state"]["object_state"]:
if step_state is None:
continue
dynamic_object_states_types.add(step_state)
dynamic_object_states_counter[step_state] += 1
number_summary_dict["dynamic_object_states_types"] = dynamic_object_states_types
number_summary_dict["dynamic_object_states_counter"] = dict(dynamic_object_states_counter)
return number_summary_dict