Connect language models to vision models for natural language visual analysis
Project description
๐ง Langvio: Natural Language Computer Vision
Connect language models to vision models for natural language visual analysis
๐ Quick Start โข ๐ Documentation โข ๐ฏ Examples โข ๐ง Installation โข ๐ค Contributing
โจ What is Langvio?
Langvio bridges the gap between human language and computer vision. Ask questions about images and videos in plain English, and get intelligent analysis powered by state-of-the-art vision models and language models.
๐ฏ Key Features
- ๐ฃ๏ธ Natural Language Interface: Ask questions like "Count all red cars" or "Find people wearing yellow"
- ๐ฅ Multi-Modal Support: Works with both images and videos
- ๐ Powered by YOLO-World v2: Fast, accurate object detection without predefined classes
- ๐น ByteTracker Integration: Advanced multi-object tracking for video analysis with boundary crossing detection
- ๐ค LLM Integration: Supports OpenAI GPT and Google Gemini for intelligent explanations
- ๐ Advanced Analytics: Object counting, speed estimation, spatial relationships, temporal tracking
- ๐จ Visual Output: Generates annotated images/videos with detection highlights and tracking trails
- ๐ Web Interface: Includes a Flask web app for easy interaction
- ๐ง Extensible: Easy to add new models and capabilities
๐ฌ See It In Action
import langvio
# Create a pipeline
pipeline = langvio.create_pipeline()
# Analyze an image
result = pipeline.process(
query="Count how many people are wearing red shirts",
media_path="street_scene.jpg"
)
print(result['explanation'])
# Output: "I found 3 people wearing red shirts in the image.
# Two are located in the center-left area, and one is on the right side."
# View the annotated result
print(f"Annotated image saved to: {result['output_path']}")
๐ง Installation
Basic Installation
pip install langvio
With LLM Provider Support
Choose your preferred language model provider:
# For OpenAI models (GPT-3.5, GPT-4)
pip install langvio[openai]
# For Google Gemini models
pip install langvio[google]
# For all supported providers
pip install langvio[all-llm]
# For development
pip install langvio[dev]
Environment Setup
- Create a
.envfile for your API keys:
# Copy the template
cp .env.template .env
- Add your API keys to
.env:
# For OpenAI
OPENAI_API_KEY=your_openai_api_key_here
# For Google Gemini
GOOGLE_API_KEY=your_google_api_key_here
- Langvio automatically loads these environment variables!
๐ Quick Start
Basic Usage
import langvio
# Create a pipeline (automatically detects available LLM providers)
pipeline = langvio.create_pipeline()
# Process an image
result = pipeline.process(
query="What objects are in this image?",
media_path="path/to/your/image.jpg"
)
print(result['explanation'])
print(f"Output: {result['output_path']}")
Video Analysis
# Analyze videos with temporal understanding
result = pipeline.process(
query="Count vehicles crossing the intersection",
media_path="traffic_video.mp4"
)
# Get detailed analysis including speed and movement patterns
print(result['explanation'])
Web Interface
# Launch the web interface
cd webapp
python app.py
# Visit http://localhost:5000 in your browser
๐ฏ Examples
Object Detection & Counting
# Count specific objects
pipeline.process("How many cars are in this parking lot?", "parking.jpg")
# Find objects by attributes
pipeline.process("Find all red objects in this image", "scene.jpg")
# Spatial relationships
pipeline.process("What objects are on the table?", "kitchen.jpg")
Video Analysis with ByteTracker
# Track movement patterns (uses ByteTracker for multi-object tracking)
pipeline.process("Track people walking through the scene", "crowd.mp4")
# Boundary crossing detection (ByteTracker tracks entry/exit)
pipeline.process("How many vehicles entered vs exited the intersection?", "traffic.mp4")
# Speed analysis (uses tracked trajectories from ByteTracker)
pipeline.process("What's the average speed of vehicles?", "highway.mp4")
# Activity detection with temporal tracking
pipeline.process("Detect any unusual activities", "security_footage.mp4")
# Object counting with tracking
pipeline.process("Count people entering and exiting the building", "entrance.mp4")
Advanced Queries
# Complex multi-part analysis
pipeline.process(
"Count people and vehicles, identify their locations, and note distinctive colors",
"street_scene.jpg"
)
# Verification tasks
pipeline.process("Is there a dog in this image?", "park_scene.jpg")
# Temporal analysis
pipeline.process("How many people entered vs exited the building?", "entrance.mp4")
๐๏ธ Architecture
graph TD
A[User Query] --> B[LLM Processor]
B --> C[Query Parser]
C --> D[Vision Processor]
D --> E[YOLO-World Detection]
E --> F[Attribute Analysis]
F --> G[Spatial Relationships]
G --> H{Is Video?}
H -->|Yes| I[ByteTracker Multi-Object Tracking]
H -->|No| J[LLM Explanation]
I --> K[Boundary Crossing Detection]
K --> L[Speed Estimation]
L --> M[Temporal Analysis]
M --> J
J --> N[Visualization]
N --> O[Output with Tracking Trails]
Core Components
- ๐ง LLM Processor: Parses queries and generates explanations (OpenAI, Google Gemini)
- ๐๏ธ Vision Processor: Detects objects and attributes using YOLO-World v2
- ๐น ByteTracker: Multi-object tracking system for video analysis with boundary crossing detection
- ๐จ Media Processor: Creates visualizations and handles I/O
- โ๏ธ Pipeline: Orchestrates the entire workflow
๐ Supported Models
Vision Models
- YOLO-World v2 (small, medium, large, extra-large)
yolo_world_v2_s- Small (fastest)yolo_world_v2_m- Medium (balanced, default)yolo_world_v2_l- Large (most accurate)yolo_world_v2_x- Extra-large (highest accuracy)
- Automatic model selection based on performance needs
Language Models
- OpenAI: GPT-3.5 Turbo (
gpt-3.5), GPT-4 Turbo (gpt-4) - Google: Gemini Pro (
gemini) - Extensible architecture for adding more providers
๐ ๏ธ Configuration
Custom Configuration
# config.yaml
llm:
default: "gemini"
models:
gemini:
model_name: "gemini-2.0-flash"
model_kwargs:
temperature: 0.2
vision:
default: "yolo_world_v2_m"
models:
yolo_world_v2_m:
type: "yolo_world"
model_name: "yolov8m-worldv2"
confidence: 0.45
# ByteTracker configuration
track_thresh: 0.3 # Detection confidence threshold for tracking
track_buffer: 70 # Frames to keep lost tracks
match_thresh: 0.6 # IoU threshold for track matching
media:
output_dir: "./results"
visualization:
box_color: [0, 255, 0]
line_thickness: 2
# Use custom configuration
pipeline = langvio.create_pipeline(config_path="config.yaml")
Command Line Interface
# Basic usage
langvio --query "Count the cars" --media image.jpg
# With custom configuration
langvio --query "Find red objects" --media scene.jpg --config custom.yaml
# List available models
langvio --list-models
๐ Advanced Features
Video Tracking with ByteTracker
Langvio uses ByteTracker for robust multi-object tracking in videos. ByteTracker is a state-of-the-art tracking algorithm that maintains object identity across video frames, even through occlusions and complex scenes.
Key ByteTracker Capabilities:
- Multi-Object Tracking: Tracks multiple objects simultaneously with unique persistent IDs
- Boundary Crossing Detection: Automatically detects when objects enter/exit defined regions
- Object Counting: Accurate counting with entry/exit tracking (in/out counts)
- Speed Estimation: Calculates object speeds based on tracked trajectories over time
- Track Persistence: Maintains object identity even through occlusions and temporary disappearances
- Configurable Tracking: Adjustable thresholds for tracking confidence, buffer, and matching
ByteTracker Technical Features:
- Kalman filter-based motion prediction for smooth tracking
- IoU-based data association for matching detections to tracks
- Track buffer management for handling occlusions (configurable buffer size)
- High/low confidence detection handling for robust tracking
- Automatic track initialization and termination
YOLO-World v2 + ByteTracker Integration
The combination of YOLO-World v2 detection and ByteTracker tracking provides:
- Seamless Integration: YOLO-World detections feed directly into ByteTracker for tracking
- Efficient Processing: Optimized frame sampling (default: every 5th frame, every 2nd for tracking tasks)
- Track File Management: Saves/loads tracking data as JSON for faster re-analysis
- Visualization: Draws tracking trails, object IDs, and trajectories on video output
- Performance: Handles real-time video processing with configurable quality/speed tradeoffs
Spatial Relationship Analysis
- Positional Understanding: "objects on the table", "cars in the parking lot"
- Relative Positioning: left/right, above/below, near/far relationships
- Containment Detection: objects inside other objects
Temporal Analysis (Video)
Powered by ByteTracker multi-object tracking:
- Movement Patterns: Track object trajectories and behaviors across frames
- Activity Recognition: Detect activities and interactions over time
- Temporal Relationships: Understand object co-occurrence and interactions
- Trajectory Analysis: Visualize and analyze object movement paths
- Entry/Exit Tracking: Monitor objects crossing boundaries or entering/exiting regions
Color & Attribute Detection
- Advanced Color Recognition: 50+ color categories with confidence scoring
- Size Classification: Automatic small/medium/large categorization
- Multi-attribute Analysis: Combined color, size, and position analysis
๐ Performance & Optimization
Model Selection Strategy
# Automatic model selection based on use case
pipeline = langvio.create_pipeline() # Uses best available model
# Manual model selection for specific needs
pipeline = langvio.create_pipeline(
vision_name="yolo_world_v2_l", # High accuracy
llm_name="gpt-4" # Advanced reasoning
)
Optimization Tips
- YOLO-World models: Better accuracy for complex scenes with flexible object detection
- Model selection: Use smaller models (
yolo_world_v2_s) for speed, larger (yolo_world_v2_l) for accuracy - Confidence thresholds: Adjust based on precision/recall needs (lower = more detections)
- Frame sampling: Control video processing speed vs accuracy (default: every 5th frame)
- Environment variables: Use
LANGVIO_DEFAULT_LLMandLANGVIO_DEFAULT_VISIONto set defaults
๐งช Testing
Langvio includes a comprehensive test suite. Run tests with:
# Install test dependencies
pip install langvio[dev]
# Run all tests
pytest
# Run with coverage
pytest --cov=langvio --cov-report=html
# Run specific test file
pytest tests/test_config.py
See tests/README.md for more testing information.
๐ค Contributing
We welcome contributions! Here's how to get started:
Development Setup
# Clone the repository
git clone https://github.com/MugheesMehdi07/langvio.git
cd langvio
# Install in development mode
pip install -e .[dev]
# Run tests
pytest
# Format code
black langvio/
isort langvio/
Contributing Guidelines
- Fork the repository
- Create a feature branch (
git checkout -b feature/amazing-feature) - Commit your changes (
git commit -m 'Add amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
๐ Documentation
- ๐ Full Documentation: Comprehensive guides and API reference
- ๐ฏ Examples: Ready-to-run example scripts
- ๐ Web App: Flask web interface for easy testing
- โ๏ธ Configuration: Sample configuration files
๐ Links & Resources
- ๐ GitHub Repository
- ๐ฆ PyPI Package
- ๐ Documentation
- ๐ Issue Tracker
- ๐ฌ Discussions
๐ License
This project is licensed under the MIT License - see the LICENSE file for details.
๐ Acknowledgments
- Ultralytics for the amazing YOLO-World v2 models
- ByteTracker algorithm for robust multi-object tracking
- LangChain for LLM integration framework
- OpenAI and Google for language model APIs
- OpenCV for computer vision utilities
โญ Star us on GitHub if Langvio helps you!
โญ Star โข ๐ Share โข ๐ Report Bug
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 langvio-0.0.4.tar.gz.
File metadata
- Download URL: langvio-0.0.4.tar.gz
- Upload date:
- Size: 96.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f79f6744623bbc9e744e11d52d6c01d49f7e71696fd6ce3f326d78a7334ffd01
|
|
| MD5 |
428c34ea259880b73d21dea46e3da6c4
|
|
| BLAKE2b-256 |
26710c4494c89c4ee6e88bd800604441a65e1891b29669050d0c6ab06dd22b73
|
File details
Details for the file langvio-0.0.4-py3-none-any.whl.
File metadata
- Download URL: langvio-0.0.4-py3-none-any.whl
- Upload date:
- Size: 82.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e9ddadfb4a481eac22e0b542c5f1c09092eb982f7d1754e9841799c4951a84d0
|
|
| MD5 |
bf038cdee1322ee82c47bac2c83c3041
|
|
| BLAKE2b-256 |
f11e3ae810db5784c56542827c7ed63d46c3523bf3b59563733fe2d7a66b3dc3
|