The present invention relates in general to traffic sensors, and more particularly relates to the calibration of traffic sensors based on a range or distance of vehicles measured from the traffic sensor.
As urban centers increase in size, and traffic congestion becomes increasingly a problem, there is a concomitant increasing need for current and accurate traffic statistics and information. Traffic surveillance relies primarily upon traffic sensors, such as (1) inductive loop traffic sensors, which are installed under the pavement; (2) video sensors; (3) acoustic sensors; and, (4) radar sensors. Inductive loop sensors, which are installed under the pavement, are expensive to install, replace and repair, both in terms of roadwork required and in terms of the disruption to traffic. In contrast, video sensors, acoustic sensors and radar sensors are easier to install, replace and repair. They have the added advantage of multi-lane detection by a single sensor. On the other hand, their accuracy depends on centering their detection zones on traffic lanes.
Video sensors typically detect vehicles based on recognizable automobile characteristics. Acoustic sensors rely on sound waves to build up a picture of traffic conditions. Radar sensors typically transmit low-power microwave signals at the traffic, and detect vehicles based on the reflected signals. However, all of these sensors require initial detection zones or lanes to be defined in order to operate accurately.
This calibration of detection zones or lanes in sensors may be provided by a technician. However, this is expensive both in terms of paying the technician, and due to the resulting disruption of traffic. Alternatively, detection zones may be defined automatically and automatically centered on traffic lanes.
In accordance with an aspect of the invention there is provided a method of operating a traffic sensor to define ranges of centers of traffic lanes from the traffic sensor. The method comprises a) providing a set of lane center variables representing the ranges of the centers of the traffic lanes from the traffic sensor; b) initializing each lane center variable in the set of lane center variables to have an associated starting range value; and then, c) updating the set of lane center variables, for each vehicle in a plurality of vehicles, by i) detecting the vehicle, ii) determining an associated lane center variable having an associated lane center range value closest to the vehicle; iii) estimating a vehicle displacement from the associated lane center range value, and iv) calculating a new lane center range value for the associated lane centre variable using the associated lane center range value and the vehicle displacement.
A sensor for obtaining vehicular traffic data, the sensor comprising: at least one antenna for transmitting radiation to a vehicle and for receiving the radiation reflected back from the vehicle; a transceiver circuit for electrically driving the antenna; a processor unit for driving and processing electrical signals from the transceiver circuit to obtain vehicular traffic data. The processor unit is operable to define ranges of centers of traffic lanes by performing the steps of a) providing a set of lane center variables representing the ranges of the centers of the traffic lanes from the traffic sensor; b) initializing each lane center variable in the set of lane center variables to have an associated starting range value; and then, c) updating the set of lane center variables by, for each vehicle in a plurality of vehicles, i) detecting the vehicle, ii) determining an associated lane center variable having an associated lane center range value closest to the vehicle, iii) estimating a vehicle displacement from the associated lane center range value, and iv) calculating a new lane center range value for the associated lane centre variable using the associated lane center range value and the vehicle displacement.
A detailed description of preferred aspects of the invention is provided herein below with reference to the following drawings in which:
a, in a flowchart, illustrates coarse tuning steps of the method of
b, in a flowchart, illustrates a coarse tuning loop executed contemporaneously with the method of
a, in a flowchart, illustrates fine-tuning steps of the method of
b, in a flowchart, illustrates a fine-tuning loop executed contemporaneously with the method of
Referring to
Referring to
In addition to the detection of vehicles described above, the sensor 100 automatically detects traffic activity and sets zones to be centered on the ranges of this activity. This enables the sensor 100 to detect and correct for deviation from previously defined zone centers and current traffic. This deviation may, for example, result from temperature drift.
The reflected signals Pr are generated in real-time such as, for example without limitation, every 1 mS. As described above, each reflected signal Pr has power level <P> and range <r>. Specifically, the elliptical footprint projected onto the road 104 by signal 106 is divided up into uslice ranges <r> each of which uslices is at a different distance from the sensor. The thickness of these uslices is selected such that several uslices are required to span the width of a single lane. For example without limitation, each uslice range can be about 40 cm thick, although this may change depending on the resolution of the sensor 100.
To first detect the vehicles and then determine lane centers, the processor module 118 maintains the following data structures:
Zi is the range (in uslices) of tentative zone number i
ΣΔi is the sum of errors of zone Zi
Ai is the sum of activities of zone Zi
Ti is a time-out counter, which is incremented by one every 1 mS.
Fi is a Boolean flag indicating, when Fi=1, that zone Zi is on an active lane.
In the above data structure, i represents the particular zone center of a data structure. For example, without limitation, i may be any integer in the range of 1 to 16 inclusive, 16 being the maximum number of zone centers. Alternatively, some other maximum number of zone centers may be used.
Ai represents the sum of activities, which is defined for a particular vehicle, instead of being defined for a plurality of vehicles. That is, Ai is incremented for every reflected signal Pr received during a vehicle's passage through the footprint provided that the reflected signal Pr is received within the range r=Zi preceding, for example without limitation, a 100 mS gap interval during which no reflected signal Pr is received from that lane. A time-out counter Ti is also provided. The 100 mS interval is measured by time-out counter Ti, which is incremented by 1 every 1 mS. Of course, time-out intervals other than 100 mS may be used.
Initially, no uslices are designated as preliminary zones centers: thus, Zi=0; Fi=0; ΣΔi=0; and, Ai=0 for i=1 to 16. For a suitable time interval, such as 1 minute or so, data is collected in the 32 counters associated with zone centers that are dynamically defined. That is, for every reflected signal sample Pr, the processor module 118 checks whether there is a previously defined zone center Zi where ABS(Zi−r)<some selected maximum distance, such as, for example without limitation, 7 uslices. If there is no previously defined zone center that satisfies this inequality, than a new tentative zone center is defined as Zi=r. The corresponding activity counter Ai for this zone center Zi is then set; Ai=1. Similarly its timer Ti is set; Ti=0.
On the other hand, if there is at least one previously defined zone center Zi that is sufficiently close to the uslice range r such that the ABS(Zi−r)<7, then this nearest zone center Zn is associated with Pr.
In cases where a previously defined zone center is associated with Pr, then the range deviation, r−Zn, for this signal is added to the sum of errors for that zone center, and An and Tn adjusted, as follows:
ΣΔn=ΣΔn+(r−Zn);An=An+1; Tn=0
By this means, Ai counts the number of valid signals associated with zone centers Zi, while ΣΔi (represented as ΣΔn in the above equation) represents the sum of the signed errors (deviations of the signal uslice from Zi). Ti, which is the time counter, will typically have low counts during a burst arising from a passing vehicle, as Ti will be reset to zero each time a reflected signal Pr is received close to Zi. The Ti counter for each zone center Zi is checked against a fixed time-out KT=100 periodically; preferably, every one millisecond. For example without limitation, KT may be set equal to 100. If Ti>KT, indicating that there has been no activity in Zi for KT milliseconds, then, if Ai<some selected minimum activity level KA, Ai, ΣΔi and Ti are all set equal to zero. For example without limitation, KA can equal 100. In other words, if there has not been enough activity near to a zone center before there is a gap of KT (in this case 100 mS) in which no further reflected signals are received, then whatever reflected signals Pr have been received are assumed to not have resulted from vehicles, but from some other temporary obstruction that reflected the signal 106. On the other hand, if, when Ti is greater than KT, Ai is greater than KA, than a vehicle is assumed to have passed, and Zi is corrected or updated according to the formula Zi=Zi+(ΣΔi/Ai). In other words, the average error in the ΣΔ i is used to shift the zone centers to where activity is centered. Subsequently, the Boolean counter Fi is set equal to 1, Ai is set equal to zero, ΣΔi is set equal to zero and Ti is set equal to zero. At the end of the collection period, only those zones that have been center-corrected based on a significant burst of activity (at least one vehicle), in which there have been no long time-out gaps—long, in this case, being time-out gaps greater than 100 mS—will have a positive Fi indicating that they are on active traffic lanes.
Referring to
Referring to
If there is no Zi such that ABS(Zi−r)<7, then query 404 returns the answer NO, and method 400a proceeds to step 406, in which one of the unused zone centers, Zn, is set equal to r. The method then proceeds to step 408. If query 404 returns the answer YES, in that there is a zone center Zn within 2.8 m of r, then method 400a proceeds directly to step 408 from query 404.
In step 408, the data counters for Zn are updated. That is, in the case where a new Zn was set equal to r in step 406, and the method 400a then proceeded to step 408, the An for this new Zn is set equal to 1 and its time-out counter Tn is set equal to zero. Alternatively, if the method 400a proceeded directly to step 408 from query 404, An is increased by 1, and Tn is again set equal to zero. Specifically, the An for this Zn is incremented by one, and Tn is set equal to zero. In addition, ΣΔi is adjusted by adding (r−Zn).
After step 408, the method 400a proceeds to query 418, which checks whether all of the reflected signals for the first minute have been processed. If the reflected signals in this first minute have not yet been processed, then the method proceeds to step 420 in which the next reflected signal Pr is processed, before returning to query 404. If, on the other hand, query 418 returns the answer YES, as all of the reflected signals received in the first minute have been processed, then in step 422, method 400a selects those zone centers Zi for which the Boolean counter Fi is positive (described in connection with step 416 of
While method 400a is executing as described above in connection with
If there has been sufficient activity, in that the sum of activities Ai is not less than 100, then method 400b proceeds to step 416 from query 412. In step 416, zone center Zi is updated by adding the average deviation error, according to the formula Zi=Zi+(ΣΔi/Ai). The Boolean counter Fi is also set equal to 1. Finally, as is the case in step 414, Ai, ΣΔi, and Ti are all set equal to zero.
Referring to
If, on the other hand, query 504 returns the answer YES, in that there is a zone center within 2.8 m of r, then the method 500a proceeds to step 508.
In step 508, the data counters for the Zn satisfying the selection criteria of query 504 are updated. Specifically, the An for this Zn is incremented by one, and Tn is set equal to zero. In addition, ΣΔi is adjusted by adding (r−Zn). After step 508, method 500a proceeds to step 506.
While method 500a is executing, a fine-tuning loop or method 500b, as illustrated in
If there has been sufficient activity, in that the sum of activities Ai is not less than 100, then the method 500b proceeds to step 516 from query 512. In step 516, zone center Zi is updated by adding 10% of the average deflection error, according to the formula Zi,=Zi+0.1×(ΣΔi/Ai). In addition, Ai, ΣΔi and Ti are all set equal to zero.
Other variations and modifications of the invention are possible. For example, during fine-tuning, instead of the zone center Zi being updated by adding 10% of the average deflection error, this zone center Zi could be updated by adding a different percentage of this deflection error. Whatever percentage is selected should, of course, be less than the percentage of the average deviation error used to update the zone center Zi during coarse tuning. For example, the selected percentage of the average deflection error used to update the zone center Zi might be greater than 50% in the case of coarse tuning, and less than 50% in the case of fine-tuning. More preferably, this selected percentage might be greater than 75% in the case of coarse tuning and less than 25% in the case of fine-tuning. Optionally, between the coarse and fine-tuning phases, zones may also be displayed to a technician to let him edit the preliminary zone settings—for example, delete a zone due to an accidental passage of one vehicle. All such modifications or variations are believed to be within the sphere and scope of the invention as defined by the claims appended hereto.