1. Field of the Invention
This invention relates generally to a system and method for identifying a reliable vehicle in a vehicle-to-vehicle communications system and, more particularly, to a system and method for assuring that information received from a vehicle in a vehicle-to-vehicle communication system is reliable and not malicious.
2. Discussion of the Related Art
Traffic accidents and roadway congestion are significant problems for vehicle travel. Vehicular ad-hoc network based active safety and driver assistance systems are known that allow a vehicle communications system to transmit messages to other vehicles in a particular area with warning messages about dangerous road conditions, driving events, accidents, etc. In these systems, multi-hop geocast routing protocols, known to those skilled in the art, are commonly used to extend the reachability of the warning messages, i.e., to deliver active messages to vehicles that may be a few kilometers away from the road condition, as a one-time multi-hop transmission process. In other words, an initial message advising drivers of a potential hazardous road condition is transferred from vehicle to vehicle using the geocast routing protocol so that vehicles a significant distance away will receive the messages because one vehicle's transmission distance is typically relatively short.
Vehicle-to-vehicle and vehicle-to-infrastructure applications require a minimum of one entity to send information to another entity. For example, many vehicle-to-vehicle safety applications can be executed on one vehicle by simply receiving broadcast messages from a neighboring vehicle. These messages are not directed to any specific vehicle, but are meant to be shared with a vehicle population to support the safety application. In these types of applications, where collision avoidance is desirable, as two or more vehicles talk to each other and a collision becomes probable, the vehicle systems can warn the vehicle drivers, or possibly take evasive action for the driver, such as applying the brakes. Likewise, traffic control units can observe the broadcast of information and generate statistics on traffic flow through a given intersection or roadway. Once a vehicle broadcasts a message, any consumer of the message could be unknown.
It is generally necessary that the information received from a vehicle in these types of vehicle-to-vehicle communications system be reliable to ensure that the vehicle is not attempting to broadcast malicious information that could result in harmful activity, such as a vehicle collision. One current solution for providing trust of the information broadcasted is by transmitting public keys, referred to as public key infrastructure (PKI), so that a vehicle that transmits a certain key is identified as a trusted source. However, transmitting a key between vehicles for identification purposes has a number of drawbacks particularly in system scalability. For example, the number of vehicles that may participate in a vehicle-to-vehicle communications system could exceed 250,000,000 vehicles in the United States alone. Also, the transmission of the key has limitations as to its timeliness of access to the PKI while on the road, the availability of the PKI from anywhere, the bandwidth to the PKI for simultaneous access and the computations needed for PKI certification, reissuance, etc.
In accordance with the teachings of the present invention, a vehicle-to-vehicle or vehicle-to-infrastructure communications system is disclosed that employs a challenge/response based process and algorithm to ensure that information received from a vehicle is reliable. A subject vehicle may receive a message from a suspect vehicle. The subject vehicle determines whether there is a memory bucket stored on the subject vehicle for the suspect vehicle, and if not, the subject vehicle creates a bucket for the suspect vehicle. The subject vehicle transmits a challenge question from the subject vehicle to the suspect vehicle to determine whether the suspect vehicle is a reliable source of information. The algorithm increases a number of tokens in the bucket for the suspect vehicle if the response to the challenge question is correct, and decreases the number of tokens in the token bucket for the suspect vehicle if the response to the challenge question is incorrect. The subject vehicle accepts the message from the suspect vehicle if the number of tokens in the bucket for the suspect vehicle is greater than a predetermined upper threshold, and discards the message from the suspect vehicle if the number of tokens in the bucket for the suspect vehicle is less than a predetermined lower threshold. The algorithm deletes the token bucket for a suspect vehicle if the subject vehicle has not received a message from the suspect vehicle for a predetermined period of time.
Additional features of the present invention will become apparent from the following description and appended claims, taken in conjunction with the accompanying drawings.
The following discussion of the embodiments of the invention directed to a vehicle-to-vehicle communications system employing a process for ensuring messages received from a vehicle are reliable is merely exemplary in nature, and is in no way intended to limit the invention or its applications or uses.
The present invention proposes a trust-based model in a vehicle-to-vehicle and vehicle-to-infrastructure communications system that will increase the knowledge that communications received by a vehicle are reliable and not malicious. The trust-based model of the communications system is a challenge/response process that is intended to segregate trusted vehicles from malicious vehicles or other nodes. Certain assumptions are made in the trust-based model, including that each vehicle is equipped with a GPS device that enables the vehicle to know its spatial coordinates. Further, each vehicle that is part of the communications system has a number of token buckets, or digital buffers storing counts, corresponding to all of the vehicles it may be communicating with. The number of tokens in the bucket corresponds to the amount of trust that that vehicle has been given. Each token bucket in the vehicle is deleted after a certain period of time has elapsed if a communication with that vehicle has not occurred. The objective to delete a token bucket is to keep the memory requirements in the vehicle as low as possible.
The challenge questions transmitted by one vehicle to another vehicle to determine its trustworthiness can be any suitable question that the transmitting vehicle will know the answer to. For example, the vehicle 12 can ask the vehicle 16 where it is located. If the vehicle 16 responds with an answer that the vehicle 12 knows is reliable because of the transmission distance, or other knowledge, then the vehicle 12 can assume that other information from the vehicle 16 is reliable.
As a vehicle travels along its everyday course, or over other courses, it will constantly be communicating with other vehicles to determine whether they are trustworthy. Thus, each time the vehicle 12 encounters another vehicle, it may issue a question or questions that the other vehicle will respond to, and the transmitting vehicle will know the answer to, at least generally. Each vehicle that the vehicle 12 encounters will have a bucket for that vehicle stored on the vehicle 12, and each time that an interrogated vehicle responds with the correct answer, the number of tokens in the bucket for that vehicle is increased, indicating that the interrogated vehicle is more reliable. For each wrong answer that the interrogated vehicle gives, tokens are removed from that vehicles bucket, thus decreasing the probability that that vehicle is a reliable source for information. Because memory on the vehicle 12 is a premium, a bucket or buffer for a vehicle is only maintained if that vehicle is encountered often enough to make keeping a bucket for that vehicle cost worthy. Therefore, if a predetermined period of time, such as three months, has gone by where the vehicle is not encountered again, the bucket for that vehicle can be deleted.
If there is a bucket corresponding to the kth vehicle at the decision diamond 24, the algorithm then determines whether the number of wrong answers Dk is greater than a predetermined threshold Th from previous challenges and responses for the kth vehicle at decision diamond 28. If the number of wrong answers is greater than the threshold Th at the decision diamond 28, then the algorithm sets the number of questions to be asked by the subject vehicle in the future to be N=εNQ to determine reliability at box 30. Because the number of wrong answers received from the kth vehicle is larger than the allowed threshold Th, more time and questions are needed to allow trust to be built up for the kth vehicle. Thus, the algorithm sets the number of questions NQ to be asked to be a fraction, i.e., εNQ.
If the number of wrong answers Dk is not greater than the threshold Th at the decision diamond 28, then the algorithm determines whether the number of tokens Tk in the bucket is greater than a predetermined upper threshold Uth which is the number of tokens that will establish trust in the kth vehicle, at decision diamond 32. If the number of tokens in the bucket is greater than the upper threshold Uth at the decision diamond 32, then the algorithm sets the number of questions to be asked to N=βNQ at box 34. Because the number of tokens Tk is above the upper threshold Uth, the vehicle trusts the kth vehicle, and sets the number of questions asked to a fraction β of the number of questions NQ, which is low.
If the number of tokens Tk in the bucket is not greater than the upper threshold Uth at the decision diamond 32, then the algorithm determines whether the number of tokens Tk in the bucket is less than a lower threshold Lth at decision diamond 36. If the number of tokens Tk in the bucket is less than the lower threshold Lth at the decision diamond 36, then the algorithm sets the number of questions to be asked to N=αNQ at box 38. Because the number of tokens Tk in the bucket is below the lower threshold Lth, the trust for the kth vehicle is low, which is either because the vehicle hasn't seen that kth vehicle very frequently or because the kth vehicle may have given too many wrong answers in the past. In either case, the probability that the kth vehicle is reliable is low so the number of questions is set to the fraction N=αNQ. If the number of tokens Tk in the bucket is not less than the lower threshold Lth at the decision diamond 36, then the algorithm sets the number of questions to be asked to N=NQ at box 40.
If the number of tokens Tk is between the two thresholds Uth and Lth, the algorithm will make a quicker decision as to whether to place confidence in messages from the kth vehicle, so the algorithm will ask more questions in the challenge response phase, where that number of questions is set to NQ.
From the boxes 26, 30, 34, 38 and 40, the algorithm then proceeds to ask whether the number of questions N is equal to 0 at decision diamond 42. If the number of questions N is not equal to 0 at the decision diamond 40, then the interrogating vehicle will issue a challenge or question at box 44. The algorithm will then determine whether the response to the challenge is correct or not at decision diamond 46. If the response is correct at the decision diamond 46, then the algorithm increases the number of tokens in the bucket for that vehicle at box 48. Likewise, if the response to the challenge is wrong at the decision diamond 46, the number of wrong answers Dk for the kth vehicle is increased and the number of tokens Tk in the bucket is set to a fraction of the number of tokens Tk by γ at box 50. The algorithm then reduces the number of questions asked at box 52.
If the number of questions N to be asked equals 0 at the decision diamond 42, then the algorithm determines whether the number of tokens Tk in the token bucket for the kth vehicle is less than the lower threshold Lth at decision diamond 54. If the number of tokens Tk is less than the lower threshold Lth at the decision diamond 54, then the vehicle discards the message received from the kth vehicle at box 56 because the kth vehicle has been determined to be unreliable. If the number of tokens Tk is not less than the lower threshold Lth at the decision diamond 54, then the algorithm determines whether the number of tokens Tk is greater than the upper threshold Uth at decision diamond 58, and if so accepts the message received from the kth vehicle at box 60. If the number of tokens Tk is less than the upper threshold Uth at the decision diamond 58, and thus, between the upper threshold Uth and the lower threshold Lth, the algorithm accepts the message from the kth vehicle with a certain probability at box 62. In one embodiment, the probability is defined as:
The foregoing discussion discloses and describes merely exemplary embodiments of the present invention. One skilled in the art will readily recognize from such discussion and from the accompanying drawings and claims that various changes, modifications and variations can be made therein without departing from the spirit and scope of the invention as defined in the following claims.