# ============================================================
# REGRESSION EXPERIMENT CONFIGURATION
# ------------------------------------------------------------

experiment:
  name: "ground_truth_recovery"
  description: "Testing the capability of constrained lasso and elastic net for recovering ground truth agents."
  seed: 101
  role_assignment:
    method: "manual"
    proxy_ratio: 0.7

# --- INPUT FILES ---
paths:
  survey_csv: "data/w42/info.csv"
  survey_yaml: "config/surveys/american_trend_panel.yaml"
  responses_csv: "outputs/ATP_w42_20250726_181405/responses.csv"
  endowments_csv: "outputs/ATP_w42_20250726_181405/endowments.csv"
  attribute_bank: "outputs/ATP_w42_20250726_181405/attribute_bank.yaml"

# --- REGRESSION METHODS ---
lasso:
  alpha_expr: "np.logspace(-5, 5, 30)"
  max_iter: 10000
  validation:
    strategy: "cv"
    cv_folds: 5
  post_selection_refit: false

elasticnet:
  alpha_expr: "np.logspace(-5, 5, 30)"
  l1_ratio_expr: "np.linspace(0.1, 1, 10)"
  max_iter: 10000
  validation:
    strategy: "cv"
    cv_folds: 5
  plot_style: "2D"
  post_selection_refit: false

# --- SPLIT SETTINGS ---
split_settings:
  use_proxy_only: false
  train_val_split: ["train", "valid"]
  test_split: "test"

# --- FRACTION SWEEP RUNNER CONFIGURATION ---
runner:
  modes: ["endowment", "response"]        # Sweep over different input types
  models: ["elasticnet"]                       # Regression methods to test
  fractions: "np.linspace(0.5, 1.0, 20)"  # Fractional grid (evaluated as numpy expression)
  n_repeats: 10                           # Number of repetitions per (mode, model, fraction)
  seed: 101                               # Base random seed (incremented across rounds)
  plot: false
  verbose: false
  output_dir: "outputs/round_sweep"  # Optional. If omitted, generated dynamically.