# core/samplers/__init__.py
"""
Samplers.
Provides various video frame sampling algorithms.
"""

import sys
import os
from pathlib import Path

from .base import (
    BaseSampler, 
    VideoBasedSampler, 
    QueryBasedSampler, 
    FrameBasedSampler,
    SimpleFrameSampler
)
from .uniform import UniformSampler
from .topk import CLIPTopKSampler
from .aks import AKSSampler
from .scope import ScopeSampler

# Sampler registry
SAMPLER_REGISTRY = {
    "uniform": UniformSampler,
    "topk": CLIPTopKSampler,
    "aks": AKSSampler,
    "scope": ScopeSampler,
}


def get_sampler(sampler_type: str, **kwargs):
    """
    Get a sampler instance.

    Args:
        sampler_type: 'uniform', 'topk', 'aks', or 'scope'
        **kwargs: Sampler init kwargs.

    Returns:
        Sampler instance.
    """
    if sampler_type not in SAMPLER_REGISTRY:
        raise ValueError(f"Unknown sampler type: {sampler_type}. "
                        f"Available: {list(SAMPLER_REGISTRY.keys())}")
    
    sampler_class = SAMPLER_REGISTRY[sampler_type]
    return sampler_class(**kwargs)


def list_samplers():
    """List all available samplers."""
    return list(SAMPLER_REGISTRY.keys())


__all__ = [
    'BaseSampler', 'VideoBasedSampler', 'QueryBasedSampler', 'FrameBasedSampler', 'SimpleFrameSampler',
    'UniformSampler', 'CLIPTopKSampler', 'AKSSampler', 'ScopeSampler',
    'SAMPLER_REGISTRY', 'get_sampler', 'list_samplers'
]
