{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from labproject.metrics.wasserstein_sinkhorn import sinkhorn_loss,sinkhorn_algorithm\n",
    "from labproject.metrics.wasserstein_kuhn import kuhn_transport\n",
    "from labproject.data import get_distribution\n",
    "from labproject.utils import set_seed\n",
    "from dataclasses import dataclass\n",
    "set_seed(0)\n",
    "plt.rcParams['figure.dpi'] = 150\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Figure size handling\n",
    "\n",
    "dpi = 150\n",
    "plt.style.use(\"../../../matplotlibrc\")\n",
    "plt.rcParams.update({\"figure.dpi\": dpi})\n",
    "\n",
    "\n",
    "\n",
    "@dataclass\n",
    "class FigureLayout:\n",
    "    width_in_pt: float\n",
    "    width_grid: int\n",
    "    base_font_size: int = 8\n",
    "    scale_factor: float = 1.0\n",
    "\n",
    "    # matplotlib uses inch\n",
    "    def _get_grid_in_inch(self, w_grid, h_grid):\n",
    "        pt_to_inch = 1 / 72\n",
    "        assert w_grid <= self.width_grid\n",
    "        return (\n",
    "            (w_grid / self.width_grid) * self.width_in_pt * pt_to_inch,\n",
    "            (h_grid / self.width_grid) * self.width_in_pt * pt_to_inch,\n",
    "        )\n",
    "\n",
    "    def get_rc(self, w_grid, h_grid):\n",
    "        return {\n",
    "            \"figure.figsize\": self._get_grid_in_inch(w_grid, h_grid),\n",
    "            \"font.size\": self.base_font_size * self.scale_factor,\n",
    "        }\n",
    "    \n",
    "textwidth=469\n",
    "fig_handler = FigureLayout(469,100)\n",
    "params = fig_handler.get_rc(75,25)\n",
    "plt.rcParams.update(params)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Load data\n",
    "\n",
    "We load in the toy mixture of Gaussians distribution in 2 dimensions as the base dataset.\n",
    "We then define an augmented approximate distribution by changing the parameters of the mixture of gaussians."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7fbc6a2d2ac0>"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 732.812x244.271 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#Base distribution\n",
    "toy_data = get_distribution(\"toy_2d\")\n",
    "datagen = toy_data()\n",
    "data = datagen.sample(1000)\n",
    "\n",
    "def update_toy_mog(datagen,means,covs,weights):\n",
    "    datagen.means = means\n",
    "    datagen.covs = covs\n",
    "    datagen.weights = weights\n",
    "\n",
    "    datagen.gaussians = [\n",
    "        torch.distributions.MultivariateNormal(mean, covariance)\n",
    "        for mean, covariance in zip(datagen.means, datagen.covariances)\n",
    "    ]    \n",
    "    return datagen\n",
    "\n",
    "means2 = torch.Tensor([\n",
    "            [0.0, 2.5],\n",
    "            [-1.0, -0.5],\n",
    "            [1.0, -2.0],\n",
    "            [-2.0, -1.0],\n",
    "        ])\n",
    "            \n",
    "covariances2 = torch.tensor(\n",
    "                        [\n",
    "                            [[1.0, 0.2], [0.2, 1.0]],\n",
    "                            [[1.0, -0.7], [-0.7, 1.0]],\n",
    "                            [[1.0, 0.0], [0.0, 1.0]],\n",
    "                            [[0.5, 0.0], [0.0, 0.5]],\n",
    "                        ]\n",
    "                        )\n",
    "weights2 = torch.tensor([0.3, 0.2, 0.1, 0.5])\n",
    "\n",
    "#Augmented distribution\n",
    "datagen2 = update_toy_mog(datagen,means2,covariances2,weights2)\n",
    "data2 = datagen2.sample(1000)\n",
    "\n",
    "#Plot the data\n",
    "plt.scatter(data[:,0],data[:,1],color=\"C3\")\n",
    "plt.scatter(data2[:,0],data2[:,1],color=\"C1\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[2.1614, 4.2141, 5.7055, 2.0034, 7.4913, 4.8794, 4.4335, 5.2918, 2.0234,\n",
      "         2.3132],\n",
      "        [1.0383, 1.8318, 3.3747, 1.1247, 5.0778, 2.6363, 1.6756, 3.0079, 0.8178,\n",
      "         0.7740],\n",
      "        [0.0609, 2.8801, 4.4264, 1.4048, 5.3957, 2.7919, 2.5926, 3.2028, 0.4049,\n",
      "         0.2920],\n",
      "        [1.7768, 3.5335, 5.0160, 1.3217, 7.0831, 4.4964, 3.8264, 4.9046, 1.5265,\n",
      "         1.8634],\n",
      "        [1.9722, 0.8979, 2.4432, 1.5200, 5.0491, 2.9121, 1.1665, 3.2116, 1.7089,\n",
      "         1.7080],\n",
      "        [1.9818, 0.8942, 2.4310, 1.5699, 4.9896, 2.8618, 1.1065, 3.1584, 1.7298,\n",
      "         1.7165],\n",
      "        [3.2032, 2.4213, 3.0358, 3.6411, 2.7947, 1.5464, 1.1749, 1.5427, 3.2601,\n",
      "         2.9968],\n",
      "        [3.1501, 1.7525, 2.6581, 1.8034, 6.8736, 4.7903, 2.9118, 5.0956, 2.7253,\n",
      "         2.9576],\n",
      "        [1.9892, 1.0879, 2.5046, 1.8880, 4.5493, 2.4478, 0.7246, 2.7305, 1.8273,\n",
      "         1.7241],\n",
      "        [2.2002, 5.0501, 6.6018, 3.1890, 6.6666, 4.1625, 4.7059, 4.5443, 2.4662,\n",
      "         2.4672]])\n"
     ]
    }
   ],
   "source": [
    "# subsample and compute optimal transport map\n",
    "\n",
    "ndata = 10\n",
    "plot_data = data[:ndata]\n",
    "plot_data2 = data2[:ndata]\n",
    "pairdist = torch.cdist(plot_data,plot_data2) #This is the cost matrix, with the norm being the euclidean distance between two points!\n",
    "print(pairdist)\n",
    "\n",
    "cost,transport = kuhn_transport(plot_data,plot_data2,norm=2)\n",
    "indices = torch.arange(0,len(plot_data))\n",
    "permutation = transport.argmax(dim=1)\n",
    "plot_data2_copy = plot_data2[permutation]\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 488.542x244.271 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "#Plot the optimal transport map\n",
    "from mpl_toolkits.axes_grid1 import make_axes_locatable\n",
    "\n",
    "params = fig_handler.get_rc(50,25)\n",
    "plt.rcParams.update(params)\n",
    "\n",
    "fig,axs = plt.subplots(1,2)\n",
    "\n",
    "for ax in axs:\n",
    "    ax.set_xlabel(\"\")\n",
    "    ax.set_ylabel(\"\")\n",
    "    ax.set_xticks([])\n",
    "    ax.set_yticks([])\n",
    "    #ax.spines[['left', 'bottom']].set_visible(False)\n",
    "    ax.tick_params(which = 'both', size = 0, labelsize = 0)\n",
    "\n",
    "colors = plt.cm.Reds(pairdist/pairdist.max())\n",
    "sm = plt.cm.ScalarMappable(cmap=plt.cm.Reds, norm=plt.Normalize(vmin=0, vmax=1))\n",
    "sm._A = []\n",
    "divider = make_axes_locatable(axs[1])\n",
    "cbar = fig.colorbar(sm, ax=axs[1], fraction=0.046,pad=0.04,location='right')\n",
    "# cbar.set_title(\"Cost\")\n",
    "cbar.ax.set_ylabel(\"cost\",rotation=270,labelpad=10)\n",
    "cbar.ax.set_yticks([])\n",
    "\n",
    "\n",
    "axs[0].set_xlim(-5,4)\n",
    "axs[0].set_ylim(-4,5)\n",
    "for ind,p1,p2 in zip(indices,plot_data,plot_data2):\n",
    "    axs[0].arrow(p1[0],p1[1],p2[0]-p1[0],p2[1]-p1[1],head_width=0.2, head_length=0.2,length_includes_head=True,color = cbar.cmap(pairdist[ind,ind].item()/pairdist.max().item()))\n",
    "cost0 = pairdist[indices,indices].mean()\n",
    "axs[0].annotate(f\"total cost = {cost0.item():.1f}\",(-1.0,4.5),xytext=(0,0),textcoords=\"offset points\",ha=\"center\",va=\"center\",fontsize=8)\n",
    "axs[0].scatter(plot_data[:, 0], plot_data[:, 1],color=\"black\",s=10)\n",
    "axs[0].scatter(plot_data2[:, 0], plot_data2[:, 1],color=\"C10\",s=10)\n",
    "\n",
    "\n",
    "axs[1].set_xlim(-5,4)\n",
    "axs[1].set_ylim(-4,5)\n",
    "for ind,p1,p2 in zip(indices,plot_data,plot_data2_copy):\n",
    "    axs[1].arrow(p1[0],p1[1],p2[0]-p1[0],p2[1]-p1[1],head_width=0.2, head_length=0.2,length_includes_head=True,color = cbar.cmap(pairdist[ind,permutation[ind]].item()/pairdist.max().item()))\n",
    "cost1 = pairdist[indices,permutation].mean()\n",
    "axs[1].annotate(f\"total cost = {cost1.item():.1f}\",(-1.0,4.5),xytext=(0,0),textcoords=\"offset points\",ha=\"center\",va=\"center\",fontsize=8)\n",
    "axs[1].scatter(plot_data[:, 0], plot_data[:, 1],color=\"black\",s=10)\n",
    "axs[1].scatter(plot_data2_copy[:, 0], plot_data2_copy[:, 1],color=\"C10\",s=10)\n",
    "\n",
    "fig.tight_layout()\n",
    "fig.savefig(\"../../../plots/wasserstein_assignment.svg\")\n",
    "\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "labproject",
   "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.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
