Method and a device for adjusting operating parameters of a robot, a program and a recording medium for the method

Information

  • Patent Application
  • 20070252839
  • Publication Number
    20070252839
  • Date Filed
    April 27, 2007
    17 years ago
  • Date Published
    November 01, 2007
    17 years ago
Abstract
This method of adjusting the operating parameters of a robot to move an effector tool along a given path in an optimum cycle time comprises a step (140) of modifying the operating parameter values to cause the cycle time to approach its optimum value. During this step, the values of the operating parameters are modified so as to approach an extremum of a compromise function, the compromise function comprising at least first and second terms, the first term being a function of the cycle time and the second term being a function of the temperature and/or the degree of wear.
Description

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:



FIG. 1 is a diagrammatic illustration of the architecture of a device for adjusting the operating parameters of a robot;



FIG. 2 is a flow chart of a method of adjusting the operating parameters of a robot using the device of FIG. 1; and



FIGS. 3A and 3B are graphs showing respectively the situations 1) and 2) described in the above introduction.






FIG. 1 shows a device 2 for adjusting the operating parameters of a robot 4. The robot 4 is provided with a hinged arm 6 and with a control cabinet 8.


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:

    • a rotary electrical machine such as an electric motor, preferably a three-phase electric motor 24; and
    • a gearbox 26 for reducing angular speed that is mechanically coupled between a shaft driven in rotation by the motor 24 and an outlet shaft 28 from the actuator 16.


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:

    • p1, p4, and p6 are the maximum accelerations accepted on the portions of the path 12 lying respectively between the points A & B, B & C, and C & D;
    • p2, p5, and p8 are the maximum speeds accepted on the portions of the path respectively lying between the points A & B, B & C, and C & D; and


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:

    • a unit 50 for generating the operating parameters of the robot 4;
    • information storage means such as a memory 52 containing the data used by the unit 50; and
    • a man/machine interface 54 enabling the unit 50 to acquire data input by the user of the device 2.


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:

    • a module 60 for acquiring coefficients input by the user via the interface 54;
    • a module 62 for determining the cycle time, the steady operating temperature of each of the actuators, and the degree of wear of each of the actuators; and
    • a module 64 for modifying the operating parameters so as to approach an extremum of a compromise function.


The various functions of the unit 50 and of the modules 60, 62, and 64 appear on reading the description made with reference to FIG. 2.


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 FIG. 2 when those instructions are executed by the computer 70.


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 FIG. 2.


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:










T


=


[




T
1











T
6




]

=


A


[





1

t
c






0

t
c






Γ
1
2



(
t
)









t















1

t
c






0

t
c






Γ
6
2



(
t
)









t







]


+

B


[





1

t
c






0

t
c







q
.

1
2



(
t
)









t















1

t
c






0

t
c







q
.

6
2



(
t
)









t







]


+

[




γ
1











γ
6




]

+

T
ext







(
1
)







where:

    • the indices 1 to 6 correspond respectively to the actuators 16 to 21.
    • Ti is the temperature of the actuator i;
    • Γi is the torque of actuator i;
    • {dot over (q)}i is the angular velocity of the outlet shaft of actuator i;
    • A, B are matrices of dimension 6×6 characteristic of heat exchanges in the robot 4;
    • γi is a constant representing a constant source of heat associated with actuator i;
    • Text is the ambient temperature of the surroundings of the robot;
    • tc is the cycle time for traveling along the entire path 12; and
    • the symbol









0

t
c







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:










D


=


[




D
1











D
6




]

=

(





(


1

t
c






0

t
c








Γ
1



(
t
)











t




)

3









(


1

t
c






0

t
c









q
.

1



(
t
)











t




)






















(


1

t
c






0

t
c








Γ
6



(
t
)











t




)

3









(


1

t
c






0

t
c









q
.

6



(
t
)











t




)




)






(
2
)







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:










L

1
,
i


=



max
path



(


Γ
i

-


a

1
,
i





q
.

i


-

b

1
,
i



)



