Error compensation system and method for numerical control (NC) machine tool based on iterative learning control
11360455 · 2022-06-14
Assignee
Inventors
Cpc classification
G05B19/251
PHYSICS
G05B19/404
PHYSICS
G05B23/0254
PHYSICS
International classification
G05B11/42
PHYSICS
G05B19/404
PHYSICS
G05B19/416
PHYSICS
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:
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:
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)
(2)
(3)
(4)
(5)
(6)
(7)
(8)
(9)
(10)
(11)
(12)
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
(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
(16)
(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)
(20) The up-sampling process S.sub.u.sup.N is expressed as:
(21)
(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
(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
(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,
(40) Secondly, the trajectory tracking is performed in the actual XY sliding table.
(41)
(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.