Skip to main content

Common server utilities for Matrice.ai services

Project description

Post-Processing Module - Refactored Architecture

Overview

This module provides a comprehensive, refactored post-processing system for the Matrice Python SDK. The system has been completely redesigned to be more pythonic, maintainable, and extensible while providing powerful analytics capabilities for various use cases.

๐Ÿš€ Key Features

โœ… Unified Architecture

  • Single Entry Point: PostProcessor class handles all processing needs
  • Standardized Results: All operations return ProcessingResult objects
  • Consistent Configuration: Type-safe configuration system with validation
  • Registry Pattern: Easy registration and discovery of use cases

โœ… Separate Use Case Classes

  • People Counting: Advanced people counting with zone analysis and tracking
  • Customer Service: Comprehensive customer service analytics with business intelligence
  • Extensible Design: Easy to add new use cases

โœ… Pythonic Configuration Management

  • Dataclass-based: Type-safe configurations using dataclasses
  • Nested Configurations: Support for complex nested config structures
  • File Support: JSON/YAML configuration file loading and saving
  • Validation: Built-in validation with detailed error messages

โœ… Comprehensive Error Handling

  • Standardized Errors: All errors return structured ProcessingResult objects
  • Detailed Information: Error messages include type, context, and debugging info
  • Graceful Degradation: System continues operating even with partial failures

โœ… Processing Statistics

  • Performance Tracking: Automatic processing time measurement
  • Success Metrics: Success/failure rates and statistics
  • Insights Generation: Automatic generation of actionable insights

๐Ÿ“ Architecture

post_processing/
โ”œโ”€โ”€ __init__.py              # Main exports and convenience functions
โ”œโ”€โ”€ processor.py             # Main PostProcessor class
โ”œโ”€โ”€ README.md               # This documentation
โ”‚
โ”œโ”€โ”€ core/                   # Core system components
โ”‚   โ”œโ”€โ”€ __init__.py
โ”‚   โ”œโ”€โ”€ base.py            # Base classes, enums, and protocols
โ”‚   โ”œโ”€โ”€ config.py          # Configuration system
โ”‚   โ””โ”€โ”€ advanced_usecases.py # Advanced use case implementations
โ”‚
โ”œโ”€โ”€ usecases/              # Separate use case implementations
โ”‚   โ”œโ”€โ”€ __init__.py
โ”‚   โ”œโ”€โ”€ people_counting.py # People counting use case
โ”‚   โ””โ”€โ”€ customer_service.py # Customer service use case
โ”‚
โ””โ”€โ”€ utils/                 # Utility functions organized by category
    โ”œโ”€โ”€ __init__.py
    โ”œโ”€โ”€ geometry_utils.py  # Geometric calculations
    โ”œโ”€โ”€ format_utils.py    # Format detection and conversion
    โ”œโ”€โ”€ filter_utils.py    # Filtering and cleaning operations
    โ”œโ”€โ”€ counting_utils.py  # Counting and aggregation
    โ””โ”€โ”€ tracking_utils.py  # Tracking and movement analysis

๐Ÿ›  Quick Start

Basic Usage

from matrice_analytics.post_processing import PostProcessor, process_simple

# Method 1: Simple processing (recommended for quick tasks)
result = process_simple(
    raw_results,
    usecase="people_counting",
    confidence_threshold=0.5
)

# Method 2: Using PostProcessor class (recommended for complex workflows)
processor = PostProcessor()
result = processor.process_simple(
    raw_results,
    usecase="people_counting", 
    confidence_threshold=0.5,
    enable_tracking=True
)

print(f"Status: {result.status.value}")
print(f"Summary: {result.summary}")
print(f"Insights: {len(result.insights)} generated")

Advanced Configuration

# Create complex configuration
config = processor.create_config(
    'people_counting',
    confidence_threshold=0.6,
    enable_tracking=True,
    person_categories=['person', 'people', 'human'],
    zone_config={
        'zones': {
            'entrance': [[0, 0], [100, 0], [100, 100], [0, 100]],
            'checkout': [[200, 200], [300, 200], [300, 300], [200, 300]]
        }
    },
    alert_config={
        'count_thresholds': {'all': 10},
        'occupancy_thresholds': {'entrance': 5}
    }
)

# Process with configuration
result = processor.process(raw_results, config)

Configuration File Support

# Save configuration to file
processor.save_config(config, "people_counting_config.json")

# Load and use configuration from file
result = processor.process_from_file(raw_results, "people_counting_config.json")

๐Ÿ“Š Use Cases

1. People Counting (people_counting)

