The embodiments described herein relate to processing images of documents captured using a mobile device, and more particularly to real-time detection of the content of a financial document for use in mobile banking applications.
Banks and other businesses have become increasingly interested in electronic processing of check and other financial documents in order to expedite processing of these documents. Users can scan a copy of the document using a scanner or copier to create an electronic copy of the document that can be processed instead of a hardcopy original which would otherwise need to be physically sent to the recipient for processing. For example, some banks can process digital images of checks and extract check information from the image needed to process the check without requiring that the physical check be routed throughout the bank for processing. However, the type of information and the accuracy of information which can be processed from an image of a check are limited. As a result, some checks cannot be processed and are rejected during the mobile deposit process.
Mobile phones that incorporate cameras have also become ubiquitous and may also be useful to capture images of financial documents for mobile processing of financial information through a mobile network connection with a banking institution or business. However, the process of uploading images of financial documents is often prone to user error, as the user is often unaware of whether the document is complete and ready for processing by a business or financial institution. A user with a mobile phone or portable electronic device cannot interact with an employee of the bank in order to determine whether the financial document is ready to be processed.
Therefore, there is a need for the ability to obtain additional information from a digital image of a check which has been captured by a mobile device in order to streamline mobile banking applications and reduce the amount of transaction errors when a document is incomplete.
Systems and methods for processing an image of a check captured using a mobile device, such as a mobile phone, are provided. These techniques can be implemented on a mobile device and at a central server, and can be used to identify content on a check and determine whether the check is ready to be processed by a business or financial institution. The system can identify portions of the check—such as the endorsement area—to determine if the check has been properly endorsed. If the check lacks an endorsement, a real time notification can be provided to a user which uploaded the check image so the user can correctly endorse the check and upload a new check image. Additional portions of the check, including the signature line, the addressee field, etc. can be checked to ensure that the check is ready to be deposited by the bank.
According to one embodiment, a mobile check image processing system for identifying content in regions of an image of a check captured by a mobile device is provided. The system may comprise a preprocessing unit which receives an image of a check from a mobile device, selects a type of content to be detected on the check image, and identifies at least one region of interest (ROI); a testing unit which performs at least one content detection test on the at least one ROI to detect content of the selected type on the check image; and a feedback unit which receives a result of the at least one content detection test and provides the result to a user. The ROI may correspond to an endorsement region on a back side of the check.
According to another embodiment, a method of identifying content in regions of an image of a check captured by a mobile device is provided. The method may comprise receiving an image of a check from a mobile device; selecting a type of content to be detected on the check image; identifying at least one region of interest (ROI) on the check image; performing at least one content detection test on the at least one ROI to detect content of the selected type on the check image; and providing a result of the at least one content detection test to a user. The ROI may correspond to an endorsement region on a back side of the check.
According to yet another embodiment, a computer-implemented method for processing a mobile-captured image of a check embodied on a computer with a processor and a memory may comprise receiving an image of a check from a mobile device; selecting a type of content to be detected on the check image; identifying at least one region of interest (ROI) on the check image; performing at least one content detection test on the at least one ROI to detect content of the selected type on the check image; and providing a result of the at least one content detection test to a user. The ROI may correspond to an endorsement region on a back side of the check.
These and other features, aspects, and embodiments are described below in the section entitled “Detailed Description.”
Features, aspects, and embodiments are described in conjunction with the attached drawings, in which:
The following detailed description is directed to certain specific embodiments. However, it will be understood that these embodiments are by way of example only and should not be seen as limiting the systems and methods described herein to the specific embodiments, architectures, etc. In this description, reference is made to the drawings wherein like parts are designated with like numerals throughout.
Systems and methods for processing an image of a check captured using a mobile device, such as a mobile phone, are provided. These techniques can be implemented on a mobile device and at a central server, and can be used to identify content on a check and determine whether the check is ready to be processed by a business or financial institution. The system can identify portions of the check—such as the endorsement area—to determine if the check has been properly endorsed. If the check lacks an endorsement, a real time notification can be provided to a user which uploaded the check image so the user can correctly endorse the check and upload a new check image. Additional portions of the check, including the signature line, the addressee field, etc. can be checked to ensure that the check is ready to be deposited by the bank.
Differentiating between characteristics of checks provides additional information to a bank being asked to deposit the check as to the potential risk of the check being fraudulent. The risk of fraudulent checks varies depending on the characteristics of the check, and so a bank can set up various customized rules. If the check has a characteristic that is commonly associated with fraud, the bank may immediately deny the request, or request additional processing of the check image before deciding whether to deposit the check. The user is sent a message if the deposit is denied, and may be provided with instructions to manually deposit the check so that the bank can review the original check.
Content Identification
Once the ROIs are identified, the check image 106 is sent to a testing unit 112 to perform one or more content detection tests on the identified ROIs. In one embodiment, the preprocessing unit may send a sub-image of the check image 106 which contains only the identified ROIs in order to streamline the process by sending only the relevant ROIs that need to be tested. Sending the sub-image would be particularly beneficial if the preprocessing unit is located on the mobile device 102 and the testing unit is located on the MCIPS server 104, as the transmission of only the ROIs across a network would take less time. The testing unit 112 obtains content detection tests from a test and rules database 114 connected with the testing unit 112. The content detection tests are programs that identify specific content in the ROIs, such as an endorsement signature in an endorsement ROI. The content detection tests may identify the presence or absence of particular content or distinguish between one or more types of content in the ROI. For example, an endorsement content detection test may first identify whether an endorsement is present in the endorsement ROI, but will also determine the type of endorsement—such as a hand-written signature or a stamp.
In one embodiment, the content on the check can be manually entered by the user. The check content can be optionally provided by the user at the time that the check is captured. This check content can include various information from the check, such as the check amount, check number, routing information from the face of the check, or other information, or a combination thereof. In some embodiments, a mobile deposition application requests this information from a user of the mobile device, allows the user to capture an image of a check or to select an image of a check that has already been captured, or both, and the mobile deposit information provides the check image, the check content, and other processing parameters to the MCIPS 100.
Once the testing unit performs the appropriate content detection tests, the results of the tests are forwarded to a feedback unit 116 to analyze the results and provide appropriate feedback to the user or to a bank 118. If the endorsement content detection test determines that there is no endorsement on the check, the feedback unit 116 will generate a message to send back to the mobile device 102 telling the user that the endorsement is missing and perhaps requesting that the user endorse the check and upload a new image of the endorsed check. Or, if the endorsement is complete, the feedback unit 116 will generate and send a message to the mobile device 102 indicating that the check is properly endorsed and will be deposited in the user's account. The feedback unit 116 may also generate messages to send to the bank 118 which is receiving the deposited check. For example, the messages may indicate whether the check is ready to be deposited, if a problem has been detected which requires the bank to perform additional processing of the check image, or if the user needs to physically bring the check in.
The feedback unit 116 may generate messages by accessing a feedback message database 120 which stores the messages. The feedback message database 120 may also store rules for generating messages based on the results of the tests performed. In one embodiment, the bank 118 may configure the rules stored in the feedback message database 120 so that certain messages are sent to the bank or the user depending on the results of the tests performed.
The feedback unit 116 may also be configured to take a particular action that coincides with the message that is being delivered to the user or the bank. If an endorsement is not present on the check, the feedback unit 116 may also suspend the mobile deposit process and await a new check image from the user. Once the revised check image is received and the testing unit 112 returns a positive test confirming the presence of an endorsement, the feedback unit 116 reactivates the mobile deposit process and sends a message to the bank 118 that the check is ready to be deposited.
In certain embodiments, the mobile application can display information on the mobile device shortly after the user takes the mobile document image to allow the user to retake the image if the image is found to have defects that affect the overall status of the image. In some embodiments, where the MCIPS 100 is implemented at least in part on the mobile device, the MCIPS 100 can include a user interface module that is configured to display the test results message on a screen of the mobile device 102.
If the endorsement test is selected (“Endorsement”), the next step is step 215 to identify a region of interest (ROI) where the endorsement would be present on the check. In many situations, the ROI is on the back of the check in an endorsement area (see
If the “Other Type” test is selected at step 210, a region of interest (ROI) on the check image is identified in step 250 where the other type content would be indicated. In step 255, a content detection test is run on the identified ROI to determine characteristics of the other type. Once the characteristics of the other type have been identified, the characteristics are evaluated in step 260 based on processing rules established for the other type. For example, the processing rule could check for a proper signature by a payer.
According to some embodiments, the systems and methods for identifying content of a check can be integrated with one or more mobile applications that process mobile document images, such as mobile deposit applications for processing images of checks to be deposited into a bank account. According to an embodiment, the mobile application can run on the mobile device and can be integrated to use mobile image quality assurance functionality that is implemented on the mobile device and/or on a remote server. The mobile application can use the system for identifying content of a check to streamline the mobile deposit process.
MICR-Line Test
In one embodiment, an image of a check can be rejected if the MICR-line on the check cannot be clearly detected in the image. MICR stands for Magnetic Ink Character Recognition. Information can be printed on the front of a check in a special typeface using a special magnetized ink. Therefore, the MICR-line test is useful to determine which side of the check is in a check image before a region of interest (ROI) is selected. A MICR IQA test can use optical character recognition techniques to identify the MICR information on a check. If the MICR line on the front of the check is damaged, simply retaking an image of the check will not correct the defects in the image and the image will be rejected; however, if the MICR line was merely blurry or unreadable due to one or more of the factors described above, retaking the image after correcting one or more of factors may result in a high-enough quality image that the MICR line can be read from the check.
Front-as-Rear Test
An image of the rear of the check is received (step 605) and the image is converted to a bitonal snippet by preprocessing unit 108 of the MCIPS 100 (step 610). A MICR recognition engine is then applied to identify a MICR-line in the bitonal snippet (step 615). The results from the MICR recognition engine can then be normalized to the 0-1000 scale used by the mobile IQA tests, and the normalized value compared to a threshold value associated with the test (step 620). According to an embodiment, the test threshold can be provided as a parameter to the test along with the with mobile document image to be tested. According to an embodiment, the threshold used for this test is lower than the threshold used in the MICR-line Test described above.
If the normalized test result equals or exceeds the threshold, then the image includes an MICR-line and the test is marked as failed (test result value=0), because a MICR line was identified in what was purported to be an image of the back of the check. If the normalized test result is less than the threshold, the image did not include a MICR line and the test is marked as passed (test result value=1000). The test results value is then returned (step 625).
The mobile device 700 also includes an image capture component 730, such as a digital camera. According to some embodiments, the mobile device 700 is a mobile phone, a smart phone, or a PDA, and the image capture component 730 is an integrated digital camera that can include various features, such as auto-focus and/or optical and/or digital zoom. In an embodiment, the image capture component 730 can capture image data and store the data in memory 720 and/or data storage 740 of the mobile device 700.
Wireless interface 750 of the mobile device can be used to send and/or receive data across a wireless network. For example, the wireless network can be a wireless LAN, a mobile phone carrier's network, and/or other types of wireless network.
I/O interface 760 can also be included in the mobile device to allow the mobile device to exchange data with peripherals such as a personal computer system. For example, the mobile device might include a USB interface that allows the mobile to be connected to USB port of a personal computer system in order to transfers information such as contact information to and from the mobile device and/or to transfer image data captured by the image capture component 730 to the personal computer system.
Those of skill in the art will appreciate that the various illustrative modules, components, engines, and method steps described in connection with the above described figures and the embodiments disclosed herein can often be implemented as electronic hardware, software, firmware or combinations of the foregoing. To clearly illustrate this interchangeability of hardware and software, various illustrative modules and method steps have been described above generally in terms of their functionality. Whether such functionality is implemented as hardware or software depends upon the particular application and design constraints imposed on the overall system. Skilled persons can implement the described functionality in varying ways for each particular application, but such implementation decisions should not be interpreted as causing a departure from the scope of the invention. In addition, the grouping of functions within a module or step is for ease of description. Specific functions can be moved from one module or step to another without departing from the invention.
Moreover, the various illustrative modules, components, modules, engines, and method steps described in connection with the embodiments disclosed herein can be implemented or performed with hardware such as a general purpose processor, a digital signal processor (“DSP”), an application specific integrated circuit (“ASIC”), field programmable gate array (“FPGA”) or other programmable logic device, discrete gate or transistor logic, discrete hardware components, or any combination thereof designed to perform the functions described herein. A general-purpose processor is hardware and can be a microprocessor, but in the alternative, the processor can be any hardware processor or controller, microcontroller. A processor can also be implemented as a combination of computing devices, for example, a combination of a DSP and a microprocessor, a plurality of microprocessors, one or more microprocessors in conjunction with a DSP core, or any other such configuration.
Additionally, the steps of a method or algorithm and the functionality of a component, engine, or module described in connection with the embodiments disclosed herein can be embodied directly in hardware, in software executed by a processor, or in a combination of the two. Software can reside in computer or controller accessible computer-readable storage media including RAM memory, flash memory, ROM memory, EPROM memory, EEPROM memory, registers, hard disk, a removable disk, a CD-ROM, or any other form of storage medium including a network storage medium. An exemplary storage medium can be coupled to the processor such the processor can read information from, and write information to, the storage medium. In the alternative, the storage medium can be integral to the processor. The processor and the storage medium can also reside in an ASIC.
Referring now to
Computing module 1900 might also include one or more memory modules, referred to as main memory 1908. For example, random access memory (RAM) or other dynamic memory might be used for storing information and instructions to be executed by processor 1904. Main memory 1908 might also be used for storing temporary variables or other intermediate information during execution of instructions by processor 1904. Computing module 1900 might likewise include a read only memory (“ROM”) or other static storage device coupled to bus 1902 for storing static information and instructions for processor 1904.
The computing module 1900 might also include one or more various forms of information storage mechanism 1910, which might include, for example, a media drive 1912 and a storage unit interface 1920. The media drive 1912 might include a drive or other mechanism to support fixed or removable storage media 1914. For example, a hard disk drive, a floppy disk drive, a magnetic tape drive, an optical disk drive, a CD or DVD drive (R or RW), or other removable or fixed media drive. Accordingly, storage media 1914 might include, for example, a hard disk, a floppy disk, magnetic tape, cartridge, optical disk, a CD or DVD, or other fixed or removable medium that is read by, written to or accessed by media drive 1912. As these examples illustrate, the storage media 1914 can include a computer usable storage medium having stored therein particular computer software or data.
In alternative embodiments, information storage mechanism 1910 might include other similar instrumentalities for allowing computer programs or other instructions or data to be loaded into computing module 1900. Such instrumentalities might include, for example, a fixed or removable storage unit 1922 and an interface 1920. Examples of such storage units 1922 and interfaces 1920 can include a program cartridge and cartridge interface, a removable memory (for example, a flash memory or other removable memory module) and memory slot, a PCMCIA slot and card, and other fixed or removable storage units 1922 and interfaces 1920 that allow software and data to be transferred from the storage unit 1922 to computing module 1900.
Computing module 1900 might also include a communications interface 1924. Communications interface 1924 might be used to allow software and data to be transferred between computing module 1900 and external devices. Examples of communications interface 1924 might include a modem or softmodem, a network interface (such as an Ethernet, network interface card, WiMedia, IEEE 802.XX or other interface), a communications port (such as for example, a USB port, IR port, RS232 port Bluetooth® interface, or other port), or other communications interface. Software and data transferred via communications interface 1924 might typically be carried on signals, which can be electronic, electromagnetic (which includes optical) or other signals capable of being exchanged by a given communications interface 1924. These signals might be provided to communications interface 1924 via a channel 1928. This channel 1928 might carry signals and might be implemented using a wired or wireless communication medium. These signals can deliver the software and data from memory or other storage medium in one computing system to memory or other storage medium in computing system 1900. Some examples of a channel might include a phone line, a cellular link, an RF link, an optical link, a network interface, a local or wide area network, and other wired or wireless communications channels.
Computing module 1900 might also include a communications interface 1924. Communications interface 1924 might be used to allow software and data to be transferred between computing module 1900 and external devices. Examples of communications interface 1924 might include a modem or softmodem, a network interface (such as an Ethernet, network interface card, WiMAX, 802.XX or other interface), a communications port (such as for example, a USB port, IR port, RS232 port, Bluetooth interface, or other port), or other communications interface. Software and data transferred via communications interface 1924 might typically be carried on signals, which can be electronic, electromagnetic, optical or other signals capable of being exchanged by a given communications interface 1924. These signals might be provided to communications interface 1924 via a channel 1928. This channel 1928 might carry signals and might be implemented using a wired or wireless medium. Some examples of a channel might include a phone line, a cellular link, an RF link, an optical link, a network interface, a local or wide area network, and other wired or wireless communications channels.
In this document, the terms “computer program medium” and “computer usable medium” are used to generally refer to physical storage media such as, for example, memory 1908, storage unit 1920, and media 1914. These and other various forms of computer program media or computer usable media may be involved in storing one or more sequences of one or more instructions to a processing device for execution. Such instructions embodied on the medium, are generally referred to as “computer program code” or a “computer program product” (which may be grouped in the form of computer programs or other groupings). When executed, such instructions might enable the computing module 1900 to perform features or functions of the present invention as discussed herein.
While certain embodiments have been described above, it will be understood that the embodiments described are by way of example only. Accordingly, the systems and methods described herein should not be limited based on the described embodiments. Rather, the systems and methods described herein should only be limited in light of the claims that follow when taken in conjunction with the above description and accompanying drawings.
This application is a continuation of U.S. patent application Ser. No. 13/488,349, now U.S. Pat. No. 9,842,331, filed on Jun. 4, 2012, which is a continuation-in-part of U.S. patent application Ser. No. 12/906,036, filed on Oct. 15, 2010, now U.S. Pat. No. 8,577,118, which is a continuation-in-part of U.S. patent application Ser. No. 12/778,943, filed on filed May 12, 2010, now U.S. Pat. No. 8,582,862. U.S. patent application Ser. No. 13/488,349 is also a continuation-in-part of U.S. patent application Ser. No. 12/346,026, filed on Dec. 30, 2008, now U.S. Pat. No. 7,978,900, which claims the benefit of U.S. Provisional Patent Application No. 61/022,279, filed on Jan. 18, 2008, all of which are hereby incorporated by reference in their entirety.
Number | Name | Date | Kind |
---|---|---|---|
5966473 | Takahashi | Oct 1999 | A |
6038351 | Rigakos | Mar 2000 | A |
7426316 | Vehvilainen | Sep 2008 | B2 |
7584128 | Mason et al. | Sep 2009 | B2 |
7735721 | Ma | Jun 2010 | B1 |
7869098 | Corso et al. | Jan 2011 | B2 |
7873200 | Oakes, III | Jan 2011 | B1 |
7876949 | Oakes, III | Jan 2011 | B1 |
7978900 | Nepomniachtchi et al. | Jul 2011 | B2 |
8358826 | Medina, III | Jan 2013 | B1 |
8538124 | Harpel | Sep 2013 | B1 |
8959033 | Oakes, III | Feb 2015 | B1 |
9058512 | Medina, III | Jun 2015 | B1 |
9613258 | Chen et al. | Apr 2017 | B2 |
9842331 | Nepomniachtchi | Dec 2017 | B2 |
10360447 | Nepomniachtchi et al. | Jul 2019 | B2 |
20040017947 | Yang | Jan 2004 | A1 |
20040037448 | Brundage | Feb 2004 | A1 |
20040109597 | Lugg | Jun 2004 | A1 |
20050097046 | Singfield | May 2005 | A1 |
20050180661 | El Bernoussi et al. | Aug 2005 | A1 |
20050220324 | Klein et al. | Oct 2005 | A1 |
20060045322 | Clarke et al. | Mar 2006 | A1 |
20060045344 | Paxton et al. | Mar 2006 | A1 |
20060177118 | Ibikunle | Aug 2006 | A1 |
20070009155 | Potts et al. | Jan 2007 | A1 |
20070086643 | Spier | Apr 2007 | A1 |
20070154071 | Lin | Jul 2007 | A1 |
20070168382 | Tillberg | Jul 2007 | A1 |
20070206877 | Wu et al. | Sep 2007 | A1 |
20070211964 | Agam | Sep 2007 | A1 |
20070288382 | Narayanan et al. | Dec 2007 | A1 |
20070297664 | Blaikie | Dec 2007 | A1 |
20080174815 | Komaki | Jul 2008 | A1 |
20080183576 | Kim et al. | Jul 2008 | A1 |
20090063431 | Erol et al. | Mar 2009 | A1 |
20090185736 | Nepomniachtchi | Jul 2009 | A1 |
20090185737 | Nepomniachtchi | Jul 2009 | A1 |
20090198493 | Hakkani-Tur et al. | Aug 2009 | A1 |
20100102119 | Gustin | Apr 2010 | A1 |
20100114765 | Gustin | May 2010 | A1 |
20100114766 | Gustin | May 2010 | A1 |
20100114771 | Gustin | May 2010 | A1 |
20100114772 | Gustin | May 2010 | A1 |
20100200660 | Moed | Aug 2010 | A1 |
20100208282 | Isaev | Aug 2010 | A1 |
20110013822 | Meek | Jan 2011 | A1 |
20110052065 | Nepomniachtchi et al. | Mar 2011 | A1 |
20110091092 | Nepomniachtchi | Apr 2011 | A1 |
20110280450 | Nepomniachtchi et al. | Nov 2011 | A1 |
20120010885 | Hakkani-Tr et al. | Jan 2012 | A1 |
20120030104 | Huff | Feb 2012 | A1 |
20120033892 | Blenkhorn et al. | Feb 2012 | A1 |
20120070062 | Houle | Mar 2012 | A1 |
20120150773 | DiCorpo et al. | Jun 2012 | A1 |
20120197640 | Hakkani-Tr et al. | Aug 2012 | A1 |
20120230577 | Calman | Sep 2012 | A1 |
20120278336 | Malik et al. | Nov 2012 | A1 |
20130058531 | Hedley et al. | Mar 2013 | A1 |
20130120595 | Roach et al. | May 2013 | A1 |
20140040141 | Gauvin | Feb 2014 | A1 |
20140126790 | Duchesne et al. | May 2014 | A1 |
20140133767 | Lund et al. | May 2014 | A1 |
Number | Date | Country |
---|---|---|
1020070115834 | Dec 2007 | KR |
Entry |
---|
Office Action for related CA Patent Application No. 2,773,730, dated Aug. 21, 2017, in 4 pages. |
International Search Report issued in International Application No. PCT/US2011/056593 dated May 30, 2012 (3 pages). |
Office Action dated Sep. 25, 2019 for related U.S. Appl. No. 16/518,815, in 10 pages. |
Number | Date | Country | |
---|---|---|---|
20180101836 A1 | Apr 2018 | US |
Number | Date | Country | |
---|---|---|---|
61022279 | Jan 2008 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13488349 | Jun 2012 | US |
Child | 15838088 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12906036 | Oct 2010 | US |
Child | 13488349 | US | |
Parent | 12778943 | May 2010 | US |
Child | 12906036 | US | |
Parent | 12346026 | Dec 2008 | US |
Child | 13488349 | US | |
Parent | 12778943 | May 2010 | US |
Child | 12346026 | US |