{"nbformat":4,"nbformat_minor":0,"metadata":{"colab":{"name":"Copy of BALDBinaryAcquisition.ipynb","provenance":[],"collapsed_sections":[],"machine_shape":"hm"},"kernelspec":{"name":"python3","display_name":"Python 3"},"accelerator":"GPU"},"cells":[{"cell_type":"code","metadata":{"id":"HOw_S60uAkb8","executionInfo":{"status":"ok","timestamp":1592237607722,"user_tz":240,"elapsed":852,"user":{"displayName":"udai nagpal","photoUrl":"","userId":"12588575064932663407"}},"outputId":"62f4fee9-ea7a-4059-96f0-86722b37e28b","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","from scipy.stats import entropy\n","import matplotlib.pyplot as plt\n","from keras.models import Sequential\n","from keras.layers.core import Dense, Dropout, Activation, Flatten, SpatialDropout2D\n","from keras.layers.convolutional import Convolution2D, MaxPooling2D\n","from keras.regularizers import l2\n","from keras import backend as K\n","\n","from google.colab import drive\n","drive.mount(\"/content/gdrive\")"],"execution_count":null,"outputs":[{"output_type":"stream","text":["Drive already mounted at /content/gdrive; to attempt to forcibly remount, call drive.mount(\"/content/gdrive\", force_remount=True).\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"iPvBmvo_Aq-T"},"source":["#Used for calculating test acc (average of MC dropout predictions)\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], 2))\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","#Used for making repeated pool predictions\n","def predict_pool_with_uncertainty(f, x, n_iter=50):\n","    \"\"\"Function generating and returning non-deterministic predictions using MC dropout\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","        All MC dropout predictions\n","    \"\"\"\n","    result = np.zeros((n_iter,x.shape[0], 2))\n","    for i in range(n_iter):\n","        predictions = np.array(f((x, 1))[0])\n","        result[i,:, :] = predictions\n","    return result\n","\n","\n","def run_model (train_data_indices, pool_sample_indices):\n","  \"\"\"Initializes and trains a Keras model from scratch on the given training data, returning test MAE and MSE (and MC dropout predictions for D_{sample})\n","  #Arguments\n","      train_data_indices: indices within X_train_All of current training points\n","      pool_sample_indices: indices within X_train_All of pool points in the selected sample D_{sample}\n","  #Returns\n","      Test Accuracy and MC dropout predictions for all pool points in D_{sample}\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[y_train==7] = 1\n","  y_train[y_train==9] = 0\n","  y_train = keras.utils.to_categorical(y_train, num_classes=2)\n","  train_size = y_train.shape[0]\n","  Weight_Decay = 0.0005/train_size\n","  dropout_prob = 0.30\n","  batch_size=128\n","  nb_filters = 35\n","  nb_pool = 3\n","  nb_conv = 4\n","  img_rows = img_cols = 28\n","  nb_classes = 2\n","  model = Sequential()\n","  model.add(Convolution2D(nb_filters, 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, nb_conv, data_format=\"channels_first\", strides=2))\n","  model.add(Activation('relu'))\n","  model.add(MaxPooling2D(pool_size=(nb_pool, nb_pool), data_format=\"channels_first\"))\n","  model.add(Dropout(dropout_prob))\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","  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","  pool_sample_predictions = predict_pool_with_uncertainty(f, np.expand_dims(X_train_All[pool_sample_indices], axis=1), n_iter=50)\n","  return [np.sum(y_test_predictions==y_test_original)/(y_test_original.shape[0]), pool_sample_predictions]\n","\n","\n","def get_acquisition_fn(pool_forward_pass):\n","  \"\"\"Evaluates BALD acquisition function (pool_forward_pass shape is [num_masks (J), number of pool candidate points, number of classes])\n","  #Arguments:\n","      pool_forward_pass: MC dropout predictions on candidate points for acquisition in the pool\n","  #Returns:\n","      Value of BALD acquisition function for each pool candidate point\n","  \"\"\"\n","  #Calculating First Term\n","  average_predictions = np.mean(pool_forward_pass, axis=0)\n","  average_prob_entropies = entropy(average_predictions, base=2, axis=1) \n","  #Calculating second term\n","  all_entropies = entropy(pool_forward_pass, base=2, axis=2)\n","  average_entropies = np.mean(all_entropies, axis=0)\n","  bald_values = average_prob_entropies - average_entropies\n","  return bald_values"],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"e4rGbms-DZ0H"},"source":["#Active learning parameters/settings\n","dropout_prob = 0.3\n","num_experiments = 3\n","num_acquisitions = 200\n","pool_sample_size = 2500\n","num_masks = 50\n","\n","batch_size = 1\n"],"execution_count":null,"outputs":[]},{"cell_type":"code","metadata":{"id":"MRHtKSU1B9gy","executionInfo":{"status":"ok","timestamp":1592238013634,"user_tz":240,"elapsed":406689,"user":{"displayName":"udai nagpal","photoUrl":"","userId":"12588575064932663407"}},"outputId":"8723351d-0a42-4006-d2a6-ca7d642b7558","colab":{"base_uri":"https://localhost:8080/","height":1000}},"source":["#Loading data\n","data_path = \"/content/gdrive/My Drive/FINAL_PAPER_ACTIVE_LEARNING_EXP/MNIST/\"\n","starting_ind_path = \"/content/gdrive/My Drive/FINAL_PAPER_ACTIVE_LEARNING_EXP/MNIST/Binary_7_9_AL_Scripts/\"\n","results_path = \"/content/gdrive/My Drive/FINAL_PAPER_ACTIVE_LEARNING_EXP/MNIST/Binary_7_9_AL_Results/\"\n","train_data = np.loadtxt(data_path + \"mnist_train.csv\", \n","\t\t\tdelimiter=\",\")\n","test_data = np.loadtxt(data_path + \"mnist_test.csv\", \n","\t\t\tdelimiter=\",\") \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.concatenate((np.argwhere(y_train_All==7), np.argwhere(y_train_All==9))).flatten()\n","test_ind = np.concatenate((np.argwhere(y_test==7), np.argwhere(y_test==9))).flatten()\n","y_test = y_test[test_ind]\n","y_test[y_test==9] = 0\n","y_test[y_test==7]= 1\n","y_test_original = y_test\n","y_test = keras.utils.to_categorical(y_test, num_classes=2)\n","X_test = np.expand_dims(X_test[test_ind], axis=1)\n","\n","#Iterating across experiments, each of which begins with a different training set (that is balanced across classes)\n","#Note: code is currently set up to *resume* an active learning experiment\n","#To start an active learning experiment from scratch, several lines below that are commented out should be uncommented, and vice versa\n","\n","for e in range(2,3):\n","  acc_file = \"BALDRevised_BS\" + str(batch_size)+\"_Acc_Ind\" + str(e+1) + \".npy\"\n","  ind_file = \"BALDRevised_BS\"+str(batch_size)+\"_Ind_Ind\" + str(e+1) + \".npy\"\n","  #exp_acc = []\n","  exp_acc = list(np.load(results_path+acc_file))\n","  #train_data_indices = list(np.load(starting_ind_path + 'trainindices' + str(e+1) + '.npy'))\n","  train_data_indices = list(np.load(results_path+ind_file))\n","  pool_indices = [i for i in train_ind if i not in train_data_indices]\n","  num_acquisitions = 200 - batch_size * (len(exp_acc)-1)\n","  #Looping over acquisition iterations\n","  for acq in range(num_acquisitions//batch_size + 1):\n","    #Selecting candidate points for aquisition\n","    pool_ind_sample = np.random.choice(pool_indices, pool_sample_size, replace=False)\n","    model_results = run_model(train_data_indices, pool_ind_sample)\n","    #if acq != 0:\n","    exp_acc.append(model_results[0])\n","    #Acquiring the point(s) maximizing the BALD acquisition function\n","    pool_forward_pass_results = model_results[1]  \n","    acq_fn_values = get_acquisition_fn(pool_forward_pass_results) \n","    acq_ind_ind = np.flip(np.argsort(acq_fn_values))[0:batch_size]\n","    #Labeling queried points and incorporating them into the training set \n","    for acq_ind in acq_ind_ind:\n","      train_data_indices.append(pool_ind_sample[acq_ind])\n","      pool_indices.remove(pool_ind_sample[acq_ind])\n","    np.save(results_path+acc_file, np.array(exp_acc))\n","    np.save(results_path+ind_file, np.array(train_data_indices))\n","    print('Exp: ' + str(e+1) + ', train size: ' + str(len(train_data_indices)) + ', Number elapsed iterations: ' + str(len(exp_acc)) + \", last acc: \" + str(exp_acc[-1]))\n"],"execution_count":null,"outputs":[{"output_type":"stream","text":["WARNING:tensorflow:From /tensorflow-1.15.2/python3.6/tensorflow_core/python/ops/resource_variable_ops.py:1630: calling BaseResourceVariable.__init__ (from tensorflow.python.ops.resource_variable_ops) with constraint is deprecated and will be removed in a future version.\n","Instructions for updating:\n","If using Keras pass *_constraint arguments to layers.\n","WARNING:tensorflow:From /usr/local/lib/python3.6/dist-packages/keras/backend/tensorflow_backend.py:4070: The name tf.nn.max_pool is deprecated. Please use tf.nn.max_pool2d instead.\n","\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["WARNING:tensorflow:From /usr/local/lib/python3.6/dist-packages/keras/backend/tensorflow_backend.py:422: The name tf.global_variables is deprecated. Please use tf.compat.v1.global_variables instead.\n","\n","Exp: 3, train size: 170, Number elapsed iterations: 160, last acc: 0.9837997054491899\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 171, Number elapsed iterations: 161, last acc: 0.9823269513991163\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 172, Number elapsed iterations: 162, last acc: 0.9867452135493373\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 173, Number elapsed iterations: 163, last acc: 0.9783996072655866\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 174, Number elapsed iterations: 164, last acc: 0.9788905252822778\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 175, Number elapsed iterations: 165, last acc: 0.9877270495827197\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 176, Number elapsed iterations: 166, last acc: 0.9911634756995582\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 177, Number elapsed iterations: 167, last acc: 0.9857633775159549\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 178, Number elapsed iterations: 168, last acc: 0.9867452135493373\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 179, Number elapsed iterations: 169, last acc: 0.9911634756995582\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 180, Number elapsed iterations: 170, last acc: 0.9916543937162494\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 181, Number elapsed iterations: 171, last acc: 0.9798723613156602\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 182, Number elapsed iterations: 172, last acc: 0.9916543937162494\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 183, Number elapsed iterations: 173, last acc: 0.9945999018163967\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 184, Number elapsed iterations: 174, last acc: 0.9872361315660285\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 185, Number elapsed iterations: 175, last acc: 0.9852724594992637\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 186, Number elapsed iterations: 176, last acc: 0.9901816396661758\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 187, Number elapsed iterations: 177, last acc: 0.9921453117329406\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 188, Number elapsed iterations: 178, last acc: 0.9901816396661758\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 189, Number elapsed iterations: 179, last acc: 0.9921453117329406\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 190, Number elapsed iterations: 180, last acc: 0.9916543937162494\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 191, Number elapsed iterations: 181, last acc: 0.9857633775159549\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 192, Number elapsed iterations: 182, last acc: 0.9862542955326461\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 193, Number elapsed iterations: 183, last acc: 0.9945999018163967\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 194, Number elapsed iterations: 184, last acc: 0.9911634756995582\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 195, Number elapsed iterations: 185, last acc: 0.993127147766323\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 196, Number elapsed iterations: 186, last acc: 0.9916543937162494\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 197, Number elapsed iterations: 187, last acc: 0.9936180657830143\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 198, Number elapsed iterations: 188, last acc: 0.993127147766323\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 199, Number elapsed iterations: 189, last acc: 0.990672557682867\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 200, Number elapsed iterations: 190, last acc: 0.9896907216494846\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 201, Number elapsed iterations: 191, last acc: 0.9847815414825725\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 202, Number elapsed iterations: 192, last acc: 0.9891998036327934\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 203, Number elapsed iterations: 193, last acc: 0.9916543937162494\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 204, Number elapsed iterations: 194, last acc: 0.9901816396661758\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 205, Number elapsed iterations: 195, last acc: 0.9901816396661758\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 206, Number elapsed iterations: 196, last acc: 0.9901816396661758\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 207, Number elapsed iterations: 197, last acc: 0.9862542955326461\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 208, Number elapsed iterations: 198, last acc: 0.9941089837997055\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 209, Number elapsed iterations: 199, last acc: 0.9921453117329406\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 210, Number elapsed iterations: 200, last acc: 0.9901816396661758\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 211, Number elapsed iterations: 201, last acc: 0.9921453117329406\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:42: 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:45: UserWarning: Update your `Dense` call to the Keras 2 API: `Dense(2, kernel_regularizer=<keras.reg...)`\n"],"name":"stderr"},{"output_type":"stream","text":["Exp: 3, train size: 212, Number elapsed iterations: 202, last acc: 0.9901816396661758\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"sWXUrGUNCZbP"},"source":["\n"],"execution_count":null,"outputs":[]}]}