{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "0e4e4d9f",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import math\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "73189da0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "log-log regression: log(y) ≈ 0.919 * log(1/(n*alpha^2)) + 0.619\n",
      "slope=1: log(y) ≈ 1 * log(1/(n*alpha^2)) + 0.639\n"
     ]
    },
    {
     "data": {
      "image/png": "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UUdHB3D+PEh7O1rPnWNLluXm5roYEZ338QBY3z+zoJh4gO6EAuPaYx4nT57E4sWL8ec//xkikQilpaUun2GMgYwXwHk8Zk7OGoTFYsG6deuQn5/v9Vdy7tw5PPXUU5g+fbrXn6F0T9xuGaKKzk6gvh4AYM7Kgq7rLtuvXz+3RUXs9/HAJWHAPGes/vYBQO7cfs7bjccffxz79+/Hfffdh8svvxz3338/u+jtVXp/jIEWiwVpaWm4cOGC119LdnY2ADj02YgENBoNXnzxRaSnp0OtVuP111/3WNh337592LhxI3Jzc9He3o4333wTIpEIX331FebMmQOlUolHH30Ub775ZliKxFANIdJRKACmvX1mJnj5+RgwYABycnJYg5v9wmVgFjGzEO0XoP3/7Y18DM7bDS6Xi7Nnz0IqlcJgMCAvLw9KpRKjR49mqx799ttv+PHHH6HX62EymXDy5En88ssvrJZBCEFiYiLrcnSGz+fjqquu8umrSUpKCqjQbqjorsuYPR0dHZgyZQree+89LF68GMOGDUNZWRkuXLiAb775Bl9++SXeffddfPTRR3jnnXfCMncqECIZpRI4cwYgBNb0dKCgAOiy1CckJEClUjk8mHJkgOs+3tmPb/+6syCx324wd/iLFy+ydgj7rYher0drayumTZvG2ipkMhmefPJJJCQkQCgUQiQSQSgUehQGDP7EFESCPYGJLwGA5uZmbNmyBbfccgsAW9/RNWvWsD0u7fn6668dSuvdcccd+OCDD1BfX4/169fjqquuwqOPPorS0lL8/PPPYbkWumWIBDQal5eI2QxUV4NDCHRZWZACyNZoILJaodPpYDQabXfvrkVktVqh53Bg7WqYyuVyYVYobIvMaASxC+4hIpGDKm+/qNy5Dffv3481a9ZALpdj0aJFGDx4MH777Tfw+Xy89dZb2Lp1K86dO4f169ejoaEBRqMR586dw9q1a9HQ0IAnnngChw4dwnfffYfq6moIBAKsW7cOSUlJqK+vx5IlS5CXl4eamhqPX9HKlSuRkJCAr776Ctdee63HmponTpzAhx9+iJSUFPznP//BihUrcPToUbz77rt4++23MXfuXLS0tGDZsmV48sknAcDj3Ow5cuQI/vd//xdpaWlYvnw5rr76ava9JUuWYPHixQB86zKmUqnQ1NTEPs/Ly4PRaERqaqrD9iA3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",
      "text/plain": [
       "<Figure size 270x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.linear_model import LinearRegression\n",
    "import matplotlib as mpl\n",
    "\n",
    "mpl.rcParams[\"mathtext.fontset\"] = \"stix\"  \n",
    "mpl.rcParams[\"font.family\"] = \"Times New Roman\"  \n",
    "df = pd.read_csv(\"cqr_vary_n_uniform_m1e7.csv\")\n",
    "df = df.groupby(['n', 'alpha']).mean().reset_index()\n",
    "df = df[(df['n'] >= 200) & (df['n'] <= 20000)]\n",
    "df = df[df['alpha'] <= 0.03] \n",
    "\n",
    "df[\"x\"] = 1.0 / (df[\"n\"] * df[\"alpha\"]**2)\n",
    "df[\"y\"] = df[\"excess_len_avg\"]\n",
    "\n",
    "X_log = np.log(df[\"x\"].values).reshape(-1, 1)\n",
    "y_log = np.log(df[\"y\"].values)\n",
    "\n",
    "model = LinearRegression()\n",
    "model.fit(X_log, y_log)\n",
    "\n",
    "slope = model.coef_[0]\n",
    "intercept = model.intercept_\n",
    "print(f\"log-log regression: log(y) ≈ {slope:.3f} * log(1/(n*alpha^2)) + {intercept:.3f}\")\n",
    "\n",
    "intercept_fixed = np.mean(y_log - X_log.flatten())\n",
    "print(f\"slope=1: log(y) ≈ 1 * log(1/(n*alpha^2)) + {intercept_fixed:.3f}\")\n",
    "\n",
    "\n",
    "plt.figure(figsize=(2.7,3))\n",
    "plt.scatter(df[\"x\"], df[\"y\"], c=\"grey\", alpha=0.3)\n",
    "\n",
    "x_grid = np.linspace(df[\"x\"].min(), df[\"x\"].max(), 200)\n",
    "y_pred = np.exp(intercept + slope * np.log(x_grid))\n",
    "plt.plot(x_grid, y_pred, \"r--\", label=rf\"fitted slope$\\approx${slope:.2f}\")\n",
    "plt.legend(prop={\"family\":\"Times New Roman\"})\n",
    "\n",
    "y_ref = np.exp(intercept_fixed + 1.0 * np.log(x_grid))\n",
    "plt.plot(x_grid, y_ref, \"k--\", alpha=0.7,\n",
    "         label=rf\"slope$=1$\")\n",
    "plt.legend(prop={\"family\":\"Times New Roman\"})\n",
    "\n",
    "plt.xscale(\"log\")\n",
    "plt.yscale(\"log\")\n",
    "plt.xlabel(r\"$1/(n \\alpha^2)$\", fontname=\"Times New Roman\")\n",
    "plt.ylabel(r\"$\\Delta$\", fontname=\"Times New Roman\")\n",
    "plt.legend(prop={\"family\":\"Times New Roman\"})\n",
    "plt.tight_layout()\n",
    "# plt.savefig(\"scaling_plot.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "quantdata",
   "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.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
