
[0001]
This is a continuationinpart of U.S. application Ser. No. 09/342,997, filed Jun. 29, 1999.
TECHNICAL FIELD

[0002]
This invention relates generally to an implement control system for a work machine and, more particularly, to a method and apparatus for determining a cross slope created by a work machine.
BACKGROUND ART

[0003]
In one embodiment, the cross slope created by a work machine, such as a motor grader, may be described as the slope of a line lying on a surface path, such as a road, which is perpendicular to the direction of the path. Cutting an accurate cross slope into a land site is an important function for a work machine such as a motor grader; an accurate cross slope allows for proper runoff of water, and, if the unfinished is properly graded, pavement is more easily and accurately laid. Therefore, it would be advantageous to accurately determine the cross slope. The determined cross slope may be provided to the machine operator or compared to a desired cross slope in order to determine if the machine is creating the appropriate slope and to make adjustments to the blade position if a position error is occurring.

[0004]
Some previous implementations of systems for determining cross slope utilize GPS and laser technologies to determine the position of the blade and the machine relative to the land site, thereby enabling a cross slope of cut of the blade to be determined. However, the required GPS and laser detection systems are expensive and are not easily implemented in remote sites, such as when cutting a road in a remote location.

[0005]
In addition, other previous implementations of systems do not utilize GPS and laser technology but do use techniques which provide inaccurate information. For example, the angle of rotation of the blade may be used to ultimately determine the cross slope. Some systems determine an angle of rotation of the blade relative to the direction of travel of the blade using velocity transducers or radar guns for measuring the ground velocity in the direction of travel of the blade. However, these systems are expensive and have associated inaccuracies due, in part, to the fact that the accuracy decreases as the measured velocity approaches zero.

[0006]
Further, other previous implementations did not account for the appropriate variables. Sensing too few parameters may lead to an inaccurate determination of cross slope.

[0007]
The present invention is directed to overcoming one or more of the problems as set forth above.
DISCLOSURE OF THE INVENTION

[0008]
In one aspect of the present invention, a method for determining a cross slope created by a work implement on a work machine is disclosed. The method includes the steps of determining a position of the work implement, determining a direction of travel of the machine, and determining the cross slope created by the machine.

[0009]
In another aspect of the present invention, a method for determining a cross slope created by a work implement on a work machine is disclosed. The method includes the steps of sensing a plurality of machine parameters, sensing a plurality of work implement parameters, and determining the cross slope created by the machine.

[0010]
In another aspect of the present invention, an apparatus for determining a cross slope created by a work machine having a work implement is disclosed. The apparatus includes a machine sensor system for sensing a plurality of machine parameters and responsively generate a plurality of machine parameter signals, a work implement sensor system adapted to determine a plurality of work implement parameters and responsively generate a plurality of work implement parameter signals, and a controller adapted to receive the machine parameter signals and the work implement parameter signals, and determine the cross slope created by the machine.
BRIEF DESCRIPTION OF THE DRAWINGS

[0011]
[0011]FIG. 1a is a high level diagram of a first embodiment of an implement control system on a nonarticulated work machine;

[0012]
[0012]FIG. 1b is a high level diagram of a second embodiment of an implement control system on an articulated work machine;

[0013]
[0013]FIG. 2 is a diagrammatic block diagram of a front portion of a motor grader;

[0014]
[0014]FIG. 3 is a diagrammatic side view of the work implement;

[0015]
[0015]FIG. 4 is a view of the apparatus for determining a cross slope created by the machine;

[0016]
[0016]FIG. 5 is an example of blade roll angle and machine roll angle;

[0017]
[0017]FIG. 6 is an example of angle of rotation of the blade;

[0018]
[0018]FIG. 7a is an example of blade pitch angle;

[0019]
[0019]FIG. 7b is an example of machine pitch angle;

[0020]
[0020]FIG. 8 is an example of the direction of travel of the nonarticulated machine;

[0021]
[0021]FIG. 9 is an example of the direction of travel of the articulated work machine;

[0022]
[0022]FIG. 10 is an example of the cross slope created by the machine;

[0023]
[0023]FIG. 11 is an illustration of an alternative embodiment of the apparatus for determining a cross slope created by the machine;

[0024]
[0024]FIG. 12 is an illustration of the method for determining a cross slope;

[0025]
[0025]FIG. 13 is an illustration of the initial blade vector position;

[0026]
[0026]FIG. 14ae illustrates five aspects of the blade translations; and

[0027]
[0027]FIG. 15 is an illustration of the cross slope plane.
BEST MODE FOR CARRYING OUT THE INVENTION

[0028]
The present invention includes a method and apparatus for determining a cross slope created by a work implement on a work machine.

[0029]
I. Assembly of the Work Machine

[0030]
A work machine 108 includes a frame 106 upon which a work implement 104 is controllably movably mounted, as illustrated in FIG. 1a. In a first embodiment, the work implement is a blade 104, and the work machine 108 is a motor grader operating in a nonarticulated manner.

[0031]
In a second embodiment, as seen in FIG. 1b, the work machine 800 may be a motor grader operating in an articulated manner. The machine 800 has a frame 802, including a front frame 804 movably connected to a rear frame 806, the front frame 804 rotatable relative to the rear frame 806. The work implement 808, which is controllably movably mounted on the front frame 804, is identical to that found in the first embodiment, namely blade 104.

