{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "2f7010d6",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T19:08:15.183885Z",
     "start_time": "2021-10-03T19:08:13.371010Z"
    }
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import matplotlib\n",
    "from sklearn.metrics import zero_one_loss\n",
    "import pandas as pd\n",
    "\n",
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "268f8dc8",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T19:08:19.857938Z",
     "start_time": "2021-10-03T19:08:15.185382Z"
    }
   },
   "outputs": [],
   "source": [
    "from sklearn.model_selection import train_test_split\n",
    "\n",
    "import numpy as np\n",
    "from tensorflow import keras\n",
    "from tensorflow.keras import layers\n",
    "import tensorflow as tf\n",
    "import tensorflow.compat.v2 as tf\n",
    "import tensorflow_datasets as tfds"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "24a93783",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T19:08:19.862160Z",
     "start_time": "2021-10-03T19:08:19.859855Z"
    }
   },
   "outputs": [],
   "source": [
    "import tensorflow.keras as K"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "876c629a",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T19:09:22.300296Z",
     "start_time": "2021-10-03T19:09:22.231282Z"
    }
   },
   "outputs": [],
   "source": [
    "from utils.tests import Drop_tester,misclas_losses\n",
    "from utils.data_gen import LDA_predictor,generate_2d_example\n",
    "from utils.set_valued_prediction import Set_valued_predictor_wrapper"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "b5cd1093",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T19:09:22.806703Z",
     "start_time": "2021-10-03T19:09:22.737180Z"
    }
   },
   "outputs": [],
   "source": [
    "sns.set(\n",
    "    style=\"whitegrid\",\n",
    "    font_scale=1.4,\n",
    "    rc={\n",
    "        \"lines.linewidth\": 2,\n",
    "        #             \"axes.facecolor\": \".9\",\n",
    "        'figure.figsize': (12, 6)\n",
    "    })\n",
    "sns.set_palette('Set2')\n",
    "matplotlib.rcParams['text.usetex'] = True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "dc51d4ad",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T19:09:22.988666Z",
     "start_time": "2021-10-03T19:09:22.917171Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "815f1868",
   "metadata": {},
   "source": [
    "# CIFAR10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "10efa33d",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-03T22:35:45.995183Z",
     "start_time": "2021-10-03T22:35:45.825632Z"
    }
   },
   "outputs": [],
   "source": [
    "from __future__ import print_function\n",
    "from tensorflow import keras\n",
    "from keras.layers import Dense, Conv2D, BatchNormalization, Activation\n",
    "from keras.layers import AveragePooling2D, Input, Flatten\n",
    "# from keras.optimizers import Adam\n",
    "from keras.callbacks import ModelCheckpoint, LearningRateScheduler\n",
    "from keras.callbacks import ReduceLROnPlateau\n",
    "from keras.preprocessing.image import ImageDataGenerator\n",
    "from keras.regularizers import l2\n",
    "from keras import backend as K\n",
    "from keras.models import Model\n",
    "from keras.datasets import cifar10\n",
    "import numpy as np\n",
    "import os"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "6fd0f2e2",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T01:41:01.161283Z",
     "start_time": "2021-10-04T01:40:58.825618Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "x_train shape: (50000, 32, 32, 3)\n",
      "50000 train samples\n",
      "10000 test samples\n",
      "y_train shape: (50000, 1)\n"
     ]
    }
   ],
   "source": [
    "# Training parameters\n",
    "batch_size = 128  # orig paper trained all networks with batch_size=128\n",
    "epochs = 20\n",
    "data_augmentation = True\n",
    "num_classes = 10\n",
    "\n",
    "# Subtracting pixel mean improves accuracy\n",
    "subtract_pixel_mean = True\n",
    "\n",
    "n = 5\n",
    "\n",
    "# Model version\n",
    "# Orig paper: version = 1 (ResNet v1), Improved ResNet: version = 2 (ResNet v2)\n",
    "version = 1\n",
    "\n",
    "# Computed depth from supplied model parameter n\n",
    "if version == 1:\n",
    "    depth = n * 6 + 2\n",
    "elif version == 2:\n",
    "    depth = n * 9 + 2\n",
    "\n",
    "model_type = 'ResNet%dv%d' % (depth, version)\n",
    "\n",
    "# Load the CIFAR10 data.\n",
    "(x_train, y_train), (x_test, y_test) = cifar10.load_data()\n",
    "\n",
    "# Input image dimensions.\n",
    "input_shape = x_train.shape[1:]\n",
    "\n",
    "# Normalize data.\n",
    "x_train = x_train.astype('float32') / 255\n",
    "x_test = x_test.astype('float32') / 255\n",
    "\n",
    "# If subtract pixel mean is enabled\n",
    "if subtract_pixel_mean:\n",
    "    x_train_mean = np.mean(x_train, axis=0)\n",
    "    x_train -= x_train_mean\n",
    "    x_test -= x_train_mean\n",
    "\n",
    "print('x_train shape:', x_train.shape)\n",
    "print(x_train.shape[0], 'train samples')\n",
    "print(x_test.shape[0], 'test samples')\n",
    "print('y_train shape:', y_train.shape)\n",
    "\n",
    "# Convert class vectors to binary class matrices.\n",
    "y_train = keras.utils.to_categorical(y_train, num_classes)\n",
    "y_test = keras.utils.to_categorical(y_test, num_classes)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "b5e08412",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T01:41:01.243103Z",
     "start_time": "2021-10-04T01:41:01.164432Z"
    }
   },
   "outputs": [],
   "source": [
    "\n",
    "def lr_schedule(epoch):\n",
    "    \"\"\"Learning Rate Schedule\n",
    "\n",
    "    Learning rate is scheduled to be reduced after 80, 120, 160, 180 epochs.\n",
    "    Called automatically every epoch as part of callbacks during training.\n",
    "\n",
    "    # Arguments\n",
    "        epoch (int): The number of epochs\n",
    "\n",
    "    # Returns\n",
    "        lr (float32): learning rate\n",
    "    \"\"\"\n",
    "    lr = 1e-3\n",
    "    if epoch > 45:\n",
    "        lr *= 0.5e-3\n",
    "    elif epoch > 35:\n",
    "        lr *= 1e-3\n",
    "    elif epoch > 25:\n",
    "        lr *= 1e-2\n",
    "    elif epoch > 10:\n",
    "        lr *= 1e-1\n",
    "    print('Learning rate: ', lr)\n",
    "    return lr\n",
    "\n",
    "\n",
    "def resnet_layer(inputs,\n",
    "                 num_filters=16,\n",
    "                 kernel_size=3,\n",
    "                 strides=1,\n",
    "                 activation='relu',\n",
    "                 batch_normalization=True,\n",
    "                 conv_first=True):\n",
    "    \"\"\"2D Convolution-Batch Normalization-Activation stack builder\n",
    "\n",
    "    # Arguments\n",
    "        inputs (tensor): input tensor from input image or previous layer\n",
    "        num_filters (int): Conv2D number of filters\n",
    "        kernel_size (int): Conv2D square kernel dimensions\n",
    "        strides (int): Conv2D square stride dimensions\n",
    "        activation (string): activation name\n",
    "        batch_normalization (bool): whether to include batch normalization\n",
    "        conv_first (bool): conv-bn-activation (True) or\n",
    "            bn-activation-conv (False)\n",
    "\n",
    "    # Returns\n",
    "        x (tensor): tensor as input to the next layer\n",
    "    \"\"\"\n",
    "    conv = Conv2D(num_filters,\n",
    "                  kernel_size=kernel_size,\n",
    "                  strides=strides,\n",
    "                  padding='same',\n",
    "                  kernel_initializer='he_normal',\n",
    "                  kernel_regularizer=l2(1e-4))\n",
    "\n",
    "    x = inputs\n",
    "    if conv_first:\n",
    "        x = conv(x)\n",
    "        if batch_normalization:\n",
    "            x = BatchNormalization()(x)\n",
    "        if activation is not None:\n",
    "            x = Activation(activation)(x)\n",
    "    else:\n",
    "        if batch_normalization:\n",
    "            x = BatchNormalization()(x)\n",
    "        if activation is not None:\n",
    "            x = Activation(activation)(x)\n",
    "        x = conv(x)\n",
    "    return x\n",
    "\n",
    "\n",
    "def resnet_v1(input_shape, depth, num_classes=10):\n",
    "    \"\"\"ResNet Version 1 Model builder [a]\n",
    "\n",
    "    Stacks of 2 x (3 x 3) Conv2D-BN-ReLU\n",
    "    Last ReLU is after the shortcut connection.\n",
    "    At the beginning of each stage, the feature map size is halved (downsampled)\n",
    "    by a convolutional layer with strides=2, while the number of filters is\n",
    "    doubled. Within each stage, the layers have the same number filters and the\n",
    "    same number of filters.\n",
    "    Features maps sizes:\n",
    "    stage 0: 32x32, 16\n",
    "    stage 1: 16x16, 32\n",
    "    stage 2:  8x8,  64\n",
    "    The Number of parameters is approx the same as Table 6 of [a]:\n",
    "    ResNet20 0.27M\n",
    "    ResNet32 0.46M\n",
    "    ResNet44 0.66M\n",
    "    ResNet56 0.85M\n",
    "    ResNet110 1.7M\n",
    "\n",
    "    # Arguments\n",
    "        input_shape (tensor): shape of input image tensor\n",
    "        depth (int): number of core convolutional layers\n",
    "        num_classes (int): number of classes (CIFAR10 has 10)\n",
    "\n",
    "    # Returns\n",
    "        model (Model): Keras model instance\n",
    "    \"\"\"\n",
    "    if (depth - 2) % 6 != 0:\n",
    "        raise ValueError('depth should be 6n+2 (eg 20, 32, 44 in [a])')\n",
    "    # Start model definition.\n",
    "    num_filters = 16\n",
    "    num_res_blocks = int((depth - 2) / 6)\n",
    "\n",
    "    inputs = Input(shape=input_shape)\n",
    "    x = resnet_layer(inputs=inputs)\n",
    "    # Instantiate the stack of residual units\n",
    "    for stack in range(3):\n",
    "        for res_block in range(num_res_blocks):\n",
    "            strides = 1\n",
    "            if stack > 0 and res_block == 0:  # first layer but not first stack\n",
    "                strides = 2  # downsample\n",
    "            y = resnet_layer(inputs=x,\n",
    "                             num_filters=num_filters,\n",
    "                             strides=strides)\n",
    "            y = resnet_layer(inputs=y,\n",
    "                             num_filters=num_filters,\n",
    "                             activation=None)\n",
    "            if stack > 0 and res_block == 0:  # first layer but not first stack\n",
    "                # linear projection residual shortcut connection to match\n",
    "                # changed dims\n",
    "                x = resnet_layer(inputs=x,\n",
    "                                 num_filters=num_filters,\n",
    "                                 kernel_size=1,\n",
    "                                 strides=strides,\n",
    "                                 activation=None,\n",
    "                                 batch_normalization=False)\n",
    "            x = keras.layers.add([x, y])\n",
    "            x = Activation('relu')(x)\n",
    "        num_filters *= 2\n",
    "\n",
    "    # Add classifier on top.\n",
    "    # v1 does not use BN after last shortcut connection-ReLU\n",
    "    x = AveragePooling2D(pool_size=8)(x)\n",
    "    y = Flatten()(x)\n",
    "    outputs = Dense(num_classes,\n",
    "                    activation='softmax',\n",
    "                    kernel_initializer='he_normal')(y)\n",
    "\n",
    "    # Instantiate model.\n",
    "    model = Model(inputs=inputs, outputs=outputs)\n",
    "    return model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "id": "bf07d8ba",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T01:41:01.901047Z",
     "start_time": "2021-10-04T01:41:01.246275Z"
    }
   },
   "outputs": [],
   "source": [
    "model = resnet_v1(input_shape=input_shape, depth=depth)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "id": "2fc58f76",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T01:41:02.191386Z",
     "start_time": "2021-10-04T01:41:02.087133Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"model_4\"\n",
      "__________________________________________________________________________________________________\n",
      "Layer (type)                    Output Shape         Param #     Connected to                     \n",
      "==================================================================================================\n",
      "input_6 (InputLayer)            [(None, 32, 32, 3)]  0                                            \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_63 (Conv2D)              (None, 32, 32, 16)   448         input_6[0][0]                    \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_57 (BatchNo (None, 32, 32, 16)   64          conv2d_63[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "activation_57 (Activation)      (None, 32, 32, 16)   0           batch_normalization_57[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_64 (Conv2D)              (None, 32, 32, 16)   2320        activation_57[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_58 (BatchNo (None, 32, 32, 16)   64          conv2d_64[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "activation_58 (Activation)      (None, 32, 32, 16)   0           batch_normalization_58[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_65 (Conv2D)              (None, 32, 32, 16)   2320        activation_58[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_59 (BatchNo (None, 32, 32, 16)   64          conv2d_65[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "add_27 (Add)                    (None, 32, 32, 16)   0           activation_57[0][0]              \n",
      "                                                                 batch_normalization_59[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "activation_59 (Activation)      (None, 32, 32, 16)   0           add_27[0][0]                     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_66 (Conv2D)              (None, 32, 32, 16)   2320        activation_59[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_60 (BatchNo (None, 32, 32, 16)   64          conv2d_66[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "activation_60 (Activation)      (None, 32, 32, 16)   0           batch_normalization_60[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_67 (Conv2D)              (None, 32, 32, 16)   2320        activation_60[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_61 (BatchNo (None, 32, 32, 16)   64          conv2d_67[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "add_28 (Add)                    (None, 32, 32, 16)   0           activation_59[0][0]              \n",
      "                                                                 batch_normalization_61[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "activation_61 (Activation)      (None, 32, 32, 16)   0           add_28[0][0]                     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_68 (Conv2D)              (None, 32, 32, 16)   2320        activation_61[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_62 (BatchNo (None, 32, 32, 16)   64          conv2d_68[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "activation_62 (Activation)      (None, 32, 32, 16)   0           batch_normalization_62[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_69 (Conv2D)              (None, 32, 32, 16)   2320        activation_62[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_63 (BatchNo (None, 32, 32, 16)   64          conv2d_69[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "add_29 (Add)                    (None, 32, 32, 16)   0           activation_61[0][0]              \n",
      "                                                                 batch_normalization_63[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "activation_63 (Activation)      (None, 32, 32, 16)   0           add_29[0][0]                     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_70 (Conv2D)              (None, 32, 32, 16)   2320        activation_63[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_64 (BatchNo (None, 32, 32, 16)   64          conv2d_70[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "activation_64 (Activation)      (None, 32, 32, 16)   0           batch_normalization_64[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_71 (Conv2D)              (None, 32, 32, 16)   2320        activation_64[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_65 (BatchNo (None, 32, 32, 16)   64          conv2d_71[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "add_30 (Add)                    (None, 32, 32, 16)   0           activation_63[0][0]              \n",
      "                                                                 batch_normalization_65[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "activation_65 (Activation)      (None, 32, 32, 16)   0           add_30[0][0]                     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_72 (Conv2D)              (None, 32, 32, 16)   2320        activation_65[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_66 (BatchNo (None, 32, 32, 16)   64          conv2d_72[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "activation_66 (Activation)      (None, 32, 32, 16)   0           batch_normalization_66[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_73 (Conv2D)              (None, 32, 32, 16)   2320        activation_66[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_67 (BatchNo (None, 32, 32, 16)   64          conv2d_73[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "add_31 (Add)                    (None, 32, 32, 16)   0           activation_65[0][0]              \n",
      "                                                                 batch_normalization_67[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "activation_67 (Activation)      (None, 32, 32, 16)   0           add_31[0][0]                     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_74 (Conv2D)              (None, 16, 16, 32)   4640        activation_67[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_68 (BatchNo (None, 16, 16, 32)   128         conv2d_74[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "activation_68 (Activation)      (None, 16, 16, 32)   0           batch_normalization_68[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_75 (Conv2D)              (None, 16, 16, 32)   9248        activation_68[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_76 (Conv2D)              (None, 16, 16, 32)   544         activation_67[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_69 (BatchNo (None, 16, 16, 32)   128         conv2d_75[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "add_32 (Add)                    (None, 16, 16, 32)   0           conv2d_76[0][0]                  \n",
      "                                                                 batch_normalization_69[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "activation_69 (Activation)      (None, 16, 16, 32)   0           add_32[0][0]                     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_77 (Conv2D)              (None, 16, 16, 32)   9248        activation_69[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_70 (BatchNo (None, 16, 16, 32)   128         conv2d_77[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "activation_70 (Activation)      (None, 16, 16, 32)   0           batch_normalization_70[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_78 (Conv2D)              (None, 16, 16, 32)   9248        activation_70[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_71 (BatchNo (None, 16, 16, 32)   128         conv2d_78[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "add_33 (Add)                    (None, 16, 16, 32)   0           activation_69[0][0]              \n",
      "                                                                 batch_normalization_71[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "activation_71 (Activation)      (None, 16, 16, 32)   0           add_33[0][0]                     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_79 (Conv2D)              (None, 16, 16, 32)   9248        activation_71[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_72 (BatchNo (None, 16, 16, 32)   128         conv2d_79[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "activation_72 (Activation)      (None, 16, 16, 32)   0           batch_normalization_72[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_80 (Conv2D)              (None, 16, 16, 32)   9248        activation_72[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_73 (BatchNo (None, 16, 16, 32)   128         conv2d_80[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "add_34 (Add)                    (None, 16, 16, 32)   0           activation_71[0][0]              \n",
      "                                                                 batch_normalization_73[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "activation_73 (Activation)      (None, 16, 16, 32)   0           add_34[0][0]                     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_81 (Conv2D)              (None, 16, 16, 32)   9248        activation_73[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_74 (BatchNo (None, 16, 16, 32)   128         conv2d_81[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "activation_74 (Activation)      (None, 16, 16, 32)   0           batch_normalization_74[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_82 (Conv2D)              (None, 16, 16, 32)   9248        activation_74[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_75 (BatchNo (None, 16, 16, 32)   128         conv2d_82[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "add_35 (Add)                    (None, 16, 16, 32)   0           activation_73[0][0]              \n",
      "                                                                 batch_normalization_75[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "activation_75 (Activation)      (None, 16, 16, 32)   0           add_35[0][0]                     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_83 (Conv2D)              (None, 16, 16, 32)   9248        activation_75[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_76 (BatchNo (None, 16, 16, 32)   128         conv2d_83[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "activation_76 (Activation)      (None, 16, 16, 32)   0           batch_normalization_76[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_84 (Conv2D)              (None, 16, 16, 32)   9248        activation_76[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_77 (BatchNo (None, 16, 16, 32)   128         conv2d_84[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "add_36 (Add)                    (None, 16, 16, 32)   0           activation_75[0][0]              \n",
      "                                                                 batch_normalization_77[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "activation_77 (Activation)      (None, 16, 16, 32)   0           add_36[0][0]                     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_85 (Conv2D)              (None, 8, 8, 64)     18496       activation_77[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_78 (BatchNo (None, 8, 8, 64)     256         conv2d_85[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "activation_78 (Activation)      (None, 8, 8, 64)     0           batch_normalization_78[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_86 (Conv2D)              (None, 8, 8, 64)     36928       activation_78[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_87 (Conv2D)              (None, 8, 8, 64)     2112        activation_77[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_79 (BatchNo (None, 8, 8, 64)     256         conv2d_86[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "add_37 (Add)                    (None, 8, 8, 64)     0           conv2d_87[0][0]                  \n",
      "                                                                 batch_normalization_79[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "activation_79 (Activation)      (None, 8, 8, 64)     0           add_37[0][0]                     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_88 (Conv2D)              (None, 8, 8, 64)     36928       activation_79[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_80 (BatchNo (None, 8, 8, 64)     256         conv2d_88[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "activation_80 (Activation)      (None, 8, 8, 64)     0           batch_normalization_80[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_89 (Conv2D)              (None, 8, 8, 64)     36928       activation_80[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_81 (BatchNo (None, 8, 8, 64)     256         conv2d_89[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "add_38 (Add)                    (None, 8, 8, 64)     0           activation_79[0][0]              \n",
      "                                                                 batch_normalization_81[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "activation_81 (Activation)      (None, 8, 8, 64)     0           add_38[0][0]                     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_90 (Conv2D)              (None, 8, 8, 64)     36928       activation_81[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_82 (BatchNo (None, 8, 8, 64)     256         conv2d_90[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "activation_82 (Activation)      (None, 8, 8, 64)     0           batch_normalization_82[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_91 (Conv2D)              (None, 8, 8, 64)     36928       activation_82[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_83 (BatchNo (None, 8, 8, 64)     256         conv2d_91[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "add_39 (Add)                    (None, 8, 8, 64)     0           activation_81[0][0]              \n",
      "                                                                 batch_normalization_83[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "activation_83 (Activation)      (None, 8, 8, 64)     0           add_39[0][0]                     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_92 (Conv2D)              (None, 8, 8, 64)     36928       activation_83[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_84 (BatchNo (None, 8, 8, 64)     256         conv2d_92[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "activation_84 (Activation)      (None, 8, 8, 64)     0           batch_normalization_84[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_93 (Conv2D)              (None, 8, 8, 64)     36928       activation_84[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_85 (BatchNo (None, 8, 8, 64)     256         conv2d_93[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "add_40 (Add)                    (None, 8, 8, 64)     0           activation_83[0][0]              \n",
      "                                                                 batch_normalization_85[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "activation_85 (Activation)      (None, 8, 8, 64)     0           add_40[0][0]                     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_94 (Conv2D)              (None, 8, 8, 64)     36928       activation_85[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_86 (BatchNo (None, 8, 8, 64)     256         conv2d_94[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "activation_86 (Activation)      (None, 8, 8, 64)     0           batch_normalization_86[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "conv2d_95 (Conv2D)              (None, 8, 8, 64)     36928       activation_86[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "batch_normalization_87 (BatchNo (None, 8, 8, 64)     256         conv2d_95[0][0]                  \n",
      "__________________________________________________________________________________________________\n",
      "add_41 (Add)                    (None, 8, 8, 64)     0           activation_85[0][0]              \n",
      "                                                                 batch_normalization_87[0][0]     \n",
      "__________________________________________________________________________________________________\n",
      "activation_87 (Activation)      (None, 8, 8, 64)     0           add_41[0][0]                     \n",
      "__________________________________________________________________________________________________\n",
      "average_pooling2d_3 (AveragePoo (None, 1, 1, 64)     0           activation_87[0][0]              \n",
      "__________________________________________________________________________________________________\n",
      "flatten_4 (Flatten)             (None, 64)           0           average_pooling2d_3[0][0]        \n",
      "__________________________________________________________________________________________________\n",
      "dense_5 (Dense)                 (None, 10)           650         flatten_4[0][0]                  \n",
      "==================================================================================================\n",
      "Total params: 470,218\n",
      "Trainable params: 467,946\n",
      "Non-trainable params: 2,272\n",
      "__________________________________________________________________________________________________\n",
      "ResNet32v1\n"
     ]
    }
   ],
   "source": [
    "model.compile(loss='categorical_crossentropy',\n",
    "              optimizer='Adam',\n",
    "              metrics=['accuracy'])\n",
    "model.summary()\n",
    "print(model_type)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "id": "6165645f",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T01:41:15.951821Z",
     "start_time": "2021-10-04T01:41:15.740840Z"
    }
   },
   "outputs": [],
   "source": [
    "model.load_weights('cifar10_ResNet32v1_model.012.h5')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "id": "fe340776",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T01:41:32.411878Z",
     "start_time": "2021-10-04T01:41:17.245326Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "313/313 [==============================] - 15s 44ms/step - loss: 0.9199 - accuracy: 0.7954\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[0.919887900352478, 0.7954000234603882]"
      ]
     },
     "execution_count": 71,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.evaluate(x_test,y_test)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 253,
   "id": "a5ea9d5e",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-05T03:57:43.018052Z",
     "start_time": "2021-10-05T03:57:42.939911Z"
    }
   },
   "outputs": [],
   "source": [
    "wrap = Set_valued_predictor_wrapper()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 254,
   "id": "2df87200",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-05T03:57:43.232278Z",
     "start_time": "2021-10-05T03:57:43.161452Z"
    }
   },
   "outputs": [],
   "source": [
    "wrap.base_predictor = model\n",
    "wrap.delta = 0.05\n",
    "wrap.alpha=0.05"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "id": "b55926e4",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T01:43:30.459839Z",
     "start_time": "2021-10-04T01:43:30.384628Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(10000, 32, 32, 3)"
      ]
     },
     "execution_count": 77,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_test.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "id": "e85cf7f7",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T01:43:51.522489Z",
     "start_time": "2021-10-04T01:43:51.444279Z"
    }
   },
   "outputs": [],
   "source": [
    "indices = np.arange(10000)\n",
    "np.random.shuffle(indices)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 100,
   "id": "b1cb09eb",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T01:50:54.316664Z",
     "start_time": "2021-10-04T01:50:54.248493Z"
    }
   },
   "outputs": [],
   "source": [
    "cal_indices = indices[:1000]\n",
    "risk_source_indices = indices[1000:2000]\n",
    "risk_target_indices = indices[2000:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "id": "59499709",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T01:48:23.346092Z",
     "start_time": "2021-10-04T01:48:23.276875Z"
    }
   },
   "outputs": [],
   "source": [
    "X_cal = x_test[cal_indices]\n",
    "y_cal = y_test[cal_indices]\n",
    "X_risk_source = x_test[risk_source_indices]\n",
    "y_risk_source = y_test[risk_source_indices]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "id": "47f017e4",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T01:48:42.470702Z",
     "start_time": "2021-10-04T01:48:24.024714Z"
    }
   },
   "outputs": [],
   "source": [
    "wrap.fit(X_cal, y_cal.argmax(axis=1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "id": "fa01e976",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T01:48:42.549096Z",
     "start_time": "2021-10-04T01:48:42.476129Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.91796875"
      ]
     },
     "execution_count": 96,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "wrap.lmbd_star"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "id": "1c6ded30",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T01:48:46.996057Z",
     "start_time": "2021-10-04T01:48:45.472880Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.09, 1.557)"
      ]
     },
     "execution_count": 97,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "wrap.eval_pred(X_risk_source, y_risk_source.argmax(axis=1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "id": "dac0bbb0",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T01:46:54.373777Z",
     "start_time": "2021-10-04T01:46:52.792778Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "32/32 [==============================] - 1s 45ms/step - loss: 0.9011 - accuracy: 0.7980\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[0.9011020660400391, 0.7979999780654907]"
      ]
     },
     "execution_count": 89,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.evaluate(X_cal,y_cal)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 321,
   "id": "95133de2",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-05T14:45:02.791981Z",
     "start_time": "2021-10-05T14:45:02.616668Z"
    }
   },
   "outputs": [],
   "source": [
    "eps_tol=0.05\n",
    "\n",
    "tester = Drop_tester()\n",
    "\n",
    "tester.eps_tol = eps_tol\n",
    "tester.source_conc_type = 'betting'\n",
    "tester.target_conc_type = 'conj-bern'\n",
    "tester.change_type = 'absolute'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 322,
   "id": "8994c6ee",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-05T14:45:03.125273Z",
     "start_time": "2021-10-05T14:45:03.050515Z"
    }
   },
   "outputs": [],
   "source": [
    "batch_size=50\n",
    "num_of_batches = 40\n",
    "num_of_repeats = 50"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 323,
   "id": "87a196e8",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-05T14:45:03.860846Z",
     "start_time": "2021-10-05T14:45:03.804685Z"
    }
   },
   "outputs": [],
   "source": [
    "wrap.alpha=0.1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 324,
   "id": "79975314",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-05T14:45:04.400493Z",
     "start_time": "2021-10-05T14:45:04.317135Z"
    }
   },
   "outputs": [],
   "source": [
    "clean_lower_bounds = list()\n",
    "source_upper_bounds = list()\n",
    "fog1_lower_bounds = list()\n",
    "fog3_lower_bounds = list()\n",
    "fog5_lower_bounds = list()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 325,
   "id": "b5538b40",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-05T15:25:02.466681Z",
     "start_time": "2021-10-05T14:45:06.773180Z"
    }
   },
   "outputs": [],
   "source": [
    "for cur_run in range(num_of_repeats):\n",
    "    \n",
    "    indices = np.arange(10000)\n",
    "    np.random.shuffle(indices)\n",
    "    cal_indices = indices[:1000]\n",
    "    risk_source_indices = indices[1000:2000]\n",
    "    risk_target_indices = indices[2000:]\n",
    "    \n",
    "    X_cal = x_clean[cal_indices]\n",
    "    y_cal = y_clean[cal_indices].argmax(axis=1)\n",
    "    X_risk_source = x_clean[risk_source_indices]\n",
    "    y_risk_source = y_clean[risk_source_indices].argmax(axis=1)\n",
    "    \n",
    "    wrap.fit(X_cal, y_cal)\n",
    "    \n",
    "    #estimate miscoverage risk on the source\n",
    "    pred_sets = wrap.predict_sets(X_risk_source)\n",
    "    num_of_preds = len(pred_sets)\n",
    "        \n",
    "    all_losses = np.array([y_risk_source[i] not in pred_sets[i] for i in range(num_of_preds)])\n",
    "    \n",
    "    tester.estimate_risk_source(all_losses)\n",
    "    \n",
    "    source_upper_bounds+= [tester.source_rejection_threshold]\n",
    "    \n",
    "    # now consider the target\n",
    "    clean_lower_bounds+=[[]]\n",
    "    fog1_lower_bounds+=[[]]\n",
    "    fog3_lower_bounds+=[[]]\n",
    "    fog5_lower_bounds+=[[]]\n",
    "    \n",
    "    np.random.shuffle(risk_target_indices)\n",
    "    \n",
    "    cur_X = x_clean[risk_target_indices][: num_of_batches * batch_size]\n",
    "    cur_y = y_clean[risk_target_indices][: num_of_batches * batch_size].argmax(axis=1)\n",
    "    pred_sets = wrap.predict_sets(cur_X)\n",
    "    num_of_preds = len(pred_sets)\n",
    "        \n",
    "    all_losses = np.array([cur_y[i] not in pred_sets[i] for i in range(num_of_preds)])\n",
    "    \n",
    "    for cur_batch in range(num_of_batches):        \n",
    "        cur_losses = all_losses[:(cur_batch + 1) * batch_size]\n",
    "        \n",
    "        \n",
    "        tester.estimate_risk_target(cur_losses)\n",
    "        clean_lower_bounds[cur_run] += [tester.target_risk_lower_bound]\n",
    "        \n",
    "    np.random.shuffle(risk_target_indices)\n",
    "    \n",
    "    cur_X = x_fog1[risk_target_indices][: num_of_batches * batch_size]\n",
    "    cur_y = y_fog1[risk_target_indices][: num_of_batches * batch_size].argmax(axis=1)\n",
    "    pred_sets = wrap.predict_sets(cur_X)\n",
    "    num_of_preds = len(pred_sets)\n",
    "        \n",
    "    all_losses = np.array([cur_y[i] not in pred_sets[i] for i in range(num_of_preds)])\n",
    "    \n",
    "    for cur_batch in range(num_of_batches):        \n",
    "        cur_losses = all_losses[:(cur_batch + 1) * batch_size]\n",
    "        \n",
    "        \n",
    "        tester.estimate_risk_target(cur_losses)\n",
    "        fog1_lower_bounds[cur_run] += [tester.target_risk_lower_bound]\n",
    "    \n",
    "    np.random.shuffle(risk_target_indices)\n",
    "    \n",
    "    cur_X = x_fog3[risk_target_indices][: num_of_batches * batch_size]\n",
    "    cur_y = y_fog3[risk_target_indices][: num_of_batches * batch_size].argmax(axis=1)\n",
    "    pred_sets = wrap.predict_sets(cur_X)\n",
    "    num_of_preds = len(pred_sets)\n",
    "        \n",
    "    all_losses = np.array([cur_y[i] not in pred_sets[i] for i in range(num_of_preds)])\n",
    "    \n",
    "    for cur_batch in range(num_of_batches):        \n",
    "        cur_losses = all_losses[:(cur_batch + 1) * batch_size]\n",
    "        \n",
    "        \n",
    "        tester.estimate_risk_target(cur_losses)\n",
    "        fog3_lower_bounds[cur_run] += [tester.target_risk_lower_bound]\n",
    "    \n",
    "    np.random.shuffle(risk_target_indices)\n",
    "    \n",
    "    cur_X = x_fog5[risk_target_indices][: num_of_batches * batch_size]\n",
    "    cur_y = y_fog5[risk_target_indices][: num_of_batches * batch_size].argmax(axis=1)\n",
    "    pred_sets = wrap.predict_sets(cur_X)\n",
    "    num_of_preds = len(pred_sets)\n",
    "        \n",
    "    all_losses = np.array([cur_y[i] not in pred_sets[i] for i in range(num_of_preds)])\n",
    "    \n",
    "    for cur_batch in range(num_of_batches):        \n",
    "        cur_losses = all_losses[:(cur_batch + 1) * batch_size]\n",
    "        \n",
    "        \n",
    "        tester.estimate_risk_target(cur_losses)\n",
    "        fog5_lower_bounds[cur_run] += [tester.target_risk_lower_bound]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 326,
   "id": "e3715b24",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-05T15:25:02.705184Z",
     "start_time": "2021-10-05T15:25:02.470040Z"
    }
   },
   "outputs": [],
   "source": [
    "clean_mean = np.mean(clean_lower_bounds, axis=0)\n",
    "fog1_mean = np.mean(fog1_lower_bounds, axis=0)\n",
    "fog3_mean = np.mean(fog3_lower_bounds, axis=0)\n",
    "fog5_mean = np.mean(fog5_lower_bounds, axis=0)\n",
    "\n",
    "clean_std = np.std(clean_lower_bounds, axis=0)\n",
    "fog1_std = np.std(fog1_lower_bounds, axis=0)\n",
    "fog3_std = np.std(fog3_lower_bounds, axis=0)\n",
    "fog5_std = np.std(fog5_lower_bounds, axis=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 327,
   "id": "0def109e",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-05T15:25:03.606231Z",
     "start_time": "2021-10-05T15:25:02.708784Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "l1, = plt.plot((np.arange(num_of_batches) + 1) * batch_size,\n",
    "               clean_mean,\n",
    "               color='dimgray',\n",
    "               marker='*',\n",
    "               label='Clean')\n",
    "\n",
    "plt.fill_between((np.arange(num_of_batches) + 1) * batch_size,\n",
    "                 y1=clean_mean - 2 * clean_std / np.sqrt(num_of_repeats),\n",
    "                 y2=clean_mean + 2 * clean_std / np.sqrt(num_of_repeats),\n",
    "                 color='dimgray',\n",
    "                 alpha=0.5)\n",
    "\n",
    "l2, = plt.plot((np.arange(num_of_batches) + 1) * batch_size,\n",
    "               fog1_mean,\n",
    "               color='mediumaquamarine',\n",
    "               marker='*',\n",
    "               label='Clean')\n",
    "\n",
    "plt.fill_between((np.arange(num_of_batches) + 1) * batch_size,\n",
    "                 y1=fog1_mean - 2 * fog1_std / np.sqrt(num_of_repeats),\n",
    "                 y2=fog1_mean + 2 * fog1_std / np.sqrt(num_of_repeats),\n",
    "                 color='mediumaquamarine',\n",
    "                 alpha=0.5)\n",
    "\n",
    "l3, = plt.plot((np.arange(num_of_batches) + 1) * batch_size,\n",
    "               fog3_mean,\n",
    "               color='steelblue',\n",
    "               marker='*',\n",
    "               label='Clean')\n",
    "\n",
    "plt.fill_between((np.arange(num_of_batches) + 1) * batch_size,\n",
    "                 y1=fog3_mean - 2 * fog3_std / np.sqrt(num_of_repeats),\n",
    "                 y2=fog3_mean + 2 * fog3_std / np.sqrt(num_of_repeats),\n",
    "                 color='steelblue',\n",
    "                 alpha=0.5)\n",
    "\n",
    "l4, = plt.plot((np.arange(num_of_batches) + 1) * batch_size,\n",
    "               fog5_mean,\n",
    "               color='indianred',\n",
    "               marker='*',\n",
    "               label='Clean')\n",
    "\n",
    "plt.fill_between((np.arange(num_of_batches) + 1) * batch_size,\n",
    "                 y1=fog5_mean - 2 * fog5_std / np.sqrt(num_of_repeats),\n",
    "                 y2=fog5_mean + 2 * fog5_std / np.sqrt(num_of_repeats),\n",
    "                 color='indianred',\n",
    "                 alpha=0.5)\n",
    "\n",
    "l5, = plt.plot((np.arange(num_of_batches) + 1) * batch_size,\n",
    "               np.repeat(np.mean(source_upper_bounds), num_of_batches),\n",
    "               linestyle='dashed',\n",
    "               c='goldenrod')\n",
    "\n",
    "plt.fill_between((np.arange(num_of_batches) + 1) * batch_size,\n",
    "                 y1=np.mean(source_upper_bounds) -\n",
    "                 2 * np.std(source_upper_bounds) / np.sqrt(num_of_repeats),\n",
    "                 y2=np.mean(source_upper_bounds) +\n",
    "                 2 * np.std(source_upper_bounds) / np.sqrt(num_of_repeats),\n",
    "                 color='goldenrod',\n",
    "                 alpha=0.5)\n",
    "\n",
    "plt.ylabel('Miscoverage risk', fontsize=23)\n",
    "plt.xlabel('Number of samples from the target domain', fontsize=23)\n",
    "\n",
    "p5, = plt.plot([0.15], marker='None', linestyle='None', label='dummy-tophead')\n",
    "\n",
    "categories = [\n",
    "    'Rejection threshold: ' +\n",
    "    r'$\\widehat{U}_S(f) + \\varepsilon_{\\mathrm{tol}}$',\n",
    "    r'$\\textbf{LCB on the target risk for:}$ ', 'Clean',\n",
    "    'Fog, level of severity: 1', 'Fog, level of severity: 3', 'Fog, level of severity: 5'\n",
    "]\n",
    "\n",
    "leg4 = plt.legend([l5, p5, l1, l2, l3, l4],\n",
    "                  categories,\n",
    "                  loc=1,\n",
    "                  ncol=1,\n",
    "                  prop={'size': 18})  # Two columns, horizontal group labels\n",
    "\n",
    "plt.savefig('img/cifar10_c_trained_once.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1dbde85e",
   "metadata": {},
   "source": [
    "# average size of prediction sets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 300,
   "id": "694cf16a",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-05T05:28:55.946407Z",
     "start_time": "2021-10-05T05:28:55.876816Z"
    }
   },
   "outputs": [],
   "source": [
    "average_size_01_clean = list()\n",
    "average_size_005_clean = list()\n",
    "\n",
    "average_size_01_fog1 = list()\n",
    "average_size_005_fog1 = list()\n",
    "\n",
    "average_size_01_fog3 = list()\n",
    "average_size_005_fog3 = list()\n",
    "\n",
    "average_size_01_fog5 = list()\n",
    "average_size_005_fog5 = list()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 301,
   "id": "ddf50d79",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-05T06:17:18.222841Z",
     "start_time": "2021-10-05T05:28:56.600459Z"
    }
   },
   "outputs": [],
   "source": [
    "for cur_run in range(50):\n",
    "\n",
    "    indices = np.arange(10000)\n",
    "    np.random.shuffle(indices)\n",
    "    cal_indices = indices[:1000]\n",
    "    risk_source_indices = indices[1000:2000]\n",
    "    risk_target_indices = indices[2000:3000]\n",
    "\n",
    "    X_cal = x_clean[cal_indices]\n",
    "    y_cal = y_clean[cal_indices].argmax(axis=1)\n",
    "    X_risk_source = x_clean[risk_source_indices]\n",
    "    y_risk_source = y_clean[risk_source_indices].argmax(axis=1)\n",
    "\n",
    "    wrap.alpha = 0.05\n",
    "    wrap.fit(X_cal, y_cal)\n",
    "\n",
    "    #estimate miscoverage risk on the source\n",
    "\n",
    "    # now consider the target\n",
    "\n",
    "    cur_X = x_clean[risk_target_indices]\n",
    "    cur_y = y_clean[risk_target_indices].argmax(axis=1)\n",
    "    pred_sets = wrap.predict_sets(cur_X)\n",
    "    average_size_005_clean += [np.mean([len(x) for x in pred_sets])]\n",
    "\n",
    "    cur_X = x_fog1[risk_target_indices]\n",
    "    cur_y = y_fog1[risk_target_indices].argmax(axis=1)\n",
    "    pred_sets = wrap.predict_sets(cur_X)\n",
    "    average_size_005_fog1 += [np.mean([len(x) for x in pred_sets])]\n",
    "\n",
    "    cur_X = x_fog3[risk_target_indices]\n",
    "    cur_y = y_fog3[risk_target_indices].argmax(axis=1)\n",
    "    pred_sets = wrap.predict_sets(cur_X)\n",
    "    average_size_005_fog3 += [np.mean([len(x) for x in pred_sets])]\n",
    "\n",
    "    cur_X = x_fog5[risk_target_indices]\n",
    "    cur_y = y_fog5[risk_target_indices].argmax(axis=1)\n",
    "    pred_sets = wrap.predict_sets(cur_X)\n",
    "    average_size_005_fog5 += [np.mean([len(x) for x in pred_sets])]\n",
    "\n",
    "    wrap.alpha = 0.1\n",
    "    wrap.fit(X_cal, y_cal)\n",
    "\n",
    "    #estimate miscoverage risk on the source\n",
    "\n",
    "    # now consider the target\n",
    "\n",
    "    cur_X = x_clean[risk_target_indices]\n",
    "    cur_y = y_clean[risk_target_indices].argmax(axis=1)\n",
    "    pred_sets = wrap.predict_sets(cur_X)\n",
    "    average_size_01_clean += [np.mean([len(x) for x in pred_sets])]\n",
    "\n",
    "    cur_X = x_fog1[risk_target_indices]\n",
    "    cur_y = y_fog1[risk_target_indices].argmax(axis=1)\n",
    "    pred_sets = wrap.predict_sets(cur_X)\n",
    "    average_size_01_fog1 += [np.mean([len(x) for x in pred_sets])]\n",
    "\n",
    "    cur_X = x_fog3[risk_target_indices]\n",
    "    cur_y = y_fog3[risk_target_indices].argmax(axis=1)\n",
    "    pred_sets = wrap.predict_sets(cur_X)\n",
    "    average_size_01_fog3 += [np.mean([len(x) for x in pred_sets])]\n",
    "\n",
    "    cur_X = x_fog5[risk_target_indices]\n",
    "    cur_y = y_fog5[risk_target_indices].argmax(axis=1)\n",
    "    pred_sets = wrap.predict_sets(cur_X)\n",
    "    average_size_01_fog5 += [np.mean([len(x) for x in pred_sets])]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 328,
   "id": "5ad3fc52",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-05T22:13:49.365392Z",
     "start_time": "2021-10-05T22:13:48.813690Z"
    }
   },
   "outputs": [],
   "source": [
    "df = pd.DataFrame()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 329,
   "id": "bb337b13",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-05T22:13:49.959231Z",
     "start_time": "2021-10-05T22:13:49.857456Z"
    }
   },
   "outputs": [],
   "source": [
    "df['Clean, '+r'$\\beta_1$']=average_size_005_clean\n",
    "df['Clean, '+r'$\\beta_2$']=average_size_01_clean\n",
    "df['Fog (1), '+r'$\\beta_1$']=average_size_005_fog1\n",
    "df['Fog (1), '+r'$\\beta_2$']=average_size_01_fog1\n",
    "df['Fog (3), '+r'$\\beta_1$']=average_size_005_fog3\n",
    "df['Fog (3), '+r'$\\beta_2$']=average_size_01_fog3\n",
    "df['Fog (5), '+r'$\\beta_1$']=average_size_005_fog5\n",
    "df['Fog (5), '+r'$\\beta_2$']=average_size_01_fog5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 331,
   "id": "1d81324b",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-05T22:14:07.173826Z",
     "start_time": "2021-10-05T22:14:06.296043Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plt.figure(figsize=[15,6])\n",
    "sns.boxplot(data=df)\n",
    "plt.ylabel('Average prediction set size', fontsize=23)\n",
    "plt.xlabel('Type of input data and prescribed error level', fontsize=23)\n",
    "plt.savefig('img/size_vs_alpha_and_cor.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 263,
   "id": "cd226fc5",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-05T04:53:34.273270Z",
     "start_time": "2021-10-05T04:53:33.917179Z"
    },
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "pr_sets_05=wrap.predict_sets(x_clean[risk_target_indices][:50])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 264,
   "id": "1eacc107",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-05T04:53:52.254526Z",
     "start_time": "2021-10-05T04:53:52.184906Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2.18"
      ]
     },
     "execution_count": 264,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean([len(x) for x in pr_sets_05])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0855ab6d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "87704541",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 193,
   "id": "74c9f7dd",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T02:40:53.637915Z",
     "start_time": "2021-10-04T02:40:52.684757Z"
    }
   },
   "outputs": [],
   "source": [
    "ds_clean = tfds.as_numpy(tfds.load('cifar10_corrupted',\n",
    "               split='test',\n",
    "               batch_size=-1,\n",
    "               as_supervised=True,\n",
    "               shuffle_files=False))\n",
    "\n",
    "ds_fog1 = tfds.as_numpy(tfds.load('cifar10_corrupted/fog_1',\n",
    "               split='test',\n",
    "               batch_size=-1,\n",
    "               as_supervised=True,\n",
    "               shuffle_files=False))\n",
    "\n",
    "ds_fog3 = tfds.as_numpy(tfds.load('cifar10_corrupted/fog_3',\n",
    "               split='test',\n",
    "               batch_size=-1,\n",
    "               as_supervised=True,\n",
    "               shuffle_files=False))\n",
    "\n",
    "ds_fog5 = tfds.as_numpy(tfds.load('cifar10_corrupted/fog_5',\n",
    "               split='test',\n",
    "               batch_size=-1,\n",
    "               as_supervised=True,\n",
    "               shuffle_files=False))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 194,
   "id": "9c743a09",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T02:42:00.788810Z",
     "start_time": "2021-10-04T02:42:00.257720Z"
    }
   },
   "outputs": [],
   "source": [
    "#preprocess all\n",
    "\n",
    "x_clean = ds_clean[0].astype('float32') / 255\n",
    "x_clean -= x_train_mean\n",
    "y_clean = keras.utils.to_categorical(ds_clean[1], num_classes)\n",
    "\n",
    "x_fog1 = ds_fog1[0].astype('float32') / 255\n",
    "x_fog1 -= x_train_mean\n",
    "y_fog1 = keras.utils.to_categorical(ds_fog1[1], num_classes)\n",
    "\n",
    "x_fog3 = ds_fog3[0].astype('float32') / 255\n",
    "x_fog3 -= x_train_mean\n",
    "y_fog3 = keras.utils.to_categorical(ds_fog3[1], num_classes)\n",
    "\n",
    "x_fog5 = ds_fog5[0].astype('float32') / 255\n",
    "x_fog5 -= x_train_mean\n",
    "y_fog5 = keras.utils.to_categorical(ds_fog5[1], num_classes)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 195,
   "id": "ec5715b9",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T02:42:28.356664Z",
     "start_time": "2021-10-04T02:42:13.524921Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "313/313 [==============================] - 15s 47ms/step - loss: 0.9281 - accuracy: 0.7942\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[0.9280756115913391, 0.7942000031471252]"
      ]
     },
     "execution_count": 195,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.evaluate(x_clean,y_clean)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 196,
   "id": "bc36c984",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T02:42:44.544521Z",
     "start_time": "2021-10-04T02:42:28.358685Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "313/313 [==============================] - 16s 51ms/step - loss: 0.9618 - accuracy: 0.7811\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[0.9617635011672974, 0.7810999751091003]"
      ]
     },
     "execution_count": 196,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.evaluate(x_fog1,y_fog1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 197,
   "id": "46e8257d",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T02:43:01.366892Z",
     "start_time": "2021-10-04T02:42:44.547117Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "313/313 [==============================] - 17s 53ms/step - loss: 1.2497 - accuracy: 0.7022\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[1.249686360359192, 0.7021999955177307]"
      ]
     },
     "execution_count": 197,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.evaluate(x_fog3,y_fog3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 198,
   "id": "edaa42c5",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T02:43:18.401427Z",
     "start_time": "2021-10-04T02:43:01.376782Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "313/313 [==============================] - 17s 54ms/step - loss: 2.1484 - accuracy: 0.4942\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[2.148421049118042, 0.4941999912261963]"
      ]
     },
     "execution_count": 198,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.evaluate(x_fog5,y_fog5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 218,
   "id": "ed80a2b7",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T02:46:27.632871Z",
     "start_time": "2021-10-04T02:46:27.562387Z"
    },
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([   4,   23,   39,   41,   44,   48,   55,   57,   65,   67,   72,\n",
       "          76,   83,   94,  123,  127,  130,  138,  147,  155,  156,  184,\n",
       "         197,  199,  205,  206,  215,  245,  270,  278,  279,  282,  285,\n",
       "         302,  307,  314,  329,  330,  359,  369,  375,  377,  383,  398,\n",
       "         407,  423,  424,  431,  434,  439,  452,  457,  458,  465,  487,\n",
       "         488,  491,  501,  531,  548,  550,  567,  577,  607,  616,  626,\n",
       "         628,  668,  669,  679,  689,  699,  710,  712,  714,  732,  746,\n",
       "         749,  764,  774,  777,  778,  782,  784,  793,  804,  817,  822,\n",
       "         832,  848,  862,  873,  877,  892,  893,  915,  921,  944,  957,\n",
       "         982,  995,  997,  999, 1007, 1008, 1009, 1019, 1038, 1045, 1052,\n",
       "        1061, 1068, 1074, 1078, 1098, 1100, 1103, 1109, 1111, 1118, 1121,\n",
       "        1127, 1129, 1136, 1155, 1156, 1162, 1167, 1185, 1187, 1190, 1201,\n",
       "        1215, 1216, 1231, 1241, 1244, 1267, 1284, 1290, 1305, 1311, 1338,\n",
       "        1364, 1366, 1372, 1403, 1404, 1405, 1411, 1434, 1443, 1444, 1445,\n",
       "        1447, 1483, 1492, 1498, 1526, 1536, 1538, 1542, 1546, 1547, 1552,\n",
       "        1554, 1559, 1564, 1566, 1567, 1574, 1579, 1588, 1598, 1620, 1622,\n",
       "        1629, 1649, 1657, 1662, 1683, 1690, 1716, 1723, 1737, 1743, 1747,\n",
       "        1753, 1755, 1772, 1773, 1780, 1785, 1808, 1820, 1839, 1841, 1842,\n",
       "        1851, 1863, 1871, 1897, 1898, 1906, 1909, 1918, 1934, 1936, 1946,\n",
       "        1958, 1959, 1961, 1966, 1979, 1987, 1991, 1999, 2003, 2022, 2031,\n",
       "        2037, 2044, 2046, 2050, 2132, 2139, 2148, 2159, 2165, 2167, 2173,\n",
       "        2193, 2209, 2250, 2251, 2255, 2268, 2274, 2281, 2309, 2317, 2330,\n",
       "        2337, 2346, 2347, 2351, 2353, 2357, 2361, 2365, 2372, 2382, 2384,\n",
       "        2390, 2400, 2443, 2447, 2465, 2467, 2485, 2488, 2499, 2501, 2515,\n",
       "        2516, 2518, 2522, 2562, 2568, 2572, 2595, 2602, 2613, 2630, 2631,\n",
       "        2637, 2672, 2688, 2689, 2717, 2767, 2774, 2775, 2780, 2782, 2790,\n",
       "        2809, 2827, 2833, 2852, 2867, 2868, 2870, 2879, 2887, 2891, 2917,\n",
       "        2926, 2934, 2937, 2938, 2967, 2968, 2979, 2983, 3013, 3026, 3038,\n",
       "        3039, 3041, 3046, 3055, 3075, 3091, 3098, 3100, 3105, 3108, 3109,\n",
       "        3138, 3166, 3177, 3178, 3188, 3193, 3209, 3232, 3271, 3280, 3291,\n",
       "        3293, 3305, 3309, 3317, 3326, 3338, 3352, 3378, 3380, 3381, 3382,\n",
       "        3394, 3399, 3400, 3405, 3417, 3429, 3439, 3456, 3460, 3462, 3464,\n",
       "        3467, 3480, 3483, 3499, 3503, 3514, 3516, 3518, 3524, 3531, 3534,\n",
       "        3538, 3541, 3546, 3555, 3557, 3566, 3568, 3576, 3582, 3605, 3606,\n",
       "        3607, 3623, 3625, 3629, 3652, 3657, 3661, 3662, 3688, 3690, 3693,\n",
       "        3710, 3726, 3729, 3730, 3733, 3735, 3746, 3752, 3767, 3768, 3778,\n",
       "        3781, 3783, 3791, 3808, 3815, 3818, 3848, 3849, 3855, 3857, 3858,\n",
       "        3868, 3881, 3907, 3919, 3928, 3983, 4019, 4026, 4027, 4038, 4059,\n",
       "        4060, 4061, 4068, 4070, 4072, 4087, 4095, 4098, 4102, 4133, 4140,\n",
       "        4149, 4153, 4168, 4171, 4175, 4177, 4180, 4207, 4221, 4224, 4245,\n",
       "        4247, 4248, 4267, 4269, 4288, 4291, 4296, 4313, 4319, 4327, 4349,\n",
       "        4356, 4361, 4366, 4374, 4382, 4395, 4400, 4414, 4415, 4422, 4423,\n",
       "        4432, 4447, 4449, 4464, 4480, 4486, 4487, 4500, 4506, 4509, 4515,\n",
       "        4527, 4540, 4545, 4553, 4564, 4607, 4617, 4624, 4626, 4630, 4645,\n",
       "        4646, 4663, 4704, 4710, 4716, 4725, 4727, 4744, 4759, 4762, 4768,\n",
       "        4774, 4784, 4809, 4816, 4825, 4828, 4839, 4840, 4842, 4844, 4853,\n",
       "        4858, 4870, 4885, 4891, 4898, 4900, 4903, 4912, 4917, 4918, 4925,\n",
       "        4940, 4960, 4974, 4976, 4981, 4989, 4995, 5001, 5022, 5034, 5037,\n",
       "        5041, 5056, 5058, 5063, 5073, 5088, 5090, 5103, 5124, 5125, 5130,\n",
       "        5140, 5154, 5157, 5175, 5186, 5188, 5221, 5228, 5229, 5243, 5245,\n",
       "        5247, 5252, 5255, 5272, 5283, 5289, 5313, 5320, 5321, 5329, 5339,\n",
       "        5355, 5362, 5366, 5373, 5379, 5390, 5401, 5410, 5425, 5449, 5460,\n",
       "        5470, 5501, 5508, 5517, 5518, 5553, 5578, 5581, 5582, 5587, 5593,\n",
       "        5597, 5603, 5605, 5612, 5619, 5650, 5652, 5669, 5685, 5691, 5706,\n",
       "        5715, 5723, 5741, 5744, 5748, 5765, 5782, 5794, 5826, 5829, 5833,\n",
       "        5858, 5863, 5867, 5880, 5900, 5919, 5921, 5925, 5951, 5983, 6030,\n",
       "        6032, 6053, 6065, 6086, 6088, 6103, 6108, 6118, 6137, 6171, 6181,\n",
       "        6203, 6205, 6217, 6230, 6232, 6235, 6242, 6249, 6257, 6279, 6283,\n",
       "        6295, 6297, 6298, 6310, 6313, 6318, 6336, 6344, 6370, 6375, 6380,\n",
       "        6384, 6409, 6412, 6430, 6451, 6471, 6481, 6502, 6509, 6511, 6513,\n",
       "        6518, 6531, 6533, 6535, 6539, 6541, 6547, 6548, 6549, 6567, 6570,\n",
       "        6588, 6602, 6628, 6637, 6641, 6646, 6659, 6666, 6715, 6718, 6723,\n",
       "        6734, 6737, 6750, 6760, 6761, 6765, 6767, 6770, 6775, 6785, 6846,\n",
       "        6849, 6860, 6890, 6899, 6901, 6905, 6964, 6968, 6990, 6997, 7008,\n",
       "        7013, 7031, 7037, 7045, 7048, 7055, 7058, 7075, 7087, 7088, 7091,\n",
       "        7107, 7109, 7112, 7115, 7128, 7135, 7139, 7151, 7168, 7171, 7175,\n",
       "        7187, 7209, 7228, 7235, 7237, 7238, 7252, 7253, 7261, 7277, 7281,\n",
       "        7283, 7300, 7304, 7340, 7349, 7353, 7364, 7371, 7384, 7417, 7442,\n",
       "        7446, 7472, 7477, 7485, 7488, 7495, 7512, 7514, 7544, 7551, 7565,\n",
       "        7567, 7582, 7584, 7585, 7609, 7640, 7648, 7674, 7682, 7695, 7710,\n",
       "        7730, 7737, 7739, 7747, 7765, 7768, 7771, 7781, 7788, 7805, 7836,\n",
       "        7837, 7861, 7867, 7877, 7880, 7891, 7894, 7906, 7926, 7943, 7946,\n",
       "        7964, 7972, 7979, 7981, 7987, 8039, 8074, 8077, 8078, 8089, 8090,\n",
       "        8091, 8097, 8104, 8114, 8146, 8159, 8171, 8177, 8182, 8184, 8193,\n",
       "        8209, 8240, 8243, 8250, 8264, 8279, 8296, 8298, 8325, 8327, 8330,\n",
       "        8336, 8341, 8342, 8364, 8377, 8379, 8386, 8390, 8401, 8407, 8421,\n",
       "        8425, 8439, 8446, 8447, 8480, 8491, 8497, 8502, 8511, 8520, 8554,\n",
       "        8555, 8557, 8564, 8566, 8572, 8598, 8599, 8604, 8606, 8610, 8613,\n",
       "        8628, 8648, 8650, 8675, 8677, 8681, 8684, 8689, 8696, 8697, 8707,\n",
       "        8708, 8710, 8716, 8718, 8722, 8723, 8724, 8733, 8744, 8746, 8750,\n",
       "        8770, 8773, 8789, 8810, 8811, 8818, 8837, 8845, 8848, 8894, 8913,\n",
       "        8929, 8937, 8949, 8953, 8976, 8983, 9012, 9015, 9022, 9023, 9025,\n",
       "        9029, 9041, 9051, 9052, 9061, 9075, 9090, 9116, 9118, 9133, 9155,\n",
       "        9162, 9166, 9172, 9195, 9197, 9199, 9205, 9207, 9209, 9211, 9213,\n",
       "        9231, 9247, 9259, 9260, 9263, 9265, 9266, 9276, 9285, 9287, 9300,\n",
       "        9314, 9316, 9322, 9324, 9334, 9336, 9349, 9351, 9358, 9370, 9388,\n",
       "        9402, 9406, 9409, 9428, 9430, 9436, 9448, 9465, 9483, 9505, 9525,\n",
       "        9541, 9543, 9556, 9560, 9569, 9570, 9571, 9574, 9586, 9609, 9647,\n",
       "        9648, 9665, 9668, 9677, 9682, 9692, 9695, 9698, 9706, 9718, 9734,\n",
       "        9743, 9744, 9768, 9771, 9776, 9807, 9826, 9868, 9888, 9902, 9917,\n",
       "        9925, 9926, 9928, 9931, 9941, 9948, 9956, 9958, 9961, 9990]),)"
      ]
     },
     "execution_count": 218,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.where(ds_clean[1] ==5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 227,
   "id": "0983d8ed",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T02:47:24.872542Z",
     "start_time": "2021-10-04T02:47:24.612374Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(x_clean[41]+ x_train_mean)\n",
    "plt.axis('off')\n",
    "plt.savefig('img/cifar10-c-clean.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 228,
   "id": "9330967d",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T02:47:30.053726Z",
     "start_time": "2021-10-04T02:47:29.822915Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(x_fog1[41]+ x_train_mean)\n",
    "plt.axis('off')\n",
    "plt.savefig('img/cifar10-c-fog1.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 229,
   "id": "e775513e",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T02:47:37.811111Z",
     "start_time": "2021-10-04T02:47:37.591878Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(x_fog3[41]+ x_train_mean)\n",
    "plt.axis('off')\n",
    "plt.savefig('img/cifar10-c-fog3.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 230,
   "id": "2a47b8fd",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T02:47:43.495364Z",
     "start_time": "2021-10-04T02:47:43.275799Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(x_fog5[41]+ x_train_mean)\n",
    "plt.axis('off')\n",
    "plt.savefig('img/cifar10-c-fog5.pdf', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f51c0d88",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 199,
   "id": "cc186504",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T02:44:12.534327Z",
     "start_time": "2021-10-04T02:44:12.454856Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(10000, 32, 32, 3)"
      ]
     },
     "execution_count": 199,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_clean.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 180,
   "id": "8607fea7",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T02:35:14.934204Z",
     "start_time": "2021-10-04T02:35:14.864045Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([7, 0, 6, ..., 8, 6, 0])"
      ]
     },
     "execution_count": 180,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ds_fog1[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 178,
   "id": "6411fa29",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T02:35:04.712455Z",
     "start_time": "2021-10-04T02:35:04.645086Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([3, 8, 8, ..., 5, 1, 7])"
      ]
     },
     "execution_count": 178,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y_test.argmax(axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 181,
   "id": "6317bab3",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T02:37:14.571404Z",
     "start_time": "2021-10-04T02:37:14.364194Z"
    }
   },
   "outputs": [],
   "source": [
    "x_fog1 = ds_fog1[0].astype('float32') / 255\n",
    "x_fog1 -= x_train_mean\n",
    "\n",
    "y_fog1 = keras.utils.to_categorical(ds_fog1[1], num_classes)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 184,
   "id": "7e43daed",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T02:38:30.485888Z",
     "start_time": "2021-10-04T02:38:30.276725Z"
    }
   },
   "outputs": [],
   "source": [
    "x_fog3 = ds_fog3[0].astype('float32') / 255\n",
    "x_fog3 -= x_train_mean\n",
    "\n",
    "y_fog3 = keras.utils.to_categorical(ds_fog3[1], num_classes)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 185,
   "id": "bf497156",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T02:38:52.617480Z",
     "start_time": "2021-10-04T02:38:38.935346Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "313/313 [==============================] - 14s 43ms/step - loss: 1.2497 - accuracy: 0.7022\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[1.249686360359192, 0.7021999955177307]"
      ]
     },
     "execution_count": 185,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.evaluate(x_fog3,y_fog3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 182,
   "id": "9ef5a049",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2021-10-04T02:37:42.873071Z",
     "start_time": "2021-10-04T02:37:29.171726Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "313/313 [==============================] - 14s 43ms/step - loss: 0.9618 - accuracy: 0.7811\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[0.9617635011672974, 0.7810999751091003]"
      ]
     },
     "execution_count": 182,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.evaluate(x_fog1,y_fog1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cb5a2ded",
   "metadata": {},
   "outputs": [],
   "source": [
    "l1, = plt.plot((np.arange(num_of_batches) + 1) * batch_size,\n",
    "               clean_mean,\n",
    "               color='dimgray',\n",
    "               marker='*',\n",
    "               label='Clean')\n",
    "\n",
    "plt.fill_between((np.arange(num_of_batches) + 1) * batch_size,\n",
    "                 y1=clean_mean - 2 * clean_std / np.sqrt(num_of_repeats),\n",
    "                 y2=clean_mean + 2 * clean_std / np.sqrt(num_of_repeats),\n",
    "                 color='goldenrod',\n",
    "                 alpha=0.5)\n",
    "\n",
    "l2, = plt.plot((np.arange(num_of_batches) + 1) * batch_size,\n",
    "               translate_mean,\n",
    "               color='indianred',\n",
    "               marker='*',\n",
    "               label='Fog')\n",
    "\n",
    "plt.fill_between((np.arange(num_of_batches) + 1) * batch_size,\n",
    "                 y1=translate_mean - 2 * translate_std / np.sqrt(num_of_repeats),\n",
    "                 y2=translate_mean + 2 * translate_std / np.sqrt(num_of_repeats),\n",
    "                 color='indianred',\n",
    "                 alpha=0.5)\n",
    "\n",
    "l3, = plt.plot((np.arange(num_of_batches) + 1) * batch_size,\n",
    "               zigzag_mean,\n",
    "               color='steelblue',\n",
    "               marker='*',\n",
    "               label='Zigzag')\n",
    "\n",
    "plt.fill_between((np.arange(num_of_batches) + 1) * batch_size,\n",
    "                 y1=zigzag_mean - 2 * fog_std / np.sqrt(num_of_repeats),\n",
    "                 y2=zigzag_mean + 2 * fog_std / np.sqrt(num_of_repeats),\n",
    "                 color='steelblue',\n",
    "                 alpha=0.5)\n",
    "\n",
    "l4, = plt.plot((np.arange(num_of_batches) + 1) * batch_size,\n",
    "               motion_mean,\n",
    "               color='mediumaquamarine',\n",
    "               marker='*',\n",
    "               label='Motion')\n",
    "\n",
    "plt.fill_between((np.arange(num_of_batches) + 1) * batch_size,\n",
    "                 y1=motion_mean - 2 * fog_std / np.sqrt(num_of_repeats),\n",
    "                 y2=motion_mean + 2 * fog_std / np.sqrt(num_of_repeats),\n",
    "                 color='mediumaquamarine',\n",
    "                 alpha=0.5)\n",
    "\n",
    "l5 = plt.axhline(tester.source_rejection_threshold,\n",
    "                 linestyle='dashed',\n",
    "                 c='goldenrod',\n",
    "                 label='Rejection threshold: ' +\n",
    "                 r'$\\widehat{U}_S(f) + \\varepsilon_{\\mathrm{tol}}$')\n",
    "\n",
    "plt.xlabel('Number of samples from the target domain', fontsize=23)\n",
    "plt.ylabel('Misclassification risk', fontsize=23)\n",
    "\n",
    "# plt.legend(loc='best', markerscale=1.5, prop={'size': 20})\n",
    "\n",
    "p5, = plt.plot([0.15], marker='None', linestyle='None', label='dummy-tophead')\n",
    "\n",
    "plt.ylabel('Misclassification risk', fontsize=23)\n",
    "plt.xlabel('Number of samples from the target domain', fontsize=23)\n",
    "\n",
    "categories = [\n",
    "    'Test rejection threshold: ' +\n",
    "    r'$\\widehat{U}_S(f) + \\varepsilon_{\\mathrm{tol}}$',\n",
    "    r'$\\textbf{LCB on the target risk for:}$ ', 'Clean', 'Translate', 'Zigzag',\n",
    "    'Motion Blur'\n",
    "]\n",
    "\n",
    "leg4 = plt.legend([l5, p5, l1, l2, l3, l4],\n",
    "                  categories,\n",
    "                  loc=1,\n",
    "                  ncol=1,\n",
    "                  prop={'size': 20})  # Two columns, horizontal group labels\n",
    "\n",
    "# plt.ylim([-0.05,0.45])\n",
    "# plt.show()\n",
    "# plt.savefig('img/mnist_c_trained_once.pdf', bbox_inches='tight')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.7"
  },
  "toc": {
   "base_numbering": 1,
   "nav_menu": {},
   "number_sections": true,
   "sideBar": true,
   "skip_h1_title": false,
   "title_cell": "Table of Contents",
   "title_sidebar": "Contents",
   "toc_cell": false,
   "toc_position": {},
   "toc_section_display": true,
   "toc_window_display": false
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
