Quick Response (QR) codes are well-known matrix or two-dimensional barcodes used in various applications from product tracking to marketing. QR codes typically include an arrangement of black squares or dots arranged in a grid, and which can be read or imaged by a device and processed to extract data.
Known QR code technology has various technical problems including distortion and size (e.g., small images are unrecognizable). QR codes (and two-dimensional bar codes in general) generally rely on high-contrast shapes and patterns of particular proportions (e.g., black and white bars or squares). This is a reasonable approach that was designed for use with limited imaging devices such as cameras included with mobile phone devices. For example, detection of such codes requires little power for computing and can work on many relatively low cost devices. However, such codes are generally not very tolerant to variations and are not practical for many applications. As such, conventional QR codes are prone to two critical problems: loss of contrast and size tolerance (e.g., smaller sized QR codes may be unrecognizable).
Further, even small distortions or scaling may render QR codes unrecognizable. Further, if a small portion of a QR code is obscured or covered (e.g., with other graphics), the underlying QR code may become unrecognizable. In some cases, if a pattern is printed below a QR code it may cause the QR code to become unrecognizable because contrast of elements can be lost. Additionally, frames, borders, or other patterns around QR codes may render them unrecognizable.
Accordingly, improved optical recognition codes are desired, e.g., optical recognitions codes that are more tolerant to loss of contrast and the detection of smaller sized codes.
According to one aspect and example of the present invention, an Optical Recognition (OR) code mark is provided. In one example, an OR code includes a segmented portion and a registration mark (e.g., in the form of an iris or pupil) positioned relative to the segmented portion. The OR code mark, e.g., as part of the segmented portion, includes a calibration region having 3 or more different colors, where each color is associated with a number (e.g., “0”, “1”, “2”, . . . “n”, and so on). The segmented portion of the mark is further colored (with the at least 3 different colors of the calibration region) to encode the segments. Accordingly, the OR code can be detected using the registration mark and calibration region to identify and assign values to the segmented regions and decode the mark.
According to another aspect and example of the present invention and exemplary system and process are provided for decoding an OR code including a segmented portion and registration mark.
Additionally, systems, electronic devices, graphical user interfaces, and non-transitory computer readable storage medium (the storage medium including programs and instructions for carrying out one or more processes described) for generating and/or decoding optical recognition codes are described.
The present application can be best understood by reference to the following description taken in conjunction with the accompanying drawing figures, in which like parts may be referred to by like numerals.
The following description is presented to enable a person of ordinary skill in the art to make and use the various embodiments. Descriptions of specific devices, techniques, and applications are provided only as examples. Various modifications to the examples described herein will be readily apparent to those of ordinary skill in the art, and the general principles defined herein may be applied to other examples and applications without departing from the spirit and scope of the present technology. Thus, the disclosed technology is not intended to be limited to the examples described herein and shown, but is to be accorded the scope consistent with the claims.
According to one example, an optical recognition (OR) code is provided, the OR code having at least three colors arranged in an arc, e.g., along a portion of a circle, ellipse, or other curved or linear geometry. The OR code further having a calibration region for providing the at least three colors and a registration mark for orientating the OR code upon detection. An exemplary OR code 100 is illustrated in
Exemplary OR codes described herein may provide improved optical recognition (e.g., more tolerant to loss of contrast and transformations) relative to conventional QR codes or barcodes. In particular, exemplary OR codes provide improved recognition robustness when included or printed on glossy paper or products.
Broadly speaking, and with reference generally to
In one example, the first ring (e.g., the inner ring 102, smaller radius) is composed of 16 colored arc segments 106, the second ring is composed of 20 colored arc segments 106. Accordingly, 36 colored arc segments are arranged on the two rings. Three arcs of the inner ring (see
Of course many variations to these examples are possible. For example, the center registration mark, shown as an iris/pupil in this example, may include other shapes (e.g., squares, crosses, triangles, and so on), features (e.g., other orientations features/marks), and may further be disposed outside of the rings (e.g., adjacent or surrounding the outer ring). Additionally, the calibration region may be disposed in other regions or positions relative to the segmented arcs (e.g., with the outer ring, as a linear bar adjacent the ring, with the registration mark, and so on).
Further, although this example includes an inner and outer circle, a single circle or more than two circles are possible. Additionally, the segmented arcs may form a spiral structure, elliptical structure, and so on. Further, shapes such as squares, polygons (pentagons, hexagons, octagons, and so on) having segmented or varying color schemes encoded therein are possible and contemplated (where such shapes can be partial as illustrated in the partial outer circle of example 1 or closed as illustrated by the outer circle of example 2). Further various shapes may be combined, e.g., a segmented inner circle with a segmented outer polygon and so on.
The three or more colors for use in the OR code may vary and are generally chosen to aid in detecting and distinguishing the different colors. For example, selecting colors that are different enough to be easily identified when detected/imaged as different colors.
According to another aspect, detection and recognition of an OR code will now be described. Broadly speaking, detection is based on the search of closed elliptical contours in mask images (see
Once an OR code is recognized, the process can then orient the OR code and determine segment boundaries.
Once segment locations or boundaries are detected, colors of the segmented arcs (see
For example, if the first coding arc is the most similar to the first calibration arc, the second most similar to the first, the third most similar to the second, the fourth most similar to the third etc., then the recognized code in ternary notation will correspond to “2210.” This determination is then converted to decimal notation and divided into a pure coding sequence, and a checksum. For example, the checksum of the pure coding sequence is calculated and compared with recognized checksum to identify if the code is recognized correctly. If the same—the code is considered to be recognized correctly (
At 812, the process may recognize the encoded number in ternary notation by matching colors of coding arcs and calibration arcs, e.g., as described herein. Four different algorithms for color matching can be used for decoding: straight decoding, gradient-based decoding, sat-val normalization, and affinity-based decoding, forming eight different combinations of recognition trials: straight, straight+sat-val, straight+affinity, straight+affinity+sat-val, gradient, gradient+sat-val, gradient+affinity, gradient+affinity+sat-val. Straight decoding procedure performs uniform division of coding circles into separate coding arcs, basing on known total number of segments in the circles. Prime color can be estimated within each coding arc in following manner. Mean values of color components of all pixels in coding arc are computed. Then two steps are iteratively repeated until converged: 1—choosing the half of pixels among all pixels in arc whose colors are most close to computed mean values; recompute mean values of color components of chosen pixels. Converged mean value of color components is the prime color. The prime colors can then be matched with calibration colors by computing Euclidian distance (in RGB space) from analyzing color to each of calibration colors and association current coding segment with calibration region with least distance. Within gradient-based decoding procedure, arc boundaries are adjusting by searching for maximal color gradients between different coding arcs. Sat-val normalization procedure performs converting of colors of coding arcs to new values with standardized values of saturation and value (in HSV color model). Affinity-based decoding is based on clustering of prime colors of coding arcs in color space by growing graphs that are connecting colors of recognizing arcs with colors of calibration arcs.
A few steps of an exemplary affinity-based decoding algorithm are schematically shown in
The conversion of ternary code to decimal notation can then be carried out at 814, and the separation of decimal code into pure code and recognized checksum may be further performed. Further, the process may calculate a checksum of the pure code and match it with recognized checksum to verify recognition at 816. The process may finally return or output the pure code at 818.
The exemplary process is for illustrative purposes only and one of skill will recognize that other imaging processes and functionality may be carried out instead of or in addition to those explicitly described herein. Further, certain processes described may be carried out at least partially in parallel or in series.
At least some values based on the results of the above-described processes can be saved for subsequent use. Additionally, a non-transitory computer-readable medium can be used to store (e.g., tangibly embody) one or more computer programs for performing any one of the above-described processes by means of a computer. The computer program may be written, for example, in a general-purpose programming language (e.g., Pascal, C, C++, Java) or some specialized application-specific language.
Various exemplary embodiments are described herein. Reference is made to these examples in a non-limiting sense. They are provided to illustrate more broadly applicable aspects of the disclosed technology. Various changes may be made and equivalents may be substituted without departing from the true spirit and scope of the various embodiments. In addition, many modifications may be made to adapt a particular situation, material, composition of matter, process, process act(s) or step(s) to the objective(s), spirit or scope of the various embodiments. Further, as will be appreciated by those with skill in the art, each of the individual variations described and illustrated herein has discrete components and features that may be readily separated from or combined with the features of any of the other several embodiments without departing from the scope or spirit of the various embodiments. All such modifications are intended to be within the scope of claims associated with this disclosure.
The present application is related to and claims benefit of U.S. provisional patent application Ser. No. 62/157,263, titled “PALETTE-BASED OPTICAL RECOGNITION CODE GENERATORS AND DECODERS”, filed on May 5, 2015, and U.S. provisional patent application Ser. No. 62/248,605, titled “PALETTE-BASED OPTICAL RECOGNITION CODE GENERATORS AND DECODERS”, filed on Oct. 30, 2015, and incorporates the contents of both in their entireties by reference for all purposes.
Number | Date | Country | |
---|---|---|---|
62157263 | May 2015 | US | |
62248605 | Oct 2015 | US |