{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/users/data/coste/miniconda3/envs/Hamilton/lib/python3.10/site-packages/tqdm/auto.py:22: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using cuda:1.\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "import torch\n",
    "from tqdm import tqdm\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "from training import training, sampling, sampling_cascade\n",
    "from utils.loss import total_loss\n",
    "import matplotlib.pyplot as plt\n",
    "from data.generator import Ornstein_generator\n",
    "device = torch.device('cuda:1' if torch.cuda.is_available() else 'cpu')\n",
    "print(f\"Using {device}.\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "K_list = [1,2,5, 10,50,100]\n",
    "n_langevin = 0\n",
    "def do_multiple_samplings(save_fname, K_list=K_list, device=device, n_langevin_corrections = n_langevin, n_samples=2000):\n",
    "    D = torch.load(save_fname)\n",
    "\n",
    "    results = {}\n",
    "    for k in K_list:\n",
    "        results[k] = sampling(\n",
    "            save_fname, \n",
    "            k=k, \n",
    "            device=device, \n",
    "            n_samples=n_samples, \n",
    "            langevin_corrections=n_langevin_corrections)\n",
    "\n",
    "    if D['multiscale']:\n",
    "        torch.save(results, f\"save/exp/syntheses_{D['L']}_M.pt\")\n",
    "    else:\n",
    "        torch.save(results, f\"save/exp/syntheses_{D['L']}_U.pt\")\n",
    "\n",
    "    return results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling begins - L=32.\n",
      "Sampling begins - L=32.\n",
      "Sampling begins - L=32.\n",
      "Sampling begins - L=32.\n",
      "Sampling begins - L=32.\n",
      "Sampling begins - L=32.\n",
      "Sampling begins - L=16.\n",
      "Sampling begins - L=16.\n",
      "Sampling begins - L=16.\n",
      "Sampling begins - L=16.\n",
      "Sampling begins - L=16.\n",
      "Sampling begins - L=16.\n",
      "Sampling begins - L=8.\n",
      "Sampling begins - L=8.\n",
      "Sampling begins - L=8.\n",
      "Sampling begins - L=8.\n",
      "Sampling begins - L=8.\n",
      "Sampling begins - L=8.\n"
     ]
    }
   ],
   "source": [
    "n=2000\n",
    "#result32M = do_multiple_samplings(f'save/exp/phi4_32_M_{n}_potGA.pt')\n",
    "result32U = do_multiple_samplings(f'save/exp/phi4_32_U_{n}_potGA.pt')\n",
    "#result16M = do_multiple_samplings(f'save/exp/phi4_16_M_{n}_potGA.pt')\n",
    "result16U = do_multiple_samplings(f'save/exp/phi4_16_U_{n}_potGA.pt')\n",
    "result8U = do_multiple_samplings(f'save/exp/phi4_8_U_{n}_potGA.pt')\n",
    "#result8M = do_multiple_samplings(f'save/exp/phi4_8_M_{n}_potGA.pt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sampling begins - L=8.\n",
      "Sampling begins - L=16.\n",
      "Sampling begins - L=32.\n",
      "Sampling begins - L=8.\n",
      "Sampling begins - L=16.\n",
      "Sampling begins - L=32.\n",
      "Sampling begins - L=8.\n",
      "Sampling begins - L=16.\n",
      "Sampling begins - L=32.\n",
      "Sampling begins - L=8.\n",
      "Sampling begins - L=16.\n",
      "Sampling begins - L=32.\n",
      "Sampling begins - L=8.\n",
      "Sampling begins - L=16.\n",
      "Sampling begins - L=32.\n",
      "Sampling begins - L=8.\n",
      "Sampling begins - L=16.\n",
      "Sampling begins - L=32.\n"
     ]
    }
   ],
   "source": [
    "\n",
    "save_fname_list = [f'save/exp/phi4_8_U_{n}_potGA.pt', f'save/exp/phi4_16_M_{n}_potGA.pt', f'save/exp/phi4_32_M_{n}_potGA.pt']\n",
    "results_cascaded = {} \n",
    "for k in K_list:\n",
    "    results_cascaded[k] = sampling_cascade(save_fname_list, [k,k,k], device=device, n_samples = 100, langevin_corrections = 11, init_dataset='save/data/phi4_4.pt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "@k=1 -------------\n",
      "psd:20.987742720202164 || dtv:0.13324925402330015\n",
      "psd:5.862535707312588 || dtv:0.14966475700297543\n",
      "psd:1.3674017605585362 || dtv:0.15745202538111877\n",
      "psd:1.0415067973484113 || dtv:0.18959373344078065\n",
      "psd:3.399461585335814 || dtv:0.14088635267828367\n",
      "psd:15.984116033758255 || dtv:0.1322138851473274\n",
      "@k=2 -------------\n",
      "psd:20.816602268085262 || dtv:0.13168766000029755\n",
      "psd:6.003407863569919 || dtv:0.14640695770097348\n",
      "psd:1.35207166304221 || dtv:0.1511462221791458\n",
      "psd:1.0092517311747002 || dtv:0.19707857044384003\n",
      "psd:3.5317363823528467 || dtv:0.13610103131207274\n",
      "psd:14.469233421903368 || dtv:0.13418164359164428\n",
      "@k=5 -------------\n",
      "psd:20.729264560274714 || dtv:0.1302197040101242\n",
      "psd:5.928691670827192 || dtv:0.14187846267202756\n",
      "psd:1.2733539350493714 || dtv:0.15312417745573426\n",
      "psd:1.460315060413265 || dtv:0.20660268254262543\n",
      "psd:4.0872731938851246 || dtv:0.13917964292376706\n",
      "psd:15.405228721159688 || dtv:0.13724077028540801\n",
      "@k=10 -------------\n",
      "psd:19.90793426653545 || dtv:0.12932082556110763\n",
      "psd:5.441965650501686 || dtv:0.14208657975979613\n",
      "psd:1.2364474220767008 || dtv:0.15175066258744813\n",
      "psd:1.5695306098424453 || dtv:0.20835634041174317\n",
      "psd:4.447875636199626 || dtv:0.1506798733494415\n",
      "psd:17.1008883669881 || dtv:0.13808721368888854\n",
      "@k=50 -------------\n",
      "psd:73.76100479160823 || dtv:0.2310251417073288\n",
      "psd:20.363989244483832 || dtv:0.2396488840441894\n",
      "psd:4.848793578718393 || dtv:0.25640462121489715\n",
      "psd:1.7149067808372749 || dtv:0.2119048683445816\n",
      "psd:5.451522472378258 || dtv:0.14637261962844847\n",
      "psd:19.55107340209406 || dtv:0.13661665083132934\n",
      "@k=100 -------------\n",
      "psd:489.35134294145973 || dtv:0.2632168803939209\n",
      "psd:125.56960364406478 || dtv:0.263627738364624\n",
      "psd:28.65055600501001 || dtv:0.27004604167996216\n",
      "psd:3.1737977738857595 || dtv:0.23411222888713074\n",
      "psd:7.864311730394547 || dtv:0.1658340924223022\n",
      "psd:22.397266525779287 || dtv:0.14157549190310667\n"
     ]
    }
   ],
   "source": [
    "true32 = torch.load(\"save/data/phi4_32.pt\")\n",
    "true16 = torch.load(\"save/data/phi4_16.pt\")\n",
    "true8 = torch.load(\"save/data/phi4_8.pt\")\n",
    "losses = {}\n",
    "\n",
    "for k in K_list:\n",
    "    print(f\"@k={k} -------------\")\n",
    "    #losses[32, 'M', k] = total_loss(true32, result32M[k])\n",
    "    losses[32, 'U', k] = total_loss(true32, result32U[k])\n",
    "    #losses[16, 'M', k] = total_loss(true16, result16M[k])\n",
    "    losses[16, 'U', k] = total_loss(true16, result16U[k])\n",
    "    #losses[8, 'M', k] = total_loss(true8, result8U[k])\n",
    "    losses[8, 'U', k] = total_loss(true8, result8U[k])\n",
    "    losses[8, 'C', k] = total_loss(true8, results_cascaded[k][1])\n",
    "    losses[16, 'C', k] = total_loss(true16, results_cascaded[k][2])\n",
    "    losses[32, 'C', k] = total_loss(true32, results_cascaded[k][3])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [],
   "source": [
    "losses_arrays = {}\n",
    "L_list = [8,16,32]\n",
    "for L in L_list:\n",
    "    losses_arrays[L, 'C'] = torch.tensor([losses[L,'C',k] for k in K_list])\n",
    "    losses_arrays[L, 'U'] = torch.tensor([losses[L,'U',k] for k in K_list])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, -0.07, 'Number of discretization steps of the backward SDE')"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 720x288 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from matplotlib import rc\n",
    "rc('font', **{'family': 'serif', 'serif': ['Computer Modern']})\n",
    "rc('text', usetex=True)\n",
    "fig, ax = plt.subplots(ncols=2, facecolor='white', figsize=(10,4), sharex=True)\n",
    "fs=20\n",
    "n_steps = [n/k for k in K_list]\n",
    "for a in [ax[0], ax[1]]:\n",
    "    a.set_xscale('log')\n",
    "    a.set_yscale('log')\n",
    "    a.grid('on')\n",
    "    a.set_ylim(0,1e2)\n",
    "    a.set_facecolor('gainsboro')\n",
    "    a.tick_params(axis='both',labelsize=fs)\n",
    "\n",
    "ax[0].set_title('SGM', fontsize=20)\n",
    "ax[1].set_title('WSGM', fontsize=20)\n",
    "#ax.plot(n_steps, torch.tensor([losses[32,'M',k] for k in K_list]), 'o-', label=\"32,M\")\n",
    "#ax.plot(n_steps, torch.tensor([losses[16,'M',k] for k in K_list]), 'o-', label=\"16,M\")\n",
    "ax[0].plot(n_steps, torch.tensor([losses[8,'U',k] for k in K_list]), 'd-', label=\"$L$=8\")\n",
    "ax[0].plot(n_steps, torch.tensor([losses[16,'U',k] for k in K_list]), 'd-', label=\"$L$=16\")\n",
    "#ax.plot(n_steps, torch.tensor([losses[8,'M',k] for k in K_list]), 'o-', label=\"8,M\")\n",
    "ax[0].plot(n_steps, torch.tensor([losses[32,'U',k] for k in K_list]), 'd-', label=\"$L$=32\")\n",
    "ax[1].plot(n_steps, torch.tensor([losses[8,'C',k] for k in K_list]), 'v-', label=\"$L$=8\")\n",
    "ax[1].plot(n_steps, torch.tensor([losses[16,'C',k] for k in K_list]), 'v-', label=\"$L$=16\")\n",
    "ax[1].plot(n_steps, torch.tensor([losses[32,'C',k] for k in K_list]), 'v-', label=\"$L$=32\")\n",
    "ax[1].legend(fontsize=fs)\n",
    "#ax[0].legend(fontsize=fs)\n",
    "\n",
    "\n",
    "ax[0].set_ylabel('error', fontsize=20)\n",
    "\n",
    "\n",
    "fig.supxlabel('Number of discretization steps of the backward SDE', fontsize=23, y=-0.07)\n",
    "\n",
    "\n",
    "#plt.savefig(f\"save/img/perf_vs_steps_phi4_langevin{n_langevin}.png\", dpi=200, bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 155,
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_N(dic, n_steps, epsilon=1.):\n",
    "    N = {}\n",
    "    fits = {}\n",
    "    for L in L_list:\n",
    "        fits[L, 'C'] = np.polyfit(np.log(n_steps), np.log(dic[L,'C']), deg=1)\n",
    "        fits[L, 'U'] = np.polyfit(np.log(n_steps), np.log(dic[L, 'U']), deg=1)\n",
    "        N[L, 'C'] = np.exp((np.log(epsilon) - fits[L, 'C'][1] ) / fits[L, 'C'][0])\n",
    "        N[L, 'U'] = np.exp((np.log(epsilon) - fits[L, 'U'][1] ) / fits[L, 'U'][0])\n",
    "    return N\n",
    "\n",
    "N = compute_N(losses_arrays, n_steps)\n",
    "\n",
    "fitC = np.polyfit(np.log(L_list), np.log(np.array([N[l, 'C'] for l in L_list])), deg=1)\n",
    "fit = np.polyfit(np.log(L_list), np.log(np.array([N[l, 'U'] for l in L_list])), deg=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 156,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 360x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fs=20\n",
    "import numpy as np\n",
    "L_list = [8,16,32]\n",
    "fig,axs = plt.subplots(facecolor='white', figsize=(5,4))\n",
    "axs.grid('on')\n",
    "axs.set_facecolor('gainsboro')\n",
    "axs.set_yscale('log')\n",
    "axs.set_xlabel(r'system size $L$', fontsize=fs)\n",
    "axs.set_ylabel(r'$N(\\varepsilon=0.1)$', fontsize=fs)\n",
    "axs.scatter(np.log(L_list), [N[l,'C'] for l in L_list], s=70, marker=\"s\", label=\"WSGM\")\n",
    "axs.scatter(np.log(L_list), [N[l, 'U'] for l in L_list], s=70, marker=\"s\", label=\"SGM\")\n",
    "#axs.plot(np.log(L_list), np.exp(fitC[0]*np.log(L_list) + fitC[1]))\n",
    "#axs.plot(np.log(L_list), np.exp(fit[0]*np.log(L_list) + fit[1]))\n",
    "#axs.legend(fontsize=15)\n",
    "#axs.set_ylim(50, 100000)\n",
    "#axs.set_title(rf\"$\\eta={eta}$\", fontsize=fs)\n",
    "axs.set_xticks(np.log(L_list))\n",
    "axs.set_xticklabels(L_list, fontsize=fs)\n",
    "axs.set_xlim(np.log(7), np.log(35))\n",
    "#axs.text(np.log(16), 5e+02, rf\"slope $\\approx$ {fit[0]:2.2f}.\", fontsize=30, color='tab:orange')\n",
    "plt.savefig(f\"save/img/N_versus_L_phi4_langevin{n_langevin}.png\", dpi=200, bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 360x360 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "phi32 = torch.load(\"save/data/phi4_32.pt\")\n",
    "fig, ax = plt.subplots(ncols=2, nrows=2, facecolor='white', figsize=(5,5))\n",
    "ax[0,0].imshow(phi32[84,0])\n",
    "ax[0,1].imshow(phi32[11,0])\n",
    "ax[1,0].imshow(results_cascaded[3][9,0])\n",
    "ax[1,1].imshow(results_cascaded[3][6,0])\n",
    "for a in [ax[0,0], ax[0,1], ax[1,0], ax[1,1]]:\n",
    "    a.set_xticks([])\n",
    "    a.set_yticks([])\n",
    "fs=22\n",
    "ax[0,0].set_ylabel('true', fontsize=fs)\n",
    "ax[1,0].set_ylabel('syntheses', fontsize=fs)\n",
    "plt.subplots_adjust(wspace=0, hspace=0.1)\n",
    "plt.savefig(\"save/img/examples_syntheses_true.png\", dpi=200)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "545af77b2f3ab44a1e507fdefb100bcaf2d5c79f57eff8b35b653a648f62a247"
  },
  "kernelspec": {
   "display_name": "Python 3.10.4 ('Hamilton')",
   "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
}
