Skip to main content

High-speed, high-accuracy, local OCR for Japanese video games.

Project description

meikiocr

license: apache 2.0 hugging face space detection model recognition model

high-speed, high-accuracy, local ocr for japanese video games.

meikiocr is a python-based ocr pipeline that combines state-of-the-art detection and recognition models to provide an unparalleled open-source solution for extracting japanese text from video games and similar rendered content.

original image ocr result
input input_ocrresult
ナルホド
こ、こんなにドキドキするの、
小学校の学級裁判のとき以来です。

live demo

the easiest way to see meikiocr in action is to try the live demo hosted on hugging face spaces. no installation required!

try the meikiocr live demo here


core features

  • high accuracy: purpose-built and trained on japanese video game text, meikiocr significantly outperforms general-purpose ocr tools like paddleocr or easyocr on this specific domain.
  • high speed: the architecture is pareto-optimal, delivering exceptional performance on both cpu and gpu.
  • fully local & private: unlike cloud-based services, meikiocr runs entirely on your machine, ensuring privacy and eliminating api costs or rate limits.
  • cross-platform: it works wherever onnx runtime runs, providing a much-needed local ocr solution for linux users.
  • open & free: both the code and the underlying models are freely available under permissive licenses.

performance & benchmarks

meikiocr is built from two highly efficient models that establish a new pareto front for japanese text recognition. this means they offer a better accuracy/latency tradeoff than any other known open-weight model.

detection (cpu) detection (gpu)
accuracy_vs_cpu_latency accuracy_vs_gpu_latency
recognition (cpu) recognition (gpu)
accuracy_vs_cpu_latency accuracy_vs_gpu_latency

installation

pip install meikiocr

for nvidia gpu users (recommended)

for a massive performance boost, you can install the gpu-enabled version of the onnx runtime. this will be detected automatically by the script.

pip install meikiocr
pip uninstall onnxruntime
pip install onnxruntime-gpu

usage - cli

after installation, you can use the meikiocr tool directly from your terminal.

meikiocr image.png

options

  • save visualization: draw bounding boxes and save the result to a file.
    meikiocr image.png --output result.jpg
    
  • json output: get detailed results (coordinates, confidence scores) for integration with other scripts.
    meikiocr image.png --json
    
  • adjust thresholds: fine-tune detection and recognition sensitivity.
    meikiocr image.png --det-threshold 0.6 --rec-threshold 0.2
    

run meikiocr --help for a full list of available options.

usage - python

this is how meikiocr can be called. you can also run demo.py for additional visual output.

import cv2
import numpy as np
from urllib.request import urlopen
from meikiocr import MeikiOCR

IMAGE_URL = "https://huggingface.co/spaces/rtr46/meikiocr/resolve/main/example.jpg"

with urlopen(IMAGE_URL) as resp:
    image = cv2.imdecode(np.asarray(bytearray(resp.read()), dtype="uint8"), cv2.IMREAD_COLOR)

ocr = MeikiOCR() # Initialize the OCR pipeline
results = ocr.run_ocr(image) # Run the full OCR pipeline
print('\n'.join([line['text'] for line in results if line['text']]))

adjusting thresholds

you can adjust the confidence thresholds for both the text line detection and the character recognition models. lowering the thresholds results in more detected text lines and characters, while higher values prevent false positives.

MeikiOCR().run_ocr(self, image, det_threshold=0.8, rec_threshold=0.2) # less, but more confident text boxes and characters returned

running dedicated detection

if you only care about the position of the text and not the content you can run the detection by itself, which is faster than running the whole ocr pipeline:

MeikiOCR().run_detection(self, image, det_threshold=0.8, rec_threshold=0.2) # only returns text line coordinates

in the same way you can also run_recognition by itself on images of precropped text lines.

how it works

meikiocr is a two-stage pipeline:

  1. text detection: the meiki.text.detect.v0 model first identifies the bounding boxes of all text lines in the image.
  2. text recognition: each detected text line is then cropped and processed in a batch by the meiki.text.recognition.v0 model, which recognizes the individual characters within it.

limitations

while meikiocr is state-of-the-art for its niche, it's important to understand its design constraints:

  • domain specific: it is highly optimized for rendered text from video games and may not perform well on handwritten or complex real-world scene text.
  • architectural limits: the detection model is capped at finding 64 text boxes, and the recognition model can process up to 48 characters per line. these limits are sufficient for over 99% of video game scenarios but may be a constraint for other use cases.
  • vertical text line accuracy: vertical text line support is in beta. it should work, but dont expect the same level of accuracy as on horizontal lines.

advanced usage & potential

the meiki_ocr.py script provides a straightforward implementation of a post-processing pipeline that selects the most confident prediction for each character. however, the raw output from the recognition model is richer and can be used for more advanced applications. for example, one could build a language-aware post-processing step using n-grams to correct ocr mistakes by considering alternative character predictions.

this opens the door for meikiocr to be integrated into a variety of projects.

license

this project is licensed under the apache 2.0 license. see the license file for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

meikiocr-0.3.4.tar.gz (18.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

meikiocr-0.3.4-py3-none-any.whl (16.0 kB view details)

Uploaded Python 3

File details

Details for the file meikiocr-0.3.4.tar.gz.

File metadata

  • Download URL: meikiocr-0.3.4.tar.gz
  • Upload date:
  • Size: 18.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.5

File hashes

Hashes for meikiocr-0.3.4.tar.gz
Algorithm Hash digest
SHA256 76de1d26c2c4dc141322be7d0e5a54af98e052ca8cfcbaefd2891f372e1344f1
MD5 35694577cd0e989ff40bd3ec0ca606f8
BLAKE2b-256 08f89a0ca64ebde6c40f215b89c83716156a0c5feca85914afd72185d7c9af08

See more details on using hashes here.

File details

Details for the file meikiocr-0.3.4-py3-none-any.whl.

File metadata

  • Download URL: meikiocr-0.3.4-py3-none-any.whl
  • Upload date:
  • Size: 16.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.5

File hashes

Hashes for meikiocr-0.3.4-py3-none-any.whl
Algorithm Hash digest
SHA256 95d03291b1b2c84a9ff8607f63fe14688cec5a038f9b30cffdcdab87a3217a07
MD5 3c10f455ebe441682868d8a55d1d2eb0
BLAKE2b-256 5ce3bd9d1cd5c35998027e04495b3e31688c6f2ce5316f9789bb6d4d34539a1c

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page