{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "3ea60a97",
   "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": 10,
   "id": "29a67d27",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import sys\n",
    "import itertools\n",
    "from pathlib import Path\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.ticker as ticker\n",
    "from matplotlib.gridspec import GridSpec\n",
    "import torch\n",
    "\n",
    "sys.path.append(os.path.abspath(os.path.join(os.getcwd(), \"..\")))\n",
    "\n",
    "from app.experiments import calc_mse_comparison, calc_expect_mse_comparison\n",
    "from app.SB import GaussianSB\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "a48d754e",
   "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\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "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(0)\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_sample.npy\"\n",
    "result_integral_path = results_dir / \"mse_integral.npy\"\n",
    "\n",
    "fig_dir = Path(\"../fig\")\n",
    "fig_dir.mkdir(parents=True, exist_ok=True)\n",
    "fig_path = fig_dir / \"mse_mn_infinf.png\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "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": 14,
   "id": "e033bc28",
   "metadata": {},
   "outputs": [],
   "source": [
    "Nsamples = [10, 100, 1000, 10000]\n",
    "MNsamples = list(itertools.product(Nsamples, repeat=2))\n",
    "tauz = [0.1, 0.3, 0.7, 0.9]\n",
    "eps = 0.1\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "65c756a0",
   "metadata": {},
   "outputs": [],
   "source": [
    "Ntest = 10000\n",
    "ntrials = 10\n",
    "\n",
    "is_calculate_mse_marginals = True\n",
    "is_calculate_mse_integral = True\n",
    "\n",
    "gaussianSB = GaussianSB(A, B, eps)\n",
    "if is_calculate_mse_marginals:\n",
    "    mse_marginals = calc_mse_comparison(\n",
    "        sb=gaussianSB,\n",
    "        device=device,\n",
    "        Ntest=Ntest,\n",
    "        MNsamples=MNsamples,\n",
    "        tauz=tauz,\n",
    "        n_trials=ntrials,\n",
    "        eps=eps,\n",
    "        sinkhorn_n_iters=[10000],\n",
    "        compare_target=\"true_drift\",\n",
    "    )\n",
    "    np.save(result_path, mse_marginals)\n",
    "else:\n",
    "    mse_marginals = np.load(result_path)\n",
    "\n",
    "if is_calculate_mse_integral:\n",
    "    mse_integral = calc_expect_mse_comparison(\n",
    "        sb=gaussianSB,\n",
    "        device=device,\n",
    "        MNsamples=MNsamples,\n",
    "        tauz=[0.9],\n",
    "        expect_n_marginals=1000,\n",
    "        expect_n_per_marginals=1000,\n",
    "        n_trials=ntrials,\n",
    "        eps=eps,\n",
    "        sinkhorn_n_iters=[10000],\n",
    "        compare_target=\"true_drift\",\n",
    "    )\n",
    "    np.save(result_integral_path, mse_integral)\n",
    "else:\n",
    "    mse_integral = np.load(result_integral_path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "29a4b20a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Vqt27Nih5s2bS8otTN9+++3OChNwCt9LNwEAAAAAAAAA9/Htt99Kktq3b19mx3j44Yf18MMPO9T2vvvuy1c4mzVrlkaPHq1q1apdctt//etfqlSpkn0ovE6dOuUrmknStGnTtGLFCv3jH/+wF80kKSQkROPHj9eVV16p3r1769ChQwX2b7FY1L17d3vh7IYbblDXrl2LjKdXr1666qqrLhm3t9qzZ49uueUWTZkyhaJZHhEREZo3b55uvfVWffDBB6Uudvn4+KhKlSqSpKpVq+qmm25yZpiAUzBUIwAAAAAAAACPsnr1akllWzgrCVuhq06dOpKkM2fO6J133rnkdtu3b9e3336r++67r8C+8vrggw8kSVdffXWh++nVq5f69OlTaOHs4n1aLJZiY2rSpIk6dOhwydi90dmzZ9WpUyd17txZjz76qKvDcTuNGzfWv/71L91///0lGo70YmvXrpUk3XLLLfL393dWeIDTUDgDAAAAAAAA4FG+++47SXK7Id4GDRpkfzxz5kxZrdZi27/xxhuKiopSp06dim23a9cuSdIPP/xQZJuRI0fq8OHDJYi2aGPGjMk3B1xFMXz4cB06dIh5t/60Y8cO9e/fP99zPXr00FVXXaXBgweXer+rVq2SJP31r391+LieJiMjQ6mpqSVaMjIyXB02/kThDAAAAAAAAIDH2Lt3r/bv36+6deva50lyF+3bt1d0dLSk3CH/vvzyyyLbnj17Vu+++66efvrpS/YCq1GjhqTcedeK2mdUVJTq1KkjY0zpgs/jxhtvdGiYSW+SmJio2bNn69FHH1WtWrVcHY7Lbd26VR07dtQ111xTYN2TTz6pr776SsuXLy/VvleuXClJ6tixY4mO6ykyMjLUpFE1BQcHl2hp0qQJxTM3QeEM8BC2ca7hPMnJyTp58mSR67nmgPPxvip/XHPA+XhflT+uOVA2eG+VP665c9iGabzttttcG0gRhg0bZn88bdq0ItvNnTtXFotFffr0ueQ+bedqjNEDDzygMWPGKDs7u0C79evXX7IIV5xt27YpNja21Nt7silTpsgYo27durk6FJfKyspSfHy82rZtq6SkJHXu3LlAm06dOslisWjSpEkl3n9ycrJ27typsLAwtWzZskTH9RQXLlzQkWM52rehsVJ2NHVo2behsY4cOaILFy64OnyIwpnXeOmll9Sw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P69nn31WdevWVb169Qp9LThi+/btmjNnjoYOHar27dure/fu9nULFy5UdHS0qlSpoq5duyorK6vE+8/bnT7vl4yLhYWFSZJ27txZ4nnOSqtWrVpq3LixVq5cqQMHDpTLMZGLXOZ5yGXlm8veeecd/fjjj/r555/t+ywKucx1yGWeh1xW/p/LvvjiC0lFD9NoQy5zLfKZ5yGfOT+fhYSE2Hta2ObruVjeec9OnTpVaBvyWcnZepvddtttl1VILwtF9Yi9/fbbdd1110mS9u3bp+eee04DBgxQ1apVHd73zp079cknnxTb5sEHH7Q/Lsm+i3P48GFt3LhRUm6e6Nevn2bOnKlevXrJYrHkGxIyNTVVTz31lEaPHq2RI0fq5ptvtvfM2rZtm8aMGaNWrVpp48aNev755xUeHq7q1avrpZdekpR7M2CrVq1UrVo1/e1vf9P58+ft+z548KCmTJmia6+9Vps3b9bjjz+u4OBg1a1bV+PHj3foXN58803de++9uvXWW3XFFVfo3Xffzbf+yiuvlPS/0TyKsmLFCmVkZKhOnToFhlq19fh64IEH1KRJE/vztp5o0uUVzr755htZrVbVqlWrQI/FVatWKTMzUzfffHO+Yl5JHThwQNu3b1dQUJBuvPHGYtvahh61FfC+/vprSbm9eAsbPWDkyJEyxui2226Tv79/qY/rSawyynFwoXDmXiiceTE/P798d5u89tprBdp8/fXX2rVrV77xkItz9dVX64svvsg3rMXvv/+u22+/XY899tgl/7g4YteuXYXG6mny/oF31E8//aRz586pRo0aBSbItElLS1OlSpX01ltv6ccff9Stt94qKXe8+oULF+rGG29UWlqafdLZEydOqGPHjvL19VWdOnV06NAhzZo1q1TnlJSUpD179uiNN97Qd999Zx9PfNSoUUpISFCnTp2UkZGhxYsX2++AKYm8d+oV9yEvMDBQkpSdnW3/I10errrqKhljtGjRonI7JshlrkYuc99c9vPPP6tHjx7q37+/tmzZos6dO9vniCkOucw1yGWuRS5z31yW17x58xQSEuLQnDXkMtchn7kW+cw98lnVqlXtc8x+8803hbbJO3xacXMmkc9Kxja/mTsO02jrfZOZmVlgXd7euhcuXCh0bru8hbeLi3DNmjXTyJEji31t5i1EFNabpzRefPFF7dixQ5LUq1cv3XPPPRoyZIjee+89PfbYY/na9uvXT+vWrdPYsWM1fvx4dejQQd26ddOJEydUrVo1HTlyRL/99pteffVVxcTEaPv27erTp4/Gjx+vfv36KSgoSD/88IPefPNNzZ8/XwkJCfZ979u3T0uWLNHmzZs1YcIE3Xvvvfr888/VtGlTvfTSS5o9e3ax5zFmzBitXbtWX3zxhb7//nvdc8896tOnj/7zn//Y29huLDh8+HCxxXPbNj179sxXIJekJUuWSCrY22rDhg1KSUlR8+bN1ahRI2VlZWnfvn3FxlwY2zCNf//73+056+J1nTt3lpSbW0tzU5Ot11f79u3l6+urffv2Ffl32Nab99prr5WU2yNUkurXr2+/ucDmzTfftPfotc3td/z4cfsNESU5LlAeKJx5uYEDB9o/GH7xxRcFkvK//vUvdenSRZGRkQ7v8+6779bvv/9eYLzcDz74QNdcc42+//57h/azePFitW3bNt8SFRWlZs2aadu2bQ7H406+//57Pf3004qKiirVhMubN2+WVPxdcG3bttUjjzwiY4wsFos6deqkl19+Wc2bN9fHH3+sAQMGSMqdQyItLU19+vTRrFmzNHHiRPt47peaW6IoHTt21CuvvGJ/Td1333169dVXVaNGDS1YsEAvv/yyvW1pxs3P+yXw4jtP8sr7pSMtLa3Exykt2+/l559/LrdjIhe5rHyRy9w/l33wwQeaOnWqTpw4Yd/PunXr1LZtWyUnJxe7LbnMdchl5Ytc5v65LK9Dhw5p7dq16tatW75/bC4Kucy1yGfli3zmnvls6NChkqStW7dqxYoVBdbn7UFWp06dIvdDPisZW+HMkZssypvtd15Y78EHH3xQ9erVkyT16NFDDRs2LNAmb++ti3spRkVFaf/+/erZs6cuXLhQ6PFtBZ3mzZurR48eBdYXN9RjYZYsWaIPP/xQHTt2lJTbe9PWo0rKLQZe/J6KiorK9zgzM1Pbt29X/fr17b2InnjiCXXo0EFBQUHq16+fpNzccs8996h69erq1auXgoOD8/USvvnmm+3D+o4ZM0Zdu3ZVTEyMFi9erMDAwGKHOz148KDGjx+vF154wd5L0Vb0+/e//21v17x5czVr1kxZWVnavn17ofsyxuirr76SlNsDO6/jx4/r559/VnBwsDp06JBv3apVqyTlFoyMMXr22Wftv8fj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85WQkCAp95otWbJEmzdv1oQJE3Tvvffq888/V9OmTfXSSy9p9uzZxZ7DmDFjtHbtWn3xxRf6/vvvdc8996hPnz4F7qaw/aPniRMnitzXihUrlJGRoTp16mjw4MH51tnuxHvggQfy3T1iu0NQurwvNN98842sVqtq1apVYM6CVatWKTMzUzfffPNlfeC3TShaVLfx7Oxs/fbbb5JUph8mCmMbfibvFzmUDXIZuUwil5WUbe6Ai8favxi5rPyQy8hlErnMEfPnz5evr2+J9kEuK1/kM/KZRD4riREjRujChQtq0aJFviEbC0M+c8zBgwe1a9cu1ahRQ61atbI/v3fvXt100026++67NX78eMXHxysyMlK33367fZhSOEfeYXn9/PwUFhZmH6LVVjxZuHChfvnlF61atUoLFiyQlDtf2K+//movWuX9m2K7ceLiwv6FCxdktRY+cJ2t56GUe/NNcnKyvahn20/eOQuvueYaPfjgg1q6dKluuukmTZ06VW+88Ybat2+vli1b2udws/H19dWXX36p3bt35xs2tiydOnVKDz74oN54441LDqvr6mNs2LBBY8aM0eLFi9WwYUMnRuidckzJFrgPCmdexvYH4uK7JaTcOyZsLly4UODDsJT/j9fFX46aNWumkSNH2v9IFsbf39/++Oabb3Y88GK8+OKL2rFjhyRp9+7d+eZuGTZsWL5jSvmHYYiKilJmZqa2b9+u+vXr68Ybb5QkPfHEE+rQoYOCgoLUr18/Sbl3od1zzz2qXr26evXqpeDgYPsY7zfffLN9/OExY8aoa9euiomJ0eLFixUYGKhJkyYVGf/Bgwc1fvx4vfDCC/YPErYvYv/+97/ztbXdBXP48OEih9GwfQnq2bNngaFslixZIkkFukRv2LBBKSkpat68uRo1aqSsrCzt27evyJiLYhs+4+9//7sCAwMLXWcb/zopKemSQ4EUxja58po1awodn3rlypVKT09XWFiYunfvXuL9Xw7b8GcXd+2H85HLyGUSuaykbHfgPvnkk8W2I5eVH3IZuUwil11KSkqKVq1apfbt2+ebi+NSyGXli3xGPpPIZ456//339dFHH6lu3br66quvLjnsI/nMMbbPuh06dMjXs2jIkCGqXLmyHnnkEftzzzzzjPbu3auJEyeWd5he7dChQ2rbtq1eeeUVjRgxQtdcc43+7//+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MXJZ+SCX5SKXkcuK+1wmSWfPntW3336rNm3aKCIiotg48iKXlR/yWS7yGfmsqHy2fft2jR8/XldddZV++uknLV68WMuWLVOdOnWKjcWGfFa0f/zjH2rSpImOHz+u//znPzp+/LheeumlfPMcJicnS5Jq165dYHvbc7t37y6fgFHmbPOWXTwfGgCUCdfW7YCSGTVqlP3xhQsXTMuWLU3nzp2NMcZs2bLFSDLPPvusvU1cXJyRZFauXGmMKZs7Adu2bWsGDBhQ5P5+++03I8l06tQp352POTk5Zvjw4fbhQfKaPHmy8fHxMVu3bnXksjhN165dzbx58zz+GGXh+uuvNx06dChwByZQGuSyskUuKxq5DM5ELitb5LKikcvgbOSzsuWt+Wz58uXm5ZdfNgsWLCi2Z21xyGeFO3nypJFkGjdubJKSksyVV15pOnbsWKBXoq3nZWFDbI4aNcpIMu+//355hY0y9P7775vGjRsbSaZ79+4e+fkFFYutx9m6LWFmy/4Ih5Z1W8LoceZG6HEGj/LOO+/YJ4328/NTWFiYbrnlFkmy3xm3cOFC/fLLL1q1apUWLFggSfrxxx/166+/6sKFC5KUb0Lq7OxsSQXvWLlw4YKs1oLTMn733Xf2xwsWLFBycrLGjRtnf862H9udMNdcc40efPBBLV26VDfddJOmTp2qN954Q+3bt1fLli1Vo0aNAscYNmyY2rZtq6efftrxi3OZTpw4of3796tr164efYyyMHv2bCUnJyshIaHAHZhAaZDLyg65rGjkMjgbuazskMuKRi5DWSCflR1vzmd33nmnxo4dq+7duxfZs7Y45LOihYSE6Mknn1R2drbuvfde9e7dW1999VWBXom2XmW290VetucCAwPLPmCUuUcffVR79+6VMUYLFizQ/fff7+qQAIfkyFKiBW7EpWU7oISk3Amhx44da4YPH26GDx+eb36qZ555xlSrVs1ERESYMWPGmP3795sGDRqYK664wqxevdq0bdvWSDKPPPKI2bhxo9mxY4d9vP7IyEgzb948c/bsWTNhwgQjyQQFBZm5c+eajIwM+52AsbGx5v777zc9evQwDzzwQL47A9euXWvuuecee5y2SWvPnTtn/vGPf5jQ0FATGBhobrzxRrNw4cJiz/Xo0aOmSZMmZtKkSWVyLfM6efKkueOOOwqdk8CTjlEWfvnl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",
      "text/plain": [
       "<Figure size 2000x600 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "all_mse_marginals_data = np.array([mse_marginals[:, tau_idx, 0, :] for tau_idx in range(len(tauz))])\n",
    "all_mse_marginals_means = np.mean(all_mse_marginals_data, axis=-1)\n",
    "vmin_marginal = np.min(all_mse_marginals_means)\n",
    "vmax_marginal = np.max(all_mse_marginals_means)\n",
    "\n",
    "all_mse_integral_data = np.array([mse_integral[:, 0, 0, :]])\n",
    "all_mse_integral_means = np.mean(all_mse_integral_data, axis=-1)\n",
    "vmin_integral = np.min(all_mse_integral_means)\n",
    "vmax_integral = np.max(all_mse_integral_means)\n",
    "\n",
    "vmin = min(vmin_marginal, vmin_integral)\n",
    "vmax = max(vmax_marginal, vmax_integral)\n",
    "\n",
    "fig = plt.figure(figsize=(20, 6))\n",
    "\n",
    "gs = GridSpec(1, len(tauz) + 2, width_ratios=[1] * (len(tauz) + 1) + [0.05])\n",
    "\n",
    "axes = []\n",
    "for tau_idx, tau in enumerate(tauz + [0.9]):\n",
    "    ax = fig.add_subplot(gs[0, tau_idx])\n",
    "    axes.append(ax)\n",
    "\n",
    "    if tau_idx == len(tauz):\n",
    "        mse_data = mse_integral[:, 0, 0, :]\n",
    "        ax.set_title(f\"$\\\\int_0^{{0.9}}\\\\text{{MSE}}_{{\\\\text{{sample}}}}(m,n,t)dt$\")\n",
    "    else:\n",
    "        mse_data = mse_marginals[:, tau_idx, 0, :]\n",
    "        ax.set_title(f\"$\\\\text{{MSE}}_{{\\\\text{{sample}}}}(m,n,{tau})$\")\n",
    "\n",
    "    mse_means = np.mean(mse_data, axis=-1)\n",
    "\n",
    "    grid_data = mse_means.reshape(len(Nsamples), len(Nsamples))\n",
    "\n",
    "    im = ax.imshow(np.log10(grid_data), cmap=\"viridis\", origin=\"lower\", vmin=np.log10(vmin), vmax=np.log10(vmax))\n",
    "\n",
    "    ax.set_xticks(np.arange(len(Nsamples)))\n",
    "    ax.set_yticks(np.arange(len(Nsamples)))\n",
    "    ax.set_xticklabels([f\"$10^{{{int(np.log10(x))}}}$\" for x in Nsamples])\n",
    "    ax.set_yticklabels([f\"$10^{{{int(np.log10(x))}}}$\" for x in Nsamples])\n",
    "\n",
    "    ax.set_xticks(np.arange(-0.5, len(Nsamples), 1), minor=True)\n",
    "    ax.set_yticks(np.arange(-0.5, len(Nsamples), 1), minor=True)\n",
    "    ax.grid(which=\"minor\", color=\"w\", linestyle=\"-\", linewidth=1)\n",
    "\n",
    "    if tau_idx == 0:\n",
    "        ax.set_ylabel(\"$m$\")\n",
    "    else:\n",
    "        ax.set_ylabel(\"\")\n",
    "        ax.set_yticklabels([])\n",
    "\n",
    "    ax.set_xlabel(\"$n$\")\n",
    "\n",
    "\n",
    "cax = fig.add_subplot(gs[0, -1])\n",
    "pos = cax.get_position()\n",
    "cax.set_position([pos.x0, pos.y0 + pos.height * 0.15, pos.width, pos.height * 0.7])\n",
    "cbar = fig.colorbar(im, cax=cax)\n",
    "\n",
    "formatter = ticker.FuncFormatter(lambda y, _: r\"$10^{%.0f}$\" % y)\n",
    "cbar.ax.yaxis.set_major_formatter(formatter)\n",
    "\n",
    "cbar.set_label(\"MSE\", rotation=270, labelpad=20)\n",
    "\n",
    "plt.savefig(fig_path, dpi=300, bbox_inches=\"tight\", format=\"png\", pad_inches=0.5)\n",
    "plt.show()\n"
   ]
  },
  {
   "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
}
