# config/settings.py
"""
Global configuration and defaults.
"""

import os

# =============================================================================
# Model config
# =============================================================================

# CLIP config
CLIP_CONFIG = {
    # Override via env var or CLI flags when needed
    "default_model_path": os.getenv("SCPOE_VISION_MODEL_PATH", "./models/clip-vit-base-patch32"),
    "default_device": "auto",
    "max_video_cache": 20,
    "max_text_cache": 500,
    "max_frame_cache": 1000,
}

# VLM config
QWEN_CONFIG = {
    "default_model": os.getenv("SCPOE_VLM_MODEL_PATH", "./models/Qwen2.5-VL-32B-Instruct"),
    "device_map": "auto",
    "attention_implementation": "flash_attention_2",
    "torch_dtype": "bfloat16",
}

# =============================================================================
# Sampling config
# =============================================================================

# Common sampling config
SAMPLING_CONFIG = {
    "default_num_frames": 8,
    "default_fps": 1.0,
    "anchor_strategy": "top1",  # 'top1', 'earliest', 'latest', 'median_topk'
}

# AKS config
AKS_CONFIG = {
    "t1": 0.5,
    "t2": -100,
    "max_depth": 3,
    "batch_size": 64,
}

# Division config
DIVISION_CONFIG = {
    "lambda_div": 0.7,
    "topL_factor": 3,
    "min_around_window": 20,  # minimum seconds for AROUND
}

# Scope config
SCOPE_CONFIG = {
    # Frame allocation
    "frame_allocation": {
        "use_importance_weighting": True,
        "default_importance": 5,
        "min_frames_per_query": 1,
    },
    
    # Multiprocessing (reserved)
    # "multiprocessing": {
    #     "use_single_process": True,
    #     "max_concurrent_models": 1,
    # }
}

# TopK config
TOPK_CONFIG = {
    "default_k": 64,
}

# =============================================================================
# Agent config
# =============================================================================

# Generation params
GENERATION_CONFIG = {
    "max_new_tokens": 128 * 64,
    "temperature": 0,
    "do_sample": False,
    "num_beams": 1,
}

# Query decomposition config (Scope)
QUERY_DECOMPOSITION_CONFIG = {
    "division_model_path": os.getenv("SCPOE_PLANNER_MODEL_PATH", "./models/Qwen3-8B"),
    "division_device_map": os.getenv("SCPOE_PLANNER_DEVICE", "cuda:0"),
    "max_retries": 3,
    "backoff": 1.0,
    "use_api": False,
}

# API config
API_CONFIG = {
    # Placeholder only; provide explicitly via env vars / CLI args
    "api_url": None,
    "model_name": None,
    "api_key": None,  # or via env API_KEY
    "max_retries": 3,
    "timeout": 60,
}

# =============================================================================
# Dataset config
# =============================================================================

DATASET_CONFIG = {
    "longvideobench": {
        "label_file": "lvb_val.json",
        "video_dir": "videos",
    },
        "videomme": {
        # The conversion script generates this file under the dataset root
        "label_file": "videomme_test.json",
        "video_dir": "videos",
    },
}

# =============================================================================
# Paths
# =============================================================================

DEFAULT_PATHS = {
    "dataset_path": "../datas/videos/longvideobench",
    "output_path": "./outputs",
    "clip_path": "./models/clip-vit-base-patch32",
}

# =============================================================================
# Experiment config
# =============================================================================

EXPERIMENT_CONFIG = {
    "supported_samplers": ["uniform", "aks", "topk", "scope"],
    "supported_agents": ["direct"],
    "default_num_workers": 8,
}
