You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							119 lines
						
					
					
						
							3.2 KiB
						
					
					
				
			
		
		
	
	
							119 lines
						
					
					
						
							3.2 KiB
						
					
					
				import numpy as np
 | 
						|
 | 
						|
from metadrive.component.sensors.rgb_camera import RGBCamera
 | 
						|
from metadrive.component.sensors.base_camera import _cuda_enable
 | 
						|
from metadrive.component.map.pg_map import MapGenerateMethod
 | 
						|
from panda3d.core import Texture, GraphicsOutput
 | 
						|
 | 
						|
from openpilot.tools.sim.bridge.common import SimulatorBridge
 | 
						|
from openpilot.tools.sim.bridge.metadrive.metadrive_world import MetaDriveWorld
 | 
						|
from openpilot.tools.sim.lib.camerad import W, H
 | 
						|
 | 
						|
 | 
						|
 | 
						|
class CopyRamRGBCamera(RGBCamera):
 | 
						|
  """Camera which copies its content into RAM during the render process, for faster image grabbing."""
 | 
						|
  def __init__(self, *args, **kwargs):
 | 
						|
    super().__init__(*args, **kwargs)
 | 
						|
    self.cpu_texture = Texture()
 | 
						|
    self.buffer.addRenderTexture(self.cpu_texture, GraphicsOutput.RTMCopyRam)
 | 
						|
 | 
						|
  def get_rgb_array_cpu(self):
 | 
						|
    origin_img = self.cpu_texture
 | 
						|
    img = np.frombuffer(origin_img.getRamImage().getData(), dtype=np.uint8)
 | 
						|
    img = img.reshape((origin_img.getYSize(), origin_img.getXSize(), -1))
 | 
						|
    img = img[:,:,:3] # RGBA to RGB
 | 
						|
    # img = np.swapaxes(img, 1, 0)
 | 
						|
    img = img[::-1] # Flip on vertical axis
 | 
						|
    return img
 | 
						|
 | 
						|
 | 
						|
class RGBCameraWide(CopyRamRGBCamera):
 | 
						|
  def __init__(self, *args, **kwargs):
 | 
						|
    super(RGBCameraWide, self).__init__(*args, **kwargs)
 | 
						|
    lens = self.get_lens()
 | 
						|
    lens.setFov(120)
 | 
						|
    lens.setNear(0.1)
 | 
						|
 | 
						|
class RGBCameraRoad(CopyRamRGBCamera):
 | 
						|
  def __init__(self, *args, **kwargs):
 | 
						|
    super(RGBCameraRoad, self).__init__(*args, **kwargs)
 | 
						|
    lens = self.get_lens()
 | 
						|
    lens.setFov(40)
 | 
						|
    lens.setNear(0.1)
 | 
						|
 | 
						|
 | 
						|
def straight_block(length):
 | 
						|
  return {
 | 
						|
    "id": "S",
 | 
						|
    "pre_block_socket_index": 0,
 | 
						|
    "length": length
 | 
						|
  }
 | 
						|
 | 
						|
def curve_block(length, angle=45, direction=0):
 | 
						|
  return {
 | 
						|
    "id": "C",
 | 
						|
    "pre_block_socket_index": 0,
 | 
						|
    "length": length,
 | 
						|
    "radius": length,
 | 
						|
    "angle": angle,
 | 
						|
    "dir": direction
 | 
						|
  }
 | 
						|
 | 
						|
def create_map(track_size=60):
 | 
						|
  return dict(
 | 
						|
    type=MapGenerateMethod.PG_MAP_FILE,
 | 
						|
    lane_num=2,
 | 
						|
    lane_width=3.5,
 | 
						|
    config=[
 | 
						|
      None,
 | 
						|
      straight_block(track_size),
 | 
						|
      curve_block(track_size*2, 90),
 | 
						|
      straight_block(track_size),
 | 
						|
      curve_block(track_size*2, 90),
 | 
						|
      straight_block(track_size),
 | 
						|
      curve_block(track_size*2, 90),
 | 
						|
      straight_block(track_size),
 | 
						|
      curve_block(track_size*2, 90),
 | 
						|
    ]
 | 
						|
  )
 | 
						|
 | 
						|
 | 
						|
class MetaDriveBridge(SimulatorBridge):
 | 
						|
  TICKS_PER_FRAME = 5
 | 
						|
 | 
						|
  def __init__(self, args):
 | 
						|
    self.should_render = False
 | 
						|
 | 
						|
    super(MetaDriveBridge, self).__init__(args)
 | 
						|
 | 
						|
  def spawn_world(self):
 | 
						|
    sensors = {
 | 
						|
      "rgb_road": (RGBCameraRoad, W, H, )
 | 
						|
    }
 | 
						|
 | 
						|
    if self.dual_camera:
 | 
						|
      sensors["rgb_wide"] = (RGBCameraWide, W, H)
 | 
						|
 | 
						|
    config = dict(
 | 
						|
      use_render=self.should_render,
 | 
						|
      vehicle_config=dict(
 | 
						|
        enable_reverse=False,
 | 
						|
        image_source="rgb_road",
 | 
						|
      ),
 | 
						|
      sensors=sensors,
 | 
						|
      image_on_cuda=_cuda_enable,
 | 
						|
      image_observation=True,
 | 
						|
      interface_panel=[],
 | 
						|
      out_of_route_done=False,
 | 
						|
      on_continuous_line_done=False,
 | 
						|
      crash_vehicle_done=False,
 | 
						|
      crash_object_done=False,
 | 
						|
      traffic_density=0.0, # traffic is incredibly expensive
 | 
						|
      map_config=create_map(),
 | 
						|
      decision_repeat=1,
 | 
						|
      physics_world_step_size=self.TICKS_PER_FRAME/100,
 | 
						|
      preload_models=False
 | 
						|
    )
 | 
						|
 | 
						|
    return MetaDriveWorld(config, self.dual_camera)
 | 
						|
 |