{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "marine-movie",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import torch.optim as optim\n",
    "\n",
    "from demo_components import MaximalCodingRateReduction, Z_loss, chunk_avg, Gumble_Softmax, get_data, MLP_net"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "regulation-functionality",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7fcbff4ecdc0>"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "#Display original data\n",
    "x, cluster_id = get_data(2000)\n",
    "plt.scatter(x[:,0],x[:,1],c=cluster_id)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "civil-amazon",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "#Train\n",
    "n_steps = 30000\n",
    "print_every = 50\n",
    "bs = 4096\n",
    "\n",
    "#task variables\n",
    "amb_dim = 2\n",
    "z_dim = 6\n",
    "noise = 0.\n",
    "n_clusters = 2\n",
    "aug_noise = 0.2\n",
    "\n",
    "net = MLP_net(amb_dim,128,z_dim,n_clusters)\n",
    "\n",
    "optimizer = optim.Adam(net.parameters(),lr=0.001,betas=(0.9,0.99),weight_decay=0.00001)\n",
    "G_Softmax = Gumble_Softmax(0.2,straight_through=False)\n",
    "\n",
    "criterion = MaximalCodingRateReduction(eps=0.01,gamma=1.0)\n",
    "criterion_z = Z_loss()\n",
    "\n",
    "for i in range(n_steps):\n",
    "    x, _ = get_data(bs,contrastive=True,aug_noise=aug_noise)\n",
    "    x = torch.cat(x,dim=0).float()\n",
    "\n",
    "    z, logits = net(x)\n",
    "    loss_z, z_sim = criterion_z(z)\n",
    "    z_sim = z_sim.mean()\n",
    "    \n",
    "    prob = G_Softmax(logits)\n",
    "    z, prob = chunk_avg(z,n_chunks=2,normalize=True), chunk_avg(prob,n_chunks=2)\n",
    "    \n",
    "    loss, loss_list= criterion(z,prob,num_classes=n_clusters)\n",
    "    \n",
    "    loss += 4000*loss_z\n",
    "    \n",
    "    optimizer.zero_grad()\n",
    "    loss.backward()\n",
    "    optimizer.step()\n",
    "    \n",
    "    if i%print_every == 0:\n",
    "        print('{} steps done, loss c {}, loss d {}, z sim {}'.format(i+1,loss_list[0],loss_list[1],z_sim.item()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "preceding-roller",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "#visualize clustering\n",
    "n_samples = 4096\n",
    "x, cluster_ids = get_data(n_samples,contrastive=True,aug_noise=aug_noise)\n",
    "x = x[0].float()\n",
    "with torch.no_grad():\n",
    "    z, logits = net(x)\n",
    "    preds = logits.max(dim=1)[1]\n",
    "x = x.detach()\n",
    "\n",
    "#plotting\n",
    "fig, ax = plt.subplots()\n",
    "ax.scatter(x[:,0],x[:,1],c=preds)\n",
    "ax.set_xlim(xmin=-16,xmax=16)\n",
    "ax.set_ylim(ymin=-16,ymax=16)\n",
    "ax.set_aspect('equal')\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.8.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
