# DRAMNet Default Configuration
# ==============================================
experiment_name: "dramnet_default"
seed: 42
debug: false

# Model Configuration
# -------------------
model:
  width: 64
  img_channel: 3
  out_channels: 3
  num_dram_blocks: 4
  depth_encoder: "vitl"  # Options: vits, vitb, vitl
  enc_blk_nums: [1, 1, 1, 4]
  enable_early_exit: true
  blur_threshold: 0.3
  confidence_threshold: 0.8
  weight_init: "kaiming"  # Options: xavier, kaiming, default

# Training Configuration
# ----------------------
training:
  trainer_type: "standard"  # Options: standard, progressive, multi_gpu
  epochs: 300
  batch_size: 8
  num_workers: 4
  pin_memory: true
  
  # Optimization
  optimizer: "adamw"  # Options: adam, adamw, sgd
  learning_rate: 1e-4
  weight_decay: 1e-2
  momentum: 0.9  # For SGD
  
  # Scheduling
  scheduler: "cosine"  # Options: cosine, step, exponential, plateau
  warmup_epochs: 10
  min_lr: 1e-6
  step_size: 50  # For step scheduler
  gamma: 0.5     # For step/exponential scheduler
  
  # Loss weights
  reconstruction_weight: 1.0
  perceptual_weight: 0.1
  early_exit_weight: 0.05
  blur_map_weight: 0.1
  
  # Mixed precision training
  use_amp: true
  gradient_clip_norm: 1.0
  
  # Adaptive training
  early_exit_warmup_epochs: 50
  progressive_blur_epochs: 100
  
  # Logging and validation
  log_interval: 100
  val_interval: 5
  save_interval: 10
  save_top_k: 3

# Data Configuration
# -----------------
data:
  # Dataset paths
  train_data_path: "./data/train"
  val_data_path: "./data/val"
  test_data_path: "./data/test"
  
  # Data loading
  batch_size: 8
  num_workers: 4
  pin_memory: true
  
  # Image preprocessing
  image_size: [256, 256]
  crop_size: [256, 256]
  normalize: true
  mean: [0.485, 0.456, 0.406]
  std: [0.229, 0.224, 0.225]
  
  # Data augmentation
  augmentation:
    enable: true
    horizontal_flip: 0.5
    vertical_flip: 0.1
    rotation: 15
    color_jitter:
      brightness: 0.1
      contrast: 0.1
      saturation: 0.1
      hue: 0.05
    gaussian_blur:
      enable: true
      prob: 0.3
      kernel_size: [3, 7]
      sigma: [0.1, 2.0]
    motion_blur:
      enable: true
      prob: 0.3
      kernel_size: [3, 15]
      angle: [-45, 45]
  
  # Dataset split ratios
  train_ratio: 0.8
  val_ratio: 0.1
  test_ratio: 0.1

# Monitoring and Logging
# ----------------------
wandb:
  use_wandb: false
  project: "dramnet"
  entity: null
  tags: ["dramnet", "deblurring", "early_exit"]
  notes: "DRAMNet training with default configuration"

tensorboard:
  enable: true
  log_dir: "./logs/tensorboard"

# Hardware Configuration
# ----------------------
device: "auto"  # Options: auto, cpu, cuda, cuda:0, etc.
multi_gpu: false
distributed: false

# Evaluation Configuration
# ------------------------
evaluation:
  metrics: ["psnr", "ssim", "lpips", "fid"]
  save_outputs: true
  save_visualizations: true
  
  # Efficiency metrics
  measure_flops: true
  measure_latency: true
  measure_memory: true
  
  # Early exit analysis
  analyze_exit_patterns: true
  exit_threshold_sweep: [0.1, 0.3, 0.5, 0.7, 0.9]

# Experimental Features
# --------------------
experimental:
  gradient_checkpointing: false
  compile_model: false  # PyTorch 2.0 compile
  channels_last: false
  benchmark_mode: true 