Successful design and deployment of autonomous vehicles (AV) requires finding an optimal road/lane-level path from the AV's current location to a specified destination in a map including a road network. Routes typically require lane changes (for example, the AV must merge into a leftmost lane to make a left turn, perform lane changes to overtake a slower object, etc.) as well as in-lane maneuvers (for example, tracking behind an object, stopping before a stationary object, steering around a stationary object, etc.).
Prior art methods for AV trajectory planning typically involve generating a number of candidate trajectories, scoring them, and selecting the best one for execution. For performing lane changes, the number of possible candidate trajectories is typically infinitely high because of the number of variations of transition start/end locations, transition start/end times, steering/speed profiles, or the like. However, the number of candidate trajectories that can be evaluated and scored is limited by available computational resources, and to conserve computation resources, prior art methods typically consider only a few transitions based on heuristics (for example, start the lane change transition immediately, set the transition length and shape using a heuristic based on current AV speed). In certain driving conditions such as dense traffic, to successfully complete a lane change may require a complex maneuver, for example to speed up and steer abruptly into a narrow gap between vehicles in the destination lane that is currently several vehicles ahead. If an autonomous driving system only considers a finite number of lane change variations based on heuristics, it is unlikely to plan a successful lane change maneuver in these conditions.
Similarly, for in-lane maneuvers, prior art methods typically sample a finite number of candidate trajectories in parametrized space, either by discretization or random sampling. Because the number of sampled trajectories is finite, this approach may fail to find a feasible trajectory when one exists, or it may find a suboptimal trajectory
This document describes methods and systems that are directed to addressing the problems described above, and/or other issues.
In one or more scenarios, systems and methods of maneuvering an autonomous vehicle in a local region using topological planning, while traversing a route to a destination location, are disclosed. The system may include an autonomous vehicle comprising one or more sensors, a processor, and a non-transitory computer medium comprising programming instructions that cause the processor to execute the methods disclosed. The methods may include determining the local region on the route and receiving real-time information corresponding to the local region. The method may further include performing topological planning to identify on or more topologically distinct classes of trajectories, computing a constraint set for each of the one or more topologically distinct classes of trajectories, optimizing a trajectory to generate a candidate trajectory for each constraint set, and selecting a trajectory for the autonomous vehicle to traverse the local region from amongst the one or more candidate trajectories. Each of the one or more topologically distinct classes is associated with a plurality of trajectories that take the same combination of discrete actions with respect to objects in the local region. The local region may be a region around the autonomous vehicle that includes a first area in front of a current location of the autonomous vehicle and a second area behind the current location of the autonomous vehicle.
Optionally, the real-time information may include, for example and without limitation, perception information corresponding to the one or more objects in the local region, trajectory predictions relating to the one or more objects in the local region, information relating to an environment of the autonomous vehicle in the local region, and/or current state information of the autonomous vehicle.
In one or more embodiments, selecting the trajectory for the autonomous vehicle to traverse the local region may include assigning a score to each of the one or more candidate trajectories, selecting a candidate trajectory that has a best score as the trajectory for the autonomous vehicle to traverse the local region. Optionally, the score may be assigned to a candidate trajectory based on, for example, a risk of collision associated with that trajectory, or compliance of that trajectory with traffic rules, or a comfort level associated with that trajectory. Furthermore, scoring may include biasing for temporal consistency.
A constraint set may include one or more constraints associated with, for example, longitudinal autonomous vehicle actions associated with perceived static or dynamic objects in the local region, longitudinal autonomous vehicle actions associated with restricted map areas, lateral autonomous vehicle actions associated with perceived static or dynamic objects in the local region, and/or lateral autonomous vehicle actions associated with restricted map areas. In certain embodiments, the methods may also include discarding a constraint set of the one or more constraint sets corresponding to the one or more topologically distinct classes of trajectories if a constraint set is determined to be infeasible, redundant, and/or heuristically expensive.
In certain embodiments, performing topological planning to identify the set of constraints determining one or more constraints associated with longitudinal autonomous vehicle actions before determining one or more constraints associated with lateral autonomous vehicle actions (with respect to a moving object).
The methods may also include updating the optimized trajectory based on at least one of the following: real-time information corresponding to the local region; or predictions updated based on an intent of the autonomous vehicle.
Optionally, if the trajectory for the autonomous vehicle to traverse the local region includes a lane change trajectory, the methods may also include identifying a time interval for executing the lane change.
As used in this document, the singular forms “a,” “an,” and “the” include plural references unless the context clearly dictates otherwise. Unless defined otherwise, all technical and scientific terms used herein have the same meanings as commonly understood by one of ordinary skill in the art. As used in this document, the term “comprising” means “including, but not limited to.” Definitions for additional terms that are relevant to this document are included at the end of this Detailed Description.
As illustrated in
The sensor system 111 may include one or more sensors that are coupled to and/or are included within the autonomous vehicle 101. Examples of such sensors include, without limitation, a Light Detection and Ranging (LiDAR) system, a Radio Detection and Ranging (RADAR) system, one or more cameras (e.g., visible spectrum cameras, infrared cameras, etc.), temperature sensors, position sensors, location sensors (e.g., global positioning system (GPS), etc.), fuel sensors, speed sensors, odometer sensor, motion sensors (e.g., inertial measurement units (IMU), accelerometer, gyroscope, etc.), object detection sensors such as one or more cameras humidity sensors, environmental sensors (e.g., a precipitation sensor and/or ambient temperature sensor) occupancy sensors, or the like. The sensor data can include information that describes the location of objects within the surrounding environment of the autonomous vehicle 101, information about the environment itself, information about the motion of the autonomous vehicle 101, information about a route of the autonomous vehicle, or the like.
As shown in
The location subsystem 121 may include and/or may retrieve map data from a map data store 121(a) that provides detailed information about the surrounding environment of the autonomous vehicle. The map data can provide information regarding: the identity and location of different roadways, road segments, buildings, or other items; the location and directions of traffic lanes (e.g., the location and direction of a parking lane, a turning lane, a bicycle lane, or other lanes within a particular roadway); traffic control data (e.g., the location and instructions of signage, traffic lights, or other traffic control devices); and/or any other map data that provides information that assists the vehicle controller 112 in analyzing the surrounding environment of the autonomous vehicle. In certain embodiments, the map data may also include reference path information that correspond to common patterns of vehicle travel along one or more lanes such that the motion of the object is constrained to the reference path (e.g., locations within traffic lanes on which an object commonly travels). Such reference paths may be pre-defined such as the centerline of the traffic lanes. Optionally, the reference path may be generated based on a historical observations of vehicles or other objects over a period of time (e.g., reference paths for straight line travel, lane merge, a turn, or the like).
In certain embodiments, the location subsystem 121 may also include and/or may receive information relating to the trip or route of a user, real-time traffic information on the route, or the like.
The location subsystem 121 may include and/or may be in communication with a routing module 121(b) that generates a navigation route from a start position to a destination position for an autonomous vehicle. The routing module 112(b) may access the map data store 112(a) to identify possible routes and road segments that a vehicle can travel on to get from the start position to the destination position. The routing module 112(b) may score the possible routes and identify a preferred route to reach the destination. For example, the routing module 112(b) may generate a navigation route that minimizes Euclidean distance traveled or other cost function during the route, and may further access the traffic information and/or estimates that can affect an amount of time it will take to travel on a particular route. Depending on implementation, the routing module 112(b) may generate one or more routes using various routing methods, such as Dijkstra's algorithm, Bellman-Ford algorithm, or other algorithms. The routing module 112(b) may also use the traffic information to generate a navigation route that reflects expected conditions of the route (e.g., current day of the week or current time of day, etc.), such that a route generated for travel during rush-hour may differ from a route generated for travel late at night. The routing module 112(b) may also generate more than one navigation route to a destination and send more than one of these navigation routes to a user for selection by the user from among various possible routes.
Based on the sensor data provided by sensor system 111 and information obtained by the location subsystem 121, the perception subsystem 122 may determine perception information of the surrounding environment of the autonomous vehicle 101 during travel from the start position to the destination along the preferred route. The perception information may represent what an ordinary driver would perceive in the surrounding environment of a vehicle. The perception data may include information relating to one or more objects in the environment of the autonomous vehicle 101. For example, the perception subsystem 122 may process sensor data (e.g., LiDAR or RADAR data, camera images, etc.) in order to identify objects and/or features in the environment of autonomous vehicle. The objects may include traffic signals, roadway boundaries, other vehicles, pedestrians, and/or obstacles, etc. The perception subsystem 122 may use any now or hereafter known object recognition algorithms, video tracking algorithms, and computer vision algorithms (e.g., track objects frame-to-frame iteratively over a number of time periods) to determine the perception.
In some embodiments, the perception subsystem 122 may also determine, for one or more identified objects in the environment, the current state of the object. The state information may include, without limitation, for each object: current location; current speed and/or acceleration, current heading; current orientation; size/footprint; type (e.g., vehicle vs. pedestrian vs. bicycle vs. static object or obstacle); and/or other state information.
The prediction subsystem 123 may predict the future locations, trajectories, and/or actions of the objects based at least in part on perception information (e.g., the state data for each object) received from the perception subsystem 122, the location information received from the location subsystem 121, the sensor data, and/or any other data that describes the past and/or current state of the objects, the autonomous vehicle 101, the surrounding environment, and/or their relationship(s). For example, if an object is a vehicle and the current driving environment includes an intersection, prediction subsystem 123 may predict whether the object will likely move straight forward or make a turn. If the perception data indicates that the intersection has no traffic light, prediction subsystem 123 may also predict whether the vehicle may have to fully stop prior to enter the intersection. Such predictions may be made for a given time horizon (e.g., 5 seconds in the future). In certain embodiments, the prediction subsystem 123 may provide the predicted trajector(ies) for each object to the motion planning subsystem 124.
The motion planning subsystem 124 may determine a motion plan for the autonomous vehicle based on the perception data and/or the prediction data. Specifically, given predictions about the future locations of proximate objects and other perception data, the motion planning subsystem 124 can determine a motion plan for the autonomous vehicle 101 that best navigates the autonomous vehicle 101 relative to the objects at their future locations.
In one or more embodiments, the motion planning subsystem 124 may receive the predictions from the prediction 123 and make a decision regarding how to handle objects in the environment of the autonomous vehicle 101. For example, for a particular object (e.g., a vehicle with a given speed, direction, turning angle, etc.), motion planning subsystem 124 decides whether to overtake, yield, stop, and/or pass based on, for example, traffic conditions, map data, state of the autonomous vehicle, etc. In some embodiments, for a given object, the motion planning subsystem 124 may decide what to do with the object and may determine how to do it. For example, for a given object, the motion planning subsystem 124 may decide to pass the object, and then may determine whether to pass on the left side or right side of the object (including motion parameters such as speed, and lane change decisions). The motion planning subsystem 124 may also assess the risk of a collision between a detected object and the autonomous vehicle 101. If the risk exceeds an acceptable threshold, it may determine whether the collision can be avoided if the autonomous vehicle follows a defined vehicle trajectory and/or implements one or more dynamically generated emergency maneuvers is performed in a pre-defined time period (e.g., N milliseconds). If the collision can be avoided, then the controller 120 may transmit appropriate control instructions to the vehicle control system 113 for execution to perform a cautious maneuver (e.g., mildly slow down, accelerate, change lane, or swerve). In contrast, if the collision cannot be avoided, then the controller 120 may transmit appropriate control instructions to the vehicle control system 113 for execution of an emergency maneuver (e.g., brake and/or change direction of travel).
Furthermore, the motion planning subsystem 124 also plans a trajectory (“trajectory generation”) for the autonomous vehicle 101 to travel on a given route (e.g., a nominal route generated by the routing module 112(b)). The trajectory specifies the spatial path for the autonomous vehicle as well as a velocity profile. The controller converts the trajectory into control instructions for the vehicle control system, including but not limited to throttle/brake and steering wheel angle commands. Trajectory generation may involve making decisions relating to lane changes, such as, without limitation, whether a lane change is required, where to perform a lane change, and when to perform a lane change. Specifically, one objective of the motion planning subsystem 124 is to generate a trajectory for motion of the vehicle from a start position to a destination on the nominal route, taking into account the perception and prediction data.
The motion planning subsystem 124 may generate the trajectory by performing topological planning to generate a set of constraints for each of a plurality of topologically distinct classes of trajectories, optimizing a single candidate trajectory for each class, and scoring the candidate trajectories to select an optimal trajectory. Topological classes are distinguished by the discrete actions taken with respect obstacles or restricted map areas. Specifically, all possible trajectories in a topologically distinct class takes the same action with respect to obstacles or restricted map areas. Obstacles may include, for example, static objects such as traffic cones and bollards, or other road users such as pedestrians, cyclists, and cars. Restricted map areas may include, for example, crosswalks and intersections. Discrete actions may include, for example, to stop before or proceed through, to track ahead or behind, or to pass on the left or right of something.
The motion planning subsystem may use the preferred route information provided by the routing module 112(b) in combination with perception data, prediction data to select the optimal trajectory, as discussed below.
As discussed above, planning and control data regarding the movement of the autonomous vehicle is generated by the motion planning subsystem 124 of the controller 120 that is transmitted to the vehicle control system 113 for execution. The vehicle control system 113 may, for example, control braking via a brake controller; direction via a steering controller; speed and acceleration via a throttle controller (in a gas-powered vehicle) or a motor speed controller (such as a current level controller in an electric vehicle); a differential gear controller (in vehicles with transmissions); and/or other controllers.
In the various embodiments discussed in this document, the description may state that the vehicle or a controller included in the vehicle (e.g., in an on-board computing system) may implement programming instructions that cause the controller to make decisions and use the decisions to control operations of one or more vehicle systems via the vehicle control system of the vehicle. However, the embodiments are not limited to this arrangement, as in various embodiments the analysis, decision making and or operational control may be handled in full or in part by other computing devices that are in electronic communication with the vehicle's on-board controller and/or vehicle control system. Examples of such other computing devices include an electronic device (such as a smartphone) associated with a person who is riding in the vehicle, as well as a remote server that is in electronic communication with the vehicle via a wireless communication network. The processor of any such device may perform the operations that will be discussed below.
Referring back to
Referring now to
At 302, the system may generate a nominal route from a starting point to a destination through a road network on which an autonomous vehicle may travel. In some embodiments, a nominal route may represent a unique or distinct route through the road network from the starting point to the destination determined before actual trajectory generation and does not take into account real-time perception information relating to the environment of the autonomous vehicle. This nominal route may be optimal with respect to a cost/reward function based solely on information in the road network; however, because it is generated with limited information, the nominal route is not necessarily the best or most optimal route between the starting point and destination considering all factors, such as blockages due to double-parked vehicles that are unobservable at time of nominal route generation.
To generate the nominal route, the system may first identify candidate routes that a vehicle can travel on to get from the start position to the destination. The system may then score the candidate routes and identify a nominal route to reach the destination. For example, the system may generate a nominal route that minimizes Euclidean distance traveled or other cost function during the route. Depending on implementation, the system may generate one or more routes using various routing methods, such as Dijkstra's algorithm, Bellman-Ford algorithm, or other algorithms. The routing module 112(b) may also use the traffic information to generate a navigation route that reflects expected conditions of the route (e.g., current day of the week or current time of day, etc.), such that a route generated for travel during rush-hour may differ from a route generated for travel late at night.
For generating the nominal route, the system may receive road network information (e.g., a map) corresponding to a geographical area of the interest from, for example, a map data store. In some embodiments, the road network information may include a road network map of the geographical location. A road network map may be a graphical representation of a collection of interconnected roads included in the geographical area, and may include roads, lanes, and lane segments. A road comprises one or more adjacent lanes, and lanes may be split longitudinally into lane segments.
In some embodiments, the road network information may also include control information, such as direction of travel information, speed limit information, toll information, grade information, such as inclination or angle information, surface material information, aesthetic information, or a combination thereof. In some embodiments, receiving the road network information may include transcoding or reformatting the road network information, storing the reformatted road network information, or both. For example, the road network information may be used to create a graph representation of a road network as a vector map, a curvilinear map, a cartesian map, or the like.
The system may identify the starting point for the nominal route within the geographical area by, for example, identifying a starting point as a current location of the autonomous vehicle. Alternatively and/or additionally, a user may provide the starting point to the system. In certain embodiments, identifying the starting point may include identifying a road, a lane, or other point within the received road network. The system may identify a destination within the geographical area, by for example, receiving user instructions including the destination; based on user information (e.g., if a user travels to the same destination at a certain time, or has a calendar entry for traveling to a destination); or the like. In certain embodiments, identifying the destination may include identifying a road, a lane, or other point within the received road network.
At 304, the system may determine a local region on the nominal route, where the local region may extend a first distance ahead of the autonomous vehicle's current location and a second distance behind the autonomous vehicle's current location.
The trajectory generation step 306 (as executed by the trajectory generation component of the motion planning subsystem) is responsible for continually planning a safe and feasible trajectory for the AV to traverse the local region. In one or more embodiments, the system may generate (306) the trajectory by receiving 342 real-time perception information (e.g., relating to the local region). The real-time information may include, without limitation, perception information corresponding to one or more objects (stationary or moving) in the local region, trajectory predictions relating to one or more objects in the local region, the environment of the autonomous vehicle (e.g., traffic lights, stop signs, intersections, pedestrian cross-walks, map information, etc.) in the local region, current state information of the autonomous vehicle, or the like. Furthermore, trajectory generation 306 may be performed in curvilinear space corresponding to the local region with respect to a reference path. The reference path establishes topological relationships between the autonomous vehicle and the objects in the curvilinear space. In this space, the autonomous vehicle can take discrete actions to be ahead of or behind something, or to the left or right.
The system may perform topologically planning 344 to determine one or more topologically distinct classes in the local region (based on an analysis of the received real-time information). Each topologically distinct class is associated with a set of trajectories that take the same discrete actions with respect to objects in the local region. For example, as shown in
For example, as shown in
The system may then compute a set of constraints 346 (including one or more constraints) for each topologically distinct class of trajectories determined through topological planning 344, where the set of constraints defines a convex envelope (bounded area) in curvilinear space within which the autonomous vehicle trajectory is confined. As discussed above, the autonomous vehicle can take discrete actions with respect to each object (e.g., to be ahead of or behind something, pass to the left or right, or the like). Each discrete action yields one or more constraints in curvilinear space. For example, the system may consider the following actions which yield the following constraints:
1. With respect to restricted areas, such as intersections and crosswalks:
2. Longitudinal actions with respect to each object:
3. Lateral actions with respect to each object:
The above actions and constraints are provided for example purposes, and other possible actions and/or constraints are within the scope of this disclosure. It should be noted that the constraints take into account the autonomous vehicle current velocity, speed limit in the local region, acceleration limit, deceleration limit, prediction data relating to objects in the autonomous vehicle environment, or the like.
Referring back to
In certain embodiments, the system may compute the constraint sets 346 concurrently with topological planning 344. The constraint sets may be used in topological planning to discard constraint sets (and the corresponding topological classes) that are infeasible, redundant with other constraint sets, and/or heuristically expensive. This allows for computationally inexpensive analysis even in complex urban environments where considering every combination of actions for every object may be intractable.
A constraint set may be infeasible based on the incompatibility of the state of the autonomous vehicle and a constraint. For example, as illustrated in
In certain embodiments, the longitudinal actions and associated constraints may be analyzed before the lateral actions because lateral margins to non-stationary objects are a function of time, and time cannot be estimated until longitudinal constraints are specified. Lateral constraints for stationary objects may be computed irrespective of the longitudinal constraints because they only on the reference path.
At 348, the system may optimize a trajectory for each constraint set to determine a candidate trajectory for each topologically distinct class. This optimization may be performed using model-predictive control or another algorithm, to generate a dynamically feasible and comfortable trajectory that satisfies the constraint set. Computation of the constraint set takes into account real-time information such as, without limitation, perception information about the local region (e.g. traffic signal state) and the predicted trajectories of other objects (e.g. vehicles, pedestrians). In some embodiments, the predicted trajectories may be updated in trajectory optimization to model interaction with the autonomous vehicle. For example, a vehicle in a lane that the autonomous vehicle intends to merge into may decelerate to widen the gap, and the optimized trajectory(ies) may be updated accordingly.
At 350, the system may assign a score to each candidate trajectory, and select (352) a best candidate trajectory based on the assigned scores (e.g., best trajectory selected as maximum reward or minimum cost depending on scoring criteria) to be used for traversing the local region from the optimized trajectories. In certain embodiments, the system may assign a score based on factors such as, without limitation, risk of collision (i.e., a trajectory that has a lesser risk of collision may be assigned a lower cost than a trajectory that has a higher risk of collision), traffic rule violations (i.e. a trajectory that clears an intersection may be assigned lower cost than a trajectory that stops in the intersection and “blocks the box”), passenger comfort (e.g., a trajectory that does not require performing sudden braking or steering maneuvers may be assigned a lower cost than a trajectory that requires such maneuvers), or the like.
The score may be assigned based on for example, the real-time perception information of the autonomous vehicle; location and predicted trajectories of objects in the autonomous vehicle's environment; locations of intersections, lights, stop signs, or the like; location of permissible lane change regions; the nominal route; or the like.
In some embodiments, scoring may be biased for temporal consistency such that the autonomous vehicle may prefer to choose the discrete action it chose the last time it executed the trajectory generation process 306, if still feasible. For example, if the situation changes such that a lane change is no longer feasible, the autonomous vehicle can abort the lane change and transition back to the origin lane, if still feasible. The system may determine (308) whether the autonomous vehicle has reached its destination on the nominal route, and repeat the above local region determination (304) and trajectory generation (306) steps until the vehicle reaches the destination.
The benefits of the described process to trajectory generation 306 using topological planning are as follows. First, the process 306 is more complete compared to sampling-based approaches. Topological planning ensures the system can generate a trajectory for every topologically distinct class, whereas a sampling-based approach may miss some classes if sampling is not sufficiently dense. Second, the process 306 is more efficient than sampling-based approaches, because it ensures just one trajectory is optimized and scored for each topologically distinct class, whereas a sampling-based approach may generate multiple trajectories for some classes, which may be effectively equivalent (i.e. take the same discrete actions with respect to objects). Finally, the process 306 may produce a more optimal trajectory than a sampling-based approach. The process 306 directly optimizes trajectories for constraint sets rather than sampling trajectories without regard for constraints, which may satisfy constraints but sub-optimally. The process is more robust than an optimization only approach because it identifies convex envelopes in which to optimize, whereas an optimization only approach attempts to find a solution in a non-convex constraint space and may converge to a local minima.
The following examples illustrate the use of topological planning for trajectory generation in the context of lane changes and in-lane maneuvers.
Alternatively, the autonomous vehicle may plan to accelerate and execute a lane change into lane 520 after tracking ahead of object 503.
Whenever an autonomous vehicle is in a lane and/or is transitioning to/from that lane, it is bound by one of the following longitudinal constraints for each object in the lane: track ahead of the object (if behind the autonomous vehicle), track behind the object (if ahead of the autonomous vehicle), or take an action to pass the object on the left or the right. Using these constraints, the system searches for a transition time interval to execute a lane change such that:
The determined convex envelope and transition time interval may be used to determine a transition spline (i.e., trajectory) for executing a lane change that is: within a distance along interval between track ahead/track behind constraints, within a permitted lane change window (as indicated by a map), and is above a minimum length based on the autonomous vehicle's projected speed and lateral acceleration limits.
The above convex envelopes, trajectories, and transition time intervals are provided for example purposes, and are not limiting.
It should be noted that the systems and methods of this disclosure do not relate to making decisions relating to whether a lane change should be performed. Rather, once a lane change decision has been made, the topological planning is used to plan the lane change maneuver.
There are at least 3 possible actions that the autonomous vehicle 610 can perform with respect to every object in this traffic situation 600: track behind, pass on left, or pass on right. Additionally, the autonomous vehicle 610 may track ahead of the object 602 (assuming the autonomous vehicle cannot pass the object 603 without performing a lane change, which is not an option being considered in this example). The system may, therefore, produce a total of 36 constraint combinations. However, as discussed above, the system may discard constraint sets that are redundant, infeasible, or heuristically expensive. For example, all constraint sets that include the action corresponding to autonomous vehicle stopping behind the static object 601 are going to result in the same trajectory, and hence only one such constraint set needs to be considered and the others may be discarded as redundant. Some additional constraint sets may be discarded as heuristically expensive. For example, given the action to track behind the jaywalking pedestrian 602 from time t1 to t2 (i.e. wait for the pedestrian to cross the lane before passing), the option to then pass the pedestrian on the left may be discarded as heuristically expensive, because by t2 the pedestrian will be on the left side of the lane, and passing on the left would force the AV to leave the lane. Similarly, given the action to track ahead of the pedestrian 602 from time t1 to t2 (i.e. pass before the pedestrian crosses the lane), the option to pass the pedestrian on the right may be discarded as heuristically expensive, because at t1 the pedestrian would still be on the right side of the lane and passing on the right would force the autonomous vehicle to leave the lane. When infeasible, redundant, and heuristically expensive constraint sets are discarded, only 5 remain:
Therefore, the system may generate optimized trajectories for each of the above constraint sets and select the best trajectory by scoring them based on the current environment of the autonomous vehicle. In some embodiments, the system may also discard the third and the fifth constraint sets above if, for example, lateral margins indicate that passing the static obstacle on the right requires lane mark violation, drivable area violation, or the like. These candidate trajectories would be low priority for optimization and scoring in anytime planning.
An optional display interface 730 may permit information from the bus 700 to be displayed on a display device 735 in visual, graphic or alphanumeric format. An audio interface and audio output (such as a speaker) also may be provided. Communication with external devices may occur using various communication devices 740 such as a wireless antenna, an RFID tag and/or short-range or near-field communication transceiver, each of which may optionally communicatively connect with other components of the device via one or more communication system. The communication device(s) 740 may be configured to be communicatively connected to a communications network, such as the Internet, a local area network or a cellular telephone data network.
The hardware may also include a user interface sensor 745 that allows for receipt of data from input devices 750 such as a keyboard, a mouse, a joystick, a touchscreen, a touch pad, a remote control, a pointing device and/or microphone. Digital image frames also may be received from a camera 720 that can capture video and/or still images. The system also may receive data from a motion and/or position sensor 770 such as an accelerometer, gyroscope or inertial measurement unit. The system also may receive data from a LiDAR system 760 such as that described earlier in this document.
The above-disclosed features and functions, as well as alternatives, may be combined into many other different systems or applications. Various components may be implemented in hardware or software or embedded software. Various presently unforeseen or unanticipated alternatives, modifications, variations or improvements may be made by those skilled in the art, each of which is also intended to be encompassed by the disclosed embodiments.
It should be noted that while the training of the neural network model and using the trained model in this disclosure is described with respect to autonomous vehicles and objects in the environments of the autonomous vehicles, the disclosure is not so limiting. The rolling horizon training methods described above may be used for training neural networks for use in other scenarios that are constrained by inertial parameters that represent short-term dynamics of an object. Examples may include neural network models configured for making predictions relating to movement of players and/or objects such as balls in a sports environment; or any other system or environment that is both constrained by physics and involves behavioral choice.
Terminology that is relevant to the disclosure provided above includes;
An “automated device” or “robotic device” refers to an electronic device that includes a processor, programming instructions, and one or more components that based on commands from the processor can perform at least some operations or tasks with minimal or no human intervention. For example, an automated device may perform one or more automatic functions or function sets. Examples of such operations, functions or tasks may include without, limitation, navigation, transportation, driving, delivering, loading, unloading, medical-related processes, construction-related processes, and/or the like. Example automated devices may include, without limitation, autonomous vehicles, drones and other autonomous robotic devices.
An “electronic device” or a “computing device” refers to a device that includes a processor and memory. Each device may have its own processor and/or memory, or the processor and/or memory may be shared with other devices as in a virtual machine or container arrangement. The memory will contain or receive programming instructions that, when executed by the processor, cause the electronic device to perform one or more operations according to the programming instructions.
The terms “memory,” “memory device,” “data store,” “data storage facility” and the like each refer to a non-transitory device on which computer-readable data, programming instructions or both are stored. Except where specifically stated otherwise, the terms “memory,” “memory device,” “data store,” “data storage facility” and the like are intended to include single device embodiments, embodiments in which multiple memory devices together or collectively store a set of data or instructions, as well as individual sectors within such devices.
The terms “processor” and “processing device” refer to a hardware component of an electronic device that is configured to execute programming instructions. Except where specifically stated otherwise, the singular term “processor” or “processing device” is intended to include both single-processing device embodiments and embodiments in which multiple processing devices together or collectively perform a process.
The term “vehicle” refers to any moving form of conveyance that is capable of carrying either one or more human occupants and/or cargo and is powered by any form of energy. The term “vehicle” includes, but is not limited to, cars, trucks, vans, trains, autonomous vehicles, aircraft, aerial drones and the like. An “autonomous vehicle” or AV is a vehicle having a processor, programming instructions and drivetrain components that are controllable by the processor without requiring a human operator. An autonomous vehicle may be fully autonomous in that it does not require a human operator for most or all driving conditions and functions, or it may be semi-autonomous in that a human operator may be required in certain conditions or for certain operations, or that a human operator may override the vehicle's autonomous system and may take control of the vehicle. The autonomous vehicle can be a ground-based autonomous vehicle (e.g., car, truck, bus, etc.), an air-based autonomous vehicle (e.g., airplane, drone, helicopter, or other aircraft), or other types of vehicles (e.g., watercraft).
In this document, when terms such “first” and “second” are used to modify a noun, such use is simply intended to distinguish one item from another, and is not intended to require a sequential order unless specifically stated. In addition, terms of relative position such as “vertical” and “horizontal”, or “front” and “rear”, when used, are intended to be relative to each other and need not be absolute, and only refer to one possible position of the device associated with those terms depending on the device's orientation.
Number | Name | Date | Kind |
---|---|---|---|
6393362 | Burns | May 2002 | B1 |
8219298 | Nishira | Jul 2012 | B2 |
8392117 | Dolgov | Mar 2013 | B2 |
8626565 | Petroff | Jan 2014 | B2 |
8660720 | LaPorte | Feb 2014 | B2 |
9475491 | Nagasaka | Oct 2016 | B1 |
9494439 | Ross | Nov 2016 | B1 |
9547309 | Ross | Jan 2017 | B2 |
9645577 | Frazzoli | May 2017 | B1 |
9734455 | Levinson | Aug 2017 | B2 |
9868443 | Zeng | Jan 2018 | B2 |
10042362 | Fairfield | Aug 2018 | B2 |
10108195 | Silvlin | Oct 2018 | B2 |
10137896 | Zhuang | Nov 2018 | B2 |
10139828 | Ho | Nov 2018 | B2 |
10183668 | Takae | Jan 2019 | B2 |
10242665 | Abeloe | Mar 2019 | B1 |
10248124 | Bellaiche | Apr 2019 | B2 |
10254760 | Abeloe | Apr 2019 | B1 |
10306430 | Abari | May 2019 | B1 |
10338591 | Baalke | Jul 2019 | B2 |
10338594 | Long | Jul 2019 | B2 |
10345809 | Ross | Jul 2019 | B2 |
10363960 | Stefan | Jul 2019 | B2 |
10379533 | Bier | Aug 2019 | B2 |
10452070 | Greenfield | Oct 2019 | B2 |
10488868 | Averhart | Nov 2019 | B2 |
10545029 | Yang | Jan 2020 | B2 |
10606269 | Millard | Mar 2020 | B2 |
10620631 | Abeloe | Apr 2020 | B1 |
10620638 | Budihal | Apr 2020 | B2 |
10671076 | Kobilarov | Jun 2020 | B1 |
10678248 | Ford | Jun 2020 | B2 |
10725473 | Nix | Jul 2020 | B2 |
10795364 | Abeloe | Oct 2020 | B1 |
10802488 | Abeloe | Oct 2020 | B1 |
10802489 | Abeloe | Oct 2020 | B1 |
10836405 | Wray | Nov 2020 | B2 |
10883844 | Ogale | Jan 2021 | B2 |
10937178 | Srinivasan | Mar 2021 | B1 |
11004000 | Gutmann | May 2021 | B1 |
11181926 | Shalev-Shwartz | Nov 2021 | B2 |
11249479 | Thakur | Feb 2022 | B2 |
11256983 | Ogale | Feb 2022 | B2 |
11403853 | Murveit | Aug 2022 | B2 |
20020143461 | Burns | Oct 2002 | A1 |
20080172148 | Isorce | Jul 2008 | A1 |
20090327011 | Petroff | Dec 2009 | A1 |
20120130582 | Hukkeri | May 2012 | A1 |
20120209457 | Bushnell | Aug 2012 | A1 |
20130006473 | Buerkle | Jan 2013 | A1 |
20130085661 | Chan | Apr 2013 | A1 |
20130231855 | Mcaree | Sep 2013 | A1 |
20140012436 | Coulmeau | Jan 2014 | A1 |
20140129073 | Ferguson | May 2014 | A1 |
20150105946 | Kumar | Apr 2015 | A1 |
20150134204 | Kunihiro | May 2015 | A1 |
20150344030 | Damerow | Dec 2015 | A1 |
20160334229 | Ross | Nov 2016 | A1 |
20160334230 | Ross | Nov 2016 | A1 |
20160334797 | Ross | Nov 2016 | A1 |
20170090480 | Ho | Mar 2017 | A1 |
20170123419 | Levinson | May 2017 | A1 |
20170124476 | Levinson | May 2017 | A1 |
20170129486 | Nakada | May 2017 | A1 |
20170183004 | Bonarens | Jun 2017 | A1 |
20170192437 | Bier | Jul 2017 | A1 |
20170242435 | Nilsson | Aug 2017 | A1 |
20170277195 | Frazzoli | Sep 2017 | A1 |
20170316333 | Levinson | Nov 2017 | A1 |
20170323249 | Khasis | Nov 2017 | A1 |
20170365178 | Shay | Dec 2017 | A1 |
20180017971 | Di Cairano | Jan 2018 | A1 |
20180024562 | Bellaiche | Jan 2018 | A1 |
20180075309 | Sathyanarayana | Mar 2018 | A1 |
20180099676 | Goto | Apr 2018 | A1 |
20180143643 | Fairfield | May 2018 | A1 |
20180189578 | Yang | Jul 2018 | A1 |
20180215386 | Naserian | Aug 2018 | A1 |
20180246517 | Costa | Aug 2018 | A1 |
20180259966 | Long | Sep 2018 | A1 |
20180315314 | Gilsenan | Nov 2018 | A1 |
20180329418 | Baalke | Nov 2018 | A1 |
20180329428 | Nagy | Nov 2018 | A1 |
20180348767 | Jafari Tafti | Dec 2018 | A1 |
20180356819 | Mahabadi | Dec 2018 | A1 |
20190033085 | Ogale | Jan 2019 | A1 |
20190034794 | Ogale | Jan 2019 | A1 |
20190056748 | Budihal | Feb 2019 | A1 |
20190071092 | Ma | Mar 2019 | A1 |
20190072964 | Nix | Mar 2019 | A1 |
20190086924 | Greenfield | Mar 2019 | A1 |
20190092570 | MacDonald | Mar 2019 | A1 |
20190118939 | Cantinaud | Apr 2019 | A1 |
20190122572 | Morellec | Apr 2019 | A1 |
20190135283 | Bonk | May 2019 | A1 |
20190137287 | Pazhayampallil | May 2019 | A1 |
20190179311 | Paden | Jun 2019 | A1 |
20190196481 | Tay | Jun 2019 | A1 |
20190216003 | Green | Jul 2019 | A1 |
20190219401 | Daniilidis | Jul 2019 | A1 |
20190236955 | Hu | Aug 2019 | A1 |
20190239416 | Green | Aug 2019 | A1 |
20190243370 | Li | Aug 2019 | A1 |
20190243371 | Nister | Aug 2019 | A1 |
20190250617 | Ford | Aug 2019 | A1 |
20190278297 | Averhart | Sep 2019 | A1 |
20190283802 | Matsunaga | Sep 2019 | A1 |
20190286151 | Palanisamy | Sep 2019 | A1 |
20190317516 | Zhu | Oct 2019 | A1 |
20190339709 | Tay | Nov 2019 | A1 |
20190346851 | Liu | Nov 2019 | A1 |
20190354106 | Gupta | Nov 2019 | A1 |
20190364403 | Abari | Nov 2019 | A1 |
20190369637 | Shalev-Shwartz | Dec 2019 | A1 |
20200023842 | Gutierrez | Jan 2020 | A1 |
20200026276 | Zhang | Jan 2020 | A1 |
20200050195 | Gross | Feb 2020 | A1 |
20200064483 | Li | Feb 2020 | A1 |
20200064851 | Wilkinson | Feb 2020 | A1 |
20200077861 | Kwak | Mar 2020 | A1 |
20200081454 | Kwak | Mar 2020 | A1 |
20200089241 | Kao | Mar 2020 | A1 |
20200110416 | Hong | Apr 2020 | A1 |
20200110421 | Lin | Apr 2020 | A1 |
20200139967 | Beller | May 2020 | A1 |
20200148201 | King | May 2020 | A1 |
20200150672 | Naghshvar | May 2020 | A1 |
20200156632 | Ding | May 2020 | A1 |
20200174490 | Ogale | Jun 2020 | A1 |
20200180612 | Finelt | Jun 2020 | A1 |
20200189573 | King | Jun 2020 | A1 |
20200225669 | Silva | Jul 2020 | A1 |
20200232806 | Goldman | Jul 2020 | A1 |
20200233415 | Panzica | Jul 2020 | A1 |
20200239024 | Srinivasan | Jul 2020 | A1 |
20200240794 | Prasser | Jul 2020 | A1 |
20200247434 | Kim | Aug 2020 | A1 |
20200249674 | Dally | Aug 2020 | A1 |
20200257301 | Weiser | Aug 2020 | A1 |
20200283014 | Wray | Sep 2020 | A1 |
20200293044 | Millard | Sep 2020 | A1 |
20200298891 | Liang | Sep 2020 | A1 |
20200312168 | Liu | Oct 2020 | A1 |
20200331476 | Chen | Oct 2020 | A1 |
20200341474 | Zuo | Oct 2020 | A1 |
20200346666 | Wray | Nov 2020 | A1 |
20200353949 | Huang | Nov 2020 | A1 |
20200363806 | Kobilarov | Nov 2020 | A1 |
20210048506 | Panaget | Feb 2021 | A1 |
20210078594 | Bansal | Mar 2021 | A1 |
Number | Date | Country |
---|---|---|
3517893 | Jul 2019 | EP |
2598408 | Mar 2022 | GB |
10-2019-0101925 | Sep 2019 | KR |
2018160486 | Sep 2018 | WO |
WO-2018172849 | Sep 2018 | WO |
WO-2019023628 | Jan 2019 | WO |
2019104112 | May 2019 | WO |
WO-2021003379 | Jan 2021 | WO |
Entry |
---|
R. Laxhammarand G. Falkman, “Online Learning and Sequential Anomaly Detection in Trajectories,” in IEEE Transactions on Pattern Analysis and Machine Intelligence, vol. 36, No. 6, pp. 1158-1173, Jun. 2014, doi: 10.1109/TPAMI.2013.172. (Year: 2014). |
N. Deo, A. Rangesh and M. M. Trivedi, “How Would Surround Vehicles Move? A Unified Framework for Maneuver Classification and Motion Prediction,” in IEEE Transactions on Intelligent Vehicles, vol. 3, No. 2, pp. 129-140, Jun. 2018, doi: 10.1109/TIV.2018.2804159. (Year: 2018). |
N. Anjum and A. Cavallaro, “Multifeature Object Trajectory Clustering for Video Analysis,” in IEEE Transactions on Circuits and Systems for Video Technology, vol. 18, No. 11, pp. 1555-1564, Nov. 2008, doi: 10.1109/TCSVT.2008.2005603 (Year: 2008). |
Deo, N., Rangesh, A. and Trivedi, M.M., 2018. How would surround vehicles move. A unified framework for maneuver classification and motion prediction. (Year: 2018). |
W. Wang, et al. “A Path Following Lateral Control Scheme for Four-Wheel Independent Drive Autonomous Vehicle Using Sliding Mode Prediction Control,” in IEEE Trans on Transportation Electrification, vol. 8, No. 3, pp. 3192-3207, Sep. 2022, doi: 10.1109/TTE.2022.3170059. (Year: 2022). |
W. Wang, T. Qie, C. Yang, W. Liu, C. Xiang and K. Huang, “An Intelligent Lane-Changing Behavior Prediction and Decision-Making Strategy for an Autonomous Vehicle,” in IEEE Transactions on Industrial Electronics, vol. 69, No. 3, pp. 2927-2937, Mar. 2022, doi: 10.1109/TIE.2021.3066943.(Year: 2021). |
Y. Wang, Z. Liu, Z. Zuo, Z. Li, L. Wang and X. Luo, “Trajectory Planning and Safety Assessment of Autonomous Vehicles Based on Motion Prediction and Model Predictive Control,” in IEEE Transactions on Vehicular Technology, vol. 68, No. 9, pp. 8546-8556, Sep. 2019, doi: 10.1109/TVT.2019.2930684.(Year: 2019). |
Gu, T. et al., “Automated Tactical Maneuver Discovery, Reasoning and Trajectory Planning for Autonomous Driving”, (<https://www.ri.cmu.edu/wp-content/uploads/2016/10/20160801-IROS-Camera-Ready.pdf>). |
International Search Report and Written Opinion dated Feb. 8, 2021, for Application No. PCT/US2020/054358. |
Number | Date | Country | |
---|---|---|---|
20210108936 A1 | Apr 2021 | US |