In the accompanying drawings:
a–d illustrates an example of the estimation of target position, lateral velocity, and road curvature parameters for a straight roadway;
a–b illustrate an example of the target state RMS errors from unconstrained and constrained filtering on the straight roadway, corresponding to
a–d illustrate an example of the estimation of target position, lateral velocity, and road curvature parameters for a curved roadway;
a–b illustrate an example of the target state RMS errors from unconstrained and constrained filtering for the curved roadway, corresponding to
a–d illustrate an example of the estimation of target position, lateral velocity, and associated RMS errors for a straight roadway involving a lane change; and
a–d illustrates an example of the estimation of target position, lateral velocity, and their RMS errors for a curved roadway involving a lane change.
Referring to
Referring to
Referring to
Referring also to
A well-designed and constructed roadway 34 can be described by a set of parameters, including curvature, wherein the curvature of a segment of the roadway 34 is defined as:
where R is the radius of the segment. In general, for a piece of smooth roadway 34, the curvature variation can be described as a function of a distance l along the roadway 34 by a so-called clothoid model, i.e.:
where C1=1/A2 and A is referred to as the clothoid parameter.
Referring to
Substituting equation (2) into equation (3) gives
Δθ=θ−θ0=C0l+C1l2/2 (4)
Referring to
Assuming the heading angle θ to be within 15 degrees, i.e. |θ|<15°, equations (5) and (6) can be approximated by:
Δx=x−x
0
≈l (7)
Accordingly, the roadway 34 is modeled by an incremental road equation in terms of curvature coefficients: C0 and C1. This incremental road equation describes a broad range of road shapes as follows: 1) Straight roadway 34: C0=O and C1=0; 2) circular roadway 34: C1=0; and 3) a general roadway 34 with an arbitrary shape for which the change in heading angle θ is less than 15 degrees: C0>0.
The road curvature parameters C0 and C1 are estimated using data from motion sensors (yaw rate sensor 16 and speed sensor 18) in the host vehicle 12, based upon the assumption that the host vehicle 12 moves along the center line 41 of the roadway 34 or associated host lane 38.
The road curvature parameters C0 and C1 can be calculated from data of ω, {dot over (ω)}, U, {dot over (U)}{dot over ( )}responsive to measurements of yaw rate ωh and speed Uh of the host vehicle 12 from the available host vehicle 12 motion sensors. However, generally the measurements of yaw rate ωh and speed Uh, from the yaw rate sensor 16 and speed sensor 18 respectively, are noisy. A host state filter implemented by a first Kalman filter 52 is beneficial to generate estimates of ω, {dot over (ω)}, U, {dot over (U)} from the associated noisy measurements of yaw rate ωh and speed Uh; after which a curvature filter implemented by a second Kalman filter 54 is used to generate smoothed estimates of the curvature parameters C0 and C1. The dynamics of the host vehicle 12 for the host state filter follows a predefined set of kinematic equations (constant velocity in this case) given by:
xk+14=Fkh·xkh+wkh,wkh˜N(0,Qkh) (9)
zkh=Hkh·xkh+vkh, vkh˜N(0,Rkh) (10)
where
and where T is the sampling period, superscript (.)h is used to indicate that the filter is the host filter, and Uh and ωh are host vehicle 12 speed and yaw rate measurements. The first Kalman filter 52 is implemented to estimate the host state {circumflex over (x)}k|kh and its error covariance Pk|kh, as illustrated in
The estimate of the host state from the first Kalman filter 52, i.e. the host state filter, is then used to generate a synthetic measurement that is input to the second Kalman filter 54, i.e. curvature coefficient filter, wherein the associated Kalman filters 52, 54 operate in accordance with the Kalman filtering process described more fully in the Appendix hereinbelow. The relationship between the road curvature parameters C0, C1 and the host state variables ω, {dot over (ω)}, U, {dot over (U)} is derived as follows:
From equation (4), the radius R of road curvature is expressed generally as a function R(l) of the distance l along the roadway, as is illustrated in
{dot over (θ)}=C0{dot over (l)}+C1·l·{dot over (l)}=(C0+C1·l)·l. (12)
Noting that θ=ω, the yaw rate of the host vehicle 12, and that {dot over (l)}=U, the speed of the host vehicle 12, and substituting the clothoid model of equation (2) in equation (12), yields:
ω=C·U (13)
or
Clothoid parameter C0 is given as the value of curvature C at l=0, or
Taking the derivative on both sides of equation (14) yields
Using the definition of C1, from equation (2), C1 may be expressed in terms of the host state as follows:
The system equations for the second Kalman filter 54, i.e. the curvature filter, that generates curvature estimates Ĉ0
where
Δt is the update time period of the second Kalman filter 54, and the values of the elements of the measurement vector zkC are given by the corresponding values of the state variables—i.e. the clothoid parameters C0 and C1—of the curvature filter.
The measurement, zkC, is transformed from the estimated state [Û, {dot over (û)}, {circumflex over (ω)}, {dot over ({circumflex over (ω)}]kT as follows:
and the associated covariance of the measurements is given by:
RkC=JkCPk|kh(JkC)T (21)
where
It should be understood that other systems and methods for estimating the curvature parameters of the roadway 34 may be substituted in the road curvature estimation subsystem 42 for that described above. For example, the curvature parameters of the roadway may also be estimated from images of the roadway 34 by a vision system, either instead of or in conjunction with the above described system based upon measurements of speed Uh and yaw rate ωh from associated motion sensors. Furthermore, it should be understood that yaw rate can be either measured or determined in a variety of ways, or using a variety of means, for example, but not limited to, using a yaw gyro sensor, a steering angle sensor, a differential wheel speed sensor, or a GPS-based sensor; a combination thereof; or functions of measurements therefrom (e.g. a function of, inter alia, steering angle rate).
Referring again to
The result from the coordinate transformation in step (512) of the output from the extended Kalman filter 56 is then partitioned into the following parts, corresponding respectively to the x and y position of the target vehicle 36 relative to the host vehicle 12, wherein the superscript 1 refers to the unconstrained target state of the target vehicle 36:
Referring again to
Prior to discussing the process of steps (514) through (524) for determining whether the target is likely constrained by a constraint, and if so, what is the most likely constraint, the process of fusing the unconstrained target state with state of a constraint will first be described for the case of a target vehicle 36 moving in the same lane as the host vehicle 12. The constraints are assumed to be active in y-direction only, consistent with the assumptions that the host vehicle 12 moves along the center line 41 of its lane 38 steadily without in-lane wandering and that the road curvatures of all the parallel lanes 38, 40 are the same, and given that the absolute coordinate system is fixed on the host vehicle 12 at the current instant of time. Assuming the target vehicle 36 is moving in the same lane 38 as the host vehicle 12, and using the road constraint equation with the estimated coefficients, in step (514), the constraint state variables are then given in terms of the lateral kinematic variable as:
and
{overscore (P)}yt
where
In step (528), the two y-coordinate estimates, one from the main filter and the other from the road constraint, are then fused as follows:
Pyt
ŷt
Finally, the composed estimate of the target state is
where
{overscore (P)}xy
In step (530), this composed estimate would then be output as the estimate of the target state if the target vehicle 36 were to be determined from steps (514) through (524) to be traveling in the host lane 38.
Returning to the process of steps (514) through (524) for determining whether the target is likely constrained by a constraint, and if so, what is the most likely constraint; according to the assumption that targets follow the same roadway 34, if the target vehicle 36 were known to travel in a particular lane, it would desirable to use estimated road parameters for that lane as a constraint in the main filter of estimating target kinematics. However, the knowledge of which lane the target vehicle 36 is current in is generally not available, especially when the target is moving on a curved roadway 34. Since the road equation (8) is only for the host lane 38 in the host-centered coordinate system, constrained filtering would require knowing which lane the target is in, and different constraint equations would be needed for different lanes. Ignoring the difference of road curvature parameters among these parallel lanes, i.e. assuming the curvature of each lane to be the same, the road equation for an arbitrary lane can be written as:
where B is the width of the lanes and m represents the lane to be described (m=0 corresponds the host lane 38, m=1 corresponds the right neighboring lane 40, m=−1 corresponds the left neighboring lane 40, and so on). Without the prior knowledge of the target lane position, each of the multiple constraints forming a multiple constraint system (analogous to the so-called multiple model system) is tested to determine identify which, if any, of the constraints are active. A multiple constraint (MC) system is subjected to one of a finite number NC of constraints. Only one constraint can be in effect at any given time. Such systems are referred to as hybrid—they have both continuous (noise) state variables as well as discrete number of constraints.
The following definitions and modeling assumptions are made to facilitate the solution of this problem:
Constraint equations:
yt
Constraint: among the possible NC constraints
Constraint jump process: is a Markov chain with known transition probabilities
P{ft
To implement the Markov model—for systems with more than one possible constraint state—it is assumed that at each scan time there is a probability pij that the target will make the transition from constraint state i to state j. These probabilities are assumed to be known a priori and can be expressed in the probability transition matrix as shown below.
The prior probability that f j is correct (f j is in effect) is
P(fj|Z0)=μt
where Z0 is the prior information and
since the correct constraint is among the assumed NC possible constraints.
The constrained target state estimation subsystem 46 provides for determining whether the target state corresponds to a possible constrained state, and if so, then provides for determining the most likely constrained state.
One way of determining this is the multiple model filtering algorithm proposed by Bar-Shalom, wherein NC parallel filters are run simultaneously in parallel.
In another way, a multiple constraint (MC) estimation algorithm mixes and updates NC constraint-conditioned state estimates using the unconstrained state estimate ŷt
1. Estimation of state variables from multiple constraints: In step (514), using the multiple lane road equation (33) to replace the first row in equation (24), the multiple constraint state estimates are given by:
where Bj=0, ±B, . . . ,
and B is the width of a lane. Stated in another way, the constraint state estimates correspond to the y locations of the centerlines of each possible lane in which the target vehicle 36 could be located.
The associated covariance is given by:
Pyt
where Ak1 and Ak2 are given by equation (26) and equation (27), Pxt
2. Constraint-conditioned updating: In step (516), the state estimates and covariance conditioned on a constraint being in effect are updated, as well as the constraint likelihood function, for each of the constraints j=1, . . . NC. The updated state estimate and covariances corresponding to constraint j are obtained using measurement ŷt
3. Likelihood calculation: In step (518), the likelihood function corresponding to constraint j is evaluated at the value yt
wherein the Gaussian distribution N(;,) has a mean value of
and an associated covariance of {overscore (P)}yt
4. Constraint Probability Evaluations: In step (520), the updated constraint probabilities are calculated for each of the constraints j=1, . . . NC, as follows:
where {overscore (α)}j, the probability after transition that constraint j is in effect, is given by
and the normalizing constant is
5. Overall state estimate and covariance: In step (522), the combination of the latest constraint-conditioned state estimates and covariances is given by:
The output of the estimator from step (522) in the above algorithm is then used as the constrained estimates in the fusion process described by equations (28) and (29), and the result of equation (51), instead of the result of equation (32), is used in equation (31).
When the target vehicle 36 is not following the roadway 34 or is changing lanes, imposing the road constraint on target kinematic state variables will result in incorrect estimates that would be worse than using the associated unconstrained estimates. However, noise related estimation errors might cause a correct road constraint to appear invalid. Accordingly, it is beneficial to incorporate a means that can keep the constraints in effect when they are valid, e.g. when the target vehicle 36 follows a particular lane; and lift them off promptly when they are invalid, e.g. when the target vehicle 36 departs from its lane.
The unconstrained target state estimate plays a useful role in road constraint validation, since it provides independent target state estimates.
One approach is to test the hypothesis that the unconstrained target state estimate satisfies the road constraint equation, or equivalently, that the constrained estimate and the unconstrained estimate each correspond to the same target. The optimal test would require using all available target state estimates in history through time tk and is generally not practical. A practical approach is the sequential hypothesis testing in which the test is carried out based on the most recent state estimates only. In accordance with the notation used hereinabove, the difference between the constrained and unconstrained target state estimates (y direction only) is denoted:
as the estimate of
δt
where yt1 is the true target state and {overscore (y)}t
H0: δt
vs.
H1: δt
The main filter error
{tilde over (y)}t
is assumed independent of the error
which is from the constraints. The covariance of the difference {circumflex over (δ)}t
Pt
Assuming that the estimation errors are Gaussian, the test of H0 vs. H1 is as follows:
Accept H0 if
ρt
The threshold is chosen such that
P(ρt
where a is a predefined error tolerance value. Note that based on the above Gaussian error assumption, ρt
Based on the above analysis, the hypothesis testing scheme efficiently uses different threshold values for targets in different lanes, with the multiple constraint filtering algorithm providing the knowledge of which lane the target is most likely in currently. Assuming that there are NC possible lanes on the roadway 34, and each lane is described by a constraint equation, the constraint equation with the highest probability μt
μt
The difference between the unconstrained state estimates and lane lt constrained state estimates (y direction only), denoted as:
is the estimate of
δt
where yt
H0: δt
vs.
H1: δt
The constrained estimation error is given by:
Assuming that the estimation errors are independent and Gaussian, the test of H0 vs. H1 becomes:
Accept H0 if
ρt
where
and the threshold is such that
P(ρt
where
γl
Such a lane adaptive hypothesis testing scheme provides for a prompt switch of the target state estimation output to the unconstrained estimate when the target vehicle 36 leaves its current lane, while the estimation accuracy of a target in host lane 38 is substantially improved by constrained filtering.
In another embodiment of the multiple constraint (MC) estimation algorithm, the constrained state estimate used for the hypothesis testing is the most likely of the separate constrained target state estimates (i.e. in accordance with a “winner take all” strategy), rather than a composite combination of all of the constrained target state estimates. If this most likely constrained state estimate is valid, i.e. if the most likely constrained state estimate corresponds to the unconstrained state estimate, then the target state is given by fusing the most likely constrained state estimate and the unconstrained state estimate; otherwise the target state is given by the unconstrained state estimate.
In yet another embodiment of the multiple constraint (MC) estimation algorithm, hypothesis tests are made for each of the constrained state estimates. If none of the hypotheses are satisfied, then the target state is given by the unconstrained state estimate. If one of the hypotheses is satisfied, then the target state is given by fusing the corresponding constrained state estimate and the unconstrained state estimate. If more than one hypotheses are satisfied, then the most likely constrained state may be identified by voting results from a plurality of approaches, or by repeating the hypothesis tests with different associated thresholds.
Generally, the number of constraints (i.e. the number of roadway lanes) can vary with respect to time, as can associated parameters therewith, for example, the width of the lanes of the roadway, so as to accommodate changes in the environment of the host vehicle 12. For example, the host vehicle 12 in one trip could travel on a one-lane road, a two-lane road with opposing traffic, a three-lane road with a center turn lane, a four line road two lanes of opposing traffic, or on a multi-lane divided freeway.
Road vehicle tracking simulations using constrained and unconstrained filtering were carried out for four scenarios. In all scenarios, the host vehicle 12 was moving at 15.5 m/s and a target vehicle 36 is approaching on the same roadway 34 at a speed of 15.5 m/s. The initial position of the target was 125 meters away from the host in the x direction, and the lane width for all lanes was assumed to be 3.6 meters. The measurement variance of the vehicle speed sensor was 0.02 m/s and the variance of the gyroscope yaw rate measurement was 0.0063 rad/s. The variances of radar range, range rate and azimuth angle measurements were 0.5 m, 1 m/s, and 1.5° respectively. Simulation results were then generated from 100 Monte-Carlo runs of the associated tracking filters.
In the first scenario, the host vehicle 12 and the target vehicle 36 were moving on a straight roadway 34 (C0=0 and C1=0) and the target vehicle 36 was moving toward the host vehicle 12 in the same lane.
In the second scenario, the host vehicle 12 and the target vehicle 36 were moving on a curved roadway 34 (C0=–10−5 and C1=−3×10−5) and the target vehicle 36 was moving toward the host vehicle 12 in the same lane.
In the third scenario, the host vehicle 12 and the target vehicle 36 were moving on a straight roadway 34 (C0=0 and C1=0) and the target vehicle 36 was initially approaching in the left neighboring lane. At t=2.2 second (55 radar scans), the target vehicle 36 began to diverge from its lane and turns toward the host lane 38, which resulted in a collision at t=4 seconds (100 radar scans).
The fourth scenario was similar to the third scenario, the only difference being that the vehicles were on a curved roadway 34 (C0=−10−5 and C1=−3×10−5) instead of a straight one. The target vehicle 36 began to diverge at t=2.2 s and results in a collision at t=4 s.
Accordingly, simulation results of road vehicle tracking on both straight and curved roadways 34 show that the predictive collision sensing system 10 could substantially reduce the estimation errors in target vehicle 36 lateral kinematics when the target vehicles 36 were in the host lane 38. When a target vehicle 36 maneuvers from a neighboring lane into the host lane 38, the predictive collision sensing system 10 promptly detects this maneuver and lifts off the road constraint to avoid an otherwise incorrect constrained result. In view of the fact that poor radar angular resolution often results in poor lateral kinematics estimation, the predictive collision sensing system 10 has provided for a substantial improvement in estimation accuracy of target vehicle 36 lateral kinematics, which is beneficial for an early and reliable road vehicle collision prediction. While specific embodiments have been described in detail in the foregoing detailed description and illustrated in the accompanying drawings, those with ordinary skill in the art will appreciate that various modifications and alternatives to those details could be developed in light of the overall teachings of the disclosure. Accordingly, the particular arrangements disclosed are meant to be illustrative only and not limiting as to the scope of the invention, which is to be given the full breadth of the appended claims and any and all equivalents thereof.
A Kalman filter is used to estimate, from a set of noisy measurements, the state and associated measurements of a dynamic system subject to noise.
The system dynamics are defined by:
xk+1=Fk·xk+wk˜N(0, Qk) (A-1)
where xk is the system state vector, Fk is the system matrix and wk an associated vector of noise variables corresponding to each state variable, each noise variable having a mean value of zero, and a variance given by the corresponding element of the associated variance vector, Qk.
The dynamics of the associated system measurements are given by:
zk=Hk·xk+vk, vk˜N(0, Rk) (A-2)
where zk is the system measurement vector, Hk is the measurement matrix and vk an associated vector of noise variables corresponding to each measurement variable, each noise variable having a mean value of zero, and a variance given by the corresponding element of the associated variance vector, Rk. The values of the elements of the associated covariance matrix Rk can be determined a priori from analysis of the representative measurements of the associated system for associated representative sets of operating conditions. The values of the elements of the associated covariance matrix Qk account for modeling errors. Generally, the associated matrices Fk, Qk, Hk, Rk can vary over time.
Given a measurement zk at time k, and initial values of the state xk−1|k−1 and associated covariance Pk−1|k−1 at time k-1, the Kalman filter is used to to estimate the associated state xk|k and associated covariance Pk|k at time k.
The first step in the filtering process is to calculate estimates of the state xk|k−1 and associated covariance Pk−l|k−l at time k based upon estimates at time k−1, as follows:
xk|k−1=Fk·xk−1|k−1 (A-3)
Pk|k−1=Fk·Pk−1|k−l·FkT+Qk (A-4)
The next step is to predict the measurement {circumflex over (z)}k and associated covariance matrix Sk at time k, as follows:
{circumflex over (z)}k=Hk·xk|k−1 (A-5)
Sk=cov({circumflex over (z)}k)=Hk·Pk|k−1·HkT+Rk (A-6)
The next step is to calculate a gain matrix Gk used for updating the state vector xk|k and associated covariance matrix Pk|k, as follows:
Gk=Pk|k−1·HkT·Sk−1 (A-7)
Finally, the state vector xk|k and associated covariance matrix Pk|k are estimated at time k, responsive to the associated measurement zk, as follows:
xk|k=xk|k−1+Gk·(zk{circumflex over (z)}k) (A-8)
Pk|k=Pk|k−1−Gk·Sk·GkT (A-9)
The instant application claims the benefit of prior U.S. Provisional Application Ser. No. 60/396,211 filed on Jul. 15, 2002, which is incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
2709804 | Chance et al. | May 1955 | A |
3177485 | Taylor, Jr. | Apr 1965 | A |
3603994 | Williams et al. | Sep 1971 | A |
3699573 | Andrews et al. | Oct 1972 | A |
3725918 | Fleischer et al. | Apr 1973 | A |
3869601 | Metcalf | Mar 1975 | A |
3971018 | Isbister et al. | Jul 1976 | A |
4623966 | O'Sullivan | Nov 1986 | A |
5051751 | Gray | Sep 1991 | A |
5138321 | Hammer | Aug 1992 | A |
5170440 | Cox | Dec 1992 | A |
5202691 | Hicks | Apr 1993 | A |
5307289 | Harris | Apr 1994 | A |
5314037 | Shaw et al. | May 1994 | A |
5343206 | Ansaldi et al. | Aug 1994 | A |
5402129 | Gellner et al. | Mar 1995 | A |
5406289 | Barker et al. | Apr 1995 | A |
5471214 | Faibish et al. | Nov 1995 | A |
5530651 | Uemura et al. | Jun 1996 | A |
5537119 | Poore, Jr. | Jul 1996 | A |
5587929 | League et al. | Dec 1996 | A |
5594414 | Namngani | Jan 1997 | A |
5598164 | Reppas et al. | Jan 1997 | A |
5627768 | Uhlmann et al. | May 1997 | A |
5631639 | Hibino et al. | May 1997 | A |
5633642 | Hoss et al. | May 1997 | A |
5657251 | Fiala | Aug 1997 | A |
5668739 | League et al. | Sep 1997 | A |
5684473 | Hibino et al. | Nov 1997 | A |
5689264 | Ishikawa et al. | Nov 1997 | A |
5703593 | Campbell et al. | Dec 1997 | A |
5710565 | Shirai et al. | Jan 1998 | A |
5751211 | Shirai et al. | May 1998 | A |
5926126 | Engelman | Jul 1999 | A |
5948043 | Mathis | Sep 1999 | A |
5955967 | Yamada | Sep 1999 | A |
5959552 | Cho | Sep 1999 | A |
5959574 | Poore, Jr. | Sep 1999 | A |
5983161 | Lemelson et al. | Nov 1999 | A |
6070121 | Matsuda | May 2000 | A |
6085151 | Farmer et al. | Jul 2000 | A |
6134509 | Furusho et al. | Oct 2000 | A |
6161071 | Shuman et al. | Dec 2000 | A |
6198426 | Tamatsu et al. | Mar 2001 | B1 |
6226389 | Lemelson et al. | May 2001 | B1 |
6265991 | Nishiwaki et al. | Jul 2001 | B1 |
6275231 | Obradovich | Aug 2001 | B1 |
6275773 | Lemelson et al. | Aug 2001 | B1 |
6282478 | Akita | Aug 2001 | B1 |
6292752 | Franke et al. | Sep 2001 | B1 |
6300865 | Fechner et al. | Oct 2001 | B1 |
6343253 | Matsuura et al. | Jan 2002 | B1 |
6370475 | Breed et al. | Apr 2002 | B1 |
6393376 | Andreas | May 2002 | B1 |
6405132 | Breed et al. | Jun 2002 | B1 |
6420997 | Cong | Jul 2002 | B1 |
6470272 | Cong et al. | Oct 2002 | B2 |
6643588 | Ibrahim | Nov 2003 | B1 |
6675094 | Russell et al. | Jan 2004 | B2 |
20020022927 | Lemelson et al. | Feb 2002 | A1 |
20020044080 | Shirai et al. | Apr 2002 | A1 |
20020049539 | Russell et al. | Apr 2002 | A1 |
20030218563 | Miyahara | Nov 2003 | A1 |
Number | Date | Country | |
---|---|---|---|
20050179580 A1 | Aug 2005 | US |
Number | Date | Country | |
---|---|---|---|
60396211 | Jul 2002 | US |