裝配圖機器人基礎教程
裝配圖機器人基礎教程,裝配,機器人,基礎教程
Chapter 7 Robot control The problem of robot control can be explained as a computation of the forces or torques which must be generated by the actuators in order to successfully ac- complish the robot task. The appropriate working conditions must be ensured both during the transient period as well as in the stationary state. The robot task can be presented either as the execution of the motions in a free space, where position con- trol is performed, or in contact with the environment, where control of the contact force is required. First, we shall study the position control of a robot mechanism which is not in contact with its environment. Then, in the further text we shall up- grade the position control with the force control. The problem of robot control is not unique. There exist various methods which differ in their complexity and in the effectiveness of robot actions. The choice of the control method depends on the robot task. An important difference is, for ex- ample, between the task where the robot end-effector must accurately follow the prescribed trajectory (e.g. laser welding) and another task where it is only required that the robot end-effector reaches the desired final pose, while the details of the trajectory between the initial and the final point are not important (e.g. palletizing). The mechanical structure of the robot mechanism also influences the selection of the appropriate control method. The control of a cartesian robot manipulator in general differs from the control of an anthropomorphic robot. Robot control usually takes place in the world coordinate frame, which is defined by the user and is called also the coordinate frame of the robot task. Instead of world coordinate frame we often use a shorter expression, namely external coordinates. We are predominantly interested in the pose of the robot end-effector expressed in the external coordinates and rarely in the joint positions, which are also called internal coordinates. Nevertheless, we must be aware that in all cases we directly control the internal coordinates i.e. joint angles or displacements. The end-effector pose is only controlled indirectly. It is determined by the kinematic model of the robot mechanism and the given values of the internal coordinates. Figure 7.1 shows a general robot control system. The input to the control system is the desired pose of the robot end-effector, which is obtained by using trajectory interpolation methods, introduced in the previous chapter. The variable x r represents T. Bajd et al., Robotics, Intelligent Systems, Control and Automation: Science 77 and Engineering 43, DOI 10.1007/978-90-481-3776-3_7, c?Springer Science+Business Media B.V. 2010 78 7 Robot control x r q + + – x Actuators Sensors q r Trajectory planning uInverse kinematics Control t Robot mechanism q ~ Fig. 7.1 A general robot control system x y z y J j Fig. 7.2 The RPY description of the orientation the desired, i.e. the reference pose of the robot end-effector. The x vector, describing the actual pose of the robot end-effector in general comprises six variables. Three of them define the position of the robot end-point, while the other three determine the orientation of the robot end-effector. Thus, we write x = bracketleftbig xyz??ψ bracketrightbig T .The position of the robot end-effector is determined by the vector from the origin of the world coordinate frame to the robot end-point. The orientation of the end-effector can be presented in various ways. One of the possible descriptions is the so called RPY notation, arising from aeronautics and shown in Figure 7.2. The orientation is determined by the angle ? around the z axis (Roll), the angle ? around the y axis (Pitch) and the angle ψ around the x axis (Yaw). By the use of the inverse kinematics algorithm, the internal coordinates q r , corresponding to the desired end-effector pose, are calculated. The variable q r rep- resents the joint position, i.e. the angle ? for the rotational joint and the distance d for the translational joint. The desired internal coordinates are compared to the ac- tual internal coordinates in the robot control system. On the basis of the positional error ?q, the control system output u is calculated. The output u is converted from a digital into an analogue signal, amplified and delivered to the robot actuators. The actuators ensure the forces or torques necessary for the required robot motion. The robot motion is assessed by the sensors which were described in the chapter devoted to robot sensors. 7.1 Control of the robot in internal coordinates 79 7.1 Control of the robot in internal coordinates The simplest robot control approach is based on controllers where the control loop is closed separately for each particular degree of freedom. Such controllers are suitable for control of independent second order systems with constant inertial and damp- ing parameters. This approach is less suitable for robotic systems characterized by nonlinear and time varying behavior. 7.1.1 PD control of position First, a simple proportional-derivative (PD) controller will be analyzed. The basic control scheme is shown in Figure 7.3. The control is based on calculation of the positional error and determination of control parameters, which enable reduction or suppression of the error. The positional error is reduced for each joint separately, which means that as many controllers are to be developed as there are degrees of freedom. The reference positions q r are compared to the actual positions of the robot joints q ?q = q r ?q. (7.1) The positional error ?q is amplified by the proportional position gain K p . As a robot manipulator has several degrees of freedom, the error ?q is expressed as a vector, while K p is a diagonal matrix of the gains of all joint controllers. The calculated control input provokes robot motion in the direction of reduction of the positional error. As the actuation of the robot motors is proportional to the error, it can occur that the robot will overshoot instead of stopping in the desired position. Such over- shoots are not allowed in robotics, as they may result in collisions with objects in the robot vicinity. To ensure safe and stable robot actions, a velocity closed loop is introduced with a negative sign. The velocity closed loop brings damping into the system. It is represented by the actual joint velocities ˙q multiplied by a diagonal matrix of velocity gains K d . The control law can be written in the following form K p q r q Robot+ + K d + – + – uq ~ q . Fig. 7.3 PD position control with high damping 80 7 Robot control K p q r q Robot+ + K d + + + – + + – u q r . q . q . ~ q ~ Fig. 7.4 PD position control u = K p (q r ?q)?K d ˙q, (7.2) where u represents the control inputs, i.e. the joint forces or torques, which must be provided by the actuators. From equation (7.2) we can notice that at higher veloc- ities of robot motions, the velocity control loop reduces the joint actuation and, by damping the system, ensures robot stability. The control method shown in Figure 7.3 provides high damping of the system in the fastest part of the trajectory, which is usually not necessary. Such behavior of the controller can be avoided by upgrading the PD controller with the reference velocity signal. This signal is obtained as the numerical derivative of the desired position. The velocity error is used as control input ˙ ?q = ˙q r ? ˙q. (7.3) The control algorithm demonstrated in Figure 7.4 can be written as u = K p (q r ?q)+K d (˙q r ? ˙q). (7.4) As the difference between the reference velocity ˙q r and ˙q is used instead of the total velocity ˙q, the damping effect is reduced. For a positive difference the control loop can even accelerate the robot motion. The synthesis of the PD position controller consists of determining the matrices K p and K d . For fast response, the K p gains must be high. By proper choice of the K d gains, critical damping of the robot systems is obtained. The critical damping ensures fast response without overshoot. Such controllers must be built for each joint separately. The behavior of each controller is entirely independent of the controllers belonging to the other joints of the robot mechanism. 7.1.2 PD control of position with gravity compensation In the chapter on robot dynamics we found that the robot mechanism is under the influence of inertial, Coriolis, centripetal and gravitational forces (4.46). In general 7.1 Control of the robot in internal coordinates 81 also friction forces, occurring in robot joints, must be included in the robot dynamic model. In a somewhat simplified model, only viscous friction, being proportional to the joint velocity, will be taken into account (F v is a diagonal matrix of the joint fric- tion coefficients). The enumerated forces must be overcome by the robot actuators which is evident from the following equation, similar to equation (4.46) B(q)¨q + C(q, ˙q)˙q + F v ˙q + g(q)=τ. (7.5) When developing the PD controller, we did not pay attention to the specific forces influencing the robot mechanism. The robot controller calculated the required actu- ation forces solely on the basis of the difference between the desired and the actual joint positions. Such a controller cannot predict the force necessary to produce the desired robot motion. As the force is calculated from the positional error, this means that in general the error is never equal to zero. When knowing the dynamic robot model, we can predict the forces which are necessary for the performance of a par- ticular robot motion. These forces are then generated by the robot motors regardless of the positional error signal. In quasi-static conditions, when the robot is moving slowly, we can assume zero accelerations ¨q ≈ 0 and velocities ˙q ≈ 0. The robot dynamic model is simplified as follows τ ≈ g(q). (7.6) According to equation (7.6), the robot motors must above all compensate the gravity effect. The model of gravitational effects ?g(q) (the circumflex denotes the robot model), which is a good approximation of the actual gravitational forces g(q), can be implemented in the control algorithm as shown in Figure 7.5. The PD controller, showninFigure7.3, was upgraded with an additional control loop, which calculates the gravitational forces from the actual robot position and directly adds them to the controller output. The control algorithm shown in Figure 7.5 can be written as follows u = K p (q r ?q)?K d ˙q + ?g(q). (7.7) K p q r q + u+ + Robot+ + K d + – + – q g(q) ^ q . ~ Fig. 7.5 PD control with gravity compensation 82 7 Robot control By introducing gravity compensation, the burden of reducing the errors caused by gravity, is taken away from the PD controller. In this way the errors in trajectory tracking are significantly reduced. 7.1.3 Control of the robot based on inverse dynamics When studying the PD controller with gravity compensation, we investigated the robot dynamic model in order to improve the efficiency of the control method. With the control method based on inverse dynamics, this concept will be further upgraded. From the equations describing the dynamic behavior of a two-segment robot ma- nipulator (4.46), we can clearly observe that the robot model is nonlinear. A linear controller, such as the PD controller, is therefore not the best choice. We shall derive the new control scheme from the robot dynamic model described by equation (7.5). Let us assume that the torques τ, generated by the motors, are equal to the control outputs u. Equation (7.5) can be rewritten B(q)¨q + C(q, ˙q)˙q + F v ˙q + g(q)=u. (7.8) In the next step we will determine the direct robot dynamic model, which describes robot motions under the influence of the given joint torques. First we express the acceleration ¨q from equation (7.8) ¨q = B ?1 (q)(u?(C(q, ˙q)˙q + F v ˙q + g(q))). (7.9) By integrating the acceleration, while taking into account the initial velocity value, the velocity of robot motion is obtained. By integrating the velocity, while taking into account the initial position, we calculate the actual positions in the robot joints. The direct dynamic model of a robot mechanism is shown in Figure 7.6. In order to simplify the dynamic equations, we shall define a new variable n(q, ˙q) comprising all dynamic components except the inertial component n(q, ˙q)=C(q, ˙q)˙q + F v ˙q + g(q). (7.10) The robot dynamic model can be described with the following shorter equation B(q)¨q + n(q, ˙q)=τ. (7.11) In the same way also equation (7.9) can be written in a shorter form ¨q = B ?1 (q)(u?n(q, ˙q)). (7.12) Let us assume that the robot dynamic model is known. The inertial matrix ? B(q) is an approximation of the real values B(q), while ?n(q, ˙q) represents an approximation of n(q, ˙q) as follows 7.1 Control of the robot in internal coordinates 83 B –1 (q) + + – q F g(q) u Robot + + + + + + n(q, q) . q¨ q . C(q, q) . n Fig. 7.6 The direct dynamic model of a robot mechanism B –1 (q) +y ++ – q q n(q, q) u + + Robot B(q) ^ ^ q ¨ q . q . . n(q, q) . Fig. 7.7 Linearization of the control system by implementing the inverse dynamic model ?n(q, ˙q)= ? C(q, ˙q)˙q + ? F v ˙q + ?g(q). (7.13) The controller output u is determined by the following equation u = ? B(q)y + ?n(q, ˙q), (7.14) where the approximate inverse dynamic model of the robot was used. The system, combining equations (7.12)and(7.14),isshowninFigure7.7. Let us assume the equivalence ? B(q)=B(q) and ?n(q, ˙q)=n(q, ˙q). In Figure 7.7 we observe that the signals ?n(q, ˙q) and n(q, ˙q) subtract, as one is presented 84 7 Robot control B(q) y + n(q, q) u + + Robot y ^ . ^ q q q . q . Fig. 7.8 The linearized system with a positive and the other with a negative sign. In a similar way, the product of matrices ? B(q) and B ?1 (q) results in a unit matrix, which can be omitted. The simplified system is shown in Figure 7.8. By implementing the inverse dynamics (7.14), the control system is linearized, as there are only two integrators between the input y and the output q. The system is not only linear, but is also decoupled, as e.g. the first element of the vector y only influences the first element of the position vector q. From Figure 7.8 it is also not difficult to realize that the variable y has the characteristics of acceleration, thus y = ¨q. (7.15) In an ideal case, it would suffice to determine the desired joint accelerations as the second derivatives of the desired joint positions and the control system will track the prescribed joint trajectories. As we never have a fully accurate dynamic model of the robot, always a difference will occur between the desired and the actual joint positions and will increase with time. The positional error is defined by ?q = q r ?q, (7.16) where q r represents the desired robot position. In a similar way also the velocity error can be defined as the difference between the desired and the actual velocity ˙ ?q = ˙q r ? ˙q. (7.17) The vector y, having the acceleration characteristics, can be now written as y = ¨q r + K p (q r ?q)+K d (˙q r ? ˙q). (7.18) It consists of the reference acceleration ¨q r and two contributing signals which de- pend on the errors of position and velocity. These two signals suppress the error arising because of the imperfectly modeled dynamics. The complete control scheme isshowninFigure7.9. By considering equation (7.18) and the equality y = ¨q, the differential equation describing the robot dynamics can be written as ¨ ?q + K d ˙ ?q + K p ?q = 0, (7.19) 7.2 Control of the robot in external coordinates 85 B(q) y q + n(q, q) u + + Robot K d + + ++ + + + – – Inverse dynamics Position control u Robot Inverse dynamics y Position control q r ¨ q r q r . q r ¨ q r q r . q ~ . q ~ K p ^ ^ . q . q q . + Fig. 7.9 Control of the robot based on inverse dynamics where the acceleration error ¨ ?q = ¨q r ? ¨q was introduced. The differential equation (7.19) describes the time dependence of the control error as it approaches zero. The dynamics of the response is determined by the gains K p and K d . 7.2 Control of the robot in external coordinates All the control schemes studied up to now were based on control of the internal coordinates, i.e. joint positions. The desired positions, velocities and accelerations were determined by the robot joint variables. Usually we are more interested in the motion of the robot end-effector than in the displacements of particular robot joints. At the tip of the robot, different tools are attached to accomplish various robot tasks. In the further text we shall focus on the robot control in the external coordinates. 7.2.1 Control based on the transposed Jacobian matrix The control method is based on the already known equation (4.17) connecting the forces acting at the robot end-effector with the joint torques. The relation is defined by the use of the transposed Jacobian matrix 86 7 Robot control τ = J T (q)f, (7.20) where the vector τ represents the joint torques and f is the force at the robot end- point. It is our aim to control the pose of the robot end-effector, where its desired pose is defined by the vector x r and the actual pose is given by the vector x. The vectors x r and x in general comprise six variables, three determining the position of the robot end-point and three for the orientation of the end-effector, thus x = bracketleftbig xyz??ψ bracketrightbig T . Robots are usually not equipped with sensors assessing the pose of the end-effector; robot sensors measure the joint variables. The pose of the robot end-effector must be therefore determined by using the equations of the direct kinematic model x = k(q) introduced in the chapter on robot kinematics (4.4). The positional error of the robot end-effector is calculated as ?x = x r ?x = x r ?k(q). (7.21) The positional error must be reduced to zero. A simple proportional control sys- tem with the gain matrix K p is introduced f = K p ?x. (7.22) When analyzing equation (7.22) more closely, we find that it reminds us of the equa- tion describing the behavior of a spring, where the force is proportional to the spring elongation. This consideration helps us to explain the introduced control principle. Let as imagine that there are six springs virtually attached to the robot end-effector, one spring for each degree of freedom (three for position and three for orientation). When the robot moves away from the desired pose, the springs are elongated and pull the robot end-effector into the desired pose with the force proportional to the positional error. The force f therefore pushes the robot end-effector towards the de- sired pose. As the robot displacement can only be produced by the motors in the joints, the variables controlling the motors must be calculated from the force f.This calculation is performed by the help of the transposed Jacobian matrix as shown in equation (7.20) u = J T (q)f. (7.23) The vector u represents the desired joint torques. The control method based on the transposed Jacobian matrix is shown in Figure 7.10. J T (q) x r q Robot+ x + – K p k(?) uf x ~ Fig. 7.10 Control based on the transposed Jacobian matrix 7.2 Control of the robot in external coordinates 87 7.2.2 Control based on the inverse Jacobian matrix The control method is based on the relation between the joint velocities and the velocities of the robot end-point (4.10), which is given by the Jacobian matrix. In equation (4.10) we emphasize the time derivatives of external coordinates x and internal coordinates q ˙x = J(q)˙q ? dx dt = J(q) dq dt . (7.24) As dt appears in the denominator on both sides of equation (7.24), it can be omitted. In this way we obtain the relation between changes of the internal coordinates and changes of the pose of the robot end-point dx = J(q)dq. (7.25) Equation (7.25) is valid only for small displacements. As with the previously studied control method, based on the transposed Jacobian matrix, also in this case we first calculate the error of the pos
收藏