{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "66d1187e-51f6-486f-bf80-f2a6284ab210",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# 定义常数\n",
    "c4 = 0.1\n",
    "c10 = 5.32e-15\n",
    "c12 = 0.08555\n",
    "c14 = 2.3266  # 通过饱和机制计算得到\n",
    "\n",
    "# 定义 t 的范围\n",
    "t = np.linspace(0, 800, 800)  # 从 0 到 800 的范围\n",
    "\n",
    "# 定义饱和项\n",
    "saturated_term = lambda t: (t - 393)**2 / (1 + (t - 393)**2)\n",
    "\n",
    "# 定义 y(t) 函数\n",
    "def y(t):\n",
    "    result = np.zeros_like(t)  # 创建一个与 t 同长度的零数组\n",
    "    # 0 <= t <= 100 的范围\n",
    "    mask_0_100 = (t >= 0) & (t <= 100)\n",
    "    result[mask_0_100] = 0.51\n",
    "    \n",
    "    # 100 < t <= 400 的范围\n",
    "    mask_100_400 = (t > 100) & (t <= 400)\n",
    "    exponent1 = c4 / (2 * np.pi) - c10 * (0.1**4) * (16**7) * (t[mask_100_400] - 100)**2 * (t[mask_100_400] - 99)**2 * 2\n",
    "    result[mask_100_400] = 0.001 + np.exp(exponent1) / 2\n",
    "    \n",
    "    # 400 < t <= 800 的范围\n",
    "    mask_400_800 = (t > 400) & (t <= 800)\n",
    "    exponent2 = c12 / (2 * np.pi) - c14 * saturated_term(t[mask_400_800])\n",
    "    result[mask_400_800] = 0.001 + np.exp(exponent2) / 2\n",
    "    \n",
    "    return result\n",
    "\n",
    "# 计算 y(t)\n",
    "y_values = y(t)\n",
    "\n",
    "# 加载矩阵数据（假设文件存在）\n",
    "try:\n",
    "    matrix1 = np.loadtxt('2.npy')\n",
    "except FileNotFoundError:\n",
    "    print(\"文件 '2.npy' 未找到，请确保文件存在。\")\n",
    "    exit()\n",
    "\n",
    "# 计算每个矩阵列方向的平均值\n",
    "mean_matrix1 = np.mean(matrix1, axis=0)\n",
    "\n",
    "# 第一阶段：前5个数据点\n",
    "first_5_data = mean_matrix1[:5]\n",
    "x_phase1 = np.arange(5)  # x轴坐标 0-4\n",
    "\n",
    "# 第二阶段：从epoch5到epoch1000均匀采样更多点（例如20个点）\n",
    "start_epoch = 5\n",
    "end_epoch = 1000\n",
    "num_samples = 20  # 增加采样点数量\n",
    "\n",
    "# 生成均匀分布的epoch数值（包括起始和结束点）\n",
    "phase2_epochs = np.linspace(start_epoch, end_epoch, num_samples, dtype=int)\n",
    "\n",
    "# 提取对应epoch的数据\n",
    "phase2_data = mean_matrix1[phase2_epochs]\n",
    "\n",
    "# 合并数据\n",
    "combined_data = np.concatenate((first_5_data, phase2_data))\n",
    "combined_epochs = np.concatenate((x_phase1, phase2_epochs))\n",
    "\n",
    "# 创建绘图\n",
    "plt.figure(figsize=(12, 6))  # 增大图形尺寸\n",
    "\n",
    "# 绘制折线图\n",
    "plt.plot(combined_epochs, combined_data, marker='o', linestyle='-', color='blue', label='Experimental Loss')\n",
    "plt.plot(t, y_values, linestyle='--', color='red', label='Theoretical Upper Bound')\n",
    "\n",
    "# 设置坐标轴范围，确保原点在 (0, 0)\n",
    "plt.xlim(0, 800)\n",
    "plt.ylim(0, max(y_values.max(), mean_matrix1.max()) * 1.1)  # 确保 y 轴范围足够显示所有数据\n",
    "\n",
    "# 设置坐标轴的原点在 (0, 0)\n",
    "plt.gca().spines['left'].set_position(('data', 0))\n",
    "plt.gca().spines['bottom'].set_position(('data', 0))\n",
    "\n",
    "# 设置坐标轴标签\n",
    "plt.xlabel('Epoch')\n",
    "plt.ylabel('Loss')\n",
    "plt.title('Numerical Comparison between Theoretical Upper Bound and Experimental Loss')\n",
    "plt.legend()\n",
    "plt.grid(True)\n",
    "\n",
    "# 保存图像\n",
    "plt.savefig('Comparison.pdf', dpi=600, bbox_inches='tight')\n",
    "plt.show()"
   ]
  }
 ],
 "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.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
