1. Field of the Invention
The present invention relates to a controller and a machining apparatus having the same.
2. Description of the Related Art
There has been known a technique of detecting the position of an object based on two periodic signals having a phase difference of 90° which are generated by an encoder for encoding an object position. A count value obtained by counting the periods of one of the two periodic signals indicates an object position in periods. On the other hand, the arctangent value of the ratio of the two periodic signal values indicates an object position during one period. A signal representing the final object position can be obtained by combining the count value and the arctangent value. Unless the period count operation and the arctangent value processing operation completely synchronize, periodic errors occur in the value obtained upon combining the count value and the arctangent value. Conventionally, processing of compensating the periodic errors is done based on only the current values of the two periodic signals.
However, as the movement of the object speeds up with respect to the sampling period, it becomes more difficult to compensate the above-described periodic errors caused by the lack of synchronism between the period count operation and the arctangent value processing operation.
The present invention provides a technique advantageous for detecting and/or controlling, for example, the position of an object which moves at a high velocity.
One of the aspects of the invention provides a controller which generates a driving instruction to control driving of an object while detecting a position of the object based on two periodic signals that are provided by an encoder and have different phases, comprising a counter configured to count periods of one of the two periodic signals, and a processor configured to detect the position of the object based on an arctangent value of a ratio of values of the two periodic signals and a count value provided by the counter, and to generate the driving instruction based on the position, wherein the processor is configured to compensates an error in the count value based on the driving instruction generated in the past and an acceleration of the object computed based on the arctangent value and the count value, and to compute the position of the object based on the compensated count value.
Further features of the present invention will become apparent from the following description of exemplary embodiments with reference to the attached drawings.
An embodiment of the present invention will now be described with reference to the accompanying drawings.
In this application, a term “position” includes “angle”, a term “velocity” includes “angular velocity” and a term “acceleration” includes “angular acceleration”.
The encoder incorporated in the driving mechanism 2 generates two periodic signals 4 having different phases. While detecting the position (angle) of the mirror 1 based on the two periodic signals, the controller 3 generates a driving signal 5 to control driving of the mirror 1 to cause it to form a target angle, and supplies the driving signal 5 to the driving mechanism 2.
Analog/digital converters (A/D converters) 6a and 6b digitize the periodic signals 4a and 4b and supply periodic signals 4a′ and 4b′ to a processor 8, respectively. Binarizing circuits 7a and 7b binarize the two periodic signals 4a and 4b and supply binary signals 15a and 15b, respectively, to a counter 9.
The counter 9 counts the periods of one of the binary signals 15a and 15b. The count operation includes count-up and count-down. Whether to count up or down is decided by the combination of the logic levels of the binary signals 15a and 15b. A count value 11 counted by the counter 9 is supplied to the processor 8. The processor 8 processes the arctangent value of the ratio of the periodic signals 4a and 4b, and based on the arctangent value and the count value 11, generates a driving instruction (current target value) 16 to control driving of the motor 2a and sends it to the driving circuit 3b. The driving circuit 3b generates the driving signal 5 in accordance with the driving instruction 16.
The arrangement will be described below. To compensate the offset and amplitude, the maximum and minimum values of the periodic signals are obtained. The centers and amplitudes of the periodic signals are then computed from the maximum and minimum values. Compensation can be done based on the centers and amplitudes.
A method of compensating the phase difference between two periodic signals to 90° will be explained next. Periodic signals A and B′ having a phase difference δ with respect to 90° are given by
A=cos θ
B′=sin(θ+δ)
When δ is obtained, the following B phase which exactly has the phase difference of 90° with respect to the A phase can be calculated by
B=sin θ
The formula of trigonometric function yields
where A and B′ are the periodic signals output from the encoder. The periodic signal to be obtained is B, and the periodic signal B can be computed by
B=(B′−A·sin δ)÷cos δ
The method of obtaining 6 is described in, for example, Japanese Patent No. 3524225.
When the periodic signals 4a′ and 4b′ have the phase difference of 90°, an arctangent value 10 of the ratio of the values of the periodic signals 4a′ and 4b′ is a value that interpolates one period and is represented by a triangular wave shown in
However, if the timing of step appearance in the arctangent value 10 does not coincide with that in the count value 11, discontinuity occurs in the position information 12, as shown in
A conventional discontinuity compensation method will be described here with reference to
Region Z1: 4a≧0, 4b≧0
Region Z2: 4a≧0, 4b<0
Region Z3: 4a<0, 4b<0
Region Z4: 4a<0, 4b≧0
The binary signal 15a should go high in the regions Z1 and Z2 and low in the regions Z3 and Z4. The count value 11 should change at the boundary between the regions Z4 and Z1.
However, if the change timing of the binary signal 15a shifts from the appropriate timing as shown in, for example,
The above-described conventional method is effective on the assumption that the regions Z1, Z2, Z3, and Z4 are identifiable. However, in digital signal processing, a signal is processed at a predetermined sampling interval (sampling period). Analog/digital conversion of the periodic signals 4a and 4b is also done at a predetermined sampling interval. Hence, if the period of the periodic signals 4a and 4b shortens, as shown in
The above-described method of compensating the count value (or synchronizing the change of the arctangent value with that of the count value) based on only the current values of the periodic signals 4a and 4b has a limitation.
In this embodiment, the processor 8 compensates the count value 11 based on the driving instruction 16 to drive the motor 2a. The motor 2a rotationally drives its rotation axis (rotor) and the mirror 1 by a force proportional to the driving signal 5 (or driving instruction 16). In other words, the acceleration (angular acceleration) of the rotation axis of the motor 2a and the mirror 1 is proportional to the driving signal 5 (or driving instruction 16).
The differential value of position information is velocity information. In digital signal processing, the difference in position information at the sampling time interval is convenient as velocity information. Similarly, the difference in velocity information at the sampling interval (sampling period) is convenient as acceleration information. Actually, to obtain velocity information based on position information, position information needs to be divided by the sampling period. To obtain acceleration information based on velocity information, velocity information needs to be divided by the sampling period. However, the sampling period is a constant and can be included in a constant M to be described later.
Let Position(k), Velocity(k), and Accel(k) be position information, velocity information, and acceleration information at a sampling point k, respectively.
The velocity information Velocity(k) and acceleration information Accel(k) at the sampling point k are given by
Velocity(k)=Position(k)−Position(k−1) (1)
Accel(k)=Velocity(k)−Velocity(k−1) (2)
Let Curr(k) and TargetP(k) be the driving instruction value 16 and the target position (target angle) of the mirror 1 at the sampling point k, respectively. In a simple example, the processor 8 can decide Curr(k) by
Curr(k)=Gain×(TargetP(k)−Position(k)) (3)
where Gain is a constant representing gain.
The processor 8 may decide Curr(k) by, e.g., PID processing. In this embodiment, however, the processor 8 decides Curr(k) by equation (3) for the descriptive convenience.
The driving instruction value 16 at a sampling point (k−1) can be expressed as Curr(k−1). Curr(k−1) is given by
Curr(k−1)=Gain×(TargetP(k−1)−Position(k−1)) (4)
Curr(k) computed by equation (3) at the sampling point (k−1) is Curr(k−1) at the sampling point k. Hence, every time Curr(k) is computed by equation (3), the value obtained by the computation is held. This enables to use the value as Curr(k−1) at the next sampling point.
The driving instruction value Curr(k−1) and the acceleration information Accel(k) have a relationship given by
Accel(k)=M×Curr(k−1) (5)
where M is a proportionality factor. When the mirror 1 is accelerated in accordance with the driving instruction value Curr(k−1) at the sampling point (k−1), the acceleration of the mirror 1 at the sampling point k is detected as the acceleration Accel(k).
The processor 8 compensates the count value based on a difference Diff between Accel(k) computed by equations (1) and (2) and the product of M and Curr(k−1) decided at the sampling point (k−1) by equation (3) (or Curr(k−1) decided by equation (4)). The difference Diff is given by
Diff=Accel(k)−M×Curr(k−1) (6)
where M×Curr(k−1) is the estimated acceleration value, as is apparent from equation (5). Accel(k) according to equations (1) and (2) is computed based on the position information Position(k) decided by the count value 11 that can contain errors. If the value Diff is larger than a positive first threshold Th (Th>0) and smaller than a negative second threshold −Th (Th>0), it can be determined that the count value 11 contains errors. Note that Th is defined to enable to determine the presence/absence of an error corresponding to one count value. For example, a value that is 90% of an error amount corresponding to one count value can be defined as Th.
In step S2, the processor 8 calculates the acceleration information Accel(k) by equation (2) using the velocity information Velocity(k) at the current sampling point k and the velocity information Velocity(k−1) at the past sampling point (k−1).
In step S3, the processor 8 computes, by equation (6), the difference Diff between the acceleration information Accel(k) computed in step S2 and the product of M and the driving instruction value Curr(k−1) decided at the past sampling point (k−1).
In step S4, the processor 8 determines whether the value Diff is larger than the positive first threshold Th (Th>0). If the value Diff is larger than the positive first threshold Th (Th>0), the process advances to step S5 to compensate the count value 11 (compensate the position information). On the other hand, if the value Diff is not larger than the positive first threshold Th (Th>0), the processor 8 advances the process to step S6. That the value Diff is larger than the positive first threshold Th (Th>0) means that the count value 11 is erroneously larger by one.
In step S6, the processor 8 determines whether the value Diff is smaller than the negative second threshold −Th (Th>0). If the value Diff is smaller than the negative second threshold −Th (Th>0), the process advances to step S7 to compensate the count value 11 (compensate the position information). On the other hand, if the value Diff is not smaller than the negative second threshold −Th (Th>0), the processor 8 ends the series of processes shown in
In step S5, the processor 8 compensates the position information Position(k) by decreasing the count value 11 by one. When one period is divided into R (e.g., 1024), compensation is done by
Position(k)=Position(k)−R (7)
For example, if Velocity(k) and/or Accel(k) is necessary for computing Curr(k), Velocity(k) and/or Accel(k) is computed based on Position(k) compensated by equation (7).
In step S7, the processor 8 compensates the position information Position(k) by increasing the count value 11 by one. When one period is divided into R (e.g., 1024), compensation is done by
Position(k)=Position(k)+R (8)
For example, if Velocity(k) and/or Accel(k) is necessary for computing Curr(k), Velocity(k) and/or Accel(k) is computed based on Position(k) compensated by equation (8).
As another embodiment, the count value 11 may be compensated based on discontinuity detected by comparing an acceleration Accel(k−1) at an immediately preceding sampling point(k−1) with the acceleration Accel(k) at a current sampling point k. This method uses the fact that the acceleration or angular acceleration of a moving object having a mass or a moment of inertia never largely charges during a short time. Discontinuity is detected by setting a reference decided in accordance with the maximum value of the acceleration change in a normal operation. In processing of this embodiment, equation (6) executed in step S3 of the processing in
Diff=Accel(k)−Accel(k−1) (9)
In the above-described embodiments, the motor 2a is a rotary motor, and the encoder 2b is a rotary encoder. However, the present invention is also applicable to an arrangement in which the motor 2a is a linear motor, and the encoder 2b is a linear encoder.
While the present invention has been described with reference to exemplary embodiments, it is to be understood that the invention is not limited to the disclosed exemplary embodiments. The scope of the following claims is to be accorded the broadest interpretation so as to encompass all such modifications and equivalent structures and functions.
This application claims the benefit of Japanese Patent Application No. 2009-009360, filed Jan. 19, 2009, which is hereby incorporated by reference herein in its entirety.
Number | Date | Country | Kind |
---|---|---|---|
2009-009360 | Jan 2009 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5021650 | Rieder et al. | Jun 1991 | A |
5036264 | Ueki | Jul 1991 | A |
5625310 | Takeishi | Apr 1997 | A |
5943639 | Tanaka et al. | Aug 1999 | A |
6188341 | Taniguchi et al. | Feb 2001 | B1 |
6327066 | Takishima et al. | Dec 2001 | B2 |
6600150 | Adkins et al. | Jul 2003 | B1 |
6791219 | Eric et al. | Sep 2004 | B1 |
6956505 | Taniguchi et al. | Oct 2005 | B2 |
7066591 | Eaton et al. | Jun 2006 | B2 |
7456599 | Piefer et al. | Nov 2008 | B2 |
7457713 | Finkler et al. | Nov 2008 | B2 |
7459872 | Woodland et al. | Dec 2008 | B2 |
7966158 | Seo | Jun 2011 | B2 |
8384570 | Hunter | Feb 2013 | B2 |
20050015099 | Momoi et al. | Jan 2005 | A1 |
20070008192 | Fujita | Jan 2007 | A1 |
20080013143 | Ide et al. | Jan 2008 | A1 |
20100045219 | Ajima et al. | Feb 2010 | A1 |
Number | Date | Country |
---|---|---|
7-229757 | Aug 1995 | JP |
11-295105 | Oct 1999 | JP |
3524225 | May 2004 | JP |
Number | Date | Country | |
---|---|---|---|
20100185340 A1 | Jul 2010 | US |