0





(
3
)







L

2
,
i


=



max
path



(



a

2
,
i





q
.

i


+

b

2
,
i


-

Γ
i


)



0





(
4
)







where:

    • a1,i, a2,i, b1,i, and b2,i are constants characteristic of the actuator that are determined experimentally or given by the manufacturer of the actuator; and
    • “Maxpath” is the function that returns the maximum instantaneous value of the expression in parentheses that is observed when the tool 10 has traveled along the entire path 12.


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:









Z
=



max
path



(




E


(
t
)




-
δ

)



0





(
5
)







where:

    • E(t) is the instantaneous difference between the position of the tool 10 controlled by the unit 38 and the corresponding position of the tool 10, as measured;
    • ∥ is the absolute value function; and
    • δ is a predetermined threshold that the difference E(t) must not cross. δ thus determines the accuracy with which the tool 10 moves along the path 12.


The compromise function 78 in this example is defined by the following relationship:










f


(


t
C

,
Γ
,

q
.


)


=


t
c

+




i
=
1

6



(



α

1
,
i








D
i

-

D

i
,
Nom




D

i
,
Nom





+


α

2
,
i








T
i

-

T

i
,
Nom




T

i
,
Nom





+


α

3
,
i






L

1
,
i




+


α

4
,
i






L

2
,
i





)


+


α

5
,
i





z







(
6
)







where:

    • f is the compromise function;
    • αi,j are coefficients that are adjustable by the user and that have respective default values recorded in the memory 52;
    • Di,Nom is the limit value for the degree of wear of actuator i;
    • Ti,Nom is the limit value for the operating temperature of actuator i; and
    • “e” is the exponential function.


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:

    • a first term that is a monotonically increasing function depending solely on the degree of wear Di;
    • a second term that is a monotonically increasing function depending solely on temperature Ti;
    • a third term and a fourth term that are respective monotonically increasing functions depending solely on the high and low torque limits L1,i and L2,i; and
    • a fifth term that is a monotonically increasing function depending solely on the positioning error εi.


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:

    • α1,i2,i strictly less than α3,i, α4,i, and α5,i; and
    • α3,i4,i5,i.


The operation of the device 2 is described below with reference to FIG. 2 for the special circumstance in which it is desired to minimize cycle time tc.


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:














f

=



[




f


(



p
1

+
h

,

p
2

,





,

p
n


)


-

f


(


p
1

,

p
2

,





,

p
n


)



h

,














f


(


p
1

,


p
2

+
h

,





,

p
n


)


-

f


(


p
1

,

p
2

,





,

p
n


)



h

,





,













f


(


p
1

,

p
2

,





,


p
n

+
h


)


-

f


(


p
1

,

p
2

,





,

p
n


)



h

]

T







(
10
)







where:

    • n is equal to 9;
    • the values pi are the operating parameters; and
    • h is the step size selected for calculating the gradient.


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:

    • pik and pi,k+1 represents respectively the value of the parameter pi before and after step 140.


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.



FIGS. 3A and 3B show various, points illustrating the path trace followed by the method of FIG. 2 in order to reach the optimum cycle time. The shaded zones in FIGS. 3A and 3B represent the sets of cycle times and temperatures that can be reached by the system with varying operating parameters pi. On these graphs, the limit value for temperature T is written TNom and the optimum value of the cycle time obtained with the method of FIG. 2 is written topt.



FIG. 3A shows a situation in which increasing the operating temperature of the actuator does not lead to a significant improvement in the cycle time tc, such that the optimum cycle time obtained at the end of the method of FIG. 2 is obtained for a temperature that is strictly less than the limit temperature TNom.


Conversely, FIG. 3B shows the same physical magnitudes but for circumstances in which slightly exceeding the limit value TNom leads to a significant improvement in the cycle time. Under such conditions, the optimum value topt for the cycle time is obtained for an operating temperature that is strictly greater than the limit value TNom.


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






