# ============================================================
# FULL PIPELINE CONFIGURATION FOR SURVEY SIMULATION & LASSO
# ------------------------------------------------------------
# This YAML file runs both stages of the alignment:
#
# Stage 1: Generate synthetic endowments & agent responses
# Stage 2: Run Lasso regression to select relevant endowments
#
# Each module (survey, agent, generator, lasso) has its own settings.
# ============================================================

# --- FILE MANAGEMENT & METADATA ---

# >>> Alignment Metadata <<<
# Describes the experiment and ensures reproducibility.
metadata:
  name: "ATP_w36"             # Short name used in output folder naming
  description: "Generate 300 active endowments for ATP Wave 36 using GPT-4-o agents."
  version: "v1"               # Config version tracking
  seed: 101                   # Random seed for reproducibility

# >>> Input & Reference File Paths <<<
# Central locations for loading survey schema and saved results.
paths:
  survey_csv: "data/w36/info.csv"                                 # CSV with question text and answer codes
  survey_yaml: "config/surveys/american_trend_panel.yaml"         # Config schema for interpreting the survey CSV
  attribute_bank: "config/attribute_banks/attribute_bank.yaml"    # Master list of attributes used for personas
  aggregate_json: "data/w36/W36_aggregate_results.json"           # Optional: human summary or target distributions

# >>> Report Styling <<<
# Specifies custom CSS stylesheets for HTML output reports.
report:
  endowment: styles/generation_report.css   # Style for endowment generation report
  regression: styles/lasso_report.css       # Style for regression experiment report

# ============================================================
#           [STAGE 1] ACTIVE ENDOWMENT GENERATION
# ============================================================

# --- RESPONSE AGENT CONFIGURATION ---
# Settings for the LLM agent that simulates survey responses.
agent: 
  type: openai
  model_name: gpt-4o
  formality: >                 # System prompt detailing formality requirements for the response
    You are completing a survey. Your answer should reflect the person described in the profile above, using their preferences, beliefs and experiences.
    Respond with only the final answer string, not the code or label in brackets.
    Do not include any reasoning, explanation, or commentary.
    Do not preface your answer with phrases like 'I would choose'.
    Just return the answer text exactly as it appears in the options.
  kwargs:
    temperature: 0             # Deterministic responses
    max_tokens: 128            # Upper limit for response length

# --- ENDOWMENT MODEL SETTINGS ---
# Controls how synthetic persona endowments are generated.
endowment_model:
  model: gpt-4o-mini           # LLM model for endowment generation 
  temperature: 0.9             # Higher temperature to encourage diversity
  batch_size: 5                # Number of persona endowments generated per call
  delay: 0.5                   # Optional delay (in seconds) between API calls
  retry_failed: true           # Retry if API request fails
  max_attributes: 10           # Cap on number of attributes per endowment
  randomize_attributes: true   # Randomly select attribute from the target mode capped at max_attributes

# --- ATTRIBUTE LEARNER SETTINGS ---
# Optional post-hoc tool to infer attributes from survey and questions
attribute_learner:
  model: gpt-4o
  max_tokens: 1024

# --- GENERATION STRATEGY ---
# Overall experiment parameters and sampling policies.
generation:
  target_n: 300                 # Total number of synthetic endowments
  initial_n: 10                 # Initial endowments sampled per preset mode before adaptation begins
  num_update_steps: 10          # Number of adaptive/expansion iterations
  parallel: true                # Whether to use multithreading (recommended for faster generation)
  max_workers: 30               # Number of parallel threads
  question_patch:
    fraction: 0.75              # Proportion of endowments assigned to low-entropy questions
    top_k: 3                    # Number of lowest-entropy questions tracked per round
    min_repeats: 2              # Reallocate patching to a mixed mode if a question appears in top_k this many times
  verbose: true                 # Print detailed logs during generation

# ============================================================
#           [STAGE 2] LASSO REGRESSION APPROXIMATION
# ============================================================

# --- 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: "2D"                                          # 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"              # Which model's weights to assign to endowments

# ============================================================
# 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`.
# ============================================================