{
  "cells": [
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "ziwrREgJx5ov"
      },
      "outputs": [],
      "source": [
        "dname = 'dataset1'"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "EVoWoTNUbK2G"
      },
      "outputs": [],
      "source": [
        "TR_ITER = 10001\n",
        "TR_AVG_ITER = 2500"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "33zdXjdb2OZ0"
      },
      "outputs": [],
      "source": [
        "EXP_NAME = 'testing_pickle1'"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "bo8IFgCbT80v"
      },
      "outputs": [],
      "source": [
        "# Path to load data fro\n",
        "BASE_DIR = ''"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "we_9ZHOJ1u77"
      },
      "outputs": [],
      "source": [
        "SAVE_DIR = ''"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "1s_i6Hr6a3QO"
      },
      "source": [
        "# Func"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "Cu709diOzAUj"
      },
      "outputs": [],
      "source": [
        "from datetime import datetime\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "eTgFZHaMEg4U"
      },
      "outputs": [],
      "source": [
        "import time\n",
        "start = time.time()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "MHh5CY-k2Cq3"
      },
      "outputs": [],
      "source": [
        "import os\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "EXxipvmSWDIi"
      },
      "outputs": [],
      "source": [
        "%matplotlib inline\n",
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "import scipy.stats\n",
        "import pandas as pd"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "FDwgr2mvrr43"
      },
      "outputs": [],
      "source": [
        "import tensorflow as tf\n",
        "import tensorflow_probability as tfp"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "MiA1dcJqpTKA"
      },
      "outputs": [],
      "source": [
        "from xgboost import XGBClassifier\n",
        "from xgboost import XGBRegressor\n",
        "from scipy.linalg import null_space\n",
        "from sklearn.cross_decomposition import CCA\n",
        "from sklearn.ensemble import RandomForestClassifier\n",
        "from scipy.spatial.distance import cdist\n",
        "from sklearn.linear_model import LogisticRegression"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "ZvQxVPBdwJfc"
      },
      "outputs": [],
      "source": [
        "from scipy.integrate import trapezoid\n",
        "from sklearn import metrics\n",
        "\n",
        "def auprc_threshs(confidences, Y, threshs, as_percentages=True):\n",
        "  areas = []\n",
        "  precisions, recalls, thresholds = metrics.precision_recall_curve(Y, confidences)\n",
        "  for t in threshs:\n",
        "    if t < 1.0:\n",
        "      interp_prec_t = np.interp(t, recalls[::-1], precisions[::-1])\n",
        "      recalls_thresh = np.concatenate(([t], recalls[recalls<t]))\n",
        "      precisions_thresh = np.concatenate(([interp_prec_t], precisions[recalls<t]))\n",
        "    else:\n",
        "      recalls_thresh = recalls\n",
        "      precisions_thresh = precisions\n",
        "    area_t = metrics.auc(recalls_thresh, precisions_thresh)\n",
        "    if as_percentages:\n",
        "      area_t = area_t/t\n",
        "    areas.append(area_t)\n",
        "  return np.array(areas)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "8Id7d7pQs3Wd"
      },
      "outputs": [],
      "source": [
        "external_colstart = 4 if dname in set(['dataset1', 'dataset2', 'dataset3', 'dataset4']) else 2  # SHOULD BE 4 for 'dataset1' ... 'dataset4' otherwise 2"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "dguz7FBcW5mq"
      },
      "outputs": [],
      "source": [
        "with open(os.path.join(BASE_DIR, dname, 'train.csv'), 'r') as f:\n",
        "  dataX = np.float32(np.array([line.strip().split(',')[2:] for line in f])[1:])\n",
        "\n",
        "with open(os.path.join(BASE_DIR, dname, 'train.csv'), 'r') as f:\n",
        "  dataY = np.float32(np.array([line.strip().split(',')[1] for line in f])[1:])\n",
        "\n",
        "X = dataX\n",
        "Y = dataY"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "48e-tD-8W5mq"
      },
      "outputs": [],
      "source": [
        "with open(os.path.join(BASE_DIR, dname, 'val_id.csv'), 'r') as f:\n",
        "  dataX_val = np.float32(np.array([line.strip().split(',')[2:] for line in f])[1:])\n",
        "\n",
        "with open(os.path.join(BASE_DIR, dname, 'val_id.csv'), 'r') as f:\n",
        "  dataY_val = np.float32(np.array([line.strip().split(',')[1] for line in f])[1:])"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "Ww0XXrrvW5mq"
      },
      "outputs": [],
      "source": [
        "with open(os.path.join(BASE_DIR, dname, 'test_id.csv'), 'r') as f:\n",
        "  dataX_tst = np.float32(np.array([line.strip().split(',')[2:] for line in f])[1:])\n",
        "\n",
        "with open(os.path.join(BASE_DIR, dname, 'test_id.csv'), 'r') as f:\n",
        "  dataY_tst = np.float32(np.array([line.strip().split(',')[1] for line in f])[1:])"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "-Zt3t0tqW5mr"
      },
      "outputs": [],
      "source": [
        "with open(os.path.join(BASE_DIR, dname, 'val_ood.csv'), 'r') as f:\n",
        "  external_X = np.float32(np.array([line.strip().split(',')[external_colstart:] for line in f])[1:])\n",
        "\n",
        "with open(os.path.join(BASE_DIR, dname, 'val_ood.csv'), 'r') as f:\n",
        "  external_Y = np.float32(np.array([line.strip().split(',')[1] for line in f])[1:])"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "vaojUtEdY2p2"
      },
      "outputs": [],
      "source": [
        "X = dataX\n",
        "Y = dataY\n",
        "\n",
        "# standardize the data\n",
        "mu_x = np.mean(X, 0, keepdims=True)\n",
        "#sigma_x = np.std(X, 0, keepdims=True)\n",
        "sigma_x = np.ones_like(mu_x)\n",
        "X = (X-mu_x)/sigma_x\n",
        "\n",
        "# PCA\n",
        "XtX = np.matmul(X.T, X)\n",
        "eigvals, eigvecs = np.linalg.eig(XtX)\n",
        "sortinds = np.argsort(-eigvals)\n",
        "V = eigvecs[:, sortinds]"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "T8FwitHVZ0-W"
      },
      "outputs": [],
      "source": [
        "external_X = (external_X-mu_x)/sigma_x\n",
        "# held_X = (dataX_val-mu_x)/sigma_x\n",
        "# held_Y = dataY_val\n",
        "held_X = (np.concatenate((dataX_val, dataX_tst), 0)-mu_x)/sigma_x\n",
        "held_Y = np.concatenate((dataY_val, dataY_tst), 0)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "2PuqxRwXJICh"
      },
      "outputs": [],
      "source": [
        "NDIRS = 128  # 256\n",
        "X = X@V[:, :NDIRS]\n",
        "held_X = held_X@V[:, :NDIRS]\n",
        "external_X = external_X@V[:, :NDIRS]"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "_U_l31CacP8F"
      },
      "outputs": [],
      "source": [
        "def get_preds(x, ests, mus=None, dirs=None, use_proba=False):\n",
        "  if mus is None:\n",
        "    mus = [0.0 for _ in range(len(ests))]\n",
        "  if dirs is not None:\n",
        "    if use_proba:\n",
        "      pred_array = [e.predict_proba((x-mu)@d)[:, 1] for mu, d, e in zip(mus, dirs, ests)]\n",
        "    else:\n",
        "      pred_array = [e.predict((x-mu)@d) for mu, d, e in zip(mus, dirs, ests)]\n",
        "  else:\n",
        "    if use_proba:\n",
        "      pred_array = [e.predict_proba((x-mu))[:, 1] for mu, e in zip(mus, ests)]\n",
        "    else:\n",
        "      pred_array = [e.predict((x-mu)) for mu, e in zip(mus, ests)]\n",
        "  return np.stack(pred_array, -1)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "s-1Nkhj3gdfx"
      },
      "outputs": [],
      "source": [
        "def aggregate_preds(preds, use_bernoulli_std=False):\n",
        "  mean_pred = np.mean(preds, 1, keepdims=False)\n",
        "  if use_bernoulli_std:\n",
        "    std_pred = mean_pred*(1-mean_pred)\n",
        "  else:\n",
        "    std_pred = np.std(preds, 1, keepdims=False)\n",
        "  return np.float32(mean_pred>0.5), mean_pred, std_pred"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "NDuawjDXkq8C"
      },
      "source": [
        "Train on random directions"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "31XMRekNlXBt"
      },
      "outputs": [],
      "source": [
        "from sklearn.metrics import precision_score"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "KpPp9Psmlmk0"
      },
      "outputs": [],
      "source": [
        "def divide_points(percentage_threshold, X, y, index):\n",
        "  dot_products = (X @ X[index, None, :].T)[:, 0]\n",
        "  thresh = np.quantile(dot_products, 1.-percentage_threshold)\n",
        "  # id_x, id_y, ood_x, ood_y\n",
        "  return (X[dot_products<thresh], y[dot_products<thresh],\n",
        "    X[dot_products>=thresh], y[dot_products>=thresh])\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "WnAOruvQp_iL"
      },
      "outputs": [],
      "source": [
        "from abc import ABC, abstractmethod"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "0PlRAAV5p_iL"
      },
      "outputs": [],
      "source": [
        "class Ensemble(ABC):\n",
        "  \"\"\" General Ensembling Class \"\"\"\n",
        "\n",
        "  @abstractmethod\n",
        "  def __init__(self, *args, **kwargs):\n",
        "    self.nmodels = kwargs.get('nmodels', 256)\n",
        "\n",
        "  @property\n",
        "  @abstractmethod\n",
        "  def estimators(self):\n",
        "    pass\n",
        "\n",
        "  @abstractmethod\n",
        "  def add_estimator(self, est):\n",
        "    pass\n",
        "\n",
        "  @abstractmethod\n",
        "  def base_model_generator(self):\n",
        "    # Returns something trainable with fit(X,Y)\n",
        "    pass\n",
        "\n",
        "  def random_sample(self, X, Y):\n",
        "    # Potentially subsample X and Y\n",
        "    return X, Y\n",
        "\n",
        "  def fit(self, X, Y, verbose=True):\n",
        "    # Returns something trainable with fit(X,Y)\n",
        "    for t in range(self.nmodels):\n",
        "      sX, sY = self.random_sample(X, Y)\n",
        "      est = self.base_model_generator()\n",
        "      if verbose:\n",
        "        print('Fitting Model {}'.format(t))\n",
        "      est.fit(sX, sY)\n",
        "      self.add_estimator(est)\n",
        "\n",
        "  def predictions(self, x):\n",
        "    # Assumes estimators return (N, ) shape predict\n",
        "    pred_array = [e.predict(x) for e in self.estimators]\n",
        "    return np.stack(pred_array, -1)\n",
        "\n",
        "  def predict(self, x=None, preds=None, return_only_prediction=True):\n",
        "    assert (x is not None) or (preds is not None)\n",
        "    if preds is None:\n",
        "      preds = self.predictions(x)\n",
        "\n",
        "    mean_pred = np.mean(preds, 1, keepdims=False)\n",
        "    std_pred = np.std(preds, 1, keepdims=False)\n",
        "\n",
        "    if return_only_prediction:\n",
        "      return np.float32(mean_pred>0.5)\n",
        "    return np.float32(mean_pred>0.5), mean_pred, std_pred"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "keuiurs4p_iM"
      },
      "outputs": [],
      "source": [
        "class ProjectionEnsemble(Ensemble):\n",
        "  \"\"\" General Ensembling Class With Projections of Dimensions\"\"\"\n",
        "\n",
        "  @abstractmethod\n",
        "  def __init__(self, *args, **kwargs):\n",
        "    super(ProjectionEnsemble, self).__init__(*args, **kwargs)\n",
        "\n",
        "  @property\n",
        "  @abstractmethod\n",
        "  def directions(self):\n",
        "    pass\n",
        "\n",
        "  @property\n",
        "  @abstractmethod\n",
        "  def means(self):\n",
        "    pass\n",
        "\n",
        "  def predictions(self, x):\n",
        "    # Assumes estimators return (N, ) shape predict\n",
        "    pred_array = [\n",
        "      e.predict((x-mu)@d)\n",
        "      for mu, d, e in zip(self.means, self.directions, self.estimators)\n",
        "    ]\n",
        "    return np.stack(pred_array, -1)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "lKdrmysap_iM"
      },
      "outputs": [],
      "source": [
        "class PCAProjectionEnsemble(ProjectionEnsemble):\n",
        "  \"\"\" General Ensembling Class With Projections of Dimensions\"\"\"\n",
        "\n",
        "  def __init__(self, *args, **kwargs):\n",
        "    super(ProjectionEnsemble, self).__init__(*args, **kwargs)\n",
        "    self.ndirs = kwargs.get('ndirs', 8)\n",
        "    self.Vpca = kwargs['Vpca']  # d x k\n",
        "    self.Vorth = kwargs.get('Vorth', 8)\n",
        "    self.projection_split = kwargs.get('projection_split', False)\n",
        "    self.split_perc = kwargs.get('split_perc', .5)\n",
        "    self._splits_rand = []\n",
        "    self._dirs_inds = []\n",
        "    self._estimators = []\n",
        "\n",
        "  @property\n",
        "  def directions(self):\n",
        "    return [self.Vpca[:, dinds] for dinds in self._dirs_inds]\n",
        "\n",
        "  @property\n",
        "  def means(self):\n",
        "    return [np.zeros((1, self.Vpca.shape[0]), dtype=np.float32)] * len(self._dirs_inds)\n",
        "\n",
        "  @property\n",
        "  def estimators(self):\n",
        "    return self._estimators\n",
        "\n",
        "  def add_estimator(self, est):\n",
        "    self._estimators.append(est)\n",
        "\n",
        "  def base_model_generator(self):\n",
        "    # Returns something trainable with fit(X,Y)\n",
        "    # TODO: make init argument\n",
        "    return XGBClassifier(n_estimators=40)\n",
        "\n",
        "  def random_sample(self, X, Y, XV=None):\n",
        "    # Potentially subsample X and Y\n",
        "    N_tot, d = X.shape\n",
        "\n",
        "    if self.projection_split:\n",
        "      newdir = np.random.randn(d, 1)\n",
        "      newdir = newdir/np.sqrt(np.sum(newdir**2))\n",
        "      projs = (X@newdir)[:, 0]\n",
        "      medianp = np.median(projs)\n",
        "      in_range = projs <= medianp\n",
        "    else:\n",
        "      in_range = np.random.rand(N_tot) <= self.split_perc\n",
        "    self._splits_rand.append(in_range)\n",
        "\n",
        "    Y_train = Y[in_range]\n",
        "    rprm = np.random.permutation(self.Vpca.shape[1])\n",
        "    self._dirs_inds.append(rprm[:self.ndirs])\n",
        "    if XV is not None:\n",
        "      X_train = XV[in_range][:, self._dirs_inds[-1]]\n",
        "    else:\n",
        "      X_train = X[in_range]@self.Vpca[:, self._dirs_inds[-1]]\n",
        "\n",
        "    return X_train, Y_train\n",
        "\n",
        "  def fit(self, X, Y, verbose=True):\n",
        "    XV = X@self.Vpca\n",
        "    for t in range(self.nmodels):\n",
        "      sX, sY = self.random_sample(X, Y, XV)\n",
        "      est = self.base_model_generator()\n",
        "      if verbose:\n",
        "        print('Fitting Model {}'.format(t))\n",
        "      est.fit(sX, sY)\n",
        "      self.add_estimator(est)\n",
        "\n",
        "  def predictions(self, x):\n",
        "    xV = x@self.Vpca\n",
        "    # Assumes estimators return (N, ) shape predict\n",
        "    pred_array = [\n",
        "      e.predict(xV[:, di])\n",
        "      for di, e in zip(self._dirs_inds, self.estimators)\n",
        "    ]\n",
        "    return np.stack(pred_array, -1)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "Pop3TGAKo-hJ"
      },
      "outputs": [],
      "source": [
        "# with open(os.path.join(BASE_DIR +'/' + EXP_NAME + '/' + dname, 'pca_projens_1024.p'), 'rb') as f:\n",
        "#     pca_proj = pickle.load(f)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "VhsbsS3b00fZ"
      },
      "outputs": [],
      "source": [
        "def knn_gibbs(Xsamp, X, nn_featinds, k):\n",
        "  Xf = X[:, nn_featinds]\n",
        "  Xsf = Xsamp[:, nn_featinds]\n",
        "  Xfnorm2 = np.sum(Xf**2, keepdims=True)\n",
        "  Xsfnorm2 = np.sum(Xsf**2, keepdims=True)\n",
        "  dotsf = Xsf@Xf.T\n",
        "  distsf = Xsfnorm2 + Xfnorm2.T - 2*dotsf\n",
        "  sortdistsf = np.argsort(distsf, axis=1)\n",
        "  # neighs = sortdistsf[:, np.random.choice(k, size=(X.shape[0], ))]\n",
        "  neighs = sortdistsf[np.arange(Xsamp.shape[0]), np.random.choice(k, size=(X.shape[0], ))]\n",
        "  Xsamp = np.copy(Xsamp)\n",
        "  Xsamp[:, np.logical_not(nn_featinds)] = X[neighs, :][:, np.logical_not(nn_featinds)]\n",
        "  return Xsamp\n",
        "\n",
        "def gibbs_sample(X, k, nrounds):\n",
        "  Xsamp = X\n",
        "  for r in range(nrounds):\n",
        "    featinds = np.random.rand(X.shape[1])<.5\n",
        "    Xsamp = knn_gibbs(Xsamp, X, featinds, k)\n",
        "    Xsamp = knn_gibbs(Xsamp, X, np.logical_not(featinds), k)\n",
        "  return Xsamp\n",
        "\n",
        "def permute_expand(X):\n",
        "  N, d = X.shape\n",
        "  return np.stack([X[np.random.permutation(N), i] for i in range(d)], -1)\n",
        "\n",
        "def convex_expand(X):\n",
        "  N, d = X.shape\n",
        "  X1 = X[np.random.permutation(N), :]\n",
        "  alphas = np.random.rand(N, 1)\n",
        "  return alphas*X + (1-alphas)*X1"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "nMFXxF3r1Ux8"
      },
      "outputs": [],
      "source": [
        "expand_funcs = [\n",
        "    # lambda x: gibbs_sample(x, 40, 2),\n",
        "    # lambda x: permute_expand(x),\n",
        "    # lambda x: convex_expand(x),\n",
        "    lambda x: x*(1+np.abs(np.random.randn(x.shape[0], 1)))\n",
        "]"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "wbZJQblJE35k"
      },
      "outputs": [],
      "source": [
        "class DatasetDiscriminator(tf.keras.Model):\n",
        "  def __init__(self, dim, nhidden_layers=2, hidden_size=256, out_size=64, net=None):\n",
        "    super(DatasetDiscriminator, self).__init__()\n",
        "\n",
        "    self.dim = dim\n",
        "    if net is not None:\n",
        "      self.net = net\n",
        "    else:\n",
        "      layers = [\n",
        "        tf.keras.layers.Dense(\n",
        "            hidden_size, activation=tf.nn.elu) for _ in range(nhidden_layers)] + \\\n",
        "            [tf.keras.layers.Dense(out_size)]\n",
        "      self.net = tf.keras.Sequential(layers)\n",
        "\n",
        "    # self.beta = tf.Variable(\n",
        "    #  tf.random.normal([out_size, 1], stddev=0.01), name='beta')\n",
        "\n",
        "  def get_features(self, x_in):\n",
        "    # print(x_in.shape)\n",
        "    feats = self.net(x_in)\n",
        "    # print(feats.shape)\n",
        "    return feats\n",
        "\n",
        "  def __call__(self, x_in):\n",
        "    return self.get_features(x_in)\n",
        "\n",
        "  def predictions(self, x_in):\n",
        "    return tf.nn.sigmoid(self.get_features(x_in))\n",
        "\n",
        "\n",
        "  def predictions_via_logits(self, x_in):\n",
        "    return tf.nn.sigmoid(np.mean(self.get_features(x_in), -1))\n",
        "\n",
        "  # def get_logits(self, x_in):\n",
        "  #   return tf.matmul(self.get_features(x_in), self.beta)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "gbIGqE5nr86Z"
      },
      "outputs": [],
      "source": [
        "def smooth_maximum(v, temp=1.0):\n",
        "  softmaxv = tf.nn.softmax(v/temp, axis=-1)\n",
        "  return tf.reduce_sum(v*softmaxv, axis=-1, keepdims=True)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "hMSLzFqAr9vb"
      },
      "outputs": [],
      "source": [
        "def sigmoid_entropy(logits, normalize=False):\n",
        "  NORM = 0.6931471805599453  # -np.log(.5)\n",
        "  p = tf.nn.sigmoid(logits)\n",
        "  entropy = p*tf.nn.softplus(-logits) + (1.-p)*tf.nn.softplus(logits)\n",
        "  if normalize:\n",
        "    return entropy/NORM\n",
        "  return entropy"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "XAFjz88dGLeo"
      },
      "outputs": [],
      "source": [
        "def training_batch(data, llks, batchsize):\n",
        "  def generate_batch():\n",
        "    rprm_in = np.random.permutation(data.shape[0])\n",
        "    if len(llks.shape)==1:\n",
        "      return data[rprm_in[:batchsize], :], llks[rprm_in[:batchsize], None]\n",
        "    return data[rprm_in[:batchsize], :], llks[rprm_in[:batchsize]]\n",
        "  return generate_batch"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "Gs9M6roQaIza"
      },
      "source": [
        "# NT EMOE"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "Bjyvy8JzUNWo",
        "outputId": "2a6a0a0e-44b5-4c0f-908c-56158dd5a4b2"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Fitting Model 0\n",
            "Fitting Model 1\n",
            "Fitting Model 2\n",
            "Fitting Model 3\n",
            "Fitting Model 4\n",
            "Fitting Model 5\n",
            "Fitting Model 6\n",
            "Fitting Model 7\n",
            "Fitting Model 8\n",
            "Fitting Model 9\n",
            "Fitting Model 10\n",
            "Fitting Model 11\n",
            "Fitting Model 12\n",
            "Fitting Model 13\n",
            "Fitting Model 14\n",
            "Fitting Model 15\n",
            "Fitting Model 16\n",
            "Fitting Model 17\n",
            "Fitting Model 18\n",
            "Fitting Model 19\n",
            "Fitting Model 20\n",
            "Fitting Model 21\n",
            "Fitting Model 22\n",
            "Fitting Model 23\n",
            "Fitting Model 24\n",
            "Fitting Model 25\n",
            "Fitting Model 26\n",
            "Fitting Model 27\n",
            "Fitting Model 28\n",
            "Fitting Model 29\n",
            "Fitting Model 30\n",
            "Fitting Model 31\n",
            "Fitting Model 32\n",
            "Fitting Model 33\n",
            "Fitting Model 34\n",
            "Fitting Model 35\n",
            "Fitting Model 36\n",
            "Fitting Model 37\n",
            "Fitting Model 38\n",
            "Fitting Model 39\n",
            "Fitting Model 40\n",
            "Fitting Model 41\n",
            "Fitting Model 42\n",
            "Fitting Model 43\n",
            "Fitting Model 44\n",
            "Fitting Model 45\n",
            "Fitting Model 46\n",
            "Fitting Model 47\n",
            "Fitting Model 48\n",
            "Fitting Model 49\n",
            "Fitting Model 50\n",
            "Fitting Model 51\n",
            "Fitting Model 52\n",
            "Fitting Model 53\n",
            "Fitting Model 54\n",
            "Fitting Model 55\n",
            "Fitting Model 56\n",
            "Fitting Model 57\n",
            "Fitting Model 58\n",
            "Fitting Model 59\n",
            "Fitting Model 60\n",
            "Fitting Model 61\n",
            "Fitting Model 62\n",
            "Fitting Model 63\n",
            "Fitting Model 64\n",
            "Fitting Model 65\n",
            "Fitting Model 66\n",
            "Fitting Model 67\n",
            "Fitting Model 68\n",
            "Fitting Model 69\n",
            "Fitting Model 70\n",
            "Fitting Model 71\n",
            "Fitting Model 72\n",
            "Fitting Model 73\n",
            "Fitting Model 74\n",
            "Fitting Model 75\n",
            "Fitting Model 76\n",
            "Fitting Model 77\n",
            "Fitting Model 78\n",
            "Fitting Model 79\n",
            "Fitting Model 80\n",
            "Fitting Model 81\n",
            "Fitting Model 82\n",
            "Fitting Model 83\n",
            "Fitting Model 84\n",
            "Fitting Model 85\n",
            "Fitting Model 86\n",
            "Fitting Model 87\n",
            "Fitting Model 88\n",
            "Fitting Model 89\n",
            "Fitting Model 90\n",
            "Fitting Model 91\n",
            "Fitting Model 92\n",
            "Fitting Model 93\n",
            "Fitting Model 94\n",
            "Fitting Model 95\n",
            "Fitting Model 96\n",
            "Fitting Model 97\n",
            "Fitting Model 98\n",
            "Fitting Model 99\n",
            "Fitting Model 100\n",
            "Fitting Model 101\n",
            "Fitting Model 102\n",
            "Fitting Model 103\n",
            "Fitting Model 104\n",
            "Fitting Model 105\n",
            "Fitting Model 106\n",
            "Fitting Model 107\n",
            "Fitting Model 108\n",
            "Fitting Model 109\n",
            "Fitting Model 110\n",
            "Fitting Model 111\n",
            "Fitting Model 112\n",
            "Fitting Model 113\n",
            "Fitting Model 114\n",
            "Fitting Model 115\n",
            "Fitting Model 116\n",
            "Fitting Model 117\n",
            "Fitting Model 118\n",
            "Fitting Model 119\n",
            "Fitting Model 120\n",
            "Fitting Model 121\n",
            "Fitting Model 122\n",
            "Fitting Model 123\n",
            "Fitting Model 124\n",
            "Fitting Model 125\n",
            "Fitting Model 126\n",
            "Fitting Model 127\n",
            "Fitting Model 128\n",
            "Fitting Model 129\n",
            "Fitting Model 130\n",
            "Fitting Model 131\n",
            "Fitting Model 132\n",
            "Fitting Model 133\n",
            "Fitting Model 134\n",
            "Fitting Model 135\n",
            "Fitting Model 136\n",
            "Fitting Model 137\n",
            "Fitting Model 138\n",
            "Fitting Model 139\n",
            "Fitting Model 140\n",
            "Fitting Model 141\n",
            "Fitting Model 142\n",
            "Fitting Model 143\n",
            "Fitting Model 144\n",
            "Fitting Model 145\n",
            "Fitting Model 146\n",
            "Fitting Model 147\n",
            "Fitting Model 148\n",
            "Fitting Model 149\n",
            "Fitting Model 150\n",
            "Fitting Model 151\n",
            "Fitting Model 152\n",
            "Fitting Model 153\n",
            "Fitting Model 154\n",
            "Fitting Model 155\n",
            "Fitting Model 156\n",
            "Fitting Model 157\n",
            "Fitting Model 158\n",
            "Fitting Model 159\n",
            "Fitting Model 160\n",
            "Fitting Model 161\n",
            "Fitting Model 162\n",
            "Fitting Model 163\n",
            "Fitting Model 164\n",
            "Fitting Model 165\n",
            "Fitting Model 166\n",
            "Fitting Model 167\n",
            "Fitting Model 168\n",
            "Fitting Model 169\n",
            "Fitting Model 170\n",
            "Fitting Model 171\n",
            "Fitting Model 172\n",
            "Fitting Model 173\n",
            "Fitting Model 174\n",
            "Fitting Model 175\n",
            "Fitting Model 176\n",
            "Fitting Model 177\n",
            "Fitting Model 178\n",
            "Fitting Model 179\n",
            "Fitting Model 180\n",
            "Fitting Model 181\n",
            "Fitting Model 182\n",
            "Fitting Model 183\n",
            "Fitting Model 184\n",
            "Fitting Model 185\n",
            "Fitting Model 186\n",
            "Fitting Model 187\n",
            "Fitting Model 188\n",
            "Fitting Model 189\n",
            "Fitting Model 190\n",
            "Fitting Model 191\n",
            "Fitting Model 192\n",
            "Fitting Model 193\n",
            "Fitting Model 194\n",
            "Fitting Model 195\n",
            "Fitting Model 196\n",
            "Fitting Model 197\n",
            "Fitting Model 198\n",
            "Fitting Model 199\n",
            "Fitting Model 200\n",
            "Fitting Model 201\n",
            "Fitting Model 202\n",
            "Fitting Model 203\n",
            "Fitting Model 204\n",
            "Fitting Model 205\n",
            "Fitting Model 206\n",
            "Fitting Model 207\n",
            "Fitting Model 208\n",
            "Fitting Model 209\n",
            "Fitting Model 210\n",
            "Fitting Model 211\n",
            "Fitting Model 212\n",
            "Fitting Model 213\n",
            "Fitting Model 214\n",
            "Fitting Model 215\n",
            "Fitting Model 216\n",
            "Fitting Model 217\n",
            "Fitting Model 218\n",
            "Fitting Model 219\n",
            "Fitting Model 220\n",
            "Fitting Model 221\n",
            "Fitting Model 222\n",
            "Fitting Model 223\n",
            "Fitting Model 224\n",
            "Fitting Model 225\n",
            "Fitting Model 226\n",
            "Fitting Model 227\n",
            "Fitting Model 228\n",
            "Fitting Model 229\n",
            "Fitting Model 230\n",
            "Fitting Model 231\n",
            "Fitting Model 232\n",
            "Fitting Model 233\n",
            "Fitting Model 234\n",
            "Fitting Model 235\n",
            "Fitting Model 236\n",
            "Fitting Model 237\n",
            "Fitting Model 238\n",
            "Fitting Model 239\n",
            "Fitting Model 240\n",
            "Fitting Model 241\n",
            "Fitting Model 242\n",
            "Fitting Model 243\n",
            "Fitting Model 244\n",
            "Fitting Model 245\n",
            "Fitting Model 246\n",
            "Fitting Model 247\n",
            "Fitting Model 248\n",
            "Fitting Model 249\n",
            "Fitting Model 250\n",
            "Fitting Model 251\n",
            "Fitting Model 252\n",
            "Fitting Model 253\n",
            "Fitting Model 254\n",
            "Fitting Model 255\n",
            "Fitting Model 256\n",
            "Fitting Model 257\n",
            "Fitting Model 258\n",
            "Fitting Model 259\n",
            "Fitting Model 260\n",
            "Fitting Model 261\n",
            "Fitting Model 262\n",
            "Fitting Model 263\n",
            "Fitting Model 264\n",
            "Fitting Model 265\n",
            "Fitting Model 266\n",
            "Fitting Model 267\n",
            "Fitting Model 268\n",
            "Fitting Model 269\n",
            "Fitting Model 270\n",
            "Fitting Model 271\n",
            "Fitting Model 272\n",
            "Fitting Model 273\n",
            "Fitting Model 274\n",
            "Fitting Model 275\n",
            "Fitting Model 276\n",
            "Fitting Model 277\n",
            "Fitting Model 278\n",
            "Fitting Model 279\n",
            "Fitting Model 280\n",
            "Fitting Model 281\n",
            "Fitting Model 282\n",
            "Fitting Model 283\n",
            "Fitting Model 284\n",
            "Fitting Model 285\n",
            "Fitting Model 286\n",
            "Fitting Model 287\n",
            "Fitting Model 288\n",
            "Fitting Model 289\n",
            "Fitting Model 290\n",
            "Fitting Model 291\n",
            "Fitting Model 292\n",
            "Fitting Model 293\n",
            "Fitting Model 294\n",
            "Fitting Model 295\n",
            "Fitting Model 296\n",
            "Fitting Model 297\n",
            "Fitting Model 298\n",
            "Fitting Model 299\n",
            "Fitting Model 300\n",
            "Fitting Model 301\n",
            "Fitting Model 302\n",
            "Fitting Model 303\n",
            "Fitting Model 304\n",
            "Fitting Model 305\n",
            "Fitting Model 306\n",
            "Fitting Model 307\n",
            "Fitting Model 308\n",
            "Fitting Model 309\n",
            "Fitting Model 310\n",
            "Fitting Model 311\n",
            "Fitting Model 312\n",
            "Fitting Model 313\n",
            "Fitting Model 314\n",
            "Fitting Model 315\n",
            "Fitting Model 316\n",
            "Fitting Model 317\n",
            "Fitting Model 318\n",
            "Fitting Model 319\n",
            "Fitting Model 320\n",
            "Fitting Model 321\n",
            "Fitting Model 322\n",
            "Fitting Model 323\n",
            "Fitting Model 324\n",
            "Fitting Model 325\n",
            "Fitting Model 326\n",
            "Fitting Model 327\n",
            "Fitting Model 328\n",
            "Fitting Model 329\n",
            "Fitting Model 330\n",
            "Fitting Model 331\n",
            "Fitting Model 332\n",
            "Fitting Model 333\n",
            "Fitting Model 334\n",
            "Fitting Model 335\n",
            "Fitting Model 336\n",
            "Fitting Model 337\n",
            "Fitting Model 338\n",
            "Fitting Model 339\n",
            "Fitting Model 340\n",
            "Fitting Model 341\n",
            "Fitting Model 342\n",
            "Fitting Model 343\n",
            "Fitting Model 344\n",
            "Fitting Model 345\n",
            "Fitting Model 346\n",
            "Fitting Model 347\n",
            "Fitting Model 348\n",
            "Fitting Model 349\n",
            "Fitting Model 350\n",
            "Fitting Model 351\n",
            "Fitting Model 352\n",
            "Fitting Model 353\n",
            "Fitting Model 354\n",
            "Fitting Model 355\n",
            "Fitting Model 356\n",
            "Fitting Model 357\n",
            "Fitting Model 358\n",
            "Fitting Model 359\n",
            "Fitting Model 360\n",
            "Fitting Model 361\n",
            "Fitting Model 362\n",
            "Fitting Model 363\n",
            "Fitting Model 364\n",
            "Fitting Model 365\n",
            "Fitting Model 366\n",
            "Fitting Model 367\n",
            "Fitting Model 368\n",
            "Fitting Model 369\n",
            "Fitting Model 370\n",
            "Fitting Model 371\n",
            "Fitting Model 372\n",
            "Fitting Model 373\n",
            "Fitting Model 374\n",
            "Fitting Model 375\n",
            "Fitting Model 376\n",
            "Fitting Model 377\n",
            "Fitting Model 378\n",
            "Fitting Model 379\n",
            "Fitting Model 380\n",
            "Fitting Model 381\n",
            "Fitting Model 382\n",
            "Fitting Model 383\n",
            "Fitting Model 384\n",
            "Fitting Model 385\n",
            "Fitting Model 386\n",
            "Fitting Model 387\n",
            "Fitting Model 388\n",
            "Fitting Model 389\n",
            "Fitting Model 390\n",
            "Fitting Model 391\n",
            "Fitting Model 392\n",
            "Fitting Model 393\n",
            "Fitting Model 394\n",
            "Fitting Model 395\n",
            "Fitting Model 396\n",
            "Fitting Model 397\n",
            "Fitting Model 398\n",
            "Fitting Model 399\n",
            "Fitting Model 400\n",
            "Fitting Model 401\n",
            "Fitting Model 402\n",
            "Fitting Model 403\n",
            "Fitting Model 404\n",
            "Fitting Model 405\n",
            "Fitting Model 406\n",
            "Fitting Model 407\n",
            "Fitting Model 408\n",
            "Fitting Model 409\n",
            "Fitting Model 410\n",
            "Fitting Model 411\n",
            "Fitting Model 412\n",
            "Fitting Model 413\n",
            "Fitting Model 414\n",
            "Fitting Model 415\n",
            "Fitting Model 416\n",
            "Fitting Model 417\n",
            "Fitting Model 418\n",
            "Fitting Model 419\n",
            "Fitting Model 420\n",
            "Fitting Model 421\n",
            "Fitting Model 422\n",
            "Fitting Model 423\n",
            "Fitting Model 424\n",
            "Fitting Model 425\n",
            "Fitting Model 426\n",
            "Fitting Model 427\n",
            "Fitting Model 428\n",
            "Fitting Model 429\n",
            "Fitting Model 430\n",
            "Fitting Model 431\n",
            "Fitting Model 432\n",
            "Fitting Model 433\n",
            "Fitting Model 434\n",
            "Fitting Model 435\n",
            "Fitting Model 436\n",
            "Fitting Model 437\n",
            "Fitting Model 438\n",
            "Fitting Model 439\n",
            "Fitting Model 440\n",
            "Fitting Model 441\n",
            "Fitting Model 442\n",
            "Fitting Model 443\n",
            "Fitting Model 444\n",
            "Fitting Model 445\n",
            "Fitting Model 446\n",
            "Fitting Model 447\n",
            "Fitting Model 448\n",
            "Fitting Model 449\n",
            "Fitting Model 450\n",
            "Fitting Model 451\n",
            "Fitting Model 452\n",
            "Fitting Model 453\n",
            "Fitting Model 454\n",
            "Fitting Model 455\n",
            "Fitting Model 456\n",
            "Fitting Model 457\n",
            "Fitting Model 458\n",
            "Fitting Model 459\n",
            "Fitting Model 460\n",
            "Fitting Model 461\n",
            "Fitting Model 462\n",
            "Fitting Model 463\n",
            "Fitting Model 464\n",
            "Fitting Model 465\n",
            "Fitting Model 466\n",
            "Fitting Model 467\n",
            "Fitting Model 468\n",
            "Fitting Model 469\n",
            "Fitting Model 470\n",
            "Fitting Model 471\n",
            "Fitting Model 472\n",
            "Fitting Model 473\n",
            "Fitting Model 474\n",
            "Fitting Model 475\n",
            "Fitting Model 476\n",
            "Fitting Model 477\n",
            "Fitting Model 478\n",
            "Fitting Model 479\n",
            "Fitting Model 480\n",
            "Fitting Model 481\n",
            "Fitting Model 482\n",
            "Fitting Model 483\n",
            "Fitting Model 484\n",
            "Fitting Model 485\n",
            "Fitting Model 486\n",
            "Fitting Model 487\n",
            "Fitting Model 488\n",
            "Fitting Model 489\n",
            "Fitting Model 490\n",
            "Fitting Model 491\n",
            "Fitting Model 492\n",
            "Fitting Model 493\n",
            "Fitting Model 494\n",
            "Fitting Model 495\n",
            "Fitting Model 496\n",
            "Fitting Model 497\n",
            "Fitting Model 498\n",
            "Fitting Model 499\n",
            "Fitting Model 500\n",
            "Fitting Model 501\n",
            "Fitting Model 502\n",
            "Fitting Model 503\n",
            "Fitting Model 504\n",
            "Fitting Model 505\n",
            "Fitting Model 506\n",
            "Fitting Model 507\n",
            "Fitting Model 508\n",
            "Fitting Model 509\n",
            "Fitting Model 510\n",
            "Fitting Model 511\n",
            "Fitting Model 512\n",
            "Fitting Model 513\n",
            "Fitting Model 514\n",
            "Fitting Model 515\n",
            "Fitting Model 516\n",
            "Fitting Model 517\n",
            "Fitting Model 518\n",
            "Fitting Model 519\n",
            "Fitting Model 520\n",
            "Fitting Model 521\n",
            "Fitting Model 522\n",
            "Fitting Model 523\n",
            "Fitting Model 524\n",
            "Fitting Model 525\n",
            "Fitting Model 526\n",
            "Fitting Model 527\n",
            "Fitting Model 528\n",
            "Fitting Model 529\n",
            "Fitting Model 530\n",
            "Fitting Model 531\n",
            "Fitting Model 532\n",
            "Fitting Model 533\n",
            "Fitting Model 534\n",
            "Fitting Model 535\n",
            "Fitting Model 536\n",
            "Fitting Model 537\n",
            "Fitting Model 538\n",
            "Fitting Model 539\n",
            "Fitting Model 540\n",
            "Fitting Model 541\n",
            "Fitting Model 542\n",
            "Fitting Model 543\n",
            "Fitting Model 544\n",
            "Fitting Model 545\n",
            "Fitting Model 546\n",
            "Fitting Model 547\n",
            "Fitting Model 548\n",
            "Fitting Model 549\n",
            "Fitting Model 550\n",
            "Fitting Model 551\n",
            "Fitting Model 552\n",
            "Fitting Model 553\n",
            "Fitting Model 554\n",
            "Fitting Model 555\n",
            "Fitting Model 556\n",
            "Fitting Model 557\n",
            "Fitting Model 558\n",
            "Fitting Model 559\n",
            "Fitting Model 560\n",
            "Fitting Model 561\n",
            "Fitting Model 562\n",
            "Fitting Model 563\n",
            "Fitting Model 564\n",
            "Fitting Model 565\n",
            "Fitting Model 566\n",
            "Fitting Model 567\n",
            "Fitting Model 568\n",
            "Fitting Model 569\n",
            "Fitting Model 570\n",
            "Fitting Model 571\n",
            "Fitting Model 572\n",
            "Fitting Model 573\n",
            "Fitting Model 574\n",
            "Fitting Model 575\n",
            "Fitting Model 576\n",
            "Fitting Model 577\n",
            "Fitting Model 578\n",
            "Fitting Model 579\n",
            "Fitting Model 580\n",
            "Fitting Model 581\n",
            "Fitting Model 582\n",
            "Fitting Model 583\n",
            "Fitting Model 584\n",
            "Fitting Model 585\n",
            "Fitting Model 586\n",
            "Fitting Model 587\n",
            "Fitting Model 588\n",
            "Fitting Model 589\n",
            "Fitting Model 590\n",
            "Fitting Model 591\n",
            "Fitting Model 592\n",
            "Fitting Model 593\n",
            "Fitting Model 594\n",
            "Fitting Model 595\n",
            "Fitting Model 596\n",
            "Fitting Model 597\n",
            "Fitting Model 598\n",
            "Fitting Model 599\n",
            "Fitting Model 600\n",
            "Fitting Model 601\n",
            "Fitting Model 602\n",
            "Fitting Model 603\n",
            "Fitting Model 604\n",
            "Fitting Model 605\n",
            "Fitting Model 606\n",
            "Fitting Model 607\n",
            "Fitting Model 608\n",
            "Fitting Model 609\n",
            "Fitting Model 610\n",
            "Fitting Model 611\n",
            "Fitting Model 612\n",
            "Fitting Model 613\n",
            "Fitting Model 614\n",
            "Fitting Model 615\n",
            "Fitting Model 616\n",
            "Fitting Model 617\n",
            "Fitting Model 618\n",
            "Fitting Model 619\n",
            "Fitting Model 620\n",
            "Fitting Model 621\n",
            "Fitting Model 622\n",
            "Fitting Model 623\n",
            "Fitting Model 624\n",
            "Fitting Model 625\n",
            "Fitting Model 626\n",
            "Fitting Model 627\n",
            "Fitting Model 628\n",
            "Fitting Model 629\n",
            "Fitting Model 630\n",
            "Fitting Model 631\n",
            "Fitting Model 632\n",
            "Fitting Model 633\n",
            "Fitting Model 634\n",
            "Fitting Model 635\n",
            "Fitting Model 636\n",
            "Fitting Model 637\n",
            "Fitting Model 638\n",
            "Fitting Model 639\n",
            "Fitting Model 640\n",
            "Fitting Model 641\n",
            "Fitting Model 642\n",
            "Fitting Model 643\n",
            "Fitting Model 644\n",
            "Fitting Model 645\n",
            "Fitting Model 646\n",
            "Fitting Model 647\n",
            "Fitting Model 648\n",
            "Fitting Model 649\n",
            "Fitting Model 650\n",
            "Fitting Model 651\n",
            "Fitting Model 652\n",
            "Fitting Model 653\n",
            "Fitting Model 654\n",
            "Fitting Model 655\n",
            "Fitting Model 656\n",
            "Fitting Model 657\n",
            "Fitting Model 658\n",
            "Fitting Model 659\n",
            "Fitting Model 660\n",
            "Fitting Model 661\n",
            "Fitting Model 662\n",
            "Fitting Model 663\n",
            "Fitting Model 664\n",
            "Fitting Model 665\n",
            "Fitting Model 666\n",
            "Fitting Model 667\n",
            "Fitting Model 668\n",
            "Fitting Model 669\n",
            "Fitting Model 670\n",
            "Fitting Model 671\n",
            "Fitting Model 672\n",
            "Fitting Model 673\n",
            "Fitting Model 674\n",
            "Fitting Model 675\n",
            "Fitting Model 676\n",
            "Fitting Model 677\n",
            "Fitting Model 678\n",
            "Fitting Model 679\n",
            "Fitting Model 680\n",
            "Fitting Model 681\n",
            "Fitting Model 682\n",
            "Fitting Model 683\n",
            "Fitting Model 684\n",
            "Fitting Model 685\n",
            "Fitting Model 686\n",
            "Fitting Model 687\n",
            "Fitting Model 688\n",
            "Fitting Model 689\n",
            "Fitting Model 690\n",
            "Fitting Model 691\n",
            "Fitting Model 692\n",
            "Fitting Model 693\n",
            "Fitting Model 694\n",
            "Fitting Model 695\n",
            "Fitting Model 696\n",
            "Fitting Model 697\n",
            "Fitting Model 698\n",
            "Fitting Model 699\n",
            "Fitting Model 700\n",
            "Fitting Model 701\n",
            "Fitting Model 702\n",
            "Fitting Model 703\n",
            "Fitting Model 704\n",
            "Fitting Model 705\n",
            "Fitting Model 706\n",
            "Fitting Model 707\n",
            "Fitting Model 708\n",
            "Fitting Model 709\n",
            "Fitting Model 710\n",
            "Fitting Model 711\n",
            "Fitting Model 712\n",
            "Fitting Model 713\n",
            "Fitting Model 714\n",
            "Fitting Model 715\n",
            "Fitting Model 716\n",
            "Fitting Model 717\n",
            "Fitting Model 718\n",
            "Fitting Model 719\n",
            "Fitting Model 720\n",
            "Fitting Model 721\n",
            "Fitting Model 722\n",
            "Fitting Model 723\n",
            "Fitting Model 724\n",
            "Fitting Model 725\n",
            "Fitting Model 726\n",
            "Fitting Model 727\n",
            "Fitting Model 728\n",
            "Fitting Model 729\n",
            "Fitting Model 730\n",
            "Fitting Model 731\n",
            "Fitting Model 732\n",
            "Fitting Model 733\n",
            "Fitting Model 734\n",
            "Fitting Model 735\n",
            "Fitting Model 736\n",
            "Fitting Model 737\n",
            "Fitting Model 738\n",
            "Fitting Model 739\n",
            "Fitting Model 740\n",
            "Fitting Model 741\n",
            "Fitting Model 742\n",
            "Fitting Model 743\n",
            "Fitting Model 744\n",
            "Fitting Model 745\n",
            "Fitting Model 746\n",
            "Fitting Model 747\n",
            "Fitting Model 748\n",
            "Fitting Model 749\n",
            "Fitting Model 750\n",
            "Fitting Model 751\n",
            "Fitting Model 752\n",
            "Fitting Model 753\n",
            "Fitting Model 754\n",
            "Fitting Model 755\n",
            "Fitting Model 756\n",
            "Fitting Model 757\n",
            "Fitting Model 758\n",
            "Fitting Model 759\n",
            "Fitting Model 760\n",
            "Fitting Model 761\n",
            "Fitting Model 762\n",
            "Fitting Model 763\n",
            "Fitting Model 764\n",
            "Fitting Model 765\n",
            "Fitting Model 766\n",
            "Fitting Model 767\n",
            "Fitting Model 768\n",
            "Fitting Model 769\n",
            "Fitting Model 770\n",
            "Fitting Model 771\n",
            "Fitting Model 772\n",
            "Fitting Model 773\n",
            "Fitting Model 774\n",
            "Fitting Model 775\n",
            "Fitting Model 776\n",
            "Fitting Model 777\n",
            "Fitting Model 778\n",
            "Fitting Model 779\n",
            "Fitting Model 780\n",
            "Fitting Model 781\n",
            "Fitting Model 782\n",
            "Fitting Model 783\n",
            "Fitting Model 784\n",
            "Fitting Model 785\n",
            "Fitting Model 786\n",
            "Fitting Model 787\n",
            "Fitting Model 788\n",
            "Fitting Model 789\n",
            "Fitting Model 790\n",
            "Fitting Model 791\n",
            "Fitting Model 792\n",
            "Fitting Model 793\n",
            "Fitting Model 794\n",
            "Fitting Model 795\n",
            "Fitting Model 796\n",
            "Fitting Model 797\n",
            "Fitting Model 798\n",
            "Fitting Model 799\n",
            "Fitting Model 800\n",
            "Fitting Model 801\n",
            "Fitting Model 802\n",
            "Fitting Model 803\n",
            "Fitting Model 804\n",
            "Fitting Model 805\n",
            "Fitting Model 806\n",
            "Fitting Model 807\n",
            "Fitting Model 808\n",
            "Fitting Model 809\n",
            "Fitting Model 810\n",
            "Fitting Model 811\n",
            "Fitting Model 812\n",
            "Fitting Model 813\n",
            "Fitting Model 814\n",
            "Fitting Model 815\n",
            "Fitting Model 816\n",
            "Fitting Model 817\n",
            "Fitting Model 818\n",
            "Fitting Model 819\n",
            "Fitting Model 820\n",
            "Fitting Model 821\n",
            "Fitting Model 822\n",
            "Fitting Model 823\n",
            "Fitting Model 824\n",
            "Fitting Model 825\n",
            "Fitting Model 826\n",
            "Fitting Model 827\n",
            "Fitting Model 828\n",
            "Fitting Model 829\n",
            "Fitting Model 830\n",
            "Fitting Model 831\n",
            "Fitting Model 832\n",
            "Fitting Model 833\n",
            "Fitting Model 834\n",
            "Fitting Model 835\n",
            "Fitting Model 836\n",
            "Fitting Model 837\n",
            "Fitting Model 838\n",
            "Fitting Model 839\n",
            "Fitting Model 840\n",
            "Fitting Model 841\n",
            "Fitting Model 842\n",
            "Fitting Model 843\n",
            "Fitting Model 844\n",
            "Fitting Model 845\n",
            "Fitting Model 846\n",
            "Fitting Model 847\n",
            "Fitting Model 848\n",
            "Fitting Model 849\n",
            "Fitting Model 850\n",
            "Fitting Model 851\n",
            "Fitting Model 852\n",
            "Fitting Model 853\n",
            "Fitting Model 854\n",
            "Fitting Model 855\n",
            "Fitting Model 856\n",
            "Fitting Model 857\n",
            "Fitting Model 858\n",
            "Fitting Model 859\n",
            "Fitting Model 860\n",
            "Fitting Model 861\n",
            "Fitting Model 862\n",
            "Fitting Model 863\n",
            "Fitting Model 864\n",
            "Fitting Model 865\n",
            "Fitting Model 866\n",
            "Fitting Model 867\n",
            "Fitting Model 868\n",
            "Fitting Model 869\n",
            "Fitting Model 870\n",
            "Fitting Model 871\n",
            "Fitting Model 872\n",
            "Fitting Model 873\n",
            "Fitting Model 874\n",
            "Fitting Model 875\n",
            "Fitting Model 876\n",
            "Fitting Model 877\n",
            "Fitting Model 878\n",
            "Fitting Model 879\n",
            "Fitting Model 880\n",
            "Fitting Model 881\n",
            "Fitting Model 882\n",
            "Fitting Model 883\n",
            "Fitting Model 884\n",
            "Fitting Model 885\n",
            "Fitting Model 886\n",
            "Fitting Model 887\n",
            "Fitting Model 888\n",
            "Fitting Model 889\n",
            "Fitting Model 890\n",
            "Fitting Model 891\n",
            "Fitting Model 892\n",
            "Fitting Model 893\n",
            "Fitting Model 894\n",
            "Fitting Model 895\n",
            "Fitting Model 896\n",
            "Fitting Model 897\n",
            "Fitting Model 898\n",
            "Fitting Model 899\n",
            "Fitting Model 900\n",
            "Fitting Model 901\n",
            "Fitting Model 902\n",
            "Fitting Model 903\n",
            "Fitting Model 904\n",
            "Fitting Model 905\n",
            "Fitting Model 906\n",
            "Fitting Model 907\n",
            "Fitting Model 908\n",
            "Fitting Model 909\n",
            "Fitting Model 910\n",
            "Fitting Model 911\n",
            "Fitting Model 912\n",
            "Fitting Model 913\n",
            "Fitting Model 914\n",
            "Fitting Model 915\n",
            "Fitting Model 916\n",
            "Fitting Model 917\n",
            "Fitting Model 918\n",
            "Fitting Model 919\n",
            "Fitting Model 920\n",
            "Fitting Model 921\n",
            "Fitting Model 922\n",
            "Fitting Model 923\n",
            "Fitting Model 924\n",
            "Fitting Model 925\n",
            "Fitting Model 926\n",
            "Fitting Model 927\n",
            "Fitting Model 928\n",
            "Fitting Model 929\n",
            "Fitting Model 930\n",
            "Fitting Model 931\n",
            "Fitting Model 932\n",
            "Fitting Model 933\n",
            "Fitting Model 934\n",
            "Fitting Model 935\n",
            "Fitting Model 936\n",
            "Fitting Model 937\n",
            "Fitting Model 938\n",
            "Fitting Model 939\n",
            "Fitting Model 940\n",
            "Fitting Model 941\n",
            "Fitting Model 942\n",
            "Fitting Model 943\n",
            "Fitting Model 944\n",
            "Fitting Model 945\n",
            "Fitting Model 946\n",
            "Fitting Model 947\n",
            "Fitting Model 948\n",
            "Fitting Model 949\n",
            "Fitting Model 950\n",
            "Fitting Model 951\n",
            "Fitting Model 952\n",
            "Fitting Model 953\n",
            "Fitting Model 954\n",
            "Fitting Model 955\n",
            "Fitting Model 956\n",
            "Fitting Model 957\n",
            "Fitting Model 958\n",
            "Fitting Model 959\n",
            "Fitting Model 960\n",
            "Fitting Model 961\n",
            "Fitting Model 962\n",
            "Fitting Model 963\n",
            "Fitting Model 964\n",
            "Fitting Model 965\n",
            "Fitting Model 966\n",
            "Fitting Model 967\n",
            "Fitting Model 968\n",
            "Fitting Model 969\n",
            "Fitting Model 970\n",
            "Fitting Model 971\n",
            "Fitting Model 972\n",
            "Fitting Model 973\n",
            "Fitting Model 974\n",
            "Fitting Model 975\n",
            "Fitting Model 976\n",
            "Fitting Model 977\n",
            "Fitting Model 978\n",
            "Fitting Model 979\n",
            "Fitting Model 980\n",
            "Fitting Model 981\n",
            "Fitting Model 982\n",
            "Fitting Model 983\n",
            "Fitting Model 984\n",
            "Fitting Model 985\n",
            "Fitting Model 986\n",
            "Fitting Model 987\n",
            "Fitting Model 988\n",
            "Fitting Model 989\n",
            "Fitting Model 990\n",
            "Fitting Model 991\n",
            "Fitting Model 992\n",
            "Fitting Model 993\n",
            "Fitting Model 994\n",
            "Fitting Model 995\n",
            "Fitting Model 996\n",
            "Fitting Model 997\n",
            "Fitting Model 998\n",
            "Fitting Model 999\n",
            "Fitting Model 1000\n",
            "Fitting Model 1001\n",
            "Fitting Model 1002\n",
            "Fitting Model 1003\n",
            "Fitting Model 1004\n",
            "Fitting Model 1005\n",
            "Fitting Model 1006\n",
            "Fitting Model 1007\n",
            "Fitting Model 1008\n",
            "Fitting Model 1009\n",
            "Fitting Model 1010\n",
            "Fitting Model 1011\n",
            "Fitting Model 1012\n",
            "Fitting Model 1013\n",
            "Fitting Model 1014\n",
            "Fitting Model 1015\n",
            "Fitting Model 1016\n",
            "Fitting Model 1017\n",
            "Fitting Model 1018\n",
            "Fitting Model 1019\n",
            "Fitting Model 1020\n",
            "Fitting Model 1021\n",
            "Fitting Model 1022\n",
            "Fitting Model 1023\n"
          ]
        }
      ],
      "source": [
        "pca_proj = PCAProjectionEnsemble(nmodels=2**10, ndirs=64, Vpca=np.eye(NDIRS, dtype=np.float32))\n",
        "pca_proj.fit(X, Y)\n",
        "# with open(os.path.join(BASE_DIR +'/' + EXP_NAME + '/' + dname, 'EMOE_pca_projens.p'), 'wb') as f:\n",
        "#     pickle.dump(pca_proj, f)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "hi49WbHHaExb",
        "outputId": "1c04a077-6af7-4f45-e027-a378151c1e55"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "2025-01-22_02:32:20\n"
          ]
        }
      ],
      "source": [
        "from datetime import datetime\n",
        "now = datetime.now()\n",
        "dt_string = now.strftime('%Y-%m-%d_%H:%M:%S')\n",
        "print(dt_string)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "b2QZCRh04rnj"
      },
      "outputs": [],
      "source": [
        "X_train = X  # X[~train_low_conf_ind]\n",
        "labels_train = Y[:, None]  # Y[~train_low_conf_ind, None]\n",
        "\n",
        "train_predictions = pca_proj.predictions(X)\n",
        "train_ens_preds, train_mp, train_sp = pca_proj.predict(preds=train_predictions, return_only_prediction=False)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "k4v2lSfWgq7v"
      },
      "outputs": [],
      "source": []
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "qnS-1z_sgrbE"
      },
      "outputs": [],
      "source": [
        "expand_funcs = [\n",
        "    # # lambda x: gibbs_sample(x, 40, 2),\n",
        "    # lambda x: permute_expand(x),\n",
        "    # lambda x: convex_expand(x),\n",
        "    lambda x: x*(1+np.abs(np.random.randn(x.shape[0], 1)))\n",
        "]"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "rj3Yvj1BxaZI",
        "outputId": "7a7e52a5-d12e-40e0-adfe-5597015b1439"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "[[[[[[[[[[[[[[[[[[[[[[  0  ]]]]]]]]]]]]]]]]]]]]]]\n",
            ">>>>>>>>0\n",
            ">>>>>>>>1\n",
            ">>>>>>>>2\n",
            "[[[[[[[[[[[[[[[[[[[[[[  1  ]]]]]]]]]]]]]]]]]]]]]]\n",
            ">>>>>>>>0\n",
            ">>>>>>>>1\n",
            ">>>>>>>>2\n",
            "[[[[[[[[[[[[[[[[[[[[[[  2  ]]]]]]]]]]]]]]]]]]]]]]\n",
            ">>>>>>>>0\n",
            ">>>>>>>>1\n",
            ">>>>>>>>2\n",
            "[[[[[[[[[[[[[[[[[[[[[[  3  ]]]]]]]]]]]]]]]]]]]]]]\n",
            ">>>>>>>>0\n",
            ">>>>>>>>1\n",
            ">>>>>>>>2\n",
            "[[[[[[[[[[[[[[[[[[[[[[  4  ]]]]]]]]]]]]]]]]]]]]]]\n",
            ">>>>>>>>0\n",
            ">>>>>>>>1\n",
            ">>>>>>>>2\n"
          ]
        }
      ],
      "source": [
        "conf_range = .1\n",
        "conf_expX = []\n",
        "conf_exppreds = []\n",
        "unconf_expX = []\n",
        "unconf_exppreds = []\n",
        "all_expX = []\n",
        "all_exppreds = []\n",
        "for dexptrl in range(5):\n",
        "  print('[[[[[[[[[[[[[[[[[[[[[[  {}  ]]]]]]]]]]]]]]]]]]]]]]'.format(dexptrl))\n",
        "  for trnd, expfunc in enumerate(expand_funcs):\n",
        "    print('>>>>>>>>{}'.format(trnd))\n",
        "\n",
        "    expanded_X = expfunc(X)\n",
        "    preds_exp = pca_proj.predictions(expanded_X)\n",
        "    ens_preds_exp, mp_exp, sp_exp = pca_proj.predict(preds=preds_exp, return_only_prediction=False)\n",
        "\n",
        "    high_conf_ind = np.logical_or(\n",
        "      np.greater(mp_exp, 1-conf_range/2), np.less(mp_exp, conf_range/2))\n",
        "    conf_expX.append(expanded_X[high_conf_ind])\n",
        "    conf_exppreds.append(preds_exp[high_conf_ind])"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "oQTlC7F44xe1"
      },
      "outputs": [],
      "source": [
        "conf_expX = np.concatenate(conf_expX, 0)\n",
        "conf_exppreds = np.concatenate(conf_exppreds, 0)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "ApCYqpVbGamZ"
      },
      "source": [
        "## RUN Tiny EMEO"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "JmqpeS-CGOQf",
        "outputId": "db50574e-90c5-4bbf-9cc1-bba7fce70b78"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "0.5\n",
            "Loss at step -01: 1.515\n",
            "Loss at step -01: 1.518\n",
            "Loss at step 000: 1.523\n",
            "Loss at step 1000: 0.230\n",
            "Loss at step 2000: 0.179\n",
            "Getting Average Model (T=0)\n",
            "Loss at step 3000: 0.219\n",
            "Loss at step 4000: 0.159\n",
            "Loss at step 5000: 0.136\n",
            "Getting Average Model (T=1)\n",
            "Loss at step 6000: 0.136\n",
            "Loss at step 7000: 0.160\n",
            "Getting Average Model (T=2)\n",
            "Loss at step 8000: 0.182\n",
            "Loss at step 9000: 0.205\n",
            "Loss at step 10000: 0.162\n",
            "Getting Average Model (T=3)\n"
          ]
        }
      ],
      "source": [
        "def loss(model, inputs, labels, inputs_conf, labels_conf, alpha=0.5):\n",
        "  # inputs_unconf_logits = model.get_features(inputs_unconf)\n",
        "  # inputs_unconf_sigmoids = tf.nn.sigmoid(inputs_unconf_logits)\n",
        "  # Encourage diversity by minimizing probability distribution innerproducts\n",
        "  # p*q + (1-p)(1-q) = 1 - p - q + 2*p*q\n",
        "  # Note: encouraging diversity for low confidence instances, to minimize dependencies on errors\n",
        "  # WRT existing previous experts\n",
        "  # pw_prods = 1. - inputs_unconf_sigmoids - labels_unconf + 2.*inputs_unconf_sigmoids*labels_unconf  # N x nexps\n",
        "  # diversity_loss = tf.reduce_mean(tf.reduce_mean(pw_prods, -1))\n",
        "  diversity_loss = 0.0\n",
        "\n",
        "  # uncertainty_loss = .5*tf.reduce_mean(\n",
        "  #   tf.abs(tf.reduce_mean(inputs_unconf_sigmoids, -1)-.5)) + \\\n",
        "  #   .5*tf.reduce_mean(\n",
        "  #     tf.abs(tf.reduce_mean(inputs_unconf_sigmoids, 0)-.5))\n",
        "  # mean_axis1 = tf.reduce_mean(inputs_unconf_sigmoids, -1, keepdims=True)\n",
        "  # var_axis1 = tf.reduce_mean(\n",
        "  #   tf.reduce_mean((inputs_unconf_sigmoids-mean_axis1)**2, -1))\n",
        "  # mean_axis0 = tf.reduce_mean(inputs_unconf_sigmoids, 0, keepdims=True)\n",
        "  # var_axis0 = tf.reduce_mean(\n",
        "  #   tf.reduce_mean((inputs_unconf_sigmoids-mean_axis0)**2, 0))\n",
        "  # uncertainty_loss = -.5*(var_axis0 + var_axis1)  # increase variances\n",
        "  uncertainty_loss = 0.0\n",
        "\n",
        "  conf_logits = model.get_features(inputs_conf)\n",
        "  conf_ce_loss = tf.reduce_mean(\n",
        "    tf.keras.losses.binary_crossentropy(labels_conf, conf_logits, from_logits=True))\n",
        "  conf_prob_loss = tf.reduce_mean(tf.abs(\n",
        "    tf.reduce_mean(tf.nn.sigmoid(conf_logits), 1, keepdims=True) - tf.reduce_mean(labels_conf, 1, keepdims=True)\n",
        "  ))\n",
        "  conf_loss = conf_ce_loss  # + conf_prob_loss\n",
        "\n",
        "  in_logits = model.get_features(inputs)\n",
        "  in_ce_loss = tf.reduce_mean(\n",
        "    tf.keras.losses.binary_crossentropy(labels, in_logits, from_logits=True))\n",
        "  in_prob_loss = tf.reduce_mean(tf.abs(\n",
        "    tf.reduce_mean(tf.nn.sigmoid(in_logits), 1, keepdims=True) - tf.reduce_mean(labels, 1, keepdims=True)\n",
        "  ))\n",
        "  in_loss = in_ce_loss + in_prob_loss\n",
        "  return in_loss + alpha*conf_loss + diversity_loss + uncertainty_loss\n",
        "\n",
        "def grad(model, inputs, labels, inputs_conf, labels_conf, alpha=0.5):\n",
        "  with tf.GradientTape() as tape:\n",
        "    loss_value = loss(model, inputs, labels, inputs_conf, labels_conf, alpha=alpha)\n",
        "  return tape.gradient(loss_value, model.trainable_variables)\n",
        "\n",
        "steps = TR_ITER\n",
        "#optimizer = tf.keras.optimizers.Adam(learning_rate=0.001)\n",
        "bsize = 256\n",
        "# model = DatasetDiscriminator(dim=X.shape[0], hidden_size=512, nhidden_layers=2, out_size=train_predictions.shape[1])\n",
        "\n",
        "avgint = TR_AVG_ITER\n",
        "\n",
        "conf_thresh = .4\n",
        "alpha_rnd = .5\n",
        "print(alpha_rnd)\n",
        "# critical_X = critical_ood[np.random.permutation(critical_ood.shape[0])[:X.shape[0]]]\n",
        "# critical_X = critical_ood[np.random.permutation(critical_ood.shape[0])[:1000]]\n",
        "# critical_X = critical_ood\n",
        "expanded_X = X*(1+np.abs(np.random.randn(X.shape[0], 1)))\n",
        "expanded_predictions = pca_proj.predictions(expanded_X)\n",
        "expanded_ens_preds, expanded_mp, expanded_sp = pca_proj.predict(expanded_X, preds=expanded_predictions, return_only_prediction=False)\n",
        "expanded_X = expanded_X[np.abs(expanded_mp-.5)>conf_thresh]\n",
        "expanded_predictions = expanded_predictions[np.abs(expanded_mp-.5)>conf_thresh]\n",
        "\n",
        "batch = training_batch(\n",
        "  X_train,  # np.concatenate((X_train, conf_expX), 0),\n",
        "  np.float32(train_predictions),  #np.concatenate((np.float32(labels_train), np.float32(conf_exppreds)), 0),\n",
        "  bsize)\n",
        "batch_conf = training_batch(\n",
        "  np.concatenate((conf_expX, expanded_X), 0), # expanded_X,\n",
        "  np.float32(np.concatenate((conf_exppreds, expanded_predictions), 0)),\n",
        "  bsize)\n",
        "batch_unconf = training_batch(\n",
        "  unconf_expX,\n",
        "  np.float32(unconf_exppreds),\n",
        "  bsize)\n",
        "# conf_lbls = np.concatenate((train_predictions, expanded_predictions), 0)\n",
        "# batch_conf = training_batch(\n",
        "#   np.concatenate((X, expanded_X), 0),\n",
        "#   conf_lbls,  # (conf_lbls-np.min(conf_lbls))/(np.max(conf_lbls)-np.min(conf_lbls)),\n",
        "#   bsize)\n",
        "\n",
        "xb, xlbls = batch()\n",
        "xb_conf, xlbls_conf = batch_conf()\n",
        "# xb_unconf, xlbls_unconf = batch_unconf()\n",
        "# TODO: consider new model each round?\n",
        "T = 0\n",
        "model = DatasetDiscriminator(dim=X.shape[0], hidden_size=32, nhidden_layers=2, out_size=train_predictions.shape[1])\n",
        "average_model = DatasetDiscriminator(dim=X.shape[0], hidden_size=32, nhidden_layers=2, out_size=train_predictions.shape[1])\n",
        "optimizer = tf.keras.optimizers.Adam(learning_rate=0.0005)\n",
        "print(\"Loss at step {:03d}: {:.3f}\".format(-1, loss(model, xb, xlbls, xb_conf, xlbls_conf, alpha=alpha_rnd)))\n",
        "print(\"Loss at step {:03d}: {:.3f}\".format(-1, loss(average_model, xb, xlbls, xb_conf, xlbls_conf, alpha=alpha_rnd)))\n",
        "for i in range(steps):\n",
        "  xb, xlbls = batch()\n",
        "  xb_conf, xlbls_conf = batch_conf()\n",
        "  # xb_unconf, xlbls_unconf = batch_unconf()\n",
        "  grads = grad(model, xb, xlbls, xb_conf, xlbls_conf, alpha=alpha_rnd)\n",
        "  optimizer.apply_gradients(zip(grads, model.trainable_variables))\n",
        "  if i % 1000 == 0:\n",
        "    print(\"Loss at step {:03d}: {:.3f}\".format(i, loss(model, xb, xlbls, xb_conf, xlbls_conf, alpha=alpha_rnd)))\n",
        "  if i > 0 and i % avgint == 0:\n",
        "    print('Getting Average Model (T={})'.format(T))\n",
        "    for avgweights, weights in zip(average_model.trainable_variables, model.trainable_variables):\n",
        "      avgweights.assign((T/(T+1.))*avgweights + (1./(T+1))*weights)\n",
        "    T = T + 1\n",
        "\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "rgHHl4BRfNS0"
      },
      "outputs": [],
      "source": [
        "AUCTHRESHS = [0.1, 0.2, 0.3, 0.4, 1]"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "SZQhmMBpEwLN"
      },
      "outputs": [],
      "source": [
        "end = time.time()\n",
        "length = end - start"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "r7CPg3GeE16I",
        "outputId": "9f33f36a-a762-46e4-dfc4-667848b43cae"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "It took 1061.5244574546814 seconds!\n"
          ]
        }
      ],
      "source": [
        "print(\"It took\", length, \"seconds!\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "Fa-pqZk0hcHR"
      },
      "outputs": [],
      "source": []
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "yHEKdzIlhrHl"
      },
      "outputs": [],
      "source": [
        "save_path = os.path.join(SAVE_DIR, dname, dt_string)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "1bVBhiABhrHl"
      },
      "outputs": [],
      "source": [
        "os.makedirs(save_path, exist_ok=True)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "l2WKovbZhrHl"
      },
      "outputs": [],
      "source": [
        "models_dict = {}\n",
        "models_dict['base'] = pca_proj\n",
        "models_dict['model_net'] = model.net\n",
        "models_dict['avg_model_net'] = average_model.net"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "IKsHL1IDhrHm"
      },
      "outputs": [],
      "source": [
        "with open(os.path.join(save_path, 'models.p'), 'wb') as f:\n",
        "    pickle.dump(models_dict, f)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "s1r1vnZxhrHm",
        "outputId": "d0cf24d2-ef71-46c4-b5ec-ba8f3de3efca"
      },
      "outputs": [
        {
          "data": {
            "text/plain": [
              "TensorShape([7392, 1024])"
            ]
          },
          "execution_count": 520,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "model.get_features(external_X).shape"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "3-B0d0INhrHm"
      },
      "outputs": [],
      "source": [
        "predictions_dict = {}\n",
        "predictions_dict['heldid_Y'] = held_Y\n",
        "predictions_dict['heldid_base'] = pca_proj.predictions(held_X)\n",
        "predictions_dict['heldid_model_net'] = model.predictions(held_X)\n",
        "predictions_dict['heldid_avg_model_net'] = average_model.predictions(held_X)\n",
        "predictions_dict['heldood_Y'] = external_Y\n",
        "predictions_dict['heldood_base'] = pca_proj.predictions(external_X)\n",
        "predictions_dict['heldood_model_net'] = model.predictions(external_X)\n",
        "predictions_dict['heldood_avg_model_net'] = average_model.predictions(external_X)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "y5tx3UiAhrHm"
      },
      "outputs": [],
      "source": [
        "with open(os.path.join(save_path, 'predictions.p'), 'wb') as f:\n",
        "    pickle.dump(predictions_dict, f)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "c1YcWqG0hrHm"
      },
      "outputs": [],
      "source": [
        "results_dict = {}\n",
        "results_dict['threshs'] = AUCTHRESHS"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 651
        },
        "id": "FTsa8JlqhrHn",
        "outputId": "bfec10d0-bbfc-4f5e-de24-2f42b3323def"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Base:\n",
            "[0.99934591 0.99869182 0.99803773 0.99738363 0.98615538] (AUROC:0.8792977845915576,ACC:0.9092458884877658)\n",
            "Model:\n",
            "[0.99685077 0.99636725 0.99602944 0.99541868 0.98322942] (AUROC:0.868830309384008,ACC:0.9108503810669876)\n",
            "Average Model:\n",
            "[0.9941475  0.9941168  0.99380902 0.99356101 0.98232302] (AUROC:0.8674111376797674,ACC:0.9122543120738067)\n",
            "Base+Model:\n",
            "[0.99664381 0.99645522 0.99645914 0.99625005 0.98539759] (AUROC:0.8830108864584355,ACC:0.9119534697152025)\n",
            "Base+Average Model:\n",
            "[0.99454299 0.99503082 0.99512763 0.99509648 0.98457102] (AUROC:0.8802508841220532,ACC:0.9107501002807862)\n"
          ]
        },
        {
          "data": {
            "image/png": "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5bx69Wpl/PjxysqVKxVA+eabb27b//jx44qbm5sSGxurHDhwQJk5c6ZT/q2TAqiYtWzZUnn++eftry0WixISEqJMnTo1z/69evVSunbt6tAWERGhDB8+vETzvFlhc75ZlSpVSqUAupucFUVRzGaz4unpqXz++ecllWIud5uzoihK06ZNlQkTJpREenkqSs5ms1lp1aqV8tlnnykDBw50egFU2JwXLFigeHt7Oym7vBU259mzZyvVqlVTsrOznZViLnf75/mDDz5QPD09lbS0tJJKMZfC5vz8888rDz/8sENbbGys0rp16xLN82aFzTk4OFj5+OOPHdr+/e9/K/369SvRPPNTkAJo9OjRSv369R3aevfurURHR5dgZooiQ2DFKDs7m127dhEVFWVvU6vVREVFsWXLljy32bJli0N/gOjo6Hz7F7ei5FzaiiPnjIwMTCYTFStWLKk0HdxtzoqikJCQwKFDh2jbtm1JpmpX1JwnT55MQEAAQ4YMcUaaDoqac1paGlWqVCEsLIzu3bvz119/OSNdoGg5f//990RGRvL8888TGBhIgwYNmDJlChaLpczmfKt58+bx5JNP4u7uXlJpOihKzq1atWLXrl32Iafjx4+zevVqunTpUmZzNhqNuYZwXV1d2bRpU4nmejdK63tQCqBidOnSJSwWC4GBgQ7tgYGBJCYm5rlNYmJiofoXt6LkXNqKI+fXXnuNkJCQXH/pSkpRc05OTsbDwwOdTkfXrl2ZOXMmHTp0KOl0gaLlvGnTJubNm8fcuXOdkWIuRcm5du3azJ8/n++++46vvvoKq9VKq1atOHPmjDNSLlLOx48fZ/ny5VgsFlavXs3rr7/OtGnT+M9//uOMlO/67+D27dvZv38/Q4cOLakUcylKzn379mXy5Mk8+OCDaLVaqlevTvv27Rk3bpwzUi5SztHR0UyfPp0jR45gtVpZt24dK1eu5Pz5885IuUjy+x5MSUkhMzOzxPYrBZAod95++20WL17MN998UyqTXQvD09OTPXv2sGPHDt566y1iY2PzfERMWZCamspTTz3F3Llz8fPzK+10CiwyMpIBAwbQpEkT2rVrx8qVK/H39+fTTz8t7dTyZbVaCQgI4L///S/NmjWjd+/ejB8/njlz5pR2agUyb948GjZsSMuWLUs7ldvasGEDU6ZM4ZNPPuGPP/5g5cqVrFq1ijfffLO0U8vXhx9+SM2aNalTpw46nY6YmBgGDx6MWi1f97cq9WeB3U/8/PzQaDQkJSU5tCclJREUFJTnNkFBQYXqX9yKknNpu5uc33//fd5++21++eUXGjVqVJJpOihqzmq1mho1agDQpEkTDh48yNSpU2nfvn1JpgsUPudjx47xzz//0K1bN3ub1WoFwMXFhUOHDlG9evUylXNetFotTZs25ejRoyWRYi5FyTk4OBitVotGo7G31a1bl8TERLKzs9HpdGUu5xzp6eksXryYyZMnl2SKuRQl59dff52nnnrKfqaqYcOGpKen88wzzzB+/PgSLyqKkrO/vz/ffvstWVlZXL58mZCQEMaMGUO1atVKNNe7kd/3oJeXF66uriW2XykJi5FOp6NZs2YkJCTY26xWKwkJCURGRua5TWRkpEN/gHXr1uXbv7gVJefSVtSc3333Xd58803Wrl1L8+bNnZGqXXG9z1arFaPRWBIp5lLYnOvUqcOff/7Jnj177Mu//vUvHnroIfbs2UNYWFiZyzkvFouFP//8k+Dg4JJK00FRcm7dujVHjx61F5gAhw8fJjg4uMSLn6LmnGPZsmUYjUb69+9f0mk6KErOGRkZuYqcnKJTccJjNO/mfTYYDISGhmI2m1mxYgXdu3cv6XSLrNS+B0t0inU5tHjxYkWv1yvx8fHKgQMHlGeeeUbx8fGxX1b71FNPKWPGjLH3//333xUXFxfl/fffVw4ePKjExcWVymXwhcnZaDQqu3fvVnbv3q0EBwcro0aNUnbv3q0cOXKkzOb89ttvKzqdTlm+fLnDpbipqallNucpU6YoP//8s3Ls2DHlwIEDyvvvv6+4uLgoc+fOLbM536o0rgIrbM6TJk1SfvrpJ+XYsWPKrl27lCeffFIxGAzKX3/9VWZzPnXqlOLp6anExMQohw4dUn788UclICBA+c9//lNmc87x4IMPKr1793ZanjcrbM5xcXGKp6en8vXXXyvHjx9Xfv75Z6V69epKr169ymzOW7duVVasWKEcO3ZM+fXXX5WHH35YqVq1qnL16lWn5Zyammr/jgCU6dOnK7t371ZOnjypKIqijBkzRnnqqafs/XMug3/11VeVgwcPKrNmzZLL4O9VM2fOVCpXrqzodDqlZcuWytatW+3r2rVrpwwcONCh/9KlS5VatWopOp1OqV+/vrJq1SonZ1y4nE+cOKEAuZZ27dqV2ZyrVKmSZ85xcXFlNufx48crNWrUUAwGg1KhQgUlMjJSWbx4sVPzLWzOtyqNAkhRCpfzyy+/bO8bGBiodOnSxan3TClKzoqiKJs3b1YiIiIUvV6vVKtWTXnrrbcUs9lcpnP++++/FUD5+eefnZrnzQqTs8lkUiZOnKhUr15dMRgMSlhYmPLcc885tZgobM4bNmxQ6tatq+j1esXX11d56qmnlLNnzzo13/Xr1+f5721OngMHDsz1fbF+/XqlSZMmik6nU6pVq+aU+0OpFMUJ5/GEEEIIIcoQmQMkhBBCiHJHCiAhhBBClDtSAAkhhBCi3JECSAghhBDljhRAQgghhCh3pAASQgghRLkjBZAQQgghyh0pgIQQQghR7kgBJIQodiqVim+//RaAf/75B5VKxZ49e267zaFDhwgKCiI1NbXkEyzj4uPj8fHxuWO/m9/n4rB27VqaNGni8IwxIe5XUgAJcR8ZNGgQKpUKlUqFVqulatWqjB49mqysrNJO7Y7Gjh3LCy+8gKenp71t6dKlNGnSBDc3N6pUqcJ7772Xa7sNGzbwwAMPoNfrqVGjBvHx8Q7rJ06caH9PcpY6deo49Gnfvn2uPs8+++xt8715G4PBQL169fjkk0+K/gbcpHfv3hw+fNjhGJo0aZKr3/nz5+ncuXOx7BOgU6dOaLVaFi5cWGwxhSirpAAS4j7TqVMnzp8/z/Hjx/nggw/49NNPiYuLK+20buvUqVP8+OOPDBo0yN62Zs0a+vXrx7PPPsv+/fv55JNP+OCDD/j444/tfU6cOEHXrl3tT5x/+eWXGTp0KD/99JND/Pr163P+/Hn7smnTplw5DBs2zKHPu+++e8e8c7Y5cOAAvXr14vnnn+frr78u+htxnaurKwEBAXfsFxQUhF6vv+v93WzQoEF89NFHxRpTiLJICiAh7jN6vZ6goCDCwsLo0aMHUVFRrFu3zr7earUydepUqlatiqurK40bN2b58uUOMf766y8effRRvLy88PT0pE2bNhw7dgyAHTt20KFDB/z8/PD29qZdu3b88ccfd5Xz0qVLady4MaGhofa2L7/8kh49evDss89SrVo1unbtytixY3nnnXfIeYThnDlzqFq1KtOmTaNu3brExMTwxBNP8MEHHzjEd3FxISgoyL74+fnlysHNzc2hj5eX1x3zztmmWrVqTJw4kZo1a/L9998DtqKue/fueHh44OXlRa9evUhKSrJvu3fvXh566CE8PT3x8vKiWbNm7Ny5E3AcAouPj2fSpEns3bvXfsYp5yzXzUNgrVq14rXXXnPI7+LFi2i1Wn799VcAjEYjo0aNIjQ0FHd3dyIiItiwYYPDNt26dWPnzp32z1uI+5UUQELcx/bv38/mzZvR6XT2tqlTp/LFF18wZ84c/vrrL0aOHEn//v3ZuHEjAGfPnqVt27bo9Xr+97//sWvXLp5++mnMZjMAqampDBw4kE2bNrF161Zq1qxJly5d7mruzm+//Ubz5s0d2oxGIwaDwaHN1dWVM2fOcPLkSQC2bNlCVFSUQ5/o6Gi2bNni0HbkyBFCQkKoVq0a/fr149SpU7lyWLhwIX5+fjRo0ICxY8eSkZFR6ONwdXUlOzsbq9VK9+7duXLlChs3bmTdunUcP36c3r172/v269ePSpUqsWPHDnbt2sWYMWPQarW5Yvbu3ZtXXnnF4SzWzXFujrd48WJufr71kiVLCAkJoU2bNgDExMSwZcsWFi9ezL59++jZsyedOnXiyJEj9m0qV65MYGAgv/32W6GPX4h7Sok/b14I4TQDBw5UNBqN4u7uruj1egVQ1Gq1snz5ckVRFCUrK0txc3NTNm/e7LDdkCFDlD59+iiKoihjx45VqlatqmRnZxdonxaLRfH09FR++OEHexugfPPNN4qiKMqJEycUQNm9e3e+MRo3bqxMnjzZoe3TTz9V3NzclF9++UWxWCzKoUOHlDp16iiAPf+aNWsqU6ZMcdhu1apVCqBkZGQoiqIoq1evVpYuXars3btXWbt2rRIZGalUrlxZSUlJcdjX2rVrlX379ilfffWVEhoaqjz22GO3Pe527dopL730kqIoimI2m5Uvv/xSAZSPP/5Y+fnnnxWNRqOcOnXK3v+vv/5SAGX79u2KoiiKp6enEh8fn2fsBQsWKN7e3vbXcXFxSuPGjXP1u/l9vnDhguLi4qL8+uuv9vWRkZHKa6+9piiKopw8eVLRaDTK2bNnHWI88sgjytixYx3amjZtqkycOPG2xy/Evc6l9EovIURJeOihh5g9ezbp6el88MEHuLi48PjjjwNw9OhRMjIy6NChg8M22dnZNG3aFIA9e/bQpk2bPM9GACQlJTFhwgQ2bNjAhQsXsFgsZGRk5HlWpaAyMzNzne0ZNmwYx44d49FHH8VkMuHl5cVLL73ExIkTUasLfvL65knCjRo1IiIigipVqrB06VKGDBkCwDPPPGPv07BhQ4KDg3nkkUc4duwY1atXzzf2J598wmeffUZ2djYajYaRI0cyYsQIPv74Y8LCwggLC7P3rVevHj4+Phw8eJAWLVoQGxvL0KFD+fLLL4mKiqJnz5633ded+Pv707FjRxYuXEibNm04ceIEW7Zs4dNPPwXgzz//xGKxUKtWLYftjEYjvr6+Dm2urq5FOgMmxL1ECiAh7jPu7u7UqFEDgPnz59O4cWPmzZvHkCFDSEtLA2DVqlUO820A+2RaV1fX28YfOHAgly9f5sMPP6RKlSro9XoiIyPJzs4ucs5+fn5cvXrVoU2lUvHOO+8wZcoUEhMT8ff3JyEhAYBq1aoBtknAN8+rAVuB5uXlle9x+Pj4UKtWLY4ePZpvPhEREYCtYLxdUdKvXz/Gjx+Pq6srwcHBhSrMJk6cSN++fVm1ahVr1qwhLi6OxYsX89hjjxU4Rl75vPjii8ycOZNFixbRsGFDGjZsCEBaWhoajYZdu3ah0WgctvPw8HB4feXKFfz9/YuchxD3ApkDJMR9TK1WM27cOCZMmEBmZib16tVDr9dz6tQpatSo4bDknK1o1KgRv/32GyaTKc+Yv//+Oy+++CJdunShfv366PV6Ll26dFd5Nm3alAMHDuS5TqPREBoaik6n4+uvvyYyMtL+5RwZGWkvinKsW7eOyMjIfPeVlpbGsWPHCA4OzrdPzj2LbtcHwNvbmxo1ahAaGupQ/NStW5fTp09z+vRpe9uBAwe4du0a9erVs7fVqlWLkSP/v727B0muDeMA/n8RLRIhAqGMyKKIhqLAoSUbitqyD6JCsC0bhBCsrZYGx4Qw2iSChoIGoZCWaij6FGvRKFObohz6ArWo6x0enkNh9PC8vO/TS/5/47mvo/d9znD+3FxHnVhfX0dPTw98Pt+H36PRaPDy8vLpXADAYrEgnU4jEAhgcXERVqtVGWtsbMTLywuur6+z7n1xcbFSl06nEY1GlR1Bou+KAYjom+vr64NKpYLX64VOp4PL5YLT6cT8/Dyi0SiCwSBmZmYwPz8P4Eej7P39PQYGBnB4eIizszMsLCzg9PQUAFBdXY2FhQWEw2Hs7e3BarX+ctfoV342Lr99yCeTSczNzSESiSAUCmF0dBTLy8vweDxKzcjICC4uLjA+Po5IJILZ2VksLS3B6XQqNS6XC1tbW4jH49jZ2UF3dzdUKhUGBwcBANFoFFNTUzg6OkI8Hoff74fNZoPZbEZ9ff0/Wk9bWxvq6upgtVoRDAaxv78Pm82GlpYWmEwmpFIpOBwObG5uIpFIYHt7GwcHB6itrf3w84xGI2KxGEKhEJLJJDKZzId1Wq0WXV1dmJiYQDgcVtYI/AhbVqsVNpsNKysriMVi2N/fh9vtxurqqlK3u7ur7OoRfWtf3YRERP+eoaEhsVgsWcfdbrfo9Xp5fHyU19dX8Xg8UlNTI2q1WvR6vXR0dMjW1pZSf3x8LO3t7VJQUCA6nU6am5slGo2KiEgwGBSTyST5+flSXV0ty8vLUl5eLtPT08r5+M0m6OfnZzEYDBIIBJRjNzc30tTUJFqtVgoKCqS1tVV2d3ezzt3Y2JCGhgbRaDRSWVkpPp/v3Xh/f7+UlJSIRqOR0tJS6e/vl/Pzc2X88vJSzGazFBUVSV5enlRVVcnY2Jjc3d19cqXfN0F/JJFISGdnp2i1WtHpdNLX1ydXV1ciIpLJZGRgYEDKyspEo9GIwWAQh8MhqVRKRLKboNPptPT29kphYaEAUNb49jr/tLa2JgDEbDZnzenp6UkmJyfFaDSKWq2WkpIS6e7ulpOTE6VmeHhY7Hb7p2sn+g7+EnnzziQR0Rfxer3w+/1ZP2JIf04ymURNTQ0ODw9RUVHx1dMh+k+xCZqI/hfsdjtub2/x8PDw7u8w6M+Jx+OYnZ1l+KGcwB0gIiIiyjlsgiYiIqKcwwBEREREOYcBiIiIiHIOAxARERHlHAYgIiIiyjkMQERERJRzGICIiIgo5zAAERERUc5hACIiIqKc8zfI967S+g7c1gAAAABJRU5ErkJggg==",
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "# plot id\n",
        "###########\n",
        "base_predictions = predictions_dict['heldid_base']\n",
        "model_predictions = predictions_dict['heldid_model_net']\n",
        "average_model_predictions = predictions_dict['heldid_avg_model_net']\n",
        "true_Y = predictions_dict['heldid_Y']\n",
        "\n",
        "plt.figure()\n",
        "\n",
        "# base model\n",
        "confs = np.mean(base_predictions, -1)\n",
        "preds = (confs >.5)\n",
        "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
        "plt.plot(recall, precision, c='brown')\n",
        "BASE_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
        "BASE_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
        "BASE_ACC = metrics.accuracy_score(true_Y, preds)\n",
        "\n",
        "print('Base:\\n{} (AUROC:{},ACC:{})'.format(BASE_AUPRC, BASE_AUROC,BASE_ACC))\n",
        "\n",
        "# student model\n",
        "confs = np.mean(model_predictions, -1)\n",
        "preds = (confs >.5)\n",
        "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
        "plt.plot(recall, precision, c='red')\n",
        "MOD_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
        "MOD_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
        "MOD_ACC = metrics.accuracy_score(true_Y, preds)\n",
        "print('Model:\\n{} (AUROC:{},ACC:{})'.format(MOD_AUPRC, MOD_AUROC,MOD_ACC))\n",
        "\n",
        "# average student model\n",
        "confs = np.mean(average_model_predictions, -1)\n",
        "preds = (confs >.5)\n",
        "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
        "plt.plot(recall, precision, c='pink')\n",
        "AVGMOD_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
        "AVGMOD_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
        "AVGMOD_ACC = metrics.accuracy_score(true_Y, preds)\n",
        "print('Average Model:\\n{} (AUROC:{},ACC:{})'.format(AVGMOD_AUPRC, AVGMOD_AUROC,AVGMOD_ACC))\n",
        "\n",
        "# base+student model\n",
        "confs = (np.mean(base_predictions, -1)+np.mean(model_predictions, -1))/2.\n",
        "preds = (confs >.5)\n",
        "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
        "plt.plot(recall, precision, c='blue')\n",
        "EMOE_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
        "EMOE_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
        "EMOE_ACC = metrics.accuracy_score(true_Y, preds)\n",
        "print('Base+Model:\\n{} (AUROC:{},ACC:{})'.format(EMOE_AUPRC, EMOE_AUROC,EMOE_ACC))\n",
        "\n",
        "# base+average student model\n",
        "confs = (np.mean(base_predictions, -1)+np.mean(average_model_predictions, -1))/2.\n",
        "preds = (confs >.5)\n",
        "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
        "plt.plot(recall, precision, c='cyan')\n",
        "AVGEMOE_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
        "AVGEMOE_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
        "AVGEMOE_ACC = metrics.accuracy_score(true_Y, preds)\n",
        "print('Base+Average Model:\\n{} (AUROC:{},ACC:{})'.format(AVGEMOE_AUPRC, AVGEMOE_AUROC,AVGEMOE_ACC))\n",
        "\n",
        "plt.xticks(np.arange(0, 1.01, step=0.1))\n",
        "plt.xticks(np.arange(0, 1.01, step=0.05), minor=True)\n",
        "plt.yticks(np.arange(0.6, 1.01, step=0.05))\n",
        "plt.grid(True, which='both')\n",
        "plt.xlabel('Recall ({} Positive)'.format(int(np.sum(true_Y))))\n",
        "plt.ylabel('Precision')\n",
        "plt.title('ID Precision vs Recall')\n",
        "plt.legend(['Base', 'NNet', 'AVGNNET', 'EMOE', 'AVGEMOE'])\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "U0vHW1hqhrHn"
      },
      "outputs": [],
      "source": [
        "results_dict['heldid_base_AUPRC'] = BASE_AUPRC\n",
        "results_dict['heldid_model_AUPRC'] = MOD_AUPRC\n",
        "results_dict['heldid_avg_model_AUPRC'] = AVGMOD_AUPRC\n",
        "results_dict['heldid_emoe_AUPRC'] = EMOE_AUPRC\n",
        "results_dict['heldid_avg_emoe_AUPRC'] = AVGEMOE_AUPRC\n",
        "\n",
        "results_dict['heldid_base_AUROC'] = BASE_AUROC\n",
        "results_dict['heldid_model_AUROC'] = MOD_AUROC\n",
        "results_dict['heldid_avg_model_AUROC'] = AVGMOD_AUROC\n",
        "results_dict['heldid_emoe_AUROC'] = EMOE_AUROC\n",
        "results_dict['heldid_avg_emoe_AUROC'] = AVGEMOE_AUROC"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 651
        },
        "id": "4vK71YGzhrHn",
        "outputId": "58ba17e6-4528-4717-96e6-33d805f6af94"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Base:\n",
            "[0.98978626 0.97957253 0.97123953 0.96371758 0.91160392] (AUROC:0.7001263008870153,ACC:0.8158820346320347)\n",
            "Model:\n",
            "[0.97229201 0.96298288 0.95304496 0.94442465 0.89961754] (AUROC:0.6806948730566995,ACC:0.8058712121212122)\n",
            "Average Model:\n",
            "[0.97738618 0.96631571 0.95793361 0.95015054 0.90271913] (AUROC:0.6849178923024337,ACC:0.8110119047619048)\n",
            "Base+Model:\n",
            "[0.9879569  0.97780064 0.9681153  0.95912635 0.9084658 ] (AUROC:0.6960897633252283,ACC:0.8158820346320347)\n",
            "Base+Average Model:\n",
            "[0.98755189 0.97715961 0.96852404 0.9602149  0.90913937] (AUROC:0.6971072612101128,ACC:0.8168290043290043)\n"
          ]
        },
        {
          "data": {
            "image/png": "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HDZAREREZHHYABEREZHFYQNEREREFocNEBEREVkcNkBERERkcdgAERERkcVhA0REREQWhw0QERERWRw2QERERGRx2AARERGRxWEDRERERBaHDRARERFZHDZAREREZHHYABEREZHFYQNEREREFocNEBEREVkcNkBERERkcdgAERERkcVhA0REREQWhw0QERERWRw2QERERGRx2AARERGRxWEDRERERBaHDRARERFZHDZAREREZHHYABEREZHFYQNEREREFsfsDdCKFSvg7u4OW1tb+Pj4IDk5+b7zb9y4gaCgIGi1WqjVanh6eiImJkb/+Lx586BQKAxubdu2NfZmEBER0WPE2pxPvnnzZoSEhGDVqlXw8fHBsmXL4O/vj/T0dDRr1qzS/NLSUvTr1w/NmjXD1q1b4erqiosXL8LR0dFgXocOHfDTTz/p71tbm3UziYiIqJ4xa2ewZMkSTJo0CePHjwcArFq1CtHR0VizZg1mzpxZaf6aNWuQl5eHhIQE2NjYAADc3d0rzbO2toazs7NRsxMREdHjy2xvgZWWliIlJQV+fn5/hbGygp+fHxITE6tcs3PnTvj6+iIoKAhOTk549tlnERERgbKyMoN5586dg4uLC1q2bInAwEBcunTJqNtCREREjxezHQG6du0aysrK4OTkZDDu5OSEM2fOVLkmMzMT+/btQ2BgIGJiYnD+/Hm8+eab0Ol0CA8PBwD4+Phg3bp18PLyQnZ2NubPn4/evXvj1KlT0Gg0VdYtKSlBSUmJ/n5+fj4AQKfTQafT1cXm6lXUe1zqGrM2M5umNjM//rWZ2TS1mdk0tU2R+WEoRETqPMFDuHLlClxdXZGQkABfX1/9eGhoKA4cOIAjR45UWuPp6Yni4mJkZWVBqVQCuPs22ieffILs7Owqn+fGjRto0aIFlixZggkTJlQ5Z968eZg/f36l8U2bNsHe3r42m0dEREQmVlRUhFGjRuHmzZtwcHC471yzHQFq0qQJlEolcnNzDcZzc3OrPX9Hq9XCxsZG3/wAQLt27ZCTk4PS0lKoVKpKaxwdHeHp6Ynz589XmyUsLAwhISH6+/n5+XBzc0P//v0fuANrSqfTYe/evejXr5/+PKb6XNeYtZnZNLWZ+fGvzcymqc3MpqltzMwV7+A8DLM1QCqVCt26dUNcXByGDBkCACgvL0dcXByCg4OrXNOzZ09s2rQJ5eXlsLK6e/rS2bNnodVqq2x+AODWrVvIyMjA6NGjq82iVquhVqsrjdvY2NT5D8fYtZnZNLWZ2TS1H8fMxqzNzKapzcymqW2MujWpZ9bPAQoJCcHq1auxfv16pKWlYerUqSgsLNRfFTZmzBiEhYXp50+dOhV5eXmYNm0azp49i+joaERERCAoKEg/Z8aMGThw4AAuXLiAhIQEvPrqq1AqlRg5cqTJt4+IiIjqJ7NeBh8QEIA//vgDc+fORU5ODry9vREbG6s/MfrSpUv6Iz0A4Obmht27d2P69Ono1KkTXF1dMW3aNLz33nv6Ob///jtGjhyJ69evo2nTpujVqxeSkpLQtGlTk28fERER1U9m/4TA4ODgat/yio+PrzTm6+uLpKSkautFRUXVVTQiIiJ6Qpn9qzCIiIiITI0NEBEREVkcNkBERERkcdgAERERkcVhA0REREQWhw0QERERWRw2QERERGRx2AARERGRxWEDRERERBaHDRARERFZHDZAREREZHHYABEREZHFYQNEREREFocNEBEREVkcNkBERERkcdgAERERkcVhA0REREQWhw0QERERWRw2QERERGRx2AARERGRxWEDRERERBaHDRARERFZHDZAREREZHHYABEREZHFYQNEREREFocNEBEREVkcNkBERERkcdgAERERkcVhA0REREQWhw0QERERWRw2QERERGRx2AARERGRxWEDRERERBaHDRARERFZHLM3QCtWrIC7uztsbW3h4+OD5OTk+86/ceMGgoKCoNVqoVar4enpiZiYmEeqSURERJbFrA3Q5s2bERISgvDwcBw7dgydO3eGv78/rl69WuX80tJS9OvXDxcuXMDWrVuRnp6O1atXw9XVtdY1iYiIyPKYtQFasmQJJk2ahPHjx6N9+/ZYtWoV7O3tsWbNmirnr1mzBnl5edixYwd69uwJd3d39OnTB507d651TSIiIrI8ZmuASktLkZKSAj8/v7/CWFnBz88PiYmJVa7ZuXMnfH19ERQUBCcnJzz77LOIiIhAWVlZrWsSERGR5bE21xNfu3YNZWVlcHJyMhh3cnLCmTNnqlyTmZmJffv2ITAwEDExMTh//jzefPNN6HQ6hIeH16omAJSUlKCkpER//+bNmwCAvLw86HS62m5ilXQ6HYqKinD9+nXY2NjU+7rGrM3MpqnNzI9/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",
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "# plot ood\n",
        "###########\n",
        "base_predictions = predictions_dict['heldood_base']\n",
        "model_predictions = predictions_dict['heldood_model_net']\n",
        "average_model_predictions = predictions_dict['heldood_avg_model_net']\n",
        "true_Y = predictions_dict['heldood_Y']\n",
        "\n",
        "plt.figure()\n",
        "\n",
        "# base model\n",
        "confs = np.mean(base_predictions, -1)\n",
        "preds = (confs >.5)\n",
        "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
        "plt.plot(recall, precision, c='brown')\n",
        "BASE_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
        "BASE_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
        "BASE_ACC = metrics.accuracy_score(true_Y, preds)\n",
        "\n",
        "print('Base:\\n{} (AUROC:{},ACC:{})'.format(BASE_AUPRC, BASE_AUROC,BASE_ACC))\n",
        "\n",
        "# student model\n",
        "confs = np.mean(model_predictions, -1)\n",
        "preds = (confs >.5)\n",
        "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
        "plt.plot(recall, precision, c='red')\n",
        "MOD_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
        "MOD_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
        "MOD_ACC = metrics.accuracy_score(true_Y, preds)\n",
        "print('Model:\\n{} (AUROC:{},ACC:{})'.format(MOD_AUPRC, MOD_AUROC,MOD_ACC))\n",
        "\n",
        "# average student model\n",
        "confs = np.mean(average_model_predictions, -1)\n",
        "preds = (confs >.5)\n",
        "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
        "plt.plot(recall, precision, c='pink')\n",
        "AVGMOD_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
        "AVGMOD_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
        "AVGMOD_ACC = metrics.accuracy_score(true_Y, preds)\n",
        "print('Average Model:\\n{} (AUROC:{},ACC:{})'.format(AVGMOD_AUPRC, AVGMOD_AUROC,AVGMOD_ACC))\n",
        "\n",
        "# base+student model\n",
        "confs = (np.mean(base_predictions, -1)+np.mean(model_predictions, -1))/2.\n",
        "preds = (confs >.5)\n",
        "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
        "plt.plot(recall, precision, c='blue')\n",
        "EMOE_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
        "EMOE_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
        "EMOE_ACC = metrics.accuracy_score(true_Y, preds)\n",
        "print('Base+Model:\\n{} (AUROC:{},ACC:{})'.format(EMOE_AUPRC, EMOE_AUROC,EMOE_ACC))\n",
        "\n",
        "# base+average student model\n",
        "confs = (np.mean(base_predictions, -1)+np.mean(average_model_predictions, -1))/2.\n",
        "preds = (confs >.5)\n",
        "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
        "plt.plot(recall, precision, c='cyan')\n",
        "AVGEMOE_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
        "AVGEMOE_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
        "AVGEMOE_ACC = metrics.accuracy_score(true_Y, preds)\n",
        "print('Base+Average Model:\\n{} (AUROC:{},ACC:{})'.format(AVGEMOE_AUPRC, AVGEMOE_AUROC,AVGEMOE_ACC))\n",
        "\n",
        "plt.xticks(np.arange(0, 1.01, step=0.1))\n",
        "plt.xticks(np.arange(0, 1.01, step=0.05), minor=True)\n",
        "plt.yticks(np.arange(0.6, 1.01, step=0.05))\n",
        "plt.grid(True, which='both')\n",
        "plt.xlabel('Recall ({} Positive)'.format(int(np.sum(true_Y))))\n",
        "plt.ylabel('Precision')\n",
        "plt.title('ID Precision vs Recall')\n",
        "plt.legend(['Base', 'NNet', 'AVGNNET', 'EMOE', 'AVGEMOE'])\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "vPUQWf5ohrHn"
      },
      "outputs": [],
      "source": [
        "results_dict['heldood_base_AUPRC'] = BASE_AUPRC\n",
        "results_dict['heldood_model_AUPRC'] = MOD_AUPRC\n",
        "results_dict['heldood_avg_model_AUPRC'] = AVGMOD_AUPRC\n",
        "results_dict['heldood_emoe_AUPRC'] = EMOE_AUPRC\n",
        "results_dict['heldood_avg_emoe_AUPRC'] = AVGEMOE_AUPRC\n",
        "\n",
        "results_dict['heldood_base_AUROC'] = BASE_AUROC\n",
        "results_dict['heldood_model_AUROC'] = MOD_AUROC\n",
        "results_dict['heldood_avg_model_AUROC'] = AVGMOD_AUROC\n",
        "results_dict['heldood_emoe_AUROC'] = EMOE_AUROC\n",
        "results_dict['heldood_avg_emoe_AUROC'] = AVGEMOE_AUROC\n",
        "\n",
        "results_dict['heldood_base_ACC'] = BASE_ACC\n",
        "results_dict['heldood_model_ACC'] = MOD_ACC\n",
        "results_dict['heldood_avg_model_ACC'] = AVGMOD_ACC\n",
        "results_dict['heldood_emoe_ACC'] = EMOE_ACC\n",
        "results_dict['heldood_avg_emoe_ACC'] = AVGEMOE_ACC"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "GG1XFcaEhrHn"
      },
      "outputs": [],
      "source": [
        "with open(os.path.join(save_path, 'results.p'), 'wb') as f:\n",
        "    pickle.dump(results_dict, f)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "nvURo8ZwFTuX"
      },
      "source": [
        "## RUN FULL EMOE"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "qqydmkQoGfcR",
        "outputId": "496646b5-b3e3-4714-8cf9-cefab14afd73"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "0.5\n",
            "Loss at step -01: 1.579\n",
            "Loss at step -01: 1.581\n",
            "Loss at step 000: 1.508\n",
            "Loss at step 1000: 0.227\n",
            "Loss at step 2000: 0.162\n",
            "Loss at step 3000: 0.141\n",
            "Loss at step 4000: 0.136\n",
            "Loss at step 5000: 0.106\n",
            "Getting Average Model (T=0)\n",
            "Loss at step 6000: 0.081\n",
            "Loss at step 7000: 0.100\n",
            "Loss at step 8000: 0.082\n",
            "Loss at step 9000: 0.073\n",
            "Loss at step 10000: 0.094\n",
            "Getting Average Model (T=1)\n",
            "Loss at step 11000: 0.090\n",
            "Loss at step 12000: 0.067\n",
            "Loss at step 13000: 0.075\n",
            "Loss at step 14000: 0.077\n",
            "Loss at step 15000: 0.077\n",
            "Getting Average Model (T=2)\n",
            "Loss at step 16000: 0.067\n",
            "Loss at step 17000: 0.080\n",
            "Loss at step 18000: 0.083\n",
            "Loss at step 19000: 0.074\n",
            "Loss at step 20000: 0.072\n",
            "Getting Average Model (T=3)\n"
          ]
        }
      ],
      "source": [
        "steps = 20001\n",
        "#optimizer = tf.keras.optimizers.Adam(learning_rate=0.001)\n",
        "bsize = 256\n",
        "# model = DatasetDiscriminator(dim=X.shape[0], hidden_size=512, nhidden_layers=2, out_size=train_predictions.shape[1])\n",
        "\n",
        "avgint = 5000\n",
        "\n",
        "conf_thresh = .4\n",
        "alpha_rnd = .5\n",
        "print(alpha_rnd)\n",
        "# critical_X = critical_ood[np.random.permutation(critical_ood.shape[0])[:X.shape[0]]]\n",
        "# critical_X = critical_ood[np.random.permutation(critical_ood.shape[0])[:1000]]\n",
        "\n",
        "expanded_X = X*(1+np.abs(np.random.randn(X.shape[0], 1)))\n",
        "expanded_predictions = pca_proj.predictions(expanded_X)\n",
        "expanded_ens_preds, expanded_mp, expanded_sp = pca_proj.predict(expanded_X, preds=expanded_predictions, return_only_prediction=False)\n",
        "expanded_X = expanded_X[np.abs(expanded_mp-.5)>conf_thresh]\n",
        "expanded_predictions = expanded_predictions[np.abs(expanded_mp-.5)>conf_thresh]\n",
        "\n",
        "batch = training_batch(\n",
        "  X_train,  # np.concatenate((X_train, conf_expX), 0),\n",
        "  np.float32(train_predictions),  #np.concatenate((np.float32(labels_train), np.float32(conf_exppreds)), 0),\n",
        "  bsize)\n",
        "batch_conf = training_batch(\n",
        "  np.concatenate((conf_expX, expanded_X), 0), # expanded_X,\n",
        "  np.float32(np.concatenate((conf_exppreds, expanded_predictions), 0)),\n",
        "  bsize)\n",
        "batch_unconf = training_batch(\n",
        "  unconf_expX,\n",
        "  np.float32(unconf_exppreds),\n",
        "  bsize)\n",
        "# conf_lbls = np.concatenate((train_predictions, expanded_predictions), 0)\n",
        "# batch_conf = training_batch(\n",
        "#   np.concatenate((X, expanded_X), 0),\n",
        "#   conf_lbls,  # (conf_lbls-np.min(conf_lbls))/(np.max(conf_lbls)-np.min(conf_lbls)),\n",
        "#   bsize)\n",
        "\n",
        "xb, xlbls = batch()\n",
        "xb_conf, xlbls_conf = batch_conf()\n",
        "# xb_unconf, xlbls_unconf = batch_unconf()\n",
        "# TODO: consider new model each round?\n",
        "T = 0\n",
        "model = DatasetDiscriminator(dim=X.shape[0], hidden_size=512, nhidden_layers=2, out_size=train_predictions.shape[1])\n",
        "average_model = DatasetDiscriminator(dim=X.shape[0], hidden_size=512, nhidden_layers=2, out_size=train_predictions.shape[1])\n",
        "optimizer = tf.keras.optimizers.Adam(learning_rate=0.0005)\n",
        "print(\"Loss at step {:03d}: {:.3f}\".format(-1, loss(model, xb, xlbls, xb_conf, xlbls_conf, alpha=alpha_rnd)))\n",
        "print(\"Loss at step {:03d}: {:.3f}\".format(-1, loss(average_model, xb, xlbls, xb_conf, xlbls_conf, alpha=alpha_rnd)))\n",
        "for i in range(steps):\n",
        "  xb, xlbls = batch()\n",
        "  xb_conf, xlbls_conf = batch_conf()\n",
        "  # xb_unconf, xlbls_unconf = batch_unconf()\n",
        "  grads = grad(model, xb, xlbls, xb_conf, xlbls_conf, alpha=alpha_rnd)\n",
        "  optimizer.apply_gradients(zip(grads, model.trainable_variables))\n",
        "  if i % 1000 == 0:\n",
        "    print(\"Loss at step {:03d}: {:.3f}\".format(i, loss(model, xb, xlbls, xb_conf, xlbls_conf, alpha=alpha_rnd)))\n",
        "  if i > 0 and i % avgint == 0:\n",
        "    print('Getting Average Model (T={})'.format(T))\n",
        "    for avgweights, weights in zip(average_model.trainable_variables, model.trainable_variables):\n",
        "      avgweights.assign((T/(T+1.))*avgweights + (1./(T+1))*weights)\n",
        "    T = T + 1\n",
        "\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "98-4lUyBGfcR"
      },
      "outputs": [],
      "source": [
        "end = time.time()\n",
        "length = end - start"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "nJsUzA0VGfcR",
        "outputId": "b8210529-d0fa-4b57-961c-15e0d68aaec1"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "It took 2228.165778875351 seconds!\n"
          ]
        }
      ],
      "source": [
        "print(\"It took\", length, \"seconds!\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "jbz6Vk2kGfcR"
      },
      "outputs": [],
      "source": [
        "# from datetime import datetime\n",
        "# now = datetime.now()\n",
        "# dt_string = now.strftime('%Y-%m-%d_%H:%M:%S')\n",
        "# print(dt_string)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "FXk5DZKwGfcR"
      },
      "outputs": [],
      "source": [
        "save_path = os.path.join(SAVE_DIR, 'full_EMOE' , dname, dt_string)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "gU_lDDN8GfcR"
      },
      "outputs": [],
      "source": [
        "os.makedirs(save_path, exist_ok=True)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "TWkWll2YGfcR"
      },
      "outputs": [],
      "source": [
        "models_dict = {}\n",
        "models_dict['base'] = pca_proj\n",
        "models_dict['model_net'] = model.net\n",
        "models_dict['avg_model_net'] = average_model.net"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "Hs09LbTeGfcR"
      },
      "outputs": [],
      "source": [
        "with open(os.path.join(save_path, 'models.p'), 'wb') as f:\n",
        "    pickle.dump(models_dict, f)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "Xhho6yD2GfcR"
      },
      "outputs": [],
      "source": [
        "predictions_dict = {}\n",
        "predictions_dict['heldid_Y'] = held_Y\n",
        "predictions_dict['heldid_base'] = pca_proj.predictions(held_X)\n",
        "predictions_dict['heldid_model_net'] = model.predictions(held_X)\n",
        "predictions_dict['heldid_avg_model_net'] = average_model.predictions(held_X)\n",
        "predictions_dict['heldood_Y'] = external_Y\n",
        "predictions_dict['heldood_base'] = pca_proj.predictions(external_X)\n",
        "predictions_dict['heldood_model_net'] = model.predictions(external_X)\n",
        "predictions_dict['heldood_avg_model_net'] = average_model.predictions(external_X)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "AgoP2JGpGfcS"
      },
      "outputs": [],
      "source": [
        "with open(os.path.join(save_path, 'predictions.p'), 'wb') as f:\n",
        "    pickle.dump(predictions_dict, f)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "H-JFD9nZGfcS"
      },
      "outputs": [],
      "source": [
        "results_dict = {}\n",
        "results_dict['threshs'] = AUCTHRESHS"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 651
        },
        "id": "n77FJ6qrGfcS",
        "outputId": "021df153-2fc6-40ee-dffb-0735382d2282"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Base:\n",
            "[0.99934591 0.99869182 0.99803773 0.99738363 0.98615538] (AUROC:0.8792977845915576,ACC:0.9092458884877658)\n",
            "Model:\n",
            "[0.99448297 0.99598816 0.99640948 0.99633526 0.98624324] (AUROC:0.8898776229355682,ACC:0.9127557160048135)\n",
            "Average Model:\n",
            "[0.99422974 0.99537798 0.99599513 0.99605778 0.98601166] (AUROC:0.8887797038213702,ACC:0.9127557160048135)\n",
            "Base+Model:\n",
            "[0.99447217 0.99596969 0.99639197 0.99660406 0.98728677] (AUROC:0.8964646558924108,ACC:0.9104492579221821)\n",
            "Base+Average Model:\n",
            "[0.99419869 0.99557323 0.9963682  0.99672765 0.98738597] (AUROC:0.8968792433492885,ACC:0.910950661853189)\n"
          ]
        },
        {
          "data": {
            "image/png": "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svDaa69h8uTJ5V5UlCVnLy8v/PDDD8jNzcXNmzfh7++PCRMmoGbNmuWa6+Mo6nvQ1dUVDg4O5bZfloQWpFQq0aJFCyQkJJjajEYjEhISEBYWVug2YWFhZv0BYPv27UX2t7Sy5GxrZc157ty5+OCDDxAfH4+WLVtaI1UTS73PRqMRGo2mPFIsoLQ516tXD3///TeOHj1qWl588UU899xzOHr0KAIDAytczoUxGAz4+++/4efnV15pmilLzq1bt8bZs2dNBSYAnD59Gn5+fuVe/JQ153zr1q2DRqPBwIEDyztNM2XJOTs7u0CRk190Cis8RvNx3me1Wo2AgADo9Xps2LABPXr0KO90y8xm34PlOsXaDq1evVqoVCoRFxcnTpw4IV577TXh7u5uuqz21VdfFRMmTDD1/+OPP4RcLheffPKJOHnypIiJibHJZfClyVmj0YgjR46II0eOCD8/PzFu3Dhx5MgRcebMmQqb84cffiiUSqVYv3692aW4d+/erbA5z549W2zbtk0kJSWJEydOiE8++UTI5XKxdOnSCpvzw2xxFVhpc54xY4b49ddfRVJSkjh06JDo27evUKvV4vjx4xU25+TkZOHi4iKioqLEqVOnxC+//CK8vb3Ff/7znwqbc75nn31WREZGWi3PB5U255iYGOHi4iK+//57ce7cObFt2zZRq1Yt0adPnwqb8759+8SGDRtEUlKS+O2330SHDh1EjRo1xO3bt62W8927d03fEQDE/PnzxZEjR8TFixeFEEJMmDBBvPrqq6b++ZfBv/fee+LkyZNi8eLFvAy+slq0aJGoXr26UCqVolWrVmLfvn2mde3atRODBw8267927VpRt25doVQqRcOGDcXmzZutnHHpcj5//rwAUGBp165dhc05KCio0JxjYmIqbM6TJ08WtWvXFmq1WlSpUkWEhYWJ1atXWzXf0ub8MFsUQEKULud33nnH1NfHx0d07drVqvdMKUvOQgixZ88eERoaKlQqlahZs6aYNWuW0Ov1FTrnf//9VwAQ27Zts2qeDypNzjqdTkyfPl3UqlVLqNVqERgYKF5//XWrFhOlzTkxMVHUr19fqFQq4eHhIV599VVx5coVq+a7c+fOQv+9zc9z8ODBBb4vdu7cKZo1ayaUSqWoWbOmVe4PJRHCCuN4RERERBUI5wARERGR3WEBRERERHaHBRAR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",
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "# plot id\n",
        "###########\n",
        "base_predictions = predictions_dict['heldid_base']\n",
        "model_predictions = predictions_dict['heldid_model_net']\n",
        "average_model_predictions = predictions_dict['heldid_avg_model_net']\n",
        "true_Y = predictions_dict['heldid_Y']\n",
        "\n",
        "plt.figure()\n",
        "\n",
        "# base model\n",
        "confs = np.mean(base_predictions, -1)\n",
        "preds = (confs >.5)\n",
        "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
        "plt.plot(recall, precision, c='brown')\n",
        "BASE_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
        "BASE_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
        "BASE_ACC = metrics.accuracy_score(true_Y, preds)\n",
        "\n",
        "print('Base:\\n{} (AUROC:{},ACC:{})'.format(BASE_AUPRC, BASE_AUROC,BASE_ACC))\n",
        "\n",
        "# student model\n",
        "confs = np.mean(model_predictions, -1)\n",
        "preds = (confs >.5)\n",
        "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
        "plt.plot(recall, precision, c='red')\n",
        "MOD_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
        "MOD_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
        "MOD_ACC = metrics.accuracy_score(true_Y, preds)\n",
        "print('Model:\\n{} (AUROC:{},ACC:{})'.format(MOD_AUPRC, MOD_AUROC,MOD_ACC))\n",
        "\n",
        "# average student model\n",
        "confs = np.mean(average_model_predictions, -1)\n",
        "preds = (confs >.5)\n",
        "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
        "plt.plot(recall, precision, c='pink')\n",
        "AVGMOD_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
        "AVGMOD_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
        "AVGMOD_ACC = metrics.accuracy_score(true_Y, preds)\n",
        "print('Average Model:\\n{} (AUROC:{},ACC:{})'.format(AVGMOD_AUPRC, AVGMOD_AUROC,AVGMOD_ACC))\n",
        "\n",
        "# base+student model\n",
        "confs = (np.mean(base_predictions, -1)+np.mean(model_predictions, -1))/2.\n",
        "preds = (confs >.5)\n",
        "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
        "plt.plot(recall, precision, c='blue')\n",
        "EMOE_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
        "EMOE_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
        "EMOE_ACC = metrics.accuracy_score(true_Y, preds)\n",
        "print('Base+Model:\\n{} (AUROC:{},ACC:{})'.format(EMOE_AUPRC, EMOE_AUROC,EMOE_ACC))\n",
        "\n",
        "# base+average student model\n",
        "confs = (np.mean(base_predictions, -1)+np.mean(average_model_predictions, -1))/2.\n",
        "preds = (confs >.5)\n",
        "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
        "plt.plot(recall, precision, c='cyan')\n",
        "AVGEMOE_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
        "AVGEMOE_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
        "AVGEMOE_ACC = metrics.accuracy_score(true_Y, preds)\n",
        "print('Base+Average Model:\\n{} (AUROC:{},ACC:{})'.format(AVGEMOE_AUPRC, AVGEMOE_AUROC,AVGEMOE_ACC))\n",
        "\n",
        "plt.xticks(np.arange(0, 1.01, step=0.1))\n",
        "plt.xticks(np.arange(0, 1.01, step=0.05), minor=True)\n",
        "plt.yticks(np.arange(0.6, 1.01, step=0.05))\n",
        "plt.grid(True, which='both')\n",
        "plt.xlabel('Recall ({} Positive)'.format(int(np.sum(true_Y))))\n",
        "plt.ylabel('Precision')\n",
        "plt.title('ID Precision vs Recall')\n",
        "plt.legend(['Base', 'NNet', 'AVGNNET', 'EMOE', 'AVGEMOE'])\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "XMO0PYR5GfcS"
      },
      "outputs": [],
      "source": [
        "results_dict['heldid_base_AUPRC'] = BASE_AUPRC\n",
        "results_dict['heldid_model_AUPRC'] = MOD_AUPRC\n",
        "results_dict['heldid_avg_model_AUPRC'] = AVGMOD_AUPRC\n",
        "results_dict['heldid_emoe_AUPRC'] = EMOE_AUPRC\n",
        "results_dict['heldid_avg_emoe_AUPRC'] = AVGEMOE_AUPRC\n",
        "\n",
        "results_dict['heldid_base_AUROC'] = BASE_AUROC\n",
        "results_dict['heldid_model_AUROC'] = MOD_AUROC\n",
        "results_dict['heldid_avg_model_AUROC'] = AVGMOD_AUROC\n",
        "results_dict['heldid_emoe_AUROC'] = EMOE_AUROC\n",
        "results_dict['heldid_avg_emoe_AUROC'] = AVGEMOE_AUROC"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 651
        },
        "id": "HUPjeXDAGfcS",
        "outputId": "c47df412-90c7-4436-d02f-d9526e7d130a"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Base:\n",
            "[0.98978626 0.97957253 0.97123953 0.96371758 0.91160392] (AUROC:0.7001263008870153,ACC:0.8158820346320347)\n",
            "Model:\n",
            "[0.99526782 0.98351106 0.9717482  0.96185949 0.91175095] (AUROC:0.7037347245016448,ACC:0.8129058441558441)\n",
            "Average Model:\n",
            "[0.9943343  0.98104533 0.96850787 0.95951256 0.91021444] (AUROC:0.7008675004302957,ACC:0.8112824675324676)\n",
            "Base+Model:\n",
            "[0.99475699 0.98678272 0.97869601 0.96982057 0.91588921] (AUROC:0.7109260570123659,ACC:0.8157467532467533)\n",
            "Base+Average Model:\n",
            "[0.99437379 0.98658581 0.97890026 0.96988944 0.91573644] (AUROC:0.7102346142004863,ACC:0.8156114718614719)\n"
          ]
        },
        {
          "data": {
            "image/png": "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",
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "# plot ood\n",
        "###########\n",
        "base_predictions = predictions_dict['heldood_base']\n",
        "model_predictions = predictions_dict['heldood_model_net']\n",
        "average_model_predictions = predictions_dict['heldood_avg_model_net']\n",
        "true_Y = predictions_dict['heldood_Y']\n",
        "\n",
        "plt.figure()\n",
        "\n",
        "# base model\n",
        "confs = np.mean(base_predictions, -1)\n",
        "preds = (confs >.5)\n",
        "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
        "plt.plot(recall, precision, c='brown')\n",
        "BASE_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
        "BASE_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
        "BASE_ACC = metrics.accuracy_score(true_Y, preds)\n",
        "\n",
        "print('Base:\\n{} (AUROC:{},ACC:{})'.format(BASE_AUPRC, BASE_AUROC,BASE_ACC))\n",
        "\n",
        "# student model\n",
        "confs = np.mean(model_predictions, -1)\n",
        "preds = (confs >.5)\n",
        "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
        "plt.plot(recall, precision, c='red')\n",
        "MOD_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
        "MOD_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
        "MOD_ACC = metrics.accuracy_score(true_Y, preds)\n",
        "print('Model:\\n{} (AUROC:{},ACC:{})'.format(MOD_AUPRC, MOD_AUROC,MOD_ACC))\n",
        "\n",
        "# average student model\n",
        "confs = np.mean(average_model_predictions, -1)\n",
        "preds = (confs >.5)\n",
        "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
        "plt.plot(recall, precision, c='pink')\n",
        "AVGMOD_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
        "AVGMOD_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
        "AVGMOD_ACC = metrics.accuracy_score(true_Y, preds)\n",
        "print('Average Model:\\n{} (AUROC:{},ACC:{})'.format(AVGMOD_AUPRC, AVGMOD_AUROC,AVGMOD_ACC))\n",
        "\n",
        "# base+student model\n",
        "confs = (np.mean(base_predictions, -1)+np.mean(model_predictions, -1))/2.\n",
        "preds = (confs >.5)\n",
        "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
        "plt.plot(recall, precision, c='blue')\n",
        "EMOE_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
        "EMOE_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
        "EMOE_ACC = metrics.accuracy_score(true_Y, preds)\n",
        "print('Base+Model:\\n{} (AUROC:{},ACC:{})'.format(EMOE_AUPRC, EMOE_AUROC,EMOE_ACC))\n",
        "\n",
        "# base+average student model\n",
        "confs = (np.mean(base_predictions, -1)+np.mean(average_model_predictions, -1))/2.\n",
        "preds = (confs >.5)\n",
        "precision, recall, thresholds = metrics.precision_recall_curve(true_Y, confs)\n",
        "plt.plot(recall, precision, c='cyan')\n",
        "AVGEMOE_AUPRC = auprc_threshs(confs, true_Y, AUCTHRESHS)\n",
        "AVGEMOE_AUROC = metrics.roc_auc_score(true_Y, confs)\n",
        "AVGEMOE_ACC = metrics.accuracy_score(true_Y, preds)\n",
        "print('Base+Average Model:\\n{} (AUROC:{},ACC:{})'.format(AVGEMOE_AUPRC, AVGEMOE_AUROC,AVGEMOE_ACC))\n",
        "\n",
        "plt.xticks(np.arange(0, 1.01, step=0.1))\n",
        "plt.xticks(np.arange(0, 1.01, step=0.05), minor=True)\n",
        "plt.yticks(np.arange(0.6, 1.01, step=0.05))\n",
        "plt.grid(True, which='both')\n",
        "plt.xlabel('Recall ({} Positive)'.format(int(np.sum(true_Y))))\n",
        "plt.ylabel('Precision')\n",
        "plt.title('ID Precision vs Recall')\n",
        "plt.legend(['Base', 'NNet', 'AVGNNET', 'EMOE', 'AVGEMOE'])\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "T2gDhB4RGfcS"
      },
      "outputs": [],
      "source": [
        "results_dict['heldood_base_AUPRC'] = BASE_AUPRC\n",
        "results_dict['heldood_model_AUPRC'] = MOD_AUPRC\n",
        "results_dict['heldood_avg_model_AUPRC'] = AVGMOD_AUPRC\n",
        "results_dict['heldood_emoe_AUPRC'] = EMOE_AUPRC\n",
        "results_dict['heldood_avg_emoe_AUPRC'] = AVGEMOE_AUPRC\n",
        "\n",
        "results_dict['heldood_base_AUROC'] = BASE_AUROC\n",
        "results_dict['heldood_model_AUROC'] = MOD_AUROC\n",
        "results_dict['heldood_avg_model_AUROC'] = AVGMOD_AUROC\n",
        "results_dict['heldood_emoe_AUROC'] = EMOE_AUROC\n",
        "results_dict['heldood_avg_emoe_AUROC'] = AVGEMOE_AUROC\n",
        "\n",
        "results_dict['heldood_base_ACC'] = BASE_ACC\n",
        "results_dict['heldood_model_ACC'] = MOD_ACC\n",
        "results_dict['heldood_avg_model_ACC'] = AVGMOD_ACC\n",
        "results_dict['heldood_emoe_ACC'] = EMOE_ACC\n",
        "results_dict['heldood_avg_emoe_ACC'] = AVGEMOE_ACC"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "caAfTf29GfcS"
      },
      "outputs": [],
      "source": [
        "with open(os.path.join(save_path, 'results.p'), 'wb') as f:\n",
        "    pickle.dump(results_dict, f)"
      ]
    }
  ],
  "metadata": {
    "accelerator": "GPU",
    "colab": {
      "gpuType": "L4",
      "machine_shape": "hm",
      "provenance": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}
