{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "import re\n",
    "import sys\n",
    "import tqdm\n",
    "import json\n",
    "import copy\n",
    "import pickle\n",
    "import numpy as np\n",
    "import cvxpy as cp\n",
    "import scipy as sp\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "from itertools import combinations\n",
    "from sklearn.model_selection import train_test_split"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Add project src directory to path\n",
    "sys.path.append('../src')\n",
    "\n",
    "# Custom utilities for data processing and aggregation\n",
    "from data_tools import (\n",
    "    load_feedbackqa, load_helpsteer2, load_helpsteer3, collect_judge_outputs, is_valid_score, standardize,\n",
    "    load_ultrafeedback, load_tulu3_8b, load_hhrlhf, load_injected_bias\n",
    ")\n",
    "\n",
    "from program_judges import length_judge, special_token_judge\n",
    "from pgm_tools import learn_structure, get_weights, majority_vote, ws_aggregate, uws_aggregate\n",
    "from eval_tools import compute_mae, compute_corr"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "def normalize_text(s: str) -> str:\n",
    "    if pd.isna(s):\n",
    "        return s\n",
    "    # Convert Windows newlines (\\r\\n) to Unix newlines (\\n)\n",
    "    s = s.replace(\"\\r\\n\", \"\\n\")\n",
    "    # Normalize whitespace (replace multiple spaces/newlines with single)\n",
    "    s = re.sub(r\"\\s+\", \" \", s)\n",
    "    # Normalize dashes (– → -)\n",
    "    s = s.replace(\"–\", \"-\")\n",
    "    # Strip leading/trailing spaces\n",
    "    return s.strip()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "# ratings[\"question_clean\"] = ratings[\"question\"].apply(normalize_text)\n",
    "# ratings[\"answer_clean\"] = ratings[\"answer\"].apply(normalize_text)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "# program_judges[\"question_clean\"] = program_judges[\"question\"].apply(normalize_text)\n",
    "# program_judges[\"answer_clean\"] = program_judges[\"answer\"].apply(normalize_text)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "# merged_df = pd.merge(ratings, program_judges, left_on=[\"question_clean\", \"answer_clean\"], right_on=[\"question_clean\", \"answer_clean\"], how=\"inner\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "## feedbackqa: drop [3186]\n",
    "## ultrafeedback: drop [1098, 1164]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Llama-3.1-8B-Instruct 1.0 Added to parsed_outputs\n",
      "Llama-3.2-1B 1.0 Added to parsed_outputs\n",
      "Llama-3.2-3B 1.0 Added to parsed_outputs\n",
      "Mistral-7B-Instruct-v0.3 1.0 Added to parsed_outputs\n",
      "Phi-4-mini-instruct 1.0 Added to parsed_outputs\n",
      "Qwen3-1.7B 1.0 Added to parsed_outputs\n",
      "Qwen3-4B 1.0 Added to parsed_outputs\n",
      "Qwen3-8B 1.0 Added to parsed_outputs\n",
      "gemma-3-1b-it 1.0 Added to parsed_outputs\n",
      "gemma-3-4b-it 1.0 Added to parsed_outputs\n",
      "5659 5659 5659\n",
      "Min rating: 1.0, Max rating: 4.0\n",
      "weights 39 [ 1.62261108e+00 -1.83854503e-01  1.61470750e-01  1.54737642e+00\n",
      "  1.61277638e+00 -4.15594766e-01 -8.64546697e-01  1.13728783e+00\n",
      " -8.49382130e-01  7.83235278e-01  1.38171615e-01 -3.04442257e-01\n",
      "  1.68629928e-01  8.34508490e-01  5.23894826e-01  2.26695119e-01\n",
      " -4.12123188e-01 -4.15107068e+00  1.46815641e+00  8.33711164e-01\n",
      " -4.85925296e+00 -2.07230153e-01 -8.22823896e-01  8.49974269e-01\n",
      " -1.49083960e+00 -1.06092374e+00 -6.63827786e-01  8.80999441e-05\n",
      "  7.62329254e-02 -3.15751085e-01  8.79785664e-01 -3.80472372e+00\n",
      " -1.06068213e+00  1.33257039e+00  8.23741927e-02 -1.27128061e+00\n",
      " -1.31233211e+00 -1.02504739e+00 -1.90083032e+00]\n",
      "mv {'dataset': 'feedbackqa', 'pred': 'mv', 'mae': 0.9718034617532105, 'kendall_tau': 0.38667617101048335}\n",
      "avg {'dataset': 'feedbackqa', 'pred': 'avg', 'mae': 0.8770382568079543, 'kendall_tau': 0.4338268893864319}\n",
      "uws {'dataset': 'feedbackqa', 'pred': 'uws', 'mae': 0.929178730866, 'kendall_tau': 0.42701274936419553}\n",
      "caresl {'dataset': 'feedbackqa', 'pred': 'caresl', 'mae': 1.255767790666634, 'kendall_tau': -0.3419576586748261}\n"
     ]
    }
   ],
   "source": [
    "# -----------------------------------------------------------------------------\n",
    "threshold = 1\n",
    "gamma = 1\n",
    "\n",
    "results = []\n",
    "for dataset_name in [\"feedbackqa\"]:\n",
    "\n",
    "    # 1. Load dataset and judge outputs\n",
    "    if dataset_name == \"feedbackqa\":\n",
    "        judge_output_dir = \"../judge_outputs/feedbackqa\"\n",
    "        data_path = \"../data/feedbackqa/feedback_train.json\"\n",
    "        ratings = load_feedbackqa(data_path)\n",
    "        ratings = ratings.drop(index=[3186]).reset_index(drop=True)\n",
    "        df = collect_judge_outputs(judge_output_dir)\n",
    "        df = df.drop(index=[3186]).reset_index(drop=True)\n",
    "    elif dataset_name == \"helpsteer2\":\n",
    "        judge_output_dir = \"../judge_outputs/helpsteer2\"\n",
    "        data_path = \"../data/helpsteer2/helpsteer2_valid.json\"\n",
    "        ratings = load_helpsteer2(data_path)\n",
    "        df = collect_judge_outputs(judge_output_dir)\n",
    "    elif dataset_name == \"ultrafeedback\":\n",
    "        judge_output_dir = \"../judge_outputs/ultrafeedback_sampled\"\n",
    "        data_path = \"../data/ultrafeedback_sampled.csv\"\n",
    "        ratings = load_ultrafeedback(data_path)\n",
    "        ratings = ratings.drop(index=[1098, 1164]).reset_index(drop=True)\n",
    "        df = collect_judge_outputs(judge_output_dir)\n",
    "        df = df.drop(index=[1098, 1164]).reset_index(drop=True)\n",
    "        \n",
    "    program_judges = pd.read_csv(f\"../automated_program_synthesis/program_judge_outputs/{dataset_name}_program_judge_results.csv\")\n",
    "    program_judges_dropped = program_judges.drop(columns=[\"question\", \"answer\"])\n",
    "    responses = ratings['answer'].tolist()\n",
    "    human_eval = ratings['score']\n",
    "\n",
    "    print(len(ratings), len(program_judges), len(df))\n",
    "\n",
    "    # 5. Filter out invalid scores and convert all to float\n",
    "    # Get min and max rating values from the dataset\n",
    "    min_rating, max_rating = ratings['score'].min(), ratings['score'].max()\n",
    "\n",
    "    # Rescale program judges using min-max scaling to put scores between min_rating and max_rating\n",
    "    for col in program_judges_dropped.columns:\n",
    "        if col != 'id':  # Skip the ID column if it exists\n",
    "            # Min-max scaling formula: (x - min_x) / (max_x - min_x) * (max_rating - min_rating) + min_rating\n",
    "            min_val = program_judges_dropped[col].min()\n",
    "            max_val = program_judges_dropped[col].max()\n",
    "            \n",
    "            # Avoid division by zero\n",
    "            if max_val > min_val:\n",
    "                program_judges_dropped[col] = (program_judges_dropped[col] - min_val) / (max_val - min_val) * (max_rating - min_rating) + min_rating\n",
    "            else:\n",
    "                # If all values are the same, set them to the middle of the rating range\n",
    "                program_judges_dropped[col] = (max_rating + min_rating) / 2\n",
    "\n",
    "    # Add the rescaled program judges to the dataframe\n",
    "    for col in program_judges_dropped.columns:\n",
    "        if col != 'id':  # Skip the ID column if it exists\n",
    "            df[col] = program_judges_dropped[col].values\n",
    "    print(f\"Min rating: {min_rating}, Max rating: {max_rating}\")\n",
    "\n",
    "    # Use these values when calling is_valid_score\n",
    "    # Note: is_valid_score already has min_rating, max_rating parameters in its definition\n",
    "    mask = df.map(lambda x: is_valid_score(x, min_rating=min_rating, max_rating=max_rating)).all(axis=1)\n",
    "    df = df[mask].astype(float)\n",
    "    human_eval = human_eval[mask]\n",
    "    \n",
    "    # -----------------------------------------------------------------------------\n",
    "    # 6. Learn graphical model structure from judge correlations\n",
    "    corr_matrix = df.corr()  # Compute correlation matrix\n",
    "    corr_matrix = corr_matrix.replace([np.inf, -np.inf], np.nan).fillna(0.0)\n",
    "    np.fill_diagonal(corr_matrix.values, 1.0)\n",
    "    \n",
    "    S_est, L_est = learn_structure(corr_matrix, gamma=gamma)  # Sparse + low-rank decomposition\n",
    "    weights = get_weights(L_est, threshold=threshold)  # Weights from latent structure\n",
    "    print(\"weights\", len(weights), weights)\n",
    "\n",
    "    # -----------------------------------------------------------------------------\n",
    "    # 7. Compute various aggregation methods\n",
    "    mv = majority_vote(df)               # Most frequent score per sample\n",
    "    # print(\"mv\", mv)\n",
    "    \n",
    "    avg = df.mean(axis=1)                # Simple average\n",
    "    # print(\"avg\", avg)\n",
    "    \n",
    "    # Weighted average using latent weights\n",
    "    weighted_avg = sum(weights[i] * df.iloc[:, i].to_numpy() for i in range(len(weights))) / sum(weights)\n",
    "    # print(\"weighted_avg\", weighted_avg)\n",
    "\n",
    "    uws = uws_aggregate(df)              # Unweighted supervision aggregate\n",
    "    # print(\"uws\", uws)\n",
    "\n",
    "    # # -----------------------------------------------------------------------------\n",
    "    # # Add this to our list of predictions\n",
    "    pred_methods = ['mv', 'avg', 'uws', 'caresl']\n",
    "    pred_values = [mv, avg,  uws, weighted_avg]\n",
    "    # -----------------------------------------------------------------------------\n",
    "\n",
    "    # 8. Evaluate predictions against human scores (MAE)\n",
    "    for name, pred in zip(pred_methods, pred_values):\n",
    "        result = {\n",
    "            'dataset': dataset_name,\n",
    "            'pred': name,\n",
    "            'mae': compute_mae(pred, human_eval),\n",
    "            'kendall_tau': sp.stats.kendalltau(pred, human_eval).correlation\n",
    "        }\n",
    "        results.append(result)\n",
    "        print(name, result)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "result_df = pd.DataFrame(results)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Threshold: 1\n",
      "Gamma: 1\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>dataset</th>\n",
       "      <th>pred</th>\n",
       "      <th>mae</th>\n",
       "      <th>kendall_tau</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>feedbackqa</td>\n",
       "      <td>mv</td>\n",
       "      <td>0.971803</td>\n",
       "      <td>0.386676</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>feedbackqa</td>\n",
       "      <td>avg</td>\n",
       "      <td>0.877038</td>\n",
       "      <td>0.433827</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>feedbackqa</td>\n",
       "      <td>uws</td>\n",
       "      <td>0.929179</td>\n",
       "      <td>0.427013</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>feedbackqa</td>\n",
       "      <td>caresl</td>\n",
       "      <td>1.255768</td>\n",
       "      <td>-0.341958</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "      dataset    pred       mae  kendall_tau\n",
       "0  feedbackqa      mv  0.971803     0.386676\n",
       "1  feedbackqa     avg  0.877038     0.433827\n",
       "2  feedbackqa     uws  0.929179     0.427013\n",
       "3  feedbackqa  caresl  1.255768    -0.341958"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Display final MAE results for each aggregation method\n",
    "print(f\"Threshold: {threshold}\")\n",
    "print(f\"Gamma: {gamma}\")\n",
    "display(result_df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x600 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(8, 6)) # Adjust figure size as needed\n",
    "sns.heatmap(corr_matrix, cmap='coolwarm', fmt=\".2f\", linewidths=.5)\n",
    "plt.title('Correlation Matrix Heatmap')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Greedy Algorithm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "filter_df = copy.copy(df)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "ground_truth = copy.copy(human_eval)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Llama-3.1-8B-Instruct</th>\n",
       "      <th>Llama-3.2-1B</th>\n",
       "      <th>Llama-3.2-3B</th>\n",
       "      <th>Mistral-7B-Instruct-v0.3</th>\n",
       "      <th>Phi-4-mini-instruct</th>\n",
       "      <th>Qwen3-1.7B</th>\n",
       "      <th>Qwen3-4B</th>\n",
       "      <th>Qwen3-8B</th>\n",
       "      <th>gemma-3-1b-it</th>\n",
       "      <th>gemma-3-4b-it</th>\n",
       "      <th>judge_0001</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1.0</td>\n",
       "      <td>3.5</td>\n",
       "      <td>3.0</td>\n",
       "      <td>2.5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>2.5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>2.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>3.25</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2.0</td>\n",
       "      <td>3.5</td>\n",
       "      <td>3.0</td>\n",
       "      <td>3.5</td>\n",
       "      <td>2.5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>3.5</td>\n",
       "      <td>3.5</td>\n",
       "      <td>2.0</td>\n",
       "      <td>2.0</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2.0</td>\n",
       "      <td>3.5</td>\n",
       "      <td>3.0</td>\n",
       "      <td>2.5</td>\n",
       "      <td>1.5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>3.5</td>\n",
       "      <td>2.5</td>\n",
       "      <td>2.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>3.0</td>\n",
       "      <td>3.5</td>\n",
       "      <td>3.0</td>\n",
       "      <td>3.5</td>\n",
       "      <td>3.5</td>\n",
       "      <td>3.0</td>\n",
       "      <td>3.5</td>\n",
       "      <td>3.5</td>\n",
       "      <td>3.0</td>\n",
       "      <td>3.0</td>\n",
       "      <td>2.80</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1.0</td>\n",
       "      <td>3.5</td>\n",
       "      <td>2.0</td>\n",
       "      <td>1.5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>3.5</td>\n",
       "      <td>3.5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5653</th>\n",
       "      <td>2.0</td>\n",
       "      <td>3.5</td>\n",
       "      <td>3.0</td>\n",
       "      <td>2.5</td>\n",
       "      <td>1.5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>3.5</td>\n",
       "      <td>3.0</td>\n",
       "      <td>3.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5654</th>\n",
       "      <td>4.0</td>\n",
       "      <td>3.5</td>\n",
       "      <td>3.0</td>\n",
       "      <td>3.5</td>\n",
       "      <td>2.5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>3.5</td>\n",
       "      <td>3.5</td>\n",
       "      <td>2.0</td>\n",
       "      <td>2.0</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5655</th>\n",
       "      <td>2.0</td>\n",
       "      <td>3.5</td>\n",
       "      <td>3.0</td>\n",
       "      <td>2.5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>3.5</td>\n",
       "      <td>2.5</td>\n",
       "      <td>2.0</td>\n",
       "      <td>2.0</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5656</th>\n",
       "      <td>1.0</td>\n",
       "      <td>3.5</td>\n",
       "      <td>3.0</td>\n",
       "      <td>2.5</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>2.5</td>\n",
       "      <td>3.5</td>\n",
       "      <td>3.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>1.00</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5658</th>\n",
       "      <td>2.0</td>\n",
       "      <td>3.5</td>\n",
       "      <td>3.0</td>\n",
       "      <td>4.0</td>\n",
       "      <td>4.0</td>\n",
       "      <td>1.0</td>\n",
       "      <td>3.5</td>\n",
       "      <td>3.5</td>\n",
       "      <td>2.0</td>\n",
       "      <td>2.0</td>\n",
       "      <td>2.75</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5373 rows × 11 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "      Llama-3.1-8B-Instruct  Llama-3.2-1B  Llama-3.2-3B  \\\n",
       "0                       1.0           3.5           3.0   \n",
       "1                       2.0           3.5           3.0   \n",
       "2                       2.0           3.5           3.0   \n",
       "3                       3.0           3.5           3.0   \n",
       "4                       1.0           3.5           2.0   \n",
       "...                     ...           ...           ...   \n",
       "5653                    2.0           3.5           3.0   \n",
       "5654                    4.0           3.5           3.0   \n",
       "5655                    2.0           3.5           3.0   \n",
       "5656                    1.0           3.5           3.0   \n",
       "5658                    2.0           3.5           3.0   \n",
       "\n",
       "      Mistral-7B-Instruct-v0.3  Phi-4-mini-instruct  Qwen3-1.7B  Qwen3-4B  \\\n",
       "0                          2.5                  1.0         1.0       2.5   \n",
       "1                          3.5                  2.5         1.0       3.5   \n",
       "2                          2.5                  1.5         1.0       3.5   \n",
       "3                          3.5                  3.5         3.0       3.5   \n",
       "4                          1.5                  1.0         1.0       3.5   \n",
       "...                        ...                  ...         ...       ...   \n",
       "5653                       2.5                  1.5         1.0       3.5   \n",
       "5654                       3.5                  2.5         1.0       3.5   \n",
       "5655                       2.5                  1.0         1.0       3.5   \n",
       "5656                       2.5                  1.0         1.0       2.5   \n",
       "5658                       4.0                  4.0         1.0       3.5   \n",
       "\n",
       "      Qwen3-8B  gemma-3-1b-it  gemma-3-4b-it  judge_0001  \n",
       "0          1.0            2.0            1.0        3.25  \n",
       "1          3.5            2.0            2.0        1.00  \n",
       "2          2.5            2.0            1.0        1.00  \n",
       "3          3.5            3.0            3.0        2.80  \n",
       "4          3.5            1.0            1.0        1.00  \n",
       "...        ...            ...            ...         ...  \n",
       "5653       3.0            3.0            1.0        1.00  \n",
       "5654       3.5            2.0            2.0        1.00  \n",
       "5655       2.5            2.0            2.0        1.00  \n",
       "5656       3.5            3.0            1.0        1.00  \n",
       "5658       3.5            2.0            2.0        2.75  \n",
       "\n",
       "[5373 rows x 11 columns]"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "filter_df.iloc[:, :10]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Greedy forward feature selection using cut_weighted_avg_mae criterion with validation search\n",
    "def greedy_feature_selection(df, human_eval, gamma=1, threshold=1, start_k=3, val_size=0.1, random_state=42):\n",
    "    \n",
    "    # Split into train/validation\n",
    "    df_train, df_val, gt_train, gt_val = train_test_split(\n",
    "        df, human_eval, test_size=val_size, random_state=random_state\n",
    "    )\n",
    "\n",
    "    n_features = df.shape[1]\n",
    "\n",
    "    def compute_mae_for_features(df_eval, gt_eval, features):\n",
    "        corr_matrix = df_train.iloc[:, features].corr()\n",
    "        corr_matrix = corr_matrix.replace([np.inf, -np.inf], np.nan).fillna(0.0)\n",
    "        np.fill_diagonal(corr_matrix.values, 1.0)\n",
    "    \n",
    "        S_est, L_est = learn_structure(corr_matrix, gamma=gamma)\n",
    "        weights = get_weights(L_est, threshold=threshold)\n",
    "\n",
    "        weighted_avg_pred = sum(weights[i] * df_eval.iloc[:, features[i]].to_numpy() for i in range(len(weights))) / sum(weights)\n",
    "        weighted_avg_mae = compute_mae(weighted_avg_pred, gt_eval)\n",
    "        \n",
    "        return weighted_avg_mae\n",
    "\n",
    "    # Step 1: choose the best start_k features using validation\n",
    "    best_init = None\n",
    "    best_init_val_mae = float(\"inf\")\n",
    "    for comb in combinations(range(n_features), start_k):\n",
    "        mae_val = compute_mae_for_features(df_val, gt_val, list(comb))\n",
    "        if mae_val < best_init_val_mae:\n",
    "            best_init_val_mae = mae_val\n",
    "            best_init = list(comb)\n",
    "\n",
    "    selected_features = best_init\n",
    "    remaining_features = [f for f in range(n_features) if f not in selected_features]\n",
    "\n",
    "    maes = [compute_mae_for_features(df, human_eval, selected_features)]\n",
    "    selected_counts = [len(selected_features)]\n",
    "\n",
    "    # Step 2: greedy expansion guided by validation\n",
    "    while remaining_features:\n",
    "        best_feature = None\n",
    "        best_val_mae = float(\"inf\")\n",
    "\n",
    "        for feat in remaining_features:\n",
    "            trial_features = selected_features + [feat]\n",
    "            mae_val = compute_mae_for_features(df_val, gt_val, trial_features)\n",
    "\n",
    "            if mae_val < best_val_mae:\n",
    "                best_val_mae = mae_val\n",
    "                best_feature = feat\n",
    "\n",
    "        selected_features.append(best_feature)\n",
    "        remaining_features.remove(best_feature)\n",
    "\n",
    "        # After selecting, compute final MAE on full dataset\n",
    "        final_mae = compute_mae_for_features(df, human_eval, selected_features)\n",
    "        maes.append(final_mae)\n",
    "        selected_counts.append(len(selected_features))\n",
    "\n",
    "    return selected_counts, maes, selected_features"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n"
     ]
    }
   ],
   "source": [
    "# Example usage\n",
    "selected_counts, maes, selected_features = greedy_feature_selection(df, human_eval)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot scaling\n",
    "plt.figure(figsize=(6, 4))\n",
    "plt.plot(selected_counts[:20], maes[:20], marker='o', label=\"CARESL\")\n",
    "plt.axhline(y=result_df[result_df[\"pred\"] == \"mv\"][\"mae\"].values[0], color='r', linestyle='--', label='MV', linewidth=2)\n",
    "plt.axhline(y=result_df[result_df[\"pred\"] == \"avg\"][\"mae\"].values[0], color='b', linestyle='--', label='AVG', linewidth=2)\n",
    "plt.axhline(y=result_df[result_df[\"pred\"] == \"uws\"][\"mae\"].values[0], color='y', linestyle='--', label='UWS', linewidth=2)\n",
    "plt.xticks(selected_counts[:20], selected_counts[:20])\n",
    "plt.xlabel(\"Number of Selected Features (k)\")\n",
    "plt.ylabel(\"MAE\")\n",
    "plt.title(\"Greedy Forward Selection\")\n",
    "plt.grid(True)\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Selected feature order: [0, 9, 10, 23, 2, 32, 27, 18, 28, 14, 7, 15, 11, 12, 22, 13, 38, 8, 3, 16, 5, 29, 6, 20, 37, 34, 4, 21, 26, 30, 31, 25, 33, 1, 35, 36, 17, 19, 24]\n"
     ]
    }
   ],
   "source": [
    "print(\"Selected feature order:\", selected_features)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['Llama-3.1-8B-Instruct', 'gemma-3-4b-it', 'judge_0001', 'judge_0018',\n",
       "       'Llama-3.2-3B', 'judge_0033', 'judge_0026', 'judge_0009', 'judge_0027',\n",
       "       'judge_0005', 'Qwen3-8B', 'judge_0006', 'judge_0002', 'judge_0003',\n",
       "       'judge_0016', 'judge_0004', 'judge_0041', 'gemma-3-1b-it',\n",
       "       'Mistral-7B-Instruct-v0.3', 'judge_0007', 'Qwen3-1.7B', 'judge_0028',\n",
       "       'Qwen3-4B', 'judge_0011', 'judge_0039', 'judge_0035',\n",
       "       'Phi-4-mini-instruct', 'judge_0012', 'judge_0024', 'judge_0030',\n",
       "       'judge_0031', 'judge_0023', 'judge_0034', 'Llama-3.2-1B', 'judge_0036',\n",
       "       'judge_0038', 'judge_0008', 'judge_0010', 'judge_0020'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 41,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df.columns[selected_features]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Enhanced greedy forward feature selection with multiple models\n",
    "def greedy_feature_selection_multi(df, human_eval, gamma=1, threshold=1, start_k=3, val_size=0.1, random_state=42):\n",
    "    \"\"\"\n",
    "    Greedy forward feature selection comparing multiple aggregation methods.\n",
    "    \n",
    "    Args:\n",
    "        df: DataFrame with features\n",
    "        human_eval: Ground truth values\n",
    "        gamma: Parameter for structure learning\n",
    "        threshold: Threshold for weight computation\n",
    "        start_k: Initial number of features to select\n",
    "        val_size: Validation set size\n",
    "        random_state: Random seed\n",
    "    \n",
    "    Returns:\n",
    "        Dictionary containing results for each method\n",
    "    \"\"\"\n",
    "    \n",
    "    # Split into train/validation\n",
    "    df_train, df_val, gt_train, gt_val = train_test_split(\n",
    "        df, human_eval, test_size=val_size, random_state=random_state\n",
    "    )\n",
    "    n_features = df.shape[1]\n",
    "    \n",
    "    # Define all aggregation methods\n",
    "    def compute_mae_for_features(df_eval, gt_eval, features, method):\n",
    "        \"\"\"Compute MAE for given features using specified method\"\"\"\n",
    "        df_subset = df_eval.iloc[:, features]\n",
    "        \n",
    "        if method == 'majority_vote':\n",
    "            pred = majority_vote(df_subset)\n",
    "        elif method == 'simple_average':\n",
    "            pred = df_subset.mean(axis=1).to_numpy()\n",
    "        elif method == 'uws':\n",
    "            pred = uws_aggregate(df_subset)\n",
    "        elif method == 'weighted_avg':\n",
    "            # Use training data to learn structure\n",
    "            corr_matrix = df_train.iloc[:, features].corr()\n",
    "            corr_matrix = corr_matrix.replace([np.inf, -np.inf], np.nan).fillna(0.0)\n",
    "            np.fill_diagonal(corr_matrix.values, 1.0)\n",
    "            \n",
    "            S_est, L_est = learn_structure(corr_matrix, gamma=gamma)\n",
    "            weights = get_weights(L_est, threshold=threshold)\n",
    "            pred = sum(weights[i] * df_subset.iloc[:, i].to_numpy() for i in range(len(weights))) / sum(weights)\n",
    "        return compute_mae(pred, gt_eval)\n",
    "    \n",
    "    methods = ['weighted_avg', 'majority_vote', 'simple_average', 'uws']\n",
    "    results = {}\n",
    "    \n",
    "    # Process each method\n",
    "    for method in methods:\n",
    "        print(f\"Processing {method}...\")\n",
    "        \n",
    "        # Step 1: Choose the best start_k features using validation\n",
    "        best_init = None\n",
    "        best_init_val_mae = float(\"inf\")\n",
    "        \n",
    "        for comb in combinations(range(n_features), start_k):\n",
    "            mae_val = compute_mae_for_features(df_val, gt_val, list(comb), method)\n",
    "            if mae_val < best_init_val_mae:\n",
    "                best_init_val_mae = mae_val\n",
    "                best_init = list(comb)\n",
    "        \n",
    "        selected_features = best_init.copy()\n",
    "        remaining_features = [f for f in range(n_features) if f not in selected_features]\n",
    "        maes = [compute_mae_for_features(df, human_eval, selected_features, method)]\n",
    "        selected_counts = [len(selected_features)]\n",
    "        feature_sequence = [selected_features.copy()]\n",
    "        \n",
    "        # Step 2: Greedy expansion guided by validation\n",
    "        while remaining_features:\n",
    "            best_feature = None\n",
    "            best_val_mae = float(\"inf\")\n",
    "            \n",
    "            for feat in remaining_features:\n",
    "                trial_features = selected_features + [feat]\n",
    "                mae_val = compute_mae_for_features(df_val, gt_val, trial_features, method)\n",
    "                if mae_val < best_val_mae:\n",
    "                    best_val_mae = mae_val\n",
    "                    best_feature = feat\n",
    "            \n",
    "            selected_features.append(best_feature)\n",
    "            remaining_features.remove(best_feature)\n",
    "            \n",
    "            # After selecting, compute final MAE on full dataset\n",
    "            final_mae = compute_mae_for_features(df, human_eval, selected_features, method)\n",
    "            maes.append(final_mae)\n",
    "            selected_counts.append(len(selected_features))\n",
    "            feature_sequence.append(selected_features.copy())\n",
    "        \n",
    "        results[method] = {\n",
    "            'selected_counts': selected_counts,\n",
    "            'maes': maes,\n",
    "            'final_features': selected_features,\n",
    "            'feature_sequence': feature_sequence\n",
    "        }\n",
    "    \n",
    "    return results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Processing weighted_avg...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n",
      "/mnt/task_runtime/llm-judge-bias/brian_dev/../src/pgm_tools.py:122: RuntimeWarning: invalid value encountered in sqrt\n",
      "  weights = eigenvec[:, 0] * np.sqrt(eigenval[0])\n"
     ]
    }
   ],
   "source": [
    "results = greedy_feature_selection_multi(filter_df, ground_truth, gamma=1, threshold=1, start_k=3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.figure(figsize=(6, 5))\n",
    "\n",
    "colors = ['blue', 'red', 'green', 'orange', 'purple']\n",
    "method_name = [\"CARESL\", \"MV\", \"AVG\", \"UWS\"]\n",
    "\n",
    "for i, (method, data) in enumerate(results.items()):\n",
    "    plt.plot(data['selected_counts'][:20], data['maes'][:20], \n",
    "            color=colors[i], linestyle='-', \n",
    "            marker='o', markersize=5, label=method_name[i], linewidth=1)\n",
    "\n",
    "plt.xticks(np.arange(3, 23), np.arange(3, 23))\n",
    "plt.xlabel('Number of Selected Judge', fontsize=12)\n",
    "plt.ylabel('MAE', fontsize=12)\n",
    "plt.title('Greedy Forward Selection', fontsize=14)\n",
    "plt.legend(fontsize=10)\n",
    "plt.grid(True, alpha=0.3)\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(\"helpsteer2_greedy_selection_with_new_judges.pkl\", \"wb\") as f:\n",
    "    pickle.dump(results, f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.15"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
