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.
		
		
		
		
		
			
		
			
				
					
					
						
							83 lines
						
					
					
						
							3.4 KiB
						
					
					
				
			
		
		
	
	
							83 lines
						
					
					
						
							3.4 KiB
						
					
					
				| import numpy as np
 | |
| from openpilot.selfdrive.test.longitudinal_maneuvers.plant import Plant
 | |
| 
 | |
| 
 | |
| class Maneuver:
 | |
|   def __init__(self, title, duration, **kwargs):
 | |
|     # Was tempted to make a builder class
 | |
|     self.distance_lead = kwargs.get("initial_distance_lead", 200.0)
 | |
|     self.speed = kwargs.get("initial_speed", 0.0)
 | |
|     self.lead_relevancy = kwargs.get("lead_relevancy", 0)
 | |
| 
 | |
|     self.breakpoints = kwargs.get("breakpoints", [0.0, duration])
 | |
|     self.speed_lead_values = kwargs.get("speed_lead_values", [0.0 for i in range(len(self.breakpoints))])
 | |
|     self.prob_lead_values = kwargs.get("prob_lead_values", [1.0 for i in range(len(self.breakpoints))])
 | |
|     self.prob_throttle_values = kwargs.get("prob_throttle_values", [1.0 for i in range(len(self.breakpoints))])
 | |
|     self.cruise_values = kwargs.get("cruise_values", [50.0 for i in range(len(self.breakpoints))])
 | |
|     self.pitch_values = kwargs.get("pitch_values", [0.0 for i in range(len(self.breakpoints))])
 | |
| 
 | |
|     self.only_lead2 = kwargs.get("only_lead2", False)
 | |
|     self.only_radar = kwargs.get("only_radar", False)
 | |
|     self.ensure_start = kwargs.get("ensure_start", False)
 | |
|     self.ensure_slowdown = kwargs.get("ensure_slowdown", False)
 | |
|     self.enabled = kwargs.get("enabled", True)
 | |
|     self.e2e = kwargs.get("e2e", False)
 | |
|     self.personality = kwargs.get("personality", 0)
 | |
|     self.force_decel = kwargs.get("force_decel", False)
 | |
| 
 | |
|     self.duration = duration
 | |
|     self.title = title
 | |
| 
 | |
|   def evaluate(self):
 | |
|     plant = Plant(
 | |
|       lead_relevancy=self.lead_relevancy,
 | |
|       speed=self.speed,
 | |
|       distance_lead=self.distance_lead,
 | |
|       enabled=self.enabled,
 | |
|       only_lead2=self.only_lead2,
 | |
|       only_radar=self.only_radar,
 | |
|       e2e=self.e2e,
 | |
|       personality=self.personality,
 | |
|       force_decel=self.force_decel,
 | |
|     )
 | |
| 
 | |
|     valid = True
 | |
|     logs = []
 | |
|     while plant.current_time < self.duration:
 | |
|       speed_lead = np.interp(plant.current_time, self.breakpoints, self.speed_lead_values)
 | |
|       prob_lead = np.interp(plant.current_time, self.breakpoints, self.prob_lead_values)
 | |
|       cruise = np.interp(plant.current_time, self.breakpoints, self.cruise_values)
 | |
|       pitch = np.interp(plant.current_time, self.breakpoints, self.pitch_values)
 | |
|       prob_throttle = np.interp(plant.current_time, self.breakpoints, self.prob_throttle_values)
 | |
|       log = plant.step(speed_lead, prob_lead, cruise, pitch, prob_throttle)
 | |
| 
 | |
|       d_rel = log['distance_lead'] - log['distance'] if self.lead_relevancy else 200.
 | |
|       v_rel = speed_lead - log['speed'] if self.lead_relevancy else 0.
 | |
|       log['d_rel'] = d_rel
 | |
|       log['v_rel'] = v_rel
 | |
|       logs.append(np.array([plant.current_time,
 | |
|                             log['distance'],
 | |
|                             log['distance_lead'],
 | |
|                             log['speed'],
 | |
|                             speed_lead,
 | |
|                             log['acceleration']]))
 | |
| 
 | |
|       if d_rel < .4 and (self.only_radar or prob_lead > 0.5):
 | |
|         print("Crashed!!!!")
 | |
|         valid = False
 | |
| 
 | |
|       if self.ensure_start and log['v_rel'] > 0 and log['acceleration'] < 1e-3:
 | |
|         print('LongitudinalPlanner not starting!')
 | |
|         valid = False
 | |
| 
 | |
|     if self.ensure_slowdown and log['speed'] > 5.5:
 | |
|       print('LongitudinalPlanner not slowing down!')
 | |
|       valid = False
 | |
| 
 | |
|     if self.force_decel and log['speed'] > 1e-1 and log['acceleration'] > -0.04:
 | |
|       print('Not stopping with force decel')
 | |
|       valid = False
 | |
| 
 | |
| 
 | |
|     print("maneuver end", valid)
 | |
|     return valid, np.array(logs)
 | |
| 
 |