# ManifoldKV Evaluation Registry
# ICML 2026 - Reproduction Package

from benchmarks.ruler.calculate_metrics import calculate_metrics as ruler_scorer

from kvpress import (
    AdaKVPress,
    KeyDiffPress,
    SnapKVPress,
    ManifoldKVPress,
    ManifoldKVSnapKVScorerPress,
    ManifoldKVL1Press,
    ManifoldKVLinfPress,
    WindowedManifoldKVPress,
    HybridManifoldKVPress,
    NormalizedManifoldKVPress,
)

# Dataset registry
DATASET_REGISTRY = {
    "ruler": "simonjegou/ruler",
}

# Scorer registry
SCORER_REGISTRY = {
    "ruler": ruler_scorer,
}

# Press registry - ManifoldKV and baselines
PRESS_REGISTRY = {
    # ============================================
    # ManifoldKV (Our Contribution)
    # ============================================
    
    # Standard ManifoldKV (L2 distance from centroid)
    "manifold_kv": ManifoldKVPress(),
    
    # AdaKV + ManifoldKV (SOTA: 95.73%)
    "adakv_manifold_kv": AdaKVPress(ManifoldKVSnapKVScorerPress()),
    
    # Distance metric ablations
    "manifold_kv_l1": ManifoldKVL1Press(),
    "manifold_kv_linf": ManifoldKVLinfPress(),
    "adakv_manifold_kv_l1": AdaKVPress(ManifoldKVSnapKVScorerPress(distance_metric='l1')),
    "adakv_manifold_kv_linf": AdaKVPress(ManifoldKVSnapKVScorerPress(distance_metric='linf')),
    
    # Windowed variants for 64K+ contexts
    "windowed_manifold_4k": WindowedManifoldKVPress(window_size=4096),
    "windowed_manifold_8k": WindowedManifoldKVPress(window_size=8192),
    "windowed_manifold_16k": WindowedManifoldKVPress(window_size=16384),
    
    # Hybrid variants
    "hybrid_manifold_03": HybridManifoldKVPress(global_weight=0.3),
    "hybrid_manifold_05": HybridManifoldKVPress(global_weight=0.5),
    
    # Normalized variant
    "normalized_manifold": NormalizedManifoldKVPress(),
    
    # ============================================
    # Baselines
    # ============================================
    
    # KeyDiff (cosine similarity baseline)
    "keydiff": KeyDiffPress(),
    "adakv_keydiff": AdaKVPress(KeyDiffPress()),
    
    # SnapKV (attention-based baseline)
    "snapkv": SnapKVPress(),
    "adakv_snapkv": AdaKVPress(SnapKVPress()),
    
    # No compression (upper bound)
    "no_press": None,
}
