{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "from models.diffusion import Covariance\n",
    "from data.generator import compute_psd_analytically\n",
    "from utils.loss import dkl_gaussian, operator_loss\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def condition_wavelets(mat):\n",
    "    ret = mat[1:,1:,:,:] - mat[1:,0,:,:] * mat[0,1:,:,:] / mat[0,0,:,:]\n",
    "    return ret\n",
    "\n",
    "def standardize(psd, mode):\n",
    "    if mode=='norm':\n",
    "        return psd / torch.max(psd)\n",
    "    elif mode=='trace':\n",
    "        return (psd.shape[-1]**2) * psd / torch.sum(psd)\n",
    "    elif mode==None:\n",
    "        return psd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def generate_final_covar(T, n_steps, L, eta, xi, unit_norm=True):\n",
    "    #k = torch.zeros(L,L)\n",
    "    #k[0,0]=1.\n",
    "    psd = torch.tensor(compute_psd_analytically(L,eta,xi))\n",
    "    if unit_norm:\n",
    "        psd = standardize(psd, mode=None)\n",
    "        \n",
    "    Sigma = Covariance(psd)\n",
    "    #Sigma = Covariance(torch.fft.fft2(k))\n",
    "    l = int(L/2)\n",
    "    id_lofreq = torch.zeros(4,4,l,l)\n",
    "    id_lofreq[0,0,:,:] = torch.ones(l,l)\n",
    "    id_lofreq = id_lofreq.permute(3,2,1,0)\n",
    "    id_hifreq = Sigma.identity_on_wavelets.permute(3,2,1,0)\n",
    "    id = id_lofreq + id_hifreq\n",
    "    #print(id[1,2,:,:], id_lofreq[2,1,:,:],id_hifreq[2,1,:,:])\n",
    "    delta = T / n_steps\n",
    "    state = Sigma(1000).permute(3,2,1,0).cfloat()\n",
    "    times = torch.linspace(0,T,n_steps)\n",
    "    for t in times:\n",
    "        #A = \n",
    "        A = id + delta*torch.matmul(id_hifreq.cfloat(), (id - 2*Sigma.inverse(T-t).permute(3,2,1,0)).cfloat())\n",
    "        state = torch.matmul(A, torch.matmul(state, torch.conj(A.transpose(2,3)))) + 2*delta*id_hifreq\n",
    "    state = state.permute(3,2,1,0)\n",
    "    true = Sigma(0)#condition_wavelets(Sigma(0))\n",
    "    estimated = state #condition_wavelets(state)\n",
    "    return operator_loss(true, estimated, fourier_wavelets=True), true, estimated"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def generate_covar(T, n_steps, L, eta, xi, unit_norm=True):\n",
    "    #k = torch.zeros(L,L)\n",
    "    #k[0,0]=1.\n",
    "    #psd = torch.fft.fft2(k)\n",
    "    \n",
    "    psd = torch.from_numpy(compute_psd_analytically(L,eta,xi))\n",
    "    if unit_norm:\n",
    "        psd = standardize(psd, mode=None)\n",
    "\n",
    "    delta = T / n_steps\n",
    "    ones = torch.ones_like(psd)\n",
    "    state = torch.ones_like(psd)\n",
    "    times = torch.linspace(0,T,n_steps)\n",
    "    for t in times:\n",
    "        A = ones + delta * (ones - 2 / (ones + np.exp(-2*(T-t))*(psd - ones)))\n",
    "        state = A * ( state * A.transpose(1,0))\n",
    "        state += 2*delta\n",
    "    return operator_loss(psd, state), state, psd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "8\n",
      "16\n",
      "32\n",
      "64\n"
     ]
    }
   ],
   "source": [
    "T = 10\n",
    "eta = 2\n",
    "L_list = [8,16,32,64]#,64,128,256]\n",
    "Xi_list = [8,16,32,64]\n",
    "n_steps = [50,100,250,500,750,1000,5000,10000,25000]#, 50000]\n",
    "R = {}\n",
    "RC = {}\n",
    "for L in L_list:\n",
    "    print(L)\n",
    "    for xi in [L]:\n",
    "        R[xi,L] = [generate_covar(T,n,L,eta,xi) for n in n_steps]\n",
    "        RC[xi,L] = [generate_final_covar(T,n,L,eta,xi) for n in n_steps]\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 165,
   "metadata": {},
   "outputs": [],
   "source": [
    "#torch.save(RC, f\"save/experiments/gaussian_covariances_cond_{eta}.pt\") \n",
    "#torch.save(R, f\"save/experiments/gaussian_covariances_{eta}.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 166,
   "metadata": {},
   "outputs": [],
   "source": [
    "eta=2\n",
    "#RC = torch.load(f\"save/experiments/gaussian_covariances_cond_{eta}.pt\") \n",
    "#R = torch.load(f\"save/experiments/gaussian_covariances_{eta}.pt\")  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 720x288 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "from matplotlib import rc\n",
    "\n",
    "L_list = [8,16,32,64]#,64,128,256]\n",
    "Xi_list = [8,16,32,64]\n",
    "#n_steps = [10,100,250,500,750,1000,5000,10000,25000, 50000]\n",
    "\n",
    "rc('font', **{'family': 'serif', 'serif': ['Computer Modern']})\n",
    "rc('text', usetex=True)\n",
    "\n",
    "fig,ax = plt.subplots(ncols=2, facecolor='white', figsize=(10,4), sharex=True)\n",
    "ax[0].axhline(0.1, color='gray')\n",
    "ax[1].axhline(0.1, color='gray')\n",
    "for L in L_list:\n",
    "    ax[0].plot(n_steps, torch.tensor([a[0] for a in R[L,L]]), 'o--', label=rf\"$L={L}$\")\n",
    "    ax[1].plot(n_steps, torch.tensor([a[0] for a in RC[L,L]]), 'o--', label=rf\"$L={L}$\")\n",
    "    for a in ax:\n",
    "        a.grid('on')\n",
    "        a.set_xscale('log')\n",
    "        a.set_yscale('log')\n",
    "        #a.set_ylim(0.000001, 50000)\n",
    "        #a.set_xticks(n_steps)\n",
    "        #a.set_xticklabels(n_steps)\n",
    "    ax[0].set_title('SGM', fontsize=20)\n",
    "    ax[1].set_title('WSGM', fontsize=20)\n",
    "fig.supxlabel('Number of discretization steps of the backward SDE', fontsize=23, y=-0.07)\n",
    "ax[0].set_ylabel('error', fontsize=20)\n",
    "ax[1].legend(fontsize=20)\n",
    "for a in [ax[0], ax[1]]:\n",
    "    a.tick_params(axis='both',labelsize=20)\n",
    "    a.set_facecolor('gainsboro')\n",
    "#plt.savefig(f\"save/img/spec_pow_vs_L_{eta}.png\", dpi=200, bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_N(dic, n_steps, epsilon=0.1):\n",
    "    N = {}\n",
    "    fits = {}\n",
    "    for L in L_list:\n",
    "        y = np.array([a[0] for a in dic[L,L]])\n",
    "        fits[L] = np.polyfit(np.log(n_steps), np.log(y), deg=1)\n",
    "        N[L] = np.exp((np.log(epsilon) - fits[L][1] ) / fits[L][0])\n",
    "    return N\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "N = compute_N(R, n_steps)\n",
    "NC = compute_N(RC, n_steps)\n",
    "\n",
    "fitC = np.polyfit(np.log(L_list), np.log(np.array([NC[l] for l in L_list])), deg=1)\n",
    "fit = np.polyfit(np.log(L_list), np.log(np.array([N[l] for l in L_list])), deg=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "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",
    "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'image size $L$', fontsize=fs)\n",
    "axs.set_ylabel(r'$N(\\varepsilon=0.1)$', fontsize=fs)\n",
    "axs.scatter(np.log(L_list), NC.values(), s=70, marker=\"s\", label=\"WSGM\")\n",
    "axs.scatter(np.log(L_list), N.values(), 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.text(np.log(16), 5e+03, rf\"slope $\\approx$ {fit[0]:2.2f}.\", fontsize=30, color='tab:orange')\n",
    "plt.savefig(f\"save/img/N_versus_L_{eta}.png\", dpi=200, bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Tests pour la DKL"
   ]
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "1bb6e5138cd3520c19446065856beb497a94efc3da670eca3839516d0de1ddb7"
  },
  "kernelspec": {
   "display_name": "Python 3.9.7 ('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.9.7"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
