Not applicable.
This invention relates generally to yielding to emergency vehicles, and, more particularly, to detecting and responding to emergency vehicles in a roadway.
When emergency vehicles are responding to emergency, other vehicles on a roadway are required to yield to the emergency vehicles. Emergency vehicles including ambulances, fire vehicles, and police vehicles. How to properly yield can vary depending on the roadway configuration.
The specific features, aspects and advantages of the present invention will become better understood with regard to the following description and accompanying drawings where:
The present invention extends to methods, systems, and computer program products for detecting and responding to emergency vehicles in a roadway.
In general, aspects of the invention can be used to detect emergency vehicles (e.g., ambulances, fire vehicles, police vehicles, etc.) and properly yield to emergency vehicles depending on the roadway configuration. A vehicle includes a plurality of sensors including: one or more cameras, a LIDAR sensor, one or more ultrasonic sensors, one or more radar sensors, and one or more microphones. The vehicle also includes vehicle to vehicle (V2V) communication capabilities and has access to map data. Sensor data from the plurality of sensors along with map data is provided as input to a neural network (either in the vehicle or in the cloud). Based on sensor data, the neural network detects when one or more emergency vehicles are approaching the vehicle.
A vehicle can include multi-object tracking capabilities to track multiple emergency vehicles.
In one aspect, an autonomous vehicle automatically yields to one or more detected emergency vehicles. Based on map data, the autonomous vehicle can determine a roadway configuration (e.g., urban, highway, interstate, etc.). From the roadway configuration, the autonomous vehicle can use one or more cameras and one or more microphones to automatically (and safely) yield to the emergency vehicle(s). Automatically yielding can include one or more of: slowing down, changing lanes, stopping, etc. depending on the roadway configuration. The autonomous vehicle can use LIDAR sensors, ultrasound sensors, radar sensors, and cameras for planning a path that includes one or more of: safely changing lanes, slowing down, or stopping.
In an urban environment, an autonomous vehicle can detect if an emergency vehicle is in the same lane as the autonomous vehicle, on the left side of the autonomous vehicle, or on the right side of the autonomous vehicle. If the emergency vehicle is in the same lane, the autonomous vehicle checks to the right and, if there is room, moves to the right (e.g., into another lane or to the shoulder) and slows down and stops. If there is no room to the right, the autonomous vehicle checks to the left and, if there is room, moves to the left (e.g., into another lane, a shoulder, or median) and slows down and stops. If there is no room to safely move to either side, the autonomous vehicle slows down and/or stops.
In a highway environment, an autonomous vehicle can follow a similar procedure. The autonomous vehicle can slow down but may not come to a stop.
In another aspect, a human driver is driving a vehicle that includes the described mechanisms for automatically detecting emergency vehicles. When the vehicle detects an emergency vehicle, the vehicle can activate an audio and/or a visual notification within the vehicle cabin. The audio and/or a visual notification alerts the human driver to the presence of the emergency vehicle. The human driver can then manually manipulate vehicle controls to yield to the emergency vehicle.
In some aspects, emergency vehicles are also equipped with V2V communication capabilities. The emergency vehicles can use V2V communication to notify other vehicles in the area of an intended travel path. Based on intended travel paths of emergency vehicles, other vehicles can adjust (either automatically or manually) to more effectively yield to the emergency vehicles.
In one more specific aspect, a vehicle includes a plurality of microphones, a plurality of cameras (e.g., one in front, one in back, and one on each side), and V2V communication capabilities. The plurality of microphones are used for siren detection. The plurality of cameras are used to detect spinning lights and also to detect if an emergency vehicle is in the same lane as the vehicle. Learning and sensor fusion can be used to collectively handle data for both emergency vehicle detections and tracking and path planning.
Aspects of the invention can be implemented in a variety of different types of computing devices.
Computing device 100 includes one or more processor(s) 102, one or more memory device(s) 104, one or more interface(s) 106, one or more mass storage device(s) 108, one or more Input/Output (I/O) device(s) 110, and a display device 130 all of which are coupled to a bus 112. Processor(s) 102 include one or more processors or controllers that execute instructions stored in memory device(s) 104 and/or mass storage device(s) 108. Processor(s) 102 may also include various types of computer storage media, such as cache memory.
Memory device(s) 104 include various computer storage media, such as volatile memory (e.g., random access memory (RAM) 114) and/or nonvolatile memory (e.g., read-only memory (ROM) 116). Memory device(s) 104 may also include rewritable ROM, such as Flash memory.
Mass storage device(s) 108 include various computer storage media, such as magnetic tapes, magnetic disks, optical disks, solid state memory (e.g., Flash memory), and so forth. As depicted in
I/O device(s) 110 include various devices that allow data and/or other information to be input to or retrieved from computing device 100. Example I/O device(s) 110 include cursor control devices, keyboards, keypads, barcode scanners, microphones, monitors or other display devices, speakers, printers, network interface cards, modems, cameras, lenses, radars, CCDs or other image capture devices, and the like.
Display device 130 includes any type of device capable of displaying information to one or more users of computing device 100. Examples of display device 130 include a monitor, display terminal, video projection device, and the like.
Interface(s) 106 include various interfaces that allow computing device 100 to interact with other systems, devices, or computing environments as well as humans. Example interface(s) 106 can include any number of different network interfaces 120, such as interfaces to personal area networks (PANs), local area networks (LANs), wide area networks (WANs), wireless networks (e.g., near field communication (NFC), Bluetooth, Wi-Fi, etc., networks), and the Internet. Other interfaces include user interface 118 and peripheral device interface 122.
Bus 112 allows processor(s) 102, memory device(s) 104, interface(s) 106, mass storage device(s) 108, and I/O device(s) 110 to communicate with one another, as well as other devices or components coupled to bus 112. Bus 112 represents one or more of several types of bus structures, such as a system bus, PCI bus, IEEE 1394 bus, USB bus, and so forth.
As depicted, vehicle 201 includes external sensor(s) 202, communication module 208, vehicle control systems 254, and vehicle components 211. Each of external sensor(s) 202, communication module 208, vehicle control systems 254, and vehicle components 211, as well as their respective components can be connected to one another over (or be part of) a network, such as, for example, a PAN, a LAN, a WAN, a controller area network (CAN) bus, and even the Internet. Accordingly, each of external sensor(s) 202, communication module 208, vehicle control systems 254, and vehicle components 211, as well as any other connected computer systems and their components, can create message related data and exchange message related data (e.g., near field communication (NFC) payloads, Bluetooth packets, Internet Protocol (IP) datagrams and other higher layer protocols that utilize IP datagrams, such as, Transmission Control Protocol (TCP), Hypertext Transfer Protocol (HTTP), Simple Mail Transfer Protocol (SMTP), etc.) over the network.
Communication module 208 can include hardware components (e.g., a wireless modem or wireless network card) and/or software components (e.g., a protocol stack) for wireless communication with other vehicles and/or computer systems. Communication module 208 can be used to facilitate vehicle to vehicle (V2V) communication as well as vehicle to infrastructure (V2I) communication. In some aspects, communication module 208 can receive data from other vehicles indicating a planned path of the other vehicle. Communication module 208 can forward the instructions to vehicle control systems 254. In one aspect, communication module 208 receives a planned path for an emergency vehicle. Communication module 208 can forward the planned path for the emergency vehicle to vehicle control systems 254.
External sensors 202 include one or more of: microphones 203, camera(s) 204, LIDAR sensor(s) 206, and ultrasonic sensor(s) 207. External sensors 202 may also include other types of sensors (not shown), such as, for example, radar sensors, acoustic sensors, and electromagnetic sensors. In general, external sensors 202 can sense and/or monitor objects in and/or around vehicle 201. External sensors 202 can output sensor data indicating the position and optical flow (i.e., direction and speed) of monitored objects. External sensors 202 can send sensor data to vehicle control systems 254.
Neural network module 224 can include a neural network architected in accordance with a multi-layer (or “deep”) model. A multi-layer neural network model can include an input layer, a plurality of hidden layers, and an output layer. A multi-layer neural network model may also include a loss layer. For classification of sensor data (e.g., an image), values in the sensor data (e.g., pixel-values) are assigned to input nodes and then fed through the plurality of hidden layers of the neural network. The plurality of hidden layers can perform a number of non-linear transformations. At the end of the transformations, an output node yields an indication of any approaching emergency vehicles.
In one aspect, neural network module 224 is run on cloud computing resources (e.g., compute, memory, and storage resources) in a cloud environment. In a cloud computing arrangement, communications module 208 uses V2I communication to send sensor data to neural network module 224 and to receive emergency vehicle detections from neural network module 224. Communication module 208 then forwards emergency vehicle detections to vehicle control systems 254.
In general, vehicle control systems 254 include an integrated set of control systems, for fully autonomous driving. For example, vehicle control systems 254 can include a cruise control system to control throttle 242, a steering system to control wheels 241, a collision avoidance system to control brakes 243, etc. Vehicle control systems 254 can receive sensor data from external sensors 202 and can receive data forwarded from communication module 208. Vehicle control systems 254 can send automated controls 253 to vehicle components 211 to control vehicle 201.
In one aspect, vehicle control systems 254 receive a planned path for an emergency vehicle forwarded from communication module 208. Vehicle control systems 254 can use sensor data on an ongoing basis along with the planned path to safely yield to the emergency vehicle.
As depicted, emergency vehicle 222 (e.g., an ambulance, a fire vehicle, a police vehicle, etc.) includes communication module 218, siren 219, and lights 223. When emergency vehicle 222 is responding to an emergency, siren 219 and/or lights 223 can be activated. Siren 219 can emit any of a variety of different sounds indicative of emergency vehicle 222 responding to an emergency. Lights 223 can be spinning lights. Lights 223 can include one or more lights and each of the one or more lights can be of any of a variety of different colors including: white, yellow, red, or blue.
Communication module 218 can include hardware components (e.g., a wireless modem or wireless network card) and/or software components (e.g., a protocol stack) for wireless communication with other vehicles and/or computer systems. Communication module 218 can be used to facilitate vehicle to vehicle (V2V) communication as well as vehicle to infrastructure (V2I) communication. In some aspects, communication module 228 sends data to other vehicles indicating a planned path of emergency vehicle 222.
As vehicle 201 is in motion, external sensors 202 can continually sense the environment around and/or adjacent to vehicle 201. Sensor data from external sensors 202 can be fused into sensor data 236. For example, sensor data from microphone(s) 203 and camera(s) 204 can be fused into sensor data 236. Microphone(s) 203 can detect sounds of siren 219. Camera(s) 204 can detect lights 223.
Method 300 includes accessing sensor data from one or more of the plurality of sensors (301). For example, neural network module 224 can access sensor data 236 from external sensors 202. Method 300 includes determining that an emergency vehicle is approaching the vehicle on a roadway based on the accessed sensor data (302). For example, neural network module 224 can output emergency vehicle detection 238 based on sensor data 236. Emergency vehicle detection 238 can indicate that emergency vehicle 222 is approaching vehicle 201 in lane 262.
Communication module 218 can send message 239 to vehicle 201. Message 239 indicates that emergency vehicle 222 intends to travel path 264 (e.g., straight ahead in lane 262). Communication module 208 can receive message 239 from emergency vehicle 222. Communication module 208 can forward message 239 to vehicle control systems 254.
Method 300 includes accessing additional sensor from an additional one or more of the plurality of sensors (303). For example, control systems 254 can access sensor data 237 from external sensors 202. As vehicle 201 continues in motion, external sensors 202 can continue to sense the environment around and/or adjacent to vehicle 201. Sensor data from external sensors 202 can be fused into sensor data 237.
Method 300 includes determining a yield strategy for the vehicle to yield to the emergency vehicle based on the additional sensor data (304). For example, vehicle control systems 254 can determine a yield strategy for vehicle 201 to yield to emergency vehicle 222 based on sensor data 237. Vehicle control systems 254 can use sensor data 237 to determine if other vehicles are in adjacent lanes (e.g., lane 261), speed and position of other vehicles, paths of other vehicles, other obstacles (e.g., signs, barricade, etc.), etc. A yield strategy can include one or more of: changing lanes (e.g., left or right), slowing down, and stopping. For example, vehicle control systems 254 can determine a yield strategy to pull into shoulder 263 and stop vehicle 201 until emergency vehicle 222 passes.
Method 300 includes receiving adjustments to vehicle component configurations to cause the vehicle to implement the yield strategy (305). For example, vehicle control systems 254 can send automated controls 253 to adjust vehicle components 211 to implement the yield strategy. One or more of wheels 241, throttle 242, and brakes 243 can receive adjustments (configuration changes) to implement yield 266. For example, wheels 241 can be adjusted to turn vehicle 201 into shoulder 263. Throttle 242 and brakes 243 can be adjusted to stop vehicle 201.
If neural network 409 does not detect an emergency vehicle on the road (NO at 411), vehicle 401 can re-check for emergency vehicles. Checking for emergency vehicles can continue on an ongoing basis while vehicle 401 is on a roadway.
If neural network 409 detects an emergency vehicle on the road (YES at 411) and vehicle 401 is being driven by a human driver, audio/visual alarm 431 can be activated in the cabin on vehicle 401 to alert the human driver. Based on the roadway environment, the human driver can then yield to the emergency vehicle(s) as appropriate.
In one aspect, the emergency vehicle can also send an anticipated path of travel for the emergency vehicle to vehicle 401 via V2V communication 406.
If there is an emergency vehicle on the road and vehicle 401 is in a highway roadway environment (YES/Highway at 411), vehicle 401 can formulate and implement a strategy to automatically yield to the emergency vehicle. Vehicle 401 can determine (e.g., from additional sensor data and/or the emergency vehicle's anticipated path of travel) if vehicle 401 and an emergency vehicle are in the same lane (412). If vehicle 401 is not in the same lane as an emergency vehicle (NO at 412), vehicle 401 can slow down (413) (or stop) so that the emergency vehicle can pass.
If vehicle 401 is in the same lane as an emergency vehicle (YES at 412), vehicle 401 can determine if there is an empty lane to the right of vehicle 401 (414). If there is an empty lane to the right (YES at 414), vehicle 401 can pull into the right lane (415) and stop (416) (or pull into the right lane and slow down). If there is not an empty lane to the right of vehicle 401 (NO at 414) (e.g., other traffic is in the lane to the right), vehicle 401 can determine if there is an empty lane to the left of vehicle 401 (417). If there is an empty lane to the left (YES at 417), vehicle 401 can pull into the left lane (418) and stop (419) (or pull into the left lane and slow down).
If there is not an empty lane to the left (NO at 417), vehicle 401 can again determine if vehicle 401 is in the same lane as an emergency vehicle (412). As the emergency vehicle and other vehicles in the highway roadway environment travel, vehicle positions and lane availability can change. For example, the emergency vehicle can change lanes (or pull into a median or onto a shoulder) and/or lanes to the right of vehicle 401 and/or to the left of vehicle 401 can free up. Vehicle 401 can continual re-check for appropriate ways to automatically yield to the emergency vehicle.
If there is an emergency vehicle on the road and vehicle 401 is in an urban roadway environment (YES/Urban at 411), vehicle 401 can formulate and implement a strategy to automatically yield to the emergency vehicle. Vehicle 401 can determine (e.g., from additional sensor data and/or the emergency vehicle's anticipated path of travel) if vehicle 401 and an emergency vehicle are in the same lane (422). If vehicle 401 is not in the same lane as an emergency vehicle (NO at 422), vehicle 401 can stop (423) (or slow down) so that the emergency vehicle can pass.
If vehicle 401 is in the same lane as an emergency vehicle (YES at 422), vehicle 401 can determine if there is an empty lane to the right of vehicle 401 (424). If there is an empty lane to the right (YES at 424), vehicle 401 can pull into the right lane (425) and stop (426) (or pull into the right lane and slow down). If there is not an empty lane to the right of vehicle 401 (NO at 424) (e.g., other traffic is in the lane to the right), vehicle 401 can determine if there is an empty lane to the left of vehicle 401 (427). If there is an empty lane to the left (YES at 427), vehicle 401 can pull into the left lane (428) and stop (429) (or pull into the left lane and slow down).
If there is not an empty lane to the left (NO at 427), vehicle 401 can again determine if vehicle 401 is in the same lane as an emergency vehicle (422). As the emergency vehicle and other vehicles in the highway roadway environment travel, vehicle positions and lane availability can change. For example, the emergency vehicle can change lanes (or pull into a median or onto a shoulder) and/or lanes to the right of vehicle 401 and/or to the left of vehicle 401 can free up. Vehicle 401 can continual re-check for an appropriate strategy to automatically yield to the emergency vehicle.
In one aspect, one or more processors are configured to execute instructions (e.g., computer-readable instructions, computer-executable instructions, etc.) to perform any of a plurality of described operations. The one or more processors can access information from system memory and/or store information in system memory. The one or more processors can transform information between different formats, such as, for example, sensor data, maps, emergency vehicle detections, V2V messages, yielding strategies, intended paths of travel, audio/visual alerts, etc.
System memory can be coupled to the one or more processors and can store instructions (e.g., computer-readable instructions, computer-executable instructions, etc.) executed by the one or more processors. The system memory can also be configured to store any of a plurality of other types of data generated by the described components, such as, for example, sensor data, maps, emergency vehicle detections, V2V messages, yielding strategies, intended paths of travel, audio/visual alerts, etc.
In the above disclosure, reference has been made to the accompanying drawings, which form a part hereof, and in which is shown by way of illustration specific implementations in which the disclosure may be practiced. It is understood that other implementations may be utilized and structural changes may be made without departing from the scope of the present disclosure. References in the specification to “one embodiment,” “an embodiment,” “an example embodiment,” etc., indicate that the embodiment described may include a particular feature, structure, or characteristic, but every embodiment may not necessarily include the particular feature, structure, or characteristic. Moreover, such phrases are not necessarily referring to the same embodiment. Further, when a particular feature, structure, or characteristic is described in connection with an embodiment, it is submitted that it is within the knowledge of one skilled in the art to affect such feature, structure, or characteristic in connection with other embodiments whether or not explicitly described.
Implementations of the systems, devices, and methods disclosed herein may comprise or utilize a special purpose or general-purpose computer including computer hardware, such as, for example, one or more processors and system memory, as discussed herein. Implementations within the scope of the present disclosure may also include physical and other computer-readable media for carrying or storing computer-executable instructions and/or data structures. Such computer-readable media can be any available media that can be accessed by a general purpose or special purpose computer system. Computer-readable media that store computer-executable instructions are computer storage media (devices). Computer-readable media that carry computer-executable instructions are transmission media. Thus, by way of example, and not limitation, implementations of the disclosure can comprise at least two distinctly different kinds of computer-readable media: computer storage media (devices) and transmission media.
Computer storage media (devices) includes RAM, ROM, EEPROM, CD-ROM, solid state drives (“SSDs”) (e.g., based on RAM), Flash memory, phase-change memory (“PCM”), other types of memory, other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store desired program code means in the form of computer-executable instructions or data structures and which can be accessed by a general purpose or special purpose computer.
An implementation of the devices, systems, and methods disclosed herein may communicate over a computer network. A “network” is defined as one or more data links that enable the transport of electronic data between computer systems and/or modules and/or other electronic devices. When information is transferred or provided over a network or another communications connection (either hardwired, wireless, or a combination of hardwired or wireless) to a computer, the computer properly views the connection as a transmission medium. Transmissions media can include a network and/or data links, which can be used to carry desired program code means in the form of computer-executable instructions or data structures and which can be accessed by a general purpose or special purpose computer. Combinations of the above should also be included within the scope of computer-readable media.
Computer-executable instructions comprise, for example, instructions and data which, when executed at a processor, cause a general purpose computer, special purpose computer, or special purpose processing device to perform a certain function or group of functions. The computer executable instructions may be, for example, binaries, intermediate format instructions such as assembly language, or even source code. Although the subject matter has been described in language specific to structural features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the described features or acts described above. Rather, the described features and acts are disclosed as example forms of implementing the claims.
Those skilled in the art will appreciate that the disclosure may be practiced in network computing environments with many types of computer system configurations, including, an in-dash or other vehicle computer, personal computers, desktop computers, laptop computers, message processors, hand-held devices, multi-processor systems, microprocessor-based or programmable consumer electronics, network PCs, minicomputers, mainframe computers, mobile telephones, PDAs, tablets, pagers, routers, switches, various storage devices, and the like. The disclosure may also be practiced in distributed system environments where local and remote computer systems, which are linked (either by hardwired data links, wireless data links, or by a combination of hardwired and wireless data links) through a network, both perform tasks. In a distributed system environment, program modules may be located in both local and remote memory storage devices.
Further, where appropriate, functions described herein can be performed in one or more of: hardware, software, firmware, digital components, or analog components. For example, one or more application specific integrated circuits (ASICs) can be programmed to carry out one or more of the systems and procedures described herein. Certain terms are used throughout the description and claims to refer to particular system components. As one skilled in the art will appreciate, components may be referred to by different names. This document does not intend to distinguish between components that differ in name, but not function.
It should be noted that the sensor embodiments discussed above may comprise computer hardware, software, firmware, or any combination thereof to perform at least a portion of their functions. For example, a sensor may include computer code configured to be executed in one or more processors, and may include hardware logic/electrical circuitry controlled by the computer code. These example devices are provided herein purposes of illustration, and are not intended to be limiting. Embodiments of the present disclosure may be implemented in further types of devices, as would be known to persons skilled in the relevant art(s).
At least some embodiments of the disclosure have been directed to computer program products comprising such logic (e.g., in the form of software) stored on any computer useable medium. Such software, when executed in one or more data processing devices, causes a device to operate as described herein.
While various embodiments of the present disclosure have been described above, it should be understood that they have been presented by way of example only, and not limitation. It will be apparent to persons skilled in the relevant art that various changes in form and detail can be made therein without departing from the spirit and scope of the disclosure. Thus, the breadth and scope of the present disclosure should not be limited by any of the above-described exemplary embodiments, but should be defined only in accordance with the following claims and their equivalents. The foregoing description has been presented for the purposes of illustration and description. It is not intended to be exhaustive or to limit the disclosure to the precise form disclosed. Many modifications and variations are possible in light of the above teaching. Further, it should be noted that any or all of the aforementioned alternate implementations may be used in any combination desired to form additional hybrid implementations of the disclosure.