This disclosure relates generally to automated movement of a component and, more particularly, to a system and method for controlling and optimizing automated movement of a work tool or component along a three dimensional path.
Automated or autonomous movement of mechanisms and machines is increasingly desirable for many operations including those related to earthmoving and other industrial activities. Automated machines remain consistently productive without regard to a human operator or environmental conditions. In addition, automated or autonomous systems may permit operation in environments that are unsuitable or undesirable for a human operator. Such automated or autonomous systems may also compensate for inexperienced human operators as well as inefficiencies associated with repetitive tasks.
A system is known that generates a path for automated movement of a machine along a two dimensional path. Such system operates by determining a desired target and calculating a new velocity based upon the current velocity of the machine and the desired target. The process is repeated and, as the machine moves, a new path is generated so as to create a plurality of velocity vectors that define a path of movement along the two dimensional path.
Automated or autonomous movement along a three dimensional path creates additional complexities and thus systems incorporating such movement are typically limited in their operation. U.S. Pat. No. 6,968,264 discloses a system for controlling a mechanical arm of a machine. A controller operates to determine the most suitable path from an existing database. The controller then defines the velocity commands needed to follow the chosen path, and adds a correction velocity command based upon positional error to maintain the arm along the path. Movement of the arm, however, is limited to pre-defined paths.
The foregoing background discussion is intended solely to aid the reader. It is not intended to limit the innovations described herein, nor to limit or expand the prior art discussed. Thus, the foregoing discussion should not be taken to indicate that any particular element of a prior system is unsuitable for use with the innovations described herein, nor is it intended to indicate that any element is essential in implementing the innovations described herein. The implementations and application of the innovations described herein are defined by the appended claims.
In one aspect, a system for automated movement of a component along a three dimensional path is provided. The system includes a movable component having a reference point and a controller configured to store a three dimensional path. The controller is further configured to determine a velocity vector extending generally from a position of the reference point generally in a direction of movement of the reference point and to determine a look ahead vector extending generally from the position of the reference point generally towards a look ahead point. The look ahead point is located generally along the three dimensional path. The controller also is configured to determine a plane of travel on which the velocity vector and the look ahead vector lie, to determine a directional vector of the reference point along the plane of travel, and to determine a command vector directing movement of the reference point at least in part based upon the directional vector.
In another aspect, a system for automated movement of a component along a three dimensional path is provided. The system includes a movable component having a reference point and a controller configured to store a three dimensional path. The controller is further configured to determine a plane of travel generally along which movement of the reference point is desired and to determine a velocity vector extending from a position of the reference point generally in a direction of movement of the reference point. The controller is further configured to determine a look ahead vector extending generally from the position of the reference point generally towards a look ahead point with the look ahead point being located generally along the three dimensional path and scale the velocity vector and the look ahead vector to define a scaled velocity vector and a scaled look ahead vector. The scaled velocity vector and the scaled look ahead vector have identical magnitudes. The controller is also configured to determine a directional vector of the reference point along the plane of travel based upon the scaled velocity vector and the scaled look ahead vector, and to determine a command vector directing movement of the reference point at least in part based upon the directional vector.
In another aspect, a method of moving a component along a three dimensional path in an automated manner is provided. The method includes providing a movable component having a reference point and storing a three dimensional path. A velocity vector extending generally from a position of the reference point generally in a direction of movement of the reference point is determined. A look ahead vector extending generally from the position of the reference point towards a look ahead point is determined. The look ahead point is located generally along the three dimensional path. A plane of travel on which the velocity vector and the look ahead vector lie is determined. A directional vector of the reference point along the plane of travel is determined and a command vector directing movement of the reference point is determined at least in part based upon the directional vector.
Implement system 12 may include a linkage structure utilizing fluid actuators to move work tool 13. More specifically, implement system 12 may include a boom member 14 vertically pivotal relative to frame 15 and propelled by a pair of adjacent, double-acting, boom hydraulic cylinders 16. Implement system 12 may also include a stick member 17 vertically pivotal about a horizontal axis through boom member 14 and stick member 17 and propelled by a single, double-acting, stick hydraulic cylinder 18. Implement system 12 may further include a single, double-acting, work tool hydraulic cylinder 21 operatively connected to work tool 13 to pivot work tool 13 vertically about a horizontal axis through stick member 17 and work tool 13. Frame 15 may be horizontally pivotally connected relative to an undercarriage member 22, and moved about vertical axis by a swing motor 23 (
Numerous different work tools 13 may be attachable to machine 10 and controllable through an operator station 24. In addition to the bucket depicted in
Operator station 24 may include one or more operator input devices such as single or multi-axis joysticks 25 (
Control system 30 may also include a controller 36 in communication with operator input devices 26 and the control valves to coordinate the movements described above. The controller 36 may be an electronic controller that operates in a logical fashion to perform operations, execute control algorithms, store and retrieve data and other desired operations. The controller 36 may include or access memory, secondary storage devices, processors, and any other components for running an application. The memory and secondary storage devices may be in the form of read-only memory (ROM) or random access memory (RAM) or integrated circuitry that is accessible by the controller. Various other circuits may be associated with the controller such as power supply circuitry, signal conditioning circuitry, driver circuitry, and other types of circuitry.
The controller 36 may be a single controller or may include more than one controller disposed to control various functions and/or features of the machine 10. The term “controller” is meant to be used in its broadest sense to include one or more controllers and/or microprocessors that may be associated with the machine 10 and that may cooperate in controlling various functions and operations of the machine. The functionality of the controller 36 may be implemented in hardware and/or software without regard to the functionality.
The controller 36 may rely on one or more maps relating the input device position signal, desired actuator speed or force, associated flow rates and pressures, and/or valve element positions associated with movement of the hydraulic cylinders and swing motor may be stored in the memory of controller 36. Each of these maps may include a collection of data in the form of tables, graphs, and/or equations. In one example, desired speed and commanded flow rate may form the coordinate axis of a two dimensional table for controlling the first and second chamber supply and drain elements described above. The commanded flow rate required to move the fluid actuators at the desired speed and the corresponding valve element position of the appropriate supply and drain elements may be related in another separate two dimensional map or together with desired speed in a single three dimensional map. It is also contemplated that desired actuator speed may be directly related to the valve element position in a single two dimensional map. Controller 36 may be configured to allow the operator of machine 10 to directly modify these maps and/or to select specific maps from available relationship maps stored in the memory of controller 36 to affect fluid actuator motion. It is contemplated that the maps may additionally or alternatively be automatically selectable based on modes of machine operation, if desired.
Control system 30 may be equipped with one or more sensors 37 for monitoring the position and velocity of the various components of machine 10. In one example, the sensors 37 may be position sensors associated with each of hydraulic cylinders to determine the amount of displacement of each cylinder. In another example, the sensors 37 may be angle sensors associated with the pivot joints of implement system 12. In another example, the sensors 37 may be inclinometers and/or gyroscopes. The sensors 37 may also include tilt sensors configured to detect a pitch and a roll of frame 15 and may include sensors for determining the position and orientation of the machine relative to a local or global reference such as by using, for example, a local laser system or one or more global position system (“GPS”) sensors. In some instances, a pair of GPS sensors may be used. In other instances, a single GPS sensor may be used to determine global position together with a compass to determine orientation. In addition, the sensors 37 may include elements capable of determining velocity or angular velocity as well as load sensors configured to detect a payload of work tool 13 (i.e., a mass of material contained within and transported by work tool 13). The combination of sensors may be chosen as desired for the particular needs and applications of machine 10.
Based on signals generated from the sensors and based on known kinematics of machine 10, controller 36 is configured to command the control valves to move or position the work tool 13 at the speeds and/or forces desired by the operator. In addition, based on the signals generated by the sensors, controller 36 may be able to derive and record some or all of the positions, velocities, accelerations, orientations, masses, and/or inertias of implement system 12.
Machine 10 and control system 30 may be configured to include a system for automated or autonomous movement of the work tool 13 so as to perform various tasks in an automated manner. In one example, a work tool 13 may be moved along a three dimensional path to perform a desired task. The three dimensional path may be defined by or include a plurality of points along the path.
Referring to
Referring to
Referring back to
Once the system has been initialized, the system may also conduct various tests to confirm that the system and components of machine 10 are operating properly at decision stage 46. If any of the system or components of machine 10 are not operating properly, the controller 36 may stop the machine 10 and notify the operator of an error at stage 47.
If the system and components of machine 10 are operating properly at decision stage 46, the controller may determine whether any of the hydraulic cylinders or actuators have reached their end of travel positions at decision stage 48. If any of the actuators have reached their end travel positions, movement of the work tool 13 may be limited or prevented so that reference point 19 will no longer be able to move along three dimensional path 85. In such case, the controller 36 may stop the machine 10 at stage 47 and notify the operator of an error.
If none of the actuators have reached their end of travel positions, the controller 36 may determine at decision stage 51 whether the linkage structure is in danger of colliding with the machine 10 or another obstacle so as to create a blockage of the linkage. If the controller 36 determines that the any components of the linkage structure are in danger of colliding with the machine 10 or another obstacle, the controller 36 may stop the machine at stage 47 and notify the operator of an error. If no collision or blockage is likely to occur, the controller 36 may generate command signals at stage 52 to direct the various components of the linkage assembly and thus work tool 13 along a desired path so that the reference point 19 moves along three dimensional path 85.
Referring to
At stage 61, the sensors on machine 10 including those associated with the implement system 12 such as work tool 13, boom member 14, and stick member 17 and movement of frame 15 relative to undercarriage member 22 are monitored or read and the data provided to controller 36. By using the data from the sensors, the controller 36 may determine at stage 62 the current position and the velocity of the reference point 19 on the work tool 13. The current position and velocity of the reference point 19 may be determined using kinematic equations based upon the data from the sensors and in view of the dimensions, positions and movement of the components of the machine 10 and implement system 12. The velocity of the reference point 19 is indicated as velocity vector VR in
At stage 63, the controller determines the closest point or near point 86 on three dimensional path 85 to the reference point 19 of the work tool 13. To do so, the distance from the reference point 19 to each segment along the three dimensional path 85 is determined. The calculation to determine the distance from the reference point 19 to each segment is repeated for each segment. To calculate the shortest distance between the reference point 19 and three dimensional path 85, the distance between each segment of the path and the reference point 19 is determined. As shown in
Based upon the results of the dot product, the vector from the near point 86 on the three dimensional path 85 to the reference point 19 may be determined in three different manners. If the dot product is negative, the projection 88 of vector V1R is along a line through vector V12 but before the first point P1 as depicted in
If the dot product is positive and greater than the length of the vector V12, the projection 88 of vector V1R onto the vector V12 intersects with a line through the vector V12 but after the second point P2 as depicted in
Referring back to
V
NR
=V
1R(V1R·V12)V12
where the “·” represents the dot product or scalar product function.
Referring to
To save computational time, the controller 36 may be configured to store the near point 86 from the previous control loop and only search segments starting at that location and moving forward along the three dimensional path 85 for a predetermined distance. This may not only reduce computation time by preventing the controller 36 from searching every segment along the three dimensional path 85, but also reduce errors if the path has been generated with a configuration that loops back or is otherwise configured so that segments cross over each other as depicted in the alternate path 92 of
Once the near point 86 on the three dimensional path 85 is known, a target or look ahead point 89 may be determined at stage 64. The look ahead point 89 may be determined by starting at the near point 86 as determined at stage 63 and moving forward a predetermined distance along the path. The predetermined distance may be set within the controller 36 as a fixed distance or may vary along three dimensional path 85 as a variable distance. In either case, the controller 36 determines the look ahead point 89 along the three dimensional path 85. Adjusting the distance from the near point 86 to the look ahead point 89 may affect the continuity or “smoothness” of the path of travel of the reference point 19. In general, increasing the distance to the look ahead point 89 will increase the smoothness of the movement of the reference point 19 but may reduce the accuracy by which the work tool follows the three dimensional path 85. Similarly, decreasing the distance to the look ahead point 89 will generally increase the accuracy by which the reference point 19 follows the three dimensional path 85 but may reduce the smoothness of the movement.
As shown in
At decision stage 66, the controller 36 determines whether the velocity vector VR of the reference point 19 is non-zero. If the velocity vector VR is zero, the work tool 13 is not moving and thus the impact of the momentum of the implement system 12 and work tool 13 is reduced and the reference point 19 may be moved at stage 67 directly towards the look ahead point 89 (i.e., along the look ahead vector VRA).
If the velocity of the reference point 19 is greater than zero at stage 66, it may not be desirable to move to reference point 19 directly towards the look ahead point due to the momentum of the implement system 12 and work tool 13. To determine the direction generally within the plane of travel that the reference point 19 should be moved, the controller determines at stage 68 the angle θ between the velocity vector VR and the look ahead vector VRA. At stage 68, the angle θ between the vector VR and the vector VRA may be determined based upon the following equation:
If the absolute value of angle θ is greater than 90°, such angle θ may be limited to 90° while maintaining its positive or negative sign. So limiting angle θ will generally simplify the calculations involving angle θ and, as discussed below relative to stage 72, the speed of the reference point 19 may be significantly limited for any angle θ of 80° or larger so that limiting angle angle θ to 90° will not significantly impact the performance of the system or movement of reference point 19.
At stage 71, the direction of the desired movement (depicted as directional vector VD in
where VC is the connecting vector between velocity vector VR and scaled look ahead vector V′RA and d is the distance along connecting vector VC between velocity vector VR and directional vector VD. If desired, the velocity vector VR that reflects the velocity of the reference point 19 and the look ahead vector VRA that extends from the reference point 19 to the look ahead point 89 may be redrawn as depicted in
If desired, the velocity vector VR may be scaled so as to have the same length as the look ahead vector VRA. Stated another way, the velocity vector and the look ahead vector may be scaled to define a scaled velocity vector and a scaled look ahead vector that have identical magnitudes. In any case, setting the two vectors so they have identical lengths may be desirable to simplify subsequent calculations.
As may be seen in
φ=ω/f
where the ω is the angular rate of the reference point 19 and f is the sample rate frequency of the system. The angular rate ω is equal to the curvature γ times the desired speed sd of the reference point 19. The sample rate frequency f is the inverse of the control loop time. The curvature γ of the path of circle 93 between reference point 19 and look ahead point 89 may be determined by the following equation:
From
x=|V
RA|sin(θ)
Substituting one equation into the other results in:
Noting that the velocity vector VR and the scaled look ahead vector V′R, are equal in length, the angles α opposite θ are equal. Accordingly, angle α may be determined by the following equation:
α=(π−θ)/2
The sum of angle φ, angle α and angle β must equal 180°. Therefore, the angle β may be expressed as a function of φ and angle α as follows:
Through the use of angle β and angle φ as well as the length of velocity vector VR and the Law of Sines, the length d may be determined by the following formula
Connecting vector VC may be expressed as follows:
V
C
=V′
RA
−V
R
Knowing the length d and the connecting vector VC as well as the velocity vector VR allows the calculation of directional vector VD by determining the vector along connecting vector VC having a length d and then adding that to the velocity vector VR as follows:
During operation or during the set up process, an operator may designate a desired speed for each segment or series of segments along three dimensional path 85. At stage 72, the controller 36 may limit the desired speed based upon the value of angle θ. The angle θ reflects the difference between the direction that the reference point 19 is moving (i.e., along the velocity vector VR) and the path directly to the target or look ahead point 89 (i.e., along the look ahead vector VRA). Accordingly, the smaller the angle θ, the more aligned the current direction of movement of the reference point 19 is with the desired direction towards look ahead point 89. As angle θ increases, the controller 36 may be configured to slow the movement of the work tool 13 and thus reference point 19 because a command to move the work tool towards look ahead point 89 will require a substantial change in direction. Without a reduction in speed for a relatively large angle θ, the desired change in direction coupled with the momentum of the implement system 12 and work tool 13 may result in command signals from controller 36 that cannot be followed or possibly cause an abrupt movement of the work tool. In one example, with an angle θ equal to 60°, the full desired speed along three dimensional path 85 may be used without a reduction. An angle θ equal to 70° may result in a reduction in the desired speed of approximately 50 percent and an angle θ equal to 80° may result in a reduction in desired speed by approximately 90 percent. In other words, the controller 36 may reduce the speed of reference point 19 if the angle θ exceeds a predetermined amount.
At stage 73, the directional velocity VD may also be limited based upon the speed of the reference point 19 or the magnitude of the velocity vector VR. If the speed of reference point 19 is relatively slow (i.e., the magnitude of the velocity vector VR is relatively small), as discussed with respect to stage 67 in which the velocity vector VR was zero, the directional vector VD may be modified so as to direct the reference point 19 towards look ahead point 89 in a more direct manner due to the reduced impact of the momentum of the implement system 12 and work tool 13. For example, at stage 67, if the reference point velocity were zero, the command velocity VCMD would be directly towards the look ahead point 89. The controller 36 may be configured so that as the speed of the velocity vector VR increases, the direction of the command vector VCMD is relatively quickly redirected from being aligned with the look ahead vector VRA to being aligned with the directional vector VD. In other words, once the speed of the reference point exceeds a predetermined speed, the command vector VCMD is aligned with the directional vector VD. In one example, the command vector VCMD may be aligned with the look ahead vector VRA when the speed of the velocity vector VR is relatively slow (e.g., <0.1 meters/second). The command vector may be redirected towards the directional vector VD relatively quickly as the speed of the velocity vector VR increases. In such example, the command vector VCMD may be aligned with the directional vector VD when the speed of the velocity vector VR is greater than 0.2 meters/second. The transition between alignment with the look ahead vector VRA (at <0.1 meters/second) and aligned with the directional vector VD (at 0.2 meters/second) may be linear between the two examples, if desired.
At stage 74, the command vector VCMD may be generated by multiplying the desired speed sd times a unit vector of the directional vector VD as follows:
Once the command vector VCMD has been generated, the controller 36 may use inverse kinematic equations to determine the desired positions for the various hydraulic cylinders at stage 75. Based upon the current positions of the hydraulic cylinders and the desired positions determined at stage 75, the controller 36 at decision stage 76 determines whether the generated command signals will cause any of the hydraulic cylinders to move in a manner beyond their operating parameters. For example, the controller 36 may determine whether any of the hydraulic cylinders have been directed to move at a rate faster than a predetermined maximum rate or any of the cylinders will reach their end of travel positions. If the command signals generated would cause any of the hydraulic cylinders to move faster than a predetermined maximum rate, the controller 36 may reduce the speed or de-rate the commands to each of the hydraulic cylinders at stage 77. The modified command signals are then transmitted at stage 81 to the control system for controlling operation of the hydraulic cylinders. If the hydraulic cylinders will remain within their operating parameters based upon the command signals generated at stage 75, the controller will transmit those command signals to the control system at stage 81 to control the hydraulic cylinders.
Referring back to
The industrial applicability of the control system described herein will be readily appreciated from the foregoing discussion. The foregoing discussion is applicable to machines 10 that include an implement such as a work tool 13 that is moveable along a three dimensional path. In one example, the machine 10 may be an excavator including a hammer as a work tool. The machine 10 and the system disclosed herein may be used to break apart a structure such as a concrete sidewalk. The machine 10 may be positioned along the sidewalk at a first position and the hammer moved downward to break the concrete. After moving downward a predetermined distance, the hammer may be raised to a predetermined height and moved laterally to a second point along the path. The process may be completed with the hammer breaking up the concrete at predetermined positions along the path.
In another example, the work tool 13 may be a bucket and the machine 10 positioned to dig in a designated area and then dump each bucketful of material, at a predetermined location. Sensors may be provided so that the profile or three dimensional map of the area at which the machine 10 is digging may be updated during the digging operation. In one example, as the machine 10 is moving the bucket to a dump site, the sensors may sense the revised profile and create an updated map. The system may then generate a new desired path of travel indicative of the change of profile of the ground due to the digging operation. After the revised path of travel has been generated, the system may continue in an automated manner as disclosed herein.
It will be appreciated that the foregoing description provides examples of the disclosed system and technique. However, it is contemplated that other implementations of the disclosure may differ in detail from the foregoing examples. All references to the disclosure or examples thereof are intended to reference the particular example being discussed at that point and are not intended to imply any limitation as to the scope of the disclosure more generally. All language of distinction and disparagement with respect to certain features is intended to indicate a lack of preference for those features, but not to exclude such from the scope of the disclosure entirely unless otherwise indicated.
Recitation of ranges of values herein are merely intended to serve as a shorthand method of referring individually to each separate value falling within the range, unless otherwise indicated herein, and each separate value is incorporated into the specification as if it were individually recited herein. All methods described herein can be performed in any suitable order unless otherwise indicated herein or otherwise clearly contradicted by context.
Accordingly, this disclosure includes all modifications and equivalents of the subject matter recited in the claims appended hereto as permitted by applicable law. Moreover, any combination of the above-described elements in all possible variations thereof is encompassed by the disclosure unless otherwise indicated herein or otherwise clearly contradicted by context.