[0032]
It is to be noted that other machines such as dozers, scrapers, compactors, pavers, profilers, and the like, equipped with suitable surface altering equipment, are equivalents and considered within the scope of the invention. In addition, other work implements may be used without departing from the spirit of the invention.

[0033]
The blade 104, as shown in FIGS. 2 and 3, is movably connected to the frame 106 or 804 by a supporting mechanism 80, or drawbar. The supporting mechanism 80 preferably includes a circle drive mechanism 82 having a selectively actuatable rotary drive motor 84 for rotating a circle 85, and the blade 104 connected thereto about an elevational axis located at the center of the circle 85 in a known manner.

[0034]
As best seen in FIG. 2, the machine 108 or 800 may include a first and second selectively actuatable fluid operated lift jacks 86 and 88 which are connected to and between the frame 106 or 804 and the drawbar 80. The first and second lift jacks 86 and 88 are extensibly movable between first and second spaced apart positions and elevationally move the blade 104 relative to the frame 106 or 804. Simultaneous extension of the lift jacks 86 and 88 lowers the blade 104 and simultaneous retraction of lift jacks 86 and 88 raises the blade 104. Extension or retraction of either the first and second lift jacks 86 or 88, or extension of one of the first and second lift jacks 86 or 88 and retraction of the other of the lift jacks 88 or 86 results in rolling of the blade 104 relative to the frame 106 or 804.

[0035]
As shown in FIG. 3, a fluid operated tip jack 90 may be connected to and between the drawbar 80 and a bellcrank 92. The bellcrank 92 pivotally connects the blade 104 to the circle drive mechanism 82. The tip jack 90 is extensibly movable for tipping the bellcrank 92 about the pivotal connection. This results in tipping movement of the blade 104 in forward or rearward directions, as shown in phantom lines in FIG. 3, with the blade 104 oriented transversely of the vehicle frame 106 or 804. It should be noted that the terms blade tip and blade pitch are used interchangeably and have the same meaning.

[0036]
In one embodiment, the machine 108 or 800 may include a machine sensor system 402 and a work implement sensor system 404 electrically connected to a controller 54, as illustrated in FIG. 4. The machine sensor system 402 is adapted to sense at least one machine parameter and responsively generate at least one machine parameter signal. The work implement sensor system 404 is adapted to sense at least one work implement parameter and responsively generate at least one work implement parameter signal.

[0037]
As best seen in FIG. 3, the work implement sensor system 404 may include a pitch sensor assembly 94 provided for sensing the pitch angle of the blade 104. The pitch sensor assembly 94 may include any appropriate transducer capable of sensing the pitch of the blade 104. In the preferred embodiment the sensor assembly 94 measures the pitch of the blade with respect to the earth's gravity. The sensor assembly 94 may include a potentiometer, an encoder, a resolver, or the like. In the preferred embodiment, the sensor assembly 94 is connected to the circle 85; alternatively, the sensor assembly 94 may be connected to the bellcrank 92. The pitch sensor assembly 94 generates a pitch angle signal, which may be either analog or digital. Alternatively, the pitch sensor assembly 94 may sense the pitch of the blade 104 relative to the machine 108 or 800.

[0038]
The work implement assembly 404 may include a roll sensor assembly 110 for sensing a roll angle of the blade 104. The roll sensor assembly 110 may include any appropriate transducer capable of sensing the rolled position of the blade 104. In an alternative embodiment, the roll sensor assembly 110 and the pitch sensor assembly 94 may be located on the machine frame 106 or 804 and the appropriate translations performed to determine the pitch and roll of the blade 104. Alternatively, the roll sensor assembly 110 may determine a roll angle of the blade relative to the machine.

[0039]
The angle of rotation of the blade 104 relative to the drawbar 80 may be determined by monitoring the position of the circle drive mechanism 82. Alternatively, the work implement sensor system 404 may include a blade rotation sensor 96 for determining the rotation of the blade 104 relative to the drawbar 80.

[0040]
The machine sensor system 402 may include a pitch sensor assembly 112, a roll sensor assembly 114, and an articulation angle sensor assembly 115. The pitch sensor assembly 112 and the roll sensor assembly 114 may be analogous to the pitch and roll sensor assemblies 94 and 110 respectively and may be located on the machine frame 106 or 802 to sense the pitch and roll angles of the machine 108 or 800. In an alternative embodiment, the machine pitch and roll angles may be derived from the sensed pitch and roll angles of the blade 104. The articulation angle sensor assembly may be located on the machine frame 802 to sense the rotation angle of the front frame 804 relative to the rear frame 806.

[0041]
As illustrated in FIG. 5, using the roll sensors 110 and 114, the roll angle φ_{bs }of the blade 104 and the roll angle φ_{ms }of the frame 106 or 802 may be sensed relative to horizontal 502. The angle of rotation ψ_{b }of the blade 104 relative to the frame 106 or 804 may be sensed, as illustrated in FIG. 6. As illustrated in FIGS. 7a and 7 b, using the pitch sensor assemblies 94 and 112, the pitch angle θ_{ms }of the frame 106 or 802 and the pitch θ_{b }of the blade 104 may be sensed relative to horizontal 502. FIG. 7A illustrates an angle of rotation of the circle 85 to be zero degrees for exemplary purposes only. Other circle 85, or blade 104, rotations may be performed and measured accurately using the disclosed embodiment. As illustrated in FIG. 9, the articulation angle ψ_{m }may be sensed relative to the rear frame 806.

