Information
-
Patent Grant
-
5832188
-
Patent Number
5,832,188
-
Date Filed
Thursday, October 10, 199628 years ago
-
Date Issued
Tuesday, November 3, 199826 years ago
-
Inventors
-
Original Assignees
-
Examiners
- MacDonald; Allen R.
- Smith; Jeffrey S.
Agents
-
CPC
-
US Classifications
Field of Search
-
International Classifications
-
Abstract
A method and device for clock-synchronized motion control in discrete-time sampling systems is provided, in particular for use in numerical control systems for machine tools and robots. The method includes the derivation of any order m from the tool path feedrate (v or x.sub.2) or of any order m+1 from the position (s or x.sub.1) serving as the manipulated variable (u), the acceleration (a or x.sub.3) or the jerk limitation (r or x.sub.4) preferably being used. The exact control sequence (u) for the motion control is determined from the n=m+1 discrete-time system matrix equations of the sampling system, given an initial state (x.sub.k) and desired state vector (xx.sub.k+v) The manipulated variable (u) is changed in accordance with the specific values of the control sequence (u) within the time reference (k*T) of the sampling system, in particular in the interpolation clock cycle when working with numerical control systems for machine tools and robots. If the order n of the system-matrix equation system is smaller than the number of sampling intervals (.nu.) for traveling from the initial state (x.sub.k) into the desired state (x.sub.k+v), the number (.nu.-n) of additional degrees of freedom conditional upon this is used to fulfill secondary criteria, in particular to avoid overly stressing mechanical systems being used by minimizing the average manipulated variable energy.
Description
FIELD OF THE INVENTION
The present invention relates to a method and a corresponding device for clock-synchronized motion control in discrete-time sampling systems, in particular for use in numerical control systems for machine tools and robots.
BACKGROUND OF THE INVENTION
In discrete-time sampling systems, e.g., when working with numerically controlled machine tools and robots, a manipulated variable for motion control can only be changed, as a rule, within a fixed time reference of the control, i.e., within the interpolation clock cycle when working with numerical control systems for machine tools and robots. However, no exact means for achieving a time optimal and clock-synchronized motion control of such discrete-time sampling systems has been disclosed in known methods heretofore. For this reason, alternative arrangements exist for solving this problem in different ways.
German reference no. 41 07 514 A1 describes setting up discrete-time closed loops, which aid in approaching the target with control. However, such a method can only be carried out satisfactorily when the time reference is small compared to the transient response of the control--a so-called quasi continuous action--and, as a rule, has been used successfully in elevators, hoisting cages and railroads. However, in the application area of numerically controlled machine tools, the jerk and acceleration phases lie in the order of magnitude of the interpolation clock cycle, thus of the time reference, so that there is no quasi continuous action. Accordingly, the known process is ruled out for such an application as it is generally not feasible.
The dissertation "Bahnplanung und Bahnfulhrung von Industrierobotern" �Trajectory Planning and Control for Industrial Robots!, J. Olomski, Braunschweig, Wiesbaden: Vieweg 1989, Fortschritte der Robotik �Advances in Robotics! volume 4, pages 42 to 53, describes computing the optimal manipulated variable curve for a time-continuous system and approximating the continuous instants on the basis of the discrete time reference. Since, in this case, the manipulated variable curve is established independently of the interpolation clock grid, jumps appear in the acceleration profile, which, given a control with moment precontrol, result in increased stressing of the mechanical systems being used. European Patent EP-0 419 706 B1 entitled "Verfahren zur numerischen Positions- oder Bahnsteuerung" �Method for Numerical Position or Path Control! describes the precise computation of an acceleration-controlled motion profile, where the time discretization is considered. In addition, jerk limitation is carried out in that the acceleration values are filtered through mean value generation. However, since in this case the jerk cannot be specified causally, but rather only indirectly from the acceleration values, problems arise in calculating deceleration distances. To be able to simply calculate a deceleration distance, the motion profile to be traveled of the individual data sets must be known in advance. However, an inherent disadvantage of this procedure is that it goes counter to desired on-line override changes.
European Patent Application EP-9411665.5 entitled "Ruckbegrenzte Geschwindigkeitsfuhrung" �Rate-of-Change Limited Velocity Control! proposes creating additional degrees of freedom by introducing an additional phase each time nominal velocity is approached and when decelerating into the target point. The nominal velocity is approached nearly exactly, because the jerk limitation in the additionally introduced phase, i.e., the transition clock cycle phase to nominal velocity, is allowed to change asynchronously. The approach into the target position is likewise reached nearly exactly when the acceleration prevailing at the instant deceleration begins is equal to zero. However, this condition is rarely satisfied--especially given short travel paths--, so that here, as well, the continuous instants must be approximated through the discrete time reference.
Thus, none of the methods indicated for solving the problem is able to control motion in discrete sampling systems in exact clock-controlled synchronism or in a time-optimal manner.
OBJECTS AND SUMMARY OF THE INVENTION
Therefore, an object of the invention is to provide a method as well as a corresponding device of the type mentioned at the outset that will enable motion to be controlled in discrete-time sampling systems, where the manipulated variable can only change within the fixed time reference or interpolation clock cycle of the control, in exact clock-controlled synchronism, as well as in a time-optimal manner.
This objective is achieved in accordance with the invention by the following process steps:
1.1 the derivation of any order m from the tool path feedrate or of any order m+1 from the position serves as the manipulated variable, the acceleration or the jerk limitation preferably being used;
1.2 the exact control sequence for the motion control is determined from the n=m+1 discrete-time system matrix equations of the sampling system, given an initial state and desired state vector;
1.3 the manipulated variable is changed in accordance with the specific values of the control sequence within the time reference of the sampling system, in particular in the interpolation clock cycle when working with numerical control systems for machine tools and robots.
In a first advantageous embodiment of the method in accordance with the present invention, a mathematical property of the applied system-matrix equation system is used to optimize the precisely clock-synchronized motion control in light of the factors influencing the discrete-time sampling system, especially in light of the dynamic response of electrically driven factors. This is achieved by the following further process step:
2.1 the number of additional degrees of freedom conditional upon this is used to fulfill secondary criteria, in particular to avoid stressing mechanical systems being used by minimizing the average manipulated variable energy.
In another advantageous embodiment of the method in accordance with the present invention, a control sequence is determined for a method for attaining a predetermined nominal velocity for a motion control, which takes into consideration the dynamic capabilities of the underlying discrete-time sampling system, in particular of an electrical drive, so that the motion control can be carried out in a time optimal manner. To this end, travel toward a predetermined nominal velocity takes place in accordance with the following process steps:
3.1 The acceleration continues to be built up with the maximum permissible jerk for as long as it is not imminent that the maximum permissible acceleration will be exceeded in the subsequent sampling period, and the jerk is then reduced to the extent that the maximum permissible acceleration is exactly reached at the following sampling instant;
3.2 when the maximum permissible acceleration is reached, acceleration is carried out at this level toward nominal velocity;
3.3 at the same time, it is continually checked, while retaining the current manipulated variable, whether the acceleration reached can be reduced to zero in the remaining sampling periods, within the framework of looking ahead at the following sampling instant or also within an interval of following sampling instants, while allowing for given acceleration and jerk possibilities in the remaining sampling periods;
3.4 if this is no longer the case for at least one of the sampling instants checked for future purposes, then the acceleration is reduced at the earliest sampling instant that precedes this sampling instant with as negative as possible jerk, wherever possible with the maximum permissible negative jerk, so as to allow the nominal velocity to be reached at the specified instant without overshooting it.
In another advantageous embodiment of the method in accordance with the present invention equated with the previous embodiment, a control sequence for deceleration into a specified target state is made possible in a time-optimal manner while taking into consideration the dynamic response of the underlying discrete-time sampling system, in particular of an electrical drive. To this end, the deceleration operation into the specified target state is performed in accordance with the following process steps:
4.1 a possibly still existing positive acceleration is reduced to zero with as negative as possible jerk, wherever possible with the maximum permissible negative jerk;
4.2 the negative acceleration required for the deceleration is likewise set up with as negative as possible jerk, wherever possible with the maximum permissible, negative jerk;
4.3 if the maximum permissible negative acceleration is reached, then deceleration is continued at this negative acceleration with a jerk of zero;
4.4 it is continually checked, while retaining the current manipulated variable, within the framework of looking ahead at the following sampling instant or also within an interval of following sampling instants, whether the remaining path of the block is shorter than the required deceleration distance, while allowing for given acceleration and jerk possibilities in the remaining sampling periods;
4.5 if this is the case for at least one of the sampling instants checked for future purposes, then the negative acceleration is reduced at the earliest sampling instant that precedes this sampling instant with as positive as possible jerk, wherever possible with maximum permissible positive jerk, and the target state is reached.
In an alternative embodiment, a control sequence is likewise determined for a deceleration into a predetermined target state, it not being necessary now to accept any deviations from the time-optimal characteristic curve of the deceleration operation in spite of restrictions in acceleration and jerk, rather the complete dynamic possibilities of the time-continuous sampling system, in particular of an electrical drive, being able to be utilized at any time. To this end, the deceleration operation into the specified target state is performed in accordance with the following process steps:
5.1 a possibly still existing positive acceleration is reduced to zero with as negative as possible jerk, wherever possible with the maximum permissible negative jerk;
5.2 the negative acceleration required for the deceleration is likewise set up with as negative as possible jerk, wherever possible with the maximum permissible negative jerk;
5.3 it is continually checked, while retaining the current manipulated variable, within the framework of looking ahead at the following sampling instant or also within an interval of following sampling instants, whether the remaining path of the block is shorter than the required deceleration distance, while allowing for given acceleration and jerk possibilities in the remaining sampling periods;
5.4 if this is the case for at least one of the sampling instants checked for future purposes, then the acceleration is reduced at the earliest sampling instant that precedes this sampling instant with as negative as possible jerk;
5.5 if, in so doing, the maximum permissible acceleration and/or the maximum permissible jerk is exceeded, then the number of sampling periods for the deceleration operation is increased so as to ensure that the permissible acceleration limit and/or jerk limit is not undershot or is only undershot within the scope of the permissible tolerance, and the operative deceleration point is advanced by as many sampling instants needed so that the target state is reached at an acceleration and jerk of zero.
Another advantageous refinement of the method according to the present invention reduces the computational work required to determine a suitable control sequence for an exact clock-synchronized motion control in the case of a deceleration into a predetermined target state. It makes it possible to simplify the method and reduce the degree of complexity of a control that works according to said method, so that a more cost-effective means for achieving the objective can be realized. To this end, the following alternative process steps are provided:
6.1 A possibly still existing positive acceleration is reduced with as negative as possible jerk to zero by means of discrete-time approximation from the continuously determined deceleration operation;
6.2 the negative acceleration required for deceleration is set up with as negative as possible jerk likewise by means of discrete-time approximation from the continuously determined deceleration operation.
To realize such an advantageous method for clock-synchronized motion control of discrete-time sampling systems in a simpler manner, the objective is achieved using a device with the following elements, which render possible an especially favorable and effective realization:
7.1 means are provided, in particular a microprocessor system, for determining an exact control sequence from a discrete-time system-matrix equation system of the sampling system for the motion control;
7.2 means are provided for influencing the manipulated variable in clock-controlled synchronism in accordance with the determined values of the control sequence;
7.3 means are provided for integrating the manipulated variable in accordance with any desired order n and, thus, for determining the tool path feedrate and the path from the manipulated variable.
The advantages attained with the invention include, in particular, that motion can be controlled in discrete-time sampling systems in exact clock-controlled synchronism and, moreover, optimally with respect to time, in particular, in light of the dynamic possibilities of the discrete-time sampling system. Above all in the case of the application of an electrical drive, the method for determining the control sequence can be carried out in an especially simple and effective manner on the basis of appropriate implementation of the steps for determining the control sequence. Moreover, to determine suitable control sequences, advantageous motion controls are created for a travel toward a predetermined nominal velocity, as well as for a deceleration into a specified target state, which makes it possible for a control sequence to be determined, which optimally utilizes the dynamic possibilities of the discrete-time sampling system and optimizes the control sequence in light of the motion control. With regard to reducing the computational work this entails, alternative procedures are created over and above that which enable a more cost-effective implementation. Furthermore, a device embodying the above-mentioned advantages is created, which, moreover, can be realized cost-effectively with little expenditure, and which works effectively.
Further advantages and inventive details are revealed in the following description of computational fundamentals, as are several application examples based on the drawings and in conjunction with the dependent claims.
BRIEF DESCRIPTION OF THE DRAWINGS
To further elucidate the invention, reference is made to the enclosed drawings, in which:
FIG. 1 is a block diagram of a time-continuous system comprising possible manipulated variables for motion control;
FIG. 2 is a block diagram of a discrete-time sampling system comprising possible manipulated variables for motion control;
FIG. 3 a diagram of input and output signals of a sample-&-hold element for generating discrete-time values;
FIG. 4 is a block diagram of a discrete-time system with a manipulated variable based on the example of the jerk r;
FIG. 5 is a graph of a characteristic curve of jerk, acceleration, and velocity when approaching a specified nominal velocity;
FIG. 6 is a graph of interaction of jerk, acceleration, and velocity in the phase plane when approaching a specified nominal velocity;
FIG. 7 is a graph of discrete motion control to a specified nominal velocity, with the variables being scaled;
FIG. 8 is a graph of discrete motion control to a specified nominal velocity, with the time reference and time-optimal continuous motion operation coinciding;
FIG. 9 is a graph of a section of a time-optimal deceleration operation into a specified target position;
FIG. 10 is a graph of discrete motion control of a deceleration operation into a target position without limitation when decelerating into the target point;
FIG. 11 is a graph of discrete motion control of a deceleration operation into a target position with an additional limitation when decelerating into the target point; and
FIG. 12 is a graph of discrete motion control, with the specified nominal velocity not being reached because of insufficient block length.
DETAILED DESCRIPTION
When working with the motion control, the m-th derivation of the path velocity v or the m+1-th derivation of the position or of the travel path s serves as the manipulated variable. Preferably, reference is made to the path velocity v, since, as a rule, this is determined directly, i.e., is used to trigger drives. For purposes of illustration, the continuous system can be described by a block diagram with n=m+1 memories or integrators, as shown in FIG. 1. In this diagram:
x.sub.1 :=s=travel path or position
x.sub.2 :=v=velocity
x.sub.3 :=a=acceleration
x.sub.4 :=r=jerk ##EQU1##
The flow of information of this block diagram can be described mathematically by the following differential equation system (1): ##EQU2##
This can be simply expressed as a vector or matrix notation as follows: ##EQU3##
If one solves the differential equation system (1), then for instants t.gtoreq.t.sub.0, one obtains: ##EQU4##
Here, x(t.sub.0) describes the initial state of the system at the instant t.sub.0.
If a sample/hold element, also described as sample & hold element, is connected in incoming circuit to the continuous system of FIG. 1, then one obtains a discrete-time sampling system, in which the line motion input--the manipulated variable u--can only change at the discrete sampling instants k.multidot.T, where k=0, 1, 2, . . . and T=sampling time. FIG. 2 illustrates the block pattern of such a discrete-time sampling system.
In FIG. 3, input signals of a sample & hold element are shown on the basis of a numerical sequence u.sup..multidot., and the corresponding output signals u are shown, which are plotted on a time axis t/T scaled over the sampling periods T. The numerical sequence u.sup..multidot. is generated, for example, by a computer. With the aid of a sample & hold element, a stair-step curve u is formed, which is used to drive the continuous subsystem.
Since the pattern of the output signals u(t)=u.sub.k =const is constant for instants k.multidot.T.ltoreq.t<(k+1).multidot.T within individual sampling periods, the state variables can be simply determined for the sampling system with k.multidot.T=t.sub.0 at the sampling instant (k+1).multidot.T from the prescribed calculation (2) as follows: ##EQU5##
If one substitutes (k+1)T-.tau.=.nu., then this yields the following prescribed calculation (3): ##EQU6## This prescribed calculation can also be simply expressed in a vector or matrix notation:
x.sub.k+1 =A.multidot.x.sub.k +b.multidot.u.sub.k
The discrete system matrix A=e.sup.F.multidot.T can be simply determined, inter alia, by applying the Laplace transformation:
A=L.sup.-1 �(sI-F).sup.-1 !t=T
Here, s describes the Laplace operator, I a unit matrix.
Specially for the case of the n-memory system, as shown in FIG. 1 and FIG. 2, it follows with (3) and (1): ##EQU7##
This can likewise be expressed in simplified terms in a vector or matrix notation:
x.sub.k+1 =A.multidot.x.sub.k +b.multidot.u.sub.k
In an n-memory system, A represents an n.times.n-matrix and b an n.times.1-vector. With A and b, the state vector x.sub.k+.nu. can now be calculated at a sampling instant (k+1).multidot.T from the state vector x.sub.k and from the manipulated variable u.sub.k of a preceding sampling instant k.multidot.T.
Accordingly, it follows from (4) for the instant (k+2).multidot.T:
x.sub.k+2 =A.multidot.x.sub.k+1 +b.multidot.u.sub.k+1 =A.multidot.�A.multidot.x.sub.k +b.multidot.u.sub.k!+b.multidot.u.sub.k+1
Or represented more clearly ##EQU8##
It follows accordingly for the instant (k+3).multidot.T: ##EQU9##
Thus, for a general instant (k+.nu.).multidot.T, the following generally valid prescribed calculation (5) can be stated: ##EQU10##
Thus, the state vector of a discrete-time sampling system can be calculated at the instant (k+.nu.).multidot.T, when the initial state x.sub.k of the system at the instant k.multidot.T, as well as the control sequence therebetween, represented by the control vector u, are known.
Conversely, however, in accordance with the present invention, the control sequence u, which is required to transform a sampling system from a given initial state into a desired end state, is now calculated from equation (5). To achieve an exact clock-synchronized motion control, the manipulated variable u is then modified at the sampling instants to conform with the values of the control sequence u. To this end, the computational specification (5) is solved for the control sequence u:
u=S.sup.-1 .multidot.�x.sub.k+n -A.sup.n .multidot.x.sub.k !(6)
To transform a system of the order n from an initial state into a desired target point, at least n switching operations--synonymous with n sampling intervals n.multidot.T--are required. One also speaks in this connection of a so-called dead-beat action. In this case, the matrices A.sup.n as well as S have the dimension n.times.n, so that exactly n equations for the n unknown manipulated variables result.
For .nu.>n, thus for the case that the number of sampling periods available for the motion control is greater than the order of the system of equations, such a system of equations is, however, under-determined, which has as a consequence that an infinite number of control sequences exist to get into the target point.
When one solves prescribed calculation (5) for S.multidot.u, this becomes immediately clear: ##EQU11##
With the .nu. control values, in the same way as before, only n equations are to be satisfied. Thus, in addition, one now has (.nu.-n) degrees of freedom, which can be used in accordance with the invention to satisfy a secondary criterion.
To avoid overly stressing the mechanical system of the machine tool, it is beneficial to minimize the sum of the squares of the control sequence, which corresponds to the average manipulated variable energy, concurrently with the time-optimal motion control. This is expressed mathematically by the following relation: ##EQU12##
This condition is then satisfied exactly when the vector u, the control sequence, satisfies the equation ##EQU13##
Since S.sup.+ .multidot.S yields the unit matrix, S.sup.+ is also designated as the "pseudo-inverse matrix" of S.
The preceding considerations are applied in the following exemplary embodiment to the case of motion control, where the jerk r is selected as the manipulated variable. Of course, to implement the method according to the invention, as well as to operate a corresponding device, any other desired derivations of path velocity v, in particular also the acceleration a, can be drawn upon.
For the case of the exemplary embodiment, the block diagram is simplified, as shown in FIG. 4, and the discrete system equations (4) are simplified accordingly: ##EQU14##
In principle, two different motion sections occur in this case. One is approaching a programmed nominal velocity v.sub.nominal �v.sub.soll !, illustrated in FIG. 5 by v.sup.w, the other is deceleration into a target state, which is to be introduced when the remaining travel path of the block threatens to become shorter than the required deceleration travel path.
In continuous time, the approach to a nominal velocity v.sub.nominal or v.sup.w is composed of a maximum of three phases, which are illustrated in FIG. 5 on the basis of the characteristic curve of jerk r, acceleration a, and path velocity v.
In phase 1, the maximum permissible acceleration a is built up with the maximum jerk r. In phase 2, acceleration takes place with maximum acceleration toward nominal velocity v.sub.nominal or v.sup.w. In phase 3, the acceleration is reduced again with maximum negative jerk -r, so that the nominal velocity v.sub.nominal or v.sup.w is reached without any overshooting. Phase 2 can be dropped in dependence upon the amounts of a and v.sup.w.
FIG. 6 illustrates quite clearly the approach to nominal velocity in the phase plane, where the characteristic curve of the acceleration a(t) is plotted over .DELTA.v(t)=v.sup.w -v(t). This elucidates the interaction of jerk r, acceleration a, and path velocity v with reference to the nominal velocity v.sub.nominal or v.sup.w.
The way the motion operation looks is that starting from one of the right parabola branches, for which r=r, the transition is made to the target or deceleration parabola with r=-r, the linear portion being run through in between, in some instances, with a=a and r=0.
To this end, the following equation applies for the target/deceleration parabola: ##EQU15##
For as long as the condition ##EQU16## is met, acceleration can take place with maximum permissible jerk r or with maximum permissible acceleration a and r=0. If then, in place of (10), the condition (9) is satisfied, the transition is to be made with -r to the deceleration parabola, in order to reach the target velocity without any overshooting.
When a specified nominal velocity is approached, the motion control would have to introduce the changeover to the deceleration parabola at the correct instant, which, however, causes problems in sampling systems, since, as a rule, the "correct" instant does not conform--or only conforms purely by coincidence--with the sampling raster.
Therefore, to ensure that the given restrictions r and a are not exceeded, as a rule, the deceleration to the target velocity has to be begun already before, maximally one clock cycle earlier in the discrete time. It is checked on the basis of the discrete system equations (8), while retaining the manipulated variable u during the next sampling instant, whether condition (10) is still satisfied, otherwise, the deceleration operation is still introduced within the current sampling interval. Within the framework of a so-called "look ahead", more than only the following sampling instant can also be considered. Thus, for example, a previously defined interval of any desired number of sampling instants can be considered, while retaining the manipulated variable u, to determine whether the condition (10) is still satisfied during the next sampling instant each time. If the remaining travel path for a deceleration operation is too short, then the deceleration operation is introduced in the sampling instant that comes before it in the motion control.
The deceleration operation is introduced in this case as follows. First, the time span is calculated, which would be required to reduce the acceleration reached in the sampling instant k.multidot.T to zero: ##EQU17##
Since the instant T.sub.dec.sbsb.--.sub.cont �T.sub.Brems.sbsb.--.sub.kont !, in turn, amounts only purely by coincidence to an integral multiple of the sampling period T, it is rounded up and the discrete deceleration instant is obtained. ##EQU18##
Based on the number of sampling intervals .nu. found in accordance with the prescribed calculation (11), the required sequence of manipulated variables u used to transform the system into the target state can then be calculated by means of the prescribed calculation (6) or (7) ##EQU19##
FIG. 7 shows a motion control toward a specified nominal velocity, said motion control being scaled to the machine data and carried out in accordance with this method. The path velocity v is represented by a dashed line curve, the acceleration a by a dotted line curve, and the jerk r by a continuous line curve. The interpolation clock cycle is set at T=10 msec. The underlying machine data amount to:
______________________________________maximum velocity v = 20 m/min;maximum acceleration a = 5 m/sec.sup.2 ;maximum jerk r = 250 m/sec.sup.3.______________________________________
It should also be mentioned in this connection that the manipulated-variable sequence u calculated on the basis of the pseudo-inverse is identical to the control sequence belonging to the time-optimal motion operation when the sampling time reference fits into the time-optimal, continuous motion operation "random". FIG. 8 shows such a case on the basis of a discrete motion control to a specified nominal velocity v.sup.w =0.45.multidot.v. Path velocity v, acceleration a, and jerk r are represented by the line curves elucidated in FIG. 7, the motion state likewise being scaled.
The time-optimal deceleration into a target state, which is to be introduced when the remaining travel path of the block threatens to become shorter than the required deceleration travel path, is dependent first of all on whether the maximum acceleration is reached or not during deceleration. Accordingly, a time-continuous deceleration operation is composed of three or four phases, which are shown in FIG. 9. To this end, the characteristic curve of the acceleration a is plotted over the time t, the starting point being any desired state a.sup..multidot. at an instant t.sup..multidot., from where deceleration is supposed to take place into a target position optimally with respect to time and exactly with respect to target point.
Phase 1 is used to reduce to zero a positive acceleration a.sup..multidot. still existing in some instances at the beginning of the deceleration operation t.sup..multidot.. Thus, the velocity v still continues to increase in this case. In phase 2, just as in phase 1, the negative acceleration -a required for deceleration into the target is set up with the maximum negative jerk and is to be limited, in some instances to -a, as indicated by the characteristic curve of the acceleration a that deviates from the dotted line curve. In phase 3, the jerk is equal to zero, deceleration is continued with -a. Phase 3 is dropped when .vertline.a.vertline.<.vertline.a.vertline.. In phase 4, the negative acceleration -a or -a is reduced again with the maximum positive jerk in order to thus achieve the target position with the desired target velocity and a zero acceleration.
As a result, for every desired initial state, all partial times and partial travel paths can be calculated, as can the total deceleration time t.sub.7 -t.sup..multidot. needed, as well as the total deceleration travel path s(t.sub.7)-s(t.sup..multidot.) needed, so that in continuous time, the practical conversion of this time plan can take place without extra work.
In the realization in discrete time, the present invention provides for additional adaptations and optimizations to be made on the basis of the sampling raster. Here, experience has shown that better results can be achieved when the limitations are not taken over directly from continuous time, but rather are established following a separate strategy based on the discretely calculated control sequence. Thus, the dynamic response of active electrical drives allows, for example, the permissible maximum acceleration +/-a to be exceeded for a short time by up to 100%. As a result, a deceleration action into a target state in accordance with the previously described method means forgoing dynamic response and velocity. This also seems plausible when one considers that the jerk only assumes the values -1, 0 and +1 in continuous time, while it virtually has a linear, stair-step characteristic curve in the discrete time.
Therefore, initially in calculating the total time T.sub.dec.sbsb.cont =t.sub.7 -t.sup..multidot. needed for the time-continuous deceleration operation, the restriction of not exceeding the maximum acceleration a and/or the maximum permissible jerk r, as far as absolute value is concerned, is dropped, so that looking in general at acceleration, a characteristic curve for acceleration a is obtained as drawn in with a dotted line in FIG. 9. The calculated time span is then rounded up in order to obtain an integral multiple of the sampling period T, as when approaching the programmed nominal velocity, as described previously. This is considered in the following prescribed calculation: ##EQU20##
The required manipulated variable sequence u, in which the target position S.sub.target �S.sub.ziel ! is reached with the desired target velocity V.sub.target �V.sub.ziel ! and acceleration 0, is then calculated in turn in accordance with prescribed calculation (6) or (7): ##EQU21##
Therefore, this prescribed calculation represents a form of the prescribed calculation (5) that is tailored to the exemplary embodiment. Accordingly, travel is undertaken in consideration of the maximum permissible jerk. If it turns out, in this case, that the jerk r and/or the acceleration a is exceeded in this control sequence to an unjustifiable degree, as shown, for example, in FIG. 10 for the acceleration a, then the number of sampling periods .nu. available to the deceleration operation must be increased. For this purpose, the number of clock-pulse periods provided for the deceleration operation continues to be increased until the acceleration limit is no longer exceeded or, given a negative limit of acceleration, is no longer undershot or is only still exceeded within the scope of the permissible tolerance of the dynamic response. This makes it possible to fully utilize the available dynamic response.
FIG. 10 illustrates a discrete-time motion control with driving up to a specified nominal velocity v.sup.w =v and subsequent deceleration into a specified target state where S.sub.target =47.multidot.10.sup.-3 m, v.sub.target =0, a.sub.target =0, the position or the travel path s being shown as a dot-dash curve, velocity v as a dashed-line curve, acceleration a as a dotted curve, and the jerk r as a solid-line curve, and being scaled to the machine data. The machine data have the same values as described further above. The acceleration a thereby considerably exceeds the negative limit of acceleration.
Since the target instant is specified as a fixed instant, the operative deceleration point is advanced, so that the symmetrical characteristic curves of the jerk and also of the acceleration are retained. Moreover, there is a noticeable reduction in the control energy and, consequently, in the loading of the machine. This is especially apparent in FIG. 11, where the discrete motion control from FIG. 10 is shown without limitation when decelerating into the target. Compared to FIG. 10, .nu.=11 instead amounts to 9, and the deceleration operation was already introduced one sampling step sooner.
In addition, many other limitation strategies are conceivable. For example, phases 1 and 2 can be approximated from the deceleration operation calculated continuously in discrete time and the calculation of the discrete control sequence can first be set up as of instant t.sub.5. Here, as well, the exact target state is achieved and, in fact, in favor of less computational outlay, however, at the expense of the required control energy. Which strategy is the most favorable for the specific active application must be decided from case to case.
FIG. 12 shows an example of a discrete motion control, where the specified nominal velocity v.sup.w =v is not yet reached in the first place, because the block length is too short. Thus, here, the deceleration instant t.sup..multidot. into the target state still falls into the acceleration phase toward the specified nominal velocity v.sup.w =v. Since, furthermore, in the example, a block end velocity unequal to zero is specified, the travel path increases linearly when reaching the end of the block, as revealed on the scaled travel path by the value 1. For the target state, the underlying values amount to
S.sub.target =20.multidot.10.sup.-3 m, v.sub.target =0.25.multidot.v, a.sub.target =0.
A device for implementing the method described in the preceding, in particular for implementing the individually represented, prescribed calculations (1) through (12), has means for integrating the manipulated variable u or x.sub.n according to any desired order n for determining the individual parameters used for the motion control up to the travel path s or x.sub.1. If the manipulated variable u or x.sub.n is the jerk r or x.sub.4, and if the path velocity v or x.sub.2 was used as a basis for deriving the manipulated variable u or x.sub.n, then n=m+1=3 integration steps are provided for determining acceleration a or x.sub.3, path velocity v or x.sub.2 and, finally, travel path s or x.sub.1, as shown in FIG. 4.
This can be achieved with the aid of one or more integrators or memory devices or, however, by using a suitable microprocessor-produced algorithm. Furthermore, means are provided for solving the discrete-time system-matrix equation system and, thus, for precisely calculating the control sequence u. This is preferably done by a microprocessor system using appropriate programming, since the required computational outlay increases considerably depending on the type of motion control and manipulated variable u used. Possible solving strategies are, for example, the Gau.beta.-Jordan algorithm or iteration methods, such as the newtonian method, the Bernoulli method or the secant method (regula falsi). Above and beyond that, of course, other new methods for implementing solving strategies can be applied in the numerical processing of digital signals. At the same time, an additional advantage associated with using a microprocessor system is that it enables the manipulated variable u or x.sub.n to be integrated. Because the calculation is made in discrete time, no additional integration is necessary in the mathematical sense, since the values are already determined within the scope of the prescribed calculations described previously and are, thus, available. In addition, to influence the manipulated variable u or x.sub.n in clock-controlled synchronism, means are used to control the manipulated variable u or x.sub.n in accordance with the calculated values of the control sequence u. In particular, this can be a sample & hold element, as previously described and as shown in FIGS. 2 and 4.
The application of the method as well as the device in accordance with the present invention recommends itself, for example, in the numerical control of machine tools and robots. Beyond that, however, an application in any other desired area is conceivable, where an especially precise and clock-synchronized motion control can or must be implemented.
The above descriptions of preferred specific embodiments of the device according to the invention are given for illustrative purposes. They are not exhaustive. Also, a device in accordance with the invention is not limited to the exact form indicated, rather numerous modifications and changes are possible within the scope of the indicated technical teaching. One preferred specific embodiment was selected and described to clarify the principal details of the invention and practical applications to enable one skilled in the art to understand the invention. Many preferred specific embodiments, as well as other modifications come under consideration when working in special application areas.
Claims
- 1. A method for clock-synchronized motion control in discrete-time sampling systems, in particular for use in numerical control systems for machine tools and robots, comprising the following steps:
- (a) deriving any order m from a tool path feedrate (v or x.sub.2) or any order m+1 from a position (s or x.sub.1) to serve as a manipulated variable (u), for which acceleration (a or x.sub.3) or jerk limitation (r or x.sub.4) are preferred;
- (b) determining an exact control sequence (u) for motion control from n=m+1 discrete-time system matrix equations of the sampling system, given an initial state (x.sub.k) and desired state vector (x.sub.k+v); and
- (c) changing the manipulated variable (u) in accordance with specific values of the control sequence (u) within a clock-controlled time reference (k*T) of the sampling system, in an interpolation clock cycle when working with numerical control systems for machine tools and robots.
- 2. The method of claim 1, wherein the order n of the system-matrix equation system is smaller than the number of sampling intervals (.nu.) for travel from an initial state (x.sub.k) into a desired state (x.sub.k+v), the method comprising the additional step of using the number (.nu.-n) of additional degrees of freedom conditional upon these factors to fulfill secondary criteria, in particular to avoid overly stressing mechanical systems being used by minimizing average manipulated variable energy.
- 3. The method of claim 1, wherein the control sequence (u) for travel toward a specified nominal velocity is determined in accordance with the following steps:
- (a) continuing the acceleration (a) at the maximum permissible jerk (r) for as long as it is not imminent that the maximum permissible acceleration (a) will be exceeded in a subsequent sampling period, and reducing the jerk (r) to the extent that the maximum permissible acceleration (a) is reached at the subsequent sampling instant;
- (b) when the maximum permissible acceleration (a) is reached, continuing acceleration at this level toward nominal velocity (v.sub.nominal);
- (c) at the same time, continually checking, while retaining the current manipulated variable (u), whether the acceleration reached can be reduced to zero in the remaining sampling periods, within the framework of a look ahead at the subsequent sampling instant or also within an interval of following sampling instants, while allowing for given acceleration and jerk possibilities in the remaining sampling periods; and
- (d) if this is no longer the case for at least one of the sampling instants checked for future purposes, then reducing the acceleration (a) at the earliest sampling instant that precedes this sampling instant with as negative as possible jerk (r), wherever possible with the maximum permissible negative jerk (-r), so as to allow the nominal velocity (v.sub.nominal) to be reached at the specified instant without overshooting it.
- 4. The method of claim 1, wherein the control sequence (u) for a deceleration into a specified target state is determined by the following steps:
- (a) reducing to zero any still existing positive acceleration (a.sup.*) with an as negative as possible jerk (r) wherever possible with the maximum permissible, negative jerk (-r);
- (b) establishing the negative acceleration (-a) required for the deceleration with an as negative as possible jerk (r), wherever possible with the maximum permissible negative jerk (-r);
- (c) if the maximum permissible negative acceleration (-a) is reached, then continuing deceleration with the maximum permissible negative acceleration (-a) with a jerk (r) of zero;
- (d) retaining while continually checking the current manipulated variable (u) within the framework of a look ahead at the following sampling instant or also within an interval of following sampling instants, whether the remaining path of the block is shorter than the required deceleration distance, while allowing for given acceleration and jerk possibilities in the remaining sampling periods; and
- (e) if this is the case for at least one of the sampling instants checked for future purposes, then the negative acceleration (-a) is reduced at the earliest sampling instant that precedes this sampling instant with as positive as possible jerk (r), wherever possible with maximum permissible positive jerk (+r), and the target state (s.sub.nominal) is reached.
- 5. The method of claim 1, wherein the control sequence (u) for a deceleration into a specified target state is determined by the following process steps:
- (a) reducing to zero any existing positive acceleration (a.sup.*) with an as negative as possible jerk (r), wherever possible with the maximum permissible negative jerk (-r);
- (b) establishing the negative acceleration (-a) required for the deceleration with an as negative as possible jerk (r), wherever possible with the maximum permissible, negative jerk (-r);
- (c) retaining while continually checking the current manipulated variable (u), within the framework of a look ahead at the following sampling instant or also within an interval of following sampling instants, whether the remaining path of the block is shorter than the required deceleration distance, while allowing for given acceleration and jerk possibilities in the remaining sampling periods;
- (d) if this is the case for at least one of the sampling instants checked for future purposes, then reducing the acceleration (a) at the earliest sampling instant that precedes this sampling instant with an as negative as possible jerk (r); and
- (e) if, in so doing, the maximum permissible acceleration (+a, -a) and/or the maximum permissible jerk (+r, -r) is exceeded, then increasing the number of sampling periods (v) for the deceleration operation so that the permissible acceleration limit (+a, -a) and/or jerk limit (+r, -r) is not undershot or is only undershot within a range of permissible tolerance, and the operative deceleration point is advanced by as many sampling instants needed so that the target state (s.sub.nominal) is reached at an acceleration (a) and jerk (r) of zero.
- 6. The method of claim 4, wherein
- any still existing positive acceleration (a.sup.*) is reduced with as negative as possible jerk (r) to zero by means of discrete-time approximation from the continuously determined deceleration operation; and
- the negative acceleration (-a) required for deceleration is set up with as negative as possible jerk (r) likewise by means of discrete-time approximation from the continuously determined deceleration operation.
- 7. A device for clock-synchronized motion control in discrete-time sampling systems, in particular for use in numerical control for machine tools and robots, comprising:
- (a) microprocessor means for deriving a manipulated variable (u) in accordance with any order m from the tool path feedrate (v or x.sub.2) or any order m+1 from the position (s or x.sub.1), as well as for determining an exact control sequence (u) from a discrete-time system-matrix equation system of a sampling system for the motion control given an initial state (x.sub.k) and desired state vector (x.sub.k+v);
- (b) means for influencing a manipulated variable (u) in clock-controlled time reference (k*T) in accordance with determined values of the control sequence (u); and
- (c) means for integrating the manipulated variable (u or x.sub.n) in accordance with any desired order n and for accordingly determining the tool path feedrate (v or x.sub.2) and the path (s or x.sub.1) from the manipulated variable (u or x.sub.n).
- 8. The method of claim 2, wherein the control sequence (u) for travel toward a specified nominal velocity is determined in accordance with the following steps:
- (a) continuing the acceleration (a) at the maximum permissible jerk (r) for as long as it is not imminent that the maximum permissible acceleration (a) will be exceeded in a subsequent sampling period, and reducing the jerk (r) to the extent that the maximum permissible acceleration (a) is reached at the subsequent sampling instant;
- (b) when the maximum permissible acceleration (a) is reached, continuing acceleration at this level toward nominal velocity (v.sub.nominal);
- (c) at the same time, continually checking, while retaining the current manipulated variable (u), whether the acceleration reached can be reduced to zero in the remaining sampling periods, within the framework of a look ahead at the subsequent sampling instant or also within an interval of following sampling instants, while allowing for given acceleration and jerk possibilities in the remaining sampling periods; and
- (d) if this is no longer the case for at least one of the sampling instants checked for future purposes, then reducing the acceleration (a) at the earliest sampling instant that precedes this sampling instant with as negative as possible jerk (r), wherever possible with the maximum permissible negative jerk (-r), so as to allow the nominal velocity (v.sub.nominal) to be reached at the specified instant without overshooting it.
- 9. The method of claim 2, wherein the control sequence (u) for a deceleration into a specified target state is determined by the following steps:
- (a) reducing to zero any still existing positive acceleration (a.sup.*) with an as negative as possible jerk (r) wherever possible with the maximum permissible, negative jerk (-r);
- (b) establishing the negative acceleration (-a) required for the deceleration with an as negative as possible jerk (r), wherever possible with the maximum permissible negative jerk (-r);
- (c) if the maximum permissible negative acceleration (-a) is reached, then continuing deceleration with this acceleration with a jerk (r) of zero;
- (d) retaining while continually checking the current manipulated variable (u) within the framework of a look ahead at the following sampling instant or also within an interval of following sampling instants, whether the remaining path of the block is shorter than the required deceleration distance, while allowing for given acceleration and jerk possibilities in the remaining sampling periods; and
- (e) if this is the case for at least one of the sampling instants checked for future purposes, then the negative acceleration (-a) is reduced at the earliest sampling instant that precedes this sampling instant with as positive as possible jerk (r), wherever possible with maximum permissible positive jerk (+r), and the target state (s.sub.nominal) is reached.
- 10. The method of claim 2, wherein the control sequence (u) for a deceleration into a specified target state is determined by the following process steps:
- (a) reducing to zero any existing positive acceleration (a.sup.*) with an as negative as possible jerk (r), wherever possible with the maximum permissible negative jerk (-r);
- (b) establishing the negative acceleration (-a) required for the deceleration with an as negative as possible jerk (r), wherever possible with the maximum permissible negative jerk (-r);
- (c) retaining while continually checking the current manipulated variable (u), within the framework of a look ahead at the following sampling instant or also within an interval of following sampling instants, whether the remaining path of the block is shorter than the required deceleration distance, while allowing for given acceleration and jerk possibilities in the remaining sampling periods;
- (d) if this is the case for at least one of the sampling instants checked for future purposes, then reducing the acceleration (a) at the earliest sampling instant that precedes this sampling instant with an as negative as possible jerk (r); and
- (e) if, in so doing, the maximum permissible acceleration (+a, -a) and/or the maximum permissible jerk (+r, -r) is exceeded, then increasing the number of sampling periods (v) for the deceleration operation so that the permissible acceleration limit (+a, -a) and/or jerk limit (+r, -r) is not undershot or is only undershot within a range of permissible tolerance, and the operative deceleration point is advanced by as many sampling instants needed so that the target state (s.sub.nominal) is reached at an acceleration (a) and jerk (r) of zero.
- 11. The method of claim 5, wherein
- any still existing positive acceleration (a.sup.*) is reduced with as negative as possible jerk (r) to zero by means of discrete-time approximation from the continuously determined deceleration operation; and
- the negative acceleration (-a) required for deceleration is set up with as negative as possible jerk (r) likewise by means of discrete-time approximation from the continuously determined deceleration operation.
- 12. The method of claim 10, wherein
- any still existing positive acceleration (a.sup.*) is reduced with as negative as possible jerk (r) to zero by means of discrete-time approximation from the continuously determined deceleration operation; and
- the negative acceleration (-a) required for deceleration is set up with as negative as possible jerk (r) likewise by means of discrete-time approximation from the continuously determined deceleration operation.
Priority Claims (1)
Number |
Date |
Country |
Kind |
95115952 |
Oct 1995 |
EPX |
|
US Referenced Citations (1)
Number |
Name |
Date |
Kind |
5379367 |
Song |
Jan 1995 |
|
Foreign Referenced Citations (6)
Number |
Date |
Country |
0 378 708 |
Jul 1990 |
EPX |
0 419 706 |
Apr 1991 |
EPX |
94116655 |
Aug 1996 |
EPX |
41 07 514 |
Sep 1992 |
DEX |
9010930 |
Sep 1990 |
WOX |
9510076 |
Apr 1995 |
WOX |