Benefit is claimed under 35 U.S.C. 119(a)-(d) to Foreign application Serial No. 2185/CHE/2010 entitled “SYSTEM AND METHOD FOR USING PAPER AS AN INTERFACE TO COMPUTER APPLICATIONS” by Hewlett-Packard Development Company, L.P., filed on Jul. 31, 2010, which is herein incorporated in its entirety by reference for all purposes.
Paper can be a very useful and simple on-ramp to computing for non-tech savvy users prior to using computer applications. Even for those who are computer savvy, paper can help simplify the overall experience when using the computer applications.
Multifunction devices, also known as All-In-One (AiO) devices, connected to personal computers (PCs) and PCs including cameras that can enable paper as an interface are becoming popular, both for the home and the office. Such devices as part of their basic functions of printing, etc., can also scan and/or camera capture pointed data in papers. For example, in the case of an AiO connected to a PC, with the PC normally acting as a master sending data to be printed on the AiO or the PC acting as a slave receiving data that is scanned from the AiO, the AiO could further enable much simpler interfaces to the PC. For example, a scanned paper using well defined handwritten annotations can trigger computer applications on a PC and also provide data from the scanned paper to the triggered computer applications.
The existing techniques describe scanning data in paper and linking to computer applications residing in PCs, however, they do not go beyond linking the computer applications residing in PCs, i.e., they do not provide scanned data from the scanned paper to the triggered computer applications. Further, the existing techniques do not provide simpler interfaces where paper can use the well defined handwritten annotations to provide data to applications and perform subsequent actions that can be carried out by the applications.
Various embodiments are described herein with reference to the drawings, wherein:
The drawings described herein are for illustration purposes only and are not intended to limit the scope of the present subject matter in any way.
A system and method for using paper as an interface to computer applications is disclosed. In the following detailed description of the embodiments of the invention, reference is made to the accompanying drawings that form a part hereof, and in which are shown by way of illustration specific embodiments in which the invention may be practiced. These embodiments are described in sufficient detail to enable those skilled in the art to practice the invention, and it is to be understood that other embodiments may be utilized and that changes may be made without departing from the scope of the present invention. The following detailed description is, therefore, not to be taken in a limiting sense, and the scope of the present invention is defined by the appended claims.
The process of scanning or camera capturing content in a document and linking one or more computer applications described herein analyzes the content in the scanned and/or camera captured document, links it to the one or more computer applications, and carries out subsequent operations/actions associated with the one or more computer applications based on the analysis of the scanned and/or camera captured content. Further, in one embodiment, the process analyzes content provided in a standard format that can be imported by a third party computer application, such as sending data to a web-application from the scanned content that is in standard format.
According to another embodiment of the present invention, a pre-defined form may also be used to interface with a computer application. The pre-defined form is imaged for interpreting pre-defined handwritten commands, associated syntax and data entered in the pre-defined form. Further, data entered in the pre-defined form may be extracted by matching the imaged content in the pre-defined form with a template of the computer application. Using the extracted data, the computer application may be executed. The extracted data is also imported into the computer application. In other words, the process analyzes content provided in the pre-defined form that can be imported by a third party computer application, such as sending data to a web-application.
The terms “paper” and “document” are used interchangeably throughout the description. Also, the terms “application” and “computer application” are used interchangeably throughout the description. Further, the term “annotations” refers to at least one of pre-defined handwritten commands, associated syntax, one or more computer application identifiers and pointed data on the paper/pre-defined form.
In one example embodiment, the content in the paper is imaged by scanning the content in the paper for detecting and interpreting the pre-defined handwritten commands, the one or more computer application identifiers, the associated syntax and the pointed data. For example, the content in the paper may be scanned using an All-in-One (AiO) device for detecting and interpreting the pre-defined handwritten commands, the one or more computer application identifiers, the associated syntax and the pointed data. The AiO device may include a scanner or other user input devices having capability to scan the content in the paper.
In another example embodiment, the content in the paper is imaged by camera capturing the content in the paper for detecting and interpreting the pre-defined handwritten commands, the one or more computer application identifiers, the associated syntax and the pointed data. For example, the content in the paper is camera captured using a camera disposed on a personal computer for interpreting the pre-defined handwritten commands, the one or more computer application identifiers, the associated syntax and the pointed data. The content in the paper can also be camera captured using a webcam, a mobile device having a camera, and so on.
At step 104, the imaged content is analyzed to identify the pre-defined handwritten commands, one or more computer applications associated with the one or more computer application identifiers, the associated syntax and the pointed data. In one example embodiment, the imaged content is analyzed using algorithms selected from the group consisting of an ink extraction algorithm, optical character recognition (OCR) algorithm, handwriting recognition (HWR) algorithm, handwritten keyword selection algorithm, and bar code extraction algorithm.
In accordance with the above described embodiments with respect to steps 102 and 104, a user can scan or camera capture content in a document (e.g., paper) that contains handwritten commands indicating the launch of a specific computer application.
At step 106, the pointed data is extracted into a specified format associated with the one or more computer applications. Exemplary computer applications include EXCEL, GIMP, WORD, EMAIL, PPT, Notepad, and so on. The computer applications can also include but not limited to mobile applications. In one embodiment, the user may add annotations for selecting data (e.g., pointed data 208 of
Further, the extracted data is then ‘intelligently’ mapped to data input required for the computer application. In one example embodiment, in case of a text block (e.g., printed text) being sent to a word processing application, the data may just be sent as input to the computer application. In another embodiment, in case of a handwritten text (e.g., handwritten table of
Once data is extracted from the scanned document, the AiO device may prompt the user to review the extracted results. In one example embodiment, a mechanism could be provided for the user to accept the data, alter the data, or reject the data. In another example embodiment, a default action may be performed such as sending the image or the data to the computer application without user review.
At step 108, the one or more computer applications are executed based on the identified pre-defined handwritten commands, the one or more computer application identifiers and the associated syntax. At step 110, the extracted pointed data is imported into the one or more executed computer applications. For example,
In accordance with the steps 108 and 110, several methods are documented to enable the entry of data from one computer application to another computer application. Such methods can also be utilized to transfer data from the AiO device to a computer application residing on the personal computer (PC). For example, the Microsoft clipboard format [i.e., Microsoft clipboard] provides details of how to export data from a non-Microsoft application into a Microsoft application. Once the AiO device determines a target computer application (i.e., the computer application to be launched), it will convert extracted data in the step 106 into a format suitable for the target computer application using such established standards. The AiO device may also export data extracted from step 106 in a publicly-declared format using methods such as extensible markup language (XML), and so on. Further, the computer applications can write suitable plug-ins to accept the XML formatted data being sent from the AiO device.
In yet another embodiment, the scanned document may be processed in batch mode and data sent to a computer application that is on a cloud. For example, a user may choose to process several documents like bills and input them into an accounting application in the cloud. In this case, information is extracted in batch mode and the computer application on the cloud, such as a SAP database is populated. The computer application can also be a Cloud Service, such as a personal expense application [MINT] hosted as Service on the Cloud.
In another embodiment, a pre-defined form including content can also be used to interface with a computer application. In this case, the content in the pre-defined form, filled data entered in the pre-defined form, and an associated computer application is imaged. For example, the content in the pre-defined form is imaged by scanning or by camera capturing the content in the pre-defined form for identifying and interpreting the annotations and the filled data. The annotations include commands and the computer applications/uniform resource locator (URL). An example of pre-defined form is explained in greater detail in
In these embodiments, application providers may choose to provide users with pre-defined forms for different computer applications. Once the user fills out the pre-defined form, the pre-defined form can be processed by the AiO device as described above. In case of such pre-printed forms or pre-defined forms, an annotation indicating the computer application may be replaced by specific machine readable information. In these embodiments, an agent resides on a personal computer (PC) or wherever the computer application is residing to collect or store the information associated with the computer application received from this step in order to launch the appropriate computer application. In one example embodiment, the computer application can include a web-application.
Further, the filled data entered in the pre-defined form is extracted by matching the imaged content in the pre-defined form with a template of a blank form including known field IDs. In these embodiments, the pre-defined form is matched against the template for the computer application and information is extracted and provided in a pre-defined format specified for that computer application. For example, the pre-defined form provides some options such as check boxes which allow interactions which would have otherwise needed complex menu navigation and selection to be made easier by check extracting and recognizing these annotations. The pre-defined form may also include a template that matches an electronic layout. For example, a table on the form could match the cells of a spreadsheet that needs to be created.
Furthermore, the imaged content is analyzed to identify annotations. Also, the computer application is executed based on the identified annotations. In addition, the extracted filled data entered in the pre-defined form is imported into the executed computer application.
In these embodiments, the pre-defined forms can also be created by an authoring tool. For example, the authoring tool allows the user to design/create these forms and map contents of the forms to an XML format that needs to be generated once the information from the form is extracted. If the user is not using the pre-defined forms the authoring tool can be used to define the XML format where the extracted data from paper needs to be matched against during this step.
In yet another embodiment, application providers may choose to provide users with pre-formatted paper forms (i.e., pre-defined forms). Once the user fills out this form, the form can be processed by the AiO device using steps described above. In the case of such pre-printed forms, the annotation indicating the computer application may be replaced by specific markings on the form. These markings could be a bar-code, a specific format of the form, logos or other artifacts. The user may indicate the presence of such markings to trigger the computer application. In these embodiments, the AiO device may also need to provide user interface choices to specify the PC to which the data has to be sent. If a scanner is attached to a single PC (for example USB), data could be sent to the connected PC. If the scanner is connected to a network, the user can specify the PC by keying in the IP address or other unique identifier for the PC.
As illustrated in
In the example embodiment illustrated in
Further, the imaged/scanned document 200 is analyzed to identify the launch and send commands 202 and 206, a computer application associated with the computer application identifier “excel” 204, and the pointed data 208. Furthermore, the pointed data 208 is extracted and mapped to a grammar of the specified format associated with the computer application. For example, the computer application illustrated in
In the example embodiment illustrated in
In the example embodiment illustrated in
In the example embodiment illustrated in
In another embodiment, the data in the scanned document can be sent to more than one computer application based on the identified pre-defined handwritten commands, the one or more computer application identifiers and the associated syntax. For example, the pointed data 508 within the square brackets can be sent to an email application and the pointed data 512 within the square brackets can be sent to a Microsoft® word application and so on using multiple handwritten commands and associated computer application identifiers in the document.
In the example embodiment illustrated in
Once the data is filled, the content in the pre-defined form, filled data entered in the pre-defined form, and an associated computer application is imaged. In one example embodiment, the content in the pre-defined form is imaged by scanning the content in the pre-defined form for identifying and interpreting the annotations and the filled data. In another example embodiment, the content in the pre-defined form is imaged by camera capturing the content in the pre-defined form for identifying and interpreting the annotations and the pointed data. For example, the annotations include commands and the computer applications/uniform resource locator (URL).
Further, the filled data entered in the pre-defined form is extracted by matching the imaged content in the pre-defined form with a template of a blank form including the known field IDs for the computer or web based application. Further, the imaged content is analyzed to identify annotations such as “launch” 702 followed by “URL” 704. The URL in this example includes “www.irctc.co.in”. Further, the web application “www.irctc.co.in” is executed based on the identified annotations. In addition, the extracted filled data entered in the pre-defined form is imported into the executed web application.
A general computing system 802, in the form of a personal computer or a mobile device may include a processor 804, memory 806, a removable storage 818, and a non-removable storage 820. The computing system 802 additionally includes a bus 814, a network interface 816 and a webcam 822. The computing system 802 may include or have access to the computing system environment 800 that includes a paper content capture system 824, one or more output devices 832, and one or more communication connections 840 such as a network interface card or a universal serial bus connection.
The paper content capture system 824 includes an All-in-One (AiO) device 828, a camera 830, and/or one or more user input devices 826. The one or more user input devices 826 may be a digitizer screen and a stylus, trackball, keyboard, keypad, mouse, and the like. The one or more user input devices 826 may also include a mobile device having a camera. The one or more output devices 832 may be a display device of the personal computer or the mobile device. The communication connections 840 may include a local area network, a wide area network, and/or other networks.
The memory 806 may include volatile memory 808 and non-volatile memory 810. A variety of computer-readable storage media may be stored in and accessed from the memory elements of the computing system 802, such as the volatile memory 808 and the non-volatile memory 810, the removable storage 818 and the non-removable storage 820. Computer memory elements may include any suitable memory device(s) for storing data and machine-readable instructions, such as read only memory, random access memory, erasable programmable read only memory, electrically erasable programmable read only memory, hard drive, removable media drive for handling compact disks, digital video disks, diskettes, magnetic tape cartridges, memory cards, Memory Sticks™, and the like.
The processor 804, as used herein, means any type of computational circuit, such as, but not limited to, a microprocessor, a microcontroller, a complex instruction set computing microprocessor, a reduced instruction set computing microprocessor, a very long instruction word microprocessor, an explicitly parallel instruction computing microprocessor, a graphics processor, a digital signal processor, or any other type of processing circuit. The processor 804 may also include embedded controllers, such as generic or programmable logic devices or arrays, application specific integrated circuits, single-chip computers, smart cards, and the like.
Embodiments of the present subject matter may be implemented in conjunction with program modules, including functions, procedures, data structures, and application programs, for performing tasks, or defining abstract data types or low-level hardware contexts. Machine-readable instructions stored on any of the above-mentioned storage media may be executable by the processor 804 of the computing system 802. For example, a computer program 812 may include machine-readable instructions capable of using paper to interface with one or more computer applications, according to the teachings and herein described embodiments of the present subject matter. In one embodiment, the computer program 812 may be included on a compact disk-read only memory (CD-ROM) and loaded from the CD-ROM to a hard drive in the non-volatile memory 810. The machine-readable instructions may cause the computing system 802 to encode according to the various embodiments of the present subject matter.
As shown, the computer program 812 includes a paper to computer applications interface module 834. The paper to computer applications interface module 834 further includes an authoring tool 836 and a data transport driver 838.
In one embodiment, the system 800 includes a network (e.g., the communications connections 840), the paper content capture system 824, the processor 804 coupled to the paper content capture system 824 via the network. In these embodiments, the network may be a wireless or wired network.
Further, as described above, the system 800 also includes the paper to computer applications interface module 834. Furthermore, the paper to computer applications interface module 834 includes the authoring tool 836 for allowing a user to create user defined handwritten commands. In these embodiments, the authoring tool 836 is capable of authoring the user defined handwritten commands for mapping data to the computer application. In one embodiment, the user may define the handwritten commands and map the handwritten commands as required. For example, “From”, “To”, “Body” can be used to mark content for an email application. These handwritten commands could also for instance be commands in local languages that can be customized by the user. In another embodiment, the authoring tool 836 allows templates to be authored for different computer applications. For example, a predefined form for sending an email can be authored to be used by the user with or without the handwritten commands. In yet another embodiment, the authoring tool 836 can read a format of the handwritten commands that is acceptable by an electronic application such as XML format (e.g., which specifies “From”, “To” and “Body” for an email application), and allows the user to map the handwritten commands and content to this format.
The system 800 also includes the memory 806 operatively coupled to the processor 804. For example, the memory 806 includes the user defined handwritten commands and pre-defined handwritten commands. The memory 806 also includes the paper to computer applications interface module 834 having instructions capable of imaging content in the paper using the paper content capture system 824. The content includes handwritten commands, associated syntax, one or more computer application identifiers and pointed data.
The instructions further capable of identifying the handwritten commands, one or more computer applications associated with the one or more computer application identifiers, the associated syntax and the pointed data using the paper to computer applications interface module 834. Further, the instructions capable of mapping the identified handwritten commands to handwritten commands selected from the group consisting of the user defined handwritten commands and the pre-defined handwritten commands using the authoring tool 836.
Also, the instructions capable of extracting the pointed data into a specified format associated with the one or more computer applications using the paper to computer applications interface module 834, executing the one or more computer applications based on the identified and mapped pre-defined handwritten commands, the one or more computer application identifiers and the associated syntax using the paper to computer applications interface module 834, and importing the extracted pointed data into the one or more executed computer applications using the data transport driver 838 in the paper to computer applications interface module 834.
For example, the paper to computer applications interface module 834 may be in the form of instructions stored on a non-transitory computer-readable storage medium. The non-transitory computer-readable storage medium having the instructions that, when executed by the computing system 802, may cause the computing system 802 to perform one or more methods described in
In various embodiments, the systems and methods described in
Further, the above described systems and methods for filling out a pre-printed form could allow a user to provide instructions in a local language thus enabling easier interfacing to the application. Furthermore, the above described systems and methods allow extracted data to be exported in a public format that can be used by third-party applications. Currently, the only information sent out by the AiO device is the image itself, with some minimal meta-data in the case of digital sending devices. The exported data from the AiO device could include enhanced meta-data such as user intent regarding a target application, recognized handwritten content on the document, or recognized document content.
Although the present embodiments have been described with reference to specific example embodiments, it will be evident that various modifications and changes may be made to these embodiments without departing from the broader spirit and scope of the various embodiments. Furthermore, the various devices, modules, analyzers, generators, and the like described herein may be enabled and operated using hardware circuitry, for example, complementary metal oxide semiconductor based logic circuitry, firmware, software and/or any combination of hardware, firmware, and/or software embodied in a machine readable medium. For example, the various electrical structure and methods may be embodied using transistors, logic gates, and electrical circuits, such as application specific integrated circuit.
Number | Date | Country | Kind |
---|---|---|---|
2185/CHE/2010 | Jul 2010 | IN | national |
Number | Name | Date | Kind |
---|---|---|---|
4893333 | Baran et al. | Jan 1990 | A |
5418865 | Bloomberg | May 1995 | A |
5867633 | Taylor, III et al. | Feb 1999 | A |
6278483 | Sartor | Aug 2001 | B1 |
6535298 | Winter et al. | Mar 2003 | B2 |
6742708 | Shaked et al. | Jun 2004 | B2 |
6744529 | Winter et al. | Jun 2004 | B2 |
6798925 | Wagman | Sep 2004 | B1 |
6909805 | Ma et al. | Jun 2005 | B2 |
6950982 | Dourish | Sep 2005 | B1 |
6952803 | Bloomberg et al. | Oct 2005 | B1 |
6956671 | Monty et al. | Oct 2005 | B2 |
7142318 | Lopez et al. | Nov 2006 | B2 |
7181089 | Esaki et al. | Feb 2007 | B2 |
7202861 | Lynggaard | Apr 2007 | B2 |
7233913 | Scroggie et al. | Jun 2007 | B2 |
7293697 | Wiebe | Nov 2007 | B2 |
7315391 | Nakano et al. | Jan 2008 | B2 |
7489415 | Furuta | Feb 2009 | B2 |
7525675 | Shelton et al. | Apr 2009 | B2 |
7573598 | Cragun | Aug 2009 | B2 |
7650568 | Williamson | Jan 2010 | B2 |
7878617 | Mizes et al. | Feb 2011 | B2 |
8049910 | Beckman et al. | Nov 2011 | B2 |
8115948 | Rosenfeld et al. | Feb 2012 | B2 |
8228527 | Winter et al. | Jul 2012 | B2 |
8233751 | Patel et al. | Jul 2012 | B2 |
8346023 | Lin | Jan 2013 | B2 |
20010010730 | Rhoads | Aug 2001 | A1 |
20010019416 | Monty et al. | Sep 2001 | A1 |
20010040685 | Winter et al. | Nov 2001 | A1 |
20020033965 | Winter et al. | Mar 2002 | A1 |
20020051201 | Winter et al. | May 2002 | A1 |
20020138476 | Suwa et al. | Sep 2002 | A1 |
20020186404 | Gragg | Dec 2002 | A1 |
20030020945 | Lopez et al. | Jan 2003 | A1 |
20030167203 | Thorne et al. | Sep 2003 | A1 |
20040047001 | Gehring et al. | Mar 2004 | A1 |
20040145770 | Nakano et al. | Jul 2004 | A1 |
20040150845 | Brouhon | Aug 2004 | A1 |
20040151399 | Skurdal et al. | Aug 2004 | A1 |
20040205538 | Banerjee et al. | Oct 2004 | A1 |
20050071738 | Park | Mar 2005 | A1 |
20050185204 | Shelton et al. | Aug 2005 | A1 |
20050195447 | Os | Sep 2005 | A1 |
20050231746 | Parry et al. | Oct 2005 | A1 |
20060218496 | Kunori | Sep 2006 | A1 |
20060224950 | Takaai | Oct 2006 | A1 |
20060229940 | Grossman | Oct 2006 | A1 |
20060294450 | Barrus et al. | Dec 2006 | A1 |
20070147680 | Lundberg | Jun 2007 | A1 |
20070188793 | Wakai | Aug 2007 | A1 |
20080018591 | Pittel et al. | Jan 2008 | A1 |
20080273797 | Takikawa et al. | Nov 2008 | A1 |
20080309988 | Johnson et al. | Dec 2008 | A1 |
20090128865 | Kuchibhotla et al. | May 2009 | A1 |
20090232398 | Martin | Sep 2009 | A1 |
20090251338 | Marggraff | Oct 2009 | A1 |
20100027896 | Geva | Feb 2010 | A1 |
20100057573 | Singhal | Mar 2010 | A1 |
20100182631 | King et al. | Jul 2010 | A1 |
20100309527 | Mandalapu et al. | Dec 2010 | A1 |
20100318407 | Leff et al. | Dec 2010 | A1 |
20110080608 | Do et al. | Apr 2011 | A1 |
20110235128 | Sisco | Sep 2011 | A1 |
20110276383 | Heiser, II et al. | Nov 2011 | A1 |
20120050790 | Hong | Mar 2012 | A1 |
20120050818 | Watanabe | Mar 2012 | A1 |
20120079409 | Luo et al. | Mar 2012 | A1 |
20120266219 | Coleman et al. | Oct 2012 | A1 |
20120275708 | Fritz et al. | Nov 2012 | A1 |
20130290326 | Lebedev | Oct 2013 | A1 |
Number | Date | Country |
---|---|---|
1404102 | Mar 2004 | EP |
2410823 | Aug 2007 | GB |
2002305701 | Oct 2002 | JP |
2003162383 | Jun 2003 | JP |
2005236983 | Sep 2005 | JP |
2006001287 | Jan 2006 | JP |
WO-2010140983 | Dec 2010 | WO |
Entry |
---|
Nuance Community, Nuance Communications, Inc.; http://community.nuance.com/wikis/omnipage/workflows.aspx. |
http://www.ritescript.com/Manuals/ritePenManual30.aspx#Macros. |
CouponTrunk, “Discount Gifts & Flowers Shopping with a Gift Personalized Coupons for 2011,” Personalized Gifts Galore, Nov. 5, 2011, <http://web.archive.org/web/20111105064140/http://www.coupontrunk.com/coupon-codes/agiftpersonalized/>. |
Nagura et al., “A Facsimile-Based Editing System by Auxiliary Mark Recognition,” 1983, IEEE Transactions on Pattern Analysis and Machine Intelligence, vol. 5, issue 4. |
Kato et al., “A Handwritten Character Recognition System Using Directional Element Feature and Asymmetric Mahalanobis Distance,” Mar. 1999, PAMI, vol. 21, No. 3. |
EMC, “EMC Captiva Cloud Toolkit Transforms Web-based Scanning; Achieves Strong Third-party Adoption,” Jul. 26, 2012, <http://www.emc.com/about/news/press/2012/20120726-01.htm>. |
Jain Fan, “Text extraction via an edge-bounded averaging and a parametric character model,” Electronic Imaging 2003, International Society for Optics and Photonics, 2003, pp. 8-19. |
Microsoft Developer Network, “Clipboard Formats,” Sep. 9, 2010, <http://web.archive.org/web/20100909220445/http://msdn.microsoft.com/en-us/library/ms649013(VS.85).aspx>. |
MINT.COM, “Our Product,” May 22, 2010, <http://web.archive.org/web/20100522215052/http://www.mint.com/product/>. |
The IRESTE On/Off (IRONOFF) Dual Handwriting Database, C. Viard-Gaudin and P. M. Lailican, Proceedings of the Fifth International Conference on Document Analysis and Recognition, 1999. |
Evernote Corp., “ritePen 3.0 Manual,” (Web Page), 2009, retrieved Apr. 7, 2010 at http://www.ritescript.com/Manuals/ritePenManual30.aspx#Macros. |
Number | Date | Country | |
---|---|---|---|
20120026081 A1 | Feb 2012 | US |