US 7499827 B2
An absolute measurement scale has an incremental scale with light reflecting lines alternating with non-light reflecting lines in which absolute data, in the form of discrete codewords, is embedded in the incremental scale by removing light reflecting lines. The codewords are arranged such that the scale is palindromic and cyclic. A look-up table is used to determine a coarse absolute position by comparing absolute position data extracted from the scale with absolute codewords in the look-up table. The absolute position is determined by combining the coarse absolute position with the position of the start of the first codeword in the data extracted. The absolute position may be determined to within a scale pitch by combining the absolute position with the incremental position.
1. A measurement scale comprising:
a single incremental scale track comprising a series of lines having a first property, and generally alternating lines having a second property;
wherein an absense or presence of the lines from the incremental scale track having either the first property or the second property produce patterns which form codewords, thereby embedding absolute data in the incremental scale track in the form of discrete codewords.
2. A measurement scale according to
3. A measurement scale according to
4. A measurement scale according to
5. A measurement scale according to
6. A measurement scale according to
7. A measurement scale according to
8. A measurement scale according to
9. A measurement scale according to
10. A measurement scale according to
11. A measurement scale according to
12. A measurement scale according to
13. A system for measuring absolute position comprising a measurement scale and a scale reader relatively movable with respect to each other;
wherein the measurement scale comprises an incremental scale track with a series of lines having a first property generally alternating with lines having a second property;
wherein an absence or presence of the lines from the incremental scale track having either the first property or the second property produce patterns which form codewords, thereby embedding absolute data in the incremental scale track in the form of discrete codewords;
and the scale reader includes a light source to illuminate the scale, and at least one detector to determine the incremental position and the absolute position from said incremental scale track.
14. A system for measuring absolute position according to
15. A system for measuring absolute position according to
16. A system for measuring absolute position according to
17. A system for measuring absolute position according to
18. A system for measuring absolute position according to
each absolute bit of data has a value of 1 or 0;
wherein there is a clock bit with a value of 0 between each absolute data bit;
wherein it is determined whether any bit of the scale is an absolute data bit or a clock bit by measuring the values of the (m+1)th bits on either side of that bit, where m=any even integer;
and wherein the values of these bits are summed together, such that if the sum is smaller than a predetermined value the bit is an absolute data bit.
19. A measurement system according to
20. A system for measuring absolute position according to
21. A system for measuring absolute position according to
the goodness of match between the codeword in the look-up table and the codeword extracted from the scale is determined by:
comparing the sequence of an n-bit block of extracted data with the n-bit codeword in the look-up table;
wherein each bit of extracted data whose corresponding bit in the codeword in the look-up table is 1 is inverted;
and wherein the values of the n bits of extracted data are summed together;
such that if the summed value is low, the match is good.
22. A system for measuring absolute position according to
23. A system for measuring absolute position according to
24. A system for measuring absolute position according to
25. A system for measuring absolute position according to
26. A system for measuring absolute position according to
27. A system for measuring absolute position according to
28. A system for measuring absolute position according to
This application is a 371 of PCT/GB02/01629, filed Apr. 11, 2002.
The present invention relates to the measurement of the absolute position of an object.
An incremental position encoder is a device for measuring the relative position of two objects. Typically a scale is attached to one of the objects and a readhead to the other, the scale having regularly spaced identical markings on it. The readhead projects light onto the scale which, depending on the configuration of the scale, is then either reflected or transmitted. From the reflected or transmitted light, the readhead generates a series of signals which may be used to generate an incremental count indicative of the relative displacement of the two objects. The readhead may provide some electronic interpolation such that the resolution is higher than would be achieved by direct counting of the markings on the scale. In some cases the outputs are analogue (often two sinusoidal in quadrature) to allow electronics external to the readhead to perform the interpolation. An incremental encoder has no knowledge of the readhead's absolute position along the scale.
An absolute encoder typically comprises a scale with data written on it in the form of a pseudorandom sequence or discrete codewords. By reading this data as the readhead passes over the scale the readhead can determine its absolute position.
Hybrid incremental absolute position encoders also exist. As it is possible to make incremental encoders with finer resolution than absolute encoders, many absolute encoders also incorporate separate incremental channels. The absolute channel gives absolute position accurate to at least one period of the incremental channel. Interpolation of the incremental channel gives position within the period of the incremental channel to the desired fine resolution. Combined together, the two systems give absolute position to a fine resolution. However, as the absolute channel and the incremental channel are in separate tracks, yawing of the readhead can result in errors when combining the incremental and absolute position. Furthermore, when fixed in position the scale must be in the correct orientation such that the incremental and absolute tracks are aligned with the respective readheads.
A hybrid incremental absolute position encoder is disclosed in European Patent No. 0503716 in which the absolute channel consisting of a pseudo-random code and incremental channel are combined to form a single composite channel.
A first aspect of the present invention provides a measurement scale comprising:
Preferably the lines having a first property are light reflecting or light transmitting and wherein the lines having a second property are non-reflecting or non-transmitting.
Preferably extra or fewer lines are provided having one of said properties, compared to those having the other property, in patterns which form said codewords thereby embedding the absolute date in the incremental scale track. Alternatively the width or spacing of the lines in the incremental scale track are varied, thereby embedding the absolute data in the incremental scale track.
Preferably the lines having the first of second property extend substantially across the width of the scale. The absolute data on the scale may be palindromic.
The absolute data may be divided into discrete codewords, the beginning of each codeword being marked by an identical start symbol. The absolute data in both the codewords and the start symbols may consist of binary codes.
Preferably the codewords define N unique positions over a length of scale, this length being repeated such that the (N+1)th position is the same as the 1st position etc.
A second aspect of the invention provides a system for measuring absolute position comprising a measurement scale and a scale reader relatively movable with respect to each other;
Preferably the readhead used to determine the incremental position is a filtering readhead.
Preferably each absolute bit of data has a value of 1 or 0, wherein there is a clock bit with a value of 0 between each absolute data bit; wherein it is determined whether any bit of the scale is an absolute data bit or a clock bit by measuring the values of the (m+1)th bits on either side of that bit, where m=any even integer; and wherein the values of these bits are summed together, such that if the sum is smaller than a predetermined value the bit is an absolute data bit.
Preferably a look-up table is used to determine a coarse absolute position by comparing absolute position data extracted from the scale with absolute codewords in the look-up table. The absolute position may be determined to within one incremental scale pitch by combining the coarse absolute position with the position of the start of the first codeword in the data extracted by the detector system and the location of the first complete data bit in the data extracted by the detector system. The absolute position may be determined to within a fraction of the scale pitch by combining the absolute position with the incremental position.
Preferred embodiments of the present invention will be illustrated by way of example with reference to the accompanying drawings, wherein:
Removal of parts of the incremental pattern degrade the signal from the incremental channel, however the effect is not serious if the damage is consistent along the scale. In this example reflective lines of the incremental scale are removed resulting in a drop in the incremental signal, but also a drop in the background light by the same ratio; However, if reflective lines are added instead this would result in a drop in the incremental signal by the same amount but also an increase in the background light.
Absolute data may be embedded in the incremental scale without the addition or removal of incremental lines. Instead the width of lines or the distance between lines may be varied.
As the absolute data is embedded in the incremental scale, the scale may be prismatic. This means that it is uniform along its width as seen in
The absolute data embedded in the incremental scale is designed to be palindromic. This means that the absolute data on the scale is precisely the same if read from either end of the code sequence.
The absolute data on the scale defines unique positions over a certain length which may be several metres long. Beyond that length the coding repeats seamlessly so that the coding has no beginning or end. If the scale defines N unique positions along its length from start to finish, then by making the (N+1)th position the same as the 1st position and, the (N+2)th position the same as the 2nd position etc, the scale becomes cyclic. The length of one cycle of the scale code is known as the repeat length. Lengths of scale longer than the repeat length may be used, although positions defined along it will no longer be unique. As shown in
Cyclic coding enables the scale to be manufactured continuously and stocked in long lengths. Any length subsequently cut will contain valid coding over its entire length. For example,
There is one bit of absolute data every pitch of the incremental scale. The bits are grouped into codewords and start symbols. Each start symbol is identical and serves to mark the start of each codeword, whereas the codewords are used to define the absolute position. The choice of start symbols is constrained as the chosen sequence for the start symbol must not occur within any of the codewords otherwise part of the codeword could be misidentified as a start symbol. Furthermore, no codeword must end with the beginning of the start symbol or vice versa as this could result in the position of the codeword being misinterpreted by a few bits.
For the scale to be both palindromic and cyclic, the start symbols must also be palindromic. In addition, only two codewords within a repeat length may be palindromic without having any repeated codewords. Both scales 18 shown in
Several strategies are employed to ensure that the codewords used do not degrade the metrological accuracy of the incremental channel. Some of these strategies involve not using codewords which badly affect the incremental signal.
The first strategy is not to use codewords which do not contain equal numbers of 1s and 0s. For example a 16-bit codeword should contain exactly eight 1s and eight 0s. This ensures that the incremental signal size remains constant as the readhead traverses the scale. It may be possible to relax this constraint to codewords having between seven and nine 1s and 0s and possibly further.
The second strategy involves not using codewords which contain a string of more than a predetermined number of 1s or 0s in a row. For example, the maximum number of 1's in a row may be six, or more preferably four. These long uniform sequences cause the incremental Lissajous, formed by two sinusoidal outputs in quadrature, to be momentarily de-centred as the readhead passes over them.
The third strategy does not involve the non-use of any codewords. To minimise the effect of the absolute data on the incremental channel, the scale must appear uniform over the length of the incremental channel's reading window which is typically 50 bits long. This is achieved by rearranging the order of codewords along the scale to ensure that any sequence of fifty consecutive bits has as near as possible the same number of 1s (or equally 0s).
The readhead used to read the scale comprises at least one light source to illuminate the scale and at least one detector to determine the incremental and absolute positions.
A simplified version of the readhead 54 and scale 18 is shown in
Separate detectors may be used or alternatively both detectors could be incorporated onto one chip (i.e. the same pixels detecting both the absolute and incremental positions). Likewise, common or separate light sources and lens arrays may be used.
A filtering readhead, as described in European Patent No. 0207121, is suitable for use in determining the incremental position. In such a readhead, each point on the scale produces fringes at a detector in the form of a sinusoidal wave. Each fringe at the detector is produced by many points on the scale. If parts of the scale are missing, the signal at the detector will be slightly degraded but this effect is averaged out and the frequency and sinusoidal shape remain the same. Only the base frequency of the scale is detected and harmonics, caused by missing parts of the scale, are filtered out.
Use of a filtering readhead therefore allows a non-diffraction quality scale to be used and the readhead is still able to determine incremental position to within one pitch of the scale when selected scale 10 markings are missing or added. Thus the filtering readhead is able to read the hybrid absolute and incremental scale as if it was a purely incremental scale.
An optical detector system consisting of a linear array of pixels may be used to determine the absolute position. The maximum size of each pixel is set by the Nyquist criterion, but preferably smaller pixels are used.
A microlens array 27, as shown in
The absolute data needs to be extracted from the hybrid absolute and incremental scale. A test is required to determine whether the value of any particular pixel represents a data bit or not. Absolute data is only embedded on the reflective lines of the original incremental scale. These data bits may now have a value of 0 or 1 depending on whether the reflective lines have been removed or left remaining. The original non-reflective lines on the incremental scale have remained unchanged. These have a value of 0 and are referred to as clock bits. There is a clock bit between each data bit.
A typical scale 18, as shown in
. . . , . . . , (−5×2.56), (−3×2.56), (−1×2.56), (+1×.2.56), (+3×2.56), (+5×2.56), . . . , . . .
As fractional pixels do not exist, the following pixels should be closest to the clock data relative to the pixel under test:
The values at these locations (i.e. between 1 and 0) are summed together. The lower the total the more likely the pixels are to represent clock bits and therefore the more likely the pixel under test is to represent a data bit. As the exact magnification is not known (because of variation due to the rideheight of the readhead for example), it is only useful to search for clock bits within a certain distance of the pixel under test. Searching for clock bits too far from the pixel under test may result in them being out-of-step with their true positions due to magnification errors.
It is not possible to locate the first data bit in the image by this method as it is not possible to read sufficient pixels on either side of this data bit. For the same reasoning it is not possible to locate the last data bit on the image by this method. The data bits further towards the middle of the image are determined by the above process then, assuming the magnification is constant, data bits at each end can be read out as the number of pixels between each data bit is now known.
At this stage a block of extracted data has been created. The flow diagram in
Once the start symbols have been found 40, the locations of three complete codewords in the extracted data are calculated. This may be done by the use of a look-up table permanently stored in the readhead's memory which is used to decode the three codewords. Each series of three consecutive words in the look-up table is compared with the three words from the image 42. In each case a goodness of match is calculated 44 in the same way as for calculating the start symbols. The best match position in the look-up table gives the coarse absolute position of the readhead. The goodness of match coefficient of the second best match is also stored and this coefficient is then used to determine the trustworthiness of the coarse position 46. If the best match is only marginally better than the second best match then the reported coarse position is untrustworthy. Whereas if the best match was much better than the second best match the degree of confidence is higher. Thresholds can be applied to this value to determine whether the readhead uses the data to calculate the coarse absolute position 48 or scraps the result and starts again with a new image 30.
Assuming that the data is deemed to be sufficiently trustworthy, the final step is to calculate the absolute position. Four pieces of data are required. These are (a) the coarse position from the look-up table (to the nearest codeword on the scale), (b) the position of the start of the first word in the extracted data (to the nearest scale pitch), (c) the position of the start of the first complete data bit in the original image (to the nearest detector pixel) and (d) the phase of the Lissajous from the incremental channel (to the unit of resolution).
(a) and (b) are sufficient to calculate the absolute position of the readhead to the nearest scale pitch. (d) is used to determine the position within one scale pitch to the required final resolution. However it is possible to get a position error of one scale pitch from this information alone. (c) contains sufficient information to check for this and correct the position if necessary.
This invention may be carried out using a light-transmissive scale instead of a light-reflective scale.
Although this embodiment describes a linear scale and readhead, this invention could also be suitable for a rotary scale or a two-dimensional scale.
Furthermore, the scale is not limited to binary coding. Multi-level coding may also be used. For example if the scale comprises a glass plate with chrome deposited on it, the code could be produced by leaving clear glass for the clock bits, using half-density chrome for the “0” data bits and full-density chrome for the “1” data bits. Alternatively the “0” data bits may comprise dotted lines and the “1” data bits may comprise solid lines.
This invention would also be suitable for non-optical scales, for example capacitative or magnetic scales.