As more vehicles travel the roads, and as those roads are expanded, the traffic patterns that vehicles create are increasingly complicated and far-flung. Traffic congestion may hinder drivers, for example by prolonging travel time, by increasing the likelihood of collisions, or by forcing drivers onto unfamiliar or undesirable travel routes. Therefore, information about traffic patterns, if collected and relayed to drivers in a timely manner, may allow drivers to adjust their travel plans to increase safety and convenience. Additionally, traffic monitoring may aid emergency responders by identifying both locations of collisions and routes by which emergency vehicles may travel to a collision.
Vehicles may be connected to wireless communications networks, and vehicles may be equipped with wireless transceivers configured to send and receive wireless signals. In a typical wireless network, a radio access network (“RAN”) facilitates client devices, such as vehicles, communicating over the air interface. A RAN may be communicatively coupled to other types of networks, such as the Internet, and may include, among other components, base transceiver stations (“BTSs”), servers, and gateways, including switches. A BTS may comprise a cell tower with one or more antennas that radiate to define a cell and cell sectors. A BTS may serve client devices within the geographic coverage area corresponding to its cell, such that client devices within that area receive signals from and transmit signals to the BTS.
A server may receive signals from and transmit signals to a BTS. The server may also receive signals from and transmit signals to other network entities, possibly through network gateways, and a server may generate signals requesting or relaying information. Further, the server may process information contained in the signals it receives and may be equipped with memory, logic, and processing power sufficient for such information processing.
Methods and systems are herein disclosed to utilize wireless capabilities in vehicles to allow vehicles to communicate with each other to collect information that may then be sent to a traffic monitoring server. The information collected by the vehicles may take the form of a data packet that is generated by one vehicle and broadcast to nearby vehicles, and each vehicle that receives the packet may edit the packet and broadcast the packet to other vehicles. Vehicles may also broadcast a reporting packet to the traffic monitoring server.
An exemplary system supports the monitoring of vehicular traffic. This system comprises a plurality of vehicles that are capable of communicating using a RAN and a traffic monitoring server that is communicatively coupled to the RAN. Each vehicle of the plurality is equipped to send packets to and receive packets from other vehicles and to send packets to the traffic monitoring server. A packet, sent from a vehicle, contains at least (i) identification data including an identifier of the vehicle, (ii) a location of the vehicle, (iii) a direction of travel of the vehicle, and (iv) a counter value.
Upon receipt of a packet from a nearby vehicle, a given vehicle determines if the given vehicle is already identified in the packet and is traveling in substantially the same direction as the nearby vehicle, as indicated in the packet. If the given vehicle is not already identified in the packet and if the given vehicle is traveling in the same direction, the given vehicle generates a next packet. To generate the next packet, the given vehicle increments the counter value and adds an identifier of the given vehicle to the identification data so as to establish modified identification data. The given vehicle then broadcasts, for receipt by any nearby vehicles, a next packet containing at least (i) the modified identification data, (ii) a location of the given vehicle, (iii) a direction of travel of the given vehicle, and (iv) the incremented counter value. Additionally, the given vehicle transmits to the nearby vehicle an acknowledgement of the initially received packet.
The given vehicle is further equipped to transmit a reporting packet, containing information usable by the traffic monitoring server to determine vehicular traffic, via the radio access network to the traffic monitoring server. The transmitting of the reporting packet may be conditioned upon not receiving an acknowledgement after broadcasting a next packet. The transmitting of the reporting packet may also be conditioned upon a determination that the incremented counter value meets a threshold.
Each vehicle may be further equipped to broadcast an initial packet that is not based on data received from any nearby vehicles. Such an initial packet may include (i) an identifier of the vehicle broadcasting the initial packet, (ii) a location of the vehicle broadcasting the initial packet, (iii) a direction of travel of the vehicle broadcasting the initial packet, and (iv) a counter value of one.
An exemplary traffic monitoring module installed in a vehicle may facilitate the collection of information to send to a traffic monitoring server. The module may include, among other components, a first wireless transceiver, a second wireless transceiver, a processor, data storage, and program instructions stored in the data storage and executable by the processor. The first wireless transceiver may be operable to engage in direct wireless communication with traffic monitoring modules in nearby vehicles, and the second wireless transceiver may be operable to engage in wireless communication with the radio access network. The module may also have a speedometer to determine its speed and a compass to determine its direction and location.
The program instructions contained by the traffic monitoring module may allow the module to perform multiple functions. The module may receive a packet wirelessly transmitted from the nearby vehicle and may wirelessly broadcast a next packet, both via the first wireless transceiver. The module may also transmit, via the first transceiver, an acknowledgement of a received packet. Additionally, the module may transmit a reporting packet via the second wireless transceiver to the radio access network for transmission in turn to the traffic monitoring server.
Traffic monitoring modules 12, 16, 20, and 36 may also communicate over an air interface 22 with a RAN 24 using long-range wireless protocols. Such long-range wireless protocols are known in the art and may include, by way of example, CDMA, iDEN, TDMA, AMPS, GSM, GPRS, UMTS, EDGE, WiMAX, LTE, and satellite. A BTS 26 may include a tower with one or more antennas that radiate to define air interface 22. BTS 26 may also be connected to a traffic monitoring server 28, which may be configured to collect and process information relating to vehicular traffic congestion. Traffic monitoring server 28 may be communicatively coupled to other networks, such as a packet switched network, shown as the Internet 40.
Communication interface 56 manages communications between traffic monitoring module 12 and other elements in the network. For instance, a long-range transceiver 58 may communicate with RAN 24 and a satellite 62. Long-range transceiver 58 may comprise two separate radios—one radio adapted to communicate with RAN 24, and one radio adapted to communicate with satellite 62—integrated into a single chipset. A short-range transceiver 60 may communicate with the traffic monitoring modules of nearby vehicles, such as traffic monitoring module 16 of vehicle 14. Messages received through transceivers 58 and 60 may be communicated through communication interface 56 and over system bus 52 to processor 50. Similarly, messages to be transmitted by transceivers 58 and 60 may originate from processor 50 and travel over system bus 52 and through communication interface 56 to the transceivers.
Data storage 54 may contain system logic, including programming instructions, accessible by processor 50 via system bus 52. Such system logic may include packet logic 64 and position determination logic 66. Packet logic 64 may include instructions for generating, analyzing, manipulating, receiving, and transmitting data packets related to monitoring vehicular traffic congestion. Position determination logic 66 may include instructions for determining the geographical position of vehicle 10 using information received from satellite 62 and how to determine the direction in which vehicle 10 is traveling. Alternatively, compass unit 68 may indicate the direction in which vehicle 10 is traveling and may be connected to system bus 52.
Data Packets
Packet 350 is a propagated packet that has been processed and broadcast by n vehicles, here the nth vehicle being vehicle 14. Packet 350 has the same five data fields as packet 300; however, each of the data fields of packet 350 has been incrementally updated to reflect information about each of the vehicles that has processed packet 350. For example, counter 352 has a value of n to indicate that n vehicles have processed packet 350. When originally transmitted, packet 350 was packet 300, and therefore the first value, the value with a subscript of 1, in each of the four data arrays—identification array 354, direction array 356, location array 358, and speed array 360—indicates information from the initial vehicle, vehicle 10. The nth value in each array corresponds to information about the nth vehicle 14, and intervening values correspond to the vehicles that processed packet 350 between initial vehicle 10 and nth vehicle 14.
Exemplary Method
In step 402, the receiving vehicle may analyze the received data packet to determine if the receiving vehicle is already identified in the packet. If the receiving vehicle is already identified in the packet, the method may then proceed from step 402 to end step 416 signifying that the receiving vehicle need not to perform any further operations on the received packet. If the receiving vehicle is not already identified in the packet, the receiving vehicle may proceed from step 402 to step 404, in which the receiving vehicle may analyze the direction information in the packet to determine if the previous vehicles that have processed the packet were traveling in substantially the same direction as the receiving vehicle. Step 404 may ensure that vehicles may edit those packets containing information relevant to the receiving vehicle's direction of travel and may ignore irrelevant packets containing information regarding other directions of travel.
Once the receiving vehicle has determined by that it is not already identified in the packet and that the packet refers to a relevant direction of travel, the receiving vehicle may add information to the packet in step 406. For example, in step 406, the receiving vehicle may increment the counter by one. The receiving vehicle may also update the identification information of the packet to include identification information of the receiving vehicle. In alternative embodiments, the receiving vehicle may also edit the packet in step 406 to include direction, location, and speed information corresponding to the receiving vehicle.
In step 408, the receiving vehicle may broadcast the edited packet to other nearby vehicles. In step 410, the receiving vehicle may transmit an acknowledgement of the received packet to the vehicle that initially transmitted the packet to the receiving vehicle. In step 412, the receiving vehicle may, in turn, wait for an acknowledgement from another vehicle that that vehicle has received and updated the edited packet. If the receiving vehicle receives an acknowledgement in step 412, the receiving vehicle has no further responsibilities with respect to the edited packet, and the receiving vehicle may end its processing of the packet in step 416.
The lack of an acknowledgement received by the receiving vehicle in step 412 may signal to the receiving vehicle that it is the last vehicle that will edit the packet. For example, the receiving vehicle may be the last vehicle because the receiving vehicle is not in close enough proximity to other vehicles that other vehicles would have received the broadcast packet. Alternatively, other vehicles may have received the broadcast packet but determined that their identification information was already included in the packet, signaling to those vehicles that they had already edited the packet and need not edit it again.
If the receiving vehicle does not receive an acknowledgement and is therefore the last vehicle to edit the packet, the receiving vehicle may transmit a reporting packet to the traffic monitoring server in step 414. In one embodiment, the receiving vehicle may transmit the entire edited packet as the reporting packet to the traffic monitoring server using the long-range transceiver in its traffic monitoring module. Alternatively, the receiving vehicle may create a separate reporting packet using a subset of the information in the edited packet—for instance, including counter, direction, and location information and omitting vehicle identification information—and the receiving vehicle may then transmit the reporting packet to the traffic monitoring server. After the receiving vehicle has reported information to the traffic monitoring server, the receiving vehicle may end its packet processing in step 416.
Alternatively, reporting to the traffic monitoring server may be contingent upon the counter value rather than the receipt of an acknowledgement. In that embodiment, a receiving vehicle would determine if the counter value had reached a threshold value after the receiving vehicle had edited the packet. If such a threshold value was reached, the receiving vehicle would transmit a reporting packet to the traffic monitoring server regardless of whether nearby vehicles existed that had not edited the packet.
Given the configuration of
After receiving the data packet, vehicle 14 may perform the functions depicted in
In step 406, vehicle 14 may then augment initial packet 300 to create propagated packet 350 by incrementing the counter to 2 and adding identification, direction, location, and speed information to the appropriate data arrays. In step 408, vehicle 14 may then transmit a propagated packet to other nearby vehicles, and in step 410, vehicle 14 may transmit an acknowledgement back to vehicle 10.
Vehicle 18 may then receive the packet broadcast by vehicle 14 and also perform the functions depicted in
Vehicle 18 will not receive an acknowledgement itself of the transmitted propagated packet in step 412. This is because none of the other three vehicles in
After vehicle 18 does not receive an acknowledgement in step 412, perhaps after a waiting period has elapsed, vehicle 18 may report the propagated packet to the traffic monitoring server in step 414, including at least the counter, the direction information, and the location information. Once traffic monitoring server 38 receives the reporting packet, it may access appropriate maps to translate the reporting packet into the information that three vehicles are currently traveling in direction 32 at intersection 30.
Traffic Monitoring Server
Generally, once the traffic monitoring server receives a reporting packet, the information from the reporting packet may be used to determine traffic patterns. For example, if the reporting packet contains counter, direction, and location information, the traffic monitoring server may correlate the location information to a location on a map. The traffic monitoring server may then determine that traffic congestion does or does not exist in that location by analyzing the number of vehicles traveling in substantially the same direction around the location. Alternatively, if the reporting packet also contains speed information, the traffic monitoring server may analyze the speed information to determine if traffic congestion exists. If the traffic monitoring server receives multiple reporting packets from multiple vehicles in multiple locations, the traffic monitoring server may collect all of the information contained in those reporting packets to determine traffic patterns around a broad area.
The traffic monitoring server may also transmit messages regarding traffic patterns. For example, multiple traffic monitoring servers may also be communicatively coupled with each other to share traffic monitoring information. Alternatively, the traffic monitoring server may transmit traffic information to a vehicle equipped to receive traffic information from the traffic monitoring server. The vehicle may then present relevant traffic information to the driver of the vehicle, for example by displaying a map with traffic icons on a graphical screen embedded in the dashboard of the vehicle.
Exemplary embodiments of the present invention have been described above. Those skilled in the art will understand, however, that changes and modifications may be made to the embodiments described without departing from the true scope and spirit of the present invention, which is defined by the claims.
Number | Name | Date | Kind |
---|---|---|---|
6654681 | Kiendl | Nov 2003 | B1 |
6708107 | Impson et al. | Mar 2004 | B2 |
7106219 | Pearce | Sep 2006 | B2 |
7188025 | Hudson, Jr. | Mar 2007 | B2 |
7468653 | Takahashi | Dec 2008 | B2 |
7886960 | Birjandi et al. | Feb 2011 | B2 |
20050030202 | Tsuboi | Feb 2005 | A1 |
20070083296 | Tengler et al. | Apr 2007 | A1 |
20070117525 | Osafune | May 2007 | A1 |
Number | Date | Country |
---|---|---|
1296305 | Mar 2003 | EP |