{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 300x200 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, 2))\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",
    "handles, labels = ax.get_legend_handles_labels()\n",
    "labels = ['ShareGPT', 'Azure-Conv']  # Custom legend labels\n",
    "ax.legend(handles=handles, labels=labels, loc='center', bbox_to_anchor=(0.5, 1.15), ncol=2, columnspacing=1)\n",
    "\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": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "平均准确率：0.7715\n"
     ]
    }
   ],
   "source": [
    "# 计算平均准确率\n",
    "mean_accuracy = accuracy_df['accuracy'].mean()\n",
    "print(f\"平均准确率：{mean_accuracy:.4f}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "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.01, random_state=42) # 0.075\n",
    "# print(len(df_sharegpt))\n",
    "# df_splitwise = df_splitwise.sample(frac=0.01, 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",
    "# s1 = 100\n",
    "# s2 = 60\n",
    "# lw = 1\n",
    "# plt.scatter(x_splitwise, y_splitwise, color='#C494FB', marker='1', label='Layer (A)', s=s1, linewidths=lw)\n",
    "# plt.scatter(x_sharegpt, y_sharegpt, color='#264CFF',  marker='1', label='Layer (S)', s=s1, linewidths=lw)\n",
    "\n",
    "# # 新增点\n",
    "# plt.scatter(x_splitwise_sample, y_splitwise_sample, color='#003A1D', marker='x', label='Sample (S)', s=s2, linewidths=lw)\n",
    "# plt.scatter(x_sharegpt_sample, y_sharegpt_sample, color='#999900', marker='x', label='Sample (A)', s=s2, linewidths=lw)\n",
    "\n",
    "\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, columnspacing=0)  # 新增：图例放在上方一行\n",
    "# plt.plot([0, 5], [0, 5], color='black', linestyle='--', label='y=x')\n",
    "# plt.grid(True)\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "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/32b_sharegpt.csv')\n",
    "# df_splitwise = pd.read_csv('/mnt/sda/2022-0526/home/xuhx/projects/gLLM/experiments/predict/32b_splitwise.csv')\n",
    "# # 随机过滤掉一半的点（random_state保证可复现，去掉则每次都不同）\n",
    "# df_sharegpt = df_sharegpt.sample(frac=0.01, random_state=42) # 0.075\n",
    "# print(len(df_sharegpt))\n",
    "# df_splitwise = df_splitwise.sample(frac=0.01, 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=(4.5, 1))\n",
    "# # 原有点\n",
    "\n",
    "# s1 = 100\n",
    "# s2 = 60\n",
    "# lw = 1\n",
    "# plt.scatter(x_splitwise, y_splitwise, color='#C494FB', marker='1', label='Layer (A)', s=s1, linewidths=lw)\n",
    "# plt.scatter(x_sharegpt, y_sharegpt, color='#264CFF',  marker='1', label='Layer (S)', s=s1, linewidths=lw)\n",
    "\n",
    "# # 新增点\n",
    "# plt.scatter(x_splitwise_sample, y_splitwise_sample, color='#003A1D', marker='x', label='Sample (S)', s=s2, linewidths=lw)\n",
    "# plt.scatter(x_sharegpt_sample, y_sharegpt_sample, color='#999900', marker='x', label='Sample (A)', s=s2, linewidths=lw)\n",
    "\n",
    "\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, columnspacing=0)  # 新增：图例放在上方一行\n",
    "# plt.plot([0, 5], [0, 5], color='black', linestyle='--')\n",
    "# plt.grid(True)\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_2143606/2658263791.py:98: UserWarning: Tight layout not applied. The bottom and top margins cannot be made large enough to accommodate all Axes decorations.\n",
      "  plt.tight_layout()\n"
     ]
    },
    {
     "data": {
      "image/png": "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neTkZAD69u2Ll5eX2bGBgYF88cUXGAyG/L2QUuVU2n0/pIer6P2jQkJCBCCWLl360ON8fX3FN998I4QQ4s8//xSAOHv2rBBCiODgYKFSqcSmTZtMx4eFhYlnnnnG9HjkyJGmPochISFCo9GId999V9y4cUO88MILAhCffPKJWLZsmZg1a1aO64eGhgpA/P7777nWLyUlxXQ9nU4nvLy8xFNPPZXn85k6darw8/N76HMuDyrC+/frr78KJycnAYh69eqJP/74I9fnsGXLFqEoiggPD3/Eq/JwsakZIiwxzfg8E9NEbGpGkcorjMzMTDF+/HgBCEA888wz4vbt22bHBAYGijfffFMIIcTFixcFIH777TeRnJwstm3bJgAxdOhQsWvXLnHnzh3h7+8vGjVqJObNmyfu3Lkjli9fLgBx+PBhERMTI9asWSMAMWTIELFjxw6xefNmYW9vL1q2bGnqO7t7926zPqvR0dFm/WhXr14tFEUR+/bty/GcdDqdsLGxEV999VWez7t///6m79u0aSNatWqV57FffPGFcHR0LPJ4gujUaHEn8Y4QQog7iXdEdGp0kcorjMr2fh84cEB4eXkJQHh6eoo1a9bk+rqcPn3aVOe8VPTPYOnRZItyJZZ89hyhixaji40ldNFiks+W3VHATzzxBIGBgQCm/qRRUVEA+Pv707dvX7755hvT8evXr+fZZ58FYP/+/Zw8eZLFixfz0UcfsWHDBnr27El8fDw1atSgZcuWADz33HOMHTuWuXPn5rh+1q35rGs/6IcffmDYsGGA8XbiuHHj+PXXX4mMjMz1eG9vb86dO1e0GTBuH4PtsyE5yvjv7WOFL6uEleX373//+x9nz55l8ODBXLp0id69ezNp0qQcrUze3t4IITh16lSRXot0nYHPDoZwOjyRzw6GkK7771uzNBoN3377Ldu2baNOnTps2LCBRo0a8eeff5qO6datG48//jhg/p7Z2NjQrVs3wNhFoWvXrnh6etK3b18SExOZOnUqnp6eDBkyBIBLly7h7OxM+/btARgxYgTdunWjf//+TJkyhaNHj3LixIlc67l48WKio6P56KOP+Oijj7h06RJBQUG5dlu6cuUKKSkpef6O7tmzx1RvgAkTJnDkyJEc3W6yeHt7Ex8fT0hIyENfy0dJ06Ux+5/ZHA07yux/ZpOmS3v0ScWssr3f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",
      "text/plain": [
       "<Figure size 840x100 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.font_manager as fm\n",
    "\n",
    "# 设置字体\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",
    "plt.rcParams['font.size'] = 12\n",
    "\n",
    "# 定义统一配色方案\n",
    "# colors = {\n",
    "#     'Layer_A': '#C494FB',\n",
    "#     'Layer_S': '#264CFF',\n",
    "#     'Sample_S': '#003A1D',\n",
    "#     'Sample_A': '#999900',\n",
    "#     'Ref_line': 'black'\n",
    "# }\n",
    "colors = {\n",
    "    'Layer_A': '#cf3439',\n",
    "    'Layer_S':  '#ff7f0e',\n",
    "    'Sample_S': '#2ca02c',\n",
    "    'Sample_A': '#44a2ca',\n",
    "    'Ref_line': 'black'\n",
    "}\n",
    "\n",
    "# 加载 14B 数据\n",
    "df_sharegpt_14b = pd.read_csv('/mnt/sda/2022-0526/home/xuhx/projects/gLLM/experiments/predict/14b_sharegpt.csv')\n",
    "df_splitwise_14b = pd.read_csv('/mnt/sda/2022-0526/home/xuhx/projects/gLLM/experiments/predict/14b_splitwise.csv')\n",
    "df_sharegpt_14b = df_sharegpt_14b.sample(frac=1, random_state=42)\n",
    "df_splitwise_14b = df_splitwise_14b.sample(frac=1, random_state=42)\n",
    "\n",
    "# 提取数据\n",
    "x_sharegpt_14b = df_sharegpt_14b['each_layer_time']\n",
    "y_sharegpt_14b = df_sharegpt_14b['predict_layer_time']\n",
    "x_splitwise_14b = df_splitwise_14b['each_layer_time']\n",
    "y_splitwise_14b = df_splitwise_14b['predict_layer_time']\n",
    "x_sharegpt_sample_14b = df_sharegpt_14b['sample_time']\n",
    "y_sharegpt_sample_14b = df_sharegpt_14b['predict_sample_time']\n",
    "x_splitwise_sample_14b = df_splitwise_14b['sample_time']\n",
    "y_splitwise_sample_14b = df_splitwise_14b['predict_sample_time']\n",
    "\n",
    "# 加载 32B 数据\n",
    "df_sharegpt_32b = pd.read_csv('/mnt/sda/2022-0526/home/xuhx/projects/gLLM/experiments/predict/32b_sharegpt.csv')\n",
    "df_splitwise_32b = pd.read_csv('/mnt/sda/2022-0526/home/xuhx/projects/gLLM/experiments/predict/32b_splitwise.csv')\n",
    "df_sharegpt_32b = df_sharegpt_32b.sample(frac=1, random_state=42)\n",
    "df_splitwise_32b = df_splitwise_32b.sample(frac=1, random_state=42)\n",
    "\n",
    "x_sharegpt_32b = df_sharegpt_32b['each_layer_time']\n",
    "y_sharegpt_32b = df_sharegpt_32b['predict_layer_time']\n",
    "x_splitwise_32b = df_splitwise_32b['each_layer_time']\n",
    "y_splitwise_32b = df_splitwise_32b['predict_layer_time']\n",
    "x_sharegpt_sample_32b = df_sharegpt_32b['sample_time']\n",
    "y_sharegpt_sample_32b = df_sharegpt_32b['predict_sample_time']\n",
    "x_splitwise_sample_32b = df_splitwise_32b['sample_time']\n",
    "y_splitwise_sample_32b = df_splitwise_32b['predict_sample_time']\n",
    "\n",
    "# 创建图像\n",
    "fig, axes = plt.subplots(1, 2, figsize=(8.4, 1))\n",
    "\n",
    "s1, s2, lw = 10, 6, 0.5\n",
    "\n",
    "# --- 画 14B 子图 ---\n",
    "axes[0].scatter(x_splitwise_14b, y_splitwise_14b, color=colors['Layer_A'], marker='1', label='Layer (A)', s=s1, linewidths=lw)\n",
    "axes[0].scatter(x_sharegpt_14b, y_sharegpt_14b, color=colors['Layer_S'], marker='1', label='Layer (S)', s=s1, linewidths=lw)\n",
    "axes[0].scatter(x_splitwise_sample_14b, y_splitwise_sample_14b, color=colors['Sample_S'], marker='x', label='Sample (S)', s=s2, linewidths=lw)\n",
    "axes[0].scatter(x_sharegpt_sample_14b, y_sharegpt_sample_14b, color=colors['Sample_A'], marker='x', label='Sample (A)', s=s2, linewidths=lw)\n",
    "\n",
    "axes[0].set_xlim(0, 4)\n",
    "axes[0].set_ylim(0, 4)\n",
    "axes[0].plot([0, 4], [0, 4], color=colors['Ref_line'], linestyle='--')\n",
    "axes[0].grid(True)\n",
    "\n",
    "# 设置 legend 顺序\n",
    "handles, labels = axes[0].get_legend_handles_labels()\n",
    "new_order = [0, 1, 3, 2]\n",
    "handles = [handles[i] for i in new_order]\n",
    "labels = [labels[i] for i in new_order]\n",
    "axes[0].legend(handles, labels, loc='upper center', bbox_to_anchor=(1, 1.78), ncol=4, columnspacing=0)\n",
    "\n",
    "# --- 画 32B 子图 ---\n",
    "axes[1].scatter(x_splitwise_32b, y_splitwise_32b, color=colors['Layer_A'], marker='1', label='Layer (A)', s=s1, linewidths=lw)\n",
    "axes[1].scatter(x_sharegpt_32b, y_sharegpt_32b, color=colors['Layer_S'], marker='1', label='Layer (S)', s=s1, linewidths=lw)\n",
    "axes[1].scatter(x_splitwise_sample_32b, y_splitwise_sample_32b, color=colors['Sample_S'], marker='x', label='Sample (S)', s=s2, linewidths=lw)\n",
    "axes[1].scatter(x_sharegpt_sample_32b, y_sharegpt_sample_32b, color=colors['Sample_A'], marker='x', label='Sample (A)', s=s2, linewidths=lw)\n",
    "\n",
    "axes[1].set_xlim(0, 5)\n",
    "axes[1].set_ylim(0, 5)\n",
    "axes[1].plot([0, 5], [0, 5], color=colors['Ref_line'], linestyle='--')\n",
    "axes[1].grid(True)\n",
    "\n",
    "# 设置标签\n",
    "axes[0].set_xlabel('Actual Time(ms)\\n(a) Qwen2.5-14B', fontsize=12)\n",
    "axes[0].set_ylabel('Predict Time(ms)', fontsize=12)\n",
    "axes[1].set_xlabel('Actual Time(ms)\\n(b) Qwen2.5-32B', fontsize=12)\n",
    "axes[1].set_ylabel('Predict Time(ms)', fontsize=12)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig('predict_time_comparison.pdf', bbox_inches=\"tight\")\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import pandas as pd\n",
    "# import os\n",
    "# import matplotlib.pyplot as plt\n",
    "# import seaborn as sns\n",
    "# import matplotlib.font_manager as fm\n",
    "\n",
    "# # 设置字体\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",
    "# plt.rcParams['font.size'] = 12\n",
    "# # 设置文件路径和文件名\n",
    "# file_path = \"/mnt/sda/2022-0526/home/xuhx/projects/gLLM/experiments/predict\"\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",
    "# 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 = ((df['predict_cost_ratio'] - df['cost_ratio']).abs().isin([0,1])).mean()\n",
    "#         model, dataset = file_name.split('.')[0].split('_')\n",
    "#         accuracy_list.append({'model': model, 'dataset': dataset, 'accuracy': accuracy})\n",
    "#     else:\n",
    "#         print(f\"File {file_name} does not exist.\")\n",
    "# accuracy_df = pd.DataFrame(accuracy_list)\n",
    "\n",
    "# # 准备散点图数据\n",
    "# def load_and_sample(filename):\n",
    "#     df = pd.read_csv(os.path.join(file_path, filename))\n",
    "#     return df.sample(frac=0.01, random_state=42)\n",
    "\n",
    "# df_sharegpt_14b = load_and_sample('14b_sharegpt.csv')\n",
    "# df_splitwise_14b = load_and_sample('14b_splitwise.csv')\n",
    "# df_sharegpt_32b = load_and_sample('32b_sharegpt.csv')\n",
    "# df_splitwise_32b = load_and_sample('32b_splitwise.csv')\n",
    "\n",
    "# # 创建三图并排画布\n",
    "# fig, axes = plt.subplots(1, 3, figsize=(12, 3))  # 一行三列\n",
    "\n",
    "# # 图1: 准确率柱状图\n",
    "# palette = {'sharegpt': '#FCDBCB', 'splitwise': '#8DC5FC'}\n",
    "# sns.barplot(\n",
    "#     data=accuracy_df,\n",
    "#     x='model',\n",
    "#     y='accuracy',\n",
    "#     hue='dataset',\n",
    "#     palette=palette,\n",
    "#     ax=axes[0],\n",
    "#     edgecolor=\"black\",\n",
    "#     linewidth=1,\n",
    "#     width=0.7\n",
    "# )\n",
    "# axes[0].set_xlabel('Model')\n",
    "# axes[0].set_ylabel('Accuracy')\n",
    "# axes[0].set_ylim(0.9, 1)\n",
    "# axes[0].grid(True, linestyle='--', alpha=0.6)\n",
    "# # axes[0].legend(['ShareGPT', 'Azure-Conv'], loc='upper center', bbox_to_anchor=(0.5, 1.15), ncol=2, columnspacing=1)\n",
    "# handles, labels = axes[0].get_legend_handles_labels()\n",
    "# labels = ['ShareGPT', 'Azure-Conv']  # Custom legend labels\n",
    "# axes[0].set_xticklabels(['14B', '32B']) # 设置x轴标签\n",
    "# axes[0].legend(handles=handles, labels=labels, loc='center', bbox_to_anchor=(0.5, 1.15), ncol=2, columnspacing=1)\n",
    "\n",
    "# # 通用绘图函数（x轴标题由参数传入）\n",
    "# def scatter_plot(ax, df_splitwise, df_sharegpt, xlabel_text):\n",
    "#     s1, s2, lw = 100, 60, 1\n",
    "#     ax.scatter(df_splitwise['each_layer_time'], df_splitwise['predict_layer_time'], color='#C494FB', marker='1', label='Layer (A)', s=s1, linewidths=lw)\n",
    "#     ax.scatter(df_sharegpt['each_layer_time'], df_sharegpt['predict_layer_time'], color='#264CFF', marker='1', label='Layer (S)', s=s1, linewidths=lw)\n",
    "#     ax.scatter(df_sharegpt['sample_time'], df_sharegpt['predict_sample_time'], color='#999900', marker='x', label='Sample (A)', s=s2, linewidths=lw)\n",
    "#     ax.scatter(df_splitwise['sample_time'], df_splitwise['predict_sample_time'], color='#003A1D', marker='x', label='Sample (S)', s=s2, linewidths=lw)\n",
    "#     ax.plot([0, 5], [0, 5], color='black', linestyle='--')\n",
    "#     ax.set_xlim(0, 5)\n",
    "#     ax.set_ylim(0, 5)\n",
    "#     ax.set_yticks([0, 1, 2, 3, 4, 5])  # 手动设置刻度\n",
    "#     ax.set_xlabel(xlabel_text)\n",
    "#     ax.set_ylabel('Predict Time(ms)')\n",
    "#     ax.grid(True)\n",
    "\n",
    "\n",
    "# # 图2: 14B\n",
    "# scatter_plot(axes[1], df_splitwise_14b, df_sharegpt_14b, 'Actual Time on 14B (ms)')\n",
    "\n",
    "# # 图3: 32B\n",
    "# scatter_plot(axes[2], df_splitwise_32b, df_sharegpt_32b, 'Actual Time on 32B (ms)')\n",
    "\n",
    "# # 图例\n",
    "# # axes[0].legend().set_visible(False)\n",
    "# handles, labels = axes[2].get_legend_handles_labels()\n",
    "# fig.legend(handles, labels, loc='upper center', bbox_to_anchor=(0.68, 0.89), ncol=4)\n",
    "\n",
    "# plt.tight_layout(rect=[0, 0, 1, 0.95])\n",
    "# plt.savefig('predict_time_comparison.pdf', bbox_inches=\"tight\")\n",
    "# plt.show()\n"
   ]
  }
 ],
 "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
}
