{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "plt.rc(\"text\", usetex=True)\n",
    "plt.rc(\"text.latex\", preamble=r\"\\usepackage{mathtools}\")\n",
    "plt.rc(\"font\", size=10, family=\"serif\", serif=\"cm\")\n",
    "plt.rc(\"figure\", figsize=(2, 1.5))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "metadata": {},
   "outputs": [],
   "source": [
    "ns = np.linspace(10, 1e4, num=int(1e5))\n",
    "stationary = ns ** (-1/2)\n",
    "factor = 1e2\n",
    "upper_bound = stationary * (1 + factor / ns)\n",
    "lower_bound = stationary * (1 - factor / ns)\n",
    "lower_bound[lower_bound < 0] = 0\n",
    "weights = np.exp((100-ns) / 100) / (1 + np.exp((100-ns) / 100))\n",
    "real = weights * upper_bound + (1 - weights) * stationary"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 128,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "a, = ax.plot(ns, stationary, color=\"C0\", linestyle=\"dashed\")\n",
    "b, = ax.plot(ns, upper_bound, color=\"C0\", linestyle=\"dotted\")\n",
    "ax.plot(ns, lower_bound, color=\"C0\", linestyle=\"dotted\")\n",
    "ax.fill_between(ns, lower_bound, upper_bound, alpha=0.2)\n",
    "c, = ax.plot(ns, real, color=\"C1\")\n",
    "ax.set_yscale(\"log\")\n",
    "ax.set_ylim([5e-3, 5e0])\n",
    "ax.set_xscale(\"log\")\n",
    "ax.set_xlim([1e1, 1e4])\n",
    "ymin, ymax = ax.get_ylim()\n",
    "d, = ax.plot([2.8e2, 2.8e2], [ymin, ymax], color=\"0.4\", linestyle=\"dashed\")\n",
    "ax.text(7e2, 5e-1, r\"$\\mathcal{O}(n^{-1/2})$\", fontsize=8)\n",
    "ax.text(2.2e1, 2e0, r\"$\\mathcal{O}(n^{-3/2})$\", fontsize=8)\n",
    "ax.set_xlabel(r\"Samples $n$\", fontsize=10)\n",
    "ax.set_ylabel(r\"Excess risk\", fontsize=10)\n",
    "fig.savefig(\"transitory.pdf\", bbox_inches=\"tight\")\n",
    "\n",
    "fig, ax = plt.subplots()\n",
    "ax.legend([a,b,c, d], [\"Stationary behavior\", \"Theoretical bounds\", \"Real profile\", \"Phase transition\"], fontsize=8)\n",
    "ax.axis(\"off\")\n",
    "fig.savefig(\"transitory_legend.pdf\", bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "metadata": {},
   "outputs": [],
   "source": [
    "weights = np.exp((100-ns) / 100) / (1 + np.exp((100-ns) / 100))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 200x150 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(ns, weights)\n",
    "plt.xscale(\"log\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "dev",
   "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.4"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