[0042]
As illustrated in FIG. 8, in a first embodiment in which the work machine 108 is a nonarticulated motor grader, the direction of travel, {right arrow over (i)}, of the machine 108 may be determined relative to the center axis of the frame 106. As illustrated in FIG. 9, in a second embodiment in which the machine 800 is an articulated motor grader, the direction of travel, {right arrow over (D)}, of the machine 800 is determined relative to the center axis of the rear frame 806.

[0043]
In one embodiment, the cross slope, θ_{cs}, created by a work machine, such as a motor grader, may be described as the slope of a line lying on a surface path, such as a road, which is perpendicular to the direction of the path, as illustrated in FIG. 10.

[0044]
A controller 54 receives signals from the machine sensor system 402 and the work implement sensor system 404, as illustrated in FIG. 11. A microprocessor such as a Motorola 68HC11 may be used as the controller 54. However, other known microprocessors could be readily used without deviating from the scope of the present invention.

[0045]
In the alternative embodiment, as illustrated in FIG. 11, the controller 54 may receive sensed signals from the pitch sensor assemblies 94 and 112 and the roll sensor assemblies 110 and 114. The controller 54 may also receive signals from at least one of a circle drive mechanism 82, a rotary drive motor 84, or a blade rotation sensor assembly 94 to determine the angle of rotation of the blade 104 relative to the drawbar 80.

[0046]
The controller 54 determines a crossslope in response to the sensed parameters. In one embodiment, the controller 54 receives an operatorinitiated desired cross slope signal. For example, the operator may enter a desired crossslope using a keypad (not shown) which delivers the appropriate signal to the controller 54. The actual cross slope may then be compared to the desired cross slope and a cross slope error responsively generated. The cross slope error may be used by the controller 54 to determine the necessary changes and commands that need to be delivered to either the blade 104, drawbar 80, or both to achieve the desired cross slope. The appropriate commands are then delivered by the controller 54 to adjust the cross slope created by the machine 108 or 800. The machine and work implement parameters are continuously sensed, enabling the cross slope to be continuously monitored and adjusted.

[0047]
II. Determining the Cross Slope

[0048]
In one embodiment, the cross slope may be determined as a function of (1) the direction of travel of the machine 108 or 800 and (2) the position of the blade 104. In the first embodiment of the present invention, the drawbar 80 is located symmetrically under the frame 106, the machine 108 is traveling in a straight line of motion, and there is not articulation of the machine 108.

[0049]
In the second embodiment of the present invention, the drawbar 80 is located symmetrically under the front frame 804, the machine 800 is traveling in a straight line of motion, and there is articulation of the machine 800.

[0050]
In both embodiments, for articulated and nonarticulated machines, the method for determining the cross slope created by a work implement on a work machine includes the steps of determining a position of the work implement 104, determining a direction of travel of the machine 108 or 800, and determining the cross slope in response to the direction of travel and the work implement position.

[0051]
A. Determine a Position of the Work Implement

[0052]
In one embodiment, the position of the blade 104 may be determined in response to sensing machine and work implement parameters. Work implement parameters, such as the angle of rotation of the blade 104 relative to the machine 108 or 800 (ψ_{b}), the blade roll φ_{bs }and the blade pitch θ_{bs }may be sensed. In addition, machine parameters, such as the machine roll φ_{ms }and the machine pitch θ_{ms }may be sensed. Further, the roll and pitch of the drawbar 80 may be directly sensed by placing the appropriate sensors on the drawbars.

[0053]
[0053]FIG. 12 illustrates a flow diagram of an alternative method for determining the current position of the blade 104. The current position of the blade 104 may be determined by determining an initial blade position vector 1002, translating the initial blade vector to achieve a theoretical current blade position 1004, and determining the current blade position by correlating the sensed parameters to the theoretical current blade position 1006. This method is appropriate for both articulated and nonarticulated work machines.

[0054]
1. Determining an Initial Blade Position Vector

[0055]
The initial blade vector {right arrow over (P)}_{B} _{ 0 }represents a theoretical initial position of the blade 104. A local, or machine based, coordinate system may be defined as a three dimensional coordinate system established relative to the frame 106 or 802. In one embodiment, the local coordinates may be based on earthbased coordinates. The initial blade vector may be represented as:

{right arrow over (P)}_{B} _{ 0 }≡Initial blade vector=[1 0 0]^{T }

[0056]
where the right hand tip 116 of the blade 104 is at {right arrow over (P)}_{B} _{ 0 }and the center of the blade 104 is at the origin (0,0,0), as illustrated in FIG. 13. The current blade vector may be stated as:

{right arrow over (P)}_{B} _{ 0 }=Final blade vector=└P_{B} _{ x }P_{B} _{ y }P_{B} _{ z┘ } ^{T }

[0057]
2. Achieving a Theoretical Correct Blade Position

[0058]
A theoretical blade position vector may be determined by theoretically translating, or rotating, the machine 108 or 800, drawbar 80, and/or blade 104 through a sequence of maneuvers. That is, a sequence of theoretical work implement translations may be used to translate the implement from a first position, e.g., an initial position, to a second position, e.g., a current blade position. One example of the theoretical sequence of maneuvers is:

[0059]
1. Rotate the blade relative to the machine (ψ_{b});

[0060]
2. Roll the drawbar (φ_{d});

[0061]
3. Pitch the drawbar (θ_{d});

[0062]
4. Roll the mainframe (φ_{m}); and

[0063]
5. Pitch the mainframe (θ_{m})

