"""
Data Loaders Package

This package contains data loaders for experiments:

Synthetic Families:
- S1: High-Variance Exploration (i.i.d. with variance-driven learning)
- S2: Deceptive Arms (efficiency traps)
- S3: Selective Admission (variable quality arrivals)
- S4: Complementarity (orthogonal resource usage, proves V^mix > V*)
- S5: Simple 5-Arm Gaussian (for alpha >= 1 regret validation)

Real-World Data:
- Alibaba: Alibaba Cluster Trace 2018 (calibrated synthetic)
"""

from .base_loader import BaseDataLoader
from .s1_complementarity import S1ComplementarityLoader
from .s2_noisy import S2NoisyLoader
from .s3_dominant import S3DominantLoader
from .s4_complementarity import S4ComplementarityLoader
from .s5_gaussian import S5GaussianLoader
from .alibaba import AlibabaDataLoader


__all__ = [
    'BaseDataLoader',
    'S1ComplementarityLoader',
    'S2NoisyLoader',
    'S3DominantLoader',
    'S4ComplementarityLoader',
    'S5GaussianLoader',
    'AlibabaDataLoader',
    'get_loader',
]


def get_loader(family: str, **kwargs):
    """
    Factory function to create data loader by family name.

    Parameters
    ----------
    family : str
        Data family: 'S1', 'S2', 'S3', 'S4', 'S5', 'Alibaba'
    **kwargs
        Loader-specific arguments

    Returns
    -------
    BaseDataLoader
        Instantiated data loader

    Examples
    --------
    >>> loader = get_loader('S1', K=4, T=10000)
    >>> loader = get_loader('S4', K=2, T=10000)  # Complementarity
    >>> loader = get_loader('Alibaba', T=10000, scenario='quant_8bit')
    """
    loaders = {
        'S1': S1ComplementarityLoader,
        'S2': S2NoisyLoader,
        'S3': S3DominantLoader,
        'S4': S4ComplementarityLoader,
        'S5': S5GaussianLoader,
        'Alibaba': AlibabaDataLoader,
    }

    if family not in loaders:
        raise ValueError(
            f"Unknown family: {family}. "
            f"Available: {list(loaders.keys())}"
        )

    return loaders[family](**kwargs)
