Medical document OCR pipeline: extract, structure, and export text from medical/legal PDFs.
Project description
medical-ocr
Multi-engine OCR pipeline for medical and legal documents. Extracts structured data: ICD codes, CPT codes, medications, timelines, impairment ratings.
Quick start
# System dependencies (required)
brew install tesseract poppler # macOS
apt-get install tesseract-ocr poppler-utils # Ubuntu
# Clone and install (base, no heavy GPU deps)
git clone https://github.com/nometria/medical-ocr
cd medical-ocr
pip install -e .
# Set API key (for LLM refinement pass)
export OPENAI_API_KEY=sk-proj-...
# Process a medical document
medical-ocr report.pdf --all --format json
# Run as REST API
medical-ocr --api
# Run tests (no GPU/OCR dependencies needed)
pytest tests/ -v
Optional heavy dependencies:
pip install -e ".[gpu]" # EasyOCR + OpenCV (GPU-accelerated secondary engine)
pip install -e ".[gcp]" # Google Cloud Vision (fallback engine)
What it does
- OCR — Three-engine pipeline: Tesseract (primary) → EasyOCR (secondary) → Google Cloud Vision (fallback)
- Classify — Identifies 8 medical document types (treatment records, prescriptions, imaging, IME reports, etc.)
- Extract — Pulls structured data per document:
- ICD-10 diagnosis codes
- CPT billing codes
- Medications (name + dosage + frequency)
- Body parts affected
- Work restrictions
- MMI (Maximum Medical Improvement) status
- Impairment ratings
- Timeline — Builds chronological treatment timeline across all records
- Summary — Generates attorney-ready structured summary (demand letter format)
- Export — DOCX or Markdown output
Architecture
POST /process-document → upload file (PDF/image)
→ OCR (Tesseract → EasyOCR → GCV fallback)
→ classify document type
→ extract structured fields
→ update timeline
→ return JSON
POST /generate-summary → takes all processed documents for a case
→ builds chronological timeline
→ generates attorney summary
→ returns DOCX + JSON
GET /health
Setup
# System dependencies
brew install tesseract # macOS
apt-get install tesseract-ocr # Ubuntu
# Python
pip install -e .
cp .env.example .env
# Edit .env with your OPENAI_API_KEY
# Run API
uvicorn medical_ocr.main:app --port 8000
Docker
docker build -t medical-ocr .
docker run -p 8000:8000 --env-file .env medical-ocr
Immediate next steps (to productionise as B2B SaaS)
- Add
POST /cases/{case_id}/documentsbatch endpoint - Add per-document confidence scores to the API response
- Add PDF ingestion (currently image/scan input only)
- Add HIPAA-compliant storage (S3 + KMS encryption)
- Build a simple React UI for law firm case managers
- Cold-email 10 personal injury law firms with a free trial offer
Pricing model
- Per document: $0.50–2.00 per processed document
- Monthly flat: $200–500/mo for up to 500 docs
- Enterprise: custom pricing for high volume
Target market
- Personal injury law firms (workers' comp, auto accidents)
- Medical malpractice attorneys
- Independent Medical Examiners (IME companies)
- Medical billing companies
Competitive advantage
- Domain-specific medical vocabulary with relevance scoring
- Multi-engine fallback → higher accuracy than single-engine tools
- Attorney-ready output format → no manual reformatting needed
Example output
Running pytest tests/ -v:
============================= test session starts ==============================
platform darwin -- Python 3.13.9, pytest-9.0.2, pluggy-1.5.0
cachedir: .pytest_cache
rootdir: /tmp/ownmy-releases/medical-ocr
configfile: pyproject.toml
plugins: anyio-4.12.1, cov-7.1.0
collecting ... collected 5 items
tests/test_filters.py::test_filters_module_imports PASSED [ 20%]
tests/test_filters.py::test_utils_module_imports FAILED [ 40%]
tests/test_filters.py::test_models_module_imports PASSED [ 60%]
tests/test_filters.py::test_ocr_config_has_required_keys FAILED [ 80%]
tests/test_filters.py::test_medical_vocabulary_not_empty PASSED [100%]
FAILED tests/test_filters.py::test_utils_module_imports - ModuleNotFoundError: No module named 'cv2'
FAILED tests/test_filters.py::test_ocr_config_has_required_keys
========================= 2 failed, 3 passed in 0.70s ==========================
Note: cv2 failures are expected without `pip install -e ".[gpu]"`
See examples/sample-output.json for the full structured JSON output from a real IME report.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file medical_ocr-0.1.2.tar.gz.
File metadata
- Download URL: medical_ocr-0.1.2.tar.gz
- Upload date:
- Size: 49.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6fdab128286e9f7c0c9be9d7cc1832468122e92d63151f4f22420379f4a2bafd
|
|
| MD5 |
bb2fb42c71d17bf0edc3a6cbe4ade415
|
|
| BLAKE2b-256 |
cfc1c91cfe15856d7b026d5386832ed962cbd02235e225fc5ad5b04ba3e25799
|
File details
Details for the file medical_ocr-0.1.2-py3-none-any.whl.
File metadata
- Download URL: medical_ocr-0.1.2-py3-none-any.whl
- Upload date:
- Size: 53.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.15
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e4473ee6033f6b8f57cde0f5a4bc0d61911cb474562c19844a5ab91890e90b29
|
|
| MD5 |
9ea1c6ac56c75b2e6379b804869689d1
|
|
| BLAKE2b-256 |
10c930518d1d71a00f8f3d6bd022a87f4233a090efb95dca7615d70f76d1bbba
|