[0064]
The theoretical translation sequence is illustrated in FIGS. 14
a
14 e. The rotational sequence yields a theoretical blade position:
${\stackrel{\rightharpoonup}{P}}_{B}=\left[\begin{array}{c}{P}_{{B}_{x}}\\ {P}_{{B}_{y}}\\ {P}_{{B}_{z}}\end{array}\right]=\left[\mathrm{Rot}\ue89e\text{\hspace{1em}}\ue89e\_\ue89e\text{\hspace{1em}}\ue89ex\ue89e\text{\hspace{1em}}\ue89e\left({\theta}_{m}\right)\right]\ue89e\text{\hspace{1em}}\left[\mathrm{Rot}\ue89e\text{\hspace{1em}}\ue89e\_\ue89e\text{\hspace{1em}}\ue89ey\ue8a0\left({\phi}_{m}\right)\right]\ue89e\text{\hspace{1em}}\left[\mathrm{Rot}\ue89e\text{\hspace{1em}}\ue89e\_\ue89e\text{\hspace{1em}}\ue89ex\ue89e\text{\hspace{1em}}\ue89e\left({\theta}_{d}\right)\right]\ue89e\text{\hspace{1em}}\left[\mathrm{Rot}\ue89e\text{\hspace{1em}}\ue89e\_\ue89e\text{\hspace{1em}}\ue89ey\ue8a0\left({\phi}_{d}\right)\right]\times \left[\mathrm{Rot}\ue89e\text{\hspace{1em}}\ue89e\_\ue89e\text{\hspace{1em}}\ue89ez\ue8a0\left({\psi}_{b}\right)\right]\xb7{\stackrel{\rightharpoonup}{P}}_{\mathrm{Bo}}$

[0065]
Where Rot_x(θ
_{m}), Rot_y(φ
_{m}), Rot_x(θ
_{d}), Rot_y (φ
_{d}), and Rot_z(ψ
_{b}) are homogeneous transforms. For example, Rot_x(θ
_{m}) may be determined to be:
$\mathrm{Rot}\ue89e\text{\hspace{1em}}\ue89e\_\ue89e\text{\hspace{1em}}\ue89ex\ue8a0\left({\theta}_{m}\right)=\left[\begin{array}{ccc}1& 0& 0\\ 0& \mathrm{cos}\ue8a0\left({\theta}_{m}\right)& \mathrm{sin}\ue8a0\left({\theta}_{m}\right)\\ 0& \mathrm{sin}\ue8a0\left({\theta}_{m}\right)& \mathrm{cos}\ue89e\text{\hspace{1em}}\ue89e\left({\theta}_{m}\right)\end{array}\right]$

[0066]
Homogenous transforms are well known in the art and each transform will not be elaborated on at this point.

[0067]
The theoretical blade vector {right arrow over (P)}_{B }may be simplified by defining the overall transformation matrix as:

H _{b0} ^{b}=Rot_{—} x(θ_{m})Rot_{—} y(φ_{m})Rot_{—} x(θ_{d})Rot_{—} y(φ_{d})Rot_{—} z(ψ_{b})

[0068]
The equation for the theoretical blade position simplifies to:

{right arrow over (P)}
_{B}
=H
_{b0}
^{b}
·{right arrow over (P)}
_{B}
_{
0
}

[0069]
Where:
${H}_{\mathrm{bo}}^{b}=\left[\begin{array}{ccc}h\ue8a0\left(1,1\right)& h\ue8a0\left(1,2\right)& h\ue8a0\left(1,3\right)\\ h\ue8a0\left(2,1\right)& h\ue8a0\left(2,2\right)& h\ue8a0\left(2,3\right)\\ h\ue8a0\left(3,1\right)& h\ue8a0\left(3,2\right)& h\ue8a0\left(3,3\right)\end{array}\right]=\left[\begin{array}{ccc}{h}_{1,1}& {h}_{1,2}& {h}_{1,3}\\ {h}_{2,1}& {h}_{2,2}& {h}_{2,3}\\ {h}_{3,1}& {h}_{3,2}& {h}_{3,3}\end{array}\right]$

[0070]
The matrix elements may be determined by matrix algebra. For example:

h _{1,1}=[cos(φ_{m})cos(ψ_{b})]cos(φ_{d})−[sin(φ_{m})cos(ψ_{b})]cos(θ_{d})sin(φ_{d})+[sin(φ_{m})sin(ψ_{b})]sin(θ_{d})

[0071]
Therefore, the theoretical current blade position vector may be represented as:

{right arrow over (P)}_{b}=<h_{1,1},h_{2,1},h_{3,1}>

[0072]
3. Determining the Current Blade Position

[0073]
The actual current blade position may be determined by correlating the sensed parameters to the theoretical current blade position and determining the actual machine roll and pitch, the actual blade roll and pitch, and the blade rotation.

[0074]
The variables φ_{m}, φ_{d}, θ_{m}, θ_{d}, and ψ_{b }are theoretical translation variables. The sensed variables may be correlated to the translation variables.

