Simulator: split bridge and world into two files (#30091)
* split bridge into two files * fix metadrive * fix tests toopull/30095/head
parent
32ac71af37
commit
5af5469c66
7 changed files with 105 additions and 106 deletions
@ -0,0 +1,22 @@ |
|||||||
|
import carla |
||||||
|
|
||||||
|
from openpilot.tools.sim.bridge.common import SimulatorBridge |
||||||
|
from openpilot.tools.sim.bridge.carla.carla_world import CarlaWorld |
||||||
|
|
||||||
|
|
||||||
|
class CarlaBridge(SimulatorBridge): |
||||||
|
TICKS_PER_FRAME = 5 |
||||||
|
|
||||||
|
def __init__(self, arguments): |
||||||
|
super().__init__(arguments) |
||||||
|
self.host = arguments.host |
||||||
|
self.port = arguments.port |
||||||
|
self.town = arguments.town |
||||||
|
self.num_selected_spawn_point = arguments.num_selected_spawn_point |
||||||
|
|
||||||
|
def spawn_world(self): |
||||||
|
client = carla.Client(self.host, self.port) |
||||||
|
client.set_timeout(5) |
||||||
|
|
||||||
|
return CarlaWorld(client, high_quality=self.high_quality, dual_camera=self.dual_camera, |
||||||
|
num_selected_spawn_point=self.num_selected_spawn_point, town=self.town) |
@ -0,0 +1,65 @@ |
|||||||
|
import math |
||||||
|
import numpy as np |
||||||
|
import time |
||||||
|
|
||||||
|
from openpilot.tools.sim.lib.common import SimulatorState, World, vec3 |
||||||
|
|
||||||
|
|
||||||
|
class MetaDriveWorld(World): |
||||||
|
def __init__(self, env, dual_camera = False): |
||||||
|
super().__init__(dual_camera) |
||||||
|
self.env = env |
||||||
|
self.dual_camera = dual_camera |
||||||
|
|
||||||
|
self.steer_ratio = 15 |
||||||
|
|
||||||
|
self.vc = [0.0,0.0] |
||||||
|
|
||||||
|
self.reset_time = 0 |
||||||
|
|
||||||
|
def get_cam_as_rgb(self, cam): |
||||||
|
cam = self.env.engine.sensors[cam] |
||||||
|
img = cam.perceive(self.env.vehicle, clip=False) |
||||||
|
if type(img) != np.ndarray: |
||||||
|
img = img.get() # convert cupy array to numpy |
||||||
|
return img |
||||||
|
|
||||||
|
def apply_controls(self, steer_angle, throttle_out, brake_out): |
||||||
|
steer_metadrive = steer_angle * 1 / (self.env.vehicle.MAX_STEERING * self.steer_ratio) |
||||||
|
steer_metadrive = np.clip(steer_metadrive, -1, 1) |
||||||
|
|
||||||
|
if (time.monotonic() - self.reset_time) > 5: |
||||||
|
self.vc[0] = steer_metadrive |
||||||
|
|
||||||
|
if throttle_out: |
||||||
|
self.vc[1] = throttle_out/10 |
||||||
|
else: |
||||||
|
self.vc[1] = -brake_out |
||||||
|
else: |
||||||
|
self.vc[0] = 0 |
||||||
|
self.vc[1] = 0 |
||||||
|
|
||||||
|
def read_sensors(self, state: SimulatorState): |
||||||
|
state.velocity = vec3(x=float(self.env.vehicle.velocity[0]), y=float(self.env.vehicle.velocity[1]), z=0) |
||||||
|
state.gps.from_xy(self.env.vehicle.position) |
||||||
|
state.bearing = float(math.degrees(self.env.vehicle.heading_theta)) |
||||||
|
state.steering_angle = self.env.vehicle.steering * self.env.vehicle.MAX_STEERING |
||||||
|
state.valid = True |
||||||
|
|
||||||
|
def read_cameras(self): |
||||||
|
if self.dual_camera: |
||||||
|
self.wide_road_image = self.get_cam_as_rgb("rgb_wide") |
||||||
|
self.road_image = self.get_cam_as_rgb("rgb_road") |
||||||
|
|
||||||
|
def tick(self): |
||||||
|
obs, _, terminated, _, info = self.env.step(self.vc) |
||||||
|
|
||||||
|
if terminated: |
||||||
|
self.reset() |
||||||
|
|
||||||
|
def reset(self): |
||||||
|
self.env.reset() |
||||||
|
self.reset_time = time.monotonic() |
||||||
|
|
||||||
|
def close(self): |
||||||
|
pass |
Loading…
Reference in new issue