Various embodiments are directed to methods and apparatus for locating target patterns within an image, and more, particularly to efficiently locating QR code finder patterns and/or QR code alignment patterns in an image which may have noise and/or been damaged due to scanning errors and/or other issues.
First developed in 1994, QR codes are a two-dimensional barcode type that has come into much popularity with the recent ubiquity of mobile devices. Featuring a robust error correction mechanism and a number of structurally identifying features, this barcode type has been designed around ease of recognition. The most visually striking features of QR codes are the concentric square finder patterns and alignment patterns. These patterns serve as boundary markers and indicate locations within the code to accurately align the barcode's modules.
A QR code normally includes multiple locator patterns, e.g., three, one in each of three different corners of a square QR code. While locater pattern redundancy is helpful when trying to determine the boundaries of a QR code, in many cases a QR code may be damaged or a scan of the code may be noisy, e.g., due to some black areas being interpreted as white and visa versa. Unfortunately, noise is often present in scanned QR codes even if the original code is relatively intact. In the context of the present application a scan maybe a image captured by a camera such as a camera cell phone or an image captured by a scanner which sequentially captures portions of an image of an object such as a document. Thus scan is used to generally refer to a captured image of an object such as a page of a document or product packaging regardless of the device used to capture the image. Cameras and scanners normally include an optical sensor often simply referred to as a sensor which converts captured light to electrical signals which correspond to pixel values. Thus the output of a sensor is often a set of pixel values of a captured image, e.g., the scanned image. During image capture sensor noise may cause some pixels of the scan to assume a value different from what the actual pixel value should be.
The processing of a noisy scan and/or a scan of a damaged QR code to locate one or more finder patterns presents several technical problems. One technical problem is how to process a lossy or damaged image to make it easier to find a locator pattern and/or find the position of the corners of the locator pattern. It would be desirable if one or more methods and/or apparatus could be developed to process a damaged or noisy QR code to facilitate accurate identification of a QR locator pattern and its corners even if the damaged or noisy QR code can not be fully repaired. Another technical problem is how to determine the position and/or corners of a QR locator pattern when it is damaged which is often the case.
In view of the above discussion it should be appreciated that there is a need for methods and/or apparatus which can be used to process scanned images, e.g., of QR codes, to enhance the probability of correct identification and/or location of a QR code finder pattern. In addition there is a need for methods and/or apparatus which can find the position of a noisy or otherwise damaged QR locator pattern and/or the corners of such a QR locator pattern. While it would be desirable if the methods and apparatus could address multiple technical problems of the type described, even if one or more of the problems can be addressed it would be useful since increasing the reliability of QR locator pattern identification and location determination can facilitate successful reading and/or recovery of information communicated by a QR code in which the QR location pattern is located.
Methods and apparatus for processing a locator pattern or patterns in a QR code, e.g., a scanned QR code, are described. Various features relate to the processing of a scanned image to facilitate accurate locator pattern identification and/or detection of the corner locations of the locator pattern. Other features relate to the processing of a damaged locator pattern, which may or may not have been processed to reduce the effect of noise or other damage, to determine the location of the corners of the QR locator pattern. The scanned image of a QR code may be generated by using a camera or scanner device to generate an image of a QR code.
In some embodiments to facilitate the identification of corner points the scanned image is processed to reduce the effect of noise and/or other damage on the subsequent location identification process. In some embodiments individual white pixels which have black pixels on four sides are converted to black as part of the processing while multiple white pixels adjacent each other are left unaltered. In some embodiments processing does not alter the color of black pixels. This minimizes the processing operations performed while still addressing the effect of individual white pixels in a black region which have been found to be a more common error than an individual black pixel in a white region. Thus, the effect of local noise and/or other local damage, e.g. individual pixel level damage, is reduced through the processing used in some but not all embodiments.
Once a scanned image including a QR locator pattern has been processed, the corner points of the locator pattern are identified through additional processing and identification of line segments satisfying the expected 1:1:3:1:1 ratio of black, white, black, white, black segments expected in the center region of the locator pattern.
The position information about the corners of the locator pattern can be, and sometimes are, used to facilitate reading of the information communicated by the QR code in which the QR locator pattern is located.
By addressing one or more of the technical problems associated with QR code locator pattern identification and corner position determination, the probability that useful information communicated by a QR code can be recovered and used by a device, e.g., cell phone which scanned the pattern, or a person who used a device to scan a QR pattern is increased.
While various embodiments have been discussed in the summary above, it should be appreciated that not necessarily all embodiments include the same features and some of the features described above are not necessary but can be desirable in some embodiments. Numerous additional features, embodiments and benefits of various embodiments are discussed in the detailed description which follows.
The described processing of the damaged locator pattern 300 shown in
In step 618, horizontal and vertical line segments having a 1:1:3:1:1 ratio of adjacent black, white, black, white, black segments are extracted, e.g. identified. In some embodiments, step 618 includes a sub-step in which horizontal line segments having a 1:1:3:1:1 ratio of adjacent black, white, black, white, black segments are identified, and a sub-step in which vertical line segments having a 1:1:3:1:1 ratio of adjacent black, white, black, white, black segments are identified. The input to step 618 is the processed black and white pixel bitmap of the image 616, and the output from step 618 are identified horizontal line segments 620 and identified vertical line segments 622. In step 624, identified horizontal line segment information is stored, and in step 626 identified vertical line segment information is stored. Exemplary identified horizontal line segment information for an identified horizontal line segment includes, e.g., the location of the start of the line segment, e.g., leftmost coordinate, the location of the end of the line segment, e.g., rightmost coordinate, the length of the line segment, and the length of the center black segment within the line segment. Exemplary identified vertical line segment information for an identified vertical line segment includes, e.g., the location of the top of the line segment, the location of the bottom of the line segment, the length of the line segment, and the length of the center black segment within the line segment. Operation proceeds from step 618, 624, and 626 to step 628.
In step 628 similar identified line segments that touch each other are grouped together to form one or more match groups. Step 628 includes step 630 which is a call of a match group(s) generation subroutine, e.g., subroutine 700 of
Operation proceeds from step 628 to step 634. In step 634, for each of the match groups, the corner points of the respective outer square of a QR locator pattern are calculated. Step 634 includes step 636, 642, and 644. In step 636 the corners of a first QR code locator pattern are determined from the first match group 633. Step 636 includes step 638 in which a call is made to a QR code locator pattern corner points determination subroutine, e.g., subroutine 900 of
Operation proceeds from step 636 to step 642. In step 642 a determination is made as to whether or not there is another match group in match groups information 632 to be processed. If there is another match group to process, then operation proceeds from step 642 to step 644. In step 644 the corners of another QR code locator pattern are determined from the another match group, e.g., match group M 635. Step 644 includes step 646 in which a call is made to a QR code locator pattern corner points determination subroutine, e.g., subroutine 900 of
If in step 642, the determination is that there is not another match group to process then operation proceeds from step 642, via connecting node A 642 to step 654. In step 654, a first QR code on the scanned object, in which said first QR code locator pattern is included, is read using the location of the corners of the first QR code locator pattern as a guide to the position of the QR code on the scanned object. Step 654 includes step 656 in which information is extracted about the document or object from the binary bitmap of the scanned object which includes the first QR code. Operation proceeds from step 654 to step 658.
In step 658, a check is made as to whether or not another object is to be scanned at this time. If another object is to be scanned, then operation proceeds from step 658, via connecting node B 660, to step 604. However, if another object is not to be scanned the operation proceeds to the input of step 658 for another check, at a later time.
In step 706 a determination is made as to whether or not identified line segment H and identified line segment V intersect each other. Step 706 uses location information about the identified line segment H and location information about the identified line segment V to determine if H and V intersect at all. Step 706 includes steps 708, 710, 712714 and 716. In step 708, the following variable are calculated: HMX=horizontal middle segment {X}; HMY=horizontal middle segment {Y}; HML=horizontal middle segment {Length}; VMX=vertical middle segment {X}; VMY=vertical middle segment {Y}; VML=vertical middle segment {Length}. Operation proceeds from step 708 to step 710.
In step 710 a check is performed to determine if VMX is both: (i) greater than or equal to HMX and (ii) less than or equal to HMX+HML. If those conditions are not satisfied then operation proceeds from step 710 to step 716 in which it is determined that the segments H and V, which are being tested, do not intersect. However if the check of step 710 determines that the conditions are satisfied, then operation proceeds from step 710 to step 712. In step 712 a check is performed to determine if HMY is both: (i) greater than or equal to VMY and (ii) less than or equal to VMY+VML. If those conditions are not satisfied then operation proceeds from step 712 to step 716 in which it is determined that the segments H and V, which are being tested, do not intersect. However if the check of step 712 determines that the conditions are satisfied, then operation proceeds from step 712 to step 714, in which it is determined that the segments H and V, which are being tested, intersect. Operation proceeds from step 706 to step 718.
In step 718, if the determination is that line segment H and line segment V intersect each other then operation proceeds, via connecting node A 720 to step 724. However, if the determination is that that line segment H and line segment V do not intersect one another, then operation proceeds from step 718, via connecting node B 722, to step 733, in which a determination is made that this is an invalid match and the pair is rejected.
Returning to step 724, in step 724, the minimum, referred to as MINTOTAL, and the maximum, referred to as MAXTOTAL, of the total length of line segments H and V are determined. Operation proceeds from step 724 to step 726. In step 726, MINTOTAL is divided by MAXTOTAL and a check is made to determine if the value obtained is greater than or equal to 0.8. Step 726 compares the ratio of the smallest of the two total lengths to the largest of the two total lengths. If the ratio is greater than or equal to 80%, then the test passes. For example, if the identified horizontal line segment H's total length is 20 pixels long and the identified vertical line segment V's total length is 18 pixels long, the test would pass since 18/20=0.9 (90%). As another example, if the identified horizontal line segment H's total length is 15 pixels long and the identified vertical line segment V's total length is 20 pixels long, the test would not pass since 15/20=0.75 (75%) and does not meet or exceed 80%.
If the determination of step 726, is that the ratio is not greater than 0.8, then operation proceeds to step 733, in which a determination is made that this is an invalid match and the pair is rejected. However, if the determination of step 726, is that the ratio is greater than or equal to 0.8, e.g. the ratio is between 0.8 and 1, then the pair has satisfied the total length ratio test condition and operation proceeds to step 728.
In step 728, the minimum, referred to as MINCENTER, and the maximum, referred to as MAXCENTER, of the center black segments' lengths of line segments H and V are determined. In step 730, MINCENTER is divided by MAXCENTER and a check is made to determine if the value obtained is greater than or equal to 0.8. If the determination of step 730, is that the ratio is not greater than 0.8, then operation proceeds to step 733, in which a determination is made that this is an invalid match and the pair is rejected. However, if the determination of step 730, is that the ratio is greater than or equal to 0.8, e.g. the ratio is between 0.8 and 1, then the pair has satisfied the center length ratio test condition and operation proceeds to step 732.
In step 732 a disjoint set union between line segment H and line segment V is performed and match group information is updated. Step 732 includes step 734, in which a call is made to a disjoint set union and match group updating subroutine, e.g., subroutine 800.
In step 806, it is determined whether or not identified line segment V belongs to an existing match group. If V belongs to an existing match group then operation proceeds from step 806 to step 810. However, if V does not belong to an existing match group then operation proceeds from step 806 to step 808. In step 808, a new match group is created including identified line segment V and identified line segment H, e.g., a first match group is created.
Returning to step 810, in step 810 it is determined if only one of identified line segment H and identified line segment V belongs to an existing match group. If it is determined that only one of H and V belong to an existing match group, then operation proceeds from step 810 to step 812. However, if it is determined that both line segment H and line segment V already belong to a match group, then operation proceeds from step 810 to step 816.
Returning to step 812, in step 812, the existing match group to which one of H and V already belongs, is updated. Step 812 includes step 814 in which the other one of line segment H and line segment V which does not belong to an existing match group is added to the existing match group to which the one of line segment H and line segment V already belongs, e.g., the first match group is updated to include a new member.
Returning to step 816, in step 816, it is determined if identified line segment H and identified line segment V belong to different match groups or to the same match group. If the determination of step 816 is that H and V belong to different match groups, then operation proceeds from step 816 to step 818 in which the different match groups to which identified line segment H and identified line segment V already belong are merged, e.g., a second match group is merged into a first match group.
If in step 816 it is determined the H and V do not belong to different match groups, then operation proceeds from step 816 to step 820, in which no operation is performed regarding generating new match groups, updating match groups or merging match groups, since identified line segment H and identified line segment V already belong to the same existing match group.
Operation returns to step 732 and the preliminary match group information 736 has been updated if one of step 808, 814 or 818 was performed.
Operation proceeds from step 732 or step 733 to step 738. In step 738, a determination is performed as to whether or not there are additional identified horizontal and vertical line segment pairs to test for a match. If it is determined that there are additional pairs to test, then operation proceeds from step 738, via connecting node C 744 to step 704, in which an untested pair from identified Horizontal line segments 620 and identified vertical lines segments 622 is retrieved and processed.
If in step 732, it is determined that there are no additional pairs to test, e.g., each of the potential pairing combinations of one from identified horizontal line segment 620 and one from identified vertical line segments 622 has already been tested, then operation proceeds from step 738 to step 740.
In step 740, match groups from the preliminary match group information 736 are deleted which do not have at least 3 identified horizontal line segments and 3 identified vertical line segments as members of the group. In some embodiments, the criteria used for rejecting a match groups is different, e.g., a match group that does not include at least 2 identified horizontal line segments and at least 2 identified vertical line segments is rejected, or a match group that does not include at least 6 identified horizontal line segments and at least 6 identified vertical line segments is rejected. In some embodiments, different criteria for rejection is used regarding the minimum number of identified horizontal line segments and the minimum number of vertical line segments. The output from step 740 is match group information 632 which includes one or more match groups (match group 1633, . . . , match group M 635). In one example M=3.
Operation starts in step 902 and proceeds to step 903, in which a match group to be processed is received, the match group including multiple identified horizontal line segments and multiple identified vertical line segments. Operation proceeds from 903 to step 904. In step 904 left, right, top and bottom sets of points are calculated. Step 904 includes steps 906, 908 and 914. In step 906 an empty list is assigned to each of the left, right, top and bottom variables. Operation proceeds from step 906 to step 908 and step 914. In step 908, for each ascending—vertically sorted identified horizontal line segments (HLSs) of the match group being processed, steps 910 and 912 are performed. In step 910 the (X. Y) coordinate of the HLS's starting point is placed into the front of the left list. In step 912 the (X. Y) coordinate of the HLS's ending point is placed into the back of the right list. In step 914, for each ascending—horizontally sorted identified vertical line segments (VLSs) of the match group being processed, steps 916 and 918 are performed. In step 916 the (X. Y) coordinate of the VLS's starting point is placed into the front of the top list. In step 918 the (X. Y) coordinate of the VLS's ending point is placed into the back of the bottom list.
Operation proceeds from step 904 to step 920. In step 920 vertical and horizontal reflection points are calculated. Step 920 includes steps 922, 924 and 932. In step 922 new list variables: VERTICALREFLECTIONS and HORIZONTALREFLECTIONS are created. Operation proceeds from steps 922 to steps 924 and 932. In step 924, for each point P in the list of right points (FIRST POINT R0, LAST POINT Rn) steps 926, 928 and 930 are performed. In step 926, the value LY is calculated, where LY=R0.Y+RnY−P.Y. In step 928, the index if the point P′ in the list of left points that is closest without exceeding a Y-coordinate of LY is found. In step 930, the found index of step 928 is added to the list of vertical reflections. In step 932, for each point P in the list of top points (FIRST POINT T0, LAST POINT Tn) steps 934, 936 and 938 are performed. In step 934, the value BX is calculated, where BX=T0.X+TnX−P.X. In step 936, the index if the point P′ in the list of bottom points that is closest without exceeding a X-coordinate of BX is found. In step 938, the found index of step 936 is added to the list of horizontal reflections.
Operation proceeds from step 920 to step 940. In step 440, the variables B1, B2, B3, B4, are set as the new linear regression equation (Y=MX+B) or (X=MY+B). Operation proceeds from step 940 to step 942. In step 942, the variable LEASTERROR is set equal to the maximum double value on the machine being used to process, e.g., the variable LEASTERROR is set equal to 1.998 . . . E+308. Operation proceeds from step 942, via connecting node A 943, to step 944. Step 944 is performed for each pair of a horizontal point along the top line (TP) and a vertical point along the right line (RP). Step 944 includes steps 946, 948, 950, 952, 954, 956, 958, 960, 962, 964, 966, 968, and 970. In step 946 the variable LP is set to be the VERTICALRELECTION point for RP. Operation proceeds from step 946 to step 948. In step 948 the variable BP is set to be the HORIZONTALREFLECTION point for TP. Operation proceeds from step 948 to step 950. In step 950 a new list of variables L1, L2, L3, L4 are created. Operation proceeds from step 950 to step 952. In step 952 all of the subsequent top points after TP and all of the right points prior to RP are added to L1. Operation proceeds from step 952 to step 954. In step 954 all of the subsequent left points after LP and all of the top points prior to LP are added to L2. Operation proceeds from step 954 to step 956. In step 956 all of the subsequent bottom points after BP and all of the left points prior to LP are added to L3. Operation proceeds from step 956 to step 958. In step 958 all of the subsequent right points after RP and all of the bottom points prior to BP are added to L4. Operation proceeds from step 958 to step 960.
In step 960, linear regressions are calculated for the points in L1, L2, L3, and L4, respectively, as the variables B1′, B2′, B3′, B4′, respectively. Thus in step 960 4 linear regressions are performed. Operation proceeds from step 960 to step 962.
In step 962, the error values E1, E2, E3, and E4 are calculated from the 4 linear regressions of step 960, e.g., where the error values are the average sum of the shortest distance from the regression line. Operation proceeds from step 962 to step 964.
In step 964, error E is calculated, where E=maximum (E1, E2, E3, E4). Operation proceeds from step 964 to step 966.
In step 966 error E is compared to the value of LEASTERROR. If E is less than the current value of LEASTERROR, then operation proceeds from step 966 to step 970; otherwise, operation proceeds from step 966 to step 968. In step 968, B1 is set equal to B1′, B2 is set equal to B2′, B3 is set equal to B3′ and B4 is set equal to B4′. In step 968, LEASTERROR is set to the value of E. Operation proceeds from step 968 to step 970.
In step 970, a determination is made as to whether of not there is another pair of points to process, e.g., another horizontal point along the top line and another vertical point along the right line. If there is another pair of point to process then operation proceeds to the input of step 944. If the determination of step 970 is that there is not an additional pair of points to process, then operation proceeds from step 970 to step 972.
In step 972 the processing of step 944 returns the regression lines B1, B2, B3, B4 which were determined to produce the minimum error value. Operation proceeds from step 972 to step 974.
In step 974 the corner points, C1, C2, C3, and C4, of the QR code locator pattern are calculated, where C1=intersection of lines (B1, B2), C2=intersection of lines (B2, B3), C3=intersection of lines (B3, B4) and C4=intersection of lines (B4, B1). Points C1, C2, C3, and C4 are determined corner points of the outer square of a QR code locator pattern. The determined corner points C1, C2, C3 and C4, are returned to the step which called the routine of flowchart 900.
The overreaching goal is to find the set of four lines that best represent the points given with the left/top/right/bottom points. There is a problem in that the corner points can exist midway through the four sets of points. In order to overcome this problem, in some embodiments, a nested double loop over the points is initiated to determine what the best lines are that represent the sides. In some embodiments, a simple linear regression is used to test the error of each line.
To create reflection points the procedure of step 920 of
Input device(s) 2404 includes, e.g. a scanner, camera, keyboard, keypad, touch screen, mouse, and/or other user input devices. The display 2402 and input devices 2404 are coupled to a bus 2408 by I/O interface 2406. The bus 2408 is also coupled to the memory 2416, processor 2424, assembly of hardware components 2450, and network interface 2410. The network interface 2410 couples the internal components of the device 2400 to an external network, e.g., the Internet, thereby allowing the device 2400 to receive and send data over a network. Alternatively, or in addition, wireless interface 2426 which includes a wireless transmitter 2436 and a wireless receiver 2434, couples device 2400 to other wireless devices and/or a wireless communications network.
Memory 2416 includes routines 2418 and data/information 2420. Routines 2418 include a control routine 2419 and an assembly of components 2452, e.g., an assembly of software components. In some embodiments, the control routine 2419 causes the device 2400 to implement the steps of the methods of flowcharts of
Identified horizontal line segment information 2514 includes information corresponding to each of the identified horizontal line segments (identified horizontal line segment 1 information 2518, . . . , identified horizontal line segment m information 2520). Identified horizontal line segment 1 information 2518 includes length information 2522, e.g., total length information and middle segment length information, and location information 2524. Identified vertical line segment information 2516 includes information corresponding to each of the identified vertical line segments (identified vertical line segment 1 information 2526, . . . , identified vertical line segment n information 2528). Identified vertical line segment 1 information 2526 includes length information 2530, e.g., total length information and middle segment length information, and location information 2532.
Data/information 2500 further includes generated match groups (generated match group 12534, . . . , generated match group K 2536). Data/information 2500 further includes sets of top, right, bottom and left points for match group 12538, calculated vertical and horizontal reflection points for match group 12540, a determined set of regression lines corresponding to the lowest error for match group 12542, and the determined locations of the corners of the first QR code location pattern which corresponds to match group 12544. Data/information 2500 further includes sets of top, right, bottom and left points for match group K 2546, calculated vertical and horizontal reflection points for match group k 2548, a determined set of regression lines corresponding to the lowest error for match group k 2550, and the determined locations of the corners of the Kth QR code location pattern which corresponds to match group K 2552.
Data/information 2500 further includes a total length ratio criteria value for horizontal/vertical line segment pair match group acceptance testing 2552, e.g., a value of 0.8, a center length ratio criteria value for horizontal/vertical line segment pair match group acceptance testing 2554, e.g., a value of 0.8, and a minimum number of identified lines segments for a valid match group 2556, e.g., at least 3 accepted identified horizontal line segments and at least 3 accepted identified vertical line segments.
A method of processing image data, the method comprising: processing a binary pixel bitmap of a scanned object to remove pixel noise, said processing producing a processed binary pixel bitmap of the scanned object; identifying in the processed binary pixel bitmap horizontal line segments having an expected ratio of adjacent black, white, black, white, black segments; identifying in the processed binary pixel bitmap vertical line segments having the expected ratio of adjacent black, white, black, white, black segments; determining from the identified horizontal and vertical line segments locations of corners of at least a first QR code locator pattern; and reading a first QR code on the scanned object in which said first QR code locator pattern is included using the locations of the corners of the first QR code locator pattern as a guide to the position of the QR code on the scanned object.
The method of Method Embodiment 1, wherein said scanned object is a document or box, wherein the expected ratio of adjacent black, white, black, white, black segments is 1:1:3:1:1; and wherein reading the first QR code on the scanned object includes extracting information about the document or object from the binary pixel bitmap of the scanned object which includes the first QR code.
The method of Method Embodiment 1, wherein processing the binary pixel bitmap of a scanned object to remove pixel noise includes replacing individual white pixels which have immediately adjacent black pixels on four sides (e.g., left, right, top and bottom) with black pixels.
The method of Method Embodiment 1, wherein processing the binary pixel bitmap of a scanned object to remove pixel noise includes leaving black pixels unchanged.
The method of Method Embodiment 4, wherein processing the binary pixel bitmap of a scanned object to remove pixel noise includes leaving groups of two or more white pixels adjacent each other unchanged.
The method of Method Embodiment 1, further comprising: storing the location and length of each identified horizontal line segment; and storing the location and length of each identified vertical line segment.
The method of Method Embodiment 3, wherein determining from the identified horizontal and vertical line segments locations of corners of at least a first QR code locator pattern includes: generating at least a first match group corresponding to a QR code locator pattern by grouping identified line segments that contact each other together; and determining from the line segments in the first match group the corners of the first QR code locator pattern.
The method of Method Embodiment 7, generating at least a first match group corresponding to a QR code locator pattern by grouping identified line segments that contact each other together includes: determining if a first identified horizontal line segment intersects a first identified vertical line segment.
The method of Method Embodiment claim 8, further comprising: in response to determining that the first identified horizontal line segment intersect the first identified vertical line segment, checking that black center portions of the first horizontal line segment and black center portion of the first vertical line segment have lengths which are within a predetermined range of each other.
The method of Method Embodiment 9 wherein said predetermined range is 80% to 100%, the smaller center portion of the vertical line segment or horizontal line segment having a length which is greater than or equal 0.8 the length of the larger center portion of the vertical line segment or horizontal line segment.
The method of Method Embodiment 10, wherein the first identified horizontal line segment and the first identified vertical line segment satisfied said check; and wherein said generating at least a first match group corresponding to a QR code locator pattern further includes: starting the first match group by including in the first match group the first identified horizontal line segment and first identified vertical line segment in the first match group.
The method of Method Embodiment 9, wherein the first identified horizontal line segment and the first identified vertical line segment satisfied said check; and wherein said generating at least a first match group corresponding to a QR code locator pattern further includes: updating the first match group by including one of the first identified horizontal line segment and the first identified vertical line segment in the first match group.
The method of Method Embodiment 9, wherein the first identified horizontal line segment and the first identified vertical line segment satisfied said check; and wherein said generating at least a first match group corresponding to a QR code locator pattern further includes: updating the first match group including merging a second match group into the first match group, said second match group including one of the first identified horizontal line segment and the first identified vertical line segment.
The method of Method Embodiment 1, wherein determining from the identified horizontal and vertical line segments locations of corners of at least a first QR code locator pattern includes: processing a first match group including at least three identified vertical line segments and three identified horizontal line segments.
The method of Method Embodiment 14, wherein said processing the first match group includes performing multiple iterative linear regressions.
A device comprising: a camera or scanner for generating (e.g., by capturing an image of the portion of the object) a binary pixel bitmap of a portion of an object including a locator pattern; memory for storing the binary pixel map; a processor, coupled to said memory, the processor being configured to: processes the binary pixel bitmap to remove pixel noise, said processing producing a processed binary pixel bitmap; identify, in the processed binary pixel bitmap, horizontal line segments having an expected ratio of adjacent black, white, black, white, black segments; identify, in the processed binary pixel bitmap, vertical line segments having the expected ratio of adjacent black, white, black, white, black segments; determine from the identified horizontal and vertical line segments locations of corners of at least a first QR code locator pattern; and reading a first QR code on the scanned object in which said first QR code locator pattern is included using the locations of the corners of the first QR code locator pattern as a guide to the position of the QR code on the scanned object.
The device of Device Embodiment 16, wherein said object is a document or box; wherein the expected ratio of adjacent black, white, black, white, black segments is 1:1:3:1:1; and wherein reading the first QR code on the scanned object includes extracting information about the document or object from the binary pixel bitmap of the scanned object which includes the first QR code.
The device of Device Embodiment 16, wherein said processor is further configured to: replace, as part of process the binary pixel bitmap to remove pixel noise, individual white pixels, which have immediately adjacent black pixels on four sides (e.g., left, right, top and bottom), with black pixels.
The device of Device Embodiment 16, wherein the processor is further configured to: leave black pixels unchanged when processing the binary pixel bitmap to remove pixel noise.
The device of Device Embodiment 19, wherein the processor if further configured to: leave groups of two or more white pixels adjacent each other unchanged when processing the binary pixel bitmap to remove pixel noise.
The device of Device Embodiment 16, wherein the processor is further configured to: store in said memory the location and length of each identified horizontal line segment; and store, in said memory, the location and length of each identified vertical line segment.
The device of Device Embodiment 18, wherein said processor is configured, as part of determining from the identified horizontal and vertical line segments locations of corners of at least a first QR code locator pattern, to: generate at least a first match group corresponding to a QR code locator pattern by grouping identified line segments that contact each other together; and determine from the line segments in the first match group the corners of the first QR code locator pattern.
The device of Device Embodiment 21, wherein the processor is configured, as part of generating at least a first match group corresponding to a QR code locator pattern by grouping identified line segments that contact each other together, to: determine if a first identified horizontal line segment intersects a first identified vertical line segment.
The device of Device Embodiment 23, wherein the processor is further configured, in response to determining that the first identified horizontal line segment intersect the first identified vertical line segment, to: check that black center portions of the first horizontal line segment and black center portion of the first vertical line segment have lengths which are within a predetermined range of each other.
The device of Device Embodiment 24, wherein said predetermined range is 80% to 100%, the smaller center portion of the vertical line segment or horizontal line segment having a length which is greater than or equal 0.8 the length of the larger center portion of the vertical line segment or horizontal line segment.
The device of Device Embodiment 24, wherein the first identified horizontal line segment and the first identified vertical line segment satisfied said check; and wherein the processor is further configures, as part of generating at least a first match group corresponding to a QR code locator pattern, to: starting the first match group by including in the first match group the first identified horizontal line segment and first identified vertical line segment in the first match group.
The device of Device Embodiment 24, wherein the first identified horizontal line segment and the first identified vertical line segment satisfied said check; and wherein said processor is further configured, as part of generating at least a first match group corresponding to a QR code locator pattern, to: update the first match group by including one of the first identified horizontal line segment and the first identified vertical line segment in the first match group.
The device of Device Embodiment 24, wherein when the first identified horizontal line segment and the first identified vertical line segment satisfied said check, the processor is further configured, as part of generating at least a first match group corresponding to: update the first match group by merging a second match group into the first match group, said second match group including one of the first identified horizontal line segment and the first identified vertical line segment.
The device of Device Embodiment 16, wherein said processor is further configured, as part of determining from the identified horizontal and vertical line segments locations of corners of at least a first QR code locator pattern to: processes a first match group including at least three identified vertical line segments and three identified horizontal line segments.
The device of Device Embodiment 29, wherein the processor, is configured to: perform multiple iterative linear regressions as part of processing the first match group.
A non-transitory computer readable medium, comprising processor executable instructions which when executed by a processor control the processor to: process a binary pixel bitmap of a scanned object to remove pixel noise, said processing producing a processed binary pixel bitmap of the scanned object; identify in the processed binary pixel bitmap horizontal line segments having an expected ratio of adjacent black, white, black, white, black segments; identify in the processed binary pixel bitmap vertical line segments having the expected ratio of adjacent black, white, black, white, black segments; determine from the identified horizontal and vertical line segments locations of corners of at least a first QR code locator pattern; and read a first QR code on the scanned object in which said first QR code locator pattern is included using the locations of the corners of the first QR code locator pattern as a guide to the position of the QR code on the scanned object.
The techniques of various embodiments may be implemented using software, hardware and/or a combination of software and hardware. Various embodiments are directed to apparatus, e.g., an image processing device or system. Various embodiments are also directed to methods, e.g., a method of locating a target pattern within an image. Various embodiments are also directed to machine, e.g., computer, readable medium, e.g., ROM, RAM, CDs, hard discs, etc., which include machine readable instructions for controlling a machine to implement one or more steps of a method.
In various embodiments apparatus described herein are implemented using one or more components to perform the steps corresponding to one or more methods. Thus, in some embodiments various features are implemented using components. Such components may be implemented using software, hardware or a combination of software and hardware. In some embodiments in which the components are implemented in hardware, the components are implemented as circuits, e.g., of a processor. In many or all of the above described embodiments, methods and/or method steps can, and in some embodiments are, implemented using computer executable instructions, such as software, included in a computer readable medium, e.g., a non-transitory computer readable medium, such as a memory device, e.g., RAM, floppy disk, etc. which when executed control a machine, e.g., general purpose computer or processor, with or without additional hardware, to implement all or portions of the above described methods. Accordingly, among other things, various embodiments are directed to a computer readable medium including computer executable instructions for causing a machine, e.g., processor or computer system, to perform one or more of the steps of the above-described method(s). Each of the steps of the method maybe and sometimes are implemented by a circuit with different circuits being used for each of the different steps in some but not all embodiments.
Some embodiments are directed to a processor configured to implement one or more of the various functions, steps, acts and/or operations of one or more methods described above. Accordingly, some embodiments are directed to a processor, e.g., CPU, configured to implement some or all of the steps of the methods described herein. The processor may be for use in, e.g., an image processing device or system. In some embodiments the image processing device is a portable device including a camera, e.g., a cell phone including a cameral with a processor that implements the method.
In some embodiments components are implemented using software, in other embodiments components are implemented in hardware, in still other embodiments the components are implemented using a combination of hardware and/or software.
Numerous additional variations on the methods and apparatus of the various embodiments described above will be apparent to those skilled in the art in view of the above description. Such variations are to be considered within the scope of the invention.
Number | Name | Date | Kind |
---|---|---|---|
9501681 | Wang | Nov 2016 | B1 |
20070069026 | Aoyama | Mar 2007 | A1 |