Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Multilingual support #1699

Open
decadance-dance opened this issue Aug 20, 2024 · 28 comments
Open

Multilingual support #1699

decadance-dance opened this issue Aug 20, 2024 · 28 comments
Labels
Milestone

Comments

@decadance-dance
Copy link

🚀 The feature

Support of multiple languages (accordingly VOCABS["multilingual"]) by pretrained models.

Motivation, pitch

It would be great to use models which supports multiple languages because it significantly improve user experience in various cases.

Alternatives

No response

Additional context

No response

@felixdittrich92
Copy link
Contributor

Hi @decadance-dance 👋,

Have you already tried:
docTR: https://huggingface.co/Felix92/doctr-torch-parseq-multilingual-v1
OnnxTR: https://huggingface.co/Felix92/onnxtr-parseq-multilingual-v1
? :)

Depends a bit if there is any data from mindee we could use.
Question goes to @odulcy-mindee ^^

@decadance-dance
Copy link
Author

Hi, @felixdittrich92
I used docTR more than half year but have never faced this multilingual model, lol.
So, I am gonna try it, thanks.

@felixdittrich92
Copy link
Contributor

Ah let's keep this issue open there is more todo i think :)

@felixdittrich92
Copy link
Contributor

Hi, @felixdittrich92 I used docTR more than half year but have never faced this multilingual model, lol. So, I am gonna try it, thanks.

Happy about an feedback how it works for you :)
The model was fine tuned only on synth data.

@odulcy-mindee
Copy link
Collaborator

Depends a bit if there is any data from mindee we could use.
Question goes to @odulcy-mindee ^^

Unfortunately, we don't have such data

@felixdittrich92
Copy link
Contributor

felixdittrich92 commented Aug 27, 2024

@decadance-dance
For training such recognition models i don't see a problem.. we can generate synth train data and need in a best case only real val samples.
But for detection we would need real data that's the main issue.

In general we would need the help of the community to collect documents (newspaper, receipt photos, etc.) in divers langauges (can be unlabeled). / This would need a license to sign that we can freely use this data.
With enough divers data we could use Azure Doc AI for example to pre-label this data.
Later on i wouldn't see an issue to open source this dataset.

But not sure how to trigger such "event" 😅 @odulcy-mindee

@nikokks
Copy link
Contributor

nikokks commented Sep 6, 2024

Hello =)
I found some public dataset for various tasks
english documents
mathematics documents
latex ocr
latex ocr
chinese ocr
chinese ocr
chinese ocr

@nikokks
Copy link
Contributor

nikokks commented Sep 6, 2024

Moreover it should be interesting for Chinese detection models to add multiple recognition data in the same image without intersection. This should help for a Chinese detection model to perform better without real detection data.
Anyone interested in creating random multilingual data for detection models (hindi, chinese, etc.) ?

@felixdittrich92
Copy link
Contributor

Hi @nikokks 😃
Recognition should not be such a big deal i found already a good way to generate such data for fine tuning.

To collect multilingual data for detection is troublesome because it should be real data (or if possible really good generated ones / for example with a fine tuned FLUX model maybe !?)
We need different kinds of layouts/documents (newspapers, invoices, receipts, cards, etc.) so the data should come close to real use cases (not only scans also document photos etc.)
:)

@decadance-dance
Copy link
Author

To collect multilingual data for detection is troublesome because it should be real data

Do you can estimate how much data we need to provide multilingual capabilities on the same level as only english ocr is?

@felixdittrich92
Copy link
Contributor

felixdittrich92 commented Oct 10, 2024

Hi @decadance-dance 👋,

I think if we could collect ~100-150 different types of documents for each language we would have a good starting point (at the end the language doesn't matter it's more about the different char sets / fonts / text sizes) - for example:
bild_design
is super useful because it captures a lot of different fonts / text sizes
or something "in the wild":
img_03771

At the end it's more critical to take care that we really can use such images legally.

The tricky part is the detection because we need complete real data .. if we have this it should be much easier for the recognition part we could create some synth data and eval on the already collected real data.

I think if we are able to collect the data up to end of january i could provide pre-labeling via Azure's Document AI.

Currently missing parts are:

  • handwritten (for the detection model - recognition is another story)
  • chinese (symbols)
  • hindi
  • bulgarian/ukrainian/russian/serbian (cyrillic)
  • special symbols (bullet points, etc.)
  • more latin based (spanish, czech, ..)
  • ...

CC @odulcy-mindee

Lang list: https://github.com/eymenefealtun/all-words-in-all-languages

@decadance-dance
Copy link
Author

@felixdittrich92, thank you for a detailed answer.
I'd help to collect data. It would be great if we can populate this initiative to our community. I think if everyone provides at least a couple of samples, then a good amount of data can be collected.
BTW, Is there any flow or established process for collecting and submitting data?

@felixdittrich92
Copy link
Contributor

felixdittrich92 commented Oct 10, 2024

