{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "b91de894-334a-436f-bf14-6955b06b737f",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "# 设置全局字体大小\n",
    "plt.rcParams.update({\n",
    "    'font.size': 30,\n",
    "    'axes.labelsize': 26,\n",
    "    'axes.titlesize': 28,\n",
    "    'xtick.labelsize': 24,\n",
    "    'ytick.labelsize': 24,\n",
    "    'legend.fontsize': 24\n",
    "})\n",
    "\n",
    "# 读取数据\n",
    "df = pd.read_csv(\"hyperparameter_analysis_results.csv\")\n",
    "\n",
    "# 1. 嵌入维度对性能的影响\n",
    "plt.figure(figsize=(8, 6))\n",
    "for reg in [0.0, 0.01, 0.05]:\n",
    "    subset = df[df['reg_weight'] == reg]\n",
    "    plt.plot(subset['embedding_dim'], subset['test_auc'], \n",
    "             marker='o', label=f'λ={reg}', linewidth=2, markersize=8)\n",
    "\n",
    "plt.xlabel('Embedding Dimension', fontsize=16)\n",
    "plt.ylabel('Test AUC Score', fontsize=16)\n",
    "plt.title('Impact of Embedding Dimension\\nand Regularization', fontsize=18, pad=15)\n",
    "plt.legend(frameon=True, fancybox=True, shadow=True)\n",
    "plt.grid(True, linestyle='--', alpha=0.7)\n",
    "plt.xticks([4, 8, 16, 32, 64])\n",
    "plt.savefig('dimension_analysis.png', dpi=300, bbox_inches='tight')\n",
    "plt.close()\n",
    "\n",
    "# 2. 正则化权重对性能的影响\n",
    "plt.figure(figsize=(8, 6))\n",
    "for dim in [8, 16, 32, 64]:\n",
    "    subset = df[df['embedding_dim'] == dim]\n",
    "    plt.plot(subset['reg_weight'], subset['test_auc'], \n",
    "             marker='o', label=f'd={dim}', linewidth=2, markersize=8)\n",
    "\n",
    "plt.xscale('log')\n",
    "plt.xlabel('Regularization Weight (λ)', fontsize=16)\n",
    "plt.ylabel('Test AUC Score', fontsize=16)\n",
    "plt.title('Impact of Regularization Weight', fontsize=18, pad=15)\n",
    "plt.legend(frameon=True, fancybox=True, shadow=True)\n",
    "plt.grid(True, linestyle='--', alpha=0.7)\n",
    "plt.savefig('regularization_analysis.png', dpi=300, bbox_inches='tight')\n",
    "plt.close()\n",
    "\n",
    "# 3. 训练时间分析\n",
    "plt.figure(figsize=(8, 6))\n",
    "mean_times = df.groupby('embedding_dim')['training_time'].mean()\n",
    "\n",
    "# 绘制线条和点\n",
    "plt.plot(mean_times.index, mean_times.values, marker='o', linewidth=2, \n",
    "         color='#1f77b4', markersize=8)\n",
    "\n",
    "# 在每个点上添加具体数值\n",
    "for x, y in zip(mean_times.index, mean_times.values):\n",
    "    plt.annotate(f'{y:.2f}s',\n",
    "                 xy=(x, y),\n",
    "                 xytext=(0, 10),\n",
    "                 textcoords='offset points',\n",
    "                 ha='center',\n",
    "                 va='bottom',\n",
    "                 fontsize=12,  # 增大标注字体\n",
    "                 weight='bold')  # 加粗标注\n",
    "\n",
    "plt.xlabel('Embedding Dimension', fontsize=16)\n",
    "plt.ylabel('Average Training Time (s)', fontsize=16)\n",
    "plt.title('Computational Efficiency Analysis', fontsize=18, pad=15)\n",
    "plt.grid(True, linestyle='--', alpha=0.7)\n",
    "plt.xticks([4, 8, 16, 32, 64])\n",
    "\n",
    "# 调整y轴的范围\n",
    "ymin, ymax = plt.ylim()\n",
    "plt.ylim(ymin, ymax + 8)  # 增加更多空间给标注\n",
    "\n",
    "plt.savefig('training_time_analysis.png', dpi=300, bbox_inches='tight')\n",
    "plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "29874fb5-0b78-47e0-9064-afd60bc85c84",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "412be8b6-1ed2-4816-ae5e-3d4b971d8f02",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.11.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