(



i
=
1

6

)




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:






β









(


t
c

-

t

c
,
nom



)


t

c
,
nom








where:

    • β is a weighting coefficient selected by the user; and
    • tc,nom is the optimum cycle time that it is desired to reach.


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).

Claims
  • 1. A method of adjusting the operating parameters of a robot for moving an effector tool along a given path with an optimum cycle time, the operating parameters determining at least the travel speed of the tool along the given path, the method making use of measurements taken during a real movement of the effector tool and/or on the basis of measurements delivered by a robot movement emulator, and comprising: a) a step of determining the value of the cycle time as a function of the values of the operating parameters;b) a step of determining the value of an operating temperature and/or the value of a degree of wear for at least one of the actuators of the robot resulting from following the complete path; andc) a step of modifying the values of the operating parameters to move the cycle time closer to its optimum value;wherein, during step c), the values of the operating parameters are modified so as to approach an extremum of a compromise function, the compromise function comprising at least first and second terms, the first term being a function of the cycle time determined during step a), and the second term being a function of the temperature and/or the degree of wear determined during step b).
  • 2. A method according to claim 1, wherein the compromise function also includes a third term that is a function of the instantaneous torque exerted by each actuator.
  • 3. A method according to claim 1, wherein the compromise function also includes a fourth term that is a function of the positioning error of the effector tool relative to the given path.
  • 4. A method according to claim 1, wherein, when the cycle time varies, the first term varies in the opposite direction to the second term or the sum of the other terms.
  • 5. A method according to claim 1, wherein at least one of the terms includes an adjustable coefficient, and in that the method includes a step of a user adjusting the value of said coefficient.
  • 6. A method according to claim 1, wherein at least one of the terms is a function of the difference between the values determined during step a) or b) and a limit value given for said value.
  • 7. A method according to claim 1, wherein during step b) the thermal coupling between a plurality of actuators is taken into account in order to determine the operating temperature of at least one of the actuators.
  • 8. A method according to claim 1, wherein during step b) a prediction of the temperature and/or of the degree of wear under steady conditions is established on the basis of data obtained following a single journey along the given path, and in that the prediction of the temperature and/or the degree of wear is used to modify the values of the operating parameters during step c).
  • 9. A method according to claim 1, wherein it includes a step of automatically verifying that the compromise function satisfies a predetermined stop criterion, and in the event of the compromise function satisfying the stop criterion, a step of automatically stopping iteration of steps a) to c).
  • 10. A method according to claim 9, wherein the verification step consists in checking whether the norm of the gradient of the compromise function relative to the operating parameters is less than a predetermined threshold.
  • 11. A computer program, wherein it includes instructions for implementing a method in accordance with claim 1, when said instructions are executed by an electronic computer.
  • 12. An information recording medium, wherein it includes instructions for implementing a method in accordance with claim 1 when said instructions are executed by an electronic computer.
  • 13. A device for adjusting the operating parameters of a robot for moving an effector tool along a given path in an optimum cycle time, the operating parameters determining at least the travel speed of the effector along the given path, the device responding to measurements performed during real movement of the effector tool and/or readings delivered by a robot movement emulator, and comprising: a) a determination module for determining the value of the cycle time as a function of the values of the operating parameters, and for determining the value of the operating temperature and/or the value of a degree of wear for at least one of the actuators of the robot as a result of traveling along the complete path; andb) a modification module for modifying the values of the operating parameters in order to cause the cycle time to approach its optimum value;wherein the modification module is suitable for modifying the values of the operating parameters so as to approach an extremum of a compromise function, the compromise function comprising at least first and second terms, the first term being a function of the cycle time and the second term being a function of the temperature and/or the degree of wear determined by the module a).
  • 14. A device according to claim 13, wherein at least one of the terms includes an adjustable coefficient, and in that the device includes a man/machine interface enabling a user to adjust the value of said coefficient(s).
Priority Claims (1)
Number Date Country Kind
06 03855 Apr 2006 FR national