File size: 6,283 Bytes
c4103f0
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
7c0a0b7
c4103f0
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
e4ee6ff
c4103f0
40354b6
c4103f0
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
---
license: apache-2.0
tags:
- ocr
- text-detection
- text-recognition
- tflite
- mlkit
- google-mlkit
- on-device
- image-to-text
pipeline_tag: image-to-text
language:
- en
- ru
- zh
- ja
- ko
- ar
- he
- bn
- gu
- kn
- ml
- ta
- te
- ka
- vi
---

# πŸ›οΈ OpenMLkit OCR Models

This repository hosts a collection of highly optimized, lightweight, on-device OCR (Optical Character Recognition) models extracted from Google ML Kit APK components. These models are designed to run fully offline and are fully compatible with [OpenMLkitOCR](https://github.com/0cve0/OpenMLkitOCR), a lightweight offline OCR engine for Python.

The repository includes:
* **Text Detection Model**: A Region Proposal Network (RPN) architecture (`rpn_detector.tflite`) that identifies text bounding boxes in image tiles.
* **Text Recognition Models**: Lightweight CRNN + CTC model pipelines for 15+ different languages and scripts.

---

## πŸ›οΈ Supported Languages and Scripts

Below is the registry of the available models, vocabulary maps, and language model priors stored in this repository:

| Code | Script / Language | Recognizer Model | Label Map File | Language Model / Priors |
| :--- | :--- | :--- | :--- | :--- |
| `detector` | **Text Detection (All)** | [rpn_detector.tflite](./detector/rpn_detector.tflite) | β€” | β€” |
| `en` | **Latin / English** | [line_recognizer.fb](./en/line_recognizer.fb) | [LabelMap.pb](./en/LabelMap.pb) | β€” |
| `ru` | **Cyrillic / Russian** | [recognizer_cyrl.tflite](./ru/recognizer_cyrl.tflite) | [LabelMap_cyrl.pb](./ru/LabelMap_cyrl.pb) | FST LM + Priors |
| `zh` | **Chinese / Han (Hani)** | [recognizer_hani.tflite](./zh/recognizer_hani.tflite) | [recognizer_hani_label_map.pb](./zh/recognizer_hani_label_map.pb) | FST LM + Priors |
| `ja` | **Japanese (Jpan)** | [recognizer_jpan.tflite](./ja/recognizer_jpan.tflite) | [recognizer_jpan_label_map.pb](./ja/recognizer_jpan_label_map.pb) | FST LM + Priors |
| `ko` | **Korean (Kore)** | [recognizer_kore.tflite](./ko/recognizer_kore.tflite) | [recognizer_kore_label_map.pb](./ko/recognizer_kore_label_map.pb) | FST LM + Priors |
| `ar` | **Arabic (Arab)** | [recognizer_arab_retrained.tflite](./ar/recognizer_arab_retrained.tflite) | [recognizer_arab_label_map.pb](./ar/recognizer_arab_label_map.pb) | FST LM + Priors |
| `he` | **Hebrew (Hebr)** | [hebr.tflite](./he/hebr.tflite) | [hebr_label_map.pb](./he/hebr_label_map.pb) | Priors |
| `ka` | **Georgian (Geor)** | [geor.tflite](./ka/geor.tflite) | [geor_label_map.pb](./ka/geor_label_map.pb) | Priors |
| `bn` | **Bengali & Devanagari (Bede)** | [bede.tflite](./bn/bede.tflite) | [bede_label_map.pb](./bn/bede_label_map.pb) | Priors |
| `gu` | **Gujarati (Gujr)** | [gocr_tflite_recognizer_gujr.tflite](./gu/gocr_tflite_recognizer_gujr.tflite) | [gocr_tflite_recognizer_gujr_label_map.pb](./gu/gocr_tflite_recognizer_gujr_label_map.pb) | Priors |
| `kn` | **Kannada (Knda)** | [recognizer_knda.tflite](./kn/recognizer_knda.tflite) | [recognizer_knda_label_map.pb](./kn/recognizer_knda_label_map.pb) | FST LM + Priors |
| `ml` | **Malayalam (Mlym)** | [recognizer_mlym.tflite](./ml/recognizer_mlym.tflite) | [recognizer_mlym_label_map.pb](./ml/recognizer_mlym_label_map.pb) | FST LM + Priors |
| `ta` | **Tamil (Taml)** | [recognizer_taml.tflite](./ta/recognizer_taml.tflite) | [recognizer_taml_label_map.pb](./ta/recognizer_taml_label_map.pb) | FST LM + Priors |
| `te` | **Telugu (Telu)** | [recognizer_telu.tflite](./te/recognizer_telu.tflite) | [recognizer_telu_label_map.pb](./te/recognizer_telu_label_map.pb) | FST LM + Priors |
| `vi` | **Vietnamese / Latin** | [gocr_tflite_recognizer_latn_vi.tflite](./vi/gocr_tflite_recognizer_latn_vi.tflite) | [gocr_tflite_recognizer_latn_vi_label_map.pb](./vi/gocr_tflite_recognizer_latn_vi_label_map.pb) | Priors |

---

## πŸ“‚ File Types Explained

1. **`*.tflite` / `*.fb` (Neural Network weights)**: 
   * `detector/rpn_detector.tflite` is a Convolutional Neural Network (CNN) that processes `256x256` tiles of the image and predicts text bounding boxes.
   * `recognizer_*.tflite` and `line_recognizer.fb` are CRNN (Convolutional Recurrent Neural Network) architectures that predict CTC logits for cropped text line images.
2. **`*_label_map.pb` / `LabelMap.pb` (Vocabulary)**:
   * Binary Protobuf files mapping character indices to Unicode symbols for decoding CTC outputs.
3. **`*_lm.compact_fst.gz` & `*.syms` (Language Models)**:
   * Compact Finite State Transducer (FST) language models and symbol mapping files. These are used for advanced Beam Search decoding, correcting spelling and character sequences based on word frequencies.
4. **`*_prior.pb` / `*_config.pb` (Priors & Config)**:
   * Character prior probabilities and model configurations used to calibrate neural network outputs before applying the language model.

---

## πŸš€ How to Use with `openmlkitOCR`

The Python package `openmlkitOCR` handles automatic downloading and caching of these models from Hugging Face if they are not present locally.

### 1. Installation
Install the library directly using pip:
```bash
pip install openmlkitOCR
```

### 2. Python Usage Example
```python
import os
import cv2
from openmlkit import OpenMLKitOCR

# Configure the pipeline to pull models from this Hugging Face repository
os.environ["OPENMLKIT_MODEL_REPO"] = "0cve0/OpenMLKitOCR"

# Initialize the pipeline for a specific language (e.g., 'en' for English/Latin)
# This will automatically download and cache the detector and recognizer files.
ocr = OpenMLKitOCR(lang='en')

# Load an image
image = cv2.imread("test_image.jpg")

# Run OCR (detection & recognition)
results = ocr.run(image, score_threshold=0.35)

# Output the localized text bounding boxes and recognised characters
for item in results:
    print(f"Box: {item['box']} -> Text: {item['text']}")
```

---

## βš–οΈ License and Disclaimer

* **Software**: The Python library [OpenMLkitOCR](https://github.com/0cve0/OpenMLkitOCR) is licensed under the **Apache 2.0 License**.
* **Model Weights**: The model weights and configurations in this repository are extracted from Google ML Kit APK components and are subject to Google's terms of service and license agreements. These models are intended for educational, research, and non-commercial local testing purposes.