{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Deep Learning with Topological Signatures\n",
    "\n",
    "https://arxiv.org/pdf/1707.04041.pdf\n",
    "\n",
    "### Evaluation on the fashion-mnist Dataset\n",
    "\n",
    "This notebook follows the same experimental methodology as the original with few differences adapted for the specific problem. \n",
    "\n",
    "Ref: https://github.com/c-hofer/jmlr_2019\n"
   ]
  },
  {
   "attachments": {
    "image.png": {
     "image/png": "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"
    }
   },
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "![image.png](attachment:image.png)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "torch.manual_seed(123)\n",
    "import random\n",
    "random.seed(123)\n",
    "\n",
    "\n",
    "import torch.nn as nn\n",
    "import os\n",
    "import shutil\n",
    "import itertools\n",
    "\n",
    "\n",
    "import core.config as config\n",
    "from chofer_tda_datasets import Animal\n",
    "from chofer_tda_datasets.transforms import Hdf5GroupToDict\n",
    "from core.utils import *\n",
    "\n",
    "from torchph.nn.slayer import SLayerExponential, \\\n",
    "SLayerRational, \\\n",
    "LinearRationalStretchedBirthLifeTimeCoordinateTransform, \\\n",
    "prepare_batch, SLayerRationalHat\n",
    "from sklearn.model_selection import ShuffleSplit\n",
    "from collections import Counter, defaultdict\n",
    "from torch.utils.data import DataLoader, RandomSampler\n",
    "from collections import OrderedDict\n",
    "from torch.autograd import Variable\n",
    "\n",
    "from sklearn.model_selection import StratifiedShuffleSplit\n",
    "\n",
    "%matplotlib notebook\n",
    "\n",
    "os.environ['CUDA_VISIBLE_DEVICES'] = str(1)\n",
    "\n",
    "\n",
    "class train_env:\n",
    "    nu = 0.01\n",
    "    n_epochs = 40\n",
    "    lr_initial = 0.01\n",
    "    momentum = 0.9\n",
    "    lr_epoch_step = 10\n",
    "    batch_size = 100\n",
    "used_directions = ['dim_0_dir_{}'.format(i) for i in range(0, 32,2)]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "\n",
    "# 32 directions of persistent homologies\n",
    "\n",
    "train_dataset, test_dataset = pickle.load(open(\"fmnist_dir_32.pckl\",\"rb\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "class PHTCollate:   \n",
    "    def __init__(self, nu, cuda=True, rotation_augmentation=False):\n",
    "        self.cuda = cuda\n",
    "        self.rotation_augmentation = rotation_augmentation\n",
    "        \n",
    "    def __call__(self, sample_target_iter):\n",
    "        \n",
    "        augmented_samples = []\n",
    "        if self.rotation_augmentation:\n",
    "            samples, targets = [], []\n",
    "            for x, y in sample_target_iter:                \n",
    "                i = random.randint(0, len(used_directions)-1)\n",
    "                shifted_keys = used_directions[i:] + used_directions[:i]                \n",
    "                \n",
    "                samples.append({k: x[ki] for k, ki in zip(used_directions, shifted_keys)})\n",
    "                targets.append(y)\n",
    "                \n",
    "            sample_target_iter = zip(samples, targets)\n",
    "\n",
    "        x, y = dict_sample_target_iter_concat(sample_target_iter)                                            \n",
    "                                              \n",
    "        for k in x.keys():\n",
    "            batch_view = x[k]\n",
    "            x[k] = prepare_batch(batch_view, 2)                  \n",
    "\n",
    "        y = torch.LongTensor(y)    \n",
    "\n",
    "        if self.cuda:\n",
    "            # Shifting the necessary parts of the prepared batch to the cuda\n",
    "            x = {k: collection_cascade(v,\n",
    "                                       lambda x: isinstance(x, tuple),\n",
    "                                       lambda x: (x[0].cuda(), x[1].cuda(), x[2], x[3]))\n",
    "                 for k, v in x.items()}\n",
    "\n",
    "            y = y.cuda()\n",
    "\n",
    "        return x, y                       \n",
    "    \n",
    "collate_fn = PHTCollate(train_env.nu, cuda=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def Slayer(n_elements):\n",
    "    return SLayerRationalHat(n_elements, radius_init=0.25, exponent=1)\n",
    "\n",
    "def LinearCell(n_in, n_out):\n",
    "    m = nn.Sequential(nn.Linear(n_in, n_out), \n",
    "                      nn.BatchNorm1d(n_out), \n",
    "                      nn.ReLU(),\n",
    "                     )\n",
    "    m.out_features = m[0].out_features\n",
    "    return m\n",
    "\n",
    "# Identical with AnimalModel used for the Animal Shapes for a fair comparison\n",
    "class FMnistModel(nn.Module):\n",
    "    def __init__(self):\n",
    "        super().__init__()   \n",
    "        self.n_elements = 100\n",
    "        \n",
    "        self.slayers = ModuleDict()\n",
    "        for k in used_directions:\n",
    "            s = Slayer(self.n_elements)\n",
    "            self.slayers[k] = nn.Sequential(s)            \n",
    "            \n",
    "        cls_in_dim = len(used_directions)*self.n_elements\n",
    "        self.cls = nn.Sequential(\n",
    "                                nn.Dropout(0.3),\n",
    "                                LinearCell(cls_in_dim, int(cls_in_dim/4)),    \n",
    "                                nn.Dropout(0.2),\n",
    "                                LinearCell(int(cls_in_dim/4), int(cls_in_dim/16)),  \n",
    "                                nn.Dropout(0.1),\n",
    "                                nn.Linear(int(cls_in_dim/16), 20))\n",
    "        \n",
    "    def forward(self, input):\n",
    "        x = []\n",
    "        for k in used_directions:            \n",
    "            xx = self.slayers[k](input[k])\n",
    "            x.append(xx)\n",
    "\n",
    "        x = torch.cat(x, dim=1)          \n",
    "        x = self.cls(x)       \n",
    "                                              \n",
    "        return x\n",
    "    \n",
    "    def center_init(self, sample_target_iter):\n",
    "        centers = k_means_center_init(sample_target_iter, self.n_elements)\n",
    "        \n",
    "        for k, v in centers.items():\n",
    "            self.slayers._modules[k][0].centers.data = v"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "dl_train = DataLoader(train_dataset,\n",
    "                      batch_size=train_env.batch_size, \n",
    "                      collate_fn=collate_fn,\n",
    "                      sampler=RandomSampler(train_dataset))\n",
    "\n",
    "dl_test = DataLoader(test_dataset,\n",
    "                     batch_size=train_env.batch_size, \n",
    "                     collate_fn=collate_fn, \n",
    "                     sampler=RandomSampler(test_dataset))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_slayer=True\n",
    "\n",
    "model = FMnistModel()\n",
    "model.center_init([i for i in train_dataset])\n",
    "model.cuda()\n",
    "\n",
    "\n",
    "opt = torch.optim.SGD(model.parameters() if train_slayer else model.cls.parameters(), \n",
    "                      lr=train_env.lr_initial, \n",
    "                      momentum=train_env.momentum)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "stats_of_runs = []\n",
    "\n",
    "stats = defaultdict(list)\n",
    "stats_of_runs.append(stats)\n",
    "for i_epoch in range(1, train_env.n_epochs+1):      \n",
    "\n",
    "    model.train()\n",
    "\n",
    "\n",
    "\n",
    "    epoch_loss = 0    \n",
    "\n",
    "    if i_epoch % train_env.lr_epoch_step == 0:\n",
    "        adapt_lr(opt, lambda lr: lr*0.5)\n",
    "\n",
    "    for i_batch, (x, y) in enumerate(dl_train, 1):              \n",
    "\n",
    "        y = torch.autograd.Variable(y)\n",
    "\n",
    "        def closure():\n",
    "            opt.zero_grad()\n",
    "            y_hat = model(x)            \n",
    "            loss = nn.functional.cross_entropy(y_hat, y)   \n",
    "            loss.backward()\n",
    "            return loss\n",
    "\n",
    "        loss = opt.step(closure)\n",
    "\n",
    "        epoch_loss += float(loss)\n",
    "        stats['loss_by_batch'].append(float(loss))\n",
    "        stats['centers'].append(model.slayers['dim_0_dir_0'][0].centers.data.cpu().numpy())\n",
    "\n",
    "        print(\"Epoch {}/{}, Batch {}/{}, Loss {}\".format(i_epoch, train_env.n_epochs, i_batch, len(dl_train),float(loss)), end=\"       \\r\")\n",
    "\n",
    "    stats['train_loss_by_epoch'].append(epoch_loss/len(dl_train))            \n",
    "\n",
    "    model.eval()    \n",
    "    true_samples = 0\n",
    "    seen_samples = 0\n",
    "    epoch_test_loss = 0\n",
    "\n",
    "    for i_batch, (x, y) in enumerate(dl_test):\n",
    "\n",
    "        y_hat = model(x)\n",
    "        epoch_test_loss += float(nn.functional.cross_entropy(y_hat, torch.autograd.Variable(y.cuda())).data)\n",
    "\n",
    "        y_hat = y_hat.max(dim=1)[1].data.long()\n",
    "\n",
    "        true_samples += (y_hat == y).sum()\n",
    "        seen_samples += y.size(0)  \n",
    "\n",
    "    test_acc = true_samples.item()/seen_samples\n",
    "    stats['test_accuracy'].append(test_acc)\n",
    "    stats['test_loss_by_epoch'].append(epoch_test_loss/len(dl_test))\n",
    "    print(\"Epoch {}/{}, Test Loss {} Test Acc. {}\".format(i_epoch, train_env.n_epochs, i_batch, epoch_test_loss/len(dl_test),test_acc, end=\"       \\n\"))\n",
    "\n",
    "\n",
    "print('acc.', np.mean(stats['test_accuracy'][-10:]))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "res_learned_slayer = experiment(True)\n",
    "accs = [np.mean(s['test_accuracy'][-10:]) for s in res_learned_slayer]\n",
    "print(accs)\n",
    "print(np.mean(accs))\n",
    "print(np.std(accs))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "stats = res_learned_slayer[-1]\n",
    "plt.figure()\n",
    "\n",
    "if 'centers' in stats:\n",
    "    c_start = stats['centers'][0]\n",
    "    c_end = stats['centers'][-1]\n",
    "\n",
    "    plt.plot(c_start[:,0], c_start[:, 1], 'bo', label='center initialization')\n",
    "    plt.plot(c_end[:,0], c_end[:, 1], 'ro', label='center learned')\n",
    "\n",
    "    all_centers = numpy.stack(stats['centers'], axis=0)\n",
    "    for i in range(all_centers.shape[1]):\n",
    "        points = all_centers[:,i, :]\n",
    "        plt.plot(points[:, 0], points[:, 1], '-k', alpha=0.25)\n",
    "        \n",
    "\n",
    "    plt.legend()\n",
    "    \n",
    "plt.figure()\n",
    "plt.plot(stats['train_loss_by_epoch'], label='train_loss')\n",
    "plt.plot(stats['test_loss_by_epoch'], label='test_loss')\n",
    "plt.plot(stats['test_accuracy'], label='test_accuracy')\n",
    "\n",
    "\n",
    "plt.legend()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.7.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
