The present invention relates to an optical code to be attached to an item for information processing. More particularly, the invention relates to an optical symbol for use in the optical code, a method of attaching the optical symbol to an item, and a decoding method.
The invention further relates to a method of cutting an optical recognition code. More particularly, the invention relates to a method of recognizing (cutting) a novel optical recognition code (referred to as a 1.5D color bit code (Japanese Patent Application No. 2006-196548)) invented by the inventors of the present invention.
The invention also relates to a method of recognizing an optical recognition code. More particularly, the invention relates to a method of recognizing a novel optical recognition code (referred to as 1.5D color bit code (Japanese Patent Application No. 2006-196548)) invented by the inventors of the present invention.
Various symbols which are attached to items to be optically read for information processing are used. For example, a so-called barcode that records information by black and white patterns in one-dimensional direction is used since a long time ago.
As optical codes, codes using chromatic colors such as red and blue (for convenience, such codes using chromatic colors will be referred to as color codes herein) other than black and white are widely proposed.
Normally, in an optical code (system) using colors (using chromatic colors), when a change occurs in detection of colors in a reader, the possibility that corresponding data also changes is higher than that in a black-and-white code. There is consequently a problem that the optical code using colors is susceptible to deterioration in color, printing unevenness, illumination light, and the like.
Generally, a conventional so-called two-dimensional barcode expresses data by black and white (dark and light) segments whose positions are defined in a grid shape. Normally, a “marking pattern” (which refers to the pattern of the barcode including quiet zones) is integrated with a “marked object” as an object to which marking is applied. Therefore, in optical capturing operation (capture of data as two-dimensional image data by an area sensor or the like), a part of the “marked object” is also captured.
Even in the case where only the “marking pattern” floats in the air, usually, it is unavoidable that a background is captured together with the marking pattern. In this case, an input image other than the “marking pattern” is referred to as a “background image”, and input image of the “marking pattern” is referred to as a “marking image”.
To decode the “marking image” to obtain the original data, it is necessary, as the first steps,
The cutout in a two-dimensional barcode is typically performed as follows.
First, a predetermined area is captured by the area sensor, a specific pattern (usually, called “cutout mark”) is found by image recognition from the captured image. Based on the sizes and the positional relation of the “cutout marks”, a two-dimensional barcode existing range is estimated. Further, the range and the dimension of the pattern of the two-dimensional barcode are estimated, the range is segmented, and the existence of the two-dimensional barcode is recognized.
On the other hand, a classic one-dimensional barcode represents data by the thicknesses of black and white (dark and light) bars. Bars at both ends and quiet zones correspond to the “cutout marks”.
However, a one-dimensional barcode has a specification in which linear “scan lines” are assumed and the dark and light patterns on the lines are read, and thus an operation of cutting out a marking pattern from the background is not actually performed. In reality, a work of aligning the “scan lines” with the bars in a one-dimensional barcode is necessary and is usually performed by visual observation of the operator.
Alternatively, a method of emitting a number of scan lines like a raster scan, placing a barcode in the range where the scan lines exist, and perform decoding is common.
Therefore, the idea of “cutout” in the one-dimensional barcode is handy as compared with the two-dimensional barcode. On the other hand, a predetermined width (length of thick and bars) is necessary for the “marking pattern” in the barcode. When the thickness is extremely small or large or in the case where arranged bars are curved, it is very difficult to perform decoding.
In a conventional so-called two-dimensional barcode, a check digit for checking the barcode (detection of error and correction), which is similar to that used for a one-dimensional barcode or the like, is used.
As described above, the inventors of the present invention have invented a 1.5D color bit code as a novel two-dimensional optical recognition code, for which another patent application (Japanese Patent Application 2006-196548) was filed.
In the 1.5D color bit code, for example, band-shaped regions to be colored in three colors are provided for each of the three colors. Predetermined data is expressed by coloring or not coloring each of the band-shaped regions to be colored in a corresponding color.
In other words, the 1.5D color bit code is a code system characterized in that, in lines of three colors, whether the colors are applied or not (ON/OFF states) and digital data are associated with each other. When the band-shaped regions are scanned in the longitudinal direction, a colored part is called an ON part and a not-colored part is called an OFF part.
There is consequently an advantage that, as long as the ON/OFF timings are maintained, decoding is not influenced by some deformation in a code symbol.
The timings in this case refer to timings at the time of scanning. They are not “timings” in a temporal sense but “timings” in a spatial sense. The “code symbol” refers to a specific code itself generated based on the code system of the 1.5D color bit code and will also be simply referred to as a “symbol”.
The 1.5D color bit code has a part where a read error (erroneous reading) occurs relatively easily. In some cases, it is preferable to secure the part intensively.
It is therefore preferable to use a novel check digit using the characteristic of the 1.5D color bit code, instead of the check digit used for a conventional one-dimensional barcode like other two-dimensional barcodes as described above.
For example, the patent document 1 mentioned below discloses a barcode using three colors. The barcode is constructed so that “1” is expressed when the colors are shifted in a first order, and “0” is expressed when the colors are shifted in a second order.
The patent document 2 mentioned below discloses a code realizing increased data capacity by setting the color density of each of three primary colors in a plurality of tones.
The patent document 3 mentioned below discloses a two-dimensional code in which information is divided into predetermined bit sequences according to printing capacity of a printer, and a color is selected and recorded for each of the divided bit sequences, a method of generating the two-dimensional code, and a restoring method.
The patent document 4 mentioned below discloses a code which can be used as a colored barcode as well as a general black-and-white barcode.
The patent document 5 mentioned below discloses a label printer for printing a plurality of barcodes so as to be overlapped in the same place in different colors. With the technique, the size of the label can allegedly be reduced.
The patent document 6 mentioned below discloses a technique of expressing a synthetic two-dimensional code obtained by combining a plurality of two-dimensional codes.
The patent document 7 mentioned below discloses a color multiple dot code as a two-dimensional barcode. In particular, it discloses that an error correction data region exists in a code.
The patent document 8 mentioned below discloses an apparatus for reading a two-dimensional code and reproducing information. It discloses that error correction data is included in the two-dimensional code.
Japanese Patent Application Laid-Open No. S63-255783 (Patent No. 2521088)
Japanese Patent Application Laid-Open No. 2002-342702
Japanese Patent Application Laid-Open No. 2003-178277
Japanese Patent Application Laid-Open No. 2004-326582
Japanese Patent Application Laid-Open No. 2001-88361
Japanese Patent Application Laid-Open No. 2003-323585
Japanese Patent Application Laid-Open No. 2005-310150
Japanese Patent Application Laid-Open No. 2005-310148 (Patent No. 3908250)
As described above, a so-called one-dimensional barcode is widely practically used as a code system in which codes are arranged one-dimensionally. Although a number of kinds of one-dimensional barcodes exist, they have a code system of encoding an image using variations in the widths of black and white (dark and light) patterns which alternately appear. It is understood that a two-dimensional barcode has a similar concept when the “width” is replaced with “cell position”.
Usually, a barcode is printed directly on paper or a product. Therefore, if the concept can be carried out as it is, there is no problem.
However, in circumstances that a barcode can be printed only to a distortable item or only inaccurate printing can be performed, a method relying on the widths of bars cannot be always said to be a proper method. In such a case, although there is a need for attaching an ID, the user has to give up the method in not a few cases due to the above-described problem.
On the other hand, as described above, a number of so-called color barcodes are conventionally proposed. However, most of the conventional color barcodes are directed to increase the density of data. Barcodes which realize an increased number of colors and densities to increase data density but result in lack in practicality are found here and there.
In the field of the conventional black and white barcode, the conventional techniques are used as they are, and proposals to solve the problems are hardly known. This may be due to circumstances that the method of attaching a (adhesive) seal on which a barcode is printed to an item is commonly used and a barcode is hardly directly printed on a distortable item.
However, the method of attaching a seal has the possibility of allowing illicit behavior such as re-attaching a seal or replacing with another seal. Consequently, a code which can be printed directly on an item is desirable.
The present invention has been achieved in view of such problems, and an object of the invention is to provide a code using an optical symbol which can be read at high precision even from a deformable item and in the environment that printing precision is not high.
It may be appropriate to describe the “1.5D color bit code” developed by the inventors of the present invention in comparison with a conventional two-dimensional barcode, for a two-dimensional image of an area sensor is used and the thickness and bending of a “marking pattern” are allowed.
In the following, the description will be given in such a manner.
The conventional two-dimensional barcode cutout method has been described above. However, the method has a major technical problem that cutout cannot be performed if a cutout pattern cannot be recognized accurately. Specifically, the two-dimensional barcode cannot be accurately recognized if a precondition that a two-dimensional barcode is arranged on a flat surface is not satisfied. Further, since an operation for finding a specific pattern of a “cutout mark” is performed in a complicated “background pattern”, estimation of a distortion of the cutout mark, estimation of the size, allowance in the case where the flat surface is curved, and the like have to be performed by distinguishing the cutout mark from various background patterns and, usually, the process amount is enormous.
In practice, therefore, the image capture range of the area sensor is adjusted so that an occupation range of the “marking image” in the entire screen is set to be large. In actual use, an ancillary operation of the user to adjust the position (perform positioning) of the “marking image” (in the screen) while watching the screen is also often performed.
Therefore, in the case where a plurality of barcodes exists in an image, the processes and positioning are more complicated and higher precision is required. It is consequently very difficult to realize it and the method is hardly performed in practice.
The 1.5D color bit code developed by the inventors of the present invention is originally directed to recognize/trace only the order of the “ON/OFF” state of a color, and has characteristics that the code is resistive to distortion, blurring, variations, and the like in the dimension and shape.
Naturally, for reading, a 1.5D color bit code also has to be cut out from an image captured together with the background by an area sensor or the like.
However, unlike a conventional two-dimensional barcode, the 1.5D color bit code expresses data by the order of the ON/OFF state of a color, and there is no special limitation in the dimensions and shapes. Therefore, the method of detecting a cutout mark or the like and estimating an area like in an existing two-dimensional barcode cannot be applied as it is.
The present invention has been achieved in view of the problems and an object of the invention is to propose a simple cutout method utilizing advantages of a 1.5D color bit code, resistive to distortion, blurring, variations, and the like in the dimension and shape, and different from that of a conventional two-dimensional barcode.
Another object of the present invention is to propose a method capable of easily cutting out 1.5D color bit codes even when a plurality of 1.5D color bit codes exists in an image.
Further, as described above, in the “1.5D color bit code” developed by the inventors of the present invention, fluctuations in the thickness of band-shaped areas in a “marking pattern (the ON/OFF states of a plurality of colors in band-shaped area)” and bentness to a certain degree are allowed. Consequently, in the “1.5D color bit code”, unlike a conventional two-dimensional barcode, resistance to distortion, blurring in printing, and the like is conventionally very high.
However, there is the case where data is erroneously read as another data due to deviations in the ON/OFF timings in the band-shaped area. Specifically, there is a situation that the possibility of erroneously reading data as another data is higher in a part of a specific value than data of another value.
Therefore, in a check digit employed in the 1.5D color bit code, desirably, a part (the part of the specific value) can be secured most utilizing the characteristics of the code system of the 1.5D color bit code.
The present invention has been achieved in view of the problems and an object of the invention is to provide a method of securing a part in which erroneous reading tends to occur (part of a specific value) and a check digit capable of realizing such a method utilizing the advantages of the 1.5D color bit code.
Means 1 achieved in view of the problem 1 will be described below.
In a code of the present invention, cells are arranged linearly, and specific data is indicated by a state (whether a color is attached or not) of elements in each of the cells. In particular, it is characterized in that a color to be attached to each of the elements is fixed.
The present invention proposes a code system which can be read if continuity of an element sequence and the linear form (topology) are maintained.
Herein, “linear” refers to a state where cells are arranged in a line without being branched or crossed. As long as the cells are lined, the line may be straight, curved, or bent.
Terms in the specification will be briefly described.
First, in the specification, an item to which an optical symbol is attached may be any corporeal thing. It may not be necessarily a rigid member but may be a soft item such as food. As will be described later, the present invention proposes an optical symbol resistive to distortion and deformation of an item. A soft item such as clothes is also included in the “item” in the specification.
A container and package of an item are also included in the “item”. Further, a flat- or plate-shaped item such as sheet of paper is also included in the “item” in the specification.
In the specification, the following terms are also used.
Code: A code is a standard for expressing data in a symbol. To clarify that the code is a standard, the code may also be referred to as a code system.
Symbol: A symbol is obtained by converting data based on the standard. For example, in a typical barcode, each of “black and white patterns” obtained by converting data based on the “standard” called “barcode” is called a symbol or a “barcode symbol”.
Decoding: A process of obtaining original data from each of symbols based on the code is called decoding.
Reader: A reader is an apparatus for reading a symbol attached to an item. The read data is subject to the decoding. As a result of decoding, original data is obtained.
Data: Data is an object to be converted to a symbol. Data is typically numerical data, but may be character data or digital data made of 0 and 1.
Specifically, the present invention employs the following means.
(1) To solve the problems, the present invention provides an optical symbol including continuously arranged cells each including “n” pieces of elements from a first element to an n-th element, in which a k-th element can be set in two states: a state where a k-th color is given, and a state where the k-th color is not given. “n” is an integer of 3 or greater, and “k” is an integer from 1 to “n”.
(2) In the optical symbol of (1) of the present invention, “n” is 3, a first element can be set in two states: an ON state where R as a first color is given, and an OFF state where R is not given. A second element can be set in two states: an ON state where G as a second color is given, and an OFF state where G is not given. A third element can be set in two states: an ON state where B as a third color is given, and an OFF state where B is not given.
The state where a color is not given includes, as will be described later, a case where black is given and a case where the ground color appears.
(3) In the optical symbol of (1) of the present invention, states of elements of neighboring cells are different from each other.
(4) In the optical symbol of (3) of the invention, only a state of any one of “n” elements included in the neighboring cell is different.
(5) In the optical symbol of (1) of the invention, the k-th elements included in the neighboring cells are adjacent to each other.
(6) In the optical symbol of (1) of the invention, the cells include end-point cells positioned at ends of a sequence of cells continuously arranged, a configuration cell indicative of data, positioned between the end-point cells, and neighboring cells neighboring the end-point cells. All of the elements in the end-point cells are in the OFF state, the elements in the neighboring cell neighboring the end-point cell positioned in a start point are in a predetermined first state, and the elements in the neighboring cell neighboring the end-point cell positioned in an end point are in a predetermined second state. The start point can be detected by detecting continuation of the cell whose elements are all in the OFF state and the cell whose elements are in the first state. The end point can be detected by detecting continuation of the cell whose elements are all in the OFF state and the cell whose elements are in the second state.
(7) In the optical symbol of (1) of the invention, a sign indicated by the cell is determined according to states of elements of the cell and one or more cells connected to the cell.
(8) In the optical symbol of (1) of the invention, a check, a notation, and the like are distinguished from each other by selection of the relation between the cell and the sign.
(9) In the optical symbol of (1) of the invention, a color corresponding to an excessive light amount is not included in the k-th color depending on the kind of a light source for irradiating the optical symbol.
(10) The present invention also provides an item to which the optical symbol of any one of (1) to (9) is attached.
(11) The present invention also provides a code system using the optical symbol of any one of (1) to (9).
(12) The present invention also provides a method of decoding the optical symbol according to any one of (1) to (9), including: a step of capturing the optical symbol and obtaining image data of the optical symbol; a step of retrieving end-point cells at a start point and an end point from the image data; a step of tracing a configuration cell provided between the two retrieved end-point cells at the start and end points based on the end-point cells; and a step of decoding the traced configuration cell.
(13) In the method of decoding the optical symbol of (12) of the invention, in the step of retrieving end-point cells at a start point and an end point, in the case where the elements in a cell neighboring the end-point cell are in a predetermined first state, the end-point cell is determined to be an end-point cell indicative of a start point, and in the case where the elements in a cell neighboring the end-point cell are in a predetermined second state, the end-point cell is determined to be an end-point cell indicative of an end point.
(14) In the method of decoding the optical symbol of (12) of the invention, in the step of tracing the configuration cell, in the case where a change occurs in a state of each of the elements in the configuration cell at the time of scanning the image data and tracing the configuration cell, it is determined that the border between configuration cells is passed and the scanning and tracing is shifted to a new configuration cell.
(15) The present invention also provides a method of attaching the optical symbol of any of (1) to (9) to an item, including: a step of generating the optical symbol based on data to be recorded; and a step of attaching the generated optical symbol to a predetermined item. The attaching step includes any of a step of printing the optical symbol to the item, a step of attaching the optical symbol to an item by embroidery, and a step of attaching an adhesive seal on which the optical symbol is drawn to the item.
Means 2 achieved in view of the problem 2 will be described below.
(16) To achieve the objects, the present invention provides an optical recognition code cutting method of cutting an optical recognition code from captured image data, including: an N-digitization step of expressing the captured image data in N values based on color of each pixel; a color area group generating step of generating one or a plurality of color area group(s) based on distances among color areas in the image data expressed in the N values, the color area group being a set of a plurality of color areas; and a narrowing step of selecting a color area group matching the optical recognition code from the color area groups. N is a positive integer of 2 or greater.
(17) In the present invention, in the optical recognition cutting method of (16), N is 4, the number of colors used for marking the optical recognition code is 3, and the number of colors of a background portion other than the optical recognition code is 1.
(18) In the optical recognition cutting method of (16) of the invention, in the narrowing step, one or more color area group(s) determined to be an optical recognition code based on an arrangement state of the color area group is/are selected.
(19) The optical recognition code cutting method of (16) of the invention further includes an area enlarging step of enlarging each of color areas in the image data expressed in N values by a predetermined amount. In the color area group generating step, the color area group is generated based on the enlarged image data expressed in N values.
(20) In the optical recognition code cutting method of (16) of the invention, in the narrowing step, one or more color area group(s) determined to be an optical recognition code based on the number of the color areas included in the color area group is/are selected.
(21) In the optical recognition code cutting method of (16) of the invention, the narrowing step includes: a line connecting step of dividing the color areas included in the color area group by colors and connecting the color areas of the same color with a line; and an intersection points checking step of taking lines of any two colors from the lines of the colors connected in the line connecting step, checking whether the number of intersection points of the two lines is an even number or odd number, and excluding the color area group including the odd number of intersection points from the color area groups.
(22) In the optical recognition code cutting method of (21) of the invention, the line in the line connecting step is a set of line segments connecting gravity centers or centers of color areas of the same color.
(23) In the optical recognition code cutting method of (21) of the invention, the line in the line connecting step is a set of curved lines connecting gravity centers or centers of color areas of the same color.
(24) In the optical recognition code cutting method of (16) of the invention, in the narrowing step, whether arrangement of the color areas included in the color area group is according to an alignment rule of the optical recognition code or not is checked, and the color area group against the alignment rule is excluded from the color area groups.
(25) In the optical recognition code cutting method of (16) or (19) of the invention, in the color area group generating step, a color area group as a set of color areas is generated by collecting a plurality of color areas adjacent to each other in the image data expressed in the N values.
(26) In the optical recognition code cutting method of any one of (16) to (25), the optical recognition code is a 1.5D color bit code.
(27) The present invention also provides an optical recognition code recognizing method including: a step of cutting a color area group serving as an optical recognition code by using the optical recognition code cutting method of any one of (16) to (26); and a step of decoding the one or more cut color area groups according to a rule of the optical recognition code, and obtaining data.
(28) The present invention also provides an optical recognition code cutting apparatus for cutting an optical recognition code from captured image data, including: N-digitization means for expressing the captured image data in N values based on color of each pixel; color area group generating means for generating one or a plurality of color area group(s) based on distances among color areas in the image data expressed in the N values, the color area group being a set of a plurality of color areas; and narrowing means for selecting a color area group matching the optical recognition code from the color area groups. N is a positive integer of 2 or greater.
(29) In the optical recognition code cutting apparatus of (28) of the invention, the optical recognition code is a 1.5D color bit code.
(30) The present invention also provides an optical recognition code recognizing apparatus including: the optical recognition code cutting apparatus of (28); and means for decoding the one or more curt color area groups according to a rule of the optical recognition code, and obtaining data.
(31) The present invention also provides a program for making a computer operate as a cutting apparatus for cutting an optical recognition code from captured image data, including: an N-digitization procedure for expressing the captured image data in N values based on color of each pixel; a color area group generating procedure for generating one or a plurality of color area group(s) based on distances among color areas in the image data expressed in the N values, the color area group being a set of a plurality of color areas; and a narrowing procedure for selecting a color area group matching the optical recognition code from the color area groups. N is a positive integer of 2 or greater.
(32) In the program of (31) in the invention, the optical recognition code is a 1.5D color bit code.
(33) In the present invention, the program of (31) further makes the computer execute a procedure for decoding the one or more color area groups which is/are cut when the computer executes the program of claim 31 according to a rule of the optical recognition code, and obtaining data.
The means 3 achieved in view of the problem 3 will be described below.
(34) To achieve the objects, the present invention provides a check digit calculating, method of calculating a check digit for detecting an error in an optical recognition code, including: a converting step of converting the number of each digit in an optical recognition code to which a check digit is given into a predetermined index value; and a check digit calculating step of calculating a check digit based on the nonzero converted index value of each digit. In the converting step, by using storing means for storing at least one pair made of a first erroneous recognition number and a second erroneous recognition number being a pair of numbers which tend to be mutually erroneously read in the optical recognition code, the number of each digit is compared with each of the pairs each made of the first and second erroneous recognition numbers in the storing means. In the case where the number of the digit is the first erroneous recognition number in any of the pairs, the number is converted to “1” as the index number. In the case where the number of the digit is the second erroneous recognition number in any of the pairs, the number is converted to “−1” as the index number. In the case where the number of the digit is not the first or second erroneous recognition number, the number is converted to “0” as the index value.
(35) In the check digit calculating method of (34) of the invention, the check digit calculating step includes: a weight value calculating step of multiplying a positive index value of each of the converted digits with a weight and calculating sum thereof to obtain a first weight value, and multiplying a negative index value of each of the digits with a weight and calculating sum thereof to obtain a second weight value; and a remainder check digit calculating step of calculating a remainder of division between the first and second weight values based on the first and second weight values, and obtaining the remainder as a check digit.
(36) In the check digit calculating method of (35) of the invention, in the remainder check digit calculating step, a remainder in the case of dividing the first weight value with an integer part of an average value between the first and second weight values is calculated.
(37) In the check digit calculating method of (35) of the invention, in the remainder check digit calculating step, a group of numbers which is sequentially increased by a predetermined increase amount and forms an arithmetic progression is used as the remainder.
(38) In the check digit calculating method of (34) of the invention, a code symbol of the optical recognition code is made of a plurality of color areas, and pairs of the number in which read error occurs mutually due to fluctuations in size or area of the color areas are stored as a pair of the first and second erroneous recognition numbers in the storing means.
(39) In the check digit calculating method of any one of (34) to (38), the optical recognition code is a 1.5D color bit code in septimal notation using predetermined three colors, and the digits are any of values of 0 to 6.
(40) To achieve the object, the present invention also provides a check digit calculating apparatus for calculating a check digit to detect an error in an optical recognition code, including: converting means for converting the number of each digit in an optical recognition code to which a check digit is given to a predetermined index value; and check digit calculating means for calculating a check digit based on the nonzero converted index value of each digit. The converting means includes: storing means for storing at least one pair made of a first erroneous recognition number and a second erroneous recognition number being a pair of numbers which tend to be mutually erroneously read in the optical recognition code; and index converting means for comparing the number of each digit with each of the pairs each made of the first and second erroneous recognition numbers in the storing means, in the case where the number of the digit is the first erroneous recognition number in any of the pairs, converting the number to “1” as the index number, in the case where the number of the digit is the second erroneous recognition number in any of the pairs, converting the number to “−1” as the index number, and in the case where the number of the digit is not the first or second erroneous recognition number, converting the number to “0” as the index value.
(41) In the check digit calculating apparatus of (40) in the invention, the check digit calculating means includes: weight value calculating means of multiplying a positive index value of each of the converted digits with a weight and calculating sum thereof to obtain a first weight value, and multiplying a negative index value of each of the digits with a weight and calculating sum thereof to obtain a second weight value; and remainder check digit calculating means of calculating a remainder of division between the first and second weight values based on the first and second weight values, and obtaining the remainder as a check digit.
(42) In the check digit calculating apparatus of (41) of the invention, the remainder check digit calculating means calculates a remainder in the case of dividing the first weight value with an integer part of an average value between the first and second weight values.
(43) In the check digit calculating apparatus of (41) of the invention, the remainder check digit calculating means sequentially increases a group of numbers by a predetermined increase amount and uses the series of numbers forming an arithmetic progression as the remainder.
(44) In the check digit calculating apparatus of (40) of the invention, a code symbol of the optical recognition code is made of a plurality of color areas, and pairs of the numbers in which read error occurs mutually due to fluctuations in size or area of the color areas are stored as a pair of the first and second erroneous recognition numbers in the storing means.
(45) In the check digit calculating apparatus of any one of (40) to (44) of the invention, the optical recognition code is a 1.5D color bit code in septimal notation using predetermined three colors, and the digits are any of integers of 0 to 6.
(46) To solve the problems, the present invention also provides a program for making a computer operates as an apparatus for calculating a check digit to detect an error in an optical recognition code, including: a converting procedure for converting the number of each digit in an optical recognition code to which a check digit is given to a predetermined index value; and a check digit calculating procedure for calculating a check digit based on the nonzero converted index value of each digit. In the converting procedure, by using storing means for storing at least one pair made of a first erroneous recognition number and a second erroneous recognition number being a pair of numbers which tend to be mutually erroneously read in the optical recognition code, the number of each digit is compared with each of the pairs each made of the first and second erroneous recognition numbers in the storing means. In the case where the number of the digit is the first erroneous recognition number in any of the pairs, the number is converted to “1” as the index number. In the case where the number of the digit is the second erroneous recognition number in any of the pairs, the number is converted to “−1” as the index number. In the case where the number of the digit is not the first or second erroneous recognition number, the number is converted to “0” as the index value.
(47) In the program of (46) in the invention, the check digit calculating procedure includes: a weight value calculating procedure of multiplying a positive index value of each of the converted digits with a weight and calculating sum thereof to obtain a first weight value, and multiplying a negative index value of each of the digits with a weight and calculating sum thereof to obtain a second weight value; and a remainder check digit calculating procedure of calculating a remainder of division between the first and second weight values based on the first and second weight values, and obtaining the remainder as a check digit.
(48) In the program of (46) of the invention, a code symbol of the optical recognition code is made of a plurality of color areas, and pairs of the numbers in which read error occurs mutually due to fluctuations in size or area of the color areas are stored as a pair of the first and second erroneous recognition numbers in the storing means.
(49) In the program of any one of (46) to (48), the optical recognition code is a 1.5D color bit code in septimal notation using predetermined three colors, and the digits are any of values of 0 to 6.
According to the optical symbol of the present invention, since data is expressed according to the ON/OFF states of the elements of the configuration cells, a code system which does not exert an influence on reading of data even when the size of the configuration cell changes is obtained.
Since the size of a cell as a component of a symbol is not specified, flexibility of the size is high, and the symbol can be used also for an item whose surface is soft.
For example, a symbol can be directly printed on food such as soft meat by using food colorants. A symbol can be also directly printed on cloth and a soft item.
In a conventional optical barcode, a symbol is attached to an item by a process of affixing a seal or the like, and there is not a little possibility that data is falsified by replacing with another seal or the like. In contrast, according to the present invention, a symbol can be directly printed even on a soft item. Therefore, it is significantly difficult to replace the symbol with another symbol. As a result, according to the invention, data falsification can be prevented.
In the optical symbol and the code system using the optical symbol according to the invention, a symbol is constructed by linearly arranging a plurality of cells. As long as the symbol is linear, it may be straight or curved. Therefore, a symbol having high flexibility in design can be obtained.
Particularly, the present invention has the following characteristics.
As described above, in the present invention, a group of cells satisfying the conditions of a “marking pattern” of an optical recognition code such as the 1.5D color bit code in an entire image is extracted from the “background image” based on the characteristics. Therefore, a code can be cut without a “cutout mark” unlike a conventional two-dimensional barcode.
Therefore, a process for finding a cutout mark does not exist. By processing an entire image by a predetermined method, a pattern corresponding to a “marking pattern” is distinguished.
It is therefore unnecessary to perform complicated image recognition for cutout like in the conventional two-dimensional barcode. A simple imaging process and image recognizing process can be achieved and a higher processing speed is expected.
Since an optical recognition code is recognized by a pattern of an entire captured, an effect such that a precise image and a complicated process for finding a cutout mark and performing positioning are unnecessary is produced. As a result, the process load of image capture is reduced, and the complicated image process operation conventionally required can be simplified. It is considered that, as a result of simplification, the operability improves.
At the same time, software of a reading device and an imaging process and an electric circuit or the like in which software is installed can use a simple configuration. Consequently, as compared with the conventional technique, lower price and smaller size can be expected.
Since the precision of marking itself may be low, it is considered that a simpler marking method and apparatus can be used.
According to the present invention, when a plurality of optical recognition codes (for example, 1.5D color bit codes) are included in the same image, without taking special means, all of optical recognition codes (for example, 1.5D color bit codes) can be captured. Therefore, even in the case of using a plurality of optical recognition codes, an optical recognition doe can be recognized by a simple reading work.
Further, as described above, according to the invention, a check digit which can concentratedly secure a part of a value which is easily erroneously read as another value in an optical recognition code can be realized.
As a result, an error in the optical recognition code can be detected efficiently.
A first preferred embodiment of the present invention will be described hereinbelow with reference to the drawings.
In the embodiment, a code using an optical symbol having a form in which cells are arranged linearly is proposed. The optical symbol is a symbol in a plane shape and is to be attached to various items.
An optical symbol of the embodiment is obtained by arranging a plurality of cells. A cell is constructed by a plurality of elements.
In an example shown in
The element 1012R is an area which can be set in two states: a state where red (R) is given, and a state where red (R) is not given. The state where red (R) is not given includes two cases: the case where the ground color of an item appears as it is, and the case where black (K) is given.
The state where red (R) is given to the element 1012R is referred to as “ON” or the “ON state”. The state where red (R) is not given is referred to as “OFF” or the “OFF state”.
The element 1012G is an area which can be set in two states: a state where green (G) is given, and a state where green (G) is not given. The state where green (G) is not given includes two cases: the case where the ground color of an item appears as it is, and the case where black (K) is given.
The state where green (G) is given to the element 1012G is referred to as “ON” or the “ON state”. The state where green (G) is not given is referred to as “OFF” or the “OFF state”.
The element 1012B is an area which can be set in two states: a state where blue (B) is given, and a state where blue (B) is not given. The state where blue (B) is not given includes two cases: the case where the ground color of an item appears as it is, and the case where black (K) is given.
The state where blue (B) is given to the element 1012B is referred to as “ON” or the “ON state”. The state where blue (B) is not given is referred to as “OFF” or the “OFF state”.
A single optical symbol 1020 (hereinbelow, also simply referred to as symbol 1020) is constructed by arranging a plurality of such cells 1010. Three kinds of cells exist in one optical symbol.
End-point cells 1030 are cells positioned at a start point and an end point of a sequence. Therefore, one end-point cell exists at each of the start and end points, that is, total two end-point cells 1030 exist in one optical symbol 1020. The end-point cell 1030 indicative of a start point will be referred to as a start cell. The end-point cell 1030 indicative of an end point will be referred to as an end cell.
A neighboring cell 1032 is one or more cells neighboring the end-point cell 1030. The number of the neighboring cells 1032 and the state of the elements may be in various modes. In the embodiment, an example of using the neighboring cells 1032 for identifying the start and end points and other examples will be described in detail later.
A configuration cell 1034 is a cell indicative of data. There are various methods of expressing data. In the embodiment, an example of expressing data of one digit by three cells will be described in detail later.
The optical symbol 1020 of the embodiment is constructed by arranging the cells 1012 linearly. The linear shape may be straight or curved. As long as a neighboring cell 1012 can be traced, any line may be employed.
As described above, data is expressed in septimal notation in the embodiment. The values of the digits of the septimal notation, that is, the components 0, 1, 2, 3, 4, 5, and 6 are determined by the formats shown in
Specifically, the value of the cell 1010 is determined by combination of the elements of the cell 1010, an immediately preceding cell 1010, and a cell 1010 preceding to the immediately preceding cell (referred to as two-cell-preceding cell). In the embodiment, a cell having a value (the cell 1010) exists every other cell.
As shown in
Further, in the embodiment, as shown in
In the case of permitting a change in the state of two or more elements 1012, at the time of tracing the state of the elements 1012 of the cell 1010, an unexpected intermediate state may be erroneously read due to the influence of the reading timing. In particular, in the embodiment, since the width of the cell 1012 is not specified, the possibility of read error is high.
In the embodiment, since the horizontal width of the cell 1012 is not specified, the value of the symbol 1010 can be read even from a flexible item to which the symbol 1020 is attached. Therefore, in the embodiment, the horizontal width of the cell 1012 is not specified and a change in color is regarded as detection of an adjacent cell. From this viewpoint, in the embodiment, the state of only one element 1012 in the neighboring cell 1010 changes. It is understood from
Further, in the embodiment, the cell whose elements are OFF, that is, whose elements are all black is permitted to be used only as the end-point cells 1030. A cell whose elements are all OFF is not used as the other neighboring cells 1032 and the configuration cell 1034. If a cell whose elements are all OFF is used, continuity of the cells 1010 is lost, and unity as one symbol 1020 lacks.
The start point (at the left end) is expressed by a cell whose three elements are OFF and a neighboring cell whose R is ON. Specifically, the start point is expressed by combination of an end-point cell 1030a whose three elements 1012 are OFF and a neighboring cell 1032a in which only 1012R is ON (see
The end point (at the right end) is expressed by a cell whose three elements are OFF and a neighboring cell in which G and B are ON. Specifically, the end point is expressed by combination of an end-point cell 1030b whose three elements 1012 are OFF and a neighboring cell 1032b in which 1012G and 1012R are ON (see
In the embodiment as described above, the start and end points can be identified by the details of the end-point cell 1030 and the neighboring cell 1032.
In the start part at the left end, there are three ways to start. By using the ways, plus, minus, parity, or the like can be distinguished from each other without adding a new cell 1010.
In the above-described example,
(1) “end-point cell 1030”+“element 1012 of R is in the ON state” is used as indication of the start point. “End-point cell 1030”+“elements 1012 of B and G are in the ON state” is used as indication of the end point.
(2) Similarly, “end-point cell 1030”+“element 1012 of G is in the ON state” is used as indication of the start point. “End-point cell 1030”+“elements 1012 of B and R are in the ON state” is used as indication of the end point.
(3) It is also preferable that “end-point cell 1030”+“element 1012 of B is in the ON state” is used as indication of the start point. “End-point cell 1030”+“elements 1012 of G and R are in the ON state” is used as indication of the end point.
It is preferable to properly select a method from the above-described three methods according to setting of a parity and the like.
By adding another neighboring cell 1032, a check digit, control of the number of digits, and the like can be realized.
A preferable flow of the processes of generating the optical symbol 1020 and attaching it to an item is as follows.
(1) The optical symbol 1020 is generated based on data and based on a code system employed.
(2) The generated optical symbol 1020 is attached to an item. The attaching operation is preferably the following processes (a) to (c).
(a) The optical symbol 1020 is printed to an item. It is directly printed to an item, a package or container of an item, or the like by using a predetermined printer, a printing apparatus, or the like. As described above, since the optical symbol 1020 of the embodiment has high resistance to distortion, color degradation, and the like, even if an item is deformed or color degradation or fading occurs due to a change with time, high reading precision is realized. For a similar reason, it is also preferable to print the optical symbol 1020 of the embodiment directly to food or the like. When the optical symbol 1020 is directly printed, the possibility of re-attachment or the like of the optical symbol 1020 is low, an illegal act or the like can be prevented, and very preferable characteristics from the viewpoint of assuring safety of food can be provided.
(b) The optical symbol 1020 is directly embroidered to an item with a colored thread. In particular, in the embodiment, the cells 1010 are arranged so that the elements of the same kind are adjacent to each other. Specifically, the cells 1010 are arranged so that the elements 1012R of R are adjacent to each other, the elements 1012G of G are adjacent to each other, and the elements 1012B of B are adjacent to each other. Therefore, by doing embroidery with thread of R (red) based on the ON/OFF state of the element 1012R of R, the state of the element 1012R of R can be given to an item. Similarly, by doing embroidery with thread of G (green) based on the ON/OFF state of the element of G, the state of the element 1012G of G can be given to an item. The embroidery is performed similarly with respect to B (blue).
(c) It is also possible to print the generated optical symbol 1020 onto an (adhesive) seal and adhere the seal to an item.
An operation of reading the optical symbol 1020 and restoring the original data is called decoding. Although there are various procedures for decoding, a typical preferable example is as follows.
(1) An image of a predetermined item including the optical symbol 1010 is captured by a CCD camera or the like and taken as image data.
The CCD camera is a typical example of a sensor called an area sensor. Image data may be captured by another area sensor.
(2) From the image data, the following is searched.
(a) the end-point cells 1030a and 1030b,
(b) the neighboring cell 1032a in which only the R element 1012R is in the ON state, neighboring with the end-point cell 1030a, and
(c) the neighboring cell 1032b in which only the B element 1012B and the G element 1012G are in the ON state, neighboring with the end-point cell 1030b
The start point is detected by finding the end-point cell 1030a and the neighboring cell 1032a which neighbors the end-point cell 1030a and in which only the R element 1012 is ON. The end point is detected by finding the end-point cell 1030b and the neighboring cell 1032b which neighbors the end-point cell 1030b and in which only the B element and the G element are ON.
(3) The continuity of the configuration cells 1034 connecting the neighboring cells 1032a and 1032b is traced and specified.
In the trace, a state change in the elements 1012 in the configuration cells 1034 is always observed. When a change occurs in the state of any of the elements 1012, shift to a new configuration cell 1034 crossing the border of the configuration cell 1034 is determined.
As described above, in the embodiment, the position and range of the cell 1012 are not determined by the size of the cell 1012, but shift to a new cell 1012 is determined by a change in the state, that is, a change in color. As a result, even if distortion or the like occurs in the surface of an item and a change occurs in the size of the cell 1012, reading precision can be maintained high.
(4) A white area in an image is detected as excessive light by total reflection, and it is determined that the area part is not the optical symbol 1010.
(5) An image is averaged every predetermined area, and the influence of components such as noise, fine shadow, dirt, and the like is eliminated. In short, noise elimination by filtering is performed. Various conventionally known filtering means such as a median filter can be used.
(6) It is determined that a part other than linear continuous parts in which the configuration cells 1034 are continued (the surface part of the item other than the configuration cells 1034) is not the optical symbol 1020 according to the situations such as shade and the ground color.
(7) It is also preferable to use the difference of images obtained while changing the way of applying illumination and the like.
(8) The division (border) of the cells 1010 is detected from the ON/OFF states of the element 1012, the values of the cells are decoded according to the decoding specification to perform encoding. After that, the data is checked. In the patent, decoding will be called encoding.
Further, it is characteristic in the embodiment that calibration of a color at the time of reading is performed by using three colors appearing in the neighboring cell 1032. By performing the calibration, reliability can be further improved.
In the embodiment, the colors of the three elements 1012 correspond to R, G, and B. It is also preferable that the colors correspond to three colors of Y, M, and C according to the conditions of a reader, an illumination, a tag, and the like
By such a method, decoding of the optical symbol 1020 is executed.
As descried above, the code system proposed in the embodiment has the following characteristics.
As colors used, only colors pure to a reader of a three-primary-color-system can be used. The system has a wide tolerance to color degradation and variations in illumination, printing, and the like.
Since the concept is to follow only changes in the elements 1012 constructing the cell 1010, even when the range of the cell 1010 fluctuates to some degree, the reading characteristic is not hindered.
For the same reason, even when a cell is narrow and bent, the reading characteristic is not hindered.
Since colors are given to the elements 1012 constructing the cell 1010, a symbol 1020 can be attached by using a work of intermittently giving colors (stitching in this case) on the same line of the same color like stitching of a sawing machine.
Since data can be expressed by combination of colors, information density is high.
Basically, data is constructed by color detection. Consequently, the code system has the characteristic that resistance to deformation is higher than that of a method of using the same color for all of the elements 1012 in the code and recording data based on the positional relations of the elements 1012 such as up, middle, and down.
Although an example in which three elements 1012 are included in one cell 1010 has been described, four, five, or more elements 1012 may be included. In this case, obviously, four, five, or more colors are used. Two elements 1012 may be included in one cell 1010.
With reference to the drawings, a second preferred embodiment of the present invention will be described in detail.
First, outline of the 1.5D color bit code developed by the inventors of the present invention will now be described. The 1.5D color bit code described here uses, for example, three colors as marking colors. The three colors are, for example, R (red), G (green), and B (blue) (or C, M, and Y). The quiet color in the quiet zone is, for example, W (white).
In the 1.5D color bit code, three lines of different colors are arranged in parallel at almost equal intervals.
Each of the three lines is interrupted in some places, and the interrupted parts have a color (that is, W) corresponding to the quiet zone. The interrupted parts in the lines including both ends are regarded as color change parts which will be referred to as the “ON/OFF” parts. The interruption means absence of the marking color (R, G, B, or the like) and appearance of color (W) other than the marking color.
Data is expressed by the position relation in the “ON/OFF” parts in the three lines.
All of the three colors are not interrupted in the intermediate portion other than the both ends.
The sequence of the three colors and the rule of the positional relation of “ON/OFF” are specified by data or a check method.
The range constructed by one color sandwiched in the interrupted part (the part which is not colored) in each line will be referred to as a “cell”, and a part sandwiched by cells in the line will be referred to as an “occultation part”. Therefore, each line is constructed by the “cells” and the “occultation parts”. A “marking pattern” constructing one 1.5D color bit code is constructed by predetermined number of cells. The conclusion is mathematically derived from the pattern definition of the 1.5D color bit code (the details will not be described).
The “marking pattern” is surrounded by a quiet zone of the determined color (W) more than a predetermined range.
The outline of the 1.5D color bit code has been described above. The 1.5D color bit code is generated based on such conditions.
(a) First, an image including the 1.5D color bit code is captured by image pickup means such as an area sensor.
(b) Next, the image is divided into areas of a plurality of colors based on definition. In the embodiment, an example of dividing the image into blue, red, green, and white will be described. The embodiment will be described on assumption that the 1.5D color bit code is a line of “cells” of blue, red, and green, and the number of “cells” is eight.
An “original image” originally captured is constructed by various colors including the background, and the patterns are also various. A “color quantization process” of dividing the colors into blue, red, green, and achromatic color in the color space, and applying the color of each of pixels to any of areas is performed.
The colors (blue, red, and green) constructing the 1.5D color bit code are colors defined as a marking pattern and are in a “marking color range” as a predetermined range which is set in a color space in consideration of variations in illumination, coloration, color degradation, and the like.
The achromatic color is defined as a color out of the “marking color range” and includes the color of a quiet zone.
At the time of performing the “color quantization process” on the “original image” as described above, entry of noise components cannot be usually avoided. Consequently, a common noise eliminating process such as “noise eliminating process” of adjusting an abnormal change in color in a very small region corresponding to noise to the color in the periphery, averaging colors, or the like is performed in advance.
As a result of performing the color quantization process as described above, an image as shown in
In
After the “color quantization process” is performed, predetermined width is added to the area of each of the colors (referred to as original color area 2010) to perform the “color area enlargement”. The process is a sort of “widening” process of adding pixels of a few dots to the original color area 2010, and is a process conventionally known in image processing such as thickening of a line segment.
By collecting the color areas 2020 which are in contact with each other, a “color area group” is generated. As a result, the entire image is divided into some “color area groups”.
By the process, the “marking image” as an object to be recognized becomes part of at least one “color area group”. A check to see whether predetermined areas are in contact with each other, that is, neighboring each other or not is widely executed as a basic image process. It is easy for a person skilled in the art to make a computer perform such a process.
As described above in the definition of the 1.5D color bit code, “cell lines of colors in a marking pattern are arranged at almost equal intervals”.
To group areas of the 1.5D color bit codes, a predetermined while area (quiet zone) is necessary in the periphery. This point is described above in the definition of the 1.5D color bit code that “the marking pattern is surrounded by a quiet zone of the determined color more than a predetermined range”.
In the example shown in
As a numeric condition of the “color areas” forming a color area group, there is a rule for the 1.5D color bit code that “the numbers of “color areas” forming codes are the same when the numbers of digits are the same”. For convenience, the rule will be referred to as rule 1.
Using the rule 1, the code candidates can be further narrowed. Specifically, only the candidates of the correct number of areas are left and the other candidates are excluded.
It will be proved that the rule 1 is satisfied.
First, terms will be described. Start of a red band will be referred to as R-ON, and start of occultation of the red band will be referred to as R-OFF. Similarly, start of a blue band will be referred to as B-ON, and start of occultation of the blue band will be referred to as B-OFF. Start of a green band will be referred to as G-ON, and occultation of the green band will be referred to as G-OFF.
1step: G-OFF
2step: B-OFF
3step: G-ON
4step: B-ON
5step: R-OFF
6step: B-OFF
7step: B-ON
8step: B-OFF
9step: R-ON
10step: R-OFF
11step: R-ON
12step: R-OFF
13step: G-OFF
14step: R-ON
15step: R-OFF
16step: G-ON
17step: B-OFF
18step: B-ON
19step: G-OFF
20step: G-ON
21step: B-OFF
22step: R-ON
23step: B-ON
After that, the end mark follows. The end mark is made of the following two cells.
Since the number of digits is determined by the number of steps, description will be given on precondition that the number of digits used and the number of steps are known as specifications.
The mark shape of each of the start end and the terminating end is determined (in the example to be described, the specification that three lines of R, G, and B appear just before 1step and just after 23step is employed).
Since the appearing way of R, G, and B is the same at the start and terminating ends, the difference between the number of ON times and the number of OFF times of each color is determined (in the example, the number of ON times and the number of OFF times are the same).
From the left, a new color area of each color starts at ON and the ground color appears at OFF.
That is, the number of steps (that is, the number of digits) is determined, and the difference between the number of ON times and the number of OFF times is determined. Since the number of color areas is given by the number of ON times, the number of color areas is obviously constant.
(b) Narrowing by Alignment Rule of 1.5D Color Bit Codes
There is rule 2 that “definition of the 1.5D color bit code “each of the three colors is turned ON/OFF, and all of the three colors are not in the OFF state””. The rule is, strictly, definition of the 1.5D color bit code.
(c) Test of Parallel Arrangement of Color Bands
The 1.5D color bit code used in the embodiment serves as an optical recognition code in which a plurality of color bands are arranged in parallel, and the colors appear (ON state), and are occluded (OFF state).
Basically, (the color areas of) the same colors forming a group are supposed to be arranged in parallel.
In the step, the parallel arrangement is tested.
Specifically, the following condition is tested.
The color areas are connected to each other with lines (like R-R-R, G-G-G). When arbitrary two lines (like R and B, B and G, and G and R) are selected from the three lines, whether the number of intersection points of the selected two lines is even number (including 0) or not, whether the number of intersection points is even number (including 0) or odd number is tested.
The “line” connects the gravity centers or centers of the color areas. The “line” may be a straight line (line segment) or curve. In the case of a curve, preferably, a smooth curve connecting the centers or the like of the color areas is preferable. For example, it is suitable to use a spline curve, a Bezier curve, or the like.
In the step, codes which do not satisfy the condition are eliminated, and are narrowed as candidates of the code symbol. That is, a code having odd number of intersection points is eliminated from the candidates of the code.
The condition in the step “e” comes from the definition of the 1.5D color bit code that “three lines of different colors which can be regarded as one line are arranged in parallel at almost equal intervals”.
By checking the rules; (a) the number of color areas, (b) the alignment rule of the 1.5D color bit codes, and (c) whether the parallel arrangement of color bands is satisfied or not, the candidates of codes can be further narrowed.
Finally, only the color area group 2030b remains and is recognized as the 1.5D color bit code.
By the series of processes, a color area group estimated as the 1.5D color bit code from the color area groups is decoded to obtain original data. As described above, an image is captured, one or more color area groups estimated as code symbols are obtained from the captured image, the decoding process is executed on the obtained one or more color area groups, and original data is output. The series of processes will be referred to as “recognizing process”.
Decoding is computation opposite to encoding of data and is performed according to law of signs.
The above-described series of processes is realized by making a computer execute a predetermined program. In this case, the computer servers as a 1.5D color bit code cutting apparatus. When the computer performs the decoding process on a cut color area group and outputs original data, the computer can be referred to as a 1.5D color bit code recognizing apparatus.
It is preferable to construct the apparatus by image pickup means such as a CCD camera, a video camera, or the like, a computer, and the like. Preferably, the processes and the operations described above are realized by a program of the computer.
Most of the processes are conventionally known processes such as a process of checking the state of arrangement of areas, enlarging process, and the like. It is easy for a person skilled in the art to generate a program for performing the operations on a computer.
Preferably, such a program is stored in storing means such as a hard disk on a computer or the like and is also preferable to store in a storing medium such as a CD ROM, DVD ROM, or the like. It is also preferable to employ a form of pre-storing the program on a server and using the program from the server by a client computer.
As the decoding process, the conventional decoding process can be used as it is.
Although the 1.5D color bit code has been mainly described above as an example, the invention may be applied to an optical recognition code made of a plurality of color areas.
For example, it is considered that the generation of candidates by arrangement of color areas can be widely applied to the optical recognition codes. It is also considered that enlargement of an area may be applied to an optical recognition code made of a plurality of color areas.
A preferred third embodiment of the present invention will be described below with reference to the drawings.
First, outline of the 1.5D color bit code developed by the inventors of the present invention will be described. The 1.5D color bit code described here uses, for example, three colors as marking colors. The three colors are, for example, R (red), G (green), and B (blue) (or C, M, and Y). The quiet color in the quiet zone is, for example, K (black).
In the 1.5D color bit code, three lines of different colors are arranged in parallel at almost equal intervals. Each of the three lines is interrupted in some places, and the interrupted parts have a color (that is, K (black)) corresponding to the quiet zone. The interrupted parts in the lines including both ends are regarded as color change parts which will be referred to as the “ON/OFF” parts. The interruption means absence of the marking color (R, G, B, or the like) and appearance of color (K (black)) other than the marking colors.
In the 1.5D color bit code, data is expressed by the position relation in the “ON/OFF” parts in the lines of three colors. All of the three colors are not interrupted in the intermediate portion other than the both ends. The sequence of the three colors and the rule of the positional relation of “ON/OFF” are specified by data or a check method. That is, error detection, error correction, and the like are determined separately according to a use.
The “marking pattern” is surrounded by a quiet zone of a determined color (for example, K (black)) more than a predetermined range.
The ON/OFF unit of a color is referred to as a cell. One cell includes areas (referred to as elements) of three colors. By arranging a plurality of cells in a line so that elements of the same color are adjacent to each other, a 1.5D color bit code is obtained. Since the elements of the same color are adjacent to each other, a band-shaped area of the same color is constructed. The band-shaped area corresponds to “three lines of different colors” described above.
For example, in a cell, the element R is turned on, the element B is turned off, and the element G is turned on. In the neighboring cell, the element R is turned on, the element B is turned off, and the element G is turned off. In such a manner, the colors are turned on/off.
In neighboring cells, only one element (that is, only one color) is different. By the change, the border between the cells can be detected by a scan.
The outline of the 1.5D color bit code has been described above. The 1.5D color bit code is generated under the conditions as described above.
In the example of
As shown in
Specifically, each of numerical values 0 to 6 is expressed by a combination of 2-color ON (start)—3-color ON—2-color ON (end) or a combination of 2-color ON—1-color ON—2-color ON. In the following, it is assumed that all of such arrangements are in order from the left end (start) to the right end (end). The left end, the right end, the like will not be described.
As shown in
In the case of expressing one numerical value (for example, “3”), there are three ways to express it by the respective groups.
The coding specification is that, by the combination of two colors at the right end, a group of expressing the next numerical value is selected. In other words, combination of two colors at the right end instructs the following group.
By such specification, any of the numerical values 0 to 6 can be expressed by ON/OFF of three colors and, simultaneously, ON/OFF of only one color.
In
Below the “numbers to be expressed”, the numbers “1, 2, 1, 1, 2, 0, 0, 1, 1, 1, 1, 0” of the groups of the digit numbers are shown. The group numbers are the numbers of groups shown in
In the specification, unless otherwise stated, the number is decimal number, or the numbers (0 to 6) which are the same in decimal number and septimal number.
For example, in
The number to be expressed is the second number “4” of the numbers “0, 4, 2, 1, 1, 3, 0, 2, 2, 6, 4, 6” to be expressed. The combination corresponding to “4” is selected from the group 2 (
Similarly, the combination is selected for each of the digits. The result of selection is shown in the middle part of
Therefore, at the time of forming a final code symbol, cells of a combination of the same color are not displayed. Further, to form a final code symbol, “start” and “end” of the code symbol have to be instructed. By attaching a start mark 3010 at the left end and attaching an end mark 3012 at the right end as shown in
The final code symbol constructed as described above is shown in the lower part of
If a color is interrupted or becomes long in such a case, usually, it appears as a rule violation of the code such as a change in the number of cells. Therefore, usually, occurrence of an error can be detected.
However, in the case where the position of a cell end changes for some reason with respect to “0” and “1”, and “4” and “5” in each of the groups of the embodiment, there is the possibility that the values are interchanged.
For example, when the color band of R (red) becomes long in “0” of
For example, when the color band of B (blue) becomes long in “4” of
In the embodiment, paying attention to such a behavior unique to the 1.5D color bit code, a method of tightening security on such a part is proposed.
To provide security as efficiently as possible, a method of realizing security with the smallest number of check digits is proposed.
A method of providing security of the invention will be described below.
As already described, in the embodiment, numbers in patterns, which tend to change, are limited as much as possible. In the embodiment, there are three patterns (groups). Combinations of numbers in which an error tends to occur can be limited to “0 and 1” and “4 and 5” in any of the groups. A method of calculating check digits in the embodiment will be specifically described below.
First, for example, the case of a septimal number in 10 digits will be considered. The number is expressed as follows. 0000000000 to 6666666666 (in septimal notation)
The case where only one of the numbers “0 and 1” and “4 and 5” which tend to change is included in the number of 10 digits (for example, 2222212222, 3232066232, or the like) will be examined.
In this case, generally, only one pattern (to be changed) which tends to be changed exists. 2222212222 in the above example tends to change to 2222202222.
3232066232 tends to change to 3232166232.
It is therefore sufficient to add, as check digits, a value which can take two kinds of values (for example, 0 and 1).
As it is sufficient to take two kinds of values, typically, it is preferable to add, for example, a parity (parity check) as a CD. When a parity is calculated and is different from the CD, occurrence of a change (read error) is determined.
For simplicity of explanation, a change which easily occurs in the check digit itself is not considered below.
In the embodiment, the example of providing security concentratedly to “0 and 1” and “4 and 5” which tend to change will be described, and a change in other numbers is not considered. As already described above, the possibility that any of the other numbers is erroneously read as another number due to dirt in printing or the like is low. If there is a case that dirt or deformation occurs in a code symbol to the degree that the number is erroneously read as another number, it is against a coding rule such as mismatch of the number of cells.
Therefore, in the embodiment, only the case where the position of an edge of a color changes without being against the coding rule is considered. An main object is to obtain a check digit capable of detecting such a case efficiently.
In the case where all of 10 digits are numbers “0, 1” and “4, 5” which attend to change, a check digit of 0041010044 or the like is calculated by an algorithm described below.
0 and 4 in the digits (septimal notation) is replaced with −1 and 1 and 5 are replaced with 1. The other numbers are replaced with 0. After that, the digits are re-arranged so that 0 is right-aligned and 1 and −1 are left-aligned.
Such “1”, “−1”, and “0” will be referred to as index values.
As a result of the replacement, “41010044” in the above example becomes “−1, −1, −1, 1, −1, 1, −1, −1, −1, −1”. Since there is no 0 but all of the digits are either 1 or −1, there is no work of right-alignment and left-alignment.
The values of the digits “−1, −1, −1, 1, −1, 1, −1, −1, −1, −1” are replaced with a, b, c, d, e, f, g, h, i, and j. That is,
a=−1
b=−1
c=−1
e=−1
f=−1
g=−1
h=−1
i=−1
j=−1
Next, from the right digits (that is, from “j”) as the lower-order digit, the sum of the value and its absolute value is multiplied with each of weights 1, 3, 5, . . . , and the total sum of the resultants is calculated. That is, a weighted value is calculated. This will be referred to as a first weighted value k1.
Similarly, from the right digits (that is, from “j”) as the lower-order digit, the sum of the absolute value of the value and the value is multiplied with each of weights 1, 3, 5, . . . , and the total sum of the resultants is calculated. This will be referred to as a second weighted value k2.
Specifically, k1 and k2 are described as follows.
k1=((|j|+j)*1+(|i|+i)*3+(|h|+h)*5+(|g|+g)*7+(|f|+f)*9+(|e|+e)*11+(|d|+d)*13+(|c|+c)*15+(|b|+b)*17)+(|a|+a)*19)/2
k2=((|j|−j)*1+(|i|−i)*3+(|h|−h)*5+(|g|−g)*7+(|f|−f)*9+(|e|−e)*11+(|d|−d)*13+(|c|−c)*15+(|b|−b)*17)+(|a|+a)*19)/2
In the examples, since all of the index values are nonzero, all of the digits are weighted. In the case where there is a digit whose index value is zero, 1, 3, 5, . . . are applied in order from the low order while skipping the digit. Such an example will be described later.
In the embodiment, a series of numbers (group) which sequentially increase like arithmetic progression are used as weights. As a result, occurrence of erroneous reading in a part where erroneous reading tends to occur can be efficiently detected.
Next, a check digit (CD) is calculated as follows from the first and second weighted values k1 and k2 obtained as described above.
CD=mod(k1, int((k1+k2)/2)+16−the number of nonzero digits*2)
where int(t) is an integer part of t, and the number of nonzero digits is the number of digits whose index value is nonzero.
As a result of calculation, the value of CD is 0 to 31 (in decimal number), and the check digit can be realized by using relatively small kinds of numbers for the reason that only a part where erroneous reading often occurs is detected.
The case of the above-described numerals 0041010044 will be actually calculated. Since a, b, c, d, e, f, g, h, i, and j are already obtained, weighted values k1 and k2 will be calculated.
Next, CD will be calculated from the above.
From the calculation, CD=22.
In the case of the method in the embodiment, it could be confirmed by simulation of the inventors of the present invention that the minimum error distance is 4 in any of the CD, in the numerical values having the same CD value. Even when an error that 0 is read as 1 occurs in three places at the same time, the CD values are different from each other, and occurrence of an error can be detected.
Next, a similar algorithm will be calculated with respect to the case where six digits out of 10 digits are 0, 1 and 4, which tend to change.
For example, 0042041553 (in the septimal notation) is used.
(1) First, 0 and 4 in the digits (in the septimal notation) are replaced with −1, and 1 and 5 are replaced with 1.
The other numbers are replaced with 0, 0 is left-aligned, and 1 and −1 are right-aligned as follows
Therefore, the following is obtained.
a=0
b=0
c=−1
d=−1
e=−1
f=−1
g=−1
h=1
i=1
The embodiment is characterized in that the index value of each of the numbers at which read error does not often occur is converted to 0. As a result, the values at which read error does not often occur are not related to calculation of a check digit. Security can be concentrated on values which can be erroneously read as other numerical values.
(2) Next, from the right digits, the digits are multiplied with 1, 3, 5, . . . , and the weighted values k1 and k2 are calculated.
(3) A check digit (CD) is calculated from k1 and k2.
In such a manner, 9 is obtained as the CD. In this case as well, it could be confirmed that the minimum error distance is 4 in any of the CD, in the numerical values having the same CD value.
An example of the values of 10 digits (in the septimal notation) has been described. For other digits, a check digit (CD) can be also generated by a similar algorithm. For example, in the case of 12 digits (in septimal notation), CD values of 64 CDs from 0 to 63 can be used.
The above-described series of processes is realized by making a computer execute a predetermined program. In this case, the computer servers as a 1.5D color bit code check digit calculating apparatus. When the computer performs the decoding process on a cut color area group and outputs original data, the computer can be referred to as a 1.5D color bit code recognizing apparatus.
As a result, means for executing the operation steps is realized by the computer. The means in the scope of claims is realized by making a computer execute a program. The processing operations in steps in the scope of claims are performed by making a computer execute a program.
Such an apparatus calculates a predetermined check digit for data to be expressed. In the case where data to be expressed is recorded on a recording medium, it may be received via the recording medium or it is also preferable to receive it via a network. It is preferable to output the calculated check digit as it is. It is suitable to construct a final 1.5D color bit code using the check digit and supply the 1.5D color bit code to the outside.
That is, preferably, the check digit calculating method and apparatus in the embodiment are independently used. Since those are techniques used at the scene of encoding, it is also preferable that the method and apparatus are housed (the program is installed) in the same apparatus as an encoding apparatus.
Preferably, such a program is stored in storing means such as a hard disk on a computer or the like and is also preferable to be stored in a storing medium such as a CD ROM, DVD ROM, or the like. It is also preferable to employ a form of pre-storing the program on a server and using the program from the server by a client computer.
As the decoding process, the conventional decoding process can be used as it is.
Although the 1.5D color bit code has been mainly described above as an example, the invention may be applied to an optical recognition code made of a plurality of color areas.
Particularly, in the case where a predetermined value indicated by a code easily changes to another value due to deviation of the periphery of a printing part of a color, it is also preferable to concentratedly secure the predetermined value. The present invention is also preferable for such an use.
In the above-described example, when a change occurs in the codes of “0 and 1” and “4 and 5”, security can be provided concentratedly to “0 and 1” and “4 and 5”. The existence of a read error can be determined more accurately.
In the case of employing another coding, obviously, numbers at which an error tends to occur may be other numbers. Since it is considered that the part (number) to which security is to be provided concentratedly varies generally, a place to which security is concentratedly provided has to be determined according to each of codings.
The abstract of the specification relates mainly to the first embodiment. Abstracts of the second and third embodiments are as follows.
The present invention proposes the cutting method utilizing the 1.5D color bit code devised by the inventors of the present invention, resistive to distortion, blurring, variations, and the like of the dimension and shape, and simpler than the conventional two-dimensional barcode.
An image including a 1.5D color bit code is captured by image capturing means such as an area sensor. The image is divided into blue, red, green, and an achromatic color to generate color areas. By combining the color areas 20 which are in contact with each other, a “color area group” is generated. As a result, an entire image is divided into some “color area groups”. Depending on whether the number of color areas included in the color area group is correct or not, candidates are narrowed from the color area groups. The candidates are further narrowed according to, as a criterion, whether the number of intersection points of “lines” connecting the color areas of the same color included in the color area group is an even number or an odd number. The candidates are further narrowed by detecting whether the candidates match the arrangement rule of the 1.5D color bit codes or not, thereby obtaining a final object to be recognized. By decoding the final object, original data is obtained.
The present invention provides the method of providing security which prevents erroneous reading on a part in which erroneous reading often occurs (part of a specific value) and the method of calculating a check digit realizing the security providing method while utilizing the advantages of the 1.5D color bit code devised by the inventors of the present invention.
The method includes a converting step for converting the value of each of digits of a number to be expressed by a 1.5D color bit code to a predetermined index value and a check digit calculating step of calculating a check digit based on a nonzero index value of the converted digit. In the converting step, to a pair of a first number of erroneous recognition and a second number of erroneous recognition, “1” is given as an index value to the first value, and “−1” is given as an index value to the second number. To the other numbers, “0” is given as an index value. In such a manner, security can be concentratedly provided to a part where an read error tends to occur.
Number | Date | Country | Kind |
---|---|---|---|
2006-196705 | Jul 2006 | JP | national |
2007-164286 | Jun 2007 | JP | national |
2007-186573 | Jul 2007 | JP | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/JP2007/064232 | 7/19/2007 | WO | 00 | 12/30/2008 |