{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "4354e05e",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('..')\n",
    "\n",
    "from tqdm import tqdm\n",
    "import matplotlib.pyplot as plt\n",
    "import torch\n",
    "\n",
    "from models import OrthogonalSOS as OSOS\n",
    "from models import SOS\n",
    "from datasets.wrappers.artificial import *\n",
    "from scripts.utils import num_parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "4c400453-8b16-4acd-8360-727b2480ce85",
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.set_default_dtype(torch.float64)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "19426565",
   "metadata": {},
   "outputs": [],
   "source": [
    "from matplotlib.ticker import MaxNLocator\n",
    "\n",
    "def plot_2D(fn1, fn2, title=None):\n",
    "\n",
    "    x_min, x_max = -3.0, 3.0\n",
    "    y_min, y_max = -3.0, 3.0\n",
    "\n",
    "    dx, dy = 0.01, 0.01\n",
    "\n",
    "    # generate 2 2d grids for the x & y bounds\n",
    "    y, x = np.mgrid[slice(y_min, y_max + dy, dy),\n",
    "                    slice(x_min, x_max + dx, dx)]\n",
    "\n",
    "    xy = torch.from_numpy(np.hstack((x.reshape(-1, 1), y.reshape(-1, 1)))).float()\n",
    "    with torch.no_grad():\n",
    "        z2 = fn2(xy)\n",
    "    z2 = z2.view(y.shape).numpy()\n",
    "    z2 = z2[:-1, :-1]\n",
    "\n",
    "    cmap = plt.colormaps['PiYG']                    \n",
    "    \n",
    "    fig, (ax0, ax1) = plt.subplots(ncols=2, figsize=(11, 5))\n",
    "\n",
    "    samples = fn1(1000)\n",
    "    ax0.scatter(samples[:,0], samples[:, 1])\n",
    "    \n",
    "    levels = MaxNLocator(nbins=15).tick_values(z2.min(), z2.max())\n",
    "    cf = ax1.contourf(x[:-1, :-1] + dx/2.,\n",
    "                    y[:-1, :-1] + dy/2., z2, levels=levels,\n",
    "                    cmap=cmap)\n",
    "    fig.colorbar(cf, ax=ax1)\n",
    "    if title is not None:\n",
    "        ax1.set_title(title)\n",
    "\n",
    "    # adjust spacing between subplots so `ax1` title and `ax0` tick labels\n",
    "    # don't overlap\n",
    "    fig.tight_layout()\n",
    "\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "33eda07f",
   "metadata": {},
   "outputs": [],
   "source": [
    "sample_functions = {\n",
    "    'crossing-rings': crossing_rings_sample,\n",
    "    'rings': rings_sample,\n",
    "    'ring': single_ring_sample,\n",
    "    'mring': multi_rings_sample,\n",
    "    'funnel': funnel_sample,\n",
    "    'banana': banana_sample,\n",
    "    'cosine': cosine_sample, \n",
    "    'spiral': spiral_sample,\n",
    "}\n",
    "\n",
    "dataset_name = 'crossing-rings'\n",
    "dataset_name = 'spiral'\n",
    "gt_fn = sample_functions[dataset_name]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "e28ae3ca",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x72bc29ab8510>"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = gt_fn(1000,)\n",
    "plt.scatter(x[:, 0], x[:, 1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "c3ceb94b",
   "metadata": {},
   "outputs": [],
   "source": [
    "from matplotlib.ticker import MaxNLocator\n",
    "\n",
    "@torch.no_grad()\n",
    "def plot_contour(fn, ax, lims, nsamples : int = 1000):\n",
    "    cmap = plt.colormaps['PiYG']\n",
    "\n",
    "    [[xmin, xmax], [ymin, ymax]] = lims\n",
    "    dx, dy = (xmax - xmin) / nsamples, (ymax - ymin) / nsamples,\n",
    "\n",
    "    # generate 2 2d grids for the x & y bounds\n",
    "    y, x = np.mgrid[slice(ymin, ymax + dy, dy),\n",
    "                    slice(xmin, xmax + dx, dx)]\n",
    "\n",
    "    xy = torch.from_numpy(np.hstack((x.reshape(-1, 1), y.reshape(-1, 1)))).float()\n",
    "\n",
    "    z = fn(xy)\n",
    "    z = z.view(y.shape).numpy()\n",
    "    z = z[:-1, :-1]\n",
    "\n",
    "    levels = MaxNLocator(nbins=15).tick_values(z.min(), z.max())\n",
    "    return ax.contourf(\n",
    "        x[:-1, :-1] + dx/2.,\n",
    "        y[:-1, :-1] + dy/2., z, levels=levels,\n",
    "        cmap=cmap\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1c849081",
   "metadata": {},
   "outputs": [],
   "source": [
    "from torch.optim.lr_scheduler import CosineAnnealingLR\n",
    "from optimization.landing import LandingStiefelSGD\n",
    "from optimization.landingadam import LandingStiefelAdam\n",
    "\n",
    "outputs = {}\n",
    "\n",
    "def train_model(sampling_function, num_units, *, use_fourier: bool, use_tucker: bool, complex: bool, use_osos: bool, xlim = [-3., 3.]):\n",
    "    n_iters = 3000\n",
    "    bs = 1024\n",
    "    xmin, xmax = xlim\n",
    "\n",
    "    circuit_class = OSOS if use_osos else SOS\n",
    "\n",
    "    model = circuit_class(\n",
    "        2,\n",
    "        image_shape=None,\n",
    "        num_input_units=num_units,\n",
    "        num_sum_units=num_units,\n",
    "        input_layer='fourier' if use_fourier else 'gaussian',\n",
    "        input_layer_kwargs=dict(period=[xmax-xmin]*2),\n",
    "        num_squares=3,\n",
    "        region_graph='rnd-bt',\n",
    "        structured_decomposable=True,\n",
    "        complex=complex,\n",
    "        seed=21424,\n",
    "        use_tucker=use_tucker,\n",
    "    )\n",
    "    print('Number of parameters:', num_parameters(model))\n",
    "\n",
    "    if use_osos:\n",
    "        optim = LandingStiefelAdam(model.parameters(), lr=1e-2, lambda_regul=0.1, dproject=True)\n",
    "    else:\n",
    "        optim = torch.optim.Adam(model.parameters(), lr=1e-3)\n",
    "\n",
    "    model.train()\n",
    "    pbar = tqdm(range(n_iters))\n",
    "    scheduler = CosineAnnealingLR(optim, T_max=n_iters)\n",
    "\n",
    "    for epoch in pbar:\n",
    "        optim.zero_grad()            \n",
    "\n",
    "        x = torch.from_numpy(sampling_function(bs, seed=epoch)).to(dtype=torch.get_default_dtype())\n",
    "        x += torch.rand_like(x) * 0.1\n",
    "\n",
    "        loss = -model.log_likelihood(x).mean(dim=0)\n",
    "        loss.backward()\n",
    "        optim.step()\n",
    "\n",
    "        pbar.set_description(f'Loss: {loss.item():.4f}')\n",
    "        scheduler.step()\n",
    "    \n",
    "    if use_osos:\n",
    "        with torch.no_grad():\n",
    "            print('Projecting...')\n",
    "            for p in model.parameters():\n",
    "                if hasattr(p, 'proj_'):\n",
    "                    p.proj_() # type: ignore\n",
    "\n",
    "    return model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "c4ae4aad",
   "metadata": {},
   "outputs": [],
   "source": [
    "circuits = dict()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "47f5b6a2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of parameters: 5544\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 2.8354: 100%|██████████| 3000/3000 [02:01<00:00, 24.69it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Projecting...\n",
      "Number of parameters: 5670\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 2.7585: 100%|██████████| 3000/3000 [01:46<00:00, 28.06it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of parameters: 5544\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 2.7561: 100%|██████████| 3000/3000 [02:01<00:00, 24.75it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of parameters: 336\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 2.8635: 100%|██████████| 3000/3000 [07:00<00:00,  7.14it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of parameters: 2772\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 2.7576: 100%|██████████| 3000/3000 [01:02<00:00, 47.72it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Projecting...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "name = 'crossing-rings'\n",
    "gt_fn = sample_functions[name]\n",
    "\n",
    "circuits[name] = dict()\n",
    "circuits[name]['osos_fourier'] = train_model(gt_fn, 21, use_fourier=True, use_tucker=False, complex=True, use_osos=True, xlim=[-3.,3.])\n",
    "circuits[name]['sos_gaussian'] = train_model(gt_fn, 21, use_fourier=False, use_tucker=False, complex=True, use_osos=False)\n",
    "circuits[name]['sos_fourier'] = train_model(gt_fn, 21, use_fourier=True, use_tucker=False, complex=True, use_osos=False, xlim=[-3.,3.])\n",
    "circuits[name]['sos_fourier_tucker'] = train_model(gt_fn, 7, use_fourier=True, use_tucker=True, complex=True, use_osos=False, xlim=[-3.,3.])\n",
    "circuits[name]['osos_fourier_tucker'] = train_model(gt_fn, 21, use_fourier=True, use_tucker=True, complex=True, use_osos=True, xlim=[-3.,3.])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "d71ba4a3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of parameters: 5670\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 3.6269: 100%|██████████| 3000/3000 [01:21<00:00, 36.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of parameters: 5544\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 3.5192: 100%|██████████| 3000/3000 [01:29<00:00, 33.38it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of parameters: 5544\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 3.6558: 100%|██████████| 3000/3000 [01:30<00:00, 33.25it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Projecting...\n",
      "Number of parameters: 336\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 3.8497: 100%|██████████| 3000/3000 [06:35<00:00,  7.58it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of parameters: 2772\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Loss: 3.5405: 100%|██████████| 3000/3000 [01:06<00:00, 44.84it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Projecting...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "name = 'spiral'\n",
    "gt_fn = sample_functions[name]\n",
    "\n",
    "circuits[name] = dict()\n",
    "circuits[name]['sos_gaussian'] = train_model(gt_fn, 21, use_fourier=False, use_tucker=False, complex=True, use_osos=False)\n",
    "circuits[name]['sos_fourier'] = train_model(gt_fn, 21, use_fourier=True, use_tucker=False, complex=True, use_osos=False, xlim=[-6.,6.])\n",
    "circuits[name]['osos_fourier'] = train_model(gt_fn, 21, use_fourier=True, use_tucker=False, complex=True, use_osos=True, xlim=[-6.,6.])\n",
    "circuits[name]['sos_fourier_tucker'] = train_model(gt_fn, 7, use_fourier=True, use_tucker=True, complex=True, use_osos=False, xlim=[-6.,6.])\n",
    "circuits[name]['osos_fourier_tucker'] = train_model(gt_fn, 21, use_fourier=True, use_tucker=True, complex=True, use_osos=True, xlim=[-6.,6.])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0f8a1991",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 550x183.333 with 12 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from tueplots import figsizes, bundles\n",
    "\n",
    "titles = {\n",
    "    'sos_gaussian': r'\\shortstack{$\\pm_\\mathbb{C}^2$ CP\\\\Gaussian}',\n",
    "    'sos_fourier': r'\\shortstack{$\\pm_\\mathbb{C}^2$ CP\\\\Fourier}',\n",
    "    'osos_fourier': r'\\shortstack{$\\perp_\\mathbb{C}^2$ CP\\\\Fourier}',\n",
    "    'sos_fourier_tucker': r'\\shortstack{$\\pm_\\mathbb{C}^2$ Tucker\\\\Fourier}',\n",
    "    'osos_fourier_tucker': r'\\shortstack{$\\perp_\\mathbb{C}^2$ Tucker\\\\Fourier}',\n",
    "}\n",
    "\n",
    "titles = {\n",
    "    'sos_gaussian': r'\\shortstack{$\\pm_\\mathbb{C}^2$\\\\Gaussian\\\\Hadamard}',\n",
    "    'sos_fourier': r'\\shortstack{$\\pm_\\mathbb{C}^2$\\\\Fourier\\\\Hadamard}',\n",
    "    'osos_fourier': r'\\shortstack{$\\perp_\\mathbb{C}^2$\\\\Fourier\\\\Hadamard}',\n",
    "    'sos_fourier_tucker': r'\\shortstack{$\\pm_\\mathbb{C}^2$\\\\Fourier\\\\Kronecker}',\n",
    "    'osos_fourier_tucker': r'\\shortstack{$\\perp_\\mathbb{C}^2$\\\\Fourier\\\\Kronecker}',\n",
    "}\n",
    "\n",
    "plt.close('all')\n",
    "plt.rcParams.update(bundles.iclr2024(usetex=True))\n",
    "plt.rc('text.latex', preamble=r'\\usepackage{amssymb,amsmath}')\n",
    "\n",
    "with plt.rc_context(figsizes.iclr2024(nrows=2, ncols=6, height_to_width_ratio=1.)):\n",
    "    fig, axes = plt.subplots(nrows=2, ncols=6, sharey='row')\n",
    "\n",
    "    # Crossing rings\n",
    "    name = 'crossing-rings'\n",
    "    fax = axes[0].flat[0]\n",
    "    samples = sample_functions[name](1000)\n",
    "    fax.scatter(samples[:,0], samples[:, 1], s=0.25)\n",
    "    fax.set_title('Samples')\n",
    "\n",
    "    for ax, key in zip(axes[0].flat[1:], titles.keys()):\n",
    "        circuit = circuits[name][key]\n",
    "\n",
    "        plot_contour(\n",
    "            fn=lambda x: circuit.log_likelihood(x).exp().real,\n",
    "            ax=ax,\n",
    "            lims=[fax.get_xlim(), fax.get_ylim()],\n",
    "            nsamples=100,\n",
    "        )\n",
    "        ax.set_title(titles[key])\n",
    "        ax.set_xticks([])\n",
    "\n",
    "    fax.set_ylabel('Spinner')\n",
    "    fax.set_yticks([])\n",
    "    fax.set_xticks([])\n",
    "\n",
    "    # Spiral\n",
    "    name = 'spiral'\n",
    "    fax = axes[1].flat[0]\n",
    "    samples = sample_functions[name](1000)\n",
    "    fax.scatter(samples[:,0], samples[:, 1], s=0.25)\n",
    "    fax.set_ylim(-5, 5)\n",
    "    fax.set_xlim(-5, 5)\n",
    "    \n",
    "    for ax, (key, circuit) in zip(axes[1].flat[1:], circuits[name].items()):\n",
    "        plot_contour(\n",
    "            fn=lambda x: circuit.log_likelihood(x).exp().real,\n",
    "            ax=ax,\n",
    "            lims=[fax.get_xlim(), fax.get_ylim()],\n",
    "            nsamples=100,\n",
    "        )\n",
    "        ax.set_xticks([])\n",
    "\n",
    "    fax.set_ylabel('Spiral')\n",
    "    fax.set_yticks([])\n",
    "    fax.set_xticks([])\n",
    "    \n",
    "    fig.savefig('2d-fourier.pdf', dpi=250)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5c347c0c",
   "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.11.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
