The present invention relates generally to control of an implement operably coupled to a body of a vehicle, and more particularly to the estimation, using gyros, of the attitude of the implement relative to the body of the vehicle.
In particular earthmoving operations, the attitude and position of an implement operably coupled to a vehicle body needs to be accurately controlled; consequently, the attitude and position of the implement needs to be accurately measured. In grading applications with a dozer, for example, the attitude and position of the dozer blade needs to be accurately controlled, and accurate measurements of the attitude and position of the dozer blade are needed. In some machine control systems, the attitude and position of the dozer blade are measured by sensors mounted on the dozer blade. The position of the dozer blade can be measured, for example, with a Global Navigation Satellite System (GNSS) receiver or a laser system. In these systems, a mast is installed on the dozer blade to support a GNSS antenna, a laser prism, or a laser receiver. The attitude of the dozer blade can be measured with two GNSS antennas, two laser prisms, or two laser receivers. Each GNSS antenna, laser prism, or laser receiver is supported by an individual mast installed on the dozer blade.
During earthmoving operations, the sensors are exposed to harsh environmental conditions, including high levels of shock and vibration, wide ranges of high and low temperatures, exposure to water, and impact with soil, stones, and rocks. Sensors mounted on a mast, in particular, are exposed and susceptible to damage.
An implement is operably coupled to a vehicle body. In an embodiment of the invention, the relative attitude between the implement and the vehicle body is estimated. A first system state vector estimate is received. The first system state vector corresponds to a first time instant and includes a representation of a first relative attitude estimate corresponding to the first time instant. A body angular velocity measurement from at least one body gyro mounted on the vehicle body is received, and an implement angular velocity measurement from at least one implement gyro mounted on the implement is received. An updated system state vector is computed based at least in part on the first system state vector estimate, the body angular velocity vector measurement, and the implement angular velocity vector measurement. A second system state vector estimate is predicted. The second system state vector estimate is based at least in part on the updated system state vector and a time-dependent system model, corresponds to a second time instant, and includes a representation of a second relative attitude estimate corresponding to the second time instant.
These and other advantages of the invention will be apparent to those of ordinary skill in the art by reference to the following detailed description and the accompanying drawings.
In general, embodiments of the invention described below can be used for a vehicle including a vehicle body and an implement operably coupled to the vehicle body. An implement operably coupled to a vehicle body refers to an implement whose attitude relative to the vehicle body can be varied and controlled, either manually by an operator or automatically by a control system. In some vehicles, both the attitude and the position of the implement relative to the vehicle body can be varied and controlled.
Embodiments of the invention can be used, for example, for construction vehicles such as earthmoving machines (including dozers and motorgraders) and pavers: a dozer includes a dozer body and a dozer blade operably coupled to the dozer body; a motorgrader includes a motorgrader body (frame) and a motorgrader blade operably coupled to the motorgrader body; and a paver includes a paver body and a screed operably coupled to the paver body. In the discussions below, a dozer is used as a representative example of a vehicle for which embodiments of the invention can be used.
In general, both the attitude (angular orientation) and the position of the dozer blade 104 relative to the dozer body 102 can be controlled by controlling the extensions of the hydraulic cylinders. The hydraulic cylinders can be controlled manually by an operator (for example, via the joystick 120) or automatically by a computer control system.
For grading operations, parameters such as the height of the dozer blade above the ground and the slope of the dozer blade relative to the ground are controlled. A system-state estimate system computes an estimate of the current system state and generates a feedback signal corresponding to the estimate of the current system state. In a manual control system, the feedback signal is inputted into a display system that displays the current values of the dozer blade parameters (such as the height and the slope of the dozer blade) on a lightbar or video display, and an operator manually adjusts the dozer blade to achieve and maintain the desired (target) values of the dozer blade parameters. In an automatic control system, the feedback signal is transformed into a control signal that is used by a hydraulic control system to automatically control the height and the slope of the dozer blade.
The geometrical configurations of dozers and the degrees of freedom of the dozer blade relative to the dozer body vary among different models of dozers. In the most general case, a dozer blade can have up to six degrees of freedom (three angular rotations varying the relative attitude between the dozer blade and the dozer body and three translations varying the relative position between the dozer blade and the dozer body). In most cases, a dozer is equipped with a 4-way blade or a 6-way blade. A 4-way blade has two degrees of freedom: lift and tilt. The lift is adjustable in two ways (up and down), and the tilt is adjustable in two ways (clockwise and counter-clockwise). A 6-way blade has three degrees of freedom: lift, tilt, and angle. The lift is adjustable in two ways (up and down), the tilt is adjustable in two ways (clockwise and counter-clockwise), and the angle is adjustable in two ways (left and right).
In practice, the number of parameters of the dozer blade to be controlled depends on the application. If the application requires control of only the slope of the dozer blade relative to the ground, then an estimate of the dozer blade attitude relative to the dozer body is sufficient. If the application requires control of both the slope of the dozer blade and the position of the dozer blade relative to the ground, then both an estimate of the dozer blade attitude relative to the dozer body and an estimate of the dozer blade position relative to the dozer body are needed.
If the dozer blade has no more than three degrees of freedom, an estimate of the dozer blade position relative to the dozer body can be calculated from the estimate of the dozer blade attitude relative to the dozer body. If the dozer blade has more than three degrees of freedom, additional measurements (such as the attitudes of support arms), along with the estimate of the dozer blade attitude relative to the dozer body, are needed to determine an estimate of the dozer blade position relative to the dozer body. Algorithms for calculating an estimate of the dozer blade position relative to the dozer body based on an estimate of the dozer blade attitude relative to the dozer body and based on geometrical parameters of the dozer are well-known in the art and are not described in further detail herein.
Values of the dozer blade attitude and the dozer blade position relative to the dozer body can then be used in combination with values of the dozer body attitude and the dozer body position relative to a local or geodetic coordinate system to calculate the values of the dozer blade attitude and the dozer blade position relative to the local or geodetic coordinate system. Refer to
Values of the dozer body attitude and the dozer body position relative to a local or geodetic coordinate system can be calculated from sensors such as global navigation satellite system (GNSS) antennas, laser prisms, and laser receivers mounted on the dozer body (for example, mounted on the roof of the cabin). Algorithms for calculating the values of the dozer blade attitude and the dozer blade position relative to the local or geodetic coordinate system, based on values of the dozer blade attitude and the dozer blade position relative to the dozer body in combination with values of the dozer body attitude and the dozer body position relative to a local or geodetic coordinate system, are well known to those skilled in the art and are not discussed in further detail herein.
Values of the dozer blade attitude and the dozer blade position relative to the local or geodetic coordinate system can then be used to generate a feedback signal in a manual blade control system or an automatic blade control system. Algorithms for generating a feedback signal from values of the dozer blade attitude and the dozer blade position relative to the local or geodetic coordinate system are well known to those skilled in the art and are not discussed in further detail herein. As discussed above, depending on the application, different parameters of the dozer blade can be controlled; the feedback signal depends on the parameters to be controlled.
PCT International Publication No. WO 2013/119140 (“Estimation of the Relative Attitude and Position between a Vehicle Body and an Implement Operably Coupled to the Vehicle Body”) describes a method for estimating the relative dozer blade attitude between the dozer blade and the dozer body using accelerometers or a combination of accelerometers and gyros.
In an embodiment of the invention described herein, an estimate of the current system state is computed based on measurements from gyros mounted on the dozer body and on the dozer blade. In an advantageous embodiment, the gyros are mounted in an inertial measurement unit (IMU) with a robust housing to withstand harsh environmental conditions. In
Shown in
The body frame 141 is fixed with respect to the dozer body 102 and is defined by three orthogonal axes (
The blade frame 151 is fixed with respect to the dozer blade 104 and is defined by three orthogonal axes (
Refer to the vector diagrams shown in
where ω1x1, ω1y1, ω1z1 are the components of ω1 projected onto the x1, y1, z1 axis, respectively. In
ω2=ω1+ωr. (E2)
In the blade frame, the angular velocity ω2 is referenced as ω2
where ω2x2, ω2y2, ω2z2 are the components of ω2 projected onto the x2, y2, z2 axes, respectively. The IMU1140 measures the values (ω1x1, ω1y1, ω1z1), and the IMU2150 measures the values (ω2x2, ω2y2, ω2z2).
The dozer blade attitude relative to the dozer body can be represented in one of three following forms:
three Euler angles: roll, pitch, and yaw;
direction cosine matrix (DCM): nine direction cosines; and
rotation quaternion:
q=[q
0
,q
1
,q
2
,q
3],(q02+q12+q22+q32=1). (E4)
The embodiment described below uses a rotation quaternion as the representation of the dozer blade attitude relative to the dozer body. One skilled in the art can develop embodiments in which Euler angles or DCM are used as the attitude representation.
Using the rotation quaternion q as the attitude representation, the dozer blade angular velocity vector, projected onto the axes of the body frame, is written as:
ω2
The dozer blade angular velocity vector relative to the dozer body, projected onto the axes of the body frame, is written as:
ωr
A system can be described by a discrete time state space model:
x
k+1
=f(xk), (E7)
where:
As discussed below, the extended Kalman filter procedure is used for calculating the estimate of the rotation quaternion. A brief summary of the extended Kalman filter procedure is first presented.
In the extended Kalman filter procedure, the following system equations are used for discrete time:
x
k+1
=f(xk)+wk (E8)
z
k
=h(xk)+vk, (E9)
where:
The process noise vector wk has a covariance matrix Qk; and the measurement noise vector vk has a covariance matrix Rk.
To estimate the system state vector x from the measurement vector z, the following extended Kalman filter procedure is used. At time epoch tk, the Jacobian matrices Ak and Hk are calculated. The [i, j]-th element of the matrix Ak (where i and j are integer indices) is given by
The [i, j]-th element of the matrix Hk is given by
The system state vector estimate is updated by a new measurement vector zk as follows:
K
k
=P
k
H
k
T(HkPkHkT+Rk)−1 (E12)
{circumflex over (z)}
k
=h({circumflex over (x)}k) (E13)
x
k
={umlaut over (x)}
k
+K
k(zk−{circumflex over (z)}k) (E14)
where:
Pk is the system state vector estimate covariance matrix at time epoch tk; and
Kk is the Kalman gain at time epoch tk.
The symbol {circumflex over (x)}k denotes an estimate of xk.
The new system state vector estimate is then predicted using the system equations:
{circumflex over (x)}
k+1
=f(xf) (E15)
P
k+1
=A
k
P
k
A
k
T
+Q
k. (E15)
The following extended Kalman filter procedure is used for calculating the estimate of the rotation quaternion {circumflex over (q)}. A state vector of the dozer system includes the rotation quaternion, the dozer body angular velocity, and the dozer blade angular velocity relative to the dozer body. The system state vector can include other components as well. In an embodiment, the system state vector xk comprises the following components:
where:
δx2,k=½ωrx2,kΔt (E18)
δy2,k=½ωry2,kΔt (E19)
δz2,k=½ωrz2,kΔt (E20)
For the extended Kalman filter procedure, the initial estimate of the system state vector is required at the start up of the system. The system state vector can be initialized by the identity rotation quaternion, {circumflex over (q)}=[1,0,0,0]. The identity rotation quaternion corresponds to the axes of the blade frame 151 pointing along the same directions as the axes of the body frame 141.
The discrete time state space equation for this system is given by (E8) above. With xk given by (E17), the components of (E8) are the following:
q
0,k+1
=q
0,k
−q
1,kδx2,k−q2,kδy2,k−q3,kδz2,k+wq0,k (E21)
q
1,k+1
=q
1,k
−q
0,kδx2,k−q3,kδy2,k−q2,kδz2,k+wq1,k (E22)
q
2,k+1
=q
2,k
−q
3,kδx2,k−q0,kδy2,k−q1,kδz2,k+wq2,k (E23)
q
3,k+1
=q
3,k
−q
2,kδx2,k−q1,kδy2,k−q0,kδz2,k+wq3,k (E24)
δx2,k+1=δx2,k+wδx2,k (E25)
δy2,k+1=δy2,k+wδy2,k (E26)
δz2,k+1=δz2,k+wδz2,k (E27)
ω1x2,k+1=ω1x2,k+wω1x2,k (E28)
ω1y2,k+1=ω1y2,k+wω1y2,k (E29)
ω1z2,k+1=ω1z2,k+wω1z2,k (E30)
where w(),k represents the component of wk corresponding to the component x(),k of xk.
The elements of the Jacobian matrix Ak is calculated from (E10) as
The result Ak is shown in
In an embodiment, the body angular velocity and the blade angular velocity are measured. The system measurement equations for the body angular velocity and the blade angular velocity are described below.
The system measurement equation for the body angular velocity is given by
ω1,k=h1(xk)+vk, (E32)
where:
ω1x1,k=(q0,k2+q1,k2−q2,k2−q3,k2)ω1x2,k+2(q1,kq2,k−q0,kq3,k)ω1y2,k+2(q1,kq3,k+q0,kq2,k)ω1z2,k+v1x1,k (E33)
ω1y1,k=2(q1,kq2,k+q0,kq3,k)ω1x2,k+(q0,k2−q1,k2+q2,k2−q3,k2)ω1y2,k+2(q2,kq3,k−q0,kq1,k)ω1z2,k+v1y1,k (E34)
ω1z1,k=2(q1,kq3,k−q0,kq2,k)ω1x2,k+2(q2,kq3,k+q0,kq1,k)ω1y2,k+(q0,k2−q1,k2−q2,k2+q3,k2)ω1z2,k+v1z1,k (E35)
where:
The system measurement equation for the blade angular velocity is given by:
ω2,k=h2(xk)+vk (E36)
where:
where:
To improve the accuracy of the system state vector estimate, additional information can be used to update the system state vector. In the quaternion representation, the quaternion norm is a known value, defined to be 1. The actual value of the quaternion norm, computed from the system state vector, will, in general, vary from 1 due to errors and noise. At each time epoch, the value of the quaternion norm can be considered to be a virtual measurement. The system measurement equation for the quaternion norm is then given by:
|qk|=1=h3(xk)+vk, (E40)
where:
|qk| is the quaternion norm at time epoch tk;
vk is the measurement noise vector at time epoch tk; and
h3 is a generalized measurement function.
In component form, (E40) is written as:
|qk|=1=q0,k2+q1,k2+q2,k2+q3,k2+v|q|,k, (E41)
where v|q|,k represents the noise of the measurement of the rotation quaternion norm at time epoch tk.
As discussed above, the dozer blade attitude relative to the dozer body with, in general, three angular degrees of freedom can be represented by Euler angles (three parameters), a direction cosine matrix (nine parameters), or a quaternion (four parameters). For the Euler-angles representation, the number of parameters is equal to the number of degrees of freedom, and no normalization condition is required. For the direction-cosine-matrix representation and the quaternion representation, the number of parameters exceeds the number of degrees of freedom, and a normalization condition is required. As discussed above, for the quaternion representation, the normalization condition is q02+q12+q22+q32=1. For the direction-cosine-matrix representation, the normalization condition is C−1=CT, where C is the direction cosine matrix. Therefore, for the direction-cosine-matrix representation, the system state vector can also be updated with a virtual measurement based on the normalization condition.
In an embodiment, the system state vector is updated when the relative angular velocity of the dozer blade with respect to the dozer body is determined to be zero. The system measurement equation for the relative angular velocity of the dozer blade with respect to the dozer body is given by:
ωr,k=h4(xk)+vk, (E42)
where:
where:
In an embodiment, the relative angular velocity of the dozer blade with respect to the dozer body is not directly measured. Measurements of control signals (see below), however, can determine whether the relative angular velocity of the dozer blade with respect to the dozer body is zero or non-zero. In the special case in which the relative angular velocity of the dozer blade with respect to the dozer body is zero, the following system measurement equations apply:
The measurement Jacobian matrices Hk, with elements
are calculated from the above measurement equations. For example, the measurement Jacobian matrix Hk for the blade angular velocity measurement equation ω2,k=h2(xk)+vk can be written as:
Using the above equations, the extended Kalman filter procedure can be used to estimate the system state vector at each time epoch tk. The relative attitude between the dozer blade and the dozer body can be calculated from the rotation quaternion {circumflex over (q)}k component of the system state vector estimate {circumflex over (x)}k. In some dozers, the blade supports provide a direct dependence between the blade relative attitude and the blade relative position. In these cases, the blade relative position can be calculated from the blade relative attitude and from known dozer geometrical parameters.
Embodiments of systems for estimating the relative attitude between the dozer blade and the dozer body are shown in
The hydraulic system controlling the extensions of the hydraulic cylinders uses mechanical valves or electric valves. A dozer operator can manually control the hydraulic cylinders via a joystick, such as the joystick 120 in
Refer to the embodiment shown in
Various network architectures and protocols can be used for the communications network 502. Examples of the communications network 502 include a controller area network (CAN), an Ethernet network, and an Internet Protocol (IP) network. The IMU1140, which is mounted on the dozer body 102, sends the signal 541 to the communications network 502. The signal 541 includes measurements of the angular velocity of the dozer body (ω1x1, ω1y1, ω1z1). Similarly, the IMU2150, which is mounted on the dozer blade 104, sends the signal 551 to the communications network 502. The signal 551 includes measurements of the angular velocity of the dozer blade (ω2x2, ω2y2, ω2z2).
The rotational state of the dozer blade 104 (whether the relative angular velocity of the dozer blade with respect to the dozer body is zero or non-zero) can be determined by the system. For example, the joystick sensor 506 monitors the movement of the joystick 120 and sends the signal 505 to the communications network 502. The signal 505 reports whether the relative angular velocity is zero or non-zero. If the joystick is not moving, then the dozer blade is not rotating relative to the dozer body and is also not translating relative to the dozer body. If the joystick is moving, then the response of the dozer blade is dependent on the control system. In some control systems, movement of the joystick causes only rotation of the dozer blade relative to the dozer body. In other control systems, movement of the joystick can cause rotation or translation (or both) of the dozer blade relative to the dozer body. In these control systems, the response of the dozer blade depends on the trajectory of the joystick (for example, front/back or left/right). The joystick sensor 506 then needs to distinguish movements of the joystick that cause the dozer blade to rotate or rotate and translate from movements of the joystick that cause the dozer blade to translate without rotating.
If the hydraulic control system 510 is a mechanical hydraulic control system, then the joystick sensor 506 can be mechanically coupled to the joystick 120 (for example, one or more potentiometers operably coupled to an electronic circuit). Non-contact sensors (for example, one or more optical or video sensors operably coupled to an electronic circuit) can also be used.
If the hydraulic control system 510 is an electrical hydraulic control system, a separate joystick sensor, as described above for a mechanical hydraulic control system, can also be used. In an electrical hydraulic control system, movement of the joystick controls the settings of the potentiometers, which in turn controls the current or voltage to the solenoids driving the electric valves. Therefore, the current or voltage to the solenoids can also be monitored to determine whether the relative angular velocity of the dozer blade with respect to the dozer body is zero or non-zero. The hydraulic control system 510 sends the signal 507 to the communications network 502. The signal 507, based on the current or voltage to the solenoids, reports whether the relative angular velocity is zero or non-zero.
For both mechanical and electrical hydraulic control systems, the operational state of the hydraulic cylinders can also be monitored by sensors in the hydraulic control system (for example, pressure sensors or flow sensors). The hydraulic control system 510 sends the signal 509 to the communications network 502. The signal 509, based on measurements by pressure or flow sensors, reports whether the relative angular velocity is zero or non-zero.
In general, signal 505, signal 507, and signal 509 can be used separately or in combination to monitor the relative angular velocity of the dozer blade with respect to the dozer body and to report whether the relative angular velocity of the dozer blade with respect to the dozer body is zero or non-zero.
The controller unit 160 sends the output signal 510O to the communications network 502 and receives the input signal 510I from the communications network 502. The controller unit 160 receives the input signal 503I from the user input/output devices 504 and sends the output signal 503O to the user input/output devices 504. Examples of the user input/output devices 504 include a keyboard, a touchscreen, a lightbar, and a video display.
The controller unit 160 receives the measurements of the angular velocity of the dozer body (ω1x1, ω1y1, ω1z1) from the IMU1140, the measurements of the angular velocity of the dozer blade (ω2x2, ω2y2, ω2z2) from the IMU2150, and status signals from the joystick sensor 506 and the hydraulic control system 510. The controller unit 160 calculates an estimate of the relative attitude between the dozer blade and the dozer body, generates a feedback signal, and sends the feedback signal to the user input/output devices 104. The feedback signal can be converted to a display driver signal that drives a display such as a lightbar or video display. The display displays the difference between the estimated value and the target value of the dozer blade attitude (and, in some instances, the difference between the estimated value and the target value of the dozer blade position).
Refer to
Each of the interfaces shown in
An embodiment of the controller unit 160 is shown in
The controller unit 160 includes a computer 602, which includes a processor [referred to as a central processing unit (CPU)] 604, memory 606, and a data storage device 608. The data storage device 608 includes at least one persistent, non-transitory, tangible computer readable medium, such as non-volatile semiconductor memory, a magnetic hard drive, or a compact disc read only memory.
The controller unit 160 further includes a communications network interface 610, which interfaces the computer 602 with the communications network 502, and a user input/output interface 612, which interfaces the computer 602 with the user input/output devices 504. Note that various input/output devices (not shown) can also communicate with the controller unit 160 via the communications network 502. Data, including computer executable code, can be transferred to and from the computer 602 via a remote access terminal (not shown) communicating with the communications network 502 or via the user input/output devices 504.
As is well known, a computer operates under control of computer software, which defines the overall operation of the computer and applications. The CPU 604 controls the overall operation of the computer and applications by executing computer program instructions that define the overall operation and applications. The computer program instructions can be stored in the data storage device 608 and loaded into the memory 606 when execution of the program instructions is desired. The algorithms shown schematically in
The epoch durations for the IMU1140, the IMU2150, and the controller unit 160 can be different or can be the same. The reference clocks in the IMU1140, the IMU2150, and the controller unit 160 can run asynchronously or can be synchronized to a common system time. If the reference clock in the IMU1140 and the reference clock in the IMU2150 are run asynchronously, then the sampling frequency of each IMU should be high enough such that the time difference between epochs from different IMUs are not more than a predetermined value defined by the required accuracy of the relative attitude; for example, a sampling frequency of 100 Hz should provide sufficient accuracy for most applications. In the embodiments shown in
Refer to embodiment shown in
The process then passes to step 706, in which a body angular velocity measurement and a blade angular velocity measurement are received. The body angular velocity measurement, received from the IMU1140 mounted on the dozer body 102, is measured with respect to the body frame: (ω1x1, ω1y1, ω1z1). The blade angular velocity measurement, received from the IMU2150 mounted on the dozer blade 104, is measured with respect to the blade frame: ω2x2, ω2y2, ω2z2. Depending on the timing configuration, measurements from the IMU1140 can be received before, after, or at the same time as, measurements from the IMU2150. As discussed above, IMU1140 and IMU2150 each include three orthogonally-mounted gyros. In general, each IMU can include one gyro, two orthogonally-mounted gyros, or three orthogonally-mounted gyros.
The process then passes to step 708, in which the system state vector estimate is updated with the body angular velocity measurement and the blade angular velocity measurement. The updates can be performed separately or in combination. The process then passes to step 710, in which the new system state vector estimate {circumflex over (x)}k+1 is predicted. The new system state vector estimate {circumflex over (x)}k+1 includes a representation of the new estimate of the relative attitude between the dozer blade and the dozer body. The process then passes to step 712, in which the new estimate of the relative attitude between the dozer blade and the dozer body is extracted from the new system state vector estimate. In some embodiments, a new estimate of the relative position between the dozer blade and the dozer body is calculated from the new estimate of the relative attitude between the dozer blade and the dozer body and from known geometrical parameters of the dozer. The process then passes to step 714, in which the current time epoch ends.
Refer to embodiment shown in
The process then passes to step 806, in which a body angular velocity measurement, a blade angular velocity measurement, and an updated quaternion norm value are received. Details of the body angular velocity measurement and the blade angular velocity measurement are discussed above in reference to
The process then passes to step 808, in which the system state vector estimate is updated with the body angular velocity measurement, the blade angular velocity measurement, and the updated quaternion norm value. The updates can be performed separately or in various combinations. The process then passes to step 810, in which the new system state vector estimate {circumflex over (x)}k+1 is predicted. The new system state vector estimate {circumflex over (x)}k+1 includes a representation by a quaternion of the new estimate of the relative attitude between the dozer blade and the dozer body. The process then passes to step 812, in which the new estimate of the relative attitude between the dozer blade and the dozer body is extracted from the new system state vector estimate. In some embodiments, a new estimate of the relative position between the dozer blade and the dozer body is calculated from the new estimate of the relative attitude between the dozer blade and the dozer body and from known geometrical parameters of the dozer. The process then passes to step 814, in which the current time epoch ends.
Refer to embodiment shown in
The process then passes to step 906, in which a body angular velocity measurement and a blade angular velocity measurement are received. Details of the body angular velocity measurement and the blade angular velocity measurement are discussed above in reference to
The process then passes to step 908, in which the status of the blade relative angular velocity (relative angular velocity of the dozer blade with respect to the dozer body) is determined. The status of the blade relative angular velocity can be monitored and reported, for example, by signal 505, signal 507, or signal 509 (
Refer back to step 910. If the blade relative angular velocity is zero, then the process passes to step 914, in which the system state vector estimate is updated with the body angular velocity measurement, the blade angular velocity measurement, and the zero value of the blade relative angular velocity vector (ωrx2,k=0, ωry2,k=0, ωrz2,k=0, where ωr(),k are components of the blade relative angular velocity ωr,k in the blade frame). The updates can be performed separately or in various combinations.
The process then passes to step 916, in which the new system state vector estimate {circumflex over (x)}k+1 is predicted. The new system state vector estimate {circumflex over (x)}k+1 includes a representation of the new estimate of the relative attitude between the dozer blade and the dozer body. The process then passes to step 918, in which the new estimate of the relative attitude between the dozer blade and the dozer body is extracted from the new system state vector estimate. In some embodiments, a new estimate of the relative position between the dozer blade and the dozer body is calculated from the new estimate of the relative attitude between the dozer blade and the dozer body and from known geometrical parameters of the dozer. The process then passes to step 920, in which the current time epoch ends.
Refer to embodiment shown in
The process then passes to step 1006, in which a body angular velocity measurement, a blade angular velocity measurement, and an updated quaternion norm value are received. Details of the body angular velocity measurement and the blade angular velocity measurement are discussed above in reference to
The process then passes to step 1008, in which the status of the blade relative angular velocity (relative angular velocity of the dozer blade with respect to the dozer body) is determined. The status of the blade relative angular velocity can be monitored and reported, for example, by signal 505, signal 507, or signal 509 (
Refer back to step 1010. If the blade relative angular velocity is zero, then the process passes to step 1014, in which the system state vector estimate is updated with the body angular velocity measurement, the blade angular velocity measurement, the updated quaternion norm value, and the zero value of the blade relative angular velocity vector (ωrx2,k=0, ωry2,k=0, ωrz2,k=0, where ωr(),k are components of the blade relative angular velocity ωr,k in the blade frame). The updates can be performed separately or in various combinations.
The process then passes to step 1016, in which the new system state vector estimate {circumflex over (x)}k+1 is predicted. The new system state vector estimate {circumflex over (x)}k+1 includes a representation by a quaternion of the new estimate of the relative attitude between the dozer blade and the dozer body. The process then passes to step 1018, in which the new estimate of the relative attitude between the dozer blade and the dozer body is extracted from the new system state vector estimate. In some embodiments, a new estimate of the relative position between the dozer blade and the dozer body is calculated from the new estimate of the relative attitude between the dozer blade and the dozer body and from known geometrical parameters of the dozer. The process then passes to step 1020, in which the current time epoch ends.
Specific embodiments of the invention were described above for a dozer including a dozer body and a dozer blade operably coupled to the dozer body. As discussed above, embodiments of the invention are generally applicable for a vehicle including a vehicle body and an implement operably coupled to the vehicle body.
The foregoing Detailed Description is to be understood as being in every respect illustrative and exemplary, but not restrictive, and the scope of the invention disclosed herein is not to be determined from the Detailed Description, but rather from the claims as interpreted according to the full breadth permitted by the patent laws. It is to be understood that the embodiments shown and described herein are only illustrative of the principles of the present invention and that various modifications may be implemented by those skilled in the art without departing from the scope and spirit of the invention. Those skilled in the art could implement various other feature combinations without departing from the scope and spirit of the invention.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/RU2014/000445 | 6/23/2014 | WO | 00 |