Skip to main content

No project description provided

Project description

🔤 Optical Character Recognition (OCR) Filter

OCR Filter is a modular OpenFilter-based filter for extracting text from video frames using EasyOCR or Tesseract.

It supports frame-by-frame OCR, optional skipping via metadata, and flexible deployment as part of OpenFilter pipelines.

PyPI version License: Apache 2.0 Build Status


✨ Features

  • 🧾 Extracts text using EasyOCR or Tesseract from frames
  • 🔍 Supports per-frame metadata control (e.g. skip OCR)
  • ⚙️ Configurable via CLI args, code, or environment variables
  • 🧩 Plug-and-play compatibility with OpenFilter
  • 📤 Outputs recognized text, ocr confidence score and bounding boxes as metadata

📦 Installation

Install the latest version from PyPI:

pip install filter-optical-character-recognition

Or install from source:

# Clone the repo
git clone https://github.com/PlainsightAI/filter-optical-character-recognition.git
cd filter-optical-character-recognition

# (Optional but recommended) create a virtual environemnt:
python -m venv venv && source venv/bin/activate

# Install the filter
make install

💡 The make install target installs openfilter[all], ensuring dependencies like VideoIn and Webvis work out of the box.


🚀 Quick Start (CLI)

Run the OCR Filter using the OpenFilter CLI:

# Most basic version, no annotion or result logging
openfilter run \
  - VideoIn --sources 'file://video_example.mp4!loop' \
  - filter_optical_character_recognition.filter.FilterOpticalCharacterRecognition \
  - Webvis

# Log results into stdout
openfilter run \
  - VideoIn --sources 'file://video_example.mp4!loop' \
  - filter_optical_character_recognition.filter.FilterOpticalCharacterRecognition \
    --mq_log pretty
  - Webvis

# Annotation enabled, overlaying detected text out output
openfilter run \
  - VideoIn --sources 'file://video_example.mp4!loop' \
  - filter_optical_character_recognition.filter.FilterOpticalCharacterRecognition \
      --ocr_engine easyocr \
      --forward_ocr_texts true \
      --draw_visualization true \
      --visualization_topic "main" \
      --topic_pattern "main" \
  - Webvis

Or simply:

make run

Then open http://localhost:8000 to view the output.

📄 See the .env.example file for environment variable options.


🧰 Using from PyPI

After installing with:

pip install filter-optical-character-recognition

you can use the OCR Filter directly in code:

Example usage

from openfilter.filter_runtime.filter import Filter
from openfilter.filter_runtime.filters.video_in import VideoIn
from openfilter.filter_runtime.filters.webvis import Webvis
from filter_optical_character_recognition.filter import FilterOpticalCharacterRecognition

if __name__ == "__main__":
    Filter.run_multi([
      (VideoIn, dict(
          sources='file://video_example.mp4!loop',
          outputs='tcp://*:5550'
      )),
      (FilterOpticalCharacterRecognition, dict(
          sources='tcp://localhost:5550',
          outputs='tcp://*:5552',
          draw_visualization=True,
          visualization_topic="main"
      )),
      (Webvis, dict(
          sources='tcp://localhost:5552'
      )),
    ])

🧪 Testing

Run tests locally:

make test

Or run a specific test file:

pytest -v tests/test_filter_ocr.py

Tests cover:

  • OCR accuracy and bounding box parsing
  • skip_ocr handling
  • Frame metadata propagation
  • Integration in multi-filter pipelines

🔧 Special Features

Metadata-Based Skipping

You can skip OCR on specific frames by setting this field:

"meta": {
  "skip_ocr": true
}

This allows selective processing and performance tuning.


🔩 Requirements

The OCR Filter depends on the following tools:

Ensure the tesseract binary is available in your environment when running OCR with Tesseract.


🤝 Contributing

We welcome contributions! Please read our CONTRIBUTING.md for instructions.

Highlights:

  • Format code with black
  • Lint with ruff
  • Use type hints on public methods
  • Sign commits using DCO (git commit -s)
  • Include tests when relevant

📄 License

Licensed under the Apache 2.0 License.


🙏 Acknowledgements

Thanks for using the OCR Filter! For questions or feature requests, open a GitHub issue.

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

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

File details

Details for the file filter_optical_character_recognition-0.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for filter_optical_character_recognition-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 a3885af505b84f93a4eb118c495d58a9fa4371e376102085f8515a227707f7db
MD5 79900b27b0f46d78a23d2a2c54e4959c
BLAKE2b-256 00f5c58b7a33aecc3d9778aedaae8efcf5f6bf8ec53c8081243cb7120444ddcd

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