{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "os.environ[\"PATH\"] += os.pathsep + '/usr/local/texlive/2023/bin/universal-darwin/'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib as mpl\n",
    "import matplotlib.pyplot as plt\n",
    "import pandas as pd\n",
    "import json\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "mpl.rcParams.update(mpl.rcParamsDefault)\n",
    "\n",
    "\n",
    "plt.rcParams['font.family'] = 'serif'\n",
    "plt.rcParams['font.serif'] = ['Times New Roman'] + plt.rcParams['font.serif']\n",
    "plt.rcParams.update({'text.usetex': True\n",
    "                     })\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Asymetric Fit"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def asymmetric_fit(sumlosses, neglogpassuntils, alpha=10):\n",
    "    ziped_loss_pass = list(zip(sumlosses.reshape(-1), neglogpassuntils.reshape(-1)))\n",
    "\n",
    "    ziped_non_inf = []\n",
    "    for l, p in ziped_loss_pass:\n",
    "        if not np.isinf(p):\n",
    "            ziped_non_inf.append([l,p])\n",
    "    \n",
    "    ziped_non_inf = np.array(ziped_non_inf)\n",
    "    \n",
    "    x = ziped_non_inf[:, 0:1]\n",
    "    y = ziped_non_inf[:, 1:]\n",
    "\n",
    "\n",
    "    from scipy.optimize import minimize\n",
    "    def asymmetric_loss(params, x, y):\n",
    "        \"\"\"\n",
    "        Custom asymmetric loss function.\n",
    "        \n",
    "        Parameters:\n",
    "            params (list): Parameters [slope, intercept] of the line\n",
    "            x (numpy.ndarray): The independent variable\n",
    "            y (numpy.ndarray): The dependent variable\n",
    "            alpha (float): Penalty factor for points on the left side (y < f(x))\n",
    "            \n",
    "        Returns:\n",
    "            float: The loss value\n",
    "        \"\"\"\n",
    "        slope, = params\n",
    "        y_pred = slope * x\n",
    "        residuals = y - y_pred\n",
    "        \n",
    "        # Higher penalty for points on the left side (y < f(x))\n",
    "        loss = np.where(residuals < 0, alpha * np.abs(residuals), np.abs(residuals)).sum()\n",
    "        return loss\n",
    "\n",
    "    # Initial guess for slope and intercept\n",
    "    initial_params = [0, ]\n",
    "\n",
    "    # Optimize the custom loss function\n",
    "    opt_result = minimize(asymmetric_loss, initial_params, args=(y, x), method='L-BFGS-B')\n",
    "\n",
    "    # Extract optimized parameters\n",
    "    opt_slope, = opt_result.x\n",
    "    # opt_slope, opt_intercept, opt_result.fun\n",
    "\n",
    "    y_fit = np.linspace(np.min(y), np.max(y)+0.5, 100)\n",
    "    # print(y_fit)\n",
    "    x_pred = np.array([opt_slope * _y for _y in y_fit])\n",
    "    return x_pred, y_fit, 1/opt_slope"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "def fit_pass_with_loss_RANSAC(sumlosses, neglogpassuntils):\n",
    "    ziped_loss_pass = list(zip(sumlosses.reshape(-1), neglogpassuntils.reshape(-1)))\n",
    "\n",
    "    from sklearn.linear_model import RANSACRegressor, LinearRegression\n",
    "\n",
    "    ziped_non_inf = []\n",
    "    for l, p in ziped_loss_pass:\n",
    "        if not np.isinf(p):\n",
    "            ziped_non_inf.append([l,p])\n",
    "    \n",
    "    ziped_non_inf = np.array(ziped_non_inf)\n",
    "    # print(ziped_non_inf)\n",
    "\n",
    "    linear_model = LinearRegression(fit_intercept=False)\n",
    "    linear_model.fit(ziped_non_inf[:, 1:], ziped_non_inf[:,0:1])\n",
    "    # 提取拟合参数\n",
    "    print( linear_model.coef_)\n",
    "    a = linear_model.coef_[0][0]\n",
    "\n",
    "\n",
    "    # 使用拟合参数生成拟合线\n",
    "    y_fit = np.linspace(np.min(ziped_non_inf[:, 1]), np.max(ziped_non_inf[:, 1])+0.5, 100)\n",
    "    # print(y_fit)\n",
    "    x_fit = linear_model.predict(y_fit.reshape(-1, 1))\n",
    "\n",
    "    return x_fit, y_fit, 1/a\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## OpenFile"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd \n",
    "df = pd.read_excel(\"./infer_res_5/0908result.xlsx\", sheet_name=\"pass_until\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "np.set_printoptions(suppress=True, precision=3)\n",
    "sizelist = [0.03, 0.1, 0.2, 0.5, 0.9, 1.5]\n",
    "\n",
    "def lookinto(lookinto_id):\n",
    "    all_tokens_loss = []\n",
    "    all_tokens_loss_sum = []\n",
    "    all_tokens_loss_mean = []\n",
    "\n",
    "    first_non_zero = -1\n",
    "    for size in sizelist:\n",
    "        res_list = [json.loads(line.strip()) for line in open(f\"./infer_res_5/{size}b/{size}b_res_dict.jsonl\")]\n",
    "        loss = res_list[lookinto_id]['tokens_loss']\n",
    "        if first_non_zero < 0:\n",
    "            for i, l in enumerate(loss):\n",
    "                if l > 0.0:\n",
    "                    first_non_zero = i\n",
    "                    break\n",
    "        # loss = loss[first_non_zero-1:]\n",
    "        all_tokens_loss.append(np.array(loss).reshape(1, -1))\n",
    "        all_tokens_loss_sum.append((np.array(loss)**1).sum())\n",
    "        all_tokens_loss_mean.append((np.array(loss)**1).mean())\n",
    "\n",
    "\n",
    "    all_tokens_loss = np.concatenate(all_tokens_loss, axis=0)\n",
    "    # print(all_tokens_loss)\n",
    "    # print(all_tokens_loss_sum)\n",
    "\n",
    "\n",
    "    # res = res_list[lookinto_id]\n",
    "    # print(res)\n",
    "\n",
    "    # print(list(df.iloc[lookinto_id]))\n",
    "\n",
    "    return all_tokens_loss_sum, all_tokens_loss_mean, list(df.iloc[lookinto_id])\n",
    "\n",
    "\n",
    "sumlosses, passuntils =[], []\n",
    "meanlosses = []\n",
    "for i in range(0, 164):\n",
    "    # print(\"=====\" + str(i) + \"=====\")\n",
    "    sumloss, meanloss, passuntil = lookinto(i)\n",
    "    sumlosses.append(sumloss)\n",
    "    meanlosses.append(meanloss)\n",
    "    passuntils.append(passuntil)\n",
    "    # a = list(zip(loss, passuntil))\n",
    "    # all_align.append(a)\n",
    "    # print(all_align)\n",
    "sumlosses = np.array(sumlosses)\n",
    "meanlosses = np.array(meanlosses)\n",
    "passuntils = np.array(passuntils)\n",
    "# print(list(zip(*all_align)))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Fit"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/jq/j1z91stx47z_k2bkqs12nqk40000gn/T/ipykernel_36111/162215654.py:1: RuntimeWarning: divide by zero encountered in log\n",
      "  neglogpassuntils = -np.log(passuntils)\n"
     ]
    },
    {
     "ename": "NameError",
     "evalue": "name 'fit_pass_with_loss_RANSAC' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[6], line 12\u001b[0m\n\u001b[1;32m      9\u001b[0m     ax[\u001b[39m1\u001b[39m]\u001b[39m.\u001b[39mscatter(sumlosses[:, i], neglogpassuntils[:, i], marker\u001b[39m=\u001b[39m\u001b[39m'\u001b[39m\u001b[39mo\u001b[39m\u001b[39m'\u001b[39m, s\u001b[39m=\u001b[39m\u001b[39m30\u001b[39m, c\u001b[39m=\u001b[39mcolorlist[i], label\u001b[39m=\u001b[39m\u001b[39mf\u001b[39m\u001b[39m\"\u001b[39m\u001b[39m{\u001b[39;00msizelist[i]\u001b[39m}\u001b[39;00m\u001b[39mb\u001b[39m\u001b[39m\"\u001b[39m)\n\u001b[1;32m     10\u001b[0m     ax[\u001b[39m0\u001b[39m]\u001b[39m.\u001b[39mscatter(meanlosses[:, i], neglogpassuntils[:, i], marker\u001b[39m=\u001b[39m\u001b[39m'\u001b[39m\u001b[39mo\u001b[39m\u001b[39m'\u001b[39m, s\u001b[39m=\u001b[39m\u001b[39m30\u001b[39m, c\u001b[39m=\u001b[39mcolorlist[i], label\u001b[39m=\u001b[39m\u001b[39mf\u001b[39m\u001b[39m\"\u001b[39m\u001b[39m{\u001b[39;00msizelist[i]\u001b[39m}\u001b[39;00m\u001b[39mb\u001b[39m\u001b[39m\"\u001b[39m)\n\u001b[0;32m---> 12\u001b[0m x_fit, y_fit, slope1 \u001b[39m=\u001b[39m fit_pass_with_loss_RANSAC(sumlosses, neglogpassuntils)\n\u001b[1;32m     13\u001b[0m \u001b[39m# print(x_fit, y_fit,)\u001b[39;00m\n\u001b[1;32m     14\u001b[0m \u001b[39mprint\u001b[39m(slope1)\n",
      "\u001b[0;31mNameError\u001b[0m: name 'fit_pass_with_loss_RANSAC' is not defined"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 2000x800 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "neglogpassuntils = -np.log(passuntils)\n",
    "fig, ax = plt.subplots(1,2, figsize=(20, 8))\n",
    "\n",
    "sizelist = [0.03, 0.1, 0.2, 0.5, 0.9, 1.5]\n",
    "colorlist = ['#FA7F6F', '#82B0D2',  '#8ECFC9', '#FFBE7A', '#BEB8DC', '#999999', \"#FA7F6F\"]\n",
    "\n",
    "for i in range(6):\n",
    "    # ax.scatter(allloss, allpassuntil, marker='o', s=2, label=str(i))\n",
    "    ax[1].scatter(sumlosses[:, i], neglogpassuntils[:, i], marker='o', s=30, c=colorlist[i], label=f\"{sizelist[i]}b\")\n",
    "    ax[0].scatter(meanlosses[:, i], neglogpassuntils[:, i], marker='o', s=30, c=colorlist[i], label=f\"{sizelist[i]}b\")\n",
    "\n",
    "x_fit, y_fit, slope1 = fit_pass_with_loss_RANSAC(sumlosses, neglogpassuntils)\n",
    "# print(x_fit, y_fit,)\n",
    "print(slope1)\n",
    "ax[1].plot(x_fit, y_fit, c=colorlist[-1], linestyle=\"--\", label=f\"$-log(p)={slope1:.2f}s$\")\n",
    "\n",
    "# x_fit_q, y_fit_q, slope2 = asymmetric_fit(sumlosses, neglogpassuntils)\n",
    "# print(x_fit_q, y_fit_q)\n",
    "# print(slope2)\n",
    "# ax[1].plot(x_fit_q, y_fit_q, c=\"#2878B5\", linestyle=\"--\", label=f\"$-log(p)={slope2:.2f}s$\")\n",
    "\n",
    "\n",
    "# Set labels and title\n",
    "ax[1].set_xlabel('Test Loss Sum', fontsize=18, fontweight='bold')\n",
    "ax[0].set_xlabel('Average Test Loss per Token', fontsize=18, fontweight='bold')\n",
    "ax[0].set_ylabel('Negative Log PassUntil', fontsize=18, fontweight='bold')\n",
    "ax[1].legend(fontsize=14)\n",
    "ax[0].legend(fontsize=14)\n",
    "# ax.set_title('Improved Scientific Plot', fontsize=16, fontweight='bold')\n",
    "\n",
    "# Add grid\n",
    "ax[1].grid(True, linestyle='--', linewidth=0.5, color='gray')\n",
    "ax[0].grid(True, linestyle='--', linewidth=0.5, color='gray')\n",
    "\n",
    "new_font_size = 16\n",
    "ax[1].tick_params(axis='x', labelsize=new_font_size)\n",
    "ax[1].tick_params(axis='y', labelsize=new_font_size)\n",
    "ax[0].tick_params(axis='x', labelsize=new_font_size)\n",
    "ax[0].tick_params(axis='y', labelsize=new_font_size)\n",
    "# plt.show()\n",
    "\n",
    "plt.savefig(\"nlpassuntil_vs_test_loss.pdf\",bbox_inches='tight', pad_inches=0)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.6.9 64-bit",
   "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.9.6"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "31f2aee4e71d21fbe5cf8b01ff0e069b9275f58929596ceb00d14d90e3e16cd6"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
