Autonomous vehicles, such as vehicles that do not require a human driver, can be used to aid in the transport of passengers or cargo from one location to another. Such vehicles may operate in a fully autonomous mode or a partially autonomous mode where a person may provide some driving input. In order to operate in an autonomous mode, the vehicle may employ various on-board sensors to detect features of the external environment, and use received sensor information to perform various driving operations. However, a sensor's ability to detect an object in the vehicle's environment can be limited by occlusions. Such occlusions may obscure the presence of objects that are farther away and may also impact the ability of the vehicle's computer system from determining types of detected objects. These issues can adversely impact driving operations, route planning and other autonomous actions.
The technology relates to determining the presence of occlusions in the environment around a vehicle, correcting information regarding such occlusions, and employing the corrected information in onboard and offboard systems to enhance vehicle operation in an autonomous driving mode.
According to one aspect of the technology, a method of operating a vehicle in an autonomous driving mode is provided. The method comprises receiving, by one or more processors, raw sensor data from one or more sensors of a perception system of the vehicle, the one or more sensors being configured to detect objects in an environment surrounding the vehicle; generating, by the one or more processors, a range image for a set of the raw sensor data received from a given one of the one or more sensors of the perception system; modifying, by the one or more processors, the range image by performing at least one of removing noise or filling in missing data points for the set of raw sensor data; generating, by the one or more processors, a sensor field of view (FOV) data set including the modified range image, the sensor FOV data set identifying whether there are occlusions in a field of view of the given sensor; providing the sensor FOV data set to at least one on-board module of the vehicle; and controlling operation of the vehicle in the autonomous driving mode according to the provided sensor FOV data set.
In one example, removing the noise includes filtering out noise values from the range image based on a last-returned result received by the given sensor. In another example, filling in the missing data points includes representing portions of the range image having the missing data points in a same way as one or more adjacent areas of the range image.
In a further example, modifying the range image includes applying a heuristic correction approach. The heuristic correction approach may include tracking one or more detected objects in the environment surrounding the vehicle over a period of time to determine how to correct perception data associated with the one or more detected objects. The perception data associated with the one or more detected objects may be corrected by filling in data holes associated with a given detected object. The perception data associated with the one or more detected objects may be corrected by interpolating missing pixels according to an adjacent boundary for the one or more detected objects.
In yet another example, generating the sensor FOV data set further includes compressing the modified range image while maintaining a specified amount of sensor resolution. Generating the sensor FOV data set may include determining whether to compress the modified range image based on an operational characteristic of the given sensor. Here, the operational characteristic may be selected from the group consisting of a sensor type, a minimum resolution threshold, and a transmission bandwidth.
In another example, the method may include providing the sensor data set to at least one on-board module includes providing the sensor data set to a planner module, wherein controlling operation of the vehicle in the autonomous driving mode includes the planner module controlling at least one of a direction or speed of the vehicle. In this case, controlling operation of the vehicle may include determining whether an occlusion exists along a particular direction in the environment surrounding the vehicle according to the sensor FOV data set, and, upon determining that the occlusion exists, modifying at least one of the direction or speed of the vehicle to account for the occlusion.
In yet another example, generating the sensor FOV data set comprises evaluating whether a maximum visible range value is closer than a physical distance of a point of interest to determine whether the point of interest is visible or occluded. And in another example, the method further includes providing the sensor FOV data set to at least one off-board module of a remote computing system.
According to another aspect of the technology, a system is configured to operate a vehicle in an autonomous driving mode. The system comprises memory and one or more processors operatively coupled to the memory. The one or more processors are configured to receive raw sensor data from one or more sensors of a perception system of the vehicle. The one or more sensors are configured to detect objects in an environment surrounding the vehicle. The processor(s) is further configured to generate a range image for a set of the raw sensor data received from a given one of the one or more sensors of the perception system, modify the range image by performing at least one of removal of noise or filling in missing data points for the set of raw sensor data, and generate a sensor field of view (FOV) data set including the modified range image. The sensor FOV data set identifies whether there are occlusions in a field of view of the given sensor. The processor(s) is further configured to store the generated sensor FOV data set in the memory, and control operation of the vehicle in the autonomous driving mode according to the stored sensor FOV data set.
In one example, removal of the noise includes filtering out noise values from the range image based on a last-returned result received by the given sensor. In another example, filling in the missing data points includes representing portions of the range image having the missing data points in a same way as one or more adjacent areas of the range image. In yet another example, modification of the range image includes application of a heuristic correction approach. And in a further example, generation of the sensor FOV data set includes a determination of whether to compress the modified range image based on an operational characteristic of the given sensor.
According to yet another aspect of the technology, a vehicle is provided that includes both the system described above and the perception system.
Aspects of the technology gather received data from on-board sensors and compute range images for each sensor based on their received data. The data for each range image may be corrected in accordance with obtained perception information, heuristics and/or machine learning to fill gaps in the data, filter out noise, etc. Depending on the sensor type and its characteristics, the resultant corrected data may be compressed prior to packaging into a format for consumption by onboard and offboard systems. Such systems are able to evaluate the corrected data when performing driving operations, planning an upcoming route, testing driving scenarios, etc.
The trailer 154 includes a hitching point, known as a kingpin, 158. The kingpin 158 is typically formed as a solid steel shaft, which is configured to pivotally attach to the tractor unit 152. In particular, the kingpin 158 attaches to a trailer coupling 160, known as a fifth-wheel, that is mounted rearward of the cab. For a double or triple tractor-trailer, the second and/or third trailers may have simple hitch connections to the leading trailer. Or, alternatively, each trailer may have its own kingpin. In this case, at least the first and second trailers could include a fifth-wheel type structure arranged to couple to the next trailer.
As shown, the tractor may have one or more sensor units 162, 164 disposed therealong. For instance, one or more sensor units 162 may be disposed on a roof or top portion of the cab 156, and one or more side sensor units 164 may be disposed on left and/or right sides of the cab 156. Sensor units may also be located along other regions of the cab 106, such as along the front bumper or hood area, in the rear of the cab, adjacent to the fifth-wheel, underneath the chassis, etc. The trailer 154 may also have one or more sensor units 166 disposed therealong, for instance along a side panel, front, rear, roof and/or undercarriage of the trailer 154.
By way of example, each sensor unit may include one or more sensors, such as lidar, radar, camera (e.g., optical or infrared), acoustical (e.g., microphone or sonar-type sensor), inertial (e.g., accelerometer, gyroscope, etc.) or other sensors (e.g., positioning sensors such as GPS sensors). While certain aspects of the disclosure may be particularly useful in connection with specific types of vehicles, the vehicle may be any type of vehicle including, but not limited to, cars, trucks, motorcycles, buses, recreational vehicles, etc.
There are different degrees of autonomy that may occur for a vehicle operating in a partially or fully autonomous driving mode. The U.S. National Highway Traffic Safety Administration and the Society of Automotive Engineers have identified different levels to indicate how much, or how little, the vehicle controls the driving. For instance, Level 0 has no automation and the driver makes all driving-related decisions. The lowest semi-autonomous mode, Level 1, includes some drive assistance such as cruise control. Level 2 has partial automation of certain driving operations, while Level 3 involves conditional automation that can enable a person in the driver's seat to take control as warranted. In contrast, Level 4 is a high automation level where the vehicle is able to drive without assistance in select conditions. And Level 5 is a fully autonomous mode in which the vehicle is able to drive without assistance in all situations. The architectures, components, systems and methods described herein can function in any of the semi or fully-autonomous modes, e.g., Levels 1-5, which are referred to herein as autonomous driving modes. Thus, reference to an autonomous driving mode includes both partial and full autonomy.
The memory 206 stores information accessible by the processors 204, including instructions 208 and data 210 that may be executed or otherwise used by the processors 204. The memory 206 may be of any type capable of storing information accessible by the processor, including a computing device-readable medium. The memory is a non-transitory medium such as a hard-drive, memory card, optical disk, solid-state, etc. Systems may include different combinations of the foregoing, whereby different portions of the instructions and data are stored on different types of media.
The instructions 208 may be any set of instructions to be executed directly (such as machine code) or indirectly (such as scripts) by the processor(s). For example, the instructions may be stored as computing device code on the computing device-readable medium. In that regard, the terms “instructions”, “modules” and “programs” may be used interchangeably herein. The instructions may be stored in object code format for direct processing by the processor, or in any other computing device language including scripts or collections of independent source code modules that are interpreted on demand or compiled in advance. The data 210 may be retrieved, stored or modified by one or more processors 204 in accordance with the instructions 208. In one example, some or all of the memory 206 may be an event data recorder or other secure data storage system configured to store vehicle diagnostics and/or detected sensor data, which may be on board the vehicle or remote, depending on the implementation.
The processors 204 may be any conventional processors, such as commercially available CPUs. Alternatively, each processor may be a dedicated device such as an ASIC or other hardware-based processor. Although
In one example, the computing devices 202 may form an autonomous driving computing system incorporated into vehicle 100. The autonomous driving computing system may capable of communicating with various components of the vehicle. For example, the computing devices 202 may be in communication with various systems of the vehicle, including a driving system including a deceleration system 212 (for controlling braking of the vehicle), acceleration system 214 (for controlling acceleration of the vehicle), steering system 216 (for controlling the orientation of the wheels and direction of the vehicle), signaling system 218 (for controlling turn signals), navigation system 220 (for navigating the vehicle to a location or around objects) and a positioning system 222 (for determining the position of the vehicle, e.g., including the vehicle's pose). The autonomous driving computing system may employ a planner module 223, in accordance with the navigation system 220, the positioning system 222 and/or other components of the system, e.g., for determining a route from a starting point to a destination or for making modifications to various driving aspects in view of current or expected traction conditions.
The computing devices 202 are also operatively coupled to a perception system 224 (for detecting objects in the vehicle's environment), a power system 226 (for example, a battery and/or gas or diesel powered engine) and a transmission system 230 in order to control the movement, speed, etc., of the vehicle in accordance with the instructions 208 of memory 206 in an autonomous driving mode which does not require or need continuous or periodic input from a passenger of the vehicle. Some or all of the wheels/tires 228 are coupled to the transmission system 230, and the computing devices 202 may be able to receive information about tire pressure, balance and other factors that may impact driving in an autonomous mode.
The computing devices 202 may control the direction and speed of the vehicle, e.g., via the planner module 223, by controlling various components. By way of example, computing devices 202 may navigate the vehicle to a destination location completely autonomously using data from the map information and navigation system 220. Computing devices 202 may use the positioning system 222 to determine the vehicle's location and the perception system 224 to detect and respond to objects when needed to reach the location safely. In order to do so, computing devices 202 may cause the vehicle to accelerate (e.g., by increasing fuel or other energy provided to the engine by acceleration system 214), decelerate (e.g., by decreasing the fuel supplied to the engine, changing gears, and/or by applying brakes by deceleration system 212), change direction (e.g., by turning the front or other wheels of vehicle 100 by steering system 216), and signal such changes (e.g., by lighting turn signals of signaling system 218). Thus, the acceleration system 214 and deceleration system 212 may be a part of a drivetrain or other type of transmission system 230 that includes various components between an engine of the vehicle and the wheels of the vehicle. Again, by controlling these systems, computing devices 202 may also control the transmission system 230 of the vehicle in order to maneuver the vehicle autonomously.
Navigation system 220 may be used by computing devices 202 in order to determine and follow a route to a location. In this regard, the navigation system 220 and/or memory 206 may store map information, e.g., highly detailed maps that computing devices 202 can use to navigate or control the vehicle. As an example, these maps may identify the shape and elevation of roadways, lane markers, intersections, crosswalks, speed limits, traffic signal lights, buildings, signs, real time traffic information, vegetation, or other such objects and information. The lane markers may include features such as solid or broken double or single lane lines, solid or broken lane lines, reflectors, etc. A given lane may be associated with left and/or right lane lines or other lane markers that define the boundary of the lane. Thus, most lanes may be bounded by a left edge of one lane line and a right edge of another lane line.
The perception system 224 includes sensors 232 for detecting objects external to the vehicle. The detected objects may be other vehicles, obstacles in the roadway, traffic signals, signs, trees, etc. The sensors may 232 may also detect certain aspects of weather conditions, such as snow, rain or water spray, or puddles, ice or other materials on the roadway.
By way of example only, the perception system 224 may include one or more light detection and ranging (lidar) sensors, radar units, cameras (e.g., optical imaging devices, with or without a neutral-density filter (ND) filter), positioning sensors (e.g., gyroscopes, accelerometers and/or other inertial components), infrared sensors, acoustical sensors (e.g., microphones or sonar transducers), and/or any other detection devices that record data which may be processed by computing devices 202. Such sensors of the perception system 224 may detect objects outside of the vehicle and their characteristics such as location, orientation, size, shape, type (for instance, vehicle, pedestrian, bicyclist, etc.), heading, speed of movement relative to the vehicle, etc. The perception system 224 may also include other sensors within the vehicle to detect objects and conditions within the vehicle, such as in the passenger compartment. For instance, such sensors may detect, e.g., one or more persons, pets, packages, etc., as well as conditions within and/or outside the vehicle such as temperature, humidity, etc. Still further sensors 232 of the perception system 224 may measure the rate of rotation of the wheels 228, an amount or a type of braking by the deceleration system 212, and other factors associated with the equipment of the vehicle itself.
As discussed further below, the raw data obtained by the sensors can be processed by the perception system 224 and/or sent for further processing to the computing devices 202 periodically or continuously as the data is generated by the perception system 224. Computing devices 202 may use the positioning system 222 to determine the vehicle's location and perception system 224 to detect and respond to objects when needed to reach the location safely, e.g., via adjustments made by planner module 223, including adjustments in operation to deal with occlusions and other issues. In addition, the computing devices 202 may perform calibration of individual sensors, all sensors in a particular sensor assembly, or between sensors in different sensor assemblies or other physical housings.
As illustrated in
Returning to
The passenger vehicle also includes a communication system 242. For instance, the communication system 242 may also include one or more wireless configurations to facilitate communication with other computing devices, such as passenger computing devices within the vehicle, computing devices external to the vehicle such as in another nearby vehicle on the roadway, and/or a remote server system. The network connections may include short range communication protocols such as Bluetooth™, Bluetooth™ low energy (LE), cellular connections, as well as various configurations and protocols including the Internet, World Wide Web, intranets, virtual private networks, wide area networks, local networks, private networks using communication protocols proprietary to one or more companies, Ethernet, WiFi and HTTP, and various combinations of the foregoing.
In one example, the computing devices 302 may form an autonomous driving computing system incorporated into vehicle 150. Similar to the arrangement discussed above regarding
The computing devices 302 are also operatively coupled to a perception system 324, a power system 326 and a transmission system 330. Some or all of the wheels/tires 228 are coupled to the transmission system 230, and the computing devices 202 may be able to receive information about tire pressure, balance, rotation rate and other factors that may impact driving in an autonomous mode. As with computing devices 202, the computing devices 302 may control the direction and speed of the vehicle by controlling various components. By way of example, computing devices 302 may navigate the vehicle to a destination location completely autonomously using data from the map information and navigation system 320. Computing devices 302 may employ a planner module 323, in conjunction with the positioning system 322, the perception system 324 and other subsystems to detect and respond to objects when needed to reach the location safely, similar to the manner described above for
Similar to perception system 224, the perception system 324 also includes one or more sensors or other components such as those described above for detecting objects external to the vehicle, objects or conditions internal to the vehicle, and/or operation of certain vehicle equipment such as the wheels and deceleration system 312. For instance, as indicated in FIG. 3A the perception system 324 includes one or more sensor assemblies 332. Each sensor assembly 232 includes one or more sensors. In one example, the sensor assemblies 332 may be arranged as sensor towers integrated into the side-view mirrors on the truck, farm equipment, construction equipment or the like. Sensor assemblies 332 may also be positioned at different locations on the tractor unit 152 or on the trailer 154, as noted above with regard to
Also shown in
The ECU 342 is configured to receive information and control signals from the trailer unit. The on-board processors 344 of the ECU 342 may communicate with various systems of the trailer, including a deceleration system 352, signaling system 254, and a positioning system 356. The ECU 342 may also be operatively coupled to a perception system 358 with one or more sensors for detecting objects in the trailer's environment and a power system 260 (for example, a battery power supply) to provide power to local components. Some or all of the wheels/tires 362 of the trailer may be coupled to the deceleration system 352, and the processors 344 may be able to receive information about tire pressure, balance, wheel speed and other factors that may impact driving in an autonomous mode, and to relay that information to the processing system of the tractor unit. The deceleration system 352, signaling system 354, positioning system 356, perception system 358, power system 360 and wheels/tires 362 may operate in a manner such as described above with regard to
The trailer also includes a set of landing gear 366, as well as a coupling system 368. The landing gear provide a support structure for the trailer when decoupled from the tractor unit. The coupling system 368, which may be a part of coupling system 334, provides connectivity between the trailer and the tractor unit. Thus, the coupling system 368 may include a connection section 370 (e.g., for power and/or pneumatic links). The coupling system also includes a kingpin 372 configured for connectivity with the fifth-wheel of the tractor unit.
In view of the structures and configurations described above and illustrated in the figures, various aspects will now be described in accordance with aspects of the technology.
Sensors, such as long and short range lidars, radar sensors, cameras or other imaging devices, etc., are used in self-driving vehicles (SDVs) or other vehicles that are configured to operate in an autonomous driving mode to detect objects and conditions in the environment around the vehicle. Each sensor may have a particular field of view (FOV) including a maximum range, and for some sensors a horizontal resolution and a vertical resolution. For instance, a panoramic lidar sensor may have a maximum range on the order of 70-100 meters, a vertical resolution of between 0.1°−0.3°, and a horizontal resolution of between 0.1°-0.4°, or more or less. A directional lidar sensor, for example to provide information about a front, rear or side area of the vehicle, may have a maximum range on the order of 100-300 meters, a vertical resolution of between of between 0.05°−0.2°, and a horizontal resolution of between 0.01°-0.03°, or more or less.
Examples of lidar, camera and radar sensors and their fields of view for a cargo-type vehicle (e.g., vehicle 150 of
As illustrated in
As shown by regions 508 and 526 of
It is important for the on-board computer system to know whether there is an occlusion, because knowing this can impact driving or route planning decisions, as well as off-line training and analysis. For example, in the top-down view 600 of
And
In all of these situations, the lack of information about an object in the surrounding environment may lead to one driving decision, whereas if the vehicle were aware of a possible occlusion it might lead to a different driving decision. In order to address such issues, according to aspects of the technology visibility and occlusion information is determined based on data received from the perception system's sensors, providing a sensor FOV result that can be used by different onboard and offboard systems for real-time vehicle operation, modeling, planning and other processes.
A range image computed from raw (unprocessed) received sensor data is used to capture the visibility information. For instance, this information can be stored as a matrix of values, where each value is associated with a point (pixel) in the range image. According to one example, the range image can be presented visually to a user, where different matrix values can be associated with different colors or greyscale shading. In the case of a lidar sensor, each pixel stored in the range image represents the maximum range the laser shot can see along a certain azimuth and inclination angle (view angle). For any 3D location whose visibility is being evaluated, the pixel at which the 3D location's laser shot falls into can be identified and the ranges (e.g., stored maximum visible range versus physical distance from the vehicle to the 3D location) can be compared. If the stored maximum visible range value is closer than the physical distance, then the 3D point is considered to be not visible, because there is a closer occlusion along this view angle. In contrast, if the stored maximum visible range value is at least the same as the physical distance, then the 3D point is considered to be visible (not occluded). A range image may be computed for each sensor in the vehicle's perception system.
The range image may include noise and there may be missing returns, e.g., no received data point for a particular emitted laser beam. This can result in an impairment to visibility. Impairments to visibility may reduce the maximum detection range of objects with the same reflectivity, so that issue may be factored into processing of the range image. Examples impairments include but are not limited to sun blinding, materials on the sensor aperture such as raindrops or leaves, atmospheric effects such as fog or heavy rain, dust clouds, exhaust, etc.
The range image data may be corrected using information obtained by the vehicle's perception system, generating a sensor field of view (FOV) data set. For instance, noise can be filtered out and holes in the data can be filled in. In one example, noise may be corrected by using information from a last-returned result (e.g., laser shot reflection) rather than from a first-returned result or other earlier returned result. This is because a given sensor may receive multiple returns from one emission (e.g., one shot of a laser). For example, as shown in scenario 700 of
Heuristic or learning-based approaches can be employed to correct the range image. A heuristic approach can identify large portions of the image that are sky (e.g., located along a top region of the image) or ground (e.g., located along a bottom region of the image. This approach can track perception-detected objects to help determine how to deal with specific areas or conditions. For instance, if the perception system determines that an object is a vehicle, the window “holes” can be automatically filled in as part of the vehicle. Other missing pixels can be interpolated (e.g., inward from an adjacent boundary) using various image processing techniques, such as constant color analysis, horizontal interpolation or extrapolation, or variational inpainting. In another example, exhaust may be detected in some but not all of the laser returns. Based on this, the system could determine that the exhaust is something that can be ignored.
Additional heuristics involve objects at or near the minimum or maximum range of the sensor. For instance, if an object is closer than the minimum range of a sensor, the sensor will not be able to detect this object (thus, another type of hole in range image); however, the object would block the view of the sensor and create an occlusion. Here, the system may search for holes associated with a particular region of the image, such as the bottom of the image, and consider those having the minimum range of the sensor.
With regard to the maximum sensor range of, e.g., a laser, not all laser shots are the same. For instance, some laser shots are designed to see farther away while some are designed to see closer. How far a shot is designed to see is called maximum listening range.
In an example learning-based approach, the problem to be solved is to fill in missing parts of the obtained sensor data. For a machine leaning method, a set of training data can be created by removing some of the actually captured laser shots in collected data to obtain a training range image. The removed parts are the ground truth data. The machine learning system learns how to fill in the removed parts using those ground truth. Once trained, the system is then employed with real raw sensor data. For example, in an original range image, some subset of pixels would be randomly removed. The training range image is missing the removed pixels, and those pixels are the ground truth. The system trains a net to learn how to fill those intentionally removed pixel from the entire image. This net can now be applied on real holes in “live” sensor data, and it will try to fill those holes with the knowledge it has learned.
Regardless of the approaches used to correct or otherwise modify the range image, the resultant sensor FOV data set with the modified range image may be compressed depending on the size of the set. The decision on whether to compress may be made on a sensor by sensor basis, a minimum resolution threshold requirement, a transmission bandwidth requirement (e.g., for transmission to a remote system) and/or other factors. For instance, a sensor FOV data set from a panoramic sensor (e.g., 360° lidar sensor) may be compressed, while data from a directional sensor may not need to be compressed. Various image processing techniques can be used, so long as a specified amount of resolution (e.g., within 1°) is maintained. By way of example, lossless image compression algorithms such as PNG compression may be employed
Then, whether compressed or not, the sensor FOV information for one or more sensors is made available to onboard and/or remote systems. The onboard systems may include the planner module and the perception system. In one example, the planner module employs the sensor FOV information to control the direction and speed of the vehicle. Information from different sensor FOV data sets associated with different sensors may be combined or evaluated individually by the planner module or other system as needed.
When an occlusion is identified as discussed above, objects detected by the perception system alone may not be sufficient for the planner module to make an operating decision, such as whether to start an unprotected left turn. If there is an occlusion, it may be hard for the system to tell whether there is no object at all, or whether there might be an oncoming vehicle that has not been flagged by the perception system due to the occlusion. Here, the sensor FOV information is used by the planner module to indicate there is an occlusion. For example, the planner module would consider the possibility of there being an oncoming occluded object, which may impact how the vehicle behaves. By way of example, this could occur in a situation where the vehicle is making an unprotected left turn. For instance, the planner module could query the system to see if a particular region in the external environment around the vehicle is visible or occluded. This can be done by checking the corresponding pixels covering that region in the range image representation in the sensor FOV. If not visible, that would indicate an occlusion in the region. Here, the planner module may speculate that there is another object in the occluded area (e.g., an oncoming vehicle). In this situation, the planner module may cause the vehicle to slowly pull out in order to reduce the impact of the occlusion by allowing its sensors to obtain additional information regarding the environment.
Another example includes lowering the speed of the vehicle if the vehicle is in a region that has lowered visibility, e.g., due to fog, dust or other environmental conditions. A further example involves remembering the presence of objects that were visible before, but later entered an occlusion. For instance, another car may drive through a region not visible to the self-driving vehicle. And yet another example might involve deciding that a region of particular interest cannot be guaranteed to be fully clear because it is occluded, e.g., a crosswalk.
Offboard systems may use the sensor FOV information to perform autonomous simulations based on real-world or man-made scenarios, or metric analysis to evaluate system metrics that might be impacted by visibility/occlusion. This information may be used in model training. It can also be shared across a fleet of vehicles to enhance the perception and route planning for those vehicles.
One such arrangement is shown in
As shown in
The various computing devices and vehicles may communication via one or more networks, such as network 916. The network 916, and intervening nodes, may include various configurations and protocols including short range communication protocols such as Bluetooth™, Bluetooth LE™, the Internet, World Wide Web, intranets, virtual private networks, wide area networks, local networks, private networks using communication protocols proprietary to one or more companies, Ethernet, WiFi and HTTP, and various combinations of the foregoing. Such communication may be facilitated by any device capable of transmitting data to and from other computing devices, such as modems and wireless interfaces.
In one example, computing device 902 may include one or more server computing devices having a plurality of computing devices, e.g., a load balanced server farm, that exchange information with different nodes of a network for the purpose of receiving, processing and transmitting the data to and from other computing devices. For instance, computing device 902 may include one or more server computing devices that are capable of communicating with the computing devices of vehicles 912 and/or 914, as well as computing devices 904, 906 and 908 via the network 916. For example, vehicles 912 and/or 914 may be a part of a fleet of vehicles that can be dispatched by a server computing device to various locations. In this regard, the computing device 902 may function as a dispatching server computing system which can be used to dispatch vehicles to different locations in order to pick up and drop off passengers or to pick up and deliver cargo. In addition, server computing device 902 may use network 916 to transmit and present information to a user of one of the other computing devices or a passenger of a vehicle. In this regard, computing devices 904, 906 and 908 may be considered client computing devices.
As shown in
Although the client computing devices may each comprise a full-sized personal computing device, they may alternatively comprise mobile computing devices capable of wirelessly exchanging data with a server over a network such as the Internet. By way of example only, client computing devices 906 and 908 may be mobile phones or devices such as a wireless-enabled PDA, a tablet PC, a wearable computing device (e.g., a smartwatch), or a netbook that is capable of obtaining information via the Internet or other networks.
In some examples, client computing device 904 may be a remote assistance workstation used by an administrator or operator to communicate with passengers of dispatched vehicles. Although only a single remote assistance workstation 904 is shown in
Storage system 910 can be of any type of computerized storage capable of storing information accessible by the server computing devices 902, such as a hard-drive, memory card, ROM, RAM, DVD, CD-ROM, flash drive and/or tape drive. In addition, storage system 910 may include a distributed storage system where data is stored on a plurality of different storage devices which may be physically located at the same or different geographic locations. Storage system 910 may be connected to the computing devices via the network 916 as shown in
In a situation where there are passengers, the vehicle or remote assistance may communicate directly or indirectly with the passengers' client computing device. Here, for example, information may be provided to the passengers regarding current driving operations, changes to the route in response to the situation, etc.
At block 1004, a range image is generated for a set of the raw sensor data received from a given one of the one or more sensors of the perception system. At block 1006, the range image is modified by performing at least one of removing noise or filling in missing data points for the set of raw sensor data. At block 1008, a sensor field of view (FOV) data set including the modified range image is generated. The sensor FOV data set identifies whether there are occlusions in a field of view of the given sensor
At block 1010, the sensor FOV data set is provided to at least one on-board module of the vehicle. And at block 1012, the system is configured to control operation of the vehicle in the autonomous driving mode according to the provided sensor FOV data set.
Finally, as noted above, the technology is applicable for various types of wheeled vehicles, including passenger cars, buses, RVs and trucks or other cargo carrying vehicles.
Unless otherwise stated, the foregoing alternative examples are not mutually exclusive, but may be implemented in various combinations to achieve unique advantages. As these and other variations and combinations of the features discussed above can be utilized without departing from the subject matter defined by the claims, the foregoing description of the embodiments should be taken by way of illustration rather than by way of limitation of the subject matter defined by the claims. In addition, the provision of the examples described herein, as well as clauses phrased as “such as,” “including” and the like, should not be interpreted as limiting the subject matter of the claims to the specific examples; rather, the examples are intended to illustrate only one of many possible embodiments. Further, the same reference numbers in different drawings can identify the same or similar elements. The processes or other operations may be performed in a different order or simultaneously, unless expressly indicated otherwise herein.