The invention can be better understood on reading following description given purely by way of non-limiting example and made with reference to the drawings, in which:
At one of its ends the arm 6 has an effector tool 10.
Facing the tool 10, points A, B, C, and D represent in perspective a path 12 that the tool 10 is to follow once the robot 4 has been programmed.
By way of illustration, the arm 6 is fitted with six electric actuators 16 to 21 for selectively moving the arm 6 about six hinges. To simplify the description, it is assumed below that the electric actuators 16 to 21 are all identical, and only the actuator 16 is described in detail.
By way of advantage, the actuator 16 comprises:
By way of example, the gearbox 26 is suitable for reducing the angular speed of the shaft 28 relative to that of the shaft of the motor 24 by a reduction coefficient γ.
The shaft 28 serves to move the actuator 17 in rotation.
The motor 24 is powered from a controllable power supply 30. By way of example, this power supply 30 is located in the control cabinet 8. For example, the power supply 30 is a controllable inverter connected to a direct current (DC) electricity distribution network.
The actuator 16 is also fitted with a sensor 34 for sensing the magnitude i1 of the current supplied to the motor 24, and a sensor 36 for sensing the angular position of the shaft 28.
The sensors 34 and 36 are connected to a control unit 38, e.g. situated inside the cabinet 8.
The control unit 38 includes a path generator 40 suitable for responding to operating parameters and coordinates of points of passage on the path 12 to determine the position, the speed, and the acceleration of the tool 10 along each of the portions of the path 12. For example, the generator 40 is suitable for determining the speed profile of the movements of the tool 10 along each of the portions AB, BC, and CD of the path 12. The speed profile defines how the speed of the effector 10 varies along the path portion as a function of time.
By way of example, for the robot 4, the vector {right arrow over (P)} of operating parameters is defined by the following relationship:
{right arrow over (P)}=[p1, p2, p3, . . . , pi, . . . , p9]T
where:
p3, p6, and p9 are the maximum decelerations accepted on the portions of paths respectively lying between the points A & B, B & C, and C & D.
The unit 38 is suitable for controlling the power supply 30 of each of the actuators in such a manner that the effector 10 moves along the path 12 with the speeds defined by the generator 40.
The unit 38 is associated with information storage means such as a memory 42. The memory 42 contains in particular the coordinates of the points of passage of the path 12. In this example, the memory 42 contains the coordinates in three dimensions of the points A, B, C, and D.
The unit 38 is also connected to the device 2 in order to receive the operating parameters and to send thereto the values measured by the sensors 34 and 36 of each of the actuators.
The device 2 is fitted with:
By way of example, the interface 54 comprises a display screen 56 and a keyboard 58 connected to the unit 50.
The unit 50 comprises:
The various functions of the unit 50 and of the modules 60, 62, and 64 appear on reading the description made with reference to
The unit 50 in this example is based on a programmable electronic computer 70 suitable for executing a program recorded on an information recording medium. For this purpose, the memory 52 includes program instructions for executing the method of
The memory 52 contains a heating model 72 for each of the actuators, a wear model 74 for each of the actuators, a definition 75 of the operating limits of each of the actuators, a definition 76 of a positioning error E(t) of the tool 10, a compromise function 78, and default values 80 for all of the coefficients and the parameters used in the method of
The model 72 serves to predict the operating temperature under steady conditions for each of the actuators 16 to 21 as a function of measurements performed while the tool 10 follows the path 12 on a single occasion.
By way of example, the heating model used is defined by the following relationship:
where:
designates the operation of integrating relative to time t over the range 0 to tc.
In this example, the instantaneous value Γi of the torque is obtained from the current measurement ii performed by the current sensor associated with actuator i.
The instantaneous value of angular velocity {dot over (q)}di(t) is calculated from the positions measured by the position sensor of actuator i.
The coefficients of the matrices A and B, and the values of the constants γi are determined experimentally.
In this example, the coefficients of the matrices A and B take account of thermal coupling between actuators.
The outside temperature Text is either set by the user or else measured.
The model 74 serves to calculate the degree of wear for each actuator as a function of the angular velocities {dot over (q)}i and of the torques Γi.
The degree of wear is representative of the lifetime of the robot. The greater the degree of wear the shorter the lifetime of the robot. In a robot, by way of example, one element that is characteristic of wear is the wear of the ball bearings in the gearbox 26. The degree of wear of an actuator can thus be calculated from the degree of wear of the ball bearings in the gearboxes of the robot, for example. Such a calculation of the degree of wear can be based on the international standard ISO 281:1990, for example.
The wear model used in this example is given by the following relationship:
where Di is the degree of wear of actuator i.
The definitions 75 define the range of torque possible for each actuator i. For example, equations (3) and (4) define the high and low torque limits as a function of the operating speeds of the actuators, giving for each actuator i:
where:
Relationships (3) and (4) indicate that the torque Γi of the actuator i must lie between two straight lines each a function of angular velocity {dot over (q)}i.
The definition 76 of the positioning error is given in this example by the following relationship:
where:
The compromise function 78 in this example is defined by the following relationship:
where:
The values Di,Nom and Ti,Nom are predetermined constants. For example, the value Di,Nom is a constant calculated from the mechanical characteristics of the ball bearings of the gearboxes and the number of operating hours desired for the gearboxes.
By way of example, the value Ti,Nom is given by the manufacturer of actuator i.
It should be observed that the compromise function is a sum of terms. The term “tc” is a monotonically increasing function that depends solely on cycle time.
Thereafter, the compromise function f for each actuator i comprises, reading from left to right:
Preferably, when the cycle time varies, the sum of these last five terms varies in the opposite direction to the term “tc”. For example, the value of the sum of these five terms increases when the cycle time decreases. In practice, this compromise function has a minimum.
In this example, with the exception of the term “tc”, the other terms are all functions of a difference between a value that is measured or calculated and a limit value.
These limit values do not all have the same relative importance. For example, it is much more important to avoid crossing the limit values on instantaneous torque Γi than the values set for degree of wear or temperature. Crossing a limit value imposed on torque Γi can lead to the actuator malfunctioning immediately, and can thus make it impossible for the robot 4 to complete traveling along the path 12. Conversely, crossing the value Di,Nom or the value Ti,Nom does not prevent the robot 4 from traveling along the entire path 12, and this applies several times in succession. The only consequence of exceeding the value Di,Nom or Ti,Nom is a shortening in the lifetime of the robot 4, for example, and that might be acceptable for the user if such a shortening of lifetime is compensated by a large saving in cycle time.
Similarly, in this example, it is assumed that it is absolutely essential to avoid the error E(t) exceeding the threshold δ.
Under such conditions, the values of the coefficients αj,i must be selected so as to comply with the following relationships:
The operation of the device 2 is described below with reference to
Initially, during a step 98, the module 60 acquires values for the coefficients αi,j that are input by the user via the man/machine interface 54. If the user desires not to proceed with a step 98, then the default values 80 are used.
Thereafter, during a step 100, the vector {right arrow over (P)} of operating parameters is initialized. By way of example, the coordinates pi for the vector {right arrow over (P)} are initialized from limit values for maximum acceleration, maximum speed, and maximum deceleration that are given by the manufacturer of each actuator.
Thereafter, in a step 102, the unit 50 sends the operating parameter pi to the control unit 38.
In response, during a step 104, the generator 40 calculates the path that complies with the operating parameters received for each of the portions of the path 12. To this end, the generator 40 uses the coordinates of the points of passage recorded in the memory 42 and the values received for the parameters pi to establish the speed profile of the tool 10 along each portion of the path 12.
Once the speed profiles have been established, during a step 106, the unit 38 controls each actuator 16 to 21 so that the tool 10 moves along the path 12 in compliance with the established speed profiles. Thus, during step 106, the robot 4 moves the tool 10 along the path 12.
In parallel with step 106, during a step 108, the power supply current ii and the angular positions qi of the outlet shafts of the actuators are measured. The measured values and the corresponding instants are recorded in the memory.
Once the tool 10 has traveled along the entire path 12 in one direction and then in the opposite direction so as to return to its starting point, the module 62 acts in a step 110 to determine the cycle time, the temperatures Ti, and the degrees of wear Di on the basis of the measured data recorded in the memory 42.
For example, during step 110, the module 62 determines the cycle time tc by taking the difference between the instant corresponding to the tool 10 leaving the point A and the instant corresponding to the tool 10 returning to the point A.
The cycle time thus includes the time taken by the tool 10 to travel along the path 12 from the point A to a point D and then to return from the point D back to the point A, passing via the points C and B.
The angular velocity {dot over (q)}i is calculated from the position measured by the sensors during step 108.
The module 62 also determines the temperature Ti using the heating module 72 recorded in the memory 52. For this purpose, the value of the instantaneous torque Γi is deduced from the value of the instantaneous current ii as measured during step 108.
Still during step 110, the module 62 determines the values of the degrees of wear Di from the wear model 74.
The difference E(t) is calculated by the module 62 from the angular positions measured during step 108 and the coordinates of the points of passage recorded in the memory 42.
Once the temperatures Ti, the degrees of wear Di, the instantaneous torques Γi, the angular velocities {dot over (q)}i, the difference E(t), and the cycle time tc have been calculated, the unit 50 in a step 112 calculates the value of the compromise function f.
Thereafter, during a step 114, the unit 50 verifies whether the compromise function f satisfies a predetermined stop criterion. For example, the unit 50 checks whether the compromise function is very close to an extremum, and more precisely in the particular example described herein, a minimum.
For this purpose, during an operation 116, the gradient ∇f of the compromise function is calculated and then compared in an operation 118 with a predetermined threshold ε.
By way of example, the gradient ∇f is calculated using the following relationship:
where:
In order to calculate the term f(p1, p2, . . . , pi+h, . . . , pn), during a sub-operation 120, the value of the parameter pi is incremented by the step size h, and then during a sub-operation 122, the following vector {right arrow over (P)} is sent to the control unit 38:
{right arrow over (P)}=[p1, p2, . . . , pi+h, . . . , pn]T
Thereafter, sub-operations 124 to 132 are performed. These sub-operations 124 to 132 are identical respectively to steps 102 to 112 except that the operating parameter pi is replaced by the operating parameter pi+h.
The sub-operations 120 to 132 are reiterated for each parameter pi so as to calculate each of the terms f(p1, . . . , pi+h, . . . , pn). The term f(p1, p2, . . . , pn) was calculated during step 112.
Once each term f(p1, . . . , pi+h, . . . , pn) has been calculated, then during a sub-operation 134, the gradient ∇f is calculated.
During the operation 118, the gradient ∇f is compared with the threshold ε. If the gradient is greater than the threshold ε, then in a step 140, the module 64 automatically modifies the values of the parameters pi so as to approach the minimum of the compromise function. For example, during step 140, the module 64 moves down the gradient in association with a linear search. More precisely, during step 140, the module 64 calculates an optimum downward step size σ using a linear search. For example, the linear search algorithm can be the Goldstein and Price algorithm. This linear search algorithm is described in the following bibliographic reference:
“Numerical optimization: theoretical and practical aspects”, by J. Frédéric Bonnans, J. Charles Gilbert, Claude Lemaréchal, and Claudia A. Sagastizabal, published by Springer.
Each parameter pi is then modified during the step 140 using the following relationship:
p
i,k+1
→p
i,k
−σ∇f (11)
where:
At the end of step 140, the method returns to step 102.
If the value of ∇f is less than the threshold ε, then the unit 50 proceeds with a step 142 during which the steps 102 to 140 are stopped and the current values of the operating parameters are recorded.
During a step 144, the operating parameters recorded in step 142 are used by the unit 38 for controlling the movements of the arm 6.
Conversely,
Numerous other embodiments of the device 2 are possible. In particular, there are numerous possible variants of the compromise function. The compromise function is described above for the particular circumstance in which it is formed by a sum of terms. In a variant, the compromise function could be formed by any increasing function of terms having a harmful effect on the cycle time. For example, the function
could be replaced by a function that returns the maximum of the terms.
The term tc in relationship (6) could be replaced by the following term:
where:
In a variant, either the term that is a function of the degree of wear Di or the term that is a function of the temperature Ti is omitted if the degree of wear or the operating temperature of the actuator is not to be taken into account when obtaining an optimum cycle time.
If positioning error is of no importance, then the term that is a function of the difference E(t) can be omitted.
Other additional terms could be added to the compromise function providing the function increases a function of said terms, and said terms have values that increase with increasing undesirable effect. For example it is possible to add a term that represents the positioning error of the tool 10 relative to a point of passage on the path 12, or a maximum power consumed by one or more actuators.
The iterations of steps 102 to 140 can also be stopped manually by the user once the user is satisfied by the results that have been achieved.
Other criteria for stopping the iteration of steps 102 to 140 can be used. For example, iterating the steps can be stopped when the difference between the compromise function during the preceding iteration and the value of the compromise function during the current iteration is less than a predetermined threshold. Iterations can also be stopped if the number of iterations exceeds a predefined threshold.
In a simplified implementation, the heating model does not take account of thermal coupling between the various actuators of the robot 4. The method of calculating temperatures Ti as described in WO 02/074501 can then be applied.
The operating range of each actuator can be defined on the basis of magnitudes other than the instantaneous torque Γi. For example, it could be defined by a maximum current consumed by the actuator, a maximum angular velocity, or any other parameter given by the manufacturer of the actuator.
In a variant, the device 2 is not associated with the robot 4 but with an emulator of the robot 4. The emulator must be suitable for generating the path followed by the tool 10 and the values needed for implementing the device 2. For example, the emulator generates the instantaneous values of the angular positions of the outlet shafts of the actuator and also the value of the current consumed by each actuator.
The temperatures Ti could be measured instead of being estimated on the basis of relationships (1) and (2).
Number | Date | Country | Kind |
---|---|---|---|
06 03855 | Apr 2006 | FR | national |