Advanced people counting with comprehensive analytics:

result = process_simple(
    raw_results,
    usecase="people_counting",
    confidence_threshold=0.5,
    enable_tracking=True,
    person_categories=['person', 'people'],
    zone_config={
        'zones': {
            'entrance': [[0, 0], [100, 0], [100, 100], [0, 100]]
        }
    }
)

Features:

  • Multi-category person detection
  • Zone-based counting and analysis
  • Unique person tracking
  • Occupancy analysis
  • Alert generation based on thresholds
  • Temporal analysis and trends

2. Customer Service (customer_service)

Comprehensive customer service analytics:

result = process_simple(
    raw_results,
    usecase="customer_service",
    confidence_threshold=0.6,
    service_proximity_threshold=50.0,
    staff_categories=['staff', 'employee'],
    customer_categories=['customer', 'person']
)

Features:

  • Staff utilization analysis
  • Customer-staff interaction detection
  • Service quality metrics
  • Area occupancy analysis
  • Queue management insights
  • Business intelligence metrics

๐Ÿ”ง Configuration System

Configuration Classes

All configurations are type-safe dataclasses with built-in validation:

from matrice_analytics.post_processing import PeopleCountingConfig, ZoneConfig

# Create configuration programmatically
config = PeopleCountingConfig(
    confidence_threshold=0.5,
    enable_tracking=True,
    zone_config=ZoneConfig(
        zones={
            'entrance': [[0, 0], [100, 0], [100, 100], [0, 100]]
        }
    )
)

# Validate configuration
errors = config.validate()
if errors:
    print(f"Configuration errors: {errors}")

Configuration Templates

# Get configuration template for a use case
template = processor.get_config_template('people_counting')
print(f"Available options: {list(template.keys())}")

# List all available use cases
use_cases = processor.list_available_usecases()
print(f"Available use cases: {use_cases}")

๐Ÿ“ˆ Processing Results

All processing operations return a standardized ProcessingResult object:

class ProcessingResult:
    data: Any                           # Processed data
    status: ProcessingStatus           # SUCCESS, ERROR, WARNING, PARTIAL
    usecase: str                       # Use case name
    category: str                      # Use case category
    processing_time: float             # Processing time in seconds
    summary: str                       # Human-readable summary
    insights: List[str]                # Generated insights
    warnings: List[str]                # Warning messages
    error_message: Optional[str]       # Error message if failed
    predictions: List[Dict[str, Any]]  # Detailed predictions
    metrics: Dict[str, Any]            # Performance metrics

Working with Results

result = processor.process_simple(data, "people_counting")

# Check status
if result.is_success():
    print(f"โœ… {result.summary}")
    
    # Access insights
    for insight in result.insights:
        print(f"๐Ÿ’ก {insight}")
    
    # Access metrics
    print(f"๐Ÿ“Š Metrics: {result.metrics}")
    
    # Access processed data
    processed_data = result.data
else:
    print(f"โŒ Processing failed: {result.error_message}")

๐Ÿ“Š Statistics and Monitoring

# Get processing statistics
stats = processor.get_statistics()
print(f"Total processed: {stats['total_processed']}")
print(f"Success rate: {stats['success_rate']:.2%}")
print(f"Average processing time: {stats['average_processing_time']:.3f}s")

# Reset statistics
processor.reset_statistics()

๐Ÿ”Œ Extensibility

Adding New Use Cases

  1. Create Use Case Class:
from matrice_analytics.post_processing.core.base import BaseProcessor

class MyCustomUseCase(BaseProcessor):
    def __init__(self):
        super().__init__("my_custom_usecase")
        self.category = "custom"
    
    def process(self, data, config, context=None):
        # Implement your processing logic
        return self.create_result(processed_data, "my_custom_usecase", "custom")
  1. Register Use Case:
from matrice_analytics.post_processing.core.base import registry

registry.register_use_case("custom", "my_custom_usecase", MyCustomUseCase)

Adding New Utility Functions

Add utility functions to the appropriate module in the utils/ directory and export them in utils/__init__.py.

๐Ÿงช Testing

The system includes comprehensive error handling and validation. Here's how to test your implementations:

# Test configuration validation
errors = processor.validate_config({
    'usecase': 'people_counting',
    'confidence_threshold': 0.5
})

# Test with sample data
sample_data = [
    {'category': 'person', 'confidence': 0.8, 'bbox': [10, 10, 50, 50]}
]

result = process_simple(sample_data, 'people_counting')
assert result.is_success()

๐Ÿ”„ Migration from Old System