[0075]
In the preferred embodiment, the actual machine roll may be determined by initializing a unit vector {circumflex over (ι)}
_{x} _{ m }which is representative of the roll and pitch of the machine starting in the direction î
_{x}, where î
_{x }is the unit vector in the xdirection. The unit vector {circumflex over (ι)}
_{x} _{ m }may be rolled with respect to the Yaxis. Therefore, the actual machine roll may be determined by the following equation:
${\hat{i}}_{{x}_{m}}=\mathrm{Rot}\ue89e\text{\hspace{1em}}\ue89e\_\ue89e\text{\hspace{1em}}\ue89e\mathrm{Pitch}(\text{\hspace{1em}}\ue89e\mathrm{Rot}\ue89e\text{\hspace{1em}}\ue89e\_\ue89e\text{\hspace{1em}}\ue89e\mathrm{Roll}\xb7{\hat{i}}_{x})=\left[\begin{array}{ccc}1& 0& 0\\ 0& \mathrm{cos}\ue8a0\left({\theta}_{m}\right)& \mathrm{sin}\ue8a0\left({\theta}_{m}\right)\\ 0& \mathrm{sin}\ue8a0\left({\theta}_{m}\right)& \mathrm{cos}\ue89e\text{\hspace{1em}}\ue89e\left({\theta}_{m}\right)\end{array}\right]\times \left[\begin{array}{ccc}\mathrm{cos}\ue8a0\left({\phi}_{m}\right)& 0& \mathrm{sin}\ue8a0\left({\phi}_{m}\right)\\ 0& 1& 0\\ \mathrm{sin}\ue8a0\left({\phi}_{m}\right)& 0& \mathrm{cos}\ue8a0\left({\phi}_{m}\right)\end{array}\right]\ue89e\text{\hspace{1em}}\left[\begin{array}{c}1\\ 0\\ 0\end{array}\right]$

[0076]
To isolate the roll component, the dot product of the unit vector {circumflex over (ι)}_{x} _{ m }in the vertical direction may be determined. The resulting actual machine roll equation is:

sin(φ_{m} _{ s })−cos(θ_{m})sin(φ_{m})=0

[0077]
The actual machine pitch may be determined by initializing a unit vector, {circumflex over (ι)}_{y} _{ m }, which is representative of the roll and pitch of the machine in the direction î_{y}. The vector {circumflex over (ι)}_{y} _{ m }is then rolled the amount indicated by the roll sensor and pitched by the amount indicated by the pitch sensor, resulting in:

{circumflex over (ι)}_{y} _{ m } =Rot_Pitch(Rot_Roll( i _{y}))

[0078]
The dot product of the unit vector in the vertical direction may be taken to determine the pitch component of the vector î_{y}. The resulting actual machine pitch is:

sin(θ_{m} _{ s })=sin(θ_{m})

θ_{m}=θ_{m} _{ s }

[0079]
and, by substitution, the machine roll is:
${\phi}_{m}={\mathrm{sin}}^{1}\ue8a0\left[\frac{\mathrm{sin}\ue89e\left({{\phi}_{m}}_{s}\right)}{\mathrm{cos}\ue89e\text{\hspace{1em}}\ue89e\left({\theta}_{{m}_{s}}\right)}\right]$

[0080]
The actual blade roll, φ_{b}, can be computed by determining the angle between the position of the blade 104 and the horizon 502. The blade roll with regard to the horizon (xy plane) is given by:

sin(−φ_{b})=−[H _{b0} ^{b} ·{right arrow over (P)} _{B} _{ 0 }]·{circumflex over (ι)}_{z }

[0081]
Measurement of the actual blade pitch can be computed by determining the angle between a normal blade vector, {right arrow over (N)}_{b}, and the horizon.

{right arrow over (N)}
_{B}
=H
_{b0}
^{b}
·{right arrow over (N)}
_{B}
_{
0
}

[0082]
where:

{right arrow over (N)}_{B} _{ 0 }=[0 1 0]

[0083]
The actual blade pitch, with regard to the horizon (xy plane), may be given by:

sin(θ_{b})=−[H _{b0} ^{b} ·{right arrow over (N)} _{B} _{ 0 }]·{circumflex over (ι)}_{z }

[0084]
The actual drawbar pitch and roll may also be determined. The following analysis is based on the assumption that there is no direct sensing of the drawbar 80 pitch and roll. If there is a direct sensing means, such as a roll or pitch sensor attached to the drawbar 80, then analysis analogous to the above determinations of machine roll and machine pitch may be used to determine drawbar roll and drawbar pitch.

[0085]
If there is no direct sensing of the drawbar pitch θ_{d }and roll φ_{d}, a numerical analysis approach for solving systems of nonlinear equations, such as the NewtonRaphson Method, may be used to solve for them.

sin(φ
_{b})=−[
H _{b0} ^{b} ·{right arrow over (P)} _{B} _{ 0 }]·{right arrow over (ι)}
_{z} ƒ
_{1}(ψ
_{b},θ
_{b},φ
_{b},θ
_{m},φ
_{m},θ
_{d}φ
_{d})=0

sin (−φ
_{b})=−[
H _{b0} ^{b} ·{right arrow over (N)} _{B} _{ 0 }]·{right arrow over (ι)}
_{z} ƒ
_{2}(ψ
_{b},θ
_{b},φ
_{b},θ
_{m},φ
_{m},θ
_{d},φ
_{d})=0

ƒ_{1}(θ_{d},φ_{d})=0

ƒ_{2}(θ_{d},φ_{d})=0

[0086]
Solving for θ
_{d }and φ
_{d }via the NewtonRaphson Method:
$F\ue89e\left({x}_{k}\right)=\left[\begin{array}{c}{f}_{1}\ue8a0\left({x}_{1},{x}_{2}\right)\\ {f}_{2}\ue8a0\left({x}_{1},{x}_{2}\right)\end{array}\right]$ ${x}_{k}=\left[\begin{array}{c}{x}_{1}\\ {x}_{2}\end{array}\right]=\left[\begin{array}{c}{\theta}_{d}\\ {\phi}_{d}\end{array}\right]$ ${x}_{k+1}={x}_{k}{J}_{k}^{1}\xb7F\ue8a0\left({x}_{k}\right)$

