A portion of the disclosure of this patent document contains material which is subject to copyright protection. The copyright owner has no objection to the facsimile reproduction by anyone of the patent document or the patent disclosure, as it appears in the United States Patent and Trademark Office patent file or records, but otherwise reserves all copyright rights whatsoever.
One or more implementations relate generally to sensor calibration.
Accurate and robust automated steering applications rely on accurate sensor positioning and installation. Measured vehicle position and heading is based on knowledge of the relative alignment and offset distance of the vehicle sensors from a vehicle control point. If the relative sensor distances from the control point are incorrectly measured, vehicle positions and headings based on those relative sensor distances are also incorrect.
Sensor installation parameters, such as distances and angles relative to the vehicle control point, are currently measured by the vehicle operator. Subject to the amount of care and expertise of the vehicle operator, manually measured installation parameters may include parallax errors and other types of errors that result in poor steering performance and possible vehicle instability.
The included drawings are for illustrative purposes and serve to provide examples of possible structures and operations for the disclosed inventive systems, apparatus, methods and computer-readable storage media. These drawings in no way limit any changes in form and detail that may be made by one skilled in the art without departing from the spirit and scope of the disclosed implementations.
A calibration scheme measures roll, pitch, and yaw rates and other speed and accelerations during a series of vehicle maneuvers. Based on the measurements, the calibration scheme calculates inertial sensor misalignments. The calibration scheme also calculates offsets of inertial sensors and GPS antennas from a vehicle control point. The calibration scheme can also estimate other calibration parameters, such as minimum vehicle radii and nearest orthogonal orientation.
Automated sensor calibration reduces the amount of operator input used when defining sensor installation parameters. Automated sensor calibration also allows the operator to install an electronic control unit (ECU) in any convenient orientation (roll, pitch and yaw), removing the need for the ECU to be installed in a restrictive orthogonal configuration. Automated sensor calibration may remove dependencies on a heading filter and steering interfaces by calculating sensor parameters based on raw sensor measurements taken during the vehicle maneuvers.
A plate 127 is attached to a vehicle 100 and a set of hinges 124, 125, and 126 attach plate 127 to a plate 123 attached to ECU 120. Hinges 124, 125, and 126 may rotate ECU 120 into a variety of different alignments relative to vehicle 100. In alignment 1, ECU 120 is aligned and level with attached vehicle 100. In alignment 2, ECU 120 is rotated in pitch by 90° and appears vertically aligned with vehicle 100. The orthogonal installations in
A GPS antenna may be installed on the chassis of vehicle 100 and offset from ECU 120. Preferably, IMU 150 within ECU 120 is located as close as possible to a pivot point of vehicle 100. The pivot point is alternatively referred to as a vehicle control point or center of gravity. However, due to space limitations on vehicle 100, ECU 120 may be offset and/or misaligned with the control point and longitudinal/lateral axes of vehicle 100 that extend through the control point.
References below to a local frame may refer to a frame of reference on the ground looking north and is also referred to as a fixed frame. References to a body frame may refer to a frame of vehicle 100 as it moves and an x-axis may typically be a heading of the body frame. An ECU frame may refer to the vehicle body but relative to ECU box 120.
Calibration
During step 1, the operator may turn on vehicle 100 and navigation system 110 but keep vehicle 100 in a stationary position. Navigation system 110 takes first sensor readings during step 1, such as vehicle acceleration readings from accelerometers in ECU 120 in
Referring now to
During step 5, navigation system 110 takes sensor readings while the operator drives vehicle 100 in a full lock left turn while maintaining a constant speed. During step 6, navigation system 110 takes sensor readings while the operator drives vehicle 100 in a full lock right turn while maintaining a constant speed. A full lock turn refers to the vehicle operator turning the vehicle steering wheel as far as possible to the left or to the right. Sensor readings taken by navigation system 110 during steps 5 and 6, may include global positioning system (GPS) speed readings, gyroscope yaw rate readings, and accelerometer readings.
ECU Installation Misalignment
One objective of step 1 is to obtain the roll ϕ1 and pitch θ1 measured by IMU 150 (
θ1=θt+θm (2.1)
In step 2, vehicle 100 has changed direction relative to the terrain, facing down the slope, but misalignment angle θm of ECU 120 relative to body axis 122 remains the same. Therefore, the measured pitch angle during step 2 is:
θ2=−θt+θm (2.2)
With this information, navigation system 110 may calculate the ECU pitch misalignment θm by averaging the pitch estimates obtained in steps 1 and 2, where:
Operation 2.3 eliminates the terrain pitch effects, so only the pitch installation misalignment angle θm for ECU 120 remains.
With the roll and pitch misalignments calculated, navigation system 110 performs an intermediate frame transformation to align the measurements from IMU 150 with a local-level frame. As mentioned above, the local frame is the frame of reference on the ground or fixed frame often with a reference to north. An intermediate frame transformation can be expressed as:
CbL=Ly(−θm)Lr(−ϕm) (2.7)
where CbL describes the transformation from the sensor (body) frame to the local-level frame. The matrices Lx and Ly refer to rotations in the x and y axes respectively.
The frame transformation in process 2.7 may align the IMU sensor readings with expected vehicle axes. For example, if IMU 150 pitches up and is rolled to the right, process 2.7 may unroll and depitch the measurements to align with vehicle axes that extend through the vehicle control point and effectively algorithmically straightens out IMU 150.
Navigation system 110 uses step 3 in
Navigation system 110 uses step 4 to determine the calibration speed V0, maintained throughout the calibration process. In one example, calibration speed V0 is selected to be as high as possible without the vehicle wheels slipping on the terrain. The same calibration speed may be used throughout the other vehicle maneuvers in steps 5 and 6.
Similarly, navigation system 110 uses step 6 in
In one example, the velocities from IMU 150 within ECU 120 cannot be measured directly, and are estimated using corrected accelerations that have been transformed into the local-level frame. Again, IMU 150 may include any combination of gyroscopes and accelerometers that measure yaw, pitch and roll rates, speed, acceleration, etc. Navigation system 110 uses the corrected accelerations to calculate the IMU velocities as follows:
where a{circumflex over (x)},L, aŷ,L and a{circumflex over (x)},R, a{circumflex over (x)},R are the corrected accelerations measured in the x and y axis accelerometers for each turn direction obtained during steps 5 and 6.
With these measured values, navigation system 110 determines the forward IMU offset Ix and lateral IMU offset Iy as follows:
Note that Equations 2.10 and 2.11 are functions of estimated values obtained during the calibration process, namely accelerations and yaw rates.
Navigation system 110 estimates the ECU yaw misalignment ψm following the calculation of the IMU offsets relative to the vehicle control point. The yaw misalignment can be expressed as:
In a similar manner to the calculation of the pitch and roll misalignment angles calculated in Equations 2.3 and 2.6, the calculation of yaw misalignment in Equation 2.17 is an averaging process between the left and right hand turn maneuvers. This is to eliminate any effects of an off-center ECU installation.
Navigation system 110 during step 4 determines the calibration speed V0, which is maintained throughout the calibration process. Navigation system 110 during step 5 measures the GPS velocity VGPS,L and yaw rate {dot over (ψ)}L during the left-hand turn. Similarly, navigation system 100 during step 6 measures the GPS velocity VGPS,R and yaw rate {dot over (ψ)}R for the right-hand turn. The values for V0, VGPS,L, VGPS,R, {dot over (ψ)}L, and {dot over (ψ)}R are measured and stored within ECU 120 or navigation system 110 as they are collected during steps 1-6.
Navigation system 110 uses the measured values to determine the longitudinal antenna offset lx and lateral antenna offset ly as follows:
Note that the antenna offset estimation may be more effective when GPS antenna 12 is installed ahead of control point 115 on vehicle 100, i.e. lx>0.
Minimum Radii
Navigation system 110 may calculate the left and right minimum radii for vehicle 100 using the GPS speed and yaw rates measured during each turn direction. The left and right minimum radii can be expressed as:
Installation Attitude Biases
In adhering to the current definition of roll and pitch bias, the bias angles are represented relative to the nearest orthogonal installation. This rotation can expressed as follows:
CorthECU=CbECUCorthb (2.34)
Where CorthEC|U is the transformation from the nearest orthogonal alignment to the ECU frame, C|orthECU is the transformation from the body frame to the ECU frame (known) and Corthb is the transformation from the nearest orthogonal installation to the body frame (known). An orthogonal alignment is one that has 90° rotations between axes.
Extraction of the angles from CorthEC|U yields the roll ϕb, pitch θb and yaw bias angles ψb relative to the nearest orthogonal installation in the ECU frame. To represent the bias angles in the body frame, the following rotation is applied:
In operation 200C, the navigation system reads sensor data while the vehicle is traveling in a straight line at a constant speed. In operation 200D, the navigation system reads vehicle sensor data while the vehicle is turning locked to the left and in operation 200E, the navigation system reads vehicle sensor data while the vehicle is turning locked to the right.
In operation 200F, the navigation system calculates the roll, pitch, yaw and misalignments of the ECU based on the measured vehicle sensor data. For example, the navigation system calculates the roll and pitch misalignments based on the average roll and pitch readings from operations 200A and 200B. The navigation system calculates yaw misalignment based on vehicle speed, acceleration and yaw rate measurements made during operations 200C, 200D, and 200E.
In operation 200G, the navigation system calculates offsets of the ECU and GPS antenna based on the vehicle speed, acceleration and yaw rate measurements made during operations 200C, 200D, and 200E. For example, the navigation system calculates the lateral and longitudinal distances of the inertial sensors and GPS antenna from the vehicle control point. In operation 200H, the navigation system calibrates the sensors by adjusting sensor readings to the vehicle frame axes or local axes based on the derived misalignments and offsets.
Computer, Software, and Sensor Systems
A Global navigation satellite system (GNSS) is broadly defined to include GPS (U.S.) Galileo (European Union, proposed) GLONASS (Russia), Beidou (China) Compass (China, proposed) IRNSS (India, proposed), QZSS (Japan, proposed) and other current and future positioning technology using signal from satellites, with or with augmentation from terrestrial sources.
IMUs may include gyroscopic (gyro) sensors, accelerometers and similar technologies for providing outputs corresponding to the inertial of moving components in all axes, i.e., through six degrees of freedom (positive and negative directions along transverse X, longitudinal Y and vertical Z axes). Yaw, pitch and roll refer to moving component rotation about the Z, X, and Y axes respectively. Said terminology will include the words specifically mentioned, derivative thereof and words of similar meaning.
Auto-steering system 166 may interface mechanically with the vehicle's steering column 34, which is mechanically attached to steering wheel 32. A control line 42 may transmit guidance data from the CPU 6 to the auto-steering system 166. An electrical subsystem 44, which powers the electrical needs of vehicle 100, may interface directly with auto-steering system 166 through a power cable 46. The auto-steering subsystem 166 can be mounted to steering column 34 near the floor of the vehicle, and in proximity to the vehicle's control pedals 36. Alternatively, auto-steering system 166 can be mounted at other locations along steering column 34.
The auto-steering system 166 physically drives and steers vehicle 100 or 110 by actively turning the steering wheel 32 via steering column 34. A motor 45 powered by vehicle electrical subsystem 44 may power a worm drive which powers a worm gear 48 affixed to auto-steering system 166. These components are preferably enclosed in an enclosure. In other embodiments, auto-steering system 166 is integrated directly into the vehicle drive control system independently of steering column 34.
Some of the operations described above may be implemented in software and other operations may be implemented in hardware. One or more of the operations, processes, or methods described herein may be performed by an apparatus, device, or system similar to those as described herein and with reference to the illustrated figures.
“Computer-readable storage medium” (or alternatively, “machine-readable storage medium”) used in guidance system 120 may include any type of memory, as well as new technologies that may arise in the future, as long as they may be capable of storing digital information in the nature of a computer program or other data, at least temporarily, in such a manner that the stored information may be “read” by an appropriate processing device. The term “computer-readable” may not be limited to the historical usage of “computer” to imply a complete mainframe, mini-computer, desktop, wireless device, or even a laptop computer. Rather, “computer-readable” may comprise storage medium that may be readable by a processor, processing device, or any computing system. Such media may be any available media that may be locally and/or remotely accessible by a computer or processor, and may include volatile and non-volatile media, and removable and non-removable media.
Examples of systems, apparatus, computer-readable storage media, and methods are provided solely to add context and aid in the understanding of the disclosed implementations. It will thus be apparent to one skilled in the art that the disclosed implementations may be practiced without some or all of the specific details provided. In other instances, certain process or methods also referred to herein as “blocks,” have not been described in detail in order to avoid unnecessarily obscuring the disclosed implementations. Other implementations and applications also are possible, and as such, the following examples should not be taken as definitive or limiting either in scope or setting.
References have been made to accompanying drawings, which form a part of the description and in which are shown, by way of illustration, specific implementations. Although these disclosed implementations are described in sufficient detail to enable one skilled in the art to practice the implementations, it is to be understood that these examples are not limiting, such that other implementations may be used and changes may be made to the disclosed implementations without departing from their spirit and scope. For example, the blocks of the methods shown and described are not necessarily performed in the order indicated in some other implementations. Additionally, in other implementations, the disclosed methods may include more or fewer blocks than are described. As another example, some blocks described herein as separate blocks may be combined in some other implementations. Conversely, what may be described herein as a single block may be implemented in multiple blocks in some other implementations. Additionally, the conjunction “or” is intended herein in the inclusive sense where appropriate unless otherwise indicated; that is, the phrase “A, B or C” is intended to include the possibilities of “A,” “B,” “C,” “A and B,” “B and C,” “A and C” and “A, B and C.”
Having described and illustrated the principles of a preferred embodiment, it should be apparent that the embodiments may be modified in arrangement and detail without departing from such principles. Claim is made to all modifications and variation coming within the spirit and scope of the following claims.
The present application claims priority to U.S. Provisional Patent Application Ser. No. 62/257,395 filed on Nov. 19, 2015, entitled: SENSOR ALIGNMENT CALIBRATION which is incorporated by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
4713697 | Gotou | Dec 1987 | A |
5194851 | Kraning et al. | Mar 1993 | A |
5390125 | Sennott et al. | Feb 1995 | A |
5446658 | Pastor | Aug 1995 | A |
5663879 | Trovato et al. | Sep 1997 | A |
5923270 | Sampo et al. | Jul 1999 | A |
6052647 | Parkinson et al. | Apr 2000 | A |
6070673 | Wendte | Jun 2000 | A |
6212453 | Kawagoe et al. | Apr 2001 | B1 |
6282496 | Chowdhary | Aug 2001 | B1 |
6373432 | Rabinowitz et al. | Apr 2002 | B1 |
6377889 | Soest | Apr 2002 | B1 |
6415223 | Lin | Jul 2002 | B1 |
6445983 | Dickson et al. | Sep 2002 | B1 |
6522992 | McCall | Feb 2003 | B1 |
6539303 | McClure et al. | Mar 2003 | B2 |
6711501 | McClure et al. | Mar 2004 | B2 |
6714848 | Schubert | Mar 2004 | B2 |
6714851 | Hrovat | Mar 2004 | B2 |
6789014 | Rekow et al. | Sep 2004 | B1 |
6819780 | Benson et al. | Nov 2004 | B2 |
6865465 | McClure | Mar 2005 | B2 |
6876920 | Mailer | Apr 2005 | B1 |
7142956 | Heiniger et al. | Nov 2006 | B2 |
7162348 | McClure et al. | Jan 2007 | B2 |
7277792 | Overschie | Oct 2007 | B2 |
7373231 | McClure et al. | May 2008 | B2 |
7400956 | Feller et al. | Jul 2008 | B1 |
7437230 | McClure | Oct 2008 | B2 |
7460942 | Mailer | Dec 2008 | B2 |
7689354 | Heiniger et al. | Mar 2010 | B2 |
7698036 | Watson | Apr 2010 | B2 |
RE41358 | Heiniger et al. | May 2010 | E |
7835832 | Macdonald et al. | Nov 2010 | B2 |
7885745 | McClure et al. | Feb 2011 | B2 |
8018376 | McClure et al. | Sep 2011 | B2 |
8065104 | Fiedler et al. | Nov 2011 | B2 |
8190337 | McClure | May 2012 | B2 |
8214111 | Heiniger et al. | Jul 2012 | B2 |
8271175 | Takenaka | Sep 2012 | B2 |
8311696 | Reeve | Nov 2012 | B2 |
8386129 | Collins et al. | Feb 2013 | B2 |
8392102 | Fiedler | Mar 2013 | B2 |
8401704 | Pollock et al. | Mar 2013 | B2 |
8489291 | Dearborn et al. | Jul 2013 | B2 |
8521372 | Hunt et al. | Aug 2013 | B2 |
8532899 | Loomis | Sep 2013 | B1 |
8548649 | Guyette et al. | Oct 2013 | B2 |
8566034 | Van Wyck Loomis | Oct 2013 | B1 |
8583312 | Schreiber | Nov 2013 | B2 |
8583315 | Whitehead et al. | Nov 2013 | B2 |
8583326 | Collins et al. | Nov 2013 | B2 |
8589013 | Pieper et al. | Nov 2013 | B2 |
8589015 | Willis | Nov 2013 | B2 |
8594879 | Roberge et al. | Nov 2013 | B2 |
8634993 | McClure et al. | Jan 2014 | B2 |
8639416 | Jones et al. | Jan 2014 | B2 |
8649930 | Reeve et al. | Feb 2014 | B2 |
8676620 | Hunt et al. | Mar 2014 | B2 |
8718874 | McClure et al. | May 2014 | B2 |
8768558 | Reeve et al. | Jul 2014 | B2 |
8781685 | McClure | Jul 2014 | B2 |
8803735 | McClure | Aug 2014 | B2 |
8897973 | Hunt et al. | Nov 2014 | B2 |
8924152 | Hunt et al. | Dec 2014 | B2 |
9002565 | Jones et al. | Apr 2015 | B2 |
9002566 | McClure et al. | Apr 2015 | B2 |
9141111 | Webber et al. | Sep 2015 | B2 |
9162703 | Miller et al. | Oct 2015 | B2 |
9173337 | Guyette et al. | Nov 2015 | B2 |
9223314 | McClure et al. | Dec 2015 | B2 |
9255992 | McClure | Feb 2016 | B2 |
9389615 | Webber et al. | Jul 2016 | B2 |
9791279 | Somieski | Oct 2017 | B1 |
20020008661 | McCall | Jan 2002 | A1 |
20020022924 | Begin | Feb 2002 | A1 |
20020072850 | McClure et al. | Jun 2002 | A1 |
20020128795 | Schiffmann | Sep 2002 | A1 |
20020135420 | McCall | Sep 2002 | A1 |
20020183899 | Wallner | Dec 2002 | A1 |
20040150557 | Ford et al. | Aug 2004 | A1 |
20040186644 | McClure et al. | Sep 2004 | A1 |
20060167600 | Nelson, Jr. et al. | Jul 2006 | A1 |
20080048405 | DeLorenzis | Feb 2008 | A1 |
20090025998 | Brandmeier | Jan 2009 | A1 |
20090088974 | Yasan | Apr 2009 | A1 |
20100274452 | Ringwald et al. | Oct 2010 | A1 |
20120221244 | Georgy et al. | Aug 2012 | A1 |
20140266877 | McClure | Sep 2014 | A1 |
20140277676 | Gattis | Sep 2014 | A1 |
20150175194 | Gattis | Jun 2015 | A1 |
20160039454 | Mortimer | Feb 2016 | A1 |
20160040992 | Palella | Feb 2016 | A1 |
20160154108 | McClure et al. | Jun 2016 | A1 |
20160205864 | Gattis et al. | Jul 2016 | A1 |
20160214643 | Joughin et al. | Jul 2016 | A1 |
20160252909 | Webber et al. | Sep 2016 | A1 |
20160334804 | Webber et al. | Nov 2016 | A1 |
Number | Date | Country |
---|---|---|
102005033237 | Jan 2007 | DE |
Entry |
---|
Noh, Kwang-Mo, Self-tuning controller for farm tractor guidance, Iowa State University Retrospective Theses and Dissertations, Paper 9874, (1990). |
Van Zuydam,. R.P., Centimeter-Precision Guidante of Agricultural Impleet ns in the Open Field by Means of Real Tim Kinematic DGPS, ASA-CSSA-SSSA, pp. 1023-1034 (1999). |
Van Zuydam,. R.P., Centimeter-Precision Guidance of Agricultural Implements in the Open Field by Means of Real Tim Kinematic DGPS, ASA-CSSA-SSSA, pp. 1023-1034 (1999). |
Number | Date | Country | |
---|---|---|---|
20170146667 A1 | May 2017 | US |
Number | Date | Country | |
---|---|---|---|
62257395 | Nov 2015 | US |