{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os, sys, re\n",
    "import datasets\n",
    "import numpy as np \n",
    "ROOT = \"/u/audreyh/workspace/test-code\"\n",
    "sys.path.append(os.path.join(ROOT, 'code'))\n",
    "\n",
    "os.environ['XDG_CACHE_HOME'] =  \"/work/hdd/bdkj/audreyh/.cache\"\n",
    "\n",
    "from importlib import import_module\n",
    "from omegaconf import OmegaConf, DictConfig, ListConfig\n",
    "from pathlib import Path\n",
    "\n",
    "import helpers.io as io\n",
    "import helpers.test_functions as tf\n",
    "\n",
    "import matplotlib.pyplot as plt \n",
    "import seaborn as sns\n",
    "\n",
    "params = {'legend.fontsize': 12,\n",
    "         'axes.labelsize': 12,\n",
    "         'axes.titlesize':12,\n",
    "         }\n",
    "plt.rcParams.update(params)\n",
    "\n",
    "sns.set_style(\"white\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_gen_files(gen_files):\n",
    "    logprobs = []\n",
    "    for gf in gen_files:\n",
    "        outputs = io.json_load(gf)\n",
    "        _logprobs = tf.get_key(outputs, \"logprobs\")\n",
    "        logprobs += _logprobs\n",
    "    return np.array(logprobs)\n",
    "\n",
    "def load_reward_files(reward_files):\n",
    "    rewards = []\n",
    "    for rf in reward_files:\n",
    "        _rewards = np.load(rf)\n",
    "        rewards += list(_rewards)\n",
    "    return np.array(rewards)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "task = \"gsm8k\"\n",
    "rhat = \"rm-gemma-2b\"\n",
    "rstar = \"armo-rm\"\n",
    "policies = [\"gemma-2-2b\", \"phi-3-small\"]\n",
    "root = \"/work/hdd/bdkj/audreyh/\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [],
   "source": [
    "policy = policies[0]\n",
    "reward = rhat\n",
    "load_path = os.path.join(root, \"data\", task, policy)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[PosixPath('/work/hdd/bdkj/audreyh/data/gsm8k/gemma-2-2b/generations/gsm8k-gemma-2-2b--shots-0-seed-102-generations.json')]\n",
      "Reading outputs from /work/hdd/bdkj/audreyh/data/gsm8k/gemma-2-2b/generations/gsm8k-gemma-2-2b--shots-0-seed-102-generations.json\n",
      "['/work/hdd/bdkj/audreyh/data/gsm8k/gemma-2-2b/rm-gemma-2b/gsm8k-gemma-2-2b--shots-0-seed-102-rm-gemma-2b-rewards.npy']\n",
      "['/work/hdd/bdkj/audreyh/data/gsm8k/gemma-2-2b/armo-rm/gsm8k-gemma-2-2b--shots-0-seed-102-armo-rm-rewards.npy']\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "generation_files = sorted(list(Path(load_path).rglob(f'*.json')))[1:2]\n",
    "print(generation_files)\n",
    "logprobs = load_gen_files(generation_files)\n",
    "# logprobs = [lp for lp in logprobs if lp > -200]\n",
    "sort_idxs = np.argsort(logprobs)\n",
    "sort_idxs = [idx for idx in sort_idxs if logprobs[idx] > -200]\n",
    "sorted_logprobs = logprobs[sort_idxs]\n",
    "\n",
    "\n",
    "for reward in [rhat, rstar]:\n",
    "    reward_files = [str(file).replace(\".json\", \"-rewards.npy\").replace(\"generations\", f\"{reward}\") for file in generation_files]\n",
    "    print(reward_files)\n",
    "    rewards = load_reward_files(reward_files)\n",
    "    rewards = rewards / np.max(np.abs(rewards))\n",
    "    # rewards = rewards - np.max(np.min(rewards, 0))\n",
    "    sorted_rewards = rewards[sort_idxs]\n",
    "    plt.plot(sorted_logprobs, sorted_rewards,alpha=0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# hist of logprobs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[PosixPath('/work/hdd/bdkj/audreyh/data/gsm8k/gemma-2-2b/rm-gemma-2b/gsm8k-gemma-2-2b--shots-0-seed-101-rm-gemma-2b-rewards.npy'), PosixPath('/work/hdd/bdkj/audreyh/data/gsm8k/gemma-2-2b/rm-gemma-2b/gsm8k-gemma-2-2b--shots-0-seed-112-rm-gemma-2b-rewards.npy')]\n",
      "['/work/hdd/bdkj/audreyh/data/gsm8k/gemma-2-2b/generations/gsm8k-gemma-2-2b--shots-0-seed-101-generations.json', '/work/hdd/bdkj/audreyh/data/gsm8k/gemma-2-2b/generations/gsm8k-gemma-2-2b--shots-0-seed-112-generations.json']\n"
     ]
    }
   ],
   "source": [
    "reward_files = list(Path(reward_path).rglob(f'*.npy'))\n",
    "reward_files = reward_files[:min(2, len(reward_files))]\n",
    "print(reward_files)\n",
    "\n",
    "gen_files = [str(file).replace(\"-rewards.npy\", \".json\").replace(f\"{reward}\", \"generations\") for file in reward_files]\n",
    "print(gen_files)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Reading outputs from /work/hdd/bdkj/audreyh/data/gsm8k/gemma-2-2b/generations/gsm8k-gemma-2-2b--shots-0-seed-101-generations.json\n",
      "Reading outputs from /work/hdd/bdkj/audreyh/data/gsm8k/gemma-2-2b/generations/gsm8k-gemma-2-2b--shots-0-seed-112-generations.json\n"
     ]
    }
   ],
   "source": [
    "logprobs = []\n",
    "for gf in gen_files:\n",
    "    outputs = io.json_load(gf)\n",
    "    _logprobs = tf.get_key(outputs, \"logprobs\")\n",
    "    logprobs += _logprobs\n",
    "\n",
    "rewards = []\n",
    "for rf in reward_files:\n",
    "    _rewards = np.load(rf)\n",
    "    rewards += list(_rewards)\n",
    "\n",
    "logprobs = np.array(logprobs)\n",
    "rewards = np.array(rewards)\n",
    "assert len(logprobs) == len(rewards), \"Lengths of logprobs and rewards don't match\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f0c2ba675b0>]"
      ]
     },
     "execution_count": 51,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiIAAAGdCAYAAAAvwBgXAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAABTpUlEQVR4nO3dd3gU1foH8O+mkwRCChCQ0HsavUlXqSKCgqCgiNi99sq1ASqI+tOLqCgqKiKKYkcRUGmhIwEktFACoaRBSG+78/sj7GbL7O7s7szOlu/nPvd52N2zMydjsvPuOe95j0YQBAFEREREKghQuwNERETkvxiIEBERkWoYiBAREZFqGIgQERGRahiIEBERkWoYiBAREZFqGIgQERGRahiIEBERkWqC1O6ALTqdDrm5uYiIiIBGo1G7O0RERCSBIAgoLS1F48aNERBge8zDowOR3NxcDB48WO1uEBERkRM2btyI+Ph4m208OhCJiIgAUPuDREZGqtwbIiIikqKkpASDBw823Mdt8ehARD8dExkZyUCEiIjIy0hJq2CyKhEREamGgQgRERGphoEIERERqYaBCBEREamGgQgRERGphoEIERERqYaBCBEREamGgQgRERGphoEIERERqYaBCBEREamGgQgRERGphoEIERERqYaBCBERkYqKK6rx4cbjOHOxTO2uqIKBCBERkYrm/JKBeb8fxuj/bVa7K6pgIEJERKSirccLAADFlTUq90QdDESIiIhINQxEiIiIJDhXWI5l206hvEpr8VqNVoflO7KQmVuiQs+8W5DaHSAiIvIGoxduRmFZNTJzSzB7XJLJayt2ncELP/4LADg1f4xDxz1bWG7z9X1nCpF1sQw3pDZzrMNegoEIERGRBIVl1QCAzcfyLV7bm3XJqWPaCkLWHryA2MhQ3PTBVgBAi5hwdE1oKNp2fUYOGoYHo2erGKf6oSZOzRARESmgqkaHb3efsQg28oorsXLXGZRU1uCDDZmi7z2ZX4p7lu0xBCG1z4lP+/xx8AJmfrEbNy/eJl/n3YgjIkRERAr4aNNxvLn2KEKCAnD0lVGG529evBVZBWV49vv90Ani7z17SXykJC0zH8GBAejdum7k495le2Ttt7txRISIiHxaQUklvv8nGxXVlkmmStJP4VTV6EyezyqoLVxmLQixpqi8Brd9vAOTPtyGlbvOoLCs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IvJCHr37riAIAICSkhKVe0JERERS6e/b+vu4LW4JRJo3b44jR444/L7S0lIAwODBg+XuEhERESmstLQU9evXt9lGI0gJV1Si0+mQm5uLiIgIaDQatbtDREREEgiCgNLSUjRu3BgBAbYrhXh0IEJERES+jbvvEhERkWoYiBAREZFqGIgQERGRahiIEBERkWoYiBAREZFqGIgQERGRahiIEBERkWoYiBAREZFqGIgo7IMPPsDkyZORmpqKnj17Wrx++PBhPP744xg8eDBSUlIwatQofP755xbtduzYgfHjxyMpKQnXXXcdvv/+e4s2y5cvx7Bhw5CcnIyJEydi//79ivxMcrB3XQDg3LlzuOeee5Camop+/frh9ddfR01NjUkbX7suxk6ePIn7778fffr0Qffu3TFlyhRs377dpI1c18jbbNiwARMnTkRKSgp69eqFBx54wOR1f70uVVVVGDduHDp27IhDhw6ZvHb48GHceuutSE5OxuDBg7FkyRKL9//+++8YOXIkkpOTMXbsWGzcuNFdXZdddnY2Zs2ahWHDhiElJQXXXnstFi5ciKqqKpN2/nZdxKj+GSmQov73v/8JS5cuFebNmyf06NHD4vVvv/1WmDt3rrBjxw7h9OnTwo8//iikpKQIy5YtM7Q5ffq0kJqaKsybN0/IzMwUli1bJnTu3FnYtGmToc3q1auFxMRE4bvvvhOOHTsmPP/880LPnj2F/Px8t/ycjrJ3XWpqaoTrr79emD59upCRkSFs2LBB6NOnj/DWW28Z2vjidTE2fPhw4e677xYOHToknDx5Unj55ZeF1NRUITc3VxAE+a6Rt1mzZo3Qq1cv4auvvhJOnDghHDt2TFi9erXhdX+9LoIgCHPnzhVmzpwpdOjQQcjIyDA8X1xcLPTv31944oknhKNHjwq//vqrkJKSInz99deGNnv27BE6d+4sLFmyRMjMzBTefvttITExUThy5IgaP4rLNm7cKDz77LPC5s2bhdOnTwvr168X+vXrJ8yfP9/Qxh+vizlP+IxkIOImq1atEr3hinn55ZeFadOmGR4vWLBAGDNmjEmbRx99VJgxY4bh8c033yzMnj3b8Fir1QoDBgwQPvzwQxd7rixr12XDhg1Cp06dhLy8PMNzX331ldC9e3ehsrJSEATfvi4FBQVChw4dhF27dhmeKy4uFjp06CCkpaUJgiDfNfIm1dXVwsCBA4WVK1dabeOP10UQan/ukSNHCseOHbMIRJYvXy706tXL8PMLgiC88cYbwogRIwyPH3nkEeGee+4xOebEiROFF154QfnOu8mSJUuEYcOGGR7zunjGZySnZjxQcXExGjZsaHicnp6Ofv36mbQZMGAA0tPTAdQOxx48eBD9+/c3vB4QEID+/ftj79697uiy7NLT09GhQwfExcUZnhswYABKSkqQmZlpaOOr1yU6OhqtW7fGjz/+iLKyMtTU1OCbb75BbGwsEhMTAchzjbxNRkYGcnJyEBAQgBtvvBEDBgzAzJkzcfToUUMbf7wu+fn5eOGFF7BgwQKEhYVZvJ6eno6ePXsiJCTE8NyAAQNw8uRJXL582dDGl66JmOLiYkRFRRke+/t18ZTPSAYiHuaff/7B77//jkmTJhmey8/PN/lQBYC4uDiUlJSgoqICly5dglarRWxsrEmb2NhY5Ofnu6XfcrP2MwNAXl6ezTa+cF00Gg0+++wzZGRkoHv37khJScHSpUvx8ccfGz5I5bhG3ubMmTMAgEWLFuH+++/H4sWLERUVhWnTpqGwsBCA/10XQRDw7LPPYvLkyUhOThZtY+ua6P8WxNp4w9+KVFlZWfjyyy8xefJkw3P+fl085TMyyG1n8iFvvvmmaEKTsd9++w1t27Z16LhHjx7FAw88gAcffBADBgxwpYuqUOq6+BKp16hNmzaYPXs2YmNjsXz5coSFheHbb7/Ffffdh++++w6NGzd2U4/dQ+p10el0AID77rsPI0aMAADMmzcPgwYNwpo1a0xuMt5O6jVJS0tDaWkp7r33Xjf1TF3OfM7k5ORg5syZGDlypMmXPPIMDEScMGPGDIwfP95mm4SEBIeOmZmZienTp+OWW26xWAEQFxdnEZ3m5+cjMjISYWFhCAgIQGBgIAoKCkzaFBQUWETySpLzusTFxVlkbuuvQaNGjQxtvOG6GJN6jbZv344NGzZg165diIyMBAAkJiZi69at+PHHH3HPPffIco08hdTroh/RML7JhISEICEhAefPnwcgz++OJ3DkdyU9Pd1iNOSmm27C2LFj8frrr1v9eYG6EQCxNmr+rVjj6OdMTk4Obr/9dnTr1g1z5841aedL18UZ0dHRHvEZyUDECTExMYiJiZHteMeOHcMdd9yBG2+8EY899pjF6127dsWmTZtMntu6dSu6du0KoPaDODExEdu2bcO1114LANDpdNi2bRumTp0qWz/tkfO6dO3aFYsXL0ZBQYFh2HDr1q2IjIxEu3btDG284boYk3qNysvLAdRO0RjTaDSGUQE5rpGnkHpdkpKSEBISgpMnTxqWfVdXV+Ps2bNo1qwZAN+5LlKvyfPPP49HH33U8Dg3Nxd33XUX3n77baSmpgKo/XnfeecdVFdXIzg4GEDtz9u6dWvDVF/Xrl2xfft2TJ8+3XAsT7smgGOfM/ogJDExEfPmzUNAgGk2gi9dF2d4zGek29Ji/dTZs2eFjIwM4d133xW6du0qZGRkCBkZGUJJSYkgCIJw5MgRoW/fvsKTTz4p5ObmGv5fUFBgOIZ+qeHrr78uZGZmCl9++aXoMtWkpCTh+++/FzIzM4UXXnhB6Nmzp8nKAU9i77rol2DOmDFDOHTokLBp0yahb9++okswfem66BUUFAi9e/cWHnroIeHQoUPCiRMnhPnz5wuJiYnCoUOHBEGQ7xp5m1deeUUYOHCgsHnzZuH48ePCrFmzhH79+gmFhYWCIPjvddE7c+aMxaqZoqIioX///sJTTz0lHD16VFi9erWQmppqsUy1S5cuwieffCJkZmYKCxcu9OplqhcuXBCuu+464Y477hAuXLhg8vmq54/XxZwnfEYyEFHYM888I3To0MHi/9u3bxcEQRAWLlwo+vrQoUNNjrN9+3Zh3LhxQmJionDNNdcIq1atsjjXsmXLhCFDhgiJiYnCzTffLKSnp7vlZ3SGvesiCIKQnZ0tzJw5U0hJSRH69OkjzJ8/X6iurjY5jq9dF2P79+8XZsyYIfTu3Vvo1q2bMGnSJGHDhg0mbeS6Rt6kqqpKmD9/vtCvXz+hW7duwvTp04WjR4+atPHH66InFogIgiAcOnRImDJlipCUlCQMHDhQdHnmb7/9JgwfPlxITEwUxowZY/H75k1WrVol+hnToUMHk3b+dl3EqP0ZqREEQXDf+AsRERFRHS7fJSIiItUwECEiIiLVMBAhIiIi1TAQISIiItUwECEiIiLVMBAhIiIi1TAQISIiItUwECEiIiLVMBAhIiIi1TAQISIiItUwECEiIiLVMBAhIiIi1fw/ZEfdIVMpr04AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sort_idxs = np.argsort(logprobs)\n",
    "sorted_logprobs = logprobs[sort_idxs]\n",
    "sorted_rewards = rewards[sort_idxs]\n",
    "\n",
    "plt.plot(sorted_logprobs, sorted_rewards)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "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.15"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