If you're migrating from the old post-processing system:

  1. Update Imports:

    # Old
    from matrice_analytics.old_post_processing import some_function
    
    # New
    from matrice_analytics.post_processing import PostProcessor, process_simple
    
  2. Update Processing Calls:

    # Old
    result = old_process_function(data, config_dict)
    
    # New
    result = process_simple(data, "usecase_name", **config_dict)
    
  3. Update Configuration:

    # Old
    config = {"threshold": 0.5, "enable_tracking": True}
    
    # New
    config = processor.create_config("people_counting", 
                                    confidence_threshold=0.5, 
                                    enable_tracking=True)
    

๐Ÿ› Troubleshooting

Common Issues

  1. Use Case Not Found:

    # Check available use cases
    print(processor.list_available_usecases())
    
  2. Configuration Validation Errors:

    # Validate configuration
    errors = processor.validate_config(config)
    if errors:
        print(f"Validation errors: {errors}")
    
  3. Processing Failures:

    # Check result status and error details
    if not result.is_success():
        print(f"Error: {result.error_message}")
        print(f"Error type: {result.error_type}")
        print(f"Error details: {result.error_details}")
    

๐Ÿ“ API Reference

Main Classes

  • PostProcessor: Main processing class
  • ProcessingResult: Standardized result container
  • BaseConfig: Base configuration class
  • PeopleCountingConfig: People counting configuration
  • CustomerServiceConfig: Customer service configuration

Convenience Functions

  • process_simple(): Simple processing function
  • create_config_template(): Get configuration template
  • list_available_usecases(): List available use cases
  • validate_config(): Validate configuration

Utility Functions

The system provides comprehensive utility functions organized by category:

  • Geometry: Point-in-polygon, distance calculations, IoU
  • Format: Format detection and conversion
  • Filter: Confidence filtering, deduplication
  • Counting: Object counting, zone analysis
  • Tracking: Movement analysis, line crossing detection

๐ŸŽฏ Best Practices

  1. Use Simple Processing for Quick Tasks:

    result = process_simple(data, "people_counting", confidence_threshold=0.5)
    
  2. Use PostProcessor Class for Complex Workflows:

    processor = PostProcessor()
    config = processor.create_config("people_counting", **params)
    result = processor.process(data, config)
    
  3. Always Check Result Status:

    if result.is_success():
        # Process successful result
    else:
        # Handle error
    
  4. Use Configuration Files for Complex Setups:

    processor.save_config(config, "config.json")
    result = processor.process_from_file(data, "config.json")
    
  5. Monitor Processing Statistics:

    stats = processor.get_statistics()
    # Monitor success rates and performance
    

๐Ÿ”ฎ Future Enhancements

The refactored system is designed for easy extension. Planned enhancements include:

  • Additional use cases (security monitoring, retail analytics)
  • Advanced tracking algorithms
  • Real-time processing capabilities
  • Integration with external analytics platforms
  • Machine learning-based insights generation

The refactored post-processing system provides a solid foundation for scalable, maintainable, and powerful analytics capabilities. The clean architecture makes it easy to extend and customize for specific use cases while maintaining consistency and reliability.

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

matrice_analytics-0.1.113.tar.gz (2.2 MB view details)

Uploaded Source

Built Distribution

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

matrice_analytics-0.1.113-py3-none-any.whl (2.4 MB view details)

Uploaded Python 3

File details

Details for the file matrice_analytics-0.1.113.tar.gz.

File metadata

  • Download URL: matrice_analytics-0.1.113.tar.gz
  • Upload date:
  • Size: 2.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.12

File hashes

Hashes for matrice_analytics-0.1.113.tar.gz
Algorithm Hash digest
SHA256 62b77f88bd43277e6e9da4f9f1c7f94d511b06e7a36d5e2af6f7e20c8b8a1103
MD5 405817e9621bf67f80c08227418d018e
BLAKE2b-256 15535085ec679f6ce1f53c836b3ec2a97cbaf965df73a4d1ecde38fa652f6601

See more details on using hashes here.

File details

Details for the file matrice_analytics-0.1.113-py3-none-any.whl.

File metadata

File hashes

Hashes for matrice_analytics-0.1.113-py3-none-any.whl
Algorithm Hash digest
SHA256 f980c357f082ad003cc8ae057526418b4a7752f5f4d1ab4e39a86e5b08eba569
MD5 5cef6803c05fe028b0b9b77fa8d6767c
BLAKE2b-256 7eeb0b669654cfadc813cb215118d7e0cccc5039afd2cfb5a8b178862a6561d3

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