A structured pipeline for transforming video content into **searchable, metadata-rich, and SEO-optimized assets**, combining ingestion, transcription, OCR, NLP enrichment, and persistent storage.
Project description
Part of the Abstract Media Intelligence Platform
This module handles video ingestion and multimodal extraction within a unified media pipeline.
abstract_videos processes:
- video download + metadata registry
- transcription (Whisper) + frame OCR
- NLP enrichment and structured storage
Full system: https://github.com/AbstractEndeavors/abstract-media-intelligence
abstract_videos — Video Processing & Media Intelligence Pipeline
A structured pipeline for transforming video content into searchable, metadata-rich, and SEO-optimized assets, combining ingestion, transcription, OCR, NLP enrichment, and persistent storage.
Designed for:
- large-scale video ingestion
- transcription and content extraction
- media indexing and search
- automated metadata generation and SEO
🔹 What This System Is
abstract_videos is not a downloader or transcription tool — it is a multi-stage media processing system:
- ingests video from URLs or local sources
- extracts audio, frames, and text
- performs transcription (Whisper)
- applies OCR to extracted frames
- enriches content via NLP (keywords, summaries, titles)
- persists structured results to database or filesystem
The system produces fully structured video representations usable for:
- search
- indexing
- content generation
- analytics
🔹 Pipeline Overview
Video Input (URL / File)
↓
Download + Registry (yt-dlp + metadata)
↓
Video Processing
├─ Conversion / normalization
├─ Audio extraction
├─ Frame extraction
↓
Content Extraction
├─ Transcription (Whisper)
├─ OCR on frames
↓
NLP Enrichment
├─ Summarization
├─ Keyword extraction
├─ Title generation
↓
Metadata Assembly
↓
Persistence Layer
├─ Database (JSONB structured storage)
└─ Filesystem (artifacts + media)
Pipeline
flowchart TD
A[Video URL / Local Video]
B[VideoDownloader + Registry]
C[Normalization / Conversion]
D[Audio Extraction]
E[Frame Extraction]
F[Whisper Transcription]
G[Frame OCR]
H[NLP Enrichment\nSummary + Keywords + Title]
I[Metadata Assembly\nCategory + Thumbnail + SEO]
J[Persistence Layer\nFilesystem + DB / JSONB]
K[Searchable / Structured Video Record]
A --> B --> C
C --> D --> F
C --> E --> G
F --> H
G --> H
H --> I --> J --> K
🔹 Core Capabilities
Video Ingestion & Registry
- URL normalization and ID generation
- Metadata extraction via yt-dlp
- Persistent registry with atomic updates and locking
Processing Pipeline
- Video normalization and format handling
- Audio extraction for transcription
- Frame extraction for visual analysis
Transcription & OCR
- Whisper-based transcription pipeline
- Frame-level OCR for embedded text
- Combined multimodal text extraction
NLP & Metadata Enrichment
- Keyword extraction and refinement
- Title generation from summaries
- Category inference based on content
- Thumbnail selection via frame sharpness analysis
Structured Persistence
-
PostgreSQL storage with JSONB fields for:
- raw info
- metadata
- transcripts
- captions
- thumbnails
- aggregated outputs
-
Upsert-based lifecycle management for idempotent processing
🔹 Dual Pipeline Model (Key Concept)
The system supports two execution modes:
1. Local / Read-Write Pipeline
- full processing on local machine
- filesystem-based outputs
- direct artifact generation
2. Database-Centric Pipeline
- persistent storage as primary interface
- JSONB-backed structured data
- incremental updates and enrichment
🔹 Design Intent
Database + local modules as primary External ML (HuggingFace / APIs) as secondary
This enables:
- offline-first operation
- reproducibility
- plug-and-play ML upgrades
🔹 Architecture
Core Components
-
VideoDownloader
- ingestion + metadata acquisition
-
infoRegistry
- centralized state + persistence
-
VideoTextPipeline
- orchestrates processing stages
-
Metadata Console
- post-processing and optimization (summaries, SEO)
-
Database Layer
- structured storage with upsert semantics
🔹 Key Design Decisions
Idempotent Processing
- all steps tracked via
processed_steps - pipeline resumes without duplication
- safe reprocessing of partial runs
Structured Over Raw
Everything is stored as structured JSON:
- transcripts
- keywords
- metadata
- derived content
Multimodal Extraction
Combines:
- audio → text (transcription)
- image → text (OCR)
- text → meaning (NLP)
Registry as Source of Truth
- central video registry
- thread-safe and process-safe updates
- ensures consistency across runs
🔹 Why This Exists
Most video pipelines:
- stop at transcription
- lack structure
- are not searchable
- are not reusable
abstract_videos transforms video into:
- structured data
- searchable content
- SEO-ready metadata
- indexable media assets
🔹 Example Use Cases
- video → searchable content pipelines
- media indexing platforms
- transcription + analytics systems
- SEO content generation
- LLM-ready dataset creation
🔹 Integration Context
This system integrates directly with:
abstract_hugpy→ NLP / summarization / keyword extractionabstract_ocr→ image/frame OCRabstract_pdfs→ document pipeline
🔹 Design Philosophy
- Media is data, not just content
- Structure enables reuse
- Pipelines should be resumable and deterministic
- Local-first, cloud-optional
Project details
Release history Release notifications | RSS feed
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 abstract_videos-0.0.0.266.tar.gz.
File metadata
- Download URL: abstract_videos-0.0.0.266.tar.gz
- Upload date:
- Size: 20.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
afcd92010e4881eb20298d58143b78067cccad7e45298c4204e14ce27e7a08a6
|
|
| MD5 |
6fd3b51ad6c6ea7e1fe2c39d8d051fd8
|
|
| BLAKE2b-256 |
3adec7c9b32b42ceeb79e8cacf907e3481db70544b04070978dc679f8b87f8a9
|
File details
Details for the file abstract_videos-0.0.0.266-py3-none-any.whl.
File metadata
- Download URL: abstract_videos-0.0.0.266-py3-none-any.whl
- Upload date:
- Size: 21.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6076b5bfda890c652293a213fdacab90ebb059fb5bf561c7eb082158cda44247
|
|
| MD5 |
e6bb5e540f1e9cc107b8faf4ca0a3d2c
|
|
| BLAKE2b-256 |
07a7b09e9bccae5bcb18ce1794a74e8ee5347560ac7b98b99c2d5678a95adbdd
|