Scene Text Detection

and

Recognition of Hindi

Guided by:

Dr. Mitesh M. Khapra

Presented by:

Jaya Ingle

Date: 7/5/19

Department of Computer Science and Technology, IIT Madras

  1. To detect location and size text in the wild.

2. To recognize the text in cropped word image.

सेल्फी

जिला

भारत

Introduction
Challenges involved

Lightening Conditions

Varying orientation

Perspective distortion

Complex background

To solve any machine learning problem, we need

Before going on, 

1. Data

2. Model

4. Learning Algorithm

3. Parameters

5. Loss Functions

Specifically in case of Indian languages(Hindi)

1. Data

1. Synthetic Dataset for Text Detection (Shubham's thesis)

2. Synthetic Dataset for Text Recognition(Hindi) (in this work)

So, we have generated artificial (or synthetic dataset) for Indian Languages (Tamil, Telugu, Punjabi, Malayalam, Hindi)

3. For test images, we have manually clicked the pictures and annotate them!

Cropped word dataset generation

Things required:

 

Hindi Wiki book database

Google fonts

1. Text

2. Font

3. Color of text

4. Background images

5. Rendering method

Discussed on next slide

Freely available on internet

 using dictionary of background and foreground colors

Rendering method:

Unlike English, Unicode level information won't be sufficient to render text on image

We need glyphs level information in this case. Before that, we select, text, font, background. With the help of a few rendering libraries of Python, we were able to render text on the image.

 

we store glyphs and their positions in buffer

Till the buffer did not get empty, we keep rendering the glyphs on the surface and finally rendered surface is converted to the  image.

कि

ि

will be rendered as 

कि

glyphs will be क, ि with ordering between them

कि

Also applied distortion and noise to randomly selected 80% images

To solve any machine learning problem, we need

Before going into literature, 

1. Data

2. Model

4. Learning Algorithm

3. Parameters

5. Loss Functions

Specifically in case of Indian languages, 

1. Data

2. Model (Detection /Recognition)

Solutions of Text Detection

Regression based solutions

Segmentation based solutions

Groundtruth bounding box

Anchor box

text ?

text ?

Regression-based Model

  • EAST: An Efficient and Accurate Scene Text Detector

text score map

Geometry map

rotation angle

left

right

top

bottom

It tries to directly predict word or text line predictions, which are further sent to Non Maximum Suppression (NMS)

Network

Loss

\[ = L_{scoremap} + \lambda_g L_{gemoetry} \]

 \[L_{scoremap} \] 

= balanced cross entropy between predicted

and ground truth score map

\[L_{geometry} \]

= IoU loss + 1- cos(angle_p, angle_gt)

Results

Implementational details

  • 5M synthetic images are used for training
  • Batch size  = 8, trained for 99k steps
  • 2 K80 GPUs with 12 GB memory
  • learning rate = 1e-4 (exponential decay)
  • Adam optimizer
  • Images resized 512 x 512
  • 428 images are used for inference
  • IoU threshold = 0.4

Training

Testing

scale Precision Recall F-measure
512x512 0.6445 0.4441 0.5258
Nearest multiple of 32 0.6788 0.4045 0.5069

*with IoU threshold as 0.4

Results

  • Due to variations in scale of test images and not so satisfactory results, we finetuned the model on 300 real images
scale Precision Recall F-measure
1024x1024 0.91100 0.68159 0.77977
512x512 0.954898 0.74334 0.83594
256x256 0.9421052 0.650121 0.76934
nearest multiple of 32 0.93323 0.76150 0.83866

*with IoU threshold as 0.4

  • We also experimented with different scales

Solutions of Text Detection

Regression based solutions

Segmentation based solutions

Groundtruth bounding box

Anchor box

text ?

text ?

Segmentation based model

  • Pixel link
  • Every pixel has 8 neighbours.
  • If a pixel and one of its neighbours belong to same instance, the link between them will be predicted as positive, else negative.

Unlike regression method, which performs 2 types of tasks,​

  1. Text/non-text prediction.
  2. location regression.

Here only text/non-text prediction is required. But 2 type of predictions are done:

  1. Pixel prediction.
  2. Link prediction.

positive pixel

negative pixel

positive link

negative link

Network

Loss

\[ = L_{link} + \lambda L_{pixel} \]

\[L_{link} \]

\[L_{pixel} \]

\[ \lambda \]

 = instance balanced cross entropy 

= 2

 = Cross entropy on link x sum of W for +ve and -ve links

* With base network as VGG-16

Implementational details

Results

  • 5M synthetic images are used for training
  • Batch size  = 8, trained for 99k steps
  • 2 K80 GPUs with 12 GB memory
  • learning rate = 1e-4 with momentum 0.9
  • Images resized 512 x 512
  • 428 images are used for inference
  • IoU threshold = 0.4

Training

Testing

Precision  Recall F-measure
0.4393 0.4534 0.42313

IoU threshold=0.4, link and pixel threshold=0.5

Precision  Recall F-measure
0.52 0.5573 0.5380

After finetuning on 300 real images,

Effect on changing pixel threshold

Effect on changing link threshold

Thres Precision Recall F-measure
0.5 0.520053  0.55730  0.53803
0.6 0.53269  0.57368  0.50153
0.7 0.538461 0.58166 0.55922
0.8 0.58377   0.62893 0.60551
0.9 0.57490  0.616604  0.59433
Thres Precision Recall F-measure
0.5 0.52005  0.55730  0.53803
0.6 0.58115   0.63610 0.60738
0.7 0.57657  0.64183  0.60745
0.8 0.56045  0.63753  0.59651

* link thres=0.5, IoU thres=0.4

* pixel thres=0.8, IoU thres=0.4

Qualitative results

Comparison

EAST

Pixel link

Comparison

EAST

Pixel link

Comparison

EAST

Pixel link

Text Recognition

 

भारत

Unlike the relation between object detection and text detection, there are significant differences between object recognition and text recognition,

 

In text recognition, we have to predict the series of labels, that why this problem is posed as a sequence recognition problem.

भ + ा + र + त

Model

Vgg-16 as feature extractor

Map to sequence 

BLSTM

BLSTM

Transcription

जिला

per-frame predictions

label sequence

height normalized feature maps

feature maps

input image

Transcription

To solve this a framework known as CTC ( Connectionist Temporal Classification)

- is to find the label sequence with the highest probability conditioned on the per-frame predictions

How to find this conditional probability?

  • Since we didn't know the alignment of input and output sequence
  • Also, there can be repeated label predicted in output 

we need a mapping function which can map from output sequence to label sequence.

  • It will first add a special symbol "-" in training symbol set
  • In the ground truth label, "-" will be inserted between every distinct letter.
  • While decoding, repeated letters between "-" are merged and then "-" are removed.

P(label seq|per-frame prediction)* = sum of P(output seq |per-frame prediction)

Such that the output seq can be mapped to label sequence.

The mapping function will map

ि ि ि-----जजज---लल----ा

जिला

So, the conditional probability will be framed as,

While decoding, we will return the output sequence with highest probability

*In reality, it is difficult to compute so we use forward-backward algorthm

Results

Implementational Details

Training

Testing

  • 3M synthetic word images for training, 1M for validation.
  • batch size = 32, trained for 63k steps, took 1 day.
  • 3 K80 GPUS with 12 GB memory
  • lr = 0.001, momentum=0.9
Mean per char acc Mean full sequence acc Mean edit distance
0.651006 0.419540 0.2968
  • 1740 real images have been used for testing

Total number of labels = 129

[ 128 (according to Unicode representation) + 1 (unknown label) ]

Qualitative Results

अधिनियम

कालोनी

स्वल्पाहार

नित्यानंद

विभागाध्यक्ष

मंगलमय

Mistakes

इटास्पी

इलेक्टनिक्स

अभिवान

इबलिंग

डेन

सर्वशेष्ठ

विशाम

अघिनर्थ

कों

पथम

रकूल

दं

सं

Its not only model's mistake!

Distorted images

Conclusion

  • A simple model can extract text out of the image, given the image should not be much distorted and the text is correctly written
  • The structure of Hindi symbols are complex and can be easily confused with other characters.

Possible future work

  • An end-to-end trainable framework for detection and recognition.
  • An approach to solve multilingual text detection and recognition.
  • A better evaluation metric for text detection, since most of the current metric, is borrowed from object detection and in the object case, if some part is neglected, it won't make much difference.
  • A lightweight model, which can easily be incorporated in mobile phones.

Thank you.

deck

By jaya_ingle

deck

  • 490