{"nbformat":4,"nbformat_minor":0,"metadata":{"colab":{"name":"EIAcquisition.ipynb","provenance":[],"collapsed_sections":[],"machine_shape":"hm"},"kernelspec":{"name":"python3","display_name":"Python 3"},"accelerator":"GPU"},"cells":[{"cell_type":"code","metadata":{"id":"6SN3uEym3iyU","colab_type":"code","outputId":"c2bdd282-d960-4b7b-f69c-cf3d3c391309","executionInfo":{"status":"ok","timestamp":1587935005022,"user_tz":240,"elapsed":2108,"user":{"displayName":"Udai Nagpal","photoUrl":"","userId":"13074753849068469331"}},"colab":{"base_uri":"https://localhost:8080/","height":35}},"source":["%tensorflow_version 1.x\n","\n","import numpy as np\n","import keras\n","from keras.datasets import mnist\n","import sys\n","import scipy\n","#%matplotlib inline\n","import matplotlib.pyplot as plt\n","from keras.models import Sequential\n","from keras.layers.core import Dense, Dropout, Activation, Flatten\n","from keras.layers.convolutional import Convolution2D, MaxPooling2D\n","from keras.regularizers import l2\n","from keras import backend as K\n","\n","\n","from google.colab import drive\n","drive.mount(\"/content/gdrive\", force_remount=True)"],"execution_count":0,"outputs":[{"output_type":"stream","text":["Mounted at /content/gdrive\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"4d6y0Unr4LKj","colab_type":"code","colab":{}},"source":["\n","\n","def predict_with_uncertainty(f, x, n_iter=100):\n","    \"\"\"Function generating non-deterministic predictions using MC dropout and returning the mean of these predictions\n","    Adapted from: https://stackoverflow.com/questions/43529931/how-to-calculate-prediction-uncertainty-using-keras\n","    #Arguments:\n","        f: function mapping model input and Keras backend learning_phase flag to model output\n","        x: input\n","        n_iter: number of repreated MC dropout predictions per point\n","    #Returns:\n","        Mean of MC dropout predictions\n","    \"\"\"\n","    result = np.zeros((n_iter,x.shape[0], 10))\n","    for i in range(n_iter):\n","        predictions = np.array(f((x, 1))[0])\n","        result[i,:, :] = predictions\n","    prediction = result.mean(axis=0)\n","    return prediction\n","\n","def create_dropout_masks(dim, num_masks, drop_prob):\n","    \"\"\"Creates dropout masks that are fixed across all model inputs for use in estimation of Var(Y_{sample})\n","    Note: this function is specific to keras models used in this experiment\n","    #Arguments\n","        dim: the numpy array shape of values entering the generated dropout masks for all points across all J fixed dropout masks\n","        num_masks: the number of fixed dropout masks to be created (J)\n","        drop_prob: the dropout probability\n","    #Returns\n","        dropout masks used in estimation of Var(p_{sample})\n","    \"\"\"\n","    if (len(dim)==4):\n","        return 1/(1-drop_prob)*np.random.choice(2, size=((dim[0], 1, 1, dim[3])), p=[drop_prob, 1-drop_prob])\n","    return 1/(1-drop_prob)*np.random.choice(2, size=((num_masks, 1, dim[2], dim[3], dim[4])), p=[drop_prob, 1-drop_prob])\n","\n","def apply_dropout_masks(a,b):\n","    return np.squeeze(np.multiply(a,b))\n","\n","def multi_mask_predict(layer_fn, multi_mask_input):\n","    \"\"\"Applies Keras model layers to multiple arrays of layer inputs for all points across J fixed dropout masks\n","    #Arguments\n","        layer_fn: keras backend function applying the mapping corresponding to keras model layers\n","        multi_mask_input: numpy array of layer inputs for all points across J fixed dropout masks\n","    #Returns\n","        predictions from layer_fn applied to multi_mask_input as a numpy array\n","    \"\"\"\n","    layer_output = []\n","    for mask_num in range(multi_mask_input.shape[0]):\n","        layer_output.append(layer_fn((multi_mask_input[mask_num], 1)))\n","        #layer_output.append(layer_fn([multi_mask_input[mask_num]]))\n","    return np.array(layer_output)\n","\n","def fixed_mask_forward_pass (model, forward_pass_input, num_masks, dropout_prob, conv_masks, dense_masks):\n","      \"\"\"Makes model predictions with J dropout masks that are fixed across points to enable estimation of Var(p_{sample})\n","    Function is specific to the given Keras model.\n","    #Arguments\n","        model: keras model\n","        forward_pass_input: X_{sample}\n","        num_masks: J, the number of dropout masks being used in estimation of Var(p_{sample}) and calculation of the EI acquisition function\n","        dropout_prob: dropout probability \n","        conv_masks: first set of dropout masks, applied after MaxPooling2D layer\n","        dense_masks: second set of dropout masks, applied after the first Dense layer\n","    #Returns\n","        MC dropout predictions across sample points enabling estimation of Var(p_{sample}), i.e. \\hat{p}_{sample}\n","    \"\"\"\n","    conv = K.function([model.layers[0].input, K.learning_phase()],\n","                    [model.layers[4].output])\n","\n","    dense_1 = K.function([model.layers[6].input, K.learning_phase()],\n","                   [model.layers[8].output])\n","\n","    dense_2 = K.function([model.layers[10].input, K.learning_phase()],\n","                   [model.layers[11].output])\n","    arr_input = np.array(forward_pass_input)\n","    num_points = arr_input.shape[0]\n","    if len(arr_input.shape) == 3:\n","      forward_pass_input = np.expand_dims(forward_pass_input, axis=1)\n","    conv_output = np.array(conv((forward_pass_input, 1)))\n","    dense_1_input = apply_dropout_masks(conv_output, conv_masks)\n","    if num_points == 1:\n","        dense_1_input = np.expand_dims(dense_1_input, axis=1)\n","    dense_1_output = multi_mask_predict(dense_1, dense_1_input)\n","    dense_2_input = apply_dropout_masks(dense_1_output, dense_masks)\n","    if num_points == 1:\n","        dense_2_input = np.expand_dims(dense_2_input, axis=1)\n","    dense_2_output = multi_mask_predict(dense_2, dense_2_input)\n","    return np.squeeze(dense_2_output)\n","\n","def run_model (train_data_indices):\n","  \"\"\"Trains and Keras model with the training points specified by train_data_indices and evaluates model on test data\n","  #Arguments:\n","      train_data_indices: indices of current training points within X_train_All\n","  #Returns:\n","      Test accuracy and trained Keras model\n","  \"\"\"\n","  X_train = np.expand_dims(X_train_All[train_data_indices], axis=1)\n","  y_train = y_train_All[train_data_indices]\n","  y_train = keras.utils.to_categorical(y_train, num_classes=10)\n","  train_size = y_train.shape[0]\n","  Weight_Decay = 0.01/train_size\n","  dropout_prob = 0.25\n","  nb_filters = 40\n","  nb_pool = 3\n","  nb_conv = 4\n","  img_rows = img_cols = 28\n","  nb_classes = 10\n","  model = Sequential()\n","  model.add(Convolution2D(nb_filters, kernel_size=nb_conv, strides=1, data_format=\"channels_first\", input_shape=(1, img_rows, img_cols)))\n","  model.add(Activation('relu'))\n","  model.add(Convolution2D(nb_filters, kernel_size=nb_conv, strides=2, data_format = \"channels_first\"))\n","  model.add(Activation('relu'))\n","\t\n","  model.add(MaxPooling2D(pool_size=(nb_pool, nb_pool), data_format=\"channels_first\"))\n","  model.add(Dropout(dropout_prob))\n","\n","  model.add(Flatten())\n","  model.add(Dense(128, W_regularizer=l2(Weight_Decay)))\n","  model.add(Activation('relu'))\n","  model.add(Dropout(dropout_prob))\n","  model.add(Dense(nb_classes, W_regularizer=l2(Weight_Decay)))\n","  model.add(Activation('softmax'))\n","\n","  model.compile(loss='categorical_crossentropy', optimizer='adam')\n","  model.fit(X_train, y_train, epochs=300, batch_size=128, verbose=0)\n","  f = K.function([model.layers[0].input,K.learning_phase()],[model.layers[-1].output])\n","  y_test_output = predict_with_uncertainty(f, X_test, n_iter=100)\n","  y_test_predictions = np.argmax(y_test_output, axis=1)\n","  return [np.sum(y_test_predictions==y_test_original)/(y_test_original.shape[0]), model]\n","\n","def ei_batch_acquisition_unweighted(forward_pass_results, num_pool_samples, num_training_samples, tau_inverse, batch_size):\n","  \"\"\"Given Var(p_{sample}), applies batch-mode EI active learning to query points\n","  #Arguments\n","    forward_pass_results: Fixed-mask predictions across sample points used in estimating Var(p_{sample}) (shape: [num_masks, num_points, num_classes])\n","    num_pool_samples: number of pool points in D_{sample}\n","    num_training_samples: number of training points in D_{sample}\n","    tau_inverse: smoothing parameter\n","    batch_size: number of queried points per batch\n","  #Returns\n","    the variance reductions for queried points and the indices of queried pool points as points are arranged in univ_covariance\n","  \"\"\"\n","  #First setting tau inv based on tau inv prop\n","  num_total_points = forward_pass_results.shape[1]\n","  num_masks = forward_pass_results.shape[0]\n","  flattened_forward_pass_results = forward_pass_results.reshape((num_masks, 10*num_total_points))\n","  univ_cov = np.cov(flattened_forward_pass_results, rowvar=False) + (tau_inverse*np.identity(10*num_total_points))\n","  delta_identity = 10.0**(-15.0)\n","  univ_covariance = univ_cov + (delta_identity * np.identity(univ_cov.shape[0]))\n","  #Now starting batch mode acquisition loop\n","  print('univ covariance shape: ' + str(univ_covariance.shape))\n","  acq_ind = []\n","  acq_vals = []\n","  for acq_num in range(batch_size):\n","    all_acq_values = np.zeros(num_pool_samples)\n","    for new_pt_ind in range(num_pool_samples):\n","      if new_pt_ind in acq_ind:\n","        all_acq_values[new_pt_ind] = 0.0\n","      else:\n","        start_ind = 10*(num_training_samples+new_pt_ind) \n","        new_pt_cov_inv = np.linalg.inv(univ_covariance[start_ind:start_ind+10, start_ind:start_ind+10]) \n","        covariance_matrix = univ_covariance[:, start_ind:start_ind+10] \n","        first_matrix = np.matmul(covariance_matrix, new_pt_cov_inv)\n","        trace_reduction = np.sum(np.multiply(first_matrix, covariance_matrix)) \n","        all_acq_values[new_pt_ind] = trace_reduction\n","    sorted_top_ind = np.flip(np.argsort(all_acq_values))\n","    found_new_ind = False\n","    top_ind_ctr = -1\n","    while (found_new_ind == False):\n","       top_ind_ctr += 1\n","       new_top_ind = sorted_top_ind[top_ind_ctr]\n","       if new_top_ind not in acq_ind:\n","         acq_ind.append(new_top_ind)\n","         acq_vals.append(all_acq_values[new_top_ind])\n","         found_new_ind = True\n","    update_start_ind = 10*(num_training_samples+acq_ind[-1])\n","    top_cov_matrix = univ_covariance[:, update_start_ind:update_start_ind+10]\n","    top_pt_cov_inv = np.linalg.inv(univ_covariance[update_start_ind:update_start_ind+10, update_start_ind:update_start_ind+10]) \n","    first_matrix = np.matmul(top_cov_matrix, top_pt_cov_inv)\n","    univ_covariance = univ_covariance - np.matmul(first_matrix, top_cov_matrix.T) + (delta_identity * np.identity(univ_covariance.shape[0])) \n","  return [acq_vals, acq_ind]\n","\n","\n"],"execution_count":0,"outputs":[]},{"cell_type":"code","metadata":{"id":"pkCOo3YhCX4V","colab_type":"code","colab":{}},"source":["#Active learning parameters/settings\n","num_cand = 2000\n","batch_size = 100\n","dropout_prob = 0.25\n","num_experiments = 3\n","num_acquisitions = 1000 \n","num_masks = 50\n","\n","#Note: tau_inverse is set to 0.00003 in paper results\n","tau_inverse = 0.0003\n","\n","#Keras Model Parameters\n","num_classes = 10\n","nb_filters = 40\n","nb_pool = 2\n","nb_conv = 4\n","img_rows = img_cols = 28"],"execution_count":0,"outputs":[]},{"cell_type":"code","metadata":{"id":"bmgEmPWaCK8m","colab_type":"code","outputId":"ee153abb-733c-4bec-94b5-6499a6bb2ba4","executionInfo":{"status":"ok","timestamp":1587958290538,"user_tz":240,"elapsed":19666607,"user":{"displayName":"Udai Nagpal","photoUrl":"","userId":"13074753849068469331"}},"colab":{"base_uri":"https://localhost:8080/","height":1000}},"source":["#Loading data\n","\n","data_path = \"/content/gdrive/My Drive/FINAL_PAPER_ACTIVE_LEARNING_EXP/MNIST/\"\n","train_data = np.loadtxt(data_path + \"mnist_train.csv\", \n","\t\t  delimiter=\",\")\n","test_data = np.loadtxt(data_path + \"mnist_test.csv\", \n","\t\t delimiter=\",\") \n","y_train_All = train_data[:,0]\n","y_test = test_data[:,0]\n","X_train_All = train_data[:,1:].reshape((60000,28,28))\n","X_test = test_data[:,1:].reshape((10000,28,28)) \n","train_ind = np.arange(60000)\n","test_ind = np.arange(10000)\n","\n","y_test_original = y_test\n","y_test = keras.utils.to_categorical(y_test, num_classes=10)\n","X_test = np.expand_dims(X_test[test_ind], axis=1)\n","folder_path = \"/content/gdrive/My Drive/FINAL_PAPER_ACTIVE_LEARNING_EXP/MNIST/MultiClass_AL_Scripts_v1/\"\n","out_folder_path = \"/content/gdrive/My Drive/FINAL_PAPER_ACTIVE_LEARNING_EXP/MNIST/MultiClass_AL_Results_v1/\"\n","\n","print('Running')\t  \n","all_tr_ind = []\n","all_acc = []\n","\n","#Iterating across experiments, each of which begins with a different training set (that is balanced across classes)\n","\n","for e in range(num_experiments):\n","  num_acquisitions = 1000\n","  acc_file = \"EIAccBS\"+str(batch_size)+\"Ind\"+str(e+1)+\".npy\"\n","  ind_file = \"EIIndBS\"+str(batch_size)+\"Ind\"+str(e+1)+\".npy\"\n","  exp_acc = []\n","  #exp_acc = list(np.load(out_folder_path+acc_file))\n","  #train_data_indices = list(np.load(out_folder_path+ind_file))\n","  train_data_indices = list(np.load(folder_path + 'trainindices' + str(e+1) + '.npy'))\n","  pool_indices = [i for i in train_ind if i not in train_data_indices]\n","  #Evaluating initial model\n","  model_results = run_model(train_data_indices)\n","  print('trained model')\n","  exp_acc.append(model_results[0])\n","  all_acc.append(exp_acc)\n","  all_tr_ind.append(train_data_indices)\n","  print('Initial Acc: ' + str(all_acc))\n","  #num_acquisitions = num_acquisitions - batch_size * (len(exp_acc)-1)\n","  #Looping over acquisition iterations\n","  for acq in range(num_acquisitions//batch_size):\n","    #Randomly selecting sample points\n","    all_ind_ind = np.random.choice(len(pool_indices)+len(train_data_indices), int(num_cand*1.2), replace=False)\n","    pool_sample_ratio = len(all_ind_ind[all_ind_ind>=len(train_data_indices)])/num_cand\n","    train_sample_size = len(all_ind_ind[all_ind_ind<len(train_data_indices)])\n","    train_ind_ind = all_ind_ind[all_ind_ind<len(train_data_indices)][0:int(train_sample_size//pool_sample_ratio)]\n","    pool_ind_ind = (all_ind_ind[all_ind_ind>=len(train_data_indices)] - len(train_data_indices))[0:num_cand]\n","    pool_ind_sample = np.array(pool_indices)[pool_ind_ind]\n","    train_ind_sample = np.array(train_data_indices)[train_ind_ind]\n","    X_sample = np.concatenate((np.expand_dims(X_train_All[train_ind_sample],axis=1), np.expand_dims(X_train_All[pool_ind_sample], axis=1)))\n","    conv_masks = 1/(1-dropout_prob)*np.random.choice(2, size=((num_masks, 1, 40,3,3)), p=[dropout_prob, 1-dropout_prob])\n","    dense_masks = 1/(1-dropout_prob)*np.random.choice(2, size=((num_masks, 1, 1, 128)), p=[dropout_prob, 1-dropout_prob])\n","    pool_forward_pass_results = fixed_mask_forward_pass(model_results[1], X_sample, num_masks, dropout_prob, conv_masks, dense_masks)  \n","    #EI batch-mode acquisition\n","    batch_results = ei_batch_acquisition_unweighted(pool_forward_pass_results, len(pool_ind_sample), len(train_ind_sample), tau_inverse, batch_size)\n","    batch_ind = pool_ind_sample[batch_results[1]]\n","    #Acquiring new points, retraining model, and saving results\n","    train_data_indices = list(train_data_indices) + list(batch_ind)\n","    pool_indices = list(set(pool_indices) - set(batch_ind))      \n","    model_results = run_model(train_data_indices)\n","    exp_acc.append(model_results[0])\n","    all_acc[-1] = exp_acc\n","    all_tr_ind[-1] = train_data_indices\n","    np.save(out_folder_path+acc_file, np.array(exp_acc))\n","    np.save(out_folder_path+ind_file, np.array(train_data_indices))\n","    print('Exp ' + str(e+1)+', Exp Acc: ' + str(exp_acc) + ', num training points: ' + str(len(train_data_indices)))\n","    #print('All Ind: ' + str(all_tr_ind))\n","  print('All Acc: ' + str(all_acc))\n","\n"],"execution_count":0,"outputs":[{"output_type":"stream","text":["Running\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["trained model\n","Initial Acc: [[0.5465]]\n","avg variance: 0.03276441785917519\n","univ covariance shape: (20000, 20000)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 1, Exp Acc: [0.5465, 0.6711], num training points: 130\n","avg variance: 0.019706579659053477\n","univ covariance shape: (20000, 20000)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 1, Exp Acc: [0.5465, 0.6711, 0.852], num training points: 230\n","avg variance: 0.014720808856502796\n","univ covariance shape: (20040, 20040)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 1, Exp Acc: [0.5465, 0.6711, 0.852, 0.8793], num training points: 330\n","avg variance: 0.013212270576527277\n","univ covariance shape: (20130, 20130)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 1, Exp Acc: [0.5465, 0.6711, 0.852, 0.8793, 0.9191], num training points: 430\n","avg variance: 0.011004467864818507\n","univ covariance shape: (20150, 20150)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 1, Exp Acc: [0.5465, 0.6711, 0.852, 0.8793, 0.9191, 0.9097], num training points: 530\n","avg variance: 0.011349830316401409\n","univ covariance shape: (20190, 20190)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 1, Exp Acc: [0.5465, 0.6711, 0.852, 0.8793, 0.9191, 0.9097, 0.9347], num training points: 630\n","avg variance: 0.008498124516325025\n","univ covariance shape: (20260, 20260)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 1, Exp Acc: [0.5465, 0.6711, 0.852, 0.8793, 0.9191, 0.9097, 0.9347, 0.9448], num training points: 730\n","avg variance: 0.009095591565141553\n","univ covariance shape: (20210, 20210)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 1, Exp Acc: [0.5465, 0.6711, 0.852, 0.8793, 0.9191, 0.9097, 0.9347, 0.9448, 0.9507], num training points: 830\n","avg variance: 0.008186802442473745\n","univ covariance shape: (20330, 20330)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 1, Exp Acc: [0.5465, 0.6711, 0.852, 0.8793, 0.9191, 0.9097, 0.9347, 0.9448, 0.9507, 0.9481], num training points: 930\n","avg variance: 0.008035829942750393\n","univ covariance shape: (20290, 20290)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 1, Exp Acc: [0.5465, 0.6711, 0.852, 0.8793, 0.9191, 0.9097, 0.9347, 0.9448, 0.9507, 0.9481, 0.9525], num training points: 1030\n","All Acc: [[0.5465, 0.6711, 0.852, 0.8793, 0.9191, 0.9097, 0.9347, 0.9448, 0.9507, 0.9481, 0.9525]]\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["trained model\n","Initial Acc: [[0.5465, 0.6711, 0.852, 0.8793, 0.9191, 0.9097, 0.9347, 0.9448, 0.9507, 0.9481, 0.9525], [0.614]]\n","avg variance: 0.02993812783466699\n","univ covariance shape: (20000, 20000)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 2, Exp Acc: [0.614, 0.5909], num training points: 130\n","avg variance: 0.02750636896233875\n","univ covariance shape: (20040, 20040)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 2, Exp Acc: [0.614, 0.5909, 0.8434], num training points: 230\n","avg variance: 0.01831503749402304\n","univ covariance shape: (20050, 20050)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 2, Exp Acc: [0.614, 0.5909, 0.8434, 0.8986], num training points: 330\n","avg variance: 0.013000892121270494\n","univ covariance shape: (20120, 20120)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 2, Exp Acc: [0.614, 0.5909, 0.8434, 0.8986, 0.8979], num training points: 430\n","avg variance: 0.011884956047592298\n","univ covariance shape: (20110, 20110)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 2, Exp Acc: [0.614, 0.5909, 0.8434, 0.8986, 0.8979, 0.9239], num training points: 530\n","avg variance: 0.011010424422673649\n","univ covariance shape: (20190, 20190)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 2, Exp Acc: [0.614, 0.5909, 0.8434, 0.8986, 0.8979, 0.9239, 0.9391], num training points: 630\n","avg variance: 0.009863966500818253\n","univ covariance shape: (20210, 20210)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 2, Exp Acc: [0.614, 0.5909, 0.8434, 0.8986, 0.8979, 0.9239, 0.9391, 0.9191], num training points: 730\n","avg variance: 0.011171212445273285\n","univ covariance shape: (20240, 20240)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 2, Exp Acc: [0.614, 0.5909, 0.8434, 0.8986, 0.8979, 0.9239, 0.9391, 0.9191, 0.9416], num training points: 830\n","avg variance: 0.008887506716730786\n","univ covariance shape: (20330, 20330)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 2, Exp Acc: [0.614, 0.5909, 0.8434, 0.8986, 0.8979, 0.9239, 0.9391, 0.9191, 0.9416, 0.9444], num training points: 930\n","avg variance: 0.008504692224848167\n","univ covariance shape: (20350, 20350)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 2, Exp Acc: [0.614, 0.5909, 0.8434, 0.8986, 0.8979, 0.9239, 0.9391, 0.9191, 0.9416, 0.9444, 0.948], num training points: 1030\n","All Acc: [[0.5465, 0.6711, 0.852, 0.8793, 0.9191, 0.9097, 0.9347, 0.9448, 0.9507, 0.9481, 0.9525], [0.614, 0.5909, 0.8434, 0.8986, 0.8979, 0.9239, 0.9391, 0.9191, 0.9416, 0.9444, 0.948]]\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["trained model\n","Initial Acc: [[0.5465, 0.6711, 0.852, 0.8793, 0.9191, 0.9097, 0.9347, 0.9448, 0.9507, 0.9481, 0.9525], [0.614, 0.5909, 0.8434, 0.8986, 0.8979, 0.9239, 0.9391, 0.9191, 0.9416, 0.9444, 0.948], [0.5878]]\n","avg variance: 0.03217607389484551\n","univ covariance shape: (20000, 20000)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 3, Exp Acc: [0.5878, 0.6973], num training points: 130\n","avg variance: 0.02259996522095504\n","univ covariance shape: (20050, 20050)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 3, Exp Acc: [0.5878, 0.6973, 0.8759], num training points: 230\n","avg variance: 0.015183560987675905\n","univ covariance shape: (20080, 20080)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 3, Exp Acc: [0.5878, 0.6973, 0.8759, 0.9229], num training points: 330\n","avg variance: 0.011437766481200356\n","univ covariance shape: (20100, 20100)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 3, Exp Acc: [0.5878, 0.6973, 0.8759, 0.9229, 0.9012], num training points: 430\n","avg variance: 0.01237723466284134\n","univ covariance shape: (20160, 20160)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 3, Exp Acc: [0.5878, 0.6973, 0.8759, 0.9229, 0.9012, 0.9169], num training points: 530\n","avg variance: 0.009604966772763547\n","univ covariance shape: (20170, 20170)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 3, Exp Acc: [0.5878, 0.6973, 0.8759, 0.9229, 0.9012, 0.9169, 0.9381], num training points: 630\n","avg variance: 0.010269237592519706\n","univ covariance shape: (20160, 20160)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 3, Exp Acc: [0.5878, 0.6973, 0.8759, 0.9229, 0.9012, 0.9169, 0.9381, 0.9359], num training points: 730\n","avg variance: 0.009566059040680792\n","univ covariance shape: (20270, 20270)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 3, Exp Acc: [0.5878, 0.6973, 0.8759, 0.9229, 0.9012, 0.9169, 0.9381, 0.9359, 0.9523], num training points: 830\n","avg variance: 0.007180861921966668\n","univ covariance shape: (20280, 20280)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 3, Exp Acc: [0.5878, 0.6973, 0.8759, 0.9229, 0.9012, 0.9169, 0.9381, 0.9359, 0.9523, 0.9497], num training points: 930\n","avg variance: 0.008586201198452787\n","univ covariance shape: (20370, 20370)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:71: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(128, kernel_regularizer=<keras.reg...)`\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:74: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(10, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp 3, Exp Acc: [0.5878, 0.6973, 0.8759, 0.9229, 0.9012, 0.9169, 0.9381, 0.9359, 0.9523, 0.9497, 0.9414], num training points: 1030\n","All Acc: [[0.5465, 0.6711, 0.852, 0.8793, 0.9191, 0.9097, 0.9347, 0.9448, 0.9507, 0.9481, 0.9525], [0.614, 0.5909, 0.8434, 0.8986, 0.8979, 0.9239, 0.9391, 0.9191, 0.9416, 0.9444, 0.948], [0.5878, 0.6973, 0.8759, 0.9229, 0.9012, 0.9169, 0.9381, 0.9359, 0.9523, 0.9497, 0.9414]]\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"MPQNqJvWBNYg","colab_type":"code","colab":{}},"source":[""],"execution_count":0,"outputs":[]}]}