{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "3d381e69",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "29a67d27",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import sys\n",
    "from pathlib import Path\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import torch\n",
    "\n",
    "sys.path.append(os.path.abspath(os.path.join(os.getcwd(), \"..\")))\n",
    "\n",
    "from app.experiments import calc_expect_mse_comparison\n",
    "from app.SB import GaussianSB"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "f58c4c24",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.rcParams[\"mathtext.fontset\"] = \"stix\"\n",
    "plt.rcParams[\"font.size\"] = 16\n",
    "plt.rcParams[\"xtick.labelsize\"] = 20\n",
    "plt.rcParams[\"ytick.labelsize\"] = 20\n",
    "plt.rcParams[\"axes.labelsize\"] = 20\n",
    "plt.rcParams[\"axes.titlesize\"] = 20"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "30f6bbf4",
   "metadata": {},
   "outputs": [],
   "source": [
    "SEED = 1\n",
    "np.random.seed(SEED)\n",
    "torch.manual_seed(SEED)\n",
    "\n",
    "device = \"cuda\"\n",
    "torch.cuda.set_device(1)\n",
    "torch.set_default_dtype(torch.float64)\n",
    "\n",
    "results_dir = Path(\"../exp_results\")\n",
    "results_dir.mkdir(parents=True, exist_ok=True)\n",
    "result_path = results_dir / \"mse_sinkhorn.npy\"\n",
    "\n",
    "fig_dir = Path(\"../fig\")\n",
    "fig_dir.mkdir(parents=True, exist_ok=True)\n",
    "fig_path = fig_dir / \"mse_mnk_mnstar.png\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "53286fe2",
   "metadata": {},
   "outputs": [],
   "source": [
    "dim = 3\n",
    "A = torch.eye(dim, device=device)\n",
    "B_ = torch.rand_like(A, device=device)\n",
    "B = B_ @ B_.T\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "46499231",
   "metadata": {},
   "outputs": [],
   "source": [
    "MNsamples = [(1000, 1000)]\n",
    "tauz = [0.1, 0.5, 0.9]\n",
    "sinkhorn_n_iters = [1, 10, 100, 500]\n",
    "eps = 0.005"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "29a4b20a",
   "metadata": {},
   "outputs": [],
   "source": [
    "ntrials = 10\n",
    "\n",
    "gaussianSB = GaussianSB(A, B, eps)\n",
    "\n",
    "is_calculate = True\n",
    "\n",
    "if is_calculate:\n",
    "    mse_comparison = calc_expect_mse_comparison(\n",
    "        sb=gaussianSB,\n",
    "        device=device,\n",
    "        MNsamples=MNsamples,\n",
    "        tauz=tauz,\n",
    "        expect_n_marginals=1000,\n",
    "        expect_n_per_marginals=1000,\n",
    "        n_trials=ntrials,\n",
    "        eps=eps,\n",
    "        sinkhorn_n_iters=sinkhorn_n_iters,\n",
    "        compare_target=\"m_n_star_drift\",\n",
    "    )\n",
    "    np.save(result_path, mse_comparison)\n",
    "else:\n",
    "    mse_comparison = np.load(result_path)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "0c71c969",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "ax = plt.axes()\n",
    "x = np.array(sinkhorn_n_iters)\n",
    "for taui in range(0, len(tauz)):\n",
    "    tau = tauz[taui]\n",
    "    mse_j = mse_comparison[0, taui, :, :]\n",
    "    mse_j_means = np.mean(mse_j, axis=-1)\n",
    "    plt.plot(\n",
    "        x,\n",
    "        mse_j_means,\n",
    "        linewidth=1.5,\n",
    "        label=r\"$\\tau$ = {}\".format(tau),\n",
    "    )\n",
    "\n",
    "\n",
    "ax.set_xscale(\"log\")\n",
    "ax.set_yscale(\"log\")\n",
    "plt.xticks(fontsize=12)\n",
    "plt.yticks(fontsize=12)\n",
    "\n",
    "plt.xlabel(\"k\")\n",
    "plt.ylabel(f\"$\\\\int_0^\\\\tau\\\\text{{MSE}}_{{\\\\text{{sinkhorn}}}}(k,t)\\\\: dt$\")\n",
    "ax.legend(loc=\"lower left\")\n",
    "plt.savefig(fig_path, dpi=300, bbox_inches=\"tight\", format=\"png\", pad_inches=0.05)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f78c8194",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": ".venv",
   "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.13.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
