# ============================================================
#       REGRESSION EXPERIMENT CONFIGURATION
# ------------------------------------------------------------
# Configure one or more sparse regression methods (Lasso, ElasticNet)
# with optional post-selection refit using OLS.
# ============================================================

# --- EXPERIMENT METADATA ---
experiment:
  name: "ATP_w42_empirical_regression"                  # Name of experiment (used in output folder)
  description: "Empirical analysis on W42 using proxy agents and regression-based selection. Selection methods include Lasso and ElasticNet."
  seed: 101                                             # Seed for reproducibility

# --- INPUT FILES ---
paths:
  survey_csv: "data/w42/info.csv"                        # Survey structure
  survey_yaml: "config/surveys/american_trend_panel.yaml"   # Survey config schema
  responses_csv: "outputs/ATP_w42_20250719_201256/responses.csv"     # Agent responses (binary codes)
  endowments_csv: "outputs/ATP_w42_20250719_201256/endowments.csv" # Agent endowments
  aggregate_json: "data/w42/W42_aggregate_results.json"     # Empirical targets (population response distribution)

# --- REGRESSION METHODS ---

lasso:
  alpha_expr: "np.logspace(-5, 1, 20)"                      # Lasso tuning grid
  max_iter: 10000
  validation:                                               # Cross-Validation Strategy
    strategy: "cv"                                            # "holdout" or "cv" (cross-validation)
    cv_folds: 5                                               # Used only if strategy == "cv"
  post_selection_refit: true                                # Refit OLS after selection (default: true)

elasticnet:
  alpha_expr: "np.logspace(-5, 1, 20)"                      # ElasticNet alpha grid
  l1_ratio_expr: "np.linspace(0.1, 1, 10)"                     # ElasticNet l1_ratio grid
  max_iter: 10000
  validation:                                               # Cross-Validation Strategy
    strategy: "cv"                                            # Only "cv" is supported
    cv_folds: 5                                               # Used only if strategy == "cv"
  plot_style: "3D"                                          # Plot style for the diagnostics: "2D" (default) or "3D"
  post_selection_refit: true


# --- SPLIT SETTINGS ---
split_settings:
  use_proxy_only: true                                      # Use only proxy agents
  train_val_split: ["train", "valid"]                       # Training and validation splits
  test_split: "test"                                        # Test split

# --- MODEL WEIGHT USAGE ---
weight_assignment_model: "elasticnet_post_ols"              # Which model's weights to assign to endowments

# --- REPORT STYLING ---
report:
  css: styles/lasso_report.css                              # Optional stylesheet for summary HTML

# ============================================================
# NOTES:
# - You can specify either "lasso", "elasticnet", or both.
# - Post-selection refit via OLS is optional and enabled by default.
# - Weights for endowments will be assigned using `weight_assignment_model`.
# ============================================================