[0087]
where J
_{k }represents a Jacobian matrix.
${J}^{1}=\frac{\left[\begin{array}{cc}\frac{\partial {f}_{2}}{\partial {\phi}_{d}}& \frac{\partial {f}_{1}}{\partial {\phi}_{d}}\\ \frac{\partial {f}_{2}}{\partial {\theta}_{d}}& \frac{\partial {f}_{1}}{\partial {\theta}_{d}}\end{array}\right]}{\Delta \ue89e\text{\hspace{1em}}\ue89eJ}$ $\mathrm{Where}\ue89e\text{:}$ $\Delta \ue89e\text{\hspace{1em}}\ue89eJ=\left(\frac{\partial {f}_{1}}{\partial {\theta}_{d}}\right)\ue89e\text{\hspace{1em}}\ue89e\left(\frac{\partial {f}_{2}}{\partial {\phi}_{d}}\right)\left(\frac{\partial {f}_{1}}{\partial {\phi}_{d}}\right)\ue89e\text{\hspace{1em}}\ue89e\left(\frac{\partial {f}_{2}}{\partial {\theta}_{d}}\right)$ $x=\left[\begin{array}{c}{\theta}_{d}\\ {\phi}_{d}\end{array}\right]$
${x}_{0}=\left[\begin{array}{c}{\theta}_{b}\\ {\phi}_{b}\end{array}\right]$

[0088]
For an initial estimate of blade position, the initial drawbar pitch and roll may be assumed to be equal to the initial blade pitch and roll. This assumption provides an initial estimate that may be modified. Alternatively, the last drawbar pitch and roll calculated may be used.

[0089]
Therefore, the actual current blade position may be determined using:

{right arrow over (P)} _{B} _{ x } =h _{1,1} =g _{1}(ψ_{b},θ_{m},φ_{m},θ_{d},φ_{d})

{right arrow over (P)} _{B} _{ y } =h _{2,1} =g _{2}(ψ_{b},θ_{m},φ_{m},θ_{d},φ_{d}), and

{right arrow over (P)} _{B} _{ z } =h _{3,1} =g _{3}(ψ_{b},θ_{m},φ_{m},θ_{d},φ_{d})

[0090]
Where g_{x}(ψ_{b},θ_{m},φ_{m},θ_{d},φ_{d}) represents the functional analysis illustrated above.

[0091]
B. Determining a Direction of Travel of the Machine

[0092]
The current blade position may be used in conjunction with the direction of travel of the machine to determine the cross slope, and the direction of travel of the machine may be represented by a direction path vector {right arrow over (D)}_{t}.

[0093]
1. Nonarticulated Work Machines

[0094]
In the first embodiment, the machine 108 is operating in a nonarticulated manner. Therefore, the direction path vector {right arrow over (D)}_{t }is aligned with the frame 106 and is affected only by the pitch of the machine 108. Therefore, the direction path vector may be given by the following equation:

{right arrow over (D)}_{t}=<0,cos(θ_{m}),sin(θ_{m})>^{T }

[0095]
2. Articulated Work Machines

[0096]
In the second embodiment, the machine 800 is operating in an articulated manner. Therefore, the direction path vector {right arrow over (D)}_{t }is aligned with the rear frame 806, as most easily seen in FIG. 9. Because {right arrow over (D)}_{t }is not aligned with the front frame 804, machine pitch (θ_{m}) machine roll (φ_{m}), and the articulation angle (ψ_{m}) affect the direction vector {right arrow over (D)}_{t}. Therefore, the initial direction path vector is given by the following equation:

{right arrow over (D)} _{t} _{ o }=−sin(ψ_{m})î _{xm}+cos(ψ_{m})î_{ym }

[0097]
After adding the machine pitch and roll, the direction vector is expressed as:

{right arrow over (D)} _{t} =[rot _{—} x(θ_{m})][rot _{—} y(φ_{m})]{right arrow over (D)}_{t} _{ o }

[0098]
which simplifies to:

{right arrow over (D)} _{t} =<d _{tx} ,d _{ty} ,d _{tz}>

[0099]
where

[0100]
d_{tx}=−cos(φ_{m})sin(ψ_{m})

[0101]
d_{ty}=−sin(θ_{m})sin(φ_{m})sin(ψ_{m})+cos(θ_{m})cos(ψ_{m})

[0102]
d_{tz}=cos(θ_{m})sin(φ_{m})sin(ψ_{m})+sin(θ_{m})cos(ψ_{m})

[0103]
C. Determining the Cross Slope

[0104]
The cross slope is a function of the blade position vector and the direction of travel vector:

CrossSlope=ƒ({right arrow over (D)} _{t} ,{right arrow over (P)} _{b})

[0105]
The cross slope, θ_{cs}, may be represented as a vertical measurement that is perpendicular to the direction of travel and is measured with respect to the horizon, as illustrated in FIG. 10. The blade's path as it passed through the cross section of the cut plane may be determined.

[0106]
1. NonArticulated Work Machines

