The invention relates to a method for controlling and/or regulating motors of a robot, wherein the robot has robot components that are interconnected via a number N of articulated connections GELn. Furthermore, the invention relates to a device for controlling and/or regulating motors of such a robot, a robot with such a controlling or regulating device, a computer system, a digital storage medium, a computer program product, and a computer program.
Related attempts to solve problems in the field include (citations to these references within the text, below, correspond to the following numbering):
In the drawings:
The connected robot components preferably form a robot manipulator. The term “robot manipulator” is understood to be a device of a robot which enables the physical interaction of the robot with the surroundings: The robot manipulator is a movable part of the robot which carries out mechanical work of the robot, and thus can interact mechanically with its surroundings. The robot manipulator is typically configured as a robot arm which has a plurality of manipulator components (arm components) which are connected in an articulated manner by means of articulated connections. The individual articulated connections are adjustable by actuators, so that the robot arm can change its shape and its position and situation in space (relative to the (rest of the) robot). Moreover, the robot manipulator has, typically at its free end, an effector which carries out the actual mechanical interaction with the surroundings of the robot. For this purpose, the effector preferably comprises grippers and/or tools for mechanical interaction with objects.
The articulated connections which are adjustable by actuators or motors can be designed to be rigid or can have a defined intrinsic resilience, so that in the latter case the robot manipulator overall has defined resilient properties. In particular the control/regulation of robot manipulators with resilient joints has become the focus of more intense interest in the last two decades. On the one hand, this is because of the higher demand in the industry for speed and load capacity of robots; even with oversized drives designed to be as rigid as possible, resilient deformations and dynamic interactions have a considerable influence on the motion. On the other hand, the intensified interest is because in more and more robots resilience is deliberately employed in order, for example, to simplify an interaction with people through the passive flexibility of the robot, or in order to simulate the dynamics of the biological locomotor system, and in order to use possibilities for storing potential energy.
The object of the present invention is to provide an improved method for controlling/regulating motors of a robot, wherein the motors control articulated connections which connect robot components, wherein application of the method necessitates a low computing capacity, and thus can be used for real-time control and regulation of the (drive) motors of the robot.
The invention is disclosed by the features of the independent claims. Preferred modifications and embodiments are the subject matter of the dependent claims. Further features, possible applications and advantages of the invention are disclosed by the following description as well as the explanation of exemplary embodiments of the invention, which are illustrated in the drawings.
Based on the preceding statements, as a first aspect of the invention a method for controlling and regulating motors MOTm of a robot, with m=1, 2, . . . M, is proposed, wherein the robot has robot components that are interconnected via a number N of articulated connections GELn, with n=1, 2, . . . , N; wherein the joint angles of the articulated connections GELn can be adjusted by means of associated motors MOTm; wherein Z(tk)={zp(tk)} is a state of the robot components in an interval tk, wherein k=0, 1, 2, 3, . . . and p=1, 2, . . . , P; wherein a first system of coupled motion equations BGG is predetermined and describes rigid-body dynamics or flexible-body dynamics of the robot manipulator, wherein in the first system of motion equations BGG, um(tk) is a manipulated variable for the respective motor MOTm, and wherein for the first system of coupled motion equations BGG, restrictions of the manipulated variables um(tk) and restrictions of the states Z(tk) of the connected robot components are predetermined.
The articulated connections GELn can have a defined intrinsic resilience, which is described by the flexible-body dynamics. They can also be designed to be rigid, which is described by a rigid-body dynamics. The robot components can be arranged in series and/or in parallel. The articulated connections GELn can, for example, be simple joints or coupling joints. An articulated connection GELn can have one or more hinge axes about which the articulated connection is adjustable. One or more motors MOTm for adjustment of the plurality of joint axes can be associated with a multi-axially adjustable articulated connection GELn. Preferably N=M and n=m, which means that each articulated connection is adjustable around or along an axis, and in each case one motor per articulated connection is present for adjustment.
The term “motor” should be interpreted broadly here. In the broadest sense it covers all controllable actuators, in particular electric motors, stepping motors, linear motors, but also piezoelectric elements, etc., which enable corresponding positioning/axial angle setting of articulated connections GELn of the robot components.
The robot components are arranged serially in a preferred embodiment and form, for example, a robot manipulator. In this case the robot components are assumed to be rigid, which is sufficiently close to reality in the majority of cases.
The expression “state Z(t)” designates in particular a mechanical/dynamic state of the robot components, the articulated connections GELn and/or the motors MOTm, for example, with some or all of the following time-dependent variables Zp(tk):
In this case the term “manipulated variable” um(t) indicates the nominal value of the respective reference variable and is an input variable for the corresponding control path in the case of regulation or input variable for the corresponding actuator (i.e. in this case the motors MOTm) in the case of control. The manipulated variable can be, for example, an electrical power, an electrical voltage, an electrical current intensity, or the motor torque.
Restrictions of manipulated variables um(t) and restrictions of the state Z(t) or the state variables Zp(t) defining this state can be, for example, given as relations to predetermined limiting values, for example, G1<um(t)<G2, or d(um(t))/dt<G3.
The proposed method according to the first aspect comprises the following steps.
In one step, for the first system of coupled motion equations BGG, a second system of locally equivalent decoupled motion equations BGE is provided that describes the rigid-body dynamics or the flexible-body dynamics of the connected robot components. The system of decoupled motion equations BGE is advantageously determined by a double diagonalization of the coupled motion equations BGG or by solving of the generalized eigenvalue problem of the coupled motion equations BGG.
A further step provides restrictions of the manipulated variables um(tk) transformed into the second system and provides restrictions of the states Z(tk) transformed into the second system. The coupled motion equations BGG and the decoupled motion equations BGE can be transferred by corresponding transformations into one another.
In a further step, the state Z(tk) transformed into the second system as Z*(tk) is provided.
In a further step, for the second system of decoupled motion equations BGE, setting a target state SZ* of the robot manipulator which is to be reached starting from the state Z*(tk) takes place, and setting (104) one or more conditions BD* and/or one or more characteristics KZ* that define how to achieve the target state SZ* takes place. The target state SZ* is set in the second system of decoupled motion equations BGE, preferably as SZ*={zp*} with p=1, 2, . . . , P.
In a further step, in the second system of decoupled motion equations BGE a state trajectory ZT*(t) and the associated manipulated variable trajectories uT*m(t) are predicted depending on the state Z*(tk) and the target state SZ* while meeting the conditions BD*, the characteristics KZ*, the transformed restrictions of the manipulated variables um(tk), and the transformed restrictions of the states Z(tk) for an interval of t=tk to t=tk+w, wherein Δt=tk+w−tk is a predetermined prediction interval. The prediction interval is preferably selected in such a way that the target state SZ* is achieved within the prediction interval.
In a further step transforming of the manipulated variable trajectories uT*m(t) and the state trajectories ZT*(t) into the first system of coupled motion equations BGG takes place to generate manipulated variable trajectories uTm**(t) and state trajectories ZT**(t),
In a further step, from the manipulated variable trajectories uTm**(t) determination of manipulated variables um(tk+1) for the next interval k+1 and regulating of the motors MOTm by means of the manipulated variables um(tk+1) takes place.
In a further step, from the state trajectories ZT**(t) and/or on the basis of sensor data of a detection system of the state Z(t), determining of the state Z(tk+1) takes place for the interval k+1.
In a further step, for Z(tk)=Z(tk+1), the method is performed again until a predetermined break-off criterion or the target state SZ in the first system of coupled motion equations BGG is reached. The target state SZ is produced, for example, through transformation of the target state SZ* into the first system of coupled motion equations BGG or it is predetermined correspondingly for the system of coupled motion equations BGG. Alternatively, as a second aspect of the invention a method a method for controlling and regulating motors MOTm of a robot, with m=1.2, . . . M, is proposed, wherein the robot has robot components that are interconnected via a number N of articulated connections GELn, with n=1, 2, . . . . N: joint angles of the articulated connections GELn can be adjusted by means of associated motors MOTm; Z(tk)={zp(tk)} is a state of the robot components in an interval tk, wherein k=0, 1, 2, 3, . . . and p=1, 2, . . . , P; a first system of coupled motion equations BGG is predetermined and describes rigid-body dynamics or flexible-body dynamics of the robot manipulator; in the first system of motion equations BGG um(tk) is a manipulated variable for the respective motor MOTm, and for the first system of coupled motion equations BGG, restrictions of the manipulated variables um(tk) and restrictions of the states Z(tk) of the connected robot components are predetermined.
The method according to the second aspect comprises the following steps. In one step, for the first system of coupled motion equations BGG, a second system of locally equivalent decoupled motion equations BGE is provided that describes the rigid-body dynamics or the flexible-body dynamics of the connected robot components, and a regulating and/or control law RG is provided for the manipulated variables um(tk). A further step provides restrictions of the manipulated variables um(tk) transformed into the second system and provides restrictions of the states Z(tk) transformed into the second system, and provides the regulating and/or control law RG transformed into the second system as RG*: A further step provides the state Z(tk) transformed into the second system as Z*(tk).
In a further step, for the second system of decoupled motion equations BGE, setting takes place of one or more conditions BD** and/or one or more characteristics KZ** that define the framework in which the regulating and/or control law RG should be applied. In a further step, in the second system of decoupled motion equations BGE a state trajectory ZT*(t) and the associated manipulated variable trajectories uT*m(t) are predicted depending on the state Z*(tk) and the target state SZ* on the basis of the regulating and/or control law RG transformed into the second system while meeting the transformed restrictions of the manipulated variables um(tk), the conditions BD*, the characteristics KZ*, and the transformed restrictions of the states Z(tk) with at least an accuracy of <20% for an interval of t=tk to t=tk+w, wherein Δt=tk+w−tk with W>k is a predetermined prediction interval. In a further step transforming of the manipulated variable trajectories uT*m(t) and the state trajectories ZT*(t) into the first system of coupled motion equations BGG takes place to generate manipulated variable trajectories uTm**(t) and state trajectories ZT**(t). In a further step, from the manipulated variable trajectories uTm**(t) determination of manipulated variables um(tk+1) for the next interval k+1 and regulating of the motors MOTm by means of the manipulated variables Um(tk+1) takes place. In a further step, from the state trajectories ZT**(t) and/or on the basis of sensor data of a detection system of the state Z(t), determining of the state Z(tk+1) takes place for the interval k+1. In a further step, for Z(tk)=Z(tk+1), the method is performed again until a predetermined break-off criterion is reached.
The method according to the second feature differs from the method according to the first feature in that instead of a target state SZ* a control and regulating law is predetermined which is applied with reference to predetermined conditions BD* or characteristics KZ*. In both variants of the method the following preferably applies: N=M and n=m. The two methods proposed above enable a simple, computing time saving and sufficiently accurate control/regulation of the motor MOTm which saves on computing time and is sufficiently precise. The method is preferably carried out automatically.
The N-dimensional system of coupled motion equations BGG can advantageously be represented by the following equations:
B=τ
m−τf−τJ. (30)
M(q){umlaut over (q)}=τg+τext−τJ (31)
τJ=KJ(θ−a)+DJ({dot over (θ)}−{dot over (q)}) (32)
with
θ: position vector of the motors MOTm
q: position vector of the articulated connections GELn
B: inertia of the motors MOTm
M(q): configuration-dependent inertia matrix of the connected robot components
Kj: rigidity matrix of the articulated connections GEL
Dj: rigidity matrix of the articulated connections GEL
τm: torque of the motors MOTm
τf: friction of the motors MOTm
τg: gravitational torques
τext: external torques, Coriolis torques
t: time
The coupling of the motion equations results from the configuration-dependent inertia matrix M(q) of the robot manipulator.
In order to simplify the foregoing system of equations, the influence of gravity and of Coriolis torques and other external torques is advantageously set to be equal to zero (τg=τext=0). In most cases this is possible without major disadvantages with regard to precision, and enables a reduction of the computing costs and thus an improved real-time regulation/control.
In a preferred further embodiment, the restrictions of state variables {zp(tk)} of the connected robot components in the system of coupled motion equations BGG are predetermined as follows:
|φ|=|θ−q|≤φmax, and (34)
|{dot over (θ)}|≤{dot over (θ)}max. (35)
|τm|≤τmax (36)
Thus the magnitude of the spring deflection |φ| of the joints GELn, the magnitude of the speeds |{dot over (θ)}| of the motors MOTm, and the magnitude of the motor torques |τm| are limited by correspondingly predetermined limiting values φmax, {dot over (θ)}max, τmax.
The following statements relate to the method according to the first aspect of the invention.
In a preferred further embodiment, the target state SZ* predetermined for the second system or the target state SZ=(SZ*)T transformed into the first system is predetermined in a time-variable manner: SZ=SZ(t) and SZ*=SZ*(t). The target state SZ(t) or SZ*(t) which the connected robot components should adopt in the context of the predetermined conditions BD* and/or characteristics KZ* is preferably determined depending upon obstacles in the surroundings of the robot which are recognized by a surroundings sensor system. As a result, the robot can be controlled in such a way that a collision with obstacles can be prevented in a time-variable environment.
An advantageous condition BD* is that the target state SZ* is reached in minimal time, and/or that the target state SZ* is reached with a minimal energy requirement of the motors MOTm, and/or that the target state SZ* is reached with a minimal braking distance of the joint angles of the articulated connections GELn, and/or that the target state SZ* is reached with a minimal braking distance of all the connected robot components, and/or that the target state SZ* is reached without falling short of a minimum spacing of the connected robot components from an object present in the surroundings of the robot.
Advantageously an initial state Z*(tk) is a rest state of the robot components, in which a joint angular speed of all articulated connections GELn is equal to zero, and the target state SZ* is a predetermined motion state of the robot components, wherein the target state SZ* should be reached in a minimal time.
A particularly preferred further embodiment is characterized in that an initial state Z*(tk) is a motion state of the connected robot components, the target state SZ* is a rest state of the robot components in which a joint angular speed of all articulated connections GELn is equal to zero, and the target state SZ* should be reached in a minimal time. This scenario corresponds to a braking operation of the connected robot components out of a motion state into a rest state in minimal time. The braking operation could also lead to a target state SZ* of all connected robot components which is not a rest state, but still has only a minimal residual speed, on account of which no damage is to be expected in the event of a collision with an object, in particular with a person. Furthermore, the target state SZ* could be a deflection movement contrary to a predicted direction of collision with a recognized object.
A braking distance BW* of each of the robot components is preferably predicted on the basis of the initial state Z*(tk) and the target state SZ*.
In a preferred further embodiment, the target state SZ is a state in which the connected robot components are motionless. In this case the current state Z(tk) is preferably a motion state for which, for example, the following applies: {dot over (q)}(t)={dot over (q)}a and {dot over (θ)}(t)={dot over (θ)}a, and the target state SZ is the rest state, for which the following applies: {dot over (q)}(t+Δt=0) and {dot over (θ)}(t+Δt)=0, wherein {dot over (q)}a and {dot over (θ)}a are predetermined values, and Δt is a predetermined time (for example, the minimal time) for reaching the target state SZ. Thus, the control/regulation task consists of braking the robot manipulator out of a moving state into a rest state, in a predetermined or in particular the minimal time Δt. The solution to this task can protect a robot (robot manipulator), for example, against collisions with briefly occurring objects.
Naturally, the method can also be used for control/regulation of the motors MOTm in the case in which the current state Z(tk) is a rest state, for which the following applies: {dot over (q)}(t)=0 and {dot over (θ)}(t)=0, and the target state SZ is a motion state, for which the following applies: {dot over (q)}(t+Δt)={dot over (q)}d and {dot over (θ)}(t+Δt)=
A further embodiment of the proposed method is characterized in that in the system of decoupled motion equations BGE for each articulated connection GELn a forward trajectory VTi (braking trajectory) of a future movement of the robot manipulator is determined and provided. This forward trajectory VTi comprises predicted positions of the articulated connection GELn. A braking distance Δqi=qi(t+Δt)−qi(t) is advantageously determined on the basis of the forward trajectory VTi for each articulated connection GELn. The shape or positioning of the robot manipulator in the achieved rest state can be determined, for example, from the braking distance.
A further variant of the method is characterized in that the manipulated variables um*(t) in the second system of decoupled motion equations BGE depending upon the determined forward trajectory VTi and/or the braking distances Δqi. This enables, for example, to determine the manipulated variables ui*(t) under the condition of predetermined braking distances, in particular minimal braking distances Δqi.
A further variant of the method is characterized in that the space spanned by motor torques of the motors MOTm can be described by a hypersquare Ω, of which the transformation into the system of decoupled motion equations BGE produces a hypersquare Ωv, wherein in the system of decoupled motion equations BGE based upon the hypersquare Ωv a greatest possible hypersquare Ωv′ is determined, for which it is the case that a back transformation of the hypersquare Ωv′ into the system of coupled motion equations BGG is located completely inside the borders of the hypersquare Ω, wherein the determination of the manipulated variable um*(t) takes place only on the hypersquare Ωv′. The same applies analogously for motor speed or motor acceleration as manipulated variables.
A further aspect of the invention relates to a computer system, with a data processing device, wherein the data processing is configured in such a way that a method as described above is carried out on the data processing device.
A further aspect of the invention relates to a digital storage medium with electronically readable control signals, wherein the control signals can interact with a programmable computer system, so that a method as described above is carried out.
A further aspect of the invention relates to a computer program product with program code stored on a machine-readable support for carrying out the method as described above, when the program code is executed on a data processing device.
A further aspect of the invention relates to a computer program product with program codes for carrying out the method as described above, when the program runs on a data processing device. For this purpose, the data processing device can be configured as any computer system known from the prior art.
A further aspect of the invention relates to a method for controlling and regulating motors MOTm of a robot, with m=1, 2, . . . M, wherein the robot has robot components that are interconnected via a number N of articulated connections GELn, with n=1, 2, . . . . N; joint angles of the articulated connections GELn can be adjusted by means of associated motors MOTm; Z(tk)={zp(tk)} is a state of the robot components in an interval tk, wherein k=0, 1, 2, 3, . . . and p=1, 2, . . . , P; a first system of coupled motion equations BGG is predetermined and describes rigid-body dynamics or flexible-body dynamics of the robot manipulator; in the first system of motion equations BGG um(tk) is a manipulated variable for the respective motor MOTm; and for the first system of coupled motion equations BGG, restrictions of the manipulated variables um(tk) and restrictions of the states Z(tk) of the connected robot components are predetermined. The device comprises a means by which, for the first system of coupled motion equations BGG, a second system of locally equivalent decoupled motion equations BGE is provided that describes the rigid-body dynamics or the flexible-body dynamics of the connected robot components: a means by which restrictions of the manipulated variables um(tk) transformed into the second system and restrictions of the states Z(tk) transformed into the second system are provided; a predetermining means by which the state Z(tk) transformed into the second system as Z*(a) is provided; a means by which, for the second system of decoupled motion equations BGE, setting of a target state SZ* of the robot manipulator which is to be reached starting from the state Z*(tk) takes place, and setting of one or more conditions BD* and/or one or more characteristics KZ* that define how to achieve the target state SZ* takes place; a means by which, in the second system of decoupled motion equations BGE a state trajectory ZT*(t) and the associated manipulated variable trajectories uT*m(t) are predicted depending on the state Z*(tk) and the target state SZ* while meeting the conditions BD*, the characteristics KZ*, the transformed restrictions of the manipulated variables um(tk), and the transformed restrictions of the states Z(tk) for an interval of t=tk to t=tk+w, wherein Δt=tk+w−tk is a predetermined prediction interval; a means by which, transforming of the manipulated variable trajectories uT*m(t) and the state trajectories ZT*(t) into the first system of coupled motion equations BGG takes place to generate manipulated variable trajectories uTm**(t) and state trajectories ZT**(t), a means by which, from the manipulated variable trajectories uTm**(t) determination of manipulated variables um(tk+1) for the next interval k+1 and regulating of the motors MOTm by means of the manipulated variables um(tk+1) takes place, a means (208) by which, from the state trajectories ZT**(t) and/or on the basis of sensor data of a detection system of the state Z(t), determining of the state Z(tk+1) takes place for the interval k+1; and a means which is connected to the predetermination means and passes a Z(tk) to the predetermination means, for which Z(tk)=Z(tk+1) applies until a predetermined break-off criterion or the target state SZ/SZ* is reached.
A further aspect of the invention relates to a device for controlling and regulating motors MOTm of a robot, with m=1, 2, . . . M, wherein the robot has robot components that are interconnected via a number N of articulated connections GELn, with n=1, 2, . . . , N; joint angles of the articulated connections GELn can be adjusted by means of associated motors MOTm; Z(tk)={zp(t)} is a state of the robot components in an interval tk, wherein k=0, 1, 2, 3, . . . and p=1, 2, . . . , P; a first system of coupled motion equations BGG is predetermined and describes rigid-body dynamics or flexible-body dynamics of the robot manipulator: in the first system of motion equations BGG um(tk) is a manipulated variable for the respective motor MOTm; and for the first system of coupled motion equations BGG, restrictions of the manipulated variables um(tk) and restrictions of the states Z(tk) of the connected robot components are predetermined, comprising a means by which, for the first system of coupled motion equations BGG, a second system of locally equivalent decoupled motion equations BGE is provided that describes the rigid-body dynamics or the flexible-body dynamics of the connected robot components, and a regulating and/or control law RG for the manipulated variables um(tk) is provided: a means by which restrictions of the manipulated variables um(tk) transformed into the second system, restrictions of the states Z(k) transformed into the second system, and a regulating and/or control law transformed into the second system as RG* are provided; a predetermining means by which the state Z(tk) transformed into the second system as Z*(tk) is provided; a means by which, for the second system of decoupled motion equations BGE, one or more conditions BD* and/or one or more characteristics KZ* that define how to achieve the target state SZ* are provided; a means by which, in the second system of decoupled motion equations BGE a state trajectory ZT*(t) and the associated manipulated variable trajectories uT*m(t) are predicted depending on the state Z*(tk) and the target state SZ* on the basis of the regulating and/or control law RG transformed into the second system while meeting the transformed restrictions of the manipulated variables um(tk), and the transformed restrictions of the states Z(tk) are predicted with at least an accuracy of <20% for an interval of t=tk to t=tk+w, wherein Δt=tk+w−tk with W>k is a predetermined prediction interval; a means by which transforming of the manipulated variable trajectories uT*m(t) and the state trajectories ZT*(t) into the first system of coupled motion equations BGG takes place to generate manipulated variable trajectories uTm**(t) and state trajectories ZT**(t), a means by which, from the manipulated variable trajectories uTm**(t) manipulated variables um(tk+1) are determined for the next interval k+1 and the motors MOTm are regulated by means of the manipulated variables um(tk+1): a means by which, from the state trajectories ZT**(t) and/or on the basis of sensor data of a detection system of the state Z(t), the state Z(tk+1) is determined for the interval k+1; and a means which is connected to the predetermination means and passes a Z(tk) to the predetermination means, for which Z(tk)=Z(tk+1) applies until a predetermined break-off criterion is reached.
The specified means of the proposed devices can be configured as a computer which at least comprises: a processor which performs the stated calculations or the control/regulation tasks, an input interface (keyboard, mouse, internet, WLAN. Bluetooth etc.), an output interface (monitor, printer, loudspeaker, etc.) and a storage unit (hard disk/CD/SIM card, etc.).
Lastly, a further aspect of the invention relates to a robot with a device as described above.
The following statements explain the idea underlying the invention in greater detail using the specific example of a control/regulation of a robot manipulator, the joints of which can be adjusted by motors.
In order to ensure the safety of persons located in the surroundings of the robot and/or of the robot, it is necessary in many situations to brake a robot manipulator. A partial aspect relates to a method for estimating a braking trajectory (i.e. a braking distance prediction) of the robot manipulator starting from a current state of the robot manipulator. The estimation includes a final standstill position of the robot manipulator, the standstill time associated therewith as well as the complete progression over time of the joint angle/robot position (kinematics) and dynamics from the start of the braking operation until the robot manipulator is at a standstill. When the braking trajectory is determined, the following questions inter alia can be answered:
With the aid of the answers to these questions the following (re)actions are possible inter alia:
Afterwards in this connection two models are proposed which can advantageously be used to describe a dynamics of the robot manipulator.
The first model describes the dynamics of a robot manipulator with rigid articulated connections. In this case the robot manipulator is described as an open kinematic chain with rigid bodies and n rotational articulated connections GELn. The dynamics of the robot manipulator with rigid articulated connections GELn is given in the first model by the following differential equation:
M(q){umlaut over (q)}+C(q,{dot over (q)})+g(q)=τ+τf+τext (1)
wherein the generalized coordinates qϵRn are the positions of the n articulated connections GELn. M(q)ϵRn×n is the symmetrical and positively defined mass matrix; C(q, {dot over (q)})ϵRn×n the Coriolis and centrifugal forces; and g(q)ϵRn the gravity vector, tϵRn is the motor torque; τfϵRn the motor friction torque; and τextϵRn the external torque. It is assumed that τf=τext=0 applies. The motor torque, the motor speeds and the positions of each joint i are typically limited as follows:
|τi|<τmax,i (2)
|{dot over (q)}i|<{dot over (q)}max,i (3)
|{dot over (q)}i|<{dot over (q)}max,i (4)
with: i=1, . . . , n.
Other restrictions are possible. The positions qi can also be unrestricted.
The following second model describes a robot manipulator with resilient articulated connections GELn. For robot manipulators that have definitely intrinsically resilient articulated connections have, the starting point is the following dynamics:
M(q){umlaut over (q)}+C(q,{dot over (q)})+g(q)=τJ+τext (5)
B{umlaut over (θ)}+τ
J=τ+τf (6)
τJ=KJ(θ−q)=KJ(φ) (7)
In this case θϵRn is the motor position, qϵRn the output position, τjϵRn the elastic torque, Kj=diag{kJ,i}ϵRn×n the diagonal, positive definite rigidity matrix and B=diag{bi}ϵRn×n the diagonal, positive definite motor mass matrix. In this case the following limiting values are typically taken into consideration:
|τi|<τmax,i (2)
|θi|≤θmax,i (8)
|{dot over (θ)}i|≤{dot over (θ)}max,i (9)
|φi|≤φmax,i (10)
with i=1, . . . , n. In this connection φ=0−q is the deflection of the articulated connection. In this robot model the motor dynamics is linear, i.e. the motor and output dynamics are only coupled by means of the resilient torque. The output dynamics in the second model has the same properties as the robot manipulator with rigid joints.
The initial and end conditions for braking a robot manipulator are:
q(0)=q0,q(tf)=free, or q(tf)=qd(tf) (12)
{dot over (q)}(0)={dot over (q)}0,{dot over (q)}(tf)=0 (13)
{umlaut over (q)}(0)={umlaut over (q)}0,q(tf)=0 (14)
where q(0), {dot over (q)}(0) and {umlaut over (q)}(0) are the initial position, speed and acceleration of the output. At the end time tf the speed and acceleration are zero, whereas the position is either undefined or is a specific target position. In addition to (12)-(14), the following boundary conditions apply for robot manipulators with resilient joints:
θ(0)=θ0,θ(tf)=KJ−1g(q(tf))+q(tf) (15)
{dot over (θ)}(0)={dot over (θ)}0,{dot over (θ)}(tf)=0 (16)
{umlaut over (θ)}(0)={umlaut over (θ)}0,{umlaut over (θ)}(t)=0 (17)
Similarly to the output, the motor acceleration and motor speed must be zero in order to achieve a standstill. In equilibrium the elastic torque in the joint must compensate for the gravitational torque, i.e. τJ(tf)=g(q(tf)). This results in a static deviation between the motor position and the output position.
In order to satisfy the conditions (12) to (17), different brake regulators can be used. As a rule these have the objective of meeting a specific predetermined criterion. Thus, the braking can take place inter alia optimally in terms of energy or time, and alternatively attempts can be made to brake along a desired trajectory. One or more brake regulators may be available for the braking.
Furthermore, the boundary conditions for the braking of a robot manipulator are explained, and possible brake regulators are presented which can satisfy these conditions.
The estimation of the braking trajectory of the robot manipulator (braking distance prediction) consists of determining the trajectory of the robot manipulator from the starting state θ(0), {dot over (θ)}(0), {umlaut over (θ)}(0), q(0), {dot over (q)}(0), {umlaut over (q)}(0) to a standstill {dot over (θ)}({circumflex over (t)}f)={dot over (q)}({circumflex over (t)}f)=0, {umlaut over (θ)}({circumflex over (t)}f)={umlaut over (q)}({circumflex over (t)}f)=0 including the dynamics of the robot manipulator and of the regulator. The estimated final time is designated by {circumflex over (t)}f.
In order to calculate the braking trajectory, the entire dynamics of the robot manipulator [equation (1) for robots with rigid joints or equations (5)-(7) for robots with resilient joints] can be simulated forwards. This usually requires considerable computing power and cannot be achieved in real time at high regulator scanning rates.
However, it is possible to simplify the computation by making assumptions about the dynamic system behavior. Since gravitational and Coriolis torques are usually compensated for by the robot control, for the sake of simplification they can be excluded from the computation. Thus, for robot manipulators with rigid joints (rigid kinematics), for example, only the change to the mass matrix M(q) can be considered. Furthermore, for the sake of simplification it can be assumed that the dynamics hardly changes during the braking operation and thus can be regarded as constant. These simplifications lead to an impairment of the precision of prediction of the braking trajectory, but the prediction can be calculated more quickly and, if need be, can be implemented in real time.
A simulation of the dynamics from the starting state to a standstill supplies the estimated progression of the joint positions {circumflex over (q)}b(t)ϵRn and joint speeds {circumflex over ({dot over (q)})}b(t)ϵRn, where tϵ[t0, tf] applies. By eigendecomposition of the system dynamics it is possible to describe the braking trajectory not only in the joint space but also in modal coordinates.
Furthermore if, for example, a relevant point, designated as POI (point of interest), on the robot manipulator is considered, it is possible with the aid of the forward kinematics of the robot manipulator also to determine the progression over time of the Cartesian position {circumflex over (x)}b,POI(t)ϵR3 and speed xb,POI(t)ϵR3 of this POI. Cartesian, joint and modal coordinates can always be transferred into one another by transformation.
In order to actively influence the braking distance of the robot manipulator, for example in order to avoid collisions, the braking trajectory is advantageously also calculated (estimated) when the robot manipulator behaves nominally (for example, follows a desired trajectory), no error state occurs, and there has been no request from the user for stopping or the actual braking operation has not yet been initiated. When the estimation of the braking distance is calculated regularly, with reference to different criteria that are described below the braking can be automatically initiated and/or modifications to the brake regulator or to the desired braking trajectory can be carried out.
After the braking trajectory has been calculated, starting from the initial state of the robot manipulator, this trajectory can be used advantageously for further analyses and provisions of the robot control.
For example, an object (article/obstacle/person/etc.) in a working space of the robot manipulator may be represented by a number Xobs of Cartesian points. Naturally, other coordinate systems can also be used. The distance of the aforementioned POIs of the robot manipulator from an object/obstacle can be determined with the aid of the function d=min_dist(xPOI, xobs), wherein min_dist for example can be obtained with the GJK algorithm [1] or the Kinematic Continuous Collision Detection Library [2]. Naturally, a plurality of POIs and a plurality of objects/obstacles can also be taken into consideration.
If the braking trajectory is known, the smallest distance from the object can be determined during the braking operation, namely: {circumflex over (d)}min=min(min_dist(xPOI(t),Xobs)), tϵ[t0, tf]. The smallest possible distance does not necessarily have to occur when the robot manipulator comes to a standstill, but can be present along the braking trajectory. If {circumflex over (d)}min>0 applies, then the robot manipulator probably will not collide with the object, whereas for the case {circumflex over (d)}min≤0 a contact is very likely.
During the braking operation it can happen that predetermined restrictions BD* (characteristic values KW*), such as, for example, the maximum position or speed of an articulated connection GELn, are breached. As a rule it is undesirable for limiting values to be exceeded, since this leads to damage to the robot lead and/or can impair the braking operation. With the aid of the estimated braking trajectory it is possible to examine the progression of the joint/motor positions and speeds proactively for instances of limiting values being exceeded. For robot manipulators with rigid articulated connections, values are exceeded when the following applies:
|{circumflex over (q)}b,i(t)|≥qmax,i (18)
|{circumflex over ({dot over (q)})}b,i(t)|≥{dot over (q)}max,i (19)
wherein tϵ[t0, {circumflex over (t)}f] and i=1, . . . , n. For robot manipulators with resilient articulated connections, there is a breach of limiting values when the following applies:
|{circumflex over (θ)}b,i(t)|≥θmax,i (20)
|{circumflex over ({dot over (θ)})}b,i(t)|≥{dot over (θ)}max,i (21)
|{circumflex over (φ)}b,i(t)|≥φmax,i (22)
Thus, with the aid of the braking distance prediction it is possible to determine at what time and to what extent limiting values are exceeded.
When the braking distance prediction foresees a collision, for example, with a person, i.e. {circumflex over (d)}min≤0, the probability of injury to the person and/or the probability of damage to the robot can be determined with suitable collision models or other representations/indices that assign collision parameters to injury/damage.
If a plurality of brake regulators are available for braking of the robot manipulator, it is possible to predicted which brake regulator best meets a specific predetermined criterion. For this purpose, the braking trajectory must be calculated for each brake regulator. For example, it is possible to analyze which method leads most quickly to stopping of the robot manipulator or can maintain the smallest distance from the surroundings during braking.
Thus, with the aid of the braking distance prediction it is possible to determine the minimum distance of the robot manipulator from an obstacle/object during the braking operation. This knowledge can be used to initiate the braking so that no possibly dangerous collision occurs or at least the danger emanating from the robot manipulator is minimized.
In order to avoid contact, the braking operation must be initiated so long as {circumflex over (d)}min>0 applies. If the estimated distance is less than or equal to zero, the robot manipulator will probably collide with the obstacle/object. The robot control can initiate the braking automatically as soon as the minimum estimated distance falls below a limiting value ϵ, i.e. {circumflex over (d)}min<ϵ applies.
If the result of the calculation of the braking trajectory is that predetermined limiting values are breached, the regulation parameters, the regulator type or a desired braking trajectory can be modified in order to achieve better compliance with the limiting values. If changes have been made, the braking trajectory must be estimated again. This procedure can be repeated successively until all the limiting values are complied with. In many cases, however, the initial conditions during initiation of the braking operation are such that with limited control variables it is not possible to avoid exceeding limiting values. Advantageously, during planning of the robot trajectory it is ensured are that the robot can be braked at any time.
Using the estimation of a severe injury to a person and/or of damage to the robot manipulator, the braking operation can be initiated in such a way that a contact occurs ({circumflex over (d)}min≤0), but a specific degree of severity of the injury/damage is not exceeded.
The following example serves for further explanation of the above statements. In this example the braking of a robot manipulator is treated with the dynamics (1) and limiting values (2)-(4). Robot manipulators with resilient joints and corresponding dynamics (5)-(7) are not considered, since the basic procedure is the same as for robot manipulators with rigid joints.
The aim is to bring the robot manipulator to a standstill as quickly as possible. In this case it is assumed that a person stays in the working space of the robot manipulator without moving. The position as well as the outline of the person are detected, for example, by a 3D scanner or a 3D camera system and are provided for the control of the robot manipulator. In order to determine the distance between the robot manipulator and the person, only a POI of the robot manipulator is considered.
During design of the regulator it is assumed that the motor torques are limited according to (2). A part of the maximum torque is applied to compensate for gravity. The configuration-dependent limits are:
τ′m,i(q):=−(τmax,i+gi(q))<0 (24)
τ′M,i(q):=τmax,i+gi(q)>0 (25)
The remaining component of the available torque τ′=τ−g(q) satisfies the condition:
τ′m,i(q)≤τi<τ′M,i(q),i=1, . . . ,n. (26)
Two brake regulators are proposed below. A brake regulator that is designed in joint coordinates q [5] and a brake regulator that is designed in modal co-ordinates.
The change to the kinetic energy of a robot manipulator over time is: {dot over (T)}={dot over (q)}τ′. The following regulator law leads locally to the greatest possible reduction of T:
with i=1, . . . , n. In order to achieve a compromise between an optimal solution and a uniform achievement of the target state {dot over (q)}(tf)=0, {umlaut over (q)}(tf)=0, a transition region 2ϵi can be introduced, such as takes place in (28).
For the sake of simplicity only the regulator law (27) is considered below. Since Coriolis torques are present, the effective torque is the one that accelerates the mass of the robot manipulator:
{tilde over (τ)}=τ−g(q)−C(q,{dot over (q)}){dot over (q)}. (29)
If the locally optimal brake regulator is used, the following is obtained:
{tilde over (τ)}i=−sign({dot over (q)}i)τmax,i−gi(q)−{C(q,{dot over (q)}){dot over (q)}}i (30)
with i=1, . . . , n.
With the aid of (29) the dynamics of the robot manipulator (1) can be formulated as follows:
M(q){umlaut over (q)}=f (31)
By solution of the generalized eigenvalue problem (31) can be transformed into a decoupled space. Because of the symmetrical, positively definite mass matrix M(q) an orthonormal matrix VϵRn×n can be found, so that the following correlation applies:
MV=VM
V (32)
In this case MV=diag{mV,i}i=1, . . . , n is a diagonal matrix that contains the system eigenvalue. By the use of V the output positions, speeds and accelerations as well as the effective torque can be transformed into modal coordinates.
q
V
=V
T
q (33)
{dot over (q)}
V
=V
T
{dot over (q)} (34)
{umlaut over (q)}
V
=V
T
{umlaut over (q)} (35)
{tilde over (τ)}V=VT{tilde over (τ)} (36)
As a result, n double integrators that are independent of one another are obtained
m
v,i
{umlaut over (q)}
V,i={tilde over (τ)}V,i=1, . . . ,n (37)
In order to convert the regulator law (27) into modal coordinates, the control limits, i.e. the motor torques, are likewise transformed into the decoupled space. The space that is spanned by the motor torque can be described by the hypersquare
Ω:=[τ′m,1,τ′M,1]× . . . ×[τ′m,n,τ′M,n]
with the corresponding key points vi=[vi(1), . . . , vi(n)]T, i=1, . . . , 2n, see
ΩV:=VT(Ω)
which means that each section of i is transformed. The transformation is linear, for det[Ω]T=1 the hypersquare is rotated about the origin, whereas for det[Ω]T=−1 a mirroring takes place.
After the motor torques have been transformed into the decoupled space, the maximum and minimum values of each articulated connection or modal coordinates are no longer independent of one another. This behavior can be reproduced with reference to the rectangle with sides shown by broken lines in
It is possible to find the greatest possible hypersquare Ω′V. The ratio of minimum and maximum manipulated variable of each articulated connection should also be obtained here in modal coordinates, and for this reason the original torques are scaled uniformly, see
The required scaling factor k can be determined with the aid of the algorithm set out below. The maximum and minimum joint torques are τ′M:=[τ′M,i, . . . , τ′M,n]T and τ′m:=[τ′m,i, . . . , τ′m,n]T.
The limiting values of the control input in the decoupled space are now
τ′V,m≤τ′V,i≤τ′V,M (40)
Similarly to (27), the regulator law for braking of each modal coordinate states
with i=1, . . . , n. Ultimately the control input in the joint space can be obtained by back transformation with V:
τ=Vτ′v+g(q). (42)
With regard to the required braking duration the brake regulator (42) is less efficient than the brake regulator (27), since the available motor torques must be reduced in order to implement the decoupling of dynamics and control range.
Subsequently the decoupling-based brake regulator (42) is used in order to brake the robot. The calculation (estimation) of the braking trajectory now follows. First of all, the prediction of the braking trajectory using the decoupling-based regulator is considered. Next it is described how these results can be used if the joint-based brake regulator (27) is employed.
It is assumed that Coriolis torques are negligible or have been compensated for exactly. Furthermore, since the joint angles q only change a little during the braking operation, it is assumed, that the mass matrix is constant. The dynamics in modal co-ordinates is given by:
m
V,i
{umlaut over (q)}
V,i=τ′V,ii=1, . . . ,n. (43)
The braking of a double integrator only requires one motor cycle, i.e. the motor does not have to reverse the torque. By solution of the dynamics (43) for a constant control input the following is obtained:
with i=1, . . . , n. If {circumflex over ({dot over (q)})}V,i(t)=0 is set and this equation is solved with respect to time, the final time and associated end position are obtained:
If a modal coordinate has reached a standstill, τ′V,i(t>{circumflex over (t)}f,i)=0 must be selected and consequently the following is obtained:
{circumflex over (q)}
V,i(t>{circumflex over (t)}f,i)={circumflex over (q)}V,i({circumflex over (t)}f,i) (48)
{circumflex over ({dot over (q)})}(t>{circumflex over (t)}f,i)=0 (49)
The braking duration of the entire robot manipulator is generally the greatest final time of all co-ordinates:
{circumflex over (t)}
f=max({circumflex over (t)}f,i),i=1, . . . ,n (50)
With the aid of the estimated braking duration and (44)-(45) it is now possible to determine a discretized braking trajectory. The time vector tb that consists of nb support points is defined for this purpose.
The decoupled positions and speeds (44) and (45) can now be determined for each time tb,j. The entire braking trajectory can be represented by the following matrices.
The braking trajectory in the joint space can be obtained by the back transformation by means of V.
{circumflex over (Q)}
b
=[q
bV,1
, . . . ,q
bV,n
]=[V{circumflex over (q)}
bV,1
, . . . ,V{circumflex over (q)}
bV,n
] (55)
{circumflex over ({dot over (Q)})}b=[{dot over (q)}bV,1, . . . ,{dot over (q)}bV,n
A discretization of the braking trajectory does not necessarily have to take place. For the analyses, for example, optimization processes are employed that use (44) and (45) directly.
If the joint-based regulator (27) is used in order to brake the robot manipulator, the braking distance prediction can be calculated as follows. Advantageously, in order to carry out a real-time capable computation the following simplifications are performed:
It is possible to solve the system dynamics in the joint space, from the starting state to the standstill, in order to obtain the braking trajectory. Furthermore, it is possible to determine the braking trajectory in the decoupled space (32)-(37). When calculating the modal positions and speeds attention must be paid to the plus/minus sign of τ′V,i. Whereas in the decoupling-based regulator (42) the plus/minus sign of the torque remains the same until the standstill, the plus/minus sign of the torque in the joint space can change during the braking operation because of the coupling of the system dynamics. Therefore, changes of plus/minus sign of q and r must be detected and must be included in (33)-(37) and (44)-(45).
For the sake of simplicity, only a POI of the robot manipulator to which a Cartesian position xPOI is assigned is considered. The stationary person is represented by a number of points Xh. Using the forward kinematics of the robot manipulator and the estimated braking trajectory (55), the progression the POI position {circumflex over (x)}POI,j over time can be specified, as well as the distance {circumflex over (d)}j=min_dist(xPOI,J, Xh), j=1, . . . , n, of the robot manipulator from the person. The smallest possible estimated distance is {circumflex over (d)}min=min({circumflex over (d)}). Instead of evaluating the discretized braking trajectory, alternative optimization methods (for example, gradient methods) can be used, in order to determine the minimum distance in a shorter computing time.
In order to are determine whether a speed or positioning limit is exceeded, it is necessary to examine whether (3) and (4) complied with during the braking operation. Since the decoupling approach has been chosen for the brake regulator and the braking distance prediction, the modal positions and speeds are transformed into the joint space. In vector notation (44) and (45) are:
{circumflex over (q)}
V(t)=qV,0+{dot over (q)}v,0t+½bvt2 (57)
{circumflex over ({dot over (q)})}V(t)={dot over (q)}V,0+bvt (57)
with
Through back transformation by means of V the following is obtained
{dot over (q)}
t
=q
0
+{dot over (q)}
0
t+½bt2 (59)
{circumflex over ({dot over (q)})}t={dot over (q)}v+bt (60)
with b=Vbv. In order to determine the time when a limiting value is exceeded, {circumflex over (q)}i(t)=±qmax,i is set, with i=1, . . . , n, and is solved with respect to time.
For speeds {circumflex over ({dot over (q)})}i(t)=±{dot over (q)}max,i, is set, with i=1, . . . , n, so that
is obtained. In the decoupled space, the individual coordinates can come to a standstill at different times. Therefore, up to n time intervals must be taken into consideration in the calculation of (61)-(63). If the coordinates with index i come to a standstill, τ′V,i=0 is selected at the regulator. In order to determine the time of a breach of limiting values for the next interval—if none has been ascertained beforehand—b, q0, {dot over (q)}0 must be initialized again, in order to be used in (61)-(63). Limiting values are exceeded if {circumflex over (t)}1/2,i, {circumflex over (t)}3/4,i, or {circumflex over (t)}5/6,i is less than the final time {circumflex over (t)}f,i, of the current time period.
Alternatively, breaches of limiting values can be searched for iteratively in the discretized braking trajectory (53)-(54):
|{circumflex over (q)}b,i,j|≥qmax,i (64)
|{circumflex over ({dot over (q)})}b,i,j|≥{dot over (q)}max,i (64)
with i=1, . . . , n and j=1, . . . nb.
In the following example it is stated how the probability of injury to a human in a collision with the robot manipulator can be determined with the aid of the results and methods from [3]. Let {circumflex over (t)}imp be the estimated time of a collision.
The reflected Cartesian mass {circumflex over (m)}POI ({circumflex over (t)}imp) and speed {circumflex over (x)}POI({circumflex over (t)}imp) of the POI in the direction u. can be determined [4]. With the aid of these values and the surface geometry of the POI the maximum permitted, biomechanically safe POI speed in the direction u. can be calculated by evaluating the linear safety curve:
{circumflex over ({dot over (x)})}POI,max({circumflex over (t)}imp)=c1{circumflex over (m)}POI({circumflex over (t)}imp)+c2 (22)
where {circumflex over ({dot over (x)})}POI,max({circumflex over (t)}imp) is the maximum permitted speed. The parameters c1, c2 result from collision experiments. If the following applies:
{circumflex over ({dot over (x)})}POI,MAX({circumflex over (t)}imp)≥{circumflex over ({dot over (x)})}POI({circumflex over (t)}imp), then the selected injury severity is very probably exceeded.
Two algorithms (algorithm 2 and algorithm 3) for estimation and analysis of the braking trajectory are described below, which build on the decoupling-based regulator (42). Algorithm 2 checks the braking trajectory exclusively with regard to exceeding limiting values, whereas in algorithm 3 the entire discretized braking trajectory is determined and breaches of limiting values and potentially dangerous collisions are examined.
In the algorithm 2, first of all the limits of the available motor torque t′ in the joint space are determined. Then joint positions, speeds, and torques are transformed into the decoupled space. After the locally optimal control input and the final braking duration for each modal coordinate have been determined, the braking times are sorted in ascending order s. For i=1 . . . n intervals the times of possible instances of limiting values being exceeded are calculated for each coordinate with index j=1 . . . n. If a calculated time is less than the end time of the current interval, a limiting value is probably exceeded. If in the respective interval no exceeding of limiting values has been ascertained, the initial values for positions, speeds and torques are initialized again for the next interval.
In the algorithm 3 the control input and the braking duration of each modal coordinate are determined as in algorithm 2. Then the braking duration and final position q(if) of the entire robot manipulator is determined. After definition of the time vector tb the modal positions and speeds of the discretized braking trajectory are determined. In each time step it is checked whether limiting values are exceeded and the distance from the person is estimated. In the event of a collision it is analyzed whether this leads to an injury to the person. Finally, the smallest possible distance that occurs between human and robot during the braking trajectory is determined.
Advantages and preferred embodiment of the device are produced by corresponding and analogous transfer of the statements made above with regard to the proposed method.
In this case the proposed method is actually applied, in order that a robot manipulator that is in motion is braked in a minimum time into a rest state, i.e. a state without motion. The dynamics of the robot manipulator may be described by the following system of coupled motion equations BGG:
θ=∫{dot over (θ)}dt+θ0 (37)
M(q){umlaut over (q)}=KJ(θ−q) (38)
with θ0ϵRn as the N motor positions at the time of the start of braking.
In general, the system of equations (37)-(38) cannot be solved analytically because of the coupling by means of mass or inertia matrix M(q). A numerical solution of the system of equations (37)-(38) requires too much computing time for a real-time control. On the other hand, the proposed method enables the manipulated variable to be ascertained sufficiently precisely. Moreover, with the proposed method it is possible to determine the braking trajectory of each articulated connection of the robot manipulator and the necessary braking time in real time.
In order to solve the present optimal control problem, the dynamics equation (37)-(38) is initially decoupled by means of eigenvalues. For this purpose, the mass matrix M(q) may be symmetrically and positive definite. Furthermore, the rigidity matrix Kj may be positive definite, so that an orthonormal matrix VϵRn×n can be found, for which the following applies:
MV=KVM
V, (39)
wherein MQ is a diagonal matrix. When new decoupled coordinates θQ=V−1θ and qQ=V−1q are used, N independent SISO (single input single output) spring systems are obtained:
M
V
{circumflex over (q)}
V=θV−qV. (40)
Furthermore, it is significant that the restrictions of the manipulated variables um(t) must likewise be transformed into the decoupled system. The restrictions of the manipulated variables um(t) here may be given by um,min and um,max. These restrictions span a manipulated variable space Ω (hypercube):
Ω:=[u1,min,u1,max]× . . . ×[um,min,um,max] (41)
The manipulated variable space ΩQ transformed into the decoupled system is then revealed as:
ΩV=Q−1(Ω). (42)
This transformation is linear. If, for the determinant of the transformation matrix Q−1, detV−1=1 applies, the hypercube is rotated, and for detV−q=−1 the hypercube is reflected.
Furthermore, it is significant that after the transformation of the restrictions um,min and um,max into the decoupled system, the values um,min, um,max set out above are no longer independent of one another. This means that in the decoupled system BGE, the restrictions um,min, um,max are basically not decoupled. In order nevertheless to enable an analytical solution in the decoupled system, a search is performed for the largest hypercube ΩV′ in the transformed system which lies completely within the original limits (see equation (41)) of the back-transformed hypercube Ω′. For this hypercube ΩV′ the manipulated variables um*(t) and the restrictions um,min, um,max are independent, i.e. decoupled, so that the decoupled motion equations can be solved analytically. After the manipulated variable trajectories uTm*(t) and state trajectory ZT*(t) in the decoupled system have been determined, they are back-transformed into the original coupled system. From the manipulated variable trajectory uTm**(t) the manipulated variables um(tk+1) for the next interval k+1 are determined and, furthermore, the manipulated variables um(tk+1) are used for control or regulation of the motor MOTm.
In this connection
In a step 101, for the first system of coupled motion equations BGG, a second system of locally equivalent decoupled motion equations BGE is provided that describes the rigid-body dynamics or the flexible-body dynamics of the connected robot components. A step 102 provides restrictions of the manipulated variables um(tk) transformed into the second system and provides restrictions of the states Z(tk) transformed into the second system. In a step 103 the state Z(tk) transformed into the second system as Z*(tk) is provided. In a step 104, for the second system of decoupled motion equations BGE, setting a target state SZ* of the robot manipulator which is to be reached starting from the state Z*(tk) takes place, and setting one or more conditions BD* and/or one or more characteristics KZ* that define how to achieve the target state SZ* takes place. In a step 105, in the second system of decoupled motion equations BGE a state trajectory ZT*(t) and the associated manipulated variable trajectories uT*m(t) are predicted depending on the state Z*(tk) and the target state SZ* while meeting the conditions BD*, the characteristics KZ*, the transformed restrictions of the manipulated variables um(tk), and the transformed restrictions of the states Z(k) for an interval of t=tk to t=tk+w, wherein Δt=tk+w−tk is a predetermined prediction interval. In a step 106 transforming of the manipulated variable trajectories uT*m(t) and the state trajectories ZT*(t) into the first system of coupled motion equations BGG takes place to generate manipulated variable trajectories uTm**(t) and state trajectories ZT**(t), In a step 107, from the manipulated variable trajectories uTm**(t) determination of manipulated variables um(tk+1) for the next interval k+1 and regulating of the motors MOTm by means of the manipulated variables um(tk+1) takes place. In a step 108, from the state trajectories ZT**(t) and/or on the basis of sensor data of a detection system of the state Z(t), determining of the state Z(tk+1) takes place for the interval k+1. In a step 109, for Z(tk)=Z(tk+1), the method is performed again, starting with step 103, until a predetermined break-off criterion or the target state SZ* is reached. The method is advantageously carried out automatically.
Although the invention has been illustrated and explained in detail by preferred exemplary embodiments, the invention is not restricted by the disclosed examples and other variations can be deduced therefrom by the person skilled in the art without departing from the scope of protection of the invention. It is therefore clear that a number of possible variations exist. It is likewise clear that embodiments referred to by way of example actually only constitute examples that should not be interpreted in any way as a limitation of the scope of protection, the possible applications or the configuration of the invention. In fact the foregoing description and the description of the drawings enable the person skilled in the art to implement the exemplary embodiments specifically, wherein the person skilled in the art with a knowledge of the disclosed idea underlying the invention can make diverse changes with regard to the function or the arrangement of individual elements mentioned in an exemplary embodiment, without departing from the scope of the invention that is defined by the claims and the legally corresponding passages, such as for instance further explanation in the description.
Number | Date | Country | Kind |
---|---|---|---|
10 2015 106 227.5 | Apr 2015 | DE | national |
This application is a U.S. national phase application, claiming priority under 35 U.S.C. 371 to PCT application PCT/EP2016/059062, filed on Apr. 22, 2016, claiming priority to German national application 10 2015 106 227.5, filed on Apr. 22, 2015, the contents of the these applications incorporated by reference as if fully set forth herein in their entirety.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/EP2016/059062 | 4/22/2016 | WO | 00 |