{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "naked-terminal",
   "metadata": {},
   "outputs": [],
   "source": [
    "%matplotlib inline\n",
    "\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "from torch.autograd import Variable\n",
    "from torchvision import datasets, transforms\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn\n",
    "import matplotlib.patches as patches\n",
    "from scipy.spatial import HalfspaceIntersection\n",
    "\n",
    "from voting import matrix_op_robust_voting\n",
    "\n",
    "import sys\n",
    "sys.path.append(\"../\")\n",
    "from convex_adversarial import robust_loss, robust_loss_parallel\n",
    "from trainer import robust_loss_cascade, sampler_robust_cascade\n",
    "\n",
    "%matplotlib inline\n",
    "seaborn.set(font_scale=2)\n",
    "seaborn.set_style(\"white\")\n",
    "\n",
    "import numpy as np\n",
    "\n",
    "from sklearn.datasets import make_moons\n",
    "import matplotlib.pyplot as plt\n",
    "from pandas import DataFrame"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "multiple-sample",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# generate 2d classification dataset\n",
    "X_train, y_train = make_moons(n_samples=200, noise=0.05)\n",
    "# X_train_out, y_train_out = make_moons(n_samples=300, noise=0.1)\n",
    "# scatter plot, dots colored by class value\n",
    "X_train2, y_train2 = make_moons(n_samples=200, noise=0.05)\n",
    "\n",
    "transformation_matrix = np.array(\n",
    "    [[ 0, -1],\n",
    " [ 1,0]]\n",
    ")\n",
    "\n",
    "X_train2 = X_train2 @ transformation_matrix\n",
    "\n",
    "X_train2[:, 1] += 1.5\n",
    "X_train2[:, 0] += 0.9\n",
    "\n",
    "half_y_train2_idx = y_train2 == 0\n",
    "y_train2 = y_train2[half_y_train2_idx]\n",
    "X_train2 = X_train2[half_y_train2_idx]\n",
    "\n",
    "y_train2 += 2\n",
    "\n",
    "X_train = np.concatenate([X_train, X_train2])\n",
    "y_train = np.concatenate([y_train, y_train2])\n",
    "\n",
    "X_train -= np.min(X_train, axis=0, keepdims=True)\n",
    "X_train /= np.max(X_train, axis=0, keepdims=True)\n",
    "\n",
    "df = DataFrame(dict(x=X_train[:,0], y=X_train[:,1], label=y_train))\n",
    "colors = {0:'red', 1:'blue', 2:'green'}\n",
    "fig, ax = plt.subplots(figsize=(8,8))\n",
    "ax.axis(\"off\")\n",
    "grouped = df.groupby('label')\n",
    "for key, group in grouped:\n",
    "    group.plot(ax=ax, kind='scatter', x='x', y='y', label=key, color=colors[key], fontsize=26)\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"data.pdf\", dpi=300)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "intellectual-oasis",
   "metadata": {},
   "outputs": [],
   "source": [
    "X_train, y_train = torch.tensor(X_train).float(), torch.tensor(y_train).float()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "general-welsh",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(1.1022) tensor(0.8733)\n",
      "tensor(0.1015) tensor(0.0300)\n",
      "tensor(0.0275) tensor(0.0067)\n",
      "tensor(0.0213) tensor(0.0067)\n",
      "tensor(0.0201) tensor(0.0067)\n",
      "tensor(0.0067)\n"
     ]
    }
   ],
   "source": [
    "net = nn.Sequential(\n",
    "    nn.Linear(2,100),\n",
    "    nn.ReLU(),\n",
    "    nn.Linear(100,256),\n",
    "    nn.ReLU(),\n",
    "    nn.Linear(256,256),\n",
    "    nn.ReLU(),\n",
    "    nn.Linear(256,3)\n",
    ")\n",
    "\n",
    "opt = optim.Adam(net.parameters(), lr=1e-3)\n",
    "\n",
    "net = net\n",
    "\n",
    "\n",
    "for i in range(500):\n",
    "    out = net(Variable(X_train))\n",
    "    l = nn.CrossEntropyLoss()(out, Variable(y_train.long()))\n",
    "    err = (out.max(1)[1].detach().cpu().data != y_train).float().mean()\n",
    "    if i % 100 == 0:\n",
    "        print(l.data, err)\n",
    "    opt.zero_grad()\n",
    "    (l).backward()\n",
    "    opt.step()\n",
    "print(err)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "welcome-macro",
   "metadata": {},
   "outputs": [],
   "source": [
    "N = 200"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 114,
   "id": "broke-shade",
   "metadata": {},
   "outputs": [],
   "source": [
    "def draw_boundary_standard_models(net, N=200, save_as=None):\n",
    "\n",
    "    N = 200\n",
    "    XX, YY = np.meshgrid(np.linspace(0, 1, N), np.linspace(-0.2, 1, N))\n",
    "    X0 = Variable(torch.Tensor(np.stack([np.ravel(XX), np.ravel(YY)]).T))\n",
    "    y0 = net(X0)\n",
    "    Y0 = torch.argmax(y0, dim=1).long().resize(N,N)\n",
    "\n",
    "\n",
    "    fig, ax = plt.subplots(figsize=(8,8))\n",
    "    ax.contourf(XX,YY,Y0, colors=[[1, 0, 0, 0.5], [0, 0, 1, 0.5] , [0., 1, 0, 0.5]], levels=4)\n",
    "    ax.scatter(X_train[y_train==0][:,0], X_train[y_train==0][:,1], c=[1, 0, 0, 1.0], s=50, edgecolors='k')\n",
    "    ax.scatter(X_train[y_train==1][:,0], X_train[y_train==1][:,1], c=[0, 0, 1, 1.0], s=50, edgecolors='k')\n",
    "    ax.scatter(X_train[y_train==2][:,0], X_train[y_train==2][:,1], c=[0, 1, 0, 1.0], s=50, edgecolors='k')\n",
    "    ax.axis(\"off\")\n",
    "    if save_as is not None:\n",
    "        plt.tight_layout()\n",
    "        plt.savefig(f\"{save_as}.pdf\", dpi=300)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 115,
   "id": "hundred-florist",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "*c* argument looks like a single numeric RGB or RGBA sequence, which should be avoided as value-mapping will have precedence in case its length matches with *x* & *y*.  Please use the *color* keyword-argument or provide a 2-D array with a single row if you intend to specify the same RGB or RGBA value for all points.\n",
      "*c* argument looks like a single numeric RGB or RGBA sequence, which should be avoided as value-mapping will have precedence in case its length matches with *x* & *y*.  Please use the *color* keyword-argument or provide a 2-D array with a single row if you intend to specify the same RGB or RGBA value for all points.\n",
      "*c* argument looks like a single numeric RGB or RGBA sequence, which should be avoided as value-mapping will have precedence in case its length matches with *x* & *y*.  Please use the *color* keyword-argument or provide a 2-D array with a single row if you intend to specify the same RGB or RGBA value for all points.\n"
     ]
    },
    {
     "data": {
      "image/png": "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otKkedBgyCAiIipdmgYNl9s59f8wZBAREZUkzVc0mDCIiIhKl/ZBg4iIiEqW5kHD7XRpfQlERESkEs2CxuxgLu6eEBERlSpNggY7TYiIiMpDwYMGQwYREVH5KGjQYMggIiIqLwULGgwZRERE5aewWycMGURERGVF8/ZWIiIiKl0MGkRERKSaggQNl9sJt8vNbRMiIqIyo3rQYMggIiIqX9w6ISIiItUwaBAREZFqVA0a0eeZEBERUflRLWhwQBcRERGpEjQYMoiIiAhQIWgwZBAREVFEXoMGQwYRERFFy1vQYMggIiKiePndOmHIICIioiico0FERESqYdAgIiIi1eQlaHAwFxEREcnJOWiwCJSIiIiSySloMGQQERGRkqyDBkMGERERpZJV0GDIICIionRkv3XCkEFEREQpsL2ViIiIVJNx0HC5nSpcBhEREZWijIJGJGS4XW5umxAREVFKaQcNhgwiIiLKVFpBgyGDiIiIspEyaDBkEBERUbYUgwZDBhEREeUi5YoGQwYRERFlSzFoMGQQERFRLhSDBkMGERER5YKTQYmIiEg1DBpERESkGgYNIiIiUg2DBhEREamGQYOIiIhUw6BBREREqmHQICIiItUwaBAREZFqGDSIiIhINQwaREREpBoGDSIiIlINgwYRERGphkGDiIiIVMOgQURERKph0CAiIiLVMGgQERGRahg0iIiISDUMGkRERKQaBg0iIiJSDYMGERERqYZBg4iIiFTDoEFERESqYdAgIiIi1TBoEBERkWoYNIiIiEg1DBpERESkGgYNIiIiUg2DBhEREamGQYOIiIhUw6BBREREqmHQICIiItUwaBAREZFqGDSIiIhINQwaREREpBoGDSIiIlINgwYRERGphkGDiIiIVMOgQURERKph0CAiIiLVGMLhcFjriyAiIqLSxBUNIiIiUg2DBhEREamGQYOIiIhUw6BBREREqmHQICIiItUwaBAREZFq/n9RjAuDDjHkqwAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 576x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "draw_boundary_standard_models(net, N=200, save_as='non-robust-model')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "nominated-kidney",
   "metadata": {},
   "outputs": [],
   "source": [
    "X, y = X_train, y_train.long()\n",
    "epsilon = 0.05\n",
    "N = 300"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "removable-seeking",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_robust_model(features, labels, epochs=100, lr=1e-3):\n",
    "#     torch.manual_seed(seed)\n",
    "    f =  nn.Sequential(\n",
    "    nn.Linear(2,100),\n",
    "    nn.ReLU(),\n",
    "    nn.Linear(100,256),\n",
    "    nn.ReLU(),\n",
    "    nn.Linear(256,256),\n",
    "    nn.ReLU(),\n",
    "    nn.Linear(256,3)\n",
    ")\n",
    "    \n",
    "    data = []\n",
    "    opt = optim.Adam(f.parameters(), lr=lr)\n",
    "    for i in range(epochs):\n",
    "        robust_ce, robust_err = robust_loss(f, epsilon, features, labels)\n",
    "        out = f(features)\n",
    "        l2 = nn.CrossEntropyLoss()(out, Variable(labels))\n",
    "        err = (out.max(1)[1].data != labels).float().mean()\n",
    "        data.append([l2.data, robust_ce.data, err, robust_err])\n",
    "        opt.zero_grad()\n",
    "        (robust_ce).backward()\n",
    "        opt.step()\n",
    "    \n",
    "    print(f\"CRA: {1-robust_err}\")\n",
    "        \n",
    "    return f\n",
    "\n",
    "def get_robust_predictions(XX, YY, m):\n",
    "    X0 = Variable(torch.Tensor(np.stack([np.ravel(XX), np.ravel(YY)]).T))\n",
    "    y0 = m(X0)\n",
    "    ZZ = (y0[:,0] - y0[:,1]).resize(N,N).data.numpy()\n",
    "    \n",
    "    Y0 = torch.argmax(y0, dim=1).long()\n",
    "    \n",
    "    batch_size = 512\n",
    "    certificates = []\n",
    "    for i in range(0, X0.shape[0], batch_size):\n",
    "        x1 = X0[i:i+batch_size]\n",
    "        y1 = Y0[i:i+batch_size]\n",
    "        _, _, c = robust_loss(m, epsilon, x1, y1, return_certificate=True)\n",
    "        certificates.append(c)\n",
    "\n",
    "    Y0 = Y0.resize(N, N)\n",
    "    certificates = torch.cat(certificates, dim=0)\n",
    "\n",
    "    return Y0, certificates.resize(N,N).data\n",
    "\n",
    "\n",
    "\n",
    "get_model = lambda : nn.Sequential(\n",
    "    nn.Linear(2,100),\n",
    "    nn.ReLU(),\n",
    "    nn.Linear(100,256),\n",
    "    nn.ReLU(),\n",
    "    nn.Linear(256,256),\n",
    "    nn.ReLU(),\n",
    "    nn.Linear(256,3)\n",
    ")\n",
    "\n",
    "# def train_robust_model(f, dataloader, epochs=100):\n",
    "    \n",
    "#     loss_fn = nn.CrossEntropyLoss()\n",
    "#     opt = optim.Adam(f.parameters(), lr=1e-3)\n",
    "#     for _ in range(epochs):\n",
    "#         for features, labels in dataloader:\n",
    "#             features = features\n",
    "#             labels = labels\n",
    "#             robust_ce, robust_err = robust_loss(f, epsilon, features, labels)\n",
    "#             out = f(features)\n",
    "#             l2 = loss_fn(out, Variable(labels))\n",
    "#             err = (out.max(1)[1].data != labels).float().mean()\n",
    "#             data.append([l2.data, robust_ce.data, err, robust_err])\n",
    "#             opt.zero_grad()\n",
    "#             (robust_ce).backward()\n",
    "#             opt.step()\n",
    "    \n",
    "# #     print(l2.data, robust_ce.data, robust_err)\n",
    "    \n",
    "# #     print(f\"CRA: {1-robust_err}\")\n",
    "        \n",
    "#     return f\n",
    "\n",
    "# def cascad_training(epochs=50, max_models=5):\n",
    "\n",
    "#     sampler_indices = []\n",
    "#     model = []\n",
    "    \n",
    "#     dataset = torch.utils.data.TensorDataset(X, y)\n",
    "#     trainloader = torch.utils.data.DataLoader(dataset, batch_size=500)\n",
    "    \n",
    "#     for _ in range(max_models): \n",
    "#         # reduce dataset to just uncertified examples\n",
    "\n",
    "#         number_points = 0\n",
    "#         for x1, _ in trainloader:\n",
    "#             number_points += x1.shape[0]\n",
    "            \n",
    "#         print(number_points)\n",
    "        \n",
    "#         model.append(train_robust_model(get_model(), trainloader, epochs=100))\n",
    "        \n",
    "#         print(\"Reducing dataset...\")\n",
    "#         trainloader = sampler_robust_cascade(trainloader, model, epsilon,\n",
    "#                                               128, bounded_input=True)\n",
    "#         if trainloader is None: \n",
    "#             print('No more examples, terminating')\n",
    "#             break\n",
    "#         sampler_indices.append(trainloader.sampler.indices)\n",
    "            \n",
    "#     return model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "polar-shannon",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "../convex_adversarial/dual_layers.py:189: UserWarning: This overload of nonzero is deprecated:\n",
      "\tnonzero()\n",
      "Consider using one of the following signatures instead:\n",
      "\tnonzero(*, bool as_tuple) (Triggered internally at  ../torch/csrc/utils/python_arg_parser.cpp:983.)\n",
      "  self.I_ind = I.view(-1,n).nonzero()\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CRA: 0.9066666666666666\n",
      "CRA: 0.92\n",
      "CRA: 0.91\n"
     ]
    }
   ],
   "source": [
    "X_train_left = X_train.clone()\n",
    "X_train_left[:, 1] -= 0.1\n",
    "\n",
    "\n",
    "X_train_right = X_train.clone()\n",
    "X_train_right[:, 0] += 0.1\n",
    "\n",
    "m1 = get_robust_model(X_train, y_train.long(), epochs=500, lr=1e-3)\n",
    "m2 = get_robust_model(X_train_left, y_train.long(), epochs=500, lr=1e-3)\n",
    "m3 = get_robust_model(X_train_right, y_train.long(), epochs=500, lr=1e-3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "worse-showcase",
   "metadata": {},
   "outputs": [],
   "source": [
    "XX, YY = np.meshgrid(np.linspace(0, 1, N), np.linspace(-0.2, 1.2, N))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "id": "documentary-discharge",
   "metadata": {},
   "outputs": [],
   "source": [
    "def color_the_boundary(Z_original, C):\n",
    "    \n",
    "    if isinstance(Z_original, np.ndarray):\n",
    "        Z = Z_original.copy()\n",
    "    elif isinstance(Z_original, torch.Tensor):\n",
    "        Z = Z_original.clone()\n",
    "    \n",
    "    CLASS_ONE_ROBUST = 0\n",
    "    CLASS_ONE_NONROBUST = 3\n",
    "    CLASS_TWO_ROBUST = 1\n",
    "    CLASS_TWO_NONROBUST = 4\n",
    "    CLASS_THREE_ROBUST = 2\n",
    "    CLASS_THREE_NONROBUST = 5\n",
    "    \n",
    "    for i in range(Z.shape[0]):\n",
    "        for j in range(Z.shape[1]):\n",
    "            if Z[i, j] == 0 and C[i, j] == 1:\n",
    "                Z[i, j] = CLASS_ONE_ROBUST\n",
    "            elif Z[i, j] == 0 and C[i, j] == 0:\n",
    "                Z[i, j] = CLASS_ONE_NONROBUST\n",
    "            elif Z[i, j] == 1 and C[i, j] == 1:\n",
    "                Z[i, j] = CLASS_TWO_ROBUST\n",
    "            elif Z[i, j] == 1 and C[i, j] == 0:\n",
    "                Z[i, j] = CLASS_TWO_NONROBUST\n",
    "            elif Z[i, j] == 2 and C[i, j] == 1:\n",
    "                Z[i, j] = CLASS_THREE_ROBUST\n",
    "            elif Z[i, j] == 2 and C[i, j] == 0:\n",
    "                Z[i, j] = CLASS_THREE_NONROBUST\n",
    "            else:\n",
    "                raise ValueError\n",
    "    return Z\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "id": "considerable-wedding",
   "metadata": {},
   "outputs": [],
   "source": [
    "use_shaded_color = True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "id": "prescribed-medicaid",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "ZZ1_raw, C1 = get_robust_predictions(XX.copy(), YY.copy(), m1)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(8,8))\n",
    "\n",
    "if not use_shaded_color:\n",
    "    ZZ1 = torch.where(C1 == True, ZZ1_raw, torch.zeros((N, N)).long()+3)\n",
    "    ax.contourf(XX,YY, ZZ1, colors=[[1, 0, 0, 0.5], \n",
    "                                    [0, 0, 1, 0.5], \n",
    "                                    [0., 1, 0, 0.5], \n",
    "                                    [0., 0, 0, 0.4]], \n",
    "                levels=3)\n",
    "else:\n",
    "    ZZ1 = color_the_boundary(ZZ1_raw, C1)\n",
    "    ax.contourf(XX,YY, ZZ1, colors=[[1, 0, 0, 0.5], \n",
    "                                    [0, 0, 1, 0.5], \n",
    "                                    [0, 1, 0, 0.5], \n",
    "                                    [1, 0, 0, 0.3],\n",
    "                                    [0, 0, 1, 0.3],\n",
    "                                    [0, 1, 0, 0.3],\n",
    "                                    [0, 1, 0, 0.3]])\n",
    "\n",
    "\n",
    "# ax.scatter(X_train[y_train==0][:,0], X_train[y_train==0][:,1], c=[1, 0, 0, 1.0], s=70, edgecolors='k')\n",
    "# ax.scatter(X_train[y_train==1][:,0], X_train[y_train==1][:,1], c=[0, 0, 1, 1.0], s=70, edgecolors='k')\n",
    "# ax.scatter(X_train[y_train==2][:,0], X_train[y_train==2][:,1], c=[0, 1, 0, 1.0], s=70, edgecolors='k')\n",
    "ax.axis(\"off\")\n",
    "ax.axis([0,1,-0.2,1.2])\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"m1.pdf\", dpi=300)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "id": "fossil-tutorial",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "ZZ2_raw, C2 = get_robust_predictions(XX.copy(), YY.copy(), m2)\n",
    "\n",
    "ZZ2 = torch.where(C2 == True, ZZ2_raw, torch.zeros((N, N)).long()+3)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(8,8))\n",
    "\n",
    "if not use_shaded_color:\n",
    "    ZZ2 = torch.where(C2 == True, ZZ2_raw, torch.zeros((N, N)).long()+3)\n",
    "    ax.contourf(XX,YY, ZZ2, colors=[[1, 0, 0, 0.5], \n",
    "                                    [0, 0, 1, 0.5], \n",
    "                                    [0., 1, 0, 0.5], \n",
    "                                    [0., 0, 0, 0.4]], \n",
    "                levels=3)\n",
    "else:\n",
    "    ZZ2 = color_the_boundary(ZZ2_raw, C2)\n",
    "    ax.contourf(XX,YY, ZZ2, colors=[[1, 0, 0, 0.5], \n",
    "                                    [0, 0, 1, 0.5], \n",
    "                                    [0, 1, 0, 0.5], \n",
    "                                    [1, 0, 0, 0.3],\n",
    "                                    [0, 0, 1, 0.3],\n",
    "                                    [0, 1, 0, 0.3],\n",
    "                                    [0, 1, 0, 0.3]])\n",
    "\n",
    "\n",
    "# ax.scatter(X_train_left[y_train==0][:,0], X_train_left[y_train==0][:,1], c=[1, 0, 0, 1.0], s=70, edgecolors='k')\n",
    "# ax.scatter(X_train_left[y_train==1][:,0], X_train_left[y_train==1][:,1], c=[0, 0, 1, 1.0], s=70, edgecolors='k')\n",
    "# ax.scatter(X_train_left[y_train==2][:,0], X_train_left[y_train==2][:,1], c=[0, 1, 0, 1.0], s=70, edgecolors='k')\n",
    "ax.axis(\"off\")\n",
    "# ax.axis([0,1,-0.2,1.2])\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"m2.pdf\", dpi=300)\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "id": "further-peripheral",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "ZZ3_raw, C3 = get_robust_predictions(XX.copy(), YY.copy(), m3)\n",
    "\n",
    "ZZ3 = torch.where(C3 == True, ZZ3_raw, torch.zeros((N, N)).long()+3)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(8,8))\n",
    "\n",
    "if not use_shaded_color:\n",
    "    ZZ3 = torch.where(C3 == True, ZZ3_raw, torch.zeros((N, N)).long()+3)\n",
    "    ax.contourf(XX,YY, ZZ3, colors=[[1, 0, 0, 0.5], \n",
    "                                    [0, 0, 1, 0.5], \n",
    "                                    [0., 1, 0, 0.5], \n",
    "                                    [0., 0, 0, 0.4]], \n",
    "                levels=3)\n",
    "else:\n",
    "    ZZ3 = color_the_boundary(ZZ3_raw, C3)\n",
    "    ax.contourf(XX,YY, ZZ3, colors=[[1, 0, 0, 0.5], \n",
    "                                    [0, 0, 1, 0.5], \n",
    "                                    [0, 1, 0, 0.5], \n",
    "                                    [1, 0, 0, 0.3],\n",
    "                                    [0, 0, 1, 0.3],\n",
    "                                    [0, 1, 0, 0.3],\n",
    "                                    [0, 1, 0, 0.3]])\n",
    "\n",
    "\n",
    "# ax.scatter(X_train_right[y_train==0][:,0], X_train_right[y_train==0][:,1], c=[1, 0, 0, 1.0], s=70, edgecolors='k')\n",
    "# ax.scatter(X_train_right[y_train==1][:,0], X_train_right[y_train==1][:,1], c=[0, 0, 1, 1.0], s=70, edgecolors='k')\n",
    "# ax.scatter(X_train_right[y_train==2][:,0], X_train_right[y_train==2][:,1], c=[0, 1, 0, 1.0], s=70, edgecolors='k')\n",
    "ax.axis(\"off\")\n",
    "ax.axis([0,1,-0.2,1.2])\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"m3.pdf\", dpi=300)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "id": "stone-hardwood",
   "metadata": {},
   "outputs": [],
   "source": [
    "def cascade(y_pred, certified):\n",
    "    predictions = []\n",
    "    certificates = []\n",
    "    for i in range(np.shape(y_pred)[1]):\n",
    "        certified_yet = False\n",
    "        for j in range(np.shape(y_pred)[0]-1):\n",
    "            if certified[j][i] == 1 and not certified_yet:\n",
    "                predictions.append(y_pred[j][i])\n",
    "                certificates.append(1)\n",
    "                certified_yet = True\n",
    "                \n",
    "        if not certified_yet:\n",
    "            predictions.append(y_pred[np.shape(y_pred)[0]-1][i])\n",
    "            certificates.append(certified[np.shape(y_pred)[0]-1][i])\n",
    "            \n",
    "    certificates = np.array(certificates).astype(np.int32)\n",
    "\n",
    "    return predictions, certificates"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "id": "hazardous-electronics",
   "metadata": {},
   "outputs": [],
   "source": [
    "y_pred = np.array([ZZ1_raw.flatten().numpy(), ZZ2_raw.flatten().numpy(), ZZ3_raw.flatten().numpy()])\n",
    "certified = np.array([C1.flatten().numpy(), C2.flatten().numpy(), C3.flatten().numpy()])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "id": "expensive-generic",
   "metadata": {},
   "outputs": [],
   "source": [
    "cas_ZZ_raw, cas_CC = cascade(y_pred, certified)\n",
    "cas_ZZ_raw = np.reshape(cas_ZZ_raw, (N, N))\n",
    "cas_CC = np.reshape(cas_CC, (N, N))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "id": "pursuant-course",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "*c* argument looks like a single numeric RGB or RGBA sequence, which should be avoided as value-mapping will have precedence in case its length matches with *x* & *y*.  Please use the *color* keyword-argument or provide a 2-D array with a single row if you intend to specify the same RGB or RGBA value for all points.\n",
      "*c* argument looks like a single numeric RGB or RGBA sequence, which should be avoided as value-mapping will have precedence in case its length matches with *x* & *y*.  Please use the *color* keyword-argument or provide a 2-D array with a single row if you intend to specify the same RGB or RGBA value for all points.\n",
      "*c* argument looks like a single numeric RGB or RGBA sequence, which should be avoided as value-mapping will have precedence in case its length matches with *x* & *y*.  Please use the *color* keyword-argument or provide a 2-D array with a single row if you intend to specify the same RGB or RGBA value for all points.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# cas_ZZ = np.where(cas_CC == np.ones_like(cas_CC), cas_ZZ_raw, np.zeros((N, N))+3)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(8,8))\n",
    "\n",
    "# ax.contourf(XX,YY, cas_ZZ, colors=[[1, 0, 0, 0.5], [0, 0, 1, 0.5] , [0., 1, 0, 0.5], [0., 0, 0, 0.4]], levels=3)\n",
    "\n",
    "\n",
    "if not use_shaded_color:\n",
    "    cas_ZZ = torch.where(cas_CC == True, cas_ZZ_raw, torch.zeros((N, N)).long()+3)\n",
    "    ax.contourf(XX,YY, cas_ZZ, colors=[[1, 0, 0, 0.5], \n",
    "                                    [0, 0, 1, 0.5], \n",
    "                                    [0., 1, 0, 0.5], \n",
    "                                    [0., 0, 0, 0.4]], \n",
    "                levels=3)\n",
    "else:\n",
    "    cas_ZZ = color_the_boundary(cas_ZZ_raw, cas_CC)\n",
    "    ax.contourf(XX,YY, cas_ZZ, colors=[[1, 0, 0, 0.5], \n",
    "                                    [0, 0, 1, 0.5], \n",
    "                                    [0, 1, 0, 0.5], \n",
    "                                    [1, 0, 0, 0.3],\n",
    "                                    [0, 0, 1, 0.3],\n",
    "                                    [0, 1, 0, 0.3],\n",
    "                                    [0, 1, 0, 0.3]])\n",
    "\n",
    "\n",
    "\n",
    "ax.scatter(X_train[y_train==0][:,0], X_train[y_train==0][:,1], c=[1, 0, 0, 1], s=70, edgecolors='k')\n",
    "ax.scatter(X_train[y_train==1][:,0], X_train[y_train==1][:,1], c=[0, 0, 1, 1], s=70, edgecolors='k')\n",
    "ax.scatter(X_train[y_train==2][:,0], X_train[y_train==2][:,1], c=[0, 1, 0, 1], s=70, edgecolors='k')\n",
    "ax.axis(\"off\")\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"kw_ensemble.pdf\", dpi=300)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "id": "functional-glucose",
   "metadata": {},
   "outputs": [],
   "source": [
    "ens_ZZ, ens_CC, vote_acc, vote_vra, weights = matrix_op_robust_voting(\n",
    "    y_pred,\n",
    "    np.ones((N*N,)),\n",
    "    certified.astype(np.int32),\n",
    "    solve_for_weights=False,\n",
    "    num_classes=3,\n",
    "    weights=np.array([1.0, 0.98, 0.99]))\n",
    "\n",
    "ens_ZZ = ens_ZZ.reshape((N, N))\n",
    "ens_CC = ens_CC.reshape((N, N))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "id": "electrical-obligation",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "*c* argument looks like a single numeric RGB or RGBA sequence, which should be avoided as value-mapping will have precedence in case its length matches with *x* & *y*.  Please use the *color* keyword-argument or provide a 2-D array with a single row if you intend to specify the same RGB or RGBA value for all points.\n",
      "*c* argument looks like a single numeric RGB or RGBA sequence, which should be avoided as value-mapping will have precedence in case its length matches with *x* & *y*.  Please use the *color* keyword-argument or provide a 2-D array with a single row if you intend to specify the same RGB or RGBA value for all points.\n",
      "*c* argument looks like a single numeric RGB or RGBA sequence, which should be avoided as value-mapping will have precedence in case its length matches with *x* & *y*.  Please use the *color* keyword-argument or provide a 2-D array with a single row if you intend to specify the same RGB or RGBA value for all points.\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "fig, ax = plt.subplots(figsize=(8,8))\n",
    "\n",
    "\n",
    "if not use_shaded_color:\n",
    "    ens_ZZ = np.where(ens_CC == np.ones_like(ens_ZZ), ens_ZZ, np.zeros_like(ens_ZZ)+3)\n",
    "    ax.contourf(XX,YY, ens_ZZ, colors=[[1, 0, 0, 0.5], [0, 0, 1, 0.5] , [0., 1, 0, 0.5], [0., 0, 0, 0.4]], levels=3)\n",
    "\n",
    "\n",
    "else:\n",
    "    ens_ZZ = color_the_boundary(ens_ZZ, ens_CC)\n",
    "    ax.contourf(XX,YY, ens_ZZ, colors=[[1, 0, 0, 0.5], \n",
    "                                    [0, 0, 1, 0.5], \n",
    "                                    [0, 1, 0, 0.5], \n",
    "                                    [1, 0, 0, 0.3],\n",
    "                                    [0, 0, 1, 0.3],\n",
    "                                    [0, 1, 0, 0.3],\n",
    "                                    [0, 1, 0, 0.3]])\n",
    "\n",
    "\n",
    "\n",
    "ax.scatter(X_train[y_train==0][:,0], X_train[y_train==0][:,1], c=[1, 0, 0, 1.0], s=70, edgecolors='k')\n",
    "ax.scatter(X_train[y_train==1][:,0], X_train[y_train==1][:,1], c=[0, 0, 1, 1.0], s=70, edgecolors='k')\n",
    "ax.scatter(X_train[y_train==2][:,0], X_train[y_train==2][:,1], c=[0, 1, 0, 1.0], s=70, edgecolors='k')\n",
    "ax.axis(\"off\")\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"voting_ensemble.pdf\", dpi=300)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "united-plastic",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "virtual-television",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "outside-reunion",
   "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.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
