{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.font_manager as fm\n",
    "\n",
    "\n",
    "# Load the two CSV files for 14b\n",
    "df = pd.read_csv('/mnt/sda/2022-0526/home/xuhx/projects/gLLM/experiments/predict/14b_sharegpt.csv')\n",
    "df = df.sample(frac=0.01, random_state=42)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "# 预测的敏感性分析\n",
    "def predict_worker_time(prefill, decode,memory_util):     return 5.994919      + 0.029744 * prefill      + 0.110212 * decode # 14b\n",
    "def predict_sample_time(prefill, decode,memory_util):     return 1.795752      + 0.044437 * decode # 14b\n",
    "# def predict_worker_time(prefill, decode,memory_util):     return 11.238080      + 0.075143 * prefill      + 0.140392 * decode\n",
    "# def predict_sample_time(prefill, decode,memory_util):     return 1.808118      + 0.044461 * decode"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "全体 MSE: 0.1617878595941072\n"
     ]
    }
   ],
   "source": [
    "df['predict_worker_time'] = df.apply(\n",
    "    lambda row: predict_worker_time(\n",
    "        row['prefill'],\n",
    "        row['decode'],\n",
    "        row['memory_util']\n",
    "    ),\n",
    "    axis=1\n",
    ")\n",
    "\n",
    "df['layer_mse'] = abs((df['predict_worker_time'] - df['worker_1_time'])/df['worker_1_time']) \n",
    "print(\"全体 MSE:\", df['layer_mse'].mean())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "全体 MSE: 0.021505674219410846\n"
     ]
    }
   ],
   "source": [
    "df['predict_sample_time'] = df.apply(\n",
    "    lambda row: predict_sample_time(\n",
    "        row['prefill'],\n",
    "        row['decode'],\n",
    "        row['memory_util']\n",
    "    ),\n",
    "    axis=1\n",
    ")\n",
    "# df['predict_worker_time'] = df.apply(\n",
    "#     lambda row: predict_worker_time(\n",
    "#         row['prefill'],\n",
    "#         row['decode']\n",
    "#     ),\n",
    "#     axis=1\n",
    "# )\n",
    "df['sample_mse'] = abs((df['predict_sample_time'] - df['sample_time'])/df['sample_time'])\n",
    "print(\"全体 MSE:\", df['sample_mse'].mean())"
   ]
  }
 ],
 "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
}