@decadance-dance Not yet ..maybe the easiest would be to create a huggingface space for this because from this you could also do easily pictures from your smartphone and under the hood we push the taken or uploaded images into an HF dataset.

In this case we could also add an agreement before any data can be uploaded that the person who uploads agrees to have all rights on the image and uploads the image with the knowledge to provide the uploaded images openly to everyone who downloads the dataset.

Wdyt ?

Again CC @odulcy-mindee :D

@ramSeraph
Copy link

I found one possible dataset for printed documents for multiple languages. It is wikisource. They have text and images at the page level, originally created using some existing OCR(Google vision/tesseract) and the data has then been corrected/proofread by people. They have annotations to differentiate what has been proofread and what has not been. An example - https://te.wikisource.org/wiki/పుట%3AAandhrakavula-charitramu.pdf/439. The license would be CC-BY-SA and I am expecting them to only have pulled books for which copyright has expired. Collecting fonts for various languages is a bigger problem though( because of licenses ).

@felixdittrich92 felixdittrich92 pinned this issue Oct 11, 2024
@felixdittrich92
Copy link
Contributor

Thanks @ramSeraph for sharing i will have a look 👍

@decadance-dance @nikokks

I created a space which can be used to collect some data (only raw data for starting) wdyt ?
https://huggingface.co/spaces/Felix92/docTR-multilingual-Datacollector

Later on if we say we have collected enough raw data we can filter the data and pre-label with Azure Document AI.

@decadance-dance
Copy link
Author

decadance-dance commented Oct 21, 2024 via email

@felixdittrich92
Copy link
Contributor

@decadance-dance @nikokks @ramSeraph @allOther

I created an request to the mindee team to provide support on this task.
https://mindee-community.slack.com/archives/C02HGHMUJH0/p1730452486444309

Would be nice if you could write a comment in the thread about your needs to support this 🙏

@felixdittrich92
Copy link
Contributor

felixdittrich92 commented Nov 12, 2024

First stage would be to improve the detection models, for the sec stage the recognition part we could generate additional synthetic data

@felixdittrich92
Copy link
Contributor

felixdittrich92 commented Nov 19, 2024

Short update here:

I collected ~30k samples containing:
~7k arabic
~1k hindi
~1k chinese
~1k thai
~4k cyrillic
~1k greek
~5k additional latin extended (polish, spanish, and so on)
(including ~15% handwritten - most russian, arabic and latin)
~10k receipts around the globe

Now i need to find a way to annotate all these data - AWS Textract & Azure Document AI failed as possible useful prelabeling solution

Best results reached with docTR/OnnxTR (only detection) - but still to much issues to include it directly into our dataset for pretraining.

@decadance-dance
Copy link
Author

Now i need to find a way to annotate all these data - AWS Textract & Azure Document AI failed as possible useful prelabeling solution

Why did they faile?

@felixdittrich92
Copy link
Contributor

Now i need to find a way to annotate all these data - AWS Textract & Azure Document AI failed as possible useful prelabeling solution

Why did they faile?

Detection results was really worse for many samples

@decadance-dance
Copy link
Author

For training such recognition models i don't see a problem.. we can generate synth train data and need in a best case only real val samples.

how do you think what way of generating synth word text is more beneficial?
a) use predefined vocab and randomly sample characters from it into a given range, like you are doing in _WordGenerator
b) use predefined text corpus and randomly sample entire words from it
c) combine (a) and (b)

@decadance-dance
Copy link
Author

Detection results was really worse for many samples

How did you evaluate them? As I understood your data is not annotated yet.
Did you check samples manually?

@decadance-dance
Copy link
Author

AWS Textract & Azure Document AI failed as possible useful prelabeling solution

maybe easy-ocr will work for you?

@felixdittrich92
Copy link
Contributor

Detection results was really worse for many samples

How did you evaluate them? As I understood your data is not annotated yet. Did you check samples manually?

I OCR'd some samples with Azure Document AI and Textract and wrote a script to visualize these samples for OnnxTR i prelabeled all Files and also checked the Same files manually

@felixdittrich92
Copy link
Contributor

AWS Textract & Azure Document AI failed as possible useful prelabeling solution

maybe easy-ocr will work for you?

Haven't tested yet with this data but if i remember docTR was in the most cases more accure

@felixdittrich92
Copy link
Contributor

For training such recognition models i don't see a problem.. we can generate synth train data and need in a best case only real val samples.

how do you think what way of generating synth word text is more beneficial? a) use predefined vocab and randomly sample characters from it into a given range, like you are doing in _WordGenerator b) use predefined text corpus and randomly sample entire words from it c) combine (a) and (b)

I would go with option b and augment a fixed part of this data (words) with low frequent characters (like the % symbol).

I did the same to train the multilingual parseq model :)

@felixdittrich92
Copy link
Contributor

I think the only option is to label a part of the data manually -> fine tune -> pre-label -> correct and again in an iterative process 🙈😅 (really time consuming)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

5 participants