{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import os\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "import matplotlib.font_manager as fm\n",
    "font_path = '/mnt/sda/2022-0526/home/gtyinstinct/fonts/timesbd.ttf'\n",
    "fm.fontManager.addfont(font_path)\n",
    "plt.rcParams['font.sans-serif'] = 'Times New Roman'\n",
    "\n",
    "# 定义文件路径\n",
    "file_path = \"/mnt/sda/2022-0526/home/xuhx/projects/gLLM/experiments/predict\"\n",
    "\n",
    "# 文件名\n",
    "file_names = [\n",
    "    \"14b_sharegpt.csv\",\n",
    "    \"14b_splitwise.csv\",\n",
    "    \"32b_sharegpt.csv\",\n",
    "    \"32b_splitwise.csv\"\n",
    "]\n",
    "\n",
    "# 创建空的列表来保存每个文件的数据\n",
    "accuracy_list = []\n",
    "\n",
    "# 读取每个文件并计算准确率\n",
    "for file_name in file_names:\n",
    "    file_full_path = os.path.join(file_path, file_name)\n",
    "    if os.path.exists(file_full_path):\n",
    "        df = pd.read_csv(file_full_path)\n",
    "        accuracy = (abs(df['predict_cost_ratio'] - df['cost_ratio']) == 0).mean()\n",
    "        # 解析模型和数据集类型\n",
    "        model, dataset = file_name.split('.')[0].split('_')\n",
    "        accuracy_list.append({\n",
    "            'model': model,         # 14b 或 32b\n",
    "            'dataset': dataset,     # sharegpt 或 splitwise\n",
    "            'accuracy': accuracy\n",
    "        })\n",
    "    else:\n",
    "        print(f\"File {file_name} does not exist.\")\n",
    "\n",
    "# 创建 DataFrame\n",
    "accuracy_df = pd.DataFrame(accuracy_list)\n",
    "\n",
    "# 设置配色：sharegpt 一种颜色，splitwise 一种颜色\n",
    "palette = {\n",
    "    'sharegpt': '#FCDBCB',   # 红色\n",
    "    'splitwise': '#8DC5FC'   # 蓝绿色\n",
    "}\n",
    "\n",
    "# 绘图\n",
    "fig, ax = plt.subplots(figsize=(3, 4))\n",
    "\n",
    "# 柱状图，hue 按 dataset 分组\n",
    "sns.barplot(\n",
    "    data=accuracy_df,\n",
    "    x='model',\n",
    "    y='accuracy',\n",
    "    hue='dataset',\n",
    "    palette=palette,\n",
    "    ax=ax,\n",
    "    edgecolor=\"black\",\n",
    "    linewidth=1,\n",
    "    width=0.7\n",
    ")\n",
    "\n",
    "# 设置标题和标签\n",
    "ax.set_xlabel('Model')\n",
    "ax.set_ylabel('Accuracy')\n",
    "ax.set_ylim(0, 1)\n",
    "ax.grid(True, linestyle='--', alpha=0.6)\n",
    "\n",
    "# 设置x轴标签\n",
    "plt.xticks(rotation=0)\n",
    "\n",
    "# 设置图例\n",
    "ax.legend(loc='upper right')\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "# 如需保存图形\n",
    "# fig.savefig('/mnt/data/accuracy_comparison.pdf', bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "509\n",
      "580\n"
     ]
    },
    {
     "data": {
      "image/png": "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C381XB3LPXbe6zyT/fv3qylTpiillMrPz1eLFy9W5eXlatq0aapjx45q165dKi4uTjVp0kRNmDDB8jpAxcfHK5PJpH799VdVdReNGzdOzZ8/3zI9YMAA9cYbb1i25+npqQwGg1JKqcWLF6ucnBxVWlqqFi1apPr27XvauJRS6plnnlHbtm1TSin15ZdfKm9vb1VQUFDtfa1YscKyrn379qnmzZsrpZRKT09XgMrMzFRKKfW///1PjRw50vK6p556SiUnJyullBo5cqTKy8tTSik1Y8YM1b9/f1VSUqLuv/9+FRERofbv36/eeeedc93lF9WxY0qFhyul/Vup3cLDtfn14XSf24oVK1R4eLj6888/VX5+vgoICFCbNm1SSinVqVMn9euvvyqllBoyZIh68cUXldFoVKtXr1aenp5q06ZNavny5So7O7vGz0QppebOnauWLFmilFJq7dq1yt3dXZWUlKiysjI1dOhQdd1116nY2Fj1zz//KA8PD/XMM88opZSaP3++Gjdu3GnfT9++fdWKFSuUUko99NBDauHChUoppV544QV10003KaW0v/ugoCC1bt06pZRSJpNJ3X///UoppY4ePaomT56slFLKYDCoRo0aqdWrV6usrCzl7e2tZs2apXbs2GF5/3aptFSpffuU2r375G3fPm1+PbicjqE33nhDffbZZ0oppbZt26Z++uknpZRSfn5+6ljFH2FkZKT64osvLN+Bbdq0Ubt371ZGo1G1b99ejRw5UqWkpKjU1FTl7OysDhw4oEpLS62eW79+vXJwcFAffvihUkqpLVu2qGbNmimllCorK1O33HKLKisrU0opdfPNN6v77ruvDj6pelReqlTOPqWydp+85ezT5teDy/F3MD8/3/IdVV5erubNm6eUOv33WHx8vALUO++8o8rKytRzzz2nwsLC1C+//KKU0o6bOXPmqPLycrVkyRLVvHlztX79epWWlqY6duyorr/+esu2mzVrprZs2VLrWCvVNoe6aEX9od6hrB62ml4relnmrR62mlDv+qkJcHd3Z/Xq1bRu3ZopU6Zw33334ejoiL+/Px06dLCcqTN9+nRefvnlaq93cHCw/FdwOmPHjmXVqlVMmzaNsrIyTCYT3377LXfccQcFBQWW/uaq16+qKS7Q/jt2c3Pj77//prCwkO7du5OWloaHh8dpt9+qVSs+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4eHhREVFERISIsXzlyi7Ssjuu+8+Jk+ezJQpU+jatetZlzeZTLz66quYzWYefvjhMy6bmZnJzz//zJgxY3BwcODll1/m//7v/+oqdCGEEOKMDAYDBw8etGrtiomJIS4ujhtvvJF169YBWqtXVlYWZrMZHx8fS2tX5X27du2s1jtlyhRbvB1Rx+wqIfP29uaVV15h4sSJHDx4kP79+xMZGUnjxo1p0KABRqORvLw8jh07xr59+9i5cydPPfUU995771nXXVBQwPz581m0aBG9e/dm5syZNG/evP7flBBCiCtKUVERBw8epKCggOuuuw7Q6r5CQkJOO5RTSkqK5bFOp+Pnn38mJCSExo0bS4vXFcKuEjLQkrK1a9eydetW3njjDZYvX47BYLBapnXr1owcOZJXX321xguP16R58+bnPbq/EEIIUZN//vmHffv2WbV4JSQkoJSiTZs2HDx4ENCSrDZt2nDkyJFqLV5RUVEEBgZarbdz5862eDvChuwuIat03XXXcd1112E2mzly5AhZWVm4ubkREhJCQECArcMTQghxhSgoKODAgQNER0eTnZ3NQw89ZHluwoQJ7Nmzp9prAgICaNq0qdUZkZs2bcLd3V1avESN7DYhq/Tpp59y4sQJZs+eTVZWFl999RXDhw+vdcuYEEIIcS6+/vprduzYYan1SkpKsjyn1+uZNWsWjo6OAPTp04eGDRtahpGIiooiIiKixoaDBg0aXLT3IC49dp2QPffcczz++OMMGDCA2bNn4+fnx+jRoxkxYgRLlizh6quvtnWIQgghLjG5ublWhfVHjx7l22+/tbRcffzxx3zxxRdWrwkKCrIkXQaDwTJE0/mOiSnEqew6IVuzZg3bt29n27Ztlnne3t4MHz6cSZMmsWvXLhtGJ4QQ4lLx/vvv89lnnxETE2NVQF8pKSnJMpzELbfcQkhIiKXGKyIigoYNG17skMUVxq4TsmuuuYaePXuyY8cOq/lJSUlER0fbKCohhBD2JCsri8OHD1sV1kdHR/PPP/8QFBQEwJEjR9i4caPlNU2aNLHqZqw6KPndd9992msdC1Ff7Doha9y4MWaz2aoA8ocffuD111+v1ThlQgghLh+V1xN2cXEB4O2332bevHmnHUoiJibGkpCNHDmS1q1bW1q8vL29L1bYQtSKXSdkU6dOZdy4cSQnJ5OQkMDff//N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Oh1bt24FoKSkhMmTJzNnzhxGjBjBgAED6rzOKycnhyVLltC8eXMSEhIwGo2sWbOG7t27s2rVKt5++22aNGlCWFgYv/32G4cOHaJXr164u7szY8YMq3Xt2bOH2bNnc/vttxMVFcWKFSssz73++uv079/fMp2VlcXzzz9PWFgYhw4dYvr06fj6+tK9e3cyMjJYt24dLVu2xNfXlw8//NDyugMHDjBp0iTmzp1Ly5YtGTlypFUM1113HatXryYnJ6dO95MQwg4pIcQV5eOPP1affvqpUkqpn376SQHqhx9+qLbc/fffrxYuXKiUUqqwsFC5u7urGTNmKKWUio+PV4DasmWLZfmnnnpKNWvWzDJ99OhRq2UWLFigrr32WqWUUiaTSYWEhKhHHnnEsvyKFStUbb+StmzZogC1YcMGq/lpaWlq8eLFClDx8fGqqKhI/fzzzwpQY8eOVZs3b1bJyckqKipKtWvXTr300ksqOTnZsu1du3YppZTKyspSEyZMsKz3ww8/VDqdTm3btk2lpKQoQP3444+W50+cOKEWLVqkADVv3jx14MABtXv3bqXX69XQoUPV6tWrVUZGhrr//vuVl5eXKisrU0opNXDgQPXff/8ppZRKTk5W99xzj9X7yc/PV4D6/PPPa7VfhBCXLmkhE+IK891333HbbbcBMGjQIJo3b857771ntUx8fDzvv/8+9913HwANGjRg1apVjB079rTrPbWW6tTpjh07Mm7cOMt048aNyczMvKD3cqrAwEC6dOlimXZ3d+f6668H4IYbbqBfv34EBwczdOhQCgoKmD17NsHBwYwZMwbQautAq4/Lysriueee47nnniM2Npb+/ftz7Ngx9u7da4m/UqNGjejatSsA48ePp23btnTq1IkOHTrg7+/P3Xffjb+/PyNGjCA/P5+0tDQAUlNTWbx4MQUFBQQHBzN+/Hir9+Pp6YmXlxd79uyp0/0khLA/UtQvxBXk0KFDHDhwgPvvv98yz8fHh3Xr1pGWlkajRo0A2L17N0op/Pz8LMud2p12rm699VYKCwt55ZVXyM3NpaioqMau0gt1ai2ak1P1rzk3Nzerab1eD0BZWRkA+/bto1u3bjz22GPVXlt5wkCDBg0ueDtPPvkkd911Fxs3buTRRx9l5syZ1dbRoEEDSwInhLh8SQuZEFeQ9957jy+//JKVK1dabt988w0mk4mVK1dalqtMHCpbjCoVFBSc97b37t3LgAEDGDRoEAsWLLAkf/aotLSUv//+u9r8zMxMS5JlNBoveDujR49m3759XHvttTz66KPccMMN1ZJUnU5X58NqCCHsjyRkQlwhSkpKOHLkCC1atLCaHxoaSp8+fVi+fDlKKQCioqIAePvtty3LKaVYtWoVoCUJp3JxcaG4uNgyXZlYVN5PnTqV3r17ExERUYfvqn5ERUXx9ddfW3UVxsfHs2nTJkJCQgDIy8u74O189dVXtGnThu+++4533nmHbdu2VeueLCgooGnTphe8LSGEfZOETIgrxKpVq+jVq1eNz910000cPnyYn376CYAWLVowcuRI3nnnHWbNmsVHH33EyJEjLWOFVXbXHTp0iE2bNlFYWEiLFi1IT0/niy++4Pfff+fll18GtO7P9PR0SkpK+OWXX4iNjWX16tXExcWRlpbGxo0bASyj3ddm1PvKxK9qAljp1PXUtF6z2WzVElWZiFYuM336dFxdXenfvz9PP/00S5cuZfLkydx6661cffXVeHh4cOzYsTNutzbbef311y11dKNHj8bV1dVqKI2cnBwKCgro1q3bWfeJEOISZ9NTCoQQF8Unn3yiGjZsqHr27Kl27Nhh9dz+/ftV//79FaCaNm1qOQMzNzdXjRkzRrm7u6vWrVurtWvXWr1u4sSJysfHR73xxhtKKaVKS0vVzTffrNzc3NS4ceNUTEyMCg0NVc8++6zKzMxUP/zwgwoICFAtW7ZU33zzjXrkkUdUcHCw2rp1qzp48KAlhqefflrl5OSc9r388ssvauDAgQpQAwYMUOvXr7c8l5iYqG6//XYFqAcffFAdP35cLVy40LLsnj171Pbt21X79u2Vk5OTWrZsmUpPT1dPPfWUAlT//v1VdHS0Ukqpbdu2qauvvlq5ubmp6667Th09etSynbFjx6rHHnvMMp2QkKBGjx6tADVz5kyVkpKiPvroI+Xh4aGaNWum1q1bp2JjY9WIESMUoKZPn64yMjJUmzZtVJMmTdRDDz2kJkyYoNatW2f1Xrds2aICAwOV0Wg8h09bCHEp0ilV8S+bEEKIWtm/fz/jxo2rsc6sLj366KMEBgby8MMP1+t2hBC2J12WQghxjtq1a8fQoUP58ssv620bubm5/PvvvzWeeSmEuPxIQiaEEOdhwYIF/P333xw9erTO1200Glm8eDGrV6/G2dm5ztcvhLA/0mUphBAX4Mcff2TQoEF1OjTF+vXr6dGjB56ennW2TiGEfZOETAghhBDCxqTLUgghhBDCxiQhE0IIIYSwMUnIhBBCCCFsTBIyIYQQQggbk4RMCCGEEMLGJCETQgghhLAxSciEEEIIIWzs/wGkwBhfxJrdHAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 600x100 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# Load the two CSV files\n",
    "df_sharegpt = pd.read_csv('/mnt/sda/2022-0526/home/xuhx/projects/gLLM/experiments/predict/14b_sharegpt.csv')\n",
    "df_splitwise = pd.read_csv('/mnt/sda/2022-0526/home/xuhx/projects/gLLM/experiments/predict/14b_splitwise.csv')\n",
    "# 随机过滤掉一半的点（random_state保证可复现，去掉则每次都不同）\n",
    "df_sharegpt = df_sharegpt.sample(frac=0.035, random_state=42) # 0.075\n",
    "print(len(df_sharegpt))\n",
    "df_splitwise = df_splitwise.sample(frac=0.05, random_state=42) # 0.05\n",
    "print(len(df_splitwise))\n",
    "# Extract relevant columns for both dataframes\n",
    "x_sharegpt = df_sharegpt['each_layer_time']\n",
    "y_sharegpt = df_sharegpt['predict_layer_time']\n",
    "x_splitwise = df_splitwise['each_layer_time']\n",
    "y_splitwise = df_splitwise['predict_layer_time']\n",
    "\n",
    "# 新增 sample_time 和 predict_sample_time\n",
    "x_sharegpt_sample = df_sharegpt['sample_time']\n",
    "y_sharegpt_sample = df_sharegpt['predict_sample_time']\n",
    "x_splitwise_sample = df_splitwise['sample_time']\n",
    "y_splitwise_sample = df_splitwise['predict_sample_time']\n",
    "\n",
    "plt.figure(figsize=(6, 1))\n",
    "# 原有点\n",
    "\n",
    "\n",
    "plt.scatter(x_splitwise, y_splitwise, color='green', marker='x', label='splitwise layer', alpha=1,s=20)\n",
    "plt.scatter(x_sharegpt, y_sharegpt, color='blue',  marker='x',label='sharegpt layer', alpha=1,s=20)\n",
    "# 新增点\n",
    "plt.scatter(x_sharegpt_sample, y_sharegpt_sample, color='red', marker='x', label='sharegpt sample', alpha=0.2,s=20)\n",
    "plt.scatter(x_splitwise_sample, y_splitwise_sample, color='orange', marker='x', label='splitwise sample', alpha=0.2,s=20)\n",
    "\n",
    "plt.xlabel('Actual Time(ms)', fontsize=12)\n",
    "plt.ylabel('Predict Time(ms)', fontsize=12)\n",
    "# plt.xlim(0, 5)\n",
    "# plt.ylim(0, 5)\n",
    "plt.legend(loc='upper center', bbox_to_anchor=(0.5, 1.5), ncol=4)  # 新增：图例放在上方一行\n",
    "plt.plot([0, 5], [0, 5], color='black', linestyle='--', label='y=x')\n",
    "plt.grid(True)\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "gllm",
   "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.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
