Error compensation system and method for numerical control (NC) machine tool based on iterative learning control

11360455 · 2022-06-14

Assignee

Inventors

Cpc classification

International classification

Abstract

An error compensation system for a numerical control (NC) machine tool based on iterative learning control, including a trajectory generating module, a down-sampling module, a position controller, a first holder, a velocity-loop iterative learning controller, a velocity controller, a second holder and a control plant. The trajectory generating module is configured to generate a desired trajectory command including a first sampling command. The first sampling command is transmitted to the down-sampling module and the velocity-loop iterative learning controller. The first sampling command is down-sampled through the down-sampling module to obtain a second sampling command. The velocity-loop iterative learning controller is configured to receive the first sampling command, and obtain a first sampling error compensation sequence according to a first sampling error sequence and a first sampling error compensation sequence of a previous iteration machining process stored therein. An error compensation method is also provided herein.

Claims

1. An error compensation system for a numerical control (NC) machine tool based on iterative learning control, comprising: a trajectory generating module; a down-sampling module; a position controller; a first holder; a velocity-loop iterative learning controller; a velocity controller; a second holder; and a control plant; wherein the control plant comprises a motor and a mechanical transmission module; the trajectory generating module is configured to generate a desired trajectory command; the desired trajectory command comprises a first sampling command; the first sampling command is configured to be transmitted to the down-sampling module and the velocity-loop iterative learning controller; the first sampling command r.sub.f is down-sampled by the down-sampling module to obtain a second sampling command r.sub.s; a sampling rate of the first sampling command is larger than a sampling rate of the second sampling command; the velocity-loop iterative learning controller is configured to receive the first sampling command; the velocity-loop iterative learning controller is also configured to obtain a first sampling error compensation sequence according to a first sampling error sequence and a first sampling error compensation sequence of a previous iteration machining process stored in the velocity-loop iterative learning controller; the velocity-loop iterative learning controller comprises a memory and an iterative learning controller; the first sampling error sequence of the previous iteration machining process of the NC machine tool is expressed as e.sub.j-1; the first sampling command is expressed as r.sub.f; the first sampling error sequence e.sub.j-1 of previous iteration is a difference between the first sampling command r.sub.f and a displacement y of a sliding table of the NC machine tool; the first sampling error compensation sequence of the previous iteration is expressed as u.sub.j-1; the memory is configured to store the first sampling error sequence e.sub.j-1 and the first sampling error compensation sequence u.sub.j-1 of the previous iteration machining process; after the first sampling error sequence e.sub.j-1 and the first sampling error compensation sequence u.sub.j-1 are input to the iterative learning controller, the iterative learning controller is configured to obtain the first sampling error compensation sequence u.sub.j through iterative calculation using a proportional-derivative (PD) method, expressed as: u j = Q ( u j - 1 + Γ p e j - 1 + Γ d de j - 1 dt ) ; ( 1 ) wherein j is the number of iterations; Γ.sub.p and Γ.sub.d respectively represent an iterative learning gain; Q represents a low-pass filtering process; e.sub.j-1 is the first sampling error sequence; the position controller is configured to receive a difference between the second sampling command output by the down-sampling module and the displacement y of the sliding table of the NC machine tool, and output a velocity control signal, and the velocity control signal is held by the first holder, and input to the velocity controller after compared with real-time velocity of the sliding table of the NC machine tool; a mathematical realization expression of the first holder is shown as follows:
H.sub.u=H.sup.NS.sub.u.sup.N; wherein H.sup.N represents the second holder, which is configured as a zero-order holder; S.sub.u.sup.N represents an up-sampling process; and the zero-order holder is expressed as: H N = .Math. f = 0 N z - f ; the up-sampling process S.sub.u.sup.N is expressed as: S u N : u [ n ] .fwdarw. u [ n ] u [ n ] = { u [ n 1 N ] , when n i n n i N Z 0 ; wherein Z is a time-shift operator; the velocity controller is configured to output a current signal; the current signal is configured to be superimposed on the first sampling error compensation sequence and transmitted to the second holder; the second holder is configured to drive the motor to rotate to drive the mechanical transmission module to move, such that the mechanical transmission module drives the sliding table of the NC machine tool to move to output an actual displacement y of the sliding table of the NC machine tool.

2. The error compensation system of claim 1, wherein the second sampling command is expressed as r.sub.s; the second sampling command r.sub.s is obtained from the first sampling command r.sub.f by down-sampling through the down-sampling module, and a down-sampling process S.sub.d.sup.N is expressed as:
S.sub.d.sup.N:r.sub.f[n].fwdarw.r.sub.s[n],r.sub.s[n]=r.sub.f[Nn]; wherein n and N respectively represent a positive integer, and the number of data points of the first sampling command r.sub.f is N times the number of data points of the second sampling command r.sub.s.

3. The error compensation system of claim 2, wherein after the first sampling error sequence e.sub.j-1 and the first sampling error compensation sequence u.sub.j-1 of the previous iteration are input to the iterative learning controller, the iterative calculation performed by the iterative learning controller to obtain the first sampling error compensation u.sub.j of current iteration is performed off line.

4. The error compensation system of claim 3, wherein the position controller is configured to work at a sampling rate corresponding to the second sampling command; an input of the position controller is the difference between the second sampling command r.sub.s and the displacement y of the sliding table of the NC machine tool; the motor of the sliding table of the NC machine tool is equipped with an encoder displacement detecting module; and the encoder displacement detecting module is configured to detect an angular displacement of the motor and calculate the corresponding displacement y of the sliding table of the NC machine tool.

5. The error compensation system of claim 4, further comprising: a velocity estimator; wherein the velocity estimator is configured to estimating a velocity of the sliding table of the NC machine tool in real time.

6. An error compensation method based on the error compensation system of claim 1, comprising: (S1) generating, by a trajectory generating module, a desired trajectory command comprising a first sampling command; transmitting the first sampling command to a down-sampling module and a velocity-loop iterative learning controller; down-sampling, by the down-sampling module, the first sampling command to obtain a second sampling command; and receiving, by the velocity-loop iterative learning controller, the first sampling command; (S2) setting the number of machining tasks of the NC machine tool; initializing a gain parameter of the error compensation system; and clearing an error compensation sequence of the NC machine tool; (S3) allowing the NC machine tool to perform a first machining operation; and storing a first sampling error sequence and a first sampling error compensation sequence of the first machining operation in the velocity-loop iterative learning controller; (S4) iteratively calculating, by the velocity-loop iterative learning controller, to obtain a first sampling error compensation sequence; (S5) inputting a difference between the second sampling command and an actual displacement of a sliding table of the NC machine tool to a position controller; outputting, by the position controller, a velocity control signal; and holding, by a first holder, the velocity control signal followed by inputting to a velocity controller after compared with a real-time velocity of the sliding table of the NC machine tool; (S6) outputting, by the velocity controller, a current signal; superimposing the current signal with the first sampling error compensation followed by transmitting to a second holder; and driving, by the second holder, a motor to rotate and then drive a mechanical transmission module to move, so that the mechanical transmission module drives the sliding table of the NC machine tool to move to output an actual displacement of the sliding table of the NC machine tool; and (S7) determining whether the number of actual machining tasks of the NC machine tool reaches the number of machining tasks set in step (S2); if yes, ending; otherwise, returning to step (S4).

7. The error compensation method of claim 6, wherein the low-pass filtering process is performed with an IIR-type low-pass filter using a non-causal method through steps of; filtering items in a bracket of equation (1); reversing a filtering result followed by another filtering; and reversing a filtering result to obtain a result of an entire low-pass filtering process.

Description

BRIEF DESCRIPTION OF THE DRAWINGS

(1) FIG. 1 is a block diagram of a structure of a traditional error compensation system for a numerical control (NC) machine tool;

(2) FIG. 2 is a block diagram of a structure of a fast error compensation system for a NC machine tool based on iterative learning control according to an embodiment of the present disclosure;

(3) FIG. 3 is a flowchart of a fast error compensation method for the NC machine tool based on iterative learning control according to an embodiment of the present disclosure;

(4) FIG. 4 shows a desired trajectory generated by a trajectory generating module according to an embodiment of the present disclosure;

(5) FIG. 5 schematically shows an error compensation result of a conventional slow iterative learning control (10 iterations) for a trajectory tracking process in a Matlab/Simulink environment according to an embodiment of the present disclosure;

(6) FIG. 6 schematically shows an error compensation result of a conventional fast iterative learning control (10 iterations) for the trajectory tracking process in the Matlab/Simulink environment according to an embodiment of the present disclosure;

(7) FIG. 7 schematically shows an actual hardware structure of the NC machine tool when the trajectory tracking is performed in an actual XY sliding table according to an embodiment of the present disclosure;

(8) FIG. 8 schematically shows an error convergence of a fast iterative learning control (fast ILC, 10 iterations) and a slow iterative learning control (slow ILC, 10 iterations) when the trajectory tracking is performed in the actual XY sliding table according to an embodiment of the present disclosure;

(9) FIG. 9 is a frequency spectrum diagram of error results of a slow iterative learning control (slow ILC, 10 iterations) at a sampling rate of 1000 Hz when the trajectory tracking is performed in the actual XY sliding table according to an embodiment of the present disclosure;

(10) FIG. 10 is a frequency spectrum diagram of error results of the slow iterative learning control (slow ILC, 10 iterations) at a sampling rate of 4000 Hz when the trajectory tracking is performed in the actual XY sliding table according to an embodiment of the present disclosure;

(11) FIG. 11 shows a frequency spectrum of error results of a fast iterative learning control (fast ILC, 10 iterations) at a sampling rate of 1000 Hz when the trajectory tracking is performed in the actual XY sliding table according to an embodiment of the present disclosure; and

(12) FIG. 12 shows a frequency spectrum of error results of the fast iterative learning control (fast ILC, 10 iterations) at a sampling rate of 4000 Hz when the trajectory tracking is performed in the actual XY sliding table according to an embodiment of the present disclosure.

DETAILED DESCRIPTION OF EMBODIMENTS

(13) The accompanying drawings provided herein are merely illustrative, and are not intended to limit the scope of the present disclosure. In order to better illustrate the embodiments of the disclosure, some parts may be omitted, enlarged or reduced, which do not represent the actual size. For those skilled in the art, it is understandable that some known contents in the drawings may be omitted. The description of the positional relationship in the drawings is only illustrative, and cannot be understood as a limitation of the present disclosure. The disclosure will be described completely and clearly below with reference to the accompanying drawings and embodiments to make the object, technical solutions, and beneficial effects of the present disclosure clearer.

Embodiment 1

(14) An error compensation system provided herein for a numerical control (NC) machine tool based on iterative learning control is structurally illustrated in FIG. 2, which includes a trajectory generating module, a down-sampling module, a position controller, a first holder, a velocity-loop iterative learning controller, a velocity controller, a second holder and a control plant. The control plant includes a motor and a mechanical transmission module. In FIG. 2, the velocity-loop iterative learning controller is marked as 1.

(15) The trajectory generating module is configured to generate a desired trajectory command. The desired trajectory command includes a first sampling command. The first sampling command is configured to be transmitted to the down-sampling module and the velocity-loop iterative learning controller. The first sampling command is down-sampled by the down-sampling module to obtain a second sampling command. A sampling rate of the first sampling command is larger than a sampling rate of the second sampling command. The velocity-loop iterative learning controller is configured to receive the first sampling command. The velocity-loop iterative learning controller is also configured to obtain a first sampling error compensation according to a first sampling error sequence and a first sampling error compensation sequence of a previous iteration machining process stored in the velocity-loop iterative learning controller. The velocity-loop iterative learning controller includes a memory and an iterative learning controller. As shown in FIG. 2, the iterative learning controller is represented as ILC, and the first sampling error sequence of the previous iteration machining process is expressed as e.sub.j-1. The first sampling command is expressed as r.sub.f. The first sampling error sequence e.sub.j-1 is a result of difference between the first sampling command r.sub.f and a displacement y of a sliding table of the NC machine tool. The first sampling error compensation sequence is expressed as u.sub.j-1. The memory is configured to store the first sampling error sequence e.sub.j-1 and the first sampling error compensation sequence u.sub.j-1 of the previous iteration machining process of the sliding table of the NC machine tool. After the first sampling error sequence e.sub.j-1 and the first sampling error compensation sequence u.sub.j-1 are input to the iterative learning controller, the iterative learning controller is configured to obtain the first sampling error compensation sequence u.sub.j of current iteration through iterative calculation using a proportional-derivative (PD) method, expressed as:

(16) u j = Q ( u j - 1 + Γ p e j - 1 + Γ d de j - 1 dt ) ; ( 1 )

(17) where j is the number of iterations; Γ.sub.p and Γ.sub.d respectively represent an iterative learning gain; Q represents a low-pass filtering process; e.sub.j-1 is the first sampling error sequence. The position controller is configured to receive a difference between the second sampling command output by the down-sampling module and the displacement of the sliding table of the NC machine tool and output a velocity control signal, and the velocity control signal is held by the first holder, and input to the velocity controller after compared with real-time velocity of the sliding table of the NC machine tool. A mathematical realization expression of the first holder is shown as follows:
H.sub.u=H.sup.NS.sub.u.sup.N;

(18) where H.sup.N represents the second holder, which is configured as a zero-order holder; S.sub.u.sup.N represents an up-sampling process; and the zero-order holder is expressed as:

(19) H N = .Math. f = 0 N z - f .

(20) The up-sampling process S.sub.u.sup.N is expressed as:

(21) S u N : u [ n ] .fwdarw. u [ n ] u [ n ] = { u [ n 1 N ] , when n i n n i N Z 0 ;

(22) where Z is a time-shift operator. The velocity controller is configured to output a current signal. The current signal is configured to be superimposed on the first sampling error compensation and transmitted to the second holder. The second holder is configured to drive the motor to rotate and then drive the mechanical transmission module to move, such that the mechanical transmission module drives the sliding table of the NC machine tool to move to output an actual displacement of the sliding table of the NC machine tool.

(23) Referring to FIG. 2, the error compensation system of the NC machine tool, before output a position feedback to the position controller, to form a position loop. The motor and the mechanical transmission module, as the control plant, output velocity feedback to the velocity controller to form a velocity loop. Based on the multi-sampling rate architecture, the velocity loop is configured to realize the iterative learning control strategy with the first sampling error compensation. The first sampling error compensation is injected to the velocity loop. The error compensation system of the NC machine tool is configured to enhance the characteristics of different frequencies. The multi-sampling rate architecture is realized based on the original error compensation system of the NC machine tool, and the cost will not increase with the increased error sampling rate. The enhancement of the control precision is enabled based on the original architecture, which ensures a fast convergence during the iterative learning process.

(24) The second sampling command is expressed as r.sub.s. The second sampling command r.sub.s is obtained from the first sampling command r.sub.f by down-sampling through the down-sampling module, and a down-sampling process S.sub.d.sup.N is expressed as:
S.sub.d.sup.N:r.sub.f[n].fwdarw.r.sub.s[n],r.sub.s[n]=r.sub.f[Nn];

(25) where n and N respectively represent a positive integer, and the number of data points of the first sampling command r.sub.f is N times the number of data points of the second sampling command r.sub.s. The frequency characteristics of different control loops are strengthened, that is, the position loop and the velocity loop are configured to operate at a slow sampling rate and a fast sampling rate, respectively, according to the actual engineering.

(26) The first sampling error sequence e.sub.j-1 and the first sampling error compensation sequence u.sub.j-1 are input to the iterative learning controller, the iterative calculation performed by the iterative learning controller to obtain the first sampling error compensation sequence u.sub.1 is performed off line.

(27) The position controller is configured to work at a slow sampling rate corresponding to the second sampling command. An input of the position controller is the difference between the second sampling command r.sub.s and the displacement y of the sliding table of the NC machine tool. The motor of the sliding table of the NC machine tool is equipped with an encoder displacement detecting module. The encoder displacement detecting module is configured to detect an angular displacement of the motor and calculate the corresponding displacement y of the sliding table of the NC machine tool.

(28) In an embodiment, the error compensation system of the NC machine tool further includes a velocity estimator. And the velocity estimator is configured to estimate a real-time velocity of the sliding table of the NC machine tool in real time.

(29) An error compensation method based on the error compensation system is structurally illustrated in FIG. 3. The error compensation method is performed as follows.

(30) (S1) A desired trajectory command is generated by a trajectory generating module. The desired trajectory command includes a first sampling command and a second sampling command. The first sampling command is configured to be transmitted to a down-sampling module and a velocity-loop iterative learning controller respectively. The first sampling command r.sub.f is down-sampled by the down-sampling module to obtain a second sampling command r.sub.s. The velocity-loop iterative learning controller is configured to receive the first sampling command r.sub.f.

(31) (S2) The number of machining tasks of the NC machine tool is set. A gain parameter of the error compensation system of the NC machine tool is initialized. An error compensation of the NC machine tool is cleared.

(32) (S3) A first machining operation is performed by the NC machine tool. A first sampling error sequence and a first sampling error compensation sequence of the first machining operation are stored in the velocity-loop iterative learning controller.

(33) (S4) A first sampling error compensation is iteratively calculated by the velocity-loop iterative learning controller.

(34) (S5) A difference between the second sampling command and an actual displacement of a sliding table of the NC machine tool is input to a position controller. A velocity control signal is output by the position controller. The velocity control signal is held by a first holder, and input to a velocity controller after compared with a real-time velocity of the sliding table of the NC machine tool.

(35) (S6) A current signal is output by the velocity controller. The current signal is superimposed on the first sampling error compensation and input to a second holder. The second holder is configured to drive the motor to rotate and then drive a mechanical transmission module to move, so that the mechanical transmission module drives the sliding table of the NC machine tool to move to output an actual displacement of the sliding table of the NC machine tool.

(36) (S7) Whether the number of actual machining tasks of the NC machine tool reaches the number of machining tasks set in step (S2) is determined, if yes, the error compensation control is ended; otherwise, steps (S4)-(S6) are repeated.

(37) In an embodiment, the error compensation method is realized based on the error compensation system of the NC machine tool. The error compensation method is applied to a repetitive machining operation of the NC machine tool when the error compensation system of the NC machine tool has been constituted, and a position error signal at high sampling rate is obtained under a multi-sampling rate architecture to perform a fast error compensation at high sampling rate, avoiding the problem that the slow error compensation solved by the traditional position-loop iterative learning control method is only a sub-optimal solution, which is beneficial to improve a control precision of the NC machine tool.

(38) The low-pass filtering process is performed with an IIR-type low-pass filter using a non-causal method through the following steps. Items in a bracket of equation (1) are filtered, and a filtering result is reversed and filtered again, and a filtering result is reversed to obtain a result of an entire low-pass filtering to reduce an effect of phase delay.

(39) The following takes the trajectory tracking process under the Matlab/Simulink environment and the trajectory tracking process of the actual XY sliding table as examples to further illustrate the effectiveness of the error compensation system of the NC machine tool and the error compensation method of NC machine tool provided in the present disclosure, FIG. 4 is the desired trajectory diagram generated by the trajectory generation module under two cases (position loop iterative learning controller and velocity loop iterative learning controller) for comparison, where the horizontal coordinates represents time and the vertical coordinates represents discrete positions. The curve in FIG. 4 is a combination of step trajectories. The step trajectory is planned by S-curve, and the motor and mechanical transmission model are the control plants of the error compensation system of the NC machine tool. The linear model is identified by using the identification method in the NC machine tool error compensation system. The parameters of the velocity loop controller and the position loop controller are tuned by Matlab control toolbox, and the sampling rate of the position controller is 1000 Hz, and the sampling rate of the velocity controller is 4000 Hz, iterative learning control strategies of slow error compensation in position loop and fast error compensation in velocity loop are realized respectively, and operate continuously for 10 iterations for comparison. The compensation injection point of the slow error compensation is located in the position loop, and the compensation injection point of the fast error compensation is located in the velocity loop. The performances of the two methods are compared, where FIG. 5 shows the error compensation result diagram of slow iterative learning control (10 iterations), and FIG. 6 shows the error compensation result diagram of fast iterative learning control (10 iterations). Under the condition of interference and measurement error, it can be seen from the results of the 10th iteration that both iterative learning controllers can improve the trajectory tracking accuracy of the sliding table of the NC machine tool, but the final error result of the fast error compensation method is obviously better than the slow error compensation method. The fast error compensation method can reach the order of magnitude in 1e-2 under the simulation scenario, and the slow error compensation method can only reach the order of magnitude in 1e-1.

(40) Secondly, the trajectory tracking is performed in the actual XY sliding table. FIG. 7 shows the actual hardware structure of the NC machine tool in the process. The parameters of the position controller and the velocity controller are the same with the simulation in the Matlab/Simulink environment. The controller is implemented in the sliding table of the NI CompactRIO real-time hardware. The collected error data and compensation data are transmitted to the host PC machine via Ethernet, and calculated by MATLAB according to the error compensation method of the present disclosure to obtain the error compensation sequences u.sub.j for the next iteration process. NI CompactRIO is to control the sliding table of XY in real time with the error compensation sequences u.sub.j, and the root mean square error (RMSE) performance index is introduced to evaluate the trajectory tracking results. Two error convergence processes of the two different methods can be obtained by fast iterative learning control and slow iterative learning control. As shown in FIG. 8, the vertical coordinate represents the RMSE, and the horizontal coordinate represents the number of iterations. The trajectory tracking error of each of iteration results is calculated to obtain the RMSE value, where “∘” represents the slow ILC method, and “*” represents the fast ILC method, it can be seen that the fast error compensation method has a faster convergence speed and can obtain the better control precision.

(41) FIGS. 9-10 show the frequency spectrum of the error results of the slow iterative learning control (slow ILC, 10 iterations) when the trajectory tracking is performed by the actual XY sliding table. FIGS. 11-12 show the frequency spectrum of the error results of fast iterative learning control (fast ILC, 10 iterations) when the trajectory tracking is performed by the actual XY sliding table. Among which, the sampling rate in FIG. 9 and FIG. 11 is 1000 Hz, and the sampling rate in FIG. 10 and FIG. 12 is 4000 Hz. The error spectrum of the final convergence result of the two methods is further analyzed, because in the slow ILC process, only the 1000 Hz error result is sampled for learning, which causes the high-frequency components to alias to the low-frequency part, which causes the low-frequency component of the error distorted, and finally makes the slow ILC unable to perform learning compensation correction for some error information. In contrast, the fast ILC can avoid this problem according to the error spectrum results shown in FIGS. 11-12, which fundamentally explains the superiority of the fast ILC method. The fast ILC method has a higher position accuracy for the learning convergence process compared to the slow ILC method. The fast ILC method designed by the present disclosure is implemented in the velocity loop of the error compensation system for a multi-sampling rate NC machine tool, which solves the problems of time-consuming convergence process and low precision in the traditional slow ILC method implemented in the position loop, enhancing the machining efficiency and precision of the NC machine tool.

(42) The positional relationship indicated in the drawings are merely for exemplary illustration, and should not be construed as a limitation to this application.

(43) Described above are only preferred embodiments of the present disclosure and are not intended to limit the present disclosure. It should be understood that any modifications, replacements and improvements made by those skilled in the art without departing from the spirit and scope of the present disclosure should fall within the scope of the present disclosure defined by the appended claims.