Multilingual OCR Development Plan
D-DanielYang opened this issue · 72 comments
model name | description | model size | download | Update Date |
---|---|---|---|---|
ch | Chinese and English | 3.71M | inference model / trained model | 2020.9.22 |
ch_tra | chinese traditional | 5.63M | inference model / trained model | 2021.1.21 |
en | English | 2.56M | inference model / trained model | 2020.9.22 |
fr | French | 2.65M | inference model / trained model | 2021.9.22 |
ar | Arabic | 2.53M | inference model / trained model | 2021.1.21 |
es | Spanish | 2.53M | inference model / trained model | 2021.1.21 |
pt | Portuguese | 2.63M | inference model / trained model | 2021.1.21 |
ru | Russia | 2.63M | inference model / trained model | 2021.1.21 |
ge | german | 2.65M | inference model / trained model | 2020.9.22 |
kr | Korean | 3.9M | inference model / trained model | 2020.9.22 |
jp | Japanese | 4.23M | inference model / trained model | 2020.9.22 |
it | Italian | 2.53M | inference model / trained model | 2021.1.21 |
hi | Hindi | 2.63M | inference model / trained model | 2021.1.21 |
ug | Uyghur | 2.63M | inference model / trained model | 2021.1.21 |
fa | Persian | 2.63M | inference model / trained model | 2021.1.21 |
ur | Urdu | 2.63M | inference model / trained model | 2021.1.21 |
oc | Occitan | 2.53M | inference model / trained model | 2021.1.21 |
mr | Marathi | 2.63M | inference model / trained model | 2021.1.21 |
ne | Nepali | 2.63M | inference model / trained model | 2021.1.21 |
rs_cyrillic | Serbian(cyrillic) | 2.63M | inference model / trained model | 2021.1.21 |
rs_latin | Serbian(latin) | 2.53M | inference model / trained model | 2021.1.21 |
bg | Bulgarian | 2.63M | inference model / trained model | 2021.1.21 |
uk | Ukranian | 2.63M | inference model / trained model | 2021.1.21 |
be | Belarusian | 2.63M | inference model / trained model | 2021.1.21 |
te | Telugu | 2.63M | inference model / trained model | 2021.1.21 |
kn | Kannada | 2.63M | inference model / trained model | 2021.1.21 |
ta | Tamil | 2.63M | inference model / trained model | 2021.1.21 |
mg | Mongolian | -- | Ongoing | |
bg | Bangla | -- | Need dict and corpus | |
bm | Burmese | -- | Need dict and corpus | call for contribution |
ku_cent | kurdish central | -- | PR8347 | call for contribution |
od | Odia | -- | PR6348 | call for contribution |
th | thai | -- | PR6719 issue chat | call for contribution |
More | TBC |
Guideline for new language requests
If you want to request a new language support, a PR with 2 following files are needed:
-
In folder ppocr/utils/dict,
it is necessary to submit the dict text to this path and name it with{language}_dict.txt
that contains a list of all characters. Please see the format example from other files in that folder. -
In folder ppocr/utils/corpus,
it is necessary to submit the corpus to this path and name it with{language}_corpus.txt
that contains a list of words in your language.
Maybe, 50000 words per language is necessary at least.
Of course, the more, the better. -
call for contributions to add new language support for PaddleOCR.
For anyone might be insterested in traing the new language model, Guidance to train the model is provided. We are calling contributions to add new language support for PaddleOCR.
If your language has unique elements, please tell me in advance within any way, such as useful links, wikipedia and so on.
Traditional Mongolian
I would love to work on "Bangla"
I very happy if you do that with Vietnamese
How about Arabic? That would be great.
I've find out that PADDLE OCR algorithm cannot recognize some special characters (such as comma, semicolon, or dot...) when the language is english. Is there any possible way that i can fix this problem
I would like to contribute to add the Burmese language. Is it only needed to submit two text files - dict & corpus? How further process do we need to provide?
Adding "Bangla" will be grate for the people in south Asia
Adding "Traditional Chinese (zh-TW)" would be great support.
Do you have preTrained Russian recognition model?
Hi adding " Tamil" language will be very grateful.
Tamil_dict.txt
Tamil_corpus.txt
Need more help plz refer this issue:
JaidedAI/EasyOCR#39
I can help with Turkish language.
I can help with polish language.
@shahidul56 Hello, Can you provide the corpus file of Bangla Languag?
All models updated in 2021.1.21 cannot be downloaded with following Error:
{ code: "NoSuchKey", message: "The specified key does not exist.", requestId: "aa1bfeff-f572-40aa-8935-6129b1533ed1" }
All models updated in 2021.1.21 cannot be downloaded with following Error:
{ code: "NoSuchKey", message: "The specified key does not exist.", requestId: "aa1bfeff-f572-40aa-8935-6129b1533ed1" }
Sorry for the invalid links and all of them have been revised now, you can try again.
I very happy if you do that with Vietnamese
#1847, seems to be ongoing.
@redcinelli Thank you very much. The Vietnamese model is in training and will be available soon~
model name description model size download Update Date
ch Chinese and English 3.71M inference model / trained model 2020.9.22
cht chinese traditional 5.63M inference model / trained model 2021.1.21
en English 2.56M inference model / trained model 2020.9.22
fr French 2.65M inference model / trained model 2021.9.22
ar Arabic 2.53M inference model / trained model 2021.1.21
xi Spanish 2.53M inference model / trained model 2021.1.21
pu Portuguese 2.63M inference model / trained model 2021.1.21
ru Russia 2.63M inference model / trained model 2021.1.21
ge german 2.65M inference model / trained model 2020.9.22
kr Korean 3.9M inference model / trained model 2020.9.22
jp Japanese 4.23M inference model / trained model 2020.9.22
it Italian 2.53M inference model / trained model 2021.1.21
hi Hindi 2.63M inference model / trained model 2021.1.21
ug Uyghur 2.63M inference model / trained model 2021.1.21
fa Persian 2.63M inference model / trained model 2021.1.21
ur Urdu 2.63M inference model / trained model 2021.1.21
rs Serbian(latin) 2.53M inference model / trained model 2021.1.21
oc Occitan 2.53M inference model / trained model 2021.1.21
mr Marathi 2.63M inference model / trained model 2021.1.21
ne Nepali 2.63M inference model / trained model 2021.1.21
rsc Serbian(cyrillic) 2.63M inference model / trained model 2021.1.21
bg Bulgarian 2.63M inference model / trained model 2021.1.21
uk Ukranian 2.63M inference model / trained model 2021.1.21
be Belarusian 2.63M inference model / trained model 2021.1.21
te Telugu 2.63M inference model / trained model 2021.1.21
ka Kannada 2.63M inference model / trained model 2021.1.21
ta Tamil 2.63M inference model / trained model 2021.1.21
mg Mongolian -- Ongoing
bg Bangla -- Need dict and corpus
vi Vietnamese -- Need dict and corpus
bm Burmese -- Need dict and corpus
tk Turkish -- Need dict and corpus
po polish -- Need dict and corpus
More TBCGuideline for new language requests
If you want to request a new language support, a PR with 2 following files are needed:
1. In folder [ppocr/utils/dict](./ppocr/utils/dict), it is necessary to submit the dict text to this path and name it with `{language}_dict.txt` that contains a list of all characters. Please see the format example from other files in that folder. 2. In folder [ppocr/utils/corpus](./ppocr/utils/corpus), it is necessary to submit the corpus to this path and name it with `{language}_corpus.txt` that contains a list of words in your language. Maybe, 50000 words per language is necessary at least. Of course, the more, the better.
If your language has unique elements, please tell me in advance within any way, such as useful links, wikipedia and so on.
@grasswolfs model name for Turkish should be "tr" instead of "tk", it is the widely used abbreviation for Turkish.
Thanks @habout632 for adding Southeast Asian languages via #1896
Here is a dictionary for Greek.
el_dict.txt
Hi , did we have a model to detect all English characters along with special characters like.,"()
hi, thank you for the great work! I just wonder whether you will add traditional Chinese to the general model? Right now, the general model can support Chinese(sim), English and numbers.
Hi, can we give line data above 50 max_char_length data for training?
after training rec model on 25 char length as well as 50 char length found that 25 char length less loss and good acc but 50 char length data more loose and less acc please find sample devnagri data
train_img/0022_BindiyaKiAathmakatha_Img_300_Org_Page_0001_crop_9.jpg बीत गया । असमय के इस बुढ़ापे की देहली पर बैठी, मौत की
train_img/0022_BindiyaKiAathmakatha_Img_300_Org_Page_0001_crop_10.jpg प्रतीक्षा कर रही हूँ । पर लगाता है उसने भी सबों के साथ-साथ
After downloading the inference and Trained model, how can I use them ?
Can anyone point out some resources of Testing / Evaluating code using these models
Thanks
请问有计划开发一个统一模型,支持多语种文字混合排版的图片的识别吗?谢谢。
Traditional Mongolian 👀
model name description model size download Update Date
ch Chinese and English 3.71M inference model / trained model 2020.9.22
ch_tra chinese traditional 5.63M inference model / trained model 2021.1.21
en English 2.56M inference model / trained model 2020.9.22
fr French 2.65M inference model / trained model 2021.9.22
ar Arabic 2.53M inference model / trained model 2021.1.21
es Spanish 2.53M inference model / trained model 2021.1.21
pt Portuguese 2.63M inference model / trained model 2021.1.21
ru Russia 2.63M inference model / trained model 2021.1.21
ge german 2.65M inference model / trained model 2020.9.22
kr Korean 3.9M inference model / trained model 2020.9.22
jp Japanese 4.23M inference model / trained model 2020.9.22
it Italian 2.53M inference model / trained model 2021.1.21
hi Hindi 2.63M inference model / trained model 2021.1.21
ug Uyghur 2.63M inference model / trained model 2021.1.21
fa Persian 2.63M inference model / trained model 2021.1.21
ur Urdu 2.63M inference model / trained model 2021.1.21
oc Occitan 2.53M inference model / trained model 2021.1.21
mr Marathi 2.63M inference model / trained model 2021.1.21
ne Nepali 2.63M inference model / trained model 2021.1.21
rs_cyrillic Serbian(cyrillic) 2.63M inference model / trained model 2021.1.21
rs_latin Serbian(latin) 2.53M inference model / trained model 2021.1.21
bg Bulgarian 2.63M inference model / trained model 2021.1.21
uk Ukranian 2.63M inference model / trained model 2021.1.21
be Belarusian 2.63M inference model / trained model 2021.1.21
te Telugu 2.63M inference model / trained model 2021.1.21
kn Kannada 2.63M inference model / trained model 2021.1.21
ta Tamil 2.63M inference model / trained model 2021.1.21
mg Mongolian -- Ongoing
bg Bangla -- Need dict and corpus
vi Vietnamese -- Ongoing
bm Burmese -- Need dict and corpus
tr Turkish -- Need corpus
po polish -- Need dict and corpus
More TBCGuideline for new language requests
If you want to request a new language support, a PR with 2 following files are needed:
- In folder ppocr/utils/dict,
it is necessary to submit the dict text to this path and name it with{language}_dict.txt
that contains a list of all characters. Please see the format example from other files in that folder.- In folder ppocr/utils/corpus,
it is necessary to submit the corpus to this path and name it with{language}_corpus.txt
that contains a list of words in your language.
Maybe, 50000 words per language is necessary at least.
Of course, the more, the better.If your language has unique elements, please tell me in advance within any way, such as useful links, wikipedia and so on.
Hi, thank you for the great work! I
I sent you a corpus for Vietnamese. The file was attached below.
vietnamese_dict.txt. This file gets from this research:
Download: https://github.com/VinAIResearch/dict-guided
You can evaluate on VinText dataset, text scene detection for Vietnamese, downloaded in Github.
Thank you.
@inproceedings{m_Nguyen-etal-CVPR21,
author = {Nguyen Nguyen and Thu Nguyen and Vinh Tran and Triet Tran and Thanh Ngo and Thien Nguyen and Minh Hoai},
title = {Dictionary-guided Scene Text Recognition},
year = {2021},
booktitle = {Proceedings of the {IEEE} Conference on Computer Vision and Pattern Recognition (CVPR)},
}
Hi team,
Please update Vietnamese,
I'm very excited about this project,
Thanks very much
@grasswolfs & @xmy0916
Dear already shared dict & corpus file for Bangla. please check. I have also added here.
Can I know is there Malay Language support? Malay is the main language from Malaysia.
Suppose we have an image with texts from multiple languages. How do you approach this problem? One way is to ensemble all the languages and take the most confident one but it turns out to be very inaccurate because of confidence miscalibration. Can't we train a single recognition model for all languages or at least a couple of them? I think it will be a very helpful model for applications where we don't know the language beforehand or an image contain multiple languages.
Suppose we have an image with texts from multiple languages. How do you approach this problem? One way is to ensemble all the languages and take the most confident one but it turns out to be very inaccurate because of confidence miscalibration. Can't we train a single recognition model for all languages or at least a couple of them? I think it will be a very helpful model for applications where we don't know the language beforehand or an image contain multiple languages.
Strong Upvotes for this opinion.
Hi @grasswolfs, thanks so much for all the work you've put in. I've included a PR for the Amharic language, which is spoken by over 60 million people.
#4882
One potential issue is that Amharic words contain a number of prefixes and suffixes to indicate the object, number of items, tense, gender, negation and so. Thus, a single verb may morph in a number of ways that are not all included in the dictionary.
Hi @grasswolfs, I also submitted a PR for the Tigrinya language, which is similar to Amharic and spoken by over 10 million people.
#4881
It has the same mutation issue as Amharic. Also, Arabic numerals are commonly used despite having its own numeral system.
嗨,你好。除了上面的那些连接,有最新的语言model吗,我看官方说支持80多种语言?
维吾尔语识别非常不好或者没有识别。
希望完善一下模型,非常感谢你们🙏
你好,可以识别挪威语吗?
你好,希望可以识别挪威语。只找到了1 In folder [ppocr/utils/dict],没有找到 2 In folder [ppocr/utils/corpus]。ocr小白,请问怎么添加这两个文件呢?
嗨,你好。除了上面的那些连接,有最新的语言model吗,我看官方说支持80多种语言?
all multilingual models can be found here
Is there any tutorial on how can I train my own model out of my own corpus and sample images?
Is there any tutorial on how can I train my own model out of my own corpus and sample images?
Thanks for the attention, the multilingual model training tutorial will be released next week!
Hi team,
Thank you so much for the great work. I'm very excited about the vietnamese dict anf corpus and models, could you please update vietnamese language soon ?
Again, thankyou so much and congrats on great work
I can help for these languages:
Turkish -- tr
Azerbaijani -- az
Faris -- fa
Afghani -af
how I can implement multi-language like English, Urdu, and Tamil in one paddle-OCR instancE with python
how about lao character
I can help.....
Please add Thai language, appreciate!
thai_corpus.txt e
Here are you:
Thai dictionany file:
https://raw.githubusercontent.com/JaidedAI/EasyOCR/master/easyocr/dict/th.txt
Thai corpus:
http://web-corpora.net/ThaiCorpus/texts_tagged.zip
Please add Greek Language (Modern Greek Language)
Greek dictionary txt file with 144000 words
greek_dict.txt
Greek corpus txt file
Greek_corpus.txt
Dear @D-DanielYang I have added Mongolian characters with special characters on this:
, + - * / \ ? % _ . : ₮ " - № =
Pull request #7930
https://upload.wikimedia.org/wikipedia/commons/5/54/Mongolian_keyboard_win.png
I have add the Vietnamese dict and corpus #7933
Please help in the training for Vietnamese and if you need more information please let me know
@Evezerest @tink2123 @D-DanielYang Please Lithuanian language urgently needed both in PaddleOCR and PPStructure
Please add Tajik Language
tajik_corpus.txt
tajik_dict.txt
@fcakyon @D-DanielYang @xmy0916
I would like to contribute to Bangla Dictionary and Corpus. Can I do that?
Also, I have a few queries to ask -
- Could not clearly understand this line -
If your language has unique elements, please tell me in advance within any way, such as useful links, wikipedia and so on.
- In the corpus of at least 50000 words, I am guessing all of them should be unique. Am I right?
- Is there any particular category of corpus words? Like except stop words or something similar to that?
- In
ppocr/utils
path I can not see anycorpus
directory.
Thanks in advance
Please add Indonesia (id) and English (en) together
Do you have any plan for Vietnamese release?
Is it sufficient to change the file german_dict.txt if one wants to detect Fraktur a historic german script instead of the current script form? The dictionary which was learnt for the German language should be the same? For tesseract there is one trained file for Fraktur to ocr scan historic documents.
need indonesian language please
Hi Dear plz add the bangla and english support. I have attach both the file for bangla
bangla_dict.txt
Hi team. Great work on Paddle, it's an amazing OCR engine! Can we please have Hebrew support in multilanguage models ?
Thanks !
Can you provide for any ancient scripts?
Truong
I'm trying with my private data, but the result very poor
Sorry for my stupid question, I am novice at DL: What difference between Inference model and trained model?
This issue has been automatically marked as stale because it has not had recent activity. It will be closed in 7 days if no further activity occurs. Thank you for your contributions.
I created a PR for Bangla
Does this list contain the latest models? If i want to fine tune for example german model do i use this link from this page to download the pretrained model? If so what yml file should i use? How do i know what is the architecture of these models?
Please add Tajik Language
tajik_corpus.txt
tajik_dict.txt