1. Field of the Invention
This invention relates to an apparatus and a method for capturing images of negotiable instruments such as checks used for settling transactions.
2. Description of the Related Art
Checks and other such negotiable instruments are widely used to settle commercial transactions and to pay for purchases in stores and restaurants. This payment process is described below using checks by way of example. An account number and related information is generally printed on the face of a check as magnetic ink character data (MICR) enabling the account information to be read automatically for verification with the financial institution.
When a check is used for payment in a retail store, for example, the payee, date, and amount are printed on the face of the check after the check is verified, and the verification number, date, amount, and other endorsement information is automatically printed on the back of the check using a printer. After the store has finished processing the check, the check is typically delivered to the bank or other financial institution where the final payment process (check clearing) is completed. Electronic payment has been promoted in recent years as a way to increase the efficiency of the payment process by electronically sending the transaction data and images of the printed front and back of the check to the financial institution.
Checks, however, normally have a background pattern on the front of the check, and if the check image is captured at low resolution it can be difficult to read the printed text information, including the account number, payee, date, and amount. If the scanned images are captured at high resolution or color images are captured, however, the time required for the scanning process is undesirably long. High resolution and color also greatly increase the size of the image data, making large capacity, high speed storage devices necessary for storing the image data and requiring more time to transmit the scanned image data to the financial institution.
An object of our invention is therefore to provide a negotiable instrument processing apparatus and method for efficiently capturing image data from a check or other negotiable instrument, and for effectively differentiating the magnetic ink character data required for electronic payment and printed data on the front of the check from background printing or other marks or information on the check.
To achieve this and other objects, a negotiable instrument processing apparatus according to the present invention has an image reading unit for scanning a negotiable instrument and outputting gray scale image data; a threshold value determination unit for setting a threshold value for digitizing gray scale image data based on a density level frequency distribution in primary gray scale image data obtained by the image data reading unit scanning a first scanning area; and a digital conversion processing unit for digitizing and converting secondary gray scale image data to digital image data based on the threshold value set by the threshold value determination unit. The first scanning area contains part of a printed text area where text is printed on the negotiable instrument and part of the background of the negotiable instrument. The secondary gray scale image data obtained by the image reading unit scans a predefined second scanning area of the negotiable instrument.
Our invention therefore dynamically sets a threshold value used to convert a gray scale image of a check or other negotiable instrument to digital image data based on a part of the image considered characteristic of image features in the check or other negotiable instrument. It is therefore possible to obtain digital image data from which text information can be accurately determined and read.
The first scanning area preferably includes a first area containing a part of the printed text area and a second area containing a part of the background, and the first and second areas are noncontiguous. The required memory capacity and processing time required to determine the threshold value can thus be reduced.
Further preferably, the second area includes multiple sections each containing part of the background. This enables the threshold value to be appropriately determined even if the background of the check or negotiable instrument is mottled (not of uniform density).
Yet further preferably, the threshold value determination unit determines the threshold value based on a density level frequency distribution after weighting scale data in the first area. Thus, emphasizing data in the area where text is known to exist enhances the density values detected in the text area and makes it possible to set an appropriate threshold value.
Yet further preferably, the printed text area is a magnetic ink character printing area where magnetic ink characters are printed. In this case, the negotiable instrument processing apparatus also has a magnetic head for reading magnetic ink characters, and the threshold value determination unit detects the magnetic ink character printing area based on output signals from the magnetic head, and sets the first scanning area based on said magnetic ink character printing area. This makes it possible to appropriately set the first scanning area.
Further preferably, the threshold value determination unit averages the density level frequency distribution and determines the threshold value based on the averaged density level frequency distribution. This averaging process removes noise, and thus enables accurate extracting the features of the density level frequency distribution.
Yet further preferably, the threshold value set by the threshold value determination unit is a lightness value for generating the digital image data so that the text is readable, but the background is substantially removed. Yet further preferably, the threshold value determination unit identifies a peak representing the text and an adjacent peak representing the background in the density level frequency distribution, and sets the threshold value between the peaks.
Our invention is also a method for processing checks and other such negotiable instruments. The method of our invention achieves the same effects and benefits described herein.
Other objects and attainments together with a fuller understanding of the invention will become apparent and appreciated by referring to the following description and claims taken in conjunction with the accompanying drawings.
A preferred embodiment of the present invention is described below with reference to the accompanying figures.
The form trailing edge detector 116, form leading edge detector 119, and form ejection detector 124 are, for example, transmitting or reflecting type photodetectors enabling non-contact detection of the presence of a check at various positions along the check transportation path 115.
The form positioning member 120 temporarily stops a check inserted from the insertion opening 112 at a specific position, and is configured so that it can be changed by driving a solenoid or other type of actuator between a position where the actuator projects into and closes the check transportation path 115 and a position where the actuator is retracted from and opens the check transportation path 115.
The first feed roller pair 118 and second feed roller pair 122 are pairs of roller members positioned so that the rollers of each pair are on opposite sides of the check transportation path 115. A check can be transported in forward and reverse directions by appropriately driving one of the rollers. One roller in each pair can also be freely retracted from or advanced toward the other roller member so that the check transportation path 115 can be opened or closed by driving a solenoid or other actuator to appropriately retract or advance the rollers.
The magnetic head 117 is used to read the magnetic ink characters printed on the check face. Whether a check is valid or not is determined based on the data read by the magnetic head 117. As shown in
The front print head 123 is used for printing the payee, date, amount, and other check face data on the front of the check. This data is printed on the face printing areas 128 shown in
The back print head 121 is used for printing a customer verification number, date, amount, and other information required for endorsement by the store on the back of the check. This endorsement data is printed on an endorsement printing area 129 as shown in phantom in
The scanner 125 scans the face of a printed check. The scanned image data is sent to and stored in a host computer 200 (
The scanner feed roller 126 transports the check for the scanning operation, and presses the check against the scanning surface of the scanner 125 while transporting it toward the check exit 113. When not scanning, the scanner feed roller 126 retracts from the scanner 125 so that the check transportation path 115 is open. During the scanning operation the check is transported upward by the scanner feed roller 126 while the scanner 125 scans the check, and the check is then ejected from check exit 113. After the check is transported to the scanning start position by the first feed roller pair 118 and second feed roller pair 122 in the scanning operation, retraction of the scanner feed roller 126 is cancelled so that the check is pressed against the scanner 125 while the scanner feed roller 126 is driven to transport the check over the scanner 125 surface while it is scanned.
As shown in the figures, the first step in the first process control mode is to wait for insertion of a check P (S501). During this time the first and second feed roller pairs 118, 122 are held open, and the form positioning member 120 and scanner feed roller 126 are held closed. Note that if operation was previously in the second process control mode, the scanner feed roller 126 is open.
When a check P is inserted from insertion opening 112, check insertion is detected from the detection signals output by trailing edge detector 116 and leading edge detector 119 (
If the check is valid, the transportation motor 166 is driven in the form ejection direction (S510) to set the check for endorsement printing on the check back (S511,
When endorsement printing is completed, the check is set to the front printing position (S514,
When the check front printing process is completed the transportation motor 133 is again driven in the insertion opening 112 direction (S517) to set the check to the start scanning position (S518,
A check ejection decision (S523) is then made after the scanning process ends. If the check was ejected (
It should be noted that by controlling the transportation motor 133 synchronized to the scanner feed speed in the first process control mode, the check can be transported to the end of the scanning process with the first and second feed roller pairs 118, 122 closed.
As noted above, the second process control mode differs from the first process control mode in that the scanning process is not run in the second process control mode. More specifically, the check continues to be transported toward the exit in the second process control mode after the check front printing process ends, and check ejection is evaluated. Driving the transportation motor 133 stops and the form positioning member 120 is set to the closed position when it is determined that the check has been ejected. Removal of the check is then determined based on a detection signal from the form ejection detector 124, and the first second roller pairs 118, 122 are opened and the second process control mode ends when it is determined that the check has been removed.
The threshold value determination unit 12 calculates and sets the threshold value needed for the digitizing (binarization) process that generates the digital (binary) image data from the 256-level gray scale image data by using a provisional scanning controller 16 and threshold value calculator 17 under the control of a threshold value setting controller 15.
It should be noted that the image data that results from scanning is referred to herein as gray scale image data, meaning that the density of each sample is being expressed with some number of bits per sample, which is the precision of the sample. One example used herein is 256-level gray scale, which is 8-bit precision, but 4-bit, 10-bit or other bit precision could also be used. In the example used herein with 256-level gray scale, the value 0 represents maximum darkness and the value 255 represents maximum lightness.
The image capturing unit 13 generates and sends digital image data to the host computer by digitizing the gray scale image data using scanning controller 19, digital image processor 20, image storage unit 21, and communications unit 22, under the control of image capturing control unit 18.
Once the threshold values are determined, the scanning controller 19 controls and drives the image reading unit 11 to run an image reading process 37 for scanning and capturing the entire face side of the printed check using the scanner 125. It is also possible to scan and capture a predefined area including at least both the magnetic ink character recording area 127 and the face printing areas 128 instead of scanning the entire front of the check.
The digital image processor 20 then converts the gray scale image data captured by the image reading process 37 of the scanning controller 19 to digital image data by applying a digitizing process 38 to each pixel based on the threshold values determined by the threshold value determination unit 12.
The image storage unit 21 then runs a digital image storage process 39 to temporarily store the digital image data generated by the digitizing process 38 of the digital image processor 20, and the communications unit 22 runs a digital image transmission process 40 to send the temporarily stored digital image data to the host computer. It is, of course, also possible to send the digital image data directly to the host computer instead of providing an image storage unit 21 and digital image storage process 39.
The host computer stores the received digital image data with the electronic payment data in a searchable format in the image storage device of the host computer. The digital image data can also be compressed by the check processing apparatus 110 or the host computer. When processing and verifying an electronic payment, the payment clearing house can then read and reference a digital image of the check being processed from the image storage device.
It will be further noted that if the threshold values cannot be calculated for some reason, such as when the background pattern is dark, the image capturing process can be terminated and an error process run, or the gray scale image data can be sent directly to the host computer without thresholding.
The scanning process is described next.
The threshold values for the digitizing process are then calculated from the histogram (S103). A gray scale image of the entire check face is then captured by a final scanning operation (second scanning operation) (S104), and the digital image data is generated by a digitizing process using the calculated threshold values (S105). The resulting digital image data is temporarily stored in the image storage unit 21 and sent to the host computer (S106).
It should be noted that the provisional scanning process (S101) is not limited to being run within the scanning process (S522), and can be run simultaneously to the MICR process (S506) or the scanning start position process (S518). It is particularly preferable to provisionally scan the check P either during the MICR process (S506) before the front printing process (S516), or after the MICR process (S506) but before the front printing process (S516), in order to more accurately extract image features from the background 49 of the check.
The histogram generation process is described next.
An example of provisional scanning areas T (T′) is shown in
More specifically, the location where the magnetic ink characters are printed can be determined based on the height (s,c) in the direction of the short side of the check and the length of the magnetic ink character 48 string derived from the output signals of the magnetic head 117. This height (s,c) (that is, the length in the heightwise direction of the magnetic ink characters 48) is defined by the check printing standard, and the length of the MIC string is derived from the output signals of the magnetic head 117 because the number of magnetic ink characters is variable. It should be noted that the check P is inserted into the check processing apparatus 110 leading with the right side edge of the check, and the magnetic ink characters 48 are therefore read from the right-most digit to the left-most digit.
The provisional scanning area T is an area with a specific width (b) in the form transportation direction from the position where the first magnetic ink character is detected. The other provisional scanning area T′ is an area with the same specific width (b) in the transportation direction starting from a point separated a specific distance in the transportation direction from where the first magnetic ink character is detected. The provisional scanning areas T (T′) could alternatively be set to areas including text preprinted on other specified areas instead of using the magnetic ink characters 48.
The threshold value calculation process is described next.
The minimum limit PMin of the threshold value is first calculated from the histogram of the MIC area 70 (S301). The minimum limit PMin must be lighter than the density of the magnetic ink characters 48, and minimum limit PMin is therefore calculated based on the density of the magnetic ink characters 48 as further described below. If minimum limit PMin cannot be determined (S302 returns yes), an error handling process is run (S309).
MIC maximum limit PmMax, which is the highest lightness limit in the MIC area 70, is then obtained from the histogram of the MIC area 70 (S303). The MIC maximum limit PmMax is the limit at which it will not be possible to separate the background 49 from the magnetic ink characters 48 if the threshold value is set any lighter. If the MIC maximum limit PmMax cannot be determined (S304 returns yes), an error handling process is run (S309).
The background maximum limit PbMax, which is the highest limit in background areas 71 to 73, is then similarly obtained from the histograms of background areas 71 to 73 (S305). The background maximum limit PbMax is the limit at which it will not be possible to separate the background 49 from the magnetic ink characters 48 in the MIC area 70 if the threshold value is set any lighter. If the background maximum limit PbMax cannot be determined (S306 returns yes), an error handling process is run (S309).
The maximum limit PMax of the threshold value is determined next (S307). The smaller of MIC maximum limit PmMax and background maximum limit PbMax is made maximum limit PMax.
The threshold value is then calculated based on minimum limit PMin and maximum limit PMax.
An example of the averaging process is described next.
A preferred embodiment of the averaging process (S203) is described next. The total pixel count Y captured by provisional scanning can be obtained from
Y=f(0)+f(1)+ . . . f(255)
where pixel count y of density n (n=0, 1, . . . 255) is y=f(n).
The total pixel count Ym in MIC area 70 is
Ym=fm(0)+fm(1)+ . . . fm(255).
The total pixel counts Yb for the background areas 71 to 73 are
Yb1=fb1(0)+fb1(1)+ . . . +fb1(255)
Yb2=fb2(0)+fb2(1)+ . . . +fb2(255)
Yb3=fb3(0)+fb3(1)+ . . . +fb3(255).
The total pixel count Y is the sum of all pixels in the MIC area 70 and all pixels in background areas 71 to 73, and can therefore be written as
Y=Ym+Yb
Yb=Yb1+Yb2+Yb3.
The pixel data (density values) of the MIC area 70 are important in calculating the minimum limit of the threshold value, but the total pixel count in the MIC area 70 is small compared with the total pixel count in the background areas 71 to 73. The pixel data from the MIC area 70 is therefore weighted in order to calculate a more appropriate minimum limit PMin. An averaged histogram is therefore generated for the MIC area 70 after weighting. If a weighting of 2 is used, the pixel count yv of weighted density n for MIC area 70 is
yv=2fm(n)=fmv(n)
the total pixel count Ymv of the weighted MIC area 70 is
Ymv=fmv(0)+fmv(1)+ . . . +fmv(255)
and the weighted total pixel count Yt is
Yt=Ymv+Yb.
As noted above the averaging process is a process for averaging the pixel count of each density level based on the number of pixels of a particular density before and after each target pixel. To average the pixel count fmv(n) of level n in MIC area 70 using k pixels of some level before and after each pixel, the average pixel count fma(n) of level n can be expressed as shown in equation 1. Note that this example uses four pixels before and after a pixel of level n.
fma(n)=0(n<4, n>251)
The average level n pixel count fba(n) in background areas 71 to 73 can likewise be denoted as shown in equation 2.
fba(n)=0(n<4, n>251)
This averaging process removes noise from the histogram and can therefore accurately extract density levels characteristic of the image.
Calculation of minimum limit PMin is described next.
In this example pixels are counted in the histogram of MIC area 70 from level n=0 and minimum limit PMin is set at the point where the total number of pixels counted is 10% of the total pixel count. The relative frequency r(n) (=(number of level n pixels)/(total pixel count)) in MIC area 70 is therefore calculated using the equation
r(n)=fmv(n)/Ymv.
The highest value of n where r(n) satisfies the following equation is then set as minimum limit PMin.
It will be noted that minimum limit PMin is set to the level at which the pixel count is 10% of the total pixel count in this example and that this value is an experiential value determined from tests, but minimum limit PMin can be otherwise appropriately set.
Calculation of MIC maximum limit PmMax is described next.
MIC maximum limit PmMax determines the upper limit for converting pixels in the background 49 of MIC area 70 to white. The threshold value must therefore be set so that pixels in second peak 81 shown in
The peak density Pn1 of second peak 81 is approximately 145, and the pixel count (frequency) of each level n in the valley between peaks 80 and 81 is 10 to 15. By checking the pixel count of each density level from peak density Pn1 to the dark side (that is, toward the first peak 80 in the magnetic ink characters 48) and selecting level n having a pixel count of less than 30, it should be possible to remove the pixels constituting the background 49, and MIC maximum limit PmMax is therefore set to this level n. This pixel count of 30 for setting the MIC maximum limit PmMax was experimentally determined, and can be appropriately set otherwise. Similarly to the pixel count of 30 used in this example it is also possible to calculate from the histogram a pixel frequency that does not include most density levels of the pixels in the background 49 and can be differentiated from the pixel count in the valley between peaks 80 and 81.
MIC maximum limit PmMax can be determined as follows. If there are 2560 pixels each in MIC area 70 and background areas 71 to 73 shown in
fma(k)/Ymv<0.58%(k=Pn1, Pn1−1, Pn1−2, . . . ).
Calculation of background maximum limit PbMax is described next.
Background maximum limit PbMax can be calculated the same way as MIC maximum limit PmMax. More specifically, the peak density Pn2 of third peak 82 derived from the set of pixels forming the background 49 in background areas 71 to 73 is detected, the number of pixels of each level n where level n decreases from peak density Pn2 is counted, and the level n where pixel count n <30 is set as background maximum limit PbMax.
The total pixel count of background areas 71 to 73 is 2560×3=7680. The pixel count fba(n) of each level n where level n decreases from peak density Pn2 is counted in turn from peak density Pn2, and the level n where the pixel count is less than 0.39% (=30/7680) of total pixel count Yb of background areas 71 to 73 is set to the background maximum limit PbMax. PbMax is set to the first value k where
fba(k)/Yb<0.39% (k=Pn2, Pn2−1, Pn2−2, . . . ).
The smaller of MIC maximum limit PmMax and background maximum limit PbMax is set as maximum limit PMax.
Calculation of the threshold value R is described next.
Threshold value R is obtained using the following equation based on minimum limit PMin and maximum limit PMax.
R=PMin+(PMax−PMin)×0.58
That is, the threshold value is calculated to be a value closer to Pmin than the intermediate of minimum limit PMin and maximum limit PMax. This is to remove as much of the background pattern as possible. It should be noted that the coefficient 0.58 used in this example was determined experimentally, and can be appropriately set otherwise.
A second example for calculating minimum limit PMin and maximum limit PMax is discussed as follows, first with respect to creating an averaged histogram.
The histograms of the MIC area 70 and background areas 71 to 73 are averaged. The basic concept of this averaging process is as described above, but in this example the average density n is obtained using the seven pixels before and after the target pixel.
fma(n)=0(n<7, n>248)
fba(n)=0(n<7, n>248)
A histogram for MIC area 70 and background areas 71 to 73 is then compiled based on the average pixel counts fma(n) and fba(n) for each density level.
Calculation of the minimum limit PMin is described next.
The slope s of the histogram for MIC area 70 is obtained next using the following equation where x is the data interval and y is the averaged frequency (pixel count).
Using this slope s, the density satisfying the following conditions 1 to 4 is set as the minimum limit PMin.
s(i)×s(i+1)≦0 Condition 1
s(i+1)≧0 Condition 2
s(i)<0 Condition 3
The point satisfying conditions 1 to 3 is the point where slope s changes from negative to positive.
Condition 4 is that the cumulative relative frequency Tr1 totalling relative frequency r(n) from n=0 is at least 8% of the total where the ratio (relative frequency) r(n) of the pixel count of each density n to the total pixel count of the MIC area 70 is obtained using the next equation.
r(n)=fmv(n)/Ymv Condition 1
The reason for providing the fourth condition that cumulative relative frequency Tr1 is 8% is described next. A density level satisfying conditions 1 to 3 may be found before or at the first peak 80 of the histogram representing magnetic ink characters 48 if, for example, there is a higher density area than magnetic ink characters 48 because of soiling or other reason or the density of the magnetic ink characters 48 is not uniform. Therefore, even if there is a density level satisfying conditions 1 to 3, that level will not be set to minimum limit PMin if the pixel count for that level does not also exceed 8% of the dark pixels represented in the histogram. What percentage the cumulative relative frequency Tr1 is set to can be freely determined from experience or testing, for example.
Calculation of the MIC maximum limit PmMax is described next.
The first step is to calculate the slope s(i) of the histogram based on equation 6 above in the same way as for minimum limit PMin. As indicated by arrow sd2 in
s(i)×s(i−1)≦0 Condition 1
s(i−1)≦0 Condition 2
s(i−1)>0 Condition 3
The point satisfying conditions 1 to 3 is the point where slope s changes from negative to positive, and except for the search direction being opposite is the same as when determining minimum limit PMin.
Condition 4 is that the cumulative relative frequency Tr2 totalling relative frequency r(n) from n=255 is at least 74% of the total where the ratio (relative frequency) r(n) of the pixel count of each density n to the total pixel count of the MIC area 70 is obtained using the next equation.
r(n)=fmv(n)/Ymv Condition 4
The reason for providing the fourth condition that cumulative relative frequency Tr2 is 74% of the total is to prevent setting provisional MIC maximum limit Pm1Max before or at the second peak 81 of the histogram representing background 49 even if conditions 1 to 3 are satisfied. What percentage the cumulative relative frequency Tr2 is set to can be freely determined from experience or testing, for example.
The provisional MIC maximum limit Pm1Max is thus set as described above by searching the histogram sequentially from the right side, that is, the side and direction opposite those used when setting minimum limit PMin, as indicated by arrow sd2 in
The density level closest to Pm1Max that satisfies the following condition 5 is then searched from provisional MIC maximum limit Pm1Max and set as the true MIC maximum limit PmMax.
s(i)≧1(Pm1Max≦i≦255) Condition 1
Calculation of the maximum limit PMax is described next.
Background maximum limit PbMax is obtained using the same method as MIC maximum limit PmMax, and as in the first example above the smaller of MIC maximum limit PmMax and background maximum limit PbMax is set to maximum limit PMax.
As will be known from the above, the present invention dynamically sets a threshold value used to convert a gray scale image of the check to digital image data based on a part of the image considered characteristic of check features. It is therefore possible to obtain digital image data from which the magnetic ink character data and textual information written or printed on the check face and needed for electronic payment can be accurately determined.
Although the present invention has been described in connection with the preferred embodiments thereof with reference to the accompanying drawings, it is to be noted that various changes and modifications will be apparent to those skilled in the art. For example, the present invention shall not be limited to processing checks and can also be applied to other types of negotiable instruments. Such changes and modifications are to be understood as included within the scope of the present invention as defined by the appended claims, unless they depart therefrom.
Number | Date | Country | Kind |
---|---|---|---|
2001-312947 | Oct 2001 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5809167 | Al-Hussein | Sep 1998 | A |
5848182 | Kanamori | Dec 1998 | A |
5889885 | Moed et al. | Mar 1999 | A |
5953450 | Kanamori | Sep 1999 | A |
6064762 | Haenel | May 2000 | A |
6301386 | Zhu et al. | Oct 2001 | B1 |
6351566 | Zlotnick | Feb 2002 | B1 |
6411737 | Wesolkowski et al. | Jun 2002 | B1 |
6507670 | Moed | Jan 2003 | B1 |
6792133 | Ott et al. | Sep 2004 | B1 |
Number | Date | Country |
---|---|---|
0 677 817 | Oct 1995 | EP |
6-30264 | Feb 1994 | JP |
7-273996 | Oct 1995 | JP |
8-50633 | Feb 1996 | JP |
8-204963 | Aug 1996 | JP |
11-112796 | Apr 1999 | JP |
2001-86331 | Mar 2001 | JP |
Number | Date | Country | |
---|---|---|---|
20030068077 A1 | Apr 2003 | US |