== Blueprint for Optical Character Recognition == === Functionality === Be able to scan in a paper-based form to populate the database * http://wiki.sahanafoundation.org/doku.php/sahanaocr * http://wiki.sahanafoundation.org/doku.php?id=dev:sahana_xform * http://humanitariantech.com/2009/11/16/talking-papers-a-world-without-data-entry/ * BluePrintSurveyTool This would be useful if Sahana is being used to generate forms which are printed, and filled out by hand, then can be scanned back, directly, into the database.[[BR]] It may be impractical to get people to fill out forms in handwriting which can be "recognized". * Being able to identify check-boxes being checked - and design forms which rely heavily on check boxes. * Being able to copy blocks of test out of a hand written form, and display it on screen, next to an editable text box, where the text can be "recognized" and entered manually. === Technology === The C++ code written for SahanaPHP (during GSoC 2007) can almost-certainly be tweaked to work with !SahanaPy: * http://sahana.cvs.sourceforge.net/viewvc/sahana/sahana-phase2/bin/ocr/?pathrev=rel_gsoc_2007 This version uses [http://opencv.willowgarage.com/wiki OpenCV] & [http://leenissen.dk/fann FANN] A Firefox add-on to enable a nice workflow for users is being developed for SahanaPHP as part of GSoC 2009: * http://sahana.cvs.sourceforge.net/viewvc/sahana/sahana-phase2/bin/ocr/?pathrev=gsoc_2009 This will access the Scanner (e.g. using TWAIN or SANE) and read the Image. The acquired image will be passed to the OCR library & the result will be posted into the web form. [[BR]] Again, this should be easy to tweak to get working with Py. Possibility of using pytesser ( http://code.google.com/p/pytesser/ ) with cross platform tesseract-ocr ( http://code.google.com/p/tesseract-ocr/ ) Plone uses Tesseract: http://plone.org/documentation/tutorial/ocr-in-plone-using-tesseract-ocr === Notes from Main-dev List === Why not just use data which is currently entered in the database for the keywords? (eg, location tables, organization tables, etc)[[BR]] Regarding checkboxes – if could be possible to design a survey which only requires checkboxes, maybe fields for dates. Scales of 1-10 could be converted into checkboxes.[[BR]] I like your idea for reviewing the text – I think even if the OCR isn’t too accurate, having the text from the paper displayed on screen next to the data entry box would make it easier to input the data. In some cases, it may not be important to convert the image of the writing into text, as long as the image is saved in the DB (eg, additional notes in a survey)[[BR]] Also – can you “tell” the OCR whether it should be looking for letters or numbers? It should be quite easy to determine which fields should have letters in them and which should have numbers.[[BR]] Regarding Barcodes:[[BR]] They’re easy to make, simply get a font from: http://www.barcodesinc.com/free-barcode-font/ and display an appropriate number in that font.[[BR]] I’m not convinced that each field needs a barcode, but definitely each page. Also you may want to give each form a UID (in the barcode and human readable, particularly if the forms are printed over multiple pages – that way if the pages get mixed up, they can easily be sorted out.[[BR]] === Check Boxes === Check boxes could be used in a number of different ways: ==== Yes/No ==== {{{ Living in a temporary shelter: □ }}} ==== Option List ==== {{{ Current Residence: Own House: □ Renting: □ Temporary Shelter: □ Government Camp: □ Barracks: □ }}} ==== Scale ==== {{{ Severity of Damage (1-lowest 5-highest): 1: □ 2: □ 3: □ 4: □ 5: □ or 1 2 3 4 5 □ □ □ □ □ }}} ==== Scale ==== {{{ Days in current location: 0-3: □ 4-10: □ 10-30: □ 31+: □ }}} === Step 1: Form Generation === A couple of ways to go about it: 1. Generate the XML files from the user defined data requirements and then use XSL-FO (eXtensible Stylesheet Language - Formatting Object) to work with the XML documents to tailor the document appearance for printing. A XSL-FO processor, Apache FOP has to be used to generate PDFs out of it. 2. The required data be exported into reST format from the XML files generated by the SahanaPy framework and the package rst2pdf could be used to generate pdfs. rst2pdf uses reportlab which enables us not only to logicaly format the data to be printed but also helps us keep the co-ordinates of the printed data with reference to the bottom left point taken as origin. rst2pdf uses a styling sheet to format the reST data and thus should be provided a stylesheet (a json file with several elements in it) which should be generated along with the .rst files. This helps us format the data properly as it contains the parameters to the reportlab module to personalize the printable forms. The second approach is much preferrable in the sense that the entire code base is in python and we can obtain the data that can later help us in reading the data. It is ideal if each of the documents be provided with a header (for example: 3 opaque square blocks two on either ends and one in the middle) to help align the form during the recognition process. To minimize the task of recognizing the handwriting recognition, most of the general data (like gender, location etc.) can be printed in the forms with corresponding checkboxes. The rest of the data like name and age has to be handwritten for which providing checkboxes isnt practical has to be recognized. Each custom form generated can be given an unique ID either by just printing the unique ID logically in the form of a barcodes. === Step 2: OCR === The most successful software for OCR is tesseract which is cross platform compatible. NOTE: The uploaded images so as to be recognized have to be supplied to tesseract, have to be in .tiff format. 1. The image which has been scanned into .tiff format has to be checked for any skewness using the relative position of the three squares on the top and thus set the frame of reference for the image. (using python imaging library) 2. There are two ways of reading the data. (using tesseract) a. The spatial information from the step1 which has been used to format the content using reportlab can be used to identify the contents of each block of data individually treating it as a seperate letter.(This can be done by segmenting each block out of the image and read it). This gives us more accuracy. b. The data from the image could be directly read and parsed later. The problems with this way of reading could be that a single letter could be misinterpretated as a combination of letters etc. Segmenting into smaller images and then reading it would be much more time consuming but accurate where as the other is less accurate and extremely fast. 3. Each of the checkboxes which correspond to the relevant data shall be marked with 'X' which could be read as character 'x'. 4. The read data should be parsed and be written accordingly into an xml file for other applications to use in case of need. ( Also the segmented images can be stored until manual data verification) NOTE: The accuracy of the OCR engine depends on the training data which makes it critical. === Step3: Implementation of a training module === A sub-module for the automated training of the handwriting for the end users. The data for training shall be imported as the tiff images. 1. The User shall be provided a form with the boxes in it to fill to replicate the characters in his/her handwriting according to a set of data generated by the module. 2. The automated matching of this data is done with the box file generated from image rather than human involvement . 3. Then the tesseract can be run in the training format and then clustering using different training images is done. (for the shape prototypes, the number of expected features for each character and the character normalization sensitivity prototypes). 4. Tesseract needs to know the set of possible characters it can output. To generate the unicharset data file, use the unicharset_extractor program on the same training pages bounding box files as used for clustering. Reference: http://code.google.com/p/tesseract-ocr/wiki/TrainingTesseract === Training Data === * [http://yann.lecun.com/exdb/mnist/ Hand-written digits] * [http://ai.stanford.edu/~btaskar/ocr/ Hand-written words] ---- BluePrints