{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a6413656",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Successfully loaded and transformed all data into tournament format:\n",
      "model\n",
      "primal_dual_dpo_4_42_5     7182\n",
      "primal_dual_dpo_3_42_10    7182\n",
      "primal_dual_dpo_3_42_5     3990\n",
      "primal_dual_dpo_3_42_8     3990\n",
      "primal_dual_dpo_3_42_15    3990\n",
      "primal_dual_dpo_5_42_5     3990\n",
      "primal_dual_dpo_5_42_3     2394\n",
      "primal_dual_dpo_1_42_5     2394\n",
      "primal_dual_dpo_2_42_5     1596\n",
      "primal_dual_dpo_5_42_10    1596\n",
      "Name: count, dtype: int64\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "from pathlib import Path\n",
    "import json\n",
    "# Load all the data with primal_dual_dpo naming convention\n",
    "RESULT_DIR = Path(\"./results/arena_tournament\")\n",
    "JSON_FILENAME = \"evaluation_results.csv\"\n",
    "MODEL_NAME = \"primal_dual_dpo\"\n",
    "\n",
    "csv_files = list(RESULT_DIR.rglob(JSON_FILENAME))\n",
    "\n",
    "all_tournament_dfs = []\n",
    "\n",
    "for file_path in csv_files:\n",
    "    model_a_name, model_b_name = file_path.parent.name.split(\"_vs_\")\n",
    "    # Only include when MODEL_NAME is involved\n",
    "    if (MODEL_NAME not in model_a_name) or (MODEL_NAME not in model_b_name):\n",
    "        continue\n",
    "    \n",
    "    COLUMN_NAMES = [\n",
    "        'prompt',\n",
    "        model_a_name,\n",
    "        'Reward_Model_A',\n",
    "        'Cost_Model_A',\n",
    "        model_b_name,\n",
    "        'Reward_Model_B',\n",
    "        'Cost_Model_B'\n",
    "    ]\n",
    "    df_wide = pd.read_csv(file_path, header=None, names=COLUMN_NAMES, skiprows=1)\n",
    "    df_wide = df_wide.drop('prompt', axis=1)\n",
    "\n",
    "    # --- Create the DataFrame for Model A ---\n",
    "    df_a = df_wide[[model_a_name, 'Cost_Model_A', 'Reward_Model_A']].copy()\n",
    "    # Rename columns to a standard format\n",
    "    df_a.rename(columns={\n",
    "        model_a_name: 'response',\n",
    "        'Cost_Model_A': 'cost',\n",
    "        'Reward_Model_A': 'reward'\n",
    "    }, inplace=True)\n",
    "    # Add model and opponent identifiers\n",
    "    df_a['model'] = model_a_name\n",
    "    df_a['opponent'] = model_b_name\n",
    "    \n",
    "    # --- Create the DataFrame for Model B ---\n",
    "    df_b = df_wide[[model_b_name, 'Cost_Model_B', 'Reward_Model_B']].copy()\n",
    "    # Rename columns to the same standard format\n",
    "    df_b.rename(columns={\n",
    "        model_b_name: 'response',\n",
    "        'Cost_Model_B': 'cost',\n",
    "        'Reward_Model_B': 'reward'\n",
    "    }, inplace=True)\n",
    "    # Add model and opponent identifiers (note they are swapped)\n",
    "    df_b['model'] = model_b_name\n",
    "    df_b['opponent'] = model_a_name\n",
    "\n",
    "    # --- Combine the two parts for this file ---\n",
    "    df_tournament = pd.concat([df_a, df_b], ignore_index=True)\n",
    "    \n",
    "    # Append the processed DataFrame to our master list\n",
    "    all_tournament_dfs.append(df_tournament)\n",
    "\n",
    "# --- 3. Concatenate all processed DataFrames into the final result ---\n",
    "if all_tournament_dfs:\n",
    "    final_df = pd.concat(all_tournament_dfs, ignore_index=True)\n",
    "    \n",
    "    # Optional: Reorder columns for better readability\n",
    "    final_df = final_df[['model', 'opponent', 'response', 'cost', 'reward']]\n",
    "    \n",
    "    print(\"\\nSuccessfully loaded and transformed all data into tournament format:\")\n",
    "    print(final_df['model'].value_counts())\n",
    "else:\n",
    "    print(\"No CSV files were found.\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "9cd47359",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAwgAAAIhCAYAAADq0Z1dAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjYsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvq6yFwwAAAAlwSFlzAAAPYQAAD2EBqD+naQAAZ/dJREFUeJzt3Xd4FFXbx/HfppIOCQQChN6rBZQmPTQNxUJTqfoIIigISkQFFIyC8mKjKF0BASmCCILSpCmEIgJSA6EkdEIIkJBk3j8Cy64pJJDNJuT7ea65LufMOTNndjTP3nufc8ZkGIYhAAAAAJDkYO8OAAAAAMg5CBAAAAAAmBEgAAAAADAjQAAAAABgRoAAAAAAwIwAAQAAAIAZAQIAAAAAMwIEAAAAAGYECAAAAADMCBCAPGzGjBkymUzavn17qsefeuoplSpVyqZ92Lx5s0aMGKHLly/b9Do5xe+//65atWrJw8NDJpNJS5YsSbXesWPHZDKZZDKZNGLEiFTr9OrVy1wnJxsxYoS5nyaTSc7OzipRooRefvllRUVF2bt7WSa9ZwUAuQkBAgC72rx5s0aOHJknAgTDMNSxY0c5Oztr6dKl2rJlixo1apRuGy8vL82YMUNJSUlW5VevXtWCBQvk7e1tyy5nqZUrV2rLli1asWKFOnfurGnTpqlZs2a6efOmvbsGALBAgAAA2eT06dO6ePGiOnTooGbNmqlOnToqUKBAum06deqk48eP6/fff7cqnzdvnhITE9W2bVtbdjlLPfroo6pTp46aN2+uMWPGqHv37tq3b582btxo765lyLVr1+zdBQDIFgQIADLFMAxNmDBBDz30kNzc3FSgQAE9++yzOnr0qFW91atXq127dipevLjy5cuncuXK6ZVXXtH58+fNdUaMGKEhQ4ZIkkqXLm0egrJu3TpJUqlSpfTUU0/p559/1sMPPyw3NzdVrlxZP//8s6TkIVKVK1eWh4eHHnvssRRDpbZv367OnTurVKlScnNzU6lSpdSlSxcdP37cqt7toVarV69Wz5495evrKw8PDwUHB6e4r7Rs3LhRzZo1k5eXl9zd3VWvXj0tX77c6l6LFy8uSXr77bdlMpkyNHyrYsWKqlevnqZNm2ZVPm3aND399NPy8fFJtd28efNUt25deXh4yNPTUy1bttTOnTut6mT281m7dq369u2rggULys/PT08//bROnz6dkY8nVbVq1ZIknTlzxqr8t99+U7NmzeTt7S13d3fVr1/fKkDau3evTCaTFixYYC4LCwuTyWRS1apVrc7Vtm1bPfroo1afS4sWLRQQEGD+92no0KGKjY21atejRw95enpqz549atGihby8vNSsWTNJ0pUrV/Tyyy/Lz89Pnp6eatWqlQ4ePHjPnwMA5DQECACUmJiohISEFJthGCnqvvLKK3rjjTfUvHlzLVmyRBMmTNDevXtVr149qy96R44cUd26dTVx4kStWrVK77//vv788081aNDAPKTkpZdeUv/+/SVJixYt0pYtW7RlyxY98sgj5vPs3r1bISEhevvtt7Vo0SL5+Pjo6aef1vDhwzVlyhR99NFHmj17tqKjo/XUU0/p+vXr5rbHjh1TxYoVNX78eP3666/65JNPFBkZqdq1a1sFKrf17t1bDg4OmjNnjsaPH6+//vpLjRs3vuvwp/Xr16tp06aKjo7W1KlTNXfuXHl5eSk4OFjz5s0z3+uiRYskSf3799eWLVu0ePHiDD2f3r17a8mSJbp06ZIk6cCBA9q8ebN69+6dav2PPvpIXbp0UZUqVTR//nx99913iomJ0RNPPKF9+/bd8+fz0ksvydnZWXPmzNGYMWO0bt06vfDCCxm6h9SEh4dLkipUqGAu+/7779WiRQt5e3tr5syZmj9/vnx9fdWyZUtzkFC1alUFBATot99+M7f77bff5Obmpn379pmDloSEBK1fv17Nmzc31zt06JDatGmjqVOnauXKlXrjjTc0f/58BQcHp+hffHy82rZtq6ZNm+qnn37SyJEjZRiG2rdvr++++05vvvmmFi9erDp16qh169b3/DkAQI5jAMizpk+fbkhKdytZsqS5/pYtWwxJxmeffWZ1nhMnThhubm7GW2+9lep1kpKSjJs3bxrHjx83JBk//fST+djYsWMNSUZ4eHiKdiVLljTc3NyMkydPmst27dplSDICAgKM2NhYc/mSJUsMScbSpUvTvN+EhATj6tWrhoeHh/H555+n+Bw6dOhgVX/Tpk2GJGPUqFFpntMwDKNOnTqGv7+/ERMTY3WtatWqGcWLFzeSkpIMwzCM8PBwQ5IxduzYdM/337oxMTGGp6en8dVXXxmGYRhDhgwxSpcubSQlJRn9+vUzLP+UR0REGE5OTkb//v2tzhcTE2MU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",
      "text/plain": [
       "<Figure size 1000x600 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "dpo_df = final_df.copy()\n",
    "pattern = r'primal_dual_dpo_(.+?)_42_(\\d+)'\n",
    "dpo_df[['param_a', 'lagrangian_multiplier']] = dpo_df['model'].str.extract(pattern)\n",
    "dpo_df['lagrangian_multiplier'] = pd.to_numeric(dpo_df['lagrangian_multiplier'])\n",
    "\n",
    "performance_summary = dpo_df.groupby(['param_a', 'lagrangian_multiplier'])['reward'].agg(['mean', 'std', 'count']).sort_values(by='mean', ascending=False)\n",
    "\n",
    "\n",
    "heatmap_data = performance_summary.reset_index().pivot(\n",
    "    index='param_a', \n",
    "    columns='lagrangian_multiplier', \n",
    "    values='mean'\n",
    ")\n",
    "\n",
    "plt.figure(figsize=(10, 6))\n",
    "sns.heatmap(\n",
    "    heatmap_data, \n",
    "    annot=True, \n",
    "    fmt=\".3f\", \n",
    "    cmap=\"viridis\", \n",
    "    linewidths=.5\n",
    ")\n",
    "plt.title('Heatmap of Mean Reward')\n",
    "plt.xlabel('Lagrangian Multiplier')\n",
    "plt.ylabel('Parameter \"a\"')\n",
    "plt.show()\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "safe-rlhf",
   "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.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