[0107]
In the first embodiment, in which the work machine 108 is not articulated, the cross slope plane may be illustrated as the x_{m}z plane, as shown in FIG. 15. A normal vector that crosses through the cross slope cut plane 1402 may be determined. The normal vector may be determined by taking the cross product of two known vectors that lie within the plane, such as {circumflex over (ι)}_{x} _{ m }, which contains the point {right arrow over (P)}_{B} _{ o }, and {circumflex over (ι)}_{z}, which contains the point (0,0,0) and is part of the earth coordinate system. Therefore:

{right arrow over (N)} _{x} _{ s }={circumflex over (ι)}_{x} _{ m }×{circumflex over (ι)}_{z }

[0108]
Where:

{circumflex over (ι)}_{x} _{m}=Rot_Pitch(Rot_{—Roll({circumflex over (ι)}} _{x}))

[0109]
Resulting in
$\therefore {\stackrel{\rightharpoonup}{N}}_{{x}_{s}}=\left[\begin{array}{c}\mathrm{sin}\ue8a0\left({\theta}_{m}\right)\ue89e\mathrm{sin}\ue8a0\left({\phi}_{m}\right)\\ \mathrm{cos}\ue89e\text{\hspace{1em}}\ue89e\left({i}_{m}\right)\\ 0\end{array}\right]$

[0110]
Therefore, the plane equation containing the point x
_{0}, y
_{0}, z
_{0}=(0,0,0): is
$\left[\mathrm{sin}\ue89e\text{\hspace{1em}}\ue89e\left({\theta}_{m}\right)\ue89e\mathrm{sin}\ue89e\left(\phi \ue89e\text{\hspace{1em}}\ue89em\right)\right]\xb7x+\left[\mathrm{cos}\ue89e\text{\hspace{1em}}\ue89e\left(\phi \ue89e\text{\hspace{1em}}\ue89em\right)\right]\ue89ey=0$

[0111]
Preferably, the machine follows straight line motion, where no angular variables are changing. Therefore, the right blade tip follows a line l:
${I}_{r}:x={P}_{{b}_{x}},\frac{y{P}_{{b}_{y}}}{\mathrm{cos}\ue89e\text{\hspace{1em}}\ue89e\left({\theta}_{m}\right)}=\frac{z{P}_{{b}_{z}}}{\mathrm{sin}\ue89e\text{\hspace{1em}}\ue89e\left({\theta}_{m}\right)}$

[0112]
The cross slope may then be determined by projecting {right arrow over (P)}
_{B }back or forward in time, along the line l
1406, until it intersects the cross slope plane, as illustrated in FIG. 15. The point of intersection (x*, y*, z*)
1404 is:
${x}^{*}={P}_{{b}_{x}},{y}^{*}=\frac{\mathrm{sin}\ue89e\text{\hspace{1em}}\ue89e\left({\theta}_{m}\right)\xb7\mathrm{sin}\ue89e\text{\hspace{1em}}\ue89e\left({\phi}_{m}\right)\xb7{x}^{*}}{\mathrm{cos}\ue89e\text{\hspace{1em}}\ue89e\left({\phi}_{m}\right)},{z}^{*}=\mathrm{tan}\ue89e\left({\theta}_{m}\right)\xb7{P}_{{b}_{y}}+{P}_{{b}_{z}}$

[0113]
The x,y component is the measure of this point along the {circumflex over (ι)}_{x} _{ m }direction. Therefore, the measurement of the x,y component is:

r={square root}{square root over (x*^{2}+y*^{2})}

[0114]
The cross slope created by the work implement
104 of a machine
108 may then be defined as:
$\mathrm{Cross}\ue89e\text{\hspace{1em}}\ue89e\mathrm{Slope}=\frac{{z}^{*}}{\sqrt{{x}^{*2}+{y}^{*2}}}=\frac{\Delta \ue89e\text{\hspace{1em}}\ue89ez}{\Delta \ue89e\text{\hspace{1em}}\ue89er}$

[0115]
2. Articulated Work Machines

[0116]
In the second embodiment, in which the work machine
800 is articulated, the cross slope may also be illustrated as the x
_{m}z plane, as shown in FIG. 15. A normal vector that crosses through the cross slope cut plane
1402 may be determined by taking two known vectors that lie within the plane and calculating the cross product of those vectors. One of the known vectors {circumflex over (ι)}
_{z }contains the point (0,0,0) and lies within the earth coordinate system. The other known vector {circumflex over (ι)}
_{cs }contains the point {right arrow over (P)}
_{B} _{ 0 }.
${\overrightarrow{N}}_{c}={\overrightarrow{i}}_{c}\times {\hat{i}}_{c}=\uf603\begin{array}{ccc}{i}_{x}& 0& 0\\ {i}_{\mathrm{cx}}& {i}_{\mathrm{cy}}& {i}_{\mathrm{cz}}\\ 0& 0& 1\end{array}\uf604$

[0117]
where

{right arrow over (I)} _{c}=[rot_{—} x(θ_{m})][rot _{—} y(φ_{m})]{right arrow over (I)} _{c} _{ 0 }

[0118]
is perpendicular to the direction of travel {right arrow over (D)}_{t }after machine pitch and roll. This results in:

{right arrow over (I)}_{c}=<(i _{cx,} _{cy,} _{cz}>

[0119]
where

[0120]
i_{cx}cos(φ_{m})cos(ψ_{m})

[0121]
i_{cy}=sin(θ_{m})sin(φ_{m})cos(ψ_{m})+cos(θ_{m})sin(ψ_{m})

[0122]
i_{cz}=−cos(θ_{m})sin(φ_{m})cos(ψ_{m})+sin(θ_{m})sin(ψ_{m})

[0123]
The cross product of {right arrow over (I)}
_{c }and {circumflex over (ι)}
_{z }can be performed, yielding the normal vector to the cut plane.
${\overrightarrow{N}}_{c}=\left[\begin{array}{c}{n}_{x}\\ {n}_{y}\\ {n}_{z}\end{array}\right]=\left[\begin{array}{c}\mathrm{cos}\ue89e\text{\hspace{1em}}\ue89e\left({\theta}_{m}\right)\ue89e\mathrm{sin}\ue89e\text{\hspace{1em}}\ue89e\left({\psi}_{m}\right)+\mathrm{sin}\ue89e\text{\hspace{1em}}\ue89e\left({\theta}_{m}\right)\ue89e\mathrm{sin}\ue89e\text{\hspace{1em}}\ue89e\left({\phi}_{m}\right)\ue89e\mathrm{cos}\ue89e\text{\hspace{1em}}\ue89e\left({\psi}_{m}\right)\\ \mathrm{cos}\ue89e\text{\hspace{1em}}\ue89e\left({\phi}_{m}\right)\ue89e\mathrm{cos}\ue89e\text{\hspace{1em}}\ue89e\left({\psi}_{m}\right)\\ 0\end{array}\right]$

[0124]
The projection of the blade tip P
_{b}, along the line l
_{t } 1406, onto the cut plane P
_{c}, occurs at the point (x*,y*,z*)
1404, as seen in FIG. 15. Solving for x, y , and z as a system, the projection line, which the right blade tip follows, is expressed as:
${l}_{t}:\frac{{x}^{*}{P}_{\mathrm{bx}}}{{d}_{\mathrm{tx}}}=\frac{{y}^{*}{P}_{\mathrm{by}}}{{d}_{\mathrm{ty}}}=\frac{{z}^{*}{P}_{\mathrm{bz}}}{{d}_{\mathrm{tz}}}$

[0125]
and the cut plane is expressed as:

P _{c} :n _{x}(x*−0)+n _{y}(y*−0)+n _{z}(z*−0)=0

[0126]
The cross slope may be determined by projecting {right arrow over (P)}
_{B }back or forward in time, along the line l
1406, until it intersects the cross slope plane, as seen in FIG. 15. The point of intersection (x* ,y ,z)
1404 is:
${y}^{*}=\frac{{n}_{x}\ue89e{a}_{0}{n}_{z}\ue89e{b}_{0}}{{n}_{x}\ue89e{a}_{1}+{n}_{y}\ue89e{b}_{1}+{n}_{y}}$ ${x}^{*}\ue89e\underset{\underset{{a}_{1}}{\uf613}}{\left[\frac{{d}_{\mathrm{tx}}}{{d}_{\mathrm{ty}}}\right]}\ue89e{y}^{*}+\underset{\underset{{a}_{0}}{\uf613}}{\left[{P}_{\mathrm{bx}}\frac{{d}_{\mathrm{tx}}}{{d}_{\mathrm{ty}}}\ue89e{P}_{\mathrm{by}}\right]}={a}_{1}\ue89e{y}^{*}+{a}_{0}$ ${z}^{*}\ue89e\underset{\underset{{b}_{1}}{\uf613}}{\left[\frac{{d}_{\mathrm{tz}}}{{d}_{\mathrm{ty}}}\right]}\ue89e{y}^{*}+\underset{\underset{{b}_{0}}{\uf613}}{\left[{P}_{\mathrm{bz}}\frac{{d}_{\mathrm{tz}}}{{d}_{\mathrm{ty}}}\ue89e{P}_{\mathrm{by}}\right]}={b}_{1}\ue89e{y}^{*}+{b}_{0}$

[0127]
The x,y component is the measure of this point in the î_{cs }direction. Therefore, the measurement of the x,y component is:

r+{square root}{square root over (x*^{2}+y*^{2})}

[0128]
The cross slope created by the blade
104 of the machine
800 may then be defined as:
${X}_{z}=\frac{\Delta \ue89e\text{\hspace{1em}}\ue89eZ}{\Delta \ue89e\text{\hspace{1em}}\ue89eR}=\frac{{z}^{*}}{\sqrt{{\left({x}^{*}\right)}^{2}+{\left({y}^{*}\right)}^{2}}}$

[0129]
Industrial Applicability

[0130]
The present invention provides a method and apparatus for determining the cross slope created by a work implement on a work machine. In a first embodiment, the method includes the steps of determining a position of the work implement, determining a direction of travel of the machine, and determining a cross slope in response to the direction of travel and the work implement position.

[0131]
In a second embodiment, a plurality of machine parameters, such as the roll of the machine, and work implement parameters, such as the angle of rotation of the work implement relative to the machine, are used to determine the position of the work implement.

[0132]
In a third embodiment, the actual cross slope is determined and then compared to a desired cross slope. The desired cross slope may be determined in response to either an operator input or a program that is providing automated control of some or all of the grading functions of the motor grader. The machine 108 or 800 and/or the blade 104 may be controlled in response to the desired and actual cross slope. For example, if an error exists between the actual and desired cross slope, the implement commands may be determined which will bring the actual cross slope to within a threshold of the desired cross slope. The threshold may be determined based on the desired accuracy of the system.

[0133]
Other aspects, objects, and features of the present invention can be obtained from a study of the drawings, the disclosure, and the appended claims.