blob: 5035e3cfd85ac2a1b01420c3e398aeabbab4ddf7 [file] [log] [blame]
{
"cells": [
{
"cell_type": "markdown",
"metadata": {},
"source": [
"# Model Selection for CNN Using Keras and MADlib on CIFAR-10\n",
"\n",
"E2E classification example using MADlib calling a Keras CNN for different hyperparameters and model architectures on the CIFAR-10 dataset.\n",
"\n",
"The CIFAR-10 dataset consists of 60,000 32x32 colour images in 10 classes, with 6,000 images per class. There are 50,000 training images and 10,000 test images.\n",
"https://www.cs.toronto.edu/~kriz/cifar.html\n",
"\n",
"## Table of contents \n",
"\n",
"<a href=\"#setup\">0. Setup</a>\n",
"\n",
"<a href=\"#load_dataset\">1. Load dataset into table</a>\n",
"\n",
"<a href=\"#distr\">2. Setup distribution rules and call preprocessor</a>\n",
"\n",
"<a href=\"#arch\">3. Define and load model architectures</a>\n",
"\n",
"<a href=\"#mst\">4. Define and load model selection tuples</a>\n",
"\n",
"<a href=\"#train\">5. Train</a>\n",
"\n",
"<a href=\"#plot\">6. Plot results</a>\n",
"\n",
"<a href=\"#predict\">7. Inference</a>"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"<a id=\"setup\"></a>\n",
"# 0. Setup"
]
},
{
"cell_type": "code",
"execution_count": 1,
"metadata": {
"scrolled": false
},
"outputs": [],
"source": [
"%load_ext sql"
]
},
{
"cell_type": "code",
"execution_count": 2,
"metadata": {},
"outputs": [],
"source": [
"# Greenplum Database 5.x on GCP - via tunnel\n",
"%sql postgresql://gpadmin@localhost:8000/cifar_places\n",
" \n",
"# PostgreSQL local\n",
"#%sql postgresql://fmcquillan@localhost:5432/madlib"
]
},
{
"cell_type": "code",
"execution_count": 3,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"1 rows affected.\n"
]
},
{
"data": {
"text/html": [
"<table>\n",
" <tr>\n",
" <th>version</th>\n",
" </tr>\n",
" <tr>\n",
" <td>MADlib version: 1.17-dev, git revision: rc/1.16-rc1-95-gc62dfe7, cmake configuration time: Tue Mar 17 16:53:55 UTC 2020, build type: RelWithDebInfo, build system: Linux-2.6.32-754.6.3.el6.x86_64, C compiler: gcc 4.4.7, C++ compiler: g++ 4.4.7</td>\n",
" </tr>\n",
"</table>"
],
"text/plain": [
"[(u'MADlib version: 1.17-dev, git revision: rc/1.16-rc1-95-gc62dfe7, cmake configuration time: Tue Mar 17 16:53:55 UTC 2020, build type: RelWithDebInfo, build system: Linux-2.6.32-754.6.3.el6.x86_64, C compiler: gcc 4.4.7, C++ compiler: g++ 4.4.7',)]"
]
},
"execution_count": 3,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"%sql select madlib.version();\n",
"#%sql select version();"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Import libraries"
]
},
{
"cell_type": "code",
"execution_count": 4,
"metadata": {},
"outputs": [
{
"name": "stderr",
"output_type": "stream",
"text": [
"Using TensorFlow backend.\n"
]
}
],
"source": [
"from __future__ import print_function\n",
"import keras\n",
"from keras.datasets import cifar10\n",
"from keras.preprocessing.image import ImageDataGenerator\n",
"from keras.models import Sequential\n",
"from keras.layers import Dense, Dropout, Activation, Flatten, BatchNormalization\n",
"from keras.layers import Conv2D, MaxPooling2D\n",
"import os"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Others needed in this workbook"
]
},
{
"cell_type": "code",
"execution_count": 5,
"metadata": {},
"outputs": [],
"source": [
"import pandas as pd\n",
"import numpy as np\n",
"import sys\n",
"import os\n",
"from matplotlib import pyplot as plt"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"<a id=\"load_dataset\"></a>\n",
"# 1. Load dataset into table\n",
"\n",
"PXF can be used to load image data into Greenplum database.\n",
"\n",
"But for this demo, we will get the dataset from Keras and use the script called madlib_image_loader.py located at https://github.com/apache/madlib-site/tree/asf-site/community-artifacts/Deep-learning .\n",
"\n",
"If the script is not in the same folder as the notebook, you can use the following lines to import it."
]
},
{
"cell_type": "code",
"execution_count": 6,
"metadata": {},
"outputs": [],
"source": [
"import sys\n",
"sys.path.insert(1, '/Users/fmcquillan/workspace/madlib-site/community-artifacts/Deep-learning')\n",
"from madlib_image_loader import ImageLoader, DbCredentials\n",
"\n",
"# Specify database credentials, for connecting to db\n",
"db_creds = DbCredentials(db_name='cifar_places',\n",
" user='gpadmin',\n",
" host='localhost',\n",
" port='8000',\n",
" password='')\n",
"\n",
"#db_creds = DbCredentials(db_name='cifar_places',\n",
"# user='fmcquillan',\n",
"# host='localhost',\n",
"# port='5432',\n",
"# password='')\n",
"\n",
"# Initialize ImageLoader (increase num_workers to run faster)\n",
"iloader = ImageLoader(num_workers=5, db_creds=db_creds)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Load dataset into tables"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"# Load dataset into np array\n",
"(x_train, y_train), (x_test, y_test) = cifar10.load_data()\n",
"\n",
"%sql DROP TABLE IF EXISTS cifar10_train, cifar10_val;\n",
"\n",
"# Save images to temporary directories and load into database\n",
"iloader.load_dataset_from_np(x_train, y_train, 'cifar10_train', append=False)\n",
"iloader.load_dataset_from_np(x_test, y_test, 'cifar10_val', append=False)"
]
},
{
"cell_type": "code",
"execution_count": 6,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"1 rows affected.\n"
]
},
{
"data": {
"text/html": [
"<table>\n",
" <tr>\n",
" <th>count</th>\n",
" </tr>\n",
" <tr>\n",
" <td>50000</td>\n",
" </tr>\n",
"</table>"
],
"text/plain": [
"[(50000L,)]"
]
},
"execution_count": 6,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"%sql SELECT COUNT(*) FROM cifar10_train;"
]
},
{
"cell_type": "code",
"execution_count": 7,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"1 rows affected.\n"
]
},
{
"data": {
"text/html": [
"<table>\n",
" <tr>\n",
" <th>count</th>\n",
" </tr>\n",
" <tr>\n",
" <td>10000</td>\n",
" </tr>\n",
"</table>"
],
"text/plain": [
"[(10000L,)]"
]
},
"execution_count": 7,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"%sql SELECT COUNT(*) FROM cifar10_val;"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"<a id=\"distr\"></a>\n",
"# 2. Setup distribution rules and call preprocessor\n",
"\n",
"In this example we will train on 4 VMs with 4 segments/VM and 4 GPUs/VM (i.e., 16 workers).\n",
"\n",
"First get the GPU configuration in the cluster using the MADlib helper function `gpu_configuration`:"
]
},
{
"cell_type": "code",
"execution_count": 8,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Done.\n",
"1 rows affected.\n",
"20 rows affected.\n"
]
},
{
"data": {
"text/html": [
"<table>\n",
" <tr>\n",
" <th>hostname</th>\n",
" <th>gpu_descr</th>\n",
" </tr>\n",
" <tr>\n",
" <td>gpsix0</td>\n",
" <td>device: 0, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:04.0, compute capability: 6.0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>gpsix0</td>\n",
" <td>device: 1, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:05.0, compute capability: 6.0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>gpsix0</td>\n",
" <td>device: 2, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:06.0, compute capability: 6.0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>gpsix0</td>\n",
" <td>device: 3, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:07.0, compute capability: 6.0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>gpsix1</td>\n",
" <td>device: 0, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:04.0, compute capability: 6.0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>gpsix1</td>\n",
" <td>device: 1, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:05.0, compute capability: 6.0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>gpsix1</td>\n",
" <td>device: 2, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:06.0, compute capability: 6.0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>gpsix1</td>\n",
" <td>device: 3, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:07.0, compute capability: 6.0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>gpsix2</td>\n",
" <td>device: 0, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:04.0, compute capability: 6.0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>gpsix2</td>\n",
" <td>device: 1, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:05.0, compute capability: 6.0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>gpsix2</td>\n",
" <td>device: 2, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:06.0, compute capability: 6.0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>gpsix2</td>\n",
" <td>device: 3, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:07.0, compute capability: 6.0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>gpsix3</td>\n",
" <td>device: 0, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:04.0, compute capability: 6.0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>gpsix3</td>\n",
" <td>device: 1, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:05.0, compute capability: 6.0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>gpsix3</td>\n",
" <td>device: 2, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:06.0, compute capability: 6.0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>gpsix3</td>\n",
" <td>device: 3, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:07.0, compute capability: 6.0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>gpsix4</td>\n",
" <td>device: 0, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:04.0, compute capability: 6.0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>gpsix4</td>\n",
" <td>device: 1, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:05.0, compute capability: 6.0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>gpsix4</td>\n",
" <td>device: 2, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:06.0, compute capability: 6.0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>gpsix4</td>\n",
" <td>device: 3, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:07.0, compute capability: 6.0</td>\n",
" </tr>\n",
"</table>"
],
"text/plain": [
"[(u'gpsix0', u'device: 0, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:04.0, compute capability: 6.0'),\n",
" (u'gpsix0', u'device: 1, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:05.0, compute capability: 6.0'),\n",
" (u'gpsix0', u'device: 2, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:06.0, compute capability: 6.0'),\n",
" (u'gpsix0', u'device: 3, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:07.0, compute capability: 6.0'),\n",
" (u'gpsix1', u'device: 0, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:04.0, compute capability: 6.0'),\n",
" (u'gpsix1', u'device: 1, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:05.0, compute capability: 6.0'),\n",
" (u'gpsix1', u'device: 2, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:06.0, compute capability: 6.0'),\n",
" (u'gpsix1', u'device: 3, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:07.0, compute capability: 6.0'),\n",
" (u'gpsix2', u'device: 0, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:04.0, compute capability: 6.0'),\n",
" (u'gpsix2', u'device: 1, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:05.0, compute capability: 6.0'),\n",
" (u'gpsix2', u'device: 2, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:06.0, compute capability: 6.0'),\n",
" (u'gpsix2', u'device: 3, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:07.0, compute capability: 6.0'),\n",
" (u'gpsix3', u'device: 0, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:04.0, compute capability: 6.0'),\n",
" (u'gpsix3', u'device: 1, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:05.0, compute capability: 6.0'),\n",
" (u'gpsix3', u'device: 2, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:06.0, compute capability: 6.0'),\n",
" (u'gpsix3', u'device: 3, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:07.0, compute capability: 6.0'),\n",
" (u'gpsix4', u'device: 0, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:04.0, compute capability: 6.0'),\n",
" (u'gpsix4', u'device: 1, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:05.0, compute capability: 6.0'),\n",
" (u'gpsix4', u'device: 2, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:06.0, compute capability: 6.0'),\n",
" (u'gpsix4', u'device: 3, name: Tesla P100-PCIE-16GB, pci bus id: 0000:00:07.0, compute capability: 6.0')]"
]
},
"execution_count": 8,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"%%sql\n",
"DROP TABLE IF EXISTS host_gpu_mapping_tf;\n",
"SELECT * FROM madlib.gpu_configuration('host_gpu_mapping_tf');\n",
"SELECT * FROM host_gpu_mapping_tf ORDER BY hostname, gpu_descr;"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Review the Greenplum segments in the `gp_segment_configuration` table:"
]
},
{
"cell_type": "code",
"execution_count": 9,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"21 rows affected.\n"
]
},
{
"data": {
"text/html": [
"<table>\n",
" <tr>\n",
" <th>dbid</th>\n",
" <th>content</th>\n",
" <th>role</th>\n",
" <th>preferred_role</th>\n",
" <th>mode</th>\n",
" <th>status</th>\n",
" <th>port</th>\n",
" <th>hostname</th>\n",
" <th>address</th>\n",
" <th>datadir</th>\n",
" </tr>\n",
" <tr>\n",
" <td>1</td>\n",
" <td>-1</td>\n",
" <td>p</td>\n",
" <td>p</td>\n",
" <td>n</td>\n",
" <td>u</td>\n",
" <td>5432</td>\n",
" <td>gpsix0</td>\n",
" <td>gpsix0</td>\n",
" <td>/data/master/gpseg-1</td>\n",
" </tr>\n",
" <tr>\n",
" <td>2</td>\n",
" <td>0</td>\n",
" <td>p</td>\n",
" <td>p</td>\n",
" <td>n</td>\n",
" <td>u</td>\n",
" <td>40000</td>\n",
" <td>gpsix0</td>\n",
" <td>gpsix0</td>\n",
" <td>/data/primary0/gpseg0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>3</td>\n",
" <td>1</td>\n",
" <td>p</td>\n",
" <td>p</td>\n",
" <td>n</td>\n",
" <td>u</td>\n",
" <td>40001</td>\n",
" <td>gpsix0</td>\n",
" <td>gpsix0</td>\n",
" <td>/data/primary1/gpseg1</td>\n",
" </tr>\n",
" <tr>\n",
" <td>4</td>\n",
" <td>2</td>\n",
" <td>p</td>\n",
" <td>p</td>\n",
" <td>n</td>\n",
" <td>u</td>\n",
" <td>40002</td>\n",
" <td>gpsix0</td>\n",
" <td>gpsix0</td>\n",
" <td>/data/primary2/gpseg2</td>\n",
" </tr>\n",
" <tr>\n",
" <td>5</td>\n",
" <td>3</td>\n",
" <td>p</td>\n",
" <td>p</td>\n",
" <td>n</td>\n",
" <td>u</td>\n",
" <td>40003</td>\n",
" <td>gpsix0</td>\n",
" <td>gpsix0</td>\n",
" <td>/data/primary3/gpseg3</td>\n",
" </tr>\n",
" <tr>\n",
" <td>6</td>\n",
" <td>4</td>\n",
" <td>p</td>\n",
" <td>p</td>\n",
" <td>n</td>\n",
" <td>u</td>\n",
" <td>40000</td>\n",
" <td>gpsix1</td>\n",
" <td>gpsix1</td>\n",
" <td>/data/primary0/gpseg4</td>\n",
" </tr>\n",
" <tr>\n",
" <td>7</td>\n",
" <td>5</td>\n",
" <td>p</td>\n",
" <td>p</td>\n",
" <td>n</td>\n",
" <td>u</td>\n",
" <td>40001</td>\n",
" <td>gpsix1</td>\n",
" <td>gpsix1</td>\n",
" <td>/data/primary1/gpseg5</td>\n",
" </tr>\n",
" <tr>\n",
" <td>8</td>\n",
" <td>6</td>\n",
" <td>p</td>\n",
" <td>p</td>\n",
" <td>n</td>\n",
" <td>u</td>\n",
" <td>40002</td>\n",
" <td>gpsix1</td>\n",
" <td>gpsix1</td>\n",
" <td>/data/primary2/gpseg6</td>\n",
" </tr>\n",
" <tr>\n",
" <td>9</td>\n",
" <td>7</td>\n",
" <td>p</td>\n",
" <td>p</td>\n",
" <td>n</td>\n",
" <td>u</td>\n",
" <td>40003</td>\n",
" <td>gpsix1</td>\n",
" <td>gpsix1</td>\n",
" <td>/data/primary3/gpseg7</td>\n",
" </tr>\n",
" <tr>\n",
" <td>10</td>\n",
" <td>8</td>\n",
" <td>p</td>\n",
" <td>p</td>\n",
" <td>n</td>\n",
" <td>u</td>\n",
" <td>40000</td>\n",
" <td>gpsix2</td>\n",
" <td>gpsix2</td>\n",
" <td>/data/primary0/gpseg8</td>\n",
" </tr>\n",
" <tr>\n",
" <td>11</td>\n",
" <td>9</td>\n",
" <td>p</td>\n",
" <td>p</td>\n",
" <td>n</td>\n",
" <td>u</td>\n",
" <td>40001</td>\n",
" <td>gpsix2</td>\n",
" <td>gpsix2</td>\n",
" <td>/data/primary1/gpseg9</td>\n",
" </tr>\n",
" <tr>\n",
" <td>12</td>\n",
" <td>10</td>\n",
" <td>p</td>\n",
" <td>p</td>\n",
" <td>n</td>\n",
" <td>u</td>\n",
" <td>40002</td>\n",
" <td>gpsix2</td>\n",
" <td>gpsix2</td>\n",
" <td>/data/primary2/gpseg10</td>\n",
" </tr>\n",
" <tr>\n",
" <td>13</td>\n",
" <td>11</td>\n",
" <td>p</td>\n",
" <td>p</td>\n",
" <td>n</td>\n",
" <td>u</td>\n",
" <td>40003</td>\n",
" <td>gpsix2</td>\n",
" <td>gpsix2</td>\n",
" <td>/data/primary3/gpseg11</td>\n",
" </tr>\n",
" <tr>\n",
" <td>14</td>\n",
" <td>12</td>\n",
" <td>p</td>\n",
" <td>p</td>\n",
" <td>n</td>\n",
" <td>u</td>\n",
" <td>40000</td>\n",
" <td>gpsix3</td>\n",
" <td>gpsix3</td>\n",
" <td>/data/primary0/gpseg12</td>\n",
" </tr>\n",
" <tr>\n",
" <td>15</td>\n",
" <td>13</td>\n",
" <td>p</td>\n",
" <td>p</td>\n",
" <td>n</td>\n",
" <td>u</td>\n",
" <td>40001</td>\n",
" <td>gpsix3</td>\n",
" <td>gpsix3</td>\n",
" <td>/data/primary1/gpseg13</td>\n",
" </tr>\n",
" <tr>\n",
" <td>16</td>\n",
" <td>14</td>\n",
" <td>p</td>\n",
" <td>p</td>\n",
" <td>n</td>\n",
" <td>u</td>\n",
" <td>40002</td>\n",
" <td>gpsix3</td>\n",
" <td>gpsix3</td>\n",
" <td>/data/primary2/gpseg14</td>\n",
" </tr>\n",
" <tr>\n",
" <td>17</td>\n",
" <td>15</td>\n",
" <td>p</td>\n",
" <td>p</td>\n",
" <td>n</td>\n",
" <td>u</td>\n",
" <td>40003</td>\n",
" <td>gpsix3</td>\n",
" <td>gpsix3</td>\n",
" <td>/data/primary3/gpseg15</td>\n",
" </tr>\n",
" <tr>\n",
" <td>18</td>\n",
" <td>16</td>\n",
" <td>p</td>\n",
" <td>p</td>\n",
" <td>n</td>\n",
" <td>u</td>\n",
" <td>40000</td>\n",
" <td>gpsix4</td>\n",
" <td>gpsix4</td>\n",
" <td>/data/primary0/gpseg16</td>\n",
" </tr>\n",
" <tr>\n",
" <td>19</td>\n",
" <td>17</td>\n",
" <td>p</td>\n",
" <td>p</td>\n",
" <td>n</td>\n",
" <td>u</td>\n",
" <td>40001</td>\n",
" <td>gpsix4</td>\n",
" <td>gpsix4</td>\n",
" <td>/data/primary1/gpseg17</td>\n",
" </tr>\n",
" <tr>\n",
" <td>20</td>\n",
" <td>18</td>\n",
" <td>p</td>\n",
" <td>p</td>\n",
" <td>n</td>\n",
" <td>u</td>\n",
" <td>40002</td>\n",
" <td>gpsix4</td>\n",
" <td>gpsix4</td>\n",
" <td>/data/primary2/gpseg18</td>\n",
" </tr>\n",
" <tr>\n",
" <td>21</td>\n",
" <td>19</td>\n",
" <td>p</td>\n",
" <td>p</td>\n",
" <td>n</td>\n",
" <td>u</td>\n",
" <td>40003</td>\n",
" <td>gpsix4</td>\n",
" <td>gpsix4</td>\n",
" <td>/data/primary3/gpseg19</td>\n",
" </tr>\n",
"</table>"
],
"text/plain": [
"[(1, -1, u'p', u'p', u'n', u'u', 5432, u'gpsix0', u'gpsix0', u'/data/master/gpseg-1'),\n",
" (2, 0, u'p', u'p', u'n', u'u', 40000, u'gpsix0', u'gpsix0', u'/data/primary0/gpseg0'),\n",
" (3, 1, u'p', u'p', u'n', u'u', 40001, u'gpsix0', u'gpsix0', u'/data/primary1/gpseg1'),\n",
" (4, 2, u'p', u'p', u'n', u'u', 40002, u'gpsix0', u'gpsix0', u'/data/primary2/gpseg2'),\n",
" (5, 3, u'p', u'p', u'n', u'u', 40003, u'gpsix0', u'gpsix0', u'/data/primary3/gpseg3'),\n",
" (6, 4, u'p', u'p', u'n', u'u', 40000, u'gpsix1', u'gpsix1', u'/data/primary0/gpseg4'),\n",
" (7, 5, u'p', u'p', u'n', u'u', 40001, u'gpsix1', u'gpsix1', u'/data/primary1/gpseg5'),\n",
" (8, 6, u'p', u'p', u'n', u'u', 40002, u'gpsix1', u'gpsix1', u'/data/primary2/gpseg6'),\n",
" (9, 7, u'p', u'p', u'n', u'u', 40003, u'gpsix1', u'gpsix1', u'/data/primary3/gpseg7'),\n",
" (10, 8, u'p', u'p', u'n', u'u', 40000, u'gpsix2', u'gpsix2', u'/data/primary0/gpseg8'),\n",
" (11, 9, u'p', u'p', u'n', u'u', 40001, u'gpsix2', u'gpsix2', u'/data/primary1/gpseg9'),\n",
" (12, 10, u'p', u'p', u'n', u'u', 40002, u'gpsix2', u'gpsix2', u'/data/primary2/gpseg10'),\n",
" (13, 11, u'p', u'p', u'n', u'u', 40003, u'gpsix2', u'gpsix2', u'/data/primary3/gpseg11'),\n",
" (14, 12, u'p', u'p', u'n', u'u', 40000, u'gpsix3', u'gpsix3', u'/data/primary0/gpseg12'),\n",
" (15, 13, u'p', u'p', u'n', u'u', 40001, u'gpsix3', u'gpsix3', u'/data/primary1/gpseg13'),\n",
" (16, 14, u'p', u'p', u'n', u'u', 40002, u'gpsix3', u'gpsix3', u'/data/primary2/gpseg14'),\n",
" (17, 15, u'p', u'p', u'n', u'u', 40003, u'gpsix3', u'gpsix3', u'/data/primary3/gpseg15'),\n",
" (18, 16, u'p', u'p', u'n', u'u', 40000, u'gpsix4', u'gpsix4', u'/data/primary0/gpseg16'),\n",
" (19, 17, u'p', u'p', u'n', u'u', 40001, u'gpsix4', u'gpsix4', u'/data/primary1/gpseg17'),\n",
" (20, 18, u'p', u'p', u'n', u'u', 40002, u'gpsix4', u'gpsix4', u'/data/primary2/gpseg18'),\n",
" (21, 19, u'p', u'p', u'n', u'u', 40003, u'gpsix4', u'gpsix4', u'/data/primary3/gpseg19')]"
]
},
"execution_count": 9,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"%%sql\n",
"SELECT * FROM gp_segment_configuration ORDER BY dbid;"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Now JOIN the above 2 tables to build up various distribution rules, depending on your needs.\n",
"\n",
"We build distribution rules table for 4 VMs:"
]
},
{
"cell_type": "code",
"execution_count": 10,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Done.\n",
"16 rows affected.\n",
"16 rows affected.\n"
]
},
{
"data": {
"text/html": [
"<table>\n",
" <tr>\n",
" <th>dbid</th>\n",
" <th>hostname</th>\n",
" </tr>\n",
" <tr>\n",
" <td>2</td>\n",
" <td>gpsix0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>3</td>\n",
" <td>gpsix0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>4</td>\n",
" <td>gpsix0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>5</td>\n",
" <td>gpsix0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>6</td>\n",
" <td>gpsix1</td>\n",
" </tr>\n",
" <tr>\n",
" <td>7</td>\n",
" <td>gpsix1</td>\n",
" </tr>\n",
" <tr>\n",
" <td>8</td>\n",
" <td>gpsix1</td>\n",
" </tr>\n",
" <tr>\n",
" <td>9</td>\n",
" <td>gpsix1</td>\n",
" </tr>\n",
" <tr>\n",
" <td>10</td>\n",
" <td>gpsix2</td>\n",
" </tr>\n",
" <tr>\n",
" <td>11</td>\n",
" <td>gpsix2</td>\n",
" </tr>\n",
" <tr>\n",
" <td>12</td>\n",
" <td>gpsix2</td>\n",
" </tr>\n",
" <tr>\n",
" <td>13</td>\n",
" <td>gpsix2</td>\n",
" </tr>\n",
" <tr>\n",
" <td>14</td>\n",
" <td>gpsix3</td>\n",
" </tr>\n",
" <tr>\n",
" <td>15</td>\n",
" <td>gpsix3</td>\n",
" </tr>\n",
" <tr>\n",
" <td>16</td>\n",
" <td>gpsix3</td>\n",
" </tr>\n",
" <tr>\n",
" <td>17</td>\n",
" <td>gpsix3</td>\n",
" </tr>\n",
"</table>"
],
"text/plain": [
"[(2, u'gpsix0'),\n",
" (3, u'gpsix0'),\n",
" (4, u'gpsix0'),\n",
" (5, u'gpsix0'),\n",
" (6, u'gpsix1'),\n",
" (7, u'gpsix1'),\n",
" (8, u'gpsix1'),\n",
" (9, u'gpsix1'),\n",
" (10, u'gpsix2'),\n",
" (11, u'gpsix2'),\n",
" (12, u'gpsix2'),\n",
" (13, u'gpsix2'),\n",
" (14, u'gpsix3'),\n",
" (15, u'gpsix3'),\n",
" (16, u'gpsix3'),\n",
" (17, u'gpsix3')]"
]
},
"execution_count": 10,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"%%sql\n",
"DROP TABLE IF EXISTS segments_to_use_4VMs;\n",
"CREATE TABLE segments_to_use_4VMs AS\n",
" SELECT DISTINCT dbid, hostname FROM gp_segment_configuration JOIN host_gpu_mapping_tf USING (hostname)\n",
" WHERE role='p' AND content>=0 AND hostname!='gpsix4';\n",
"SELECT * FROM segments_to_use_4VMs ORDER BY hostname, dbid;"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Run the preprocessor to generate the packed output table on the segments we want to use for training:"
]
},
{
"cell_type": "code",
"execution_count": 11,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Done.\n",
"1 rows affected.\n",
"16 rows affected.\n"
]
},
{
"data": {
"text/html": [
"<table>\n",
" <tr>\n",
" <th>__dist_key__</th>\n",
" <th>independent_var_shape</th>\n",
" <th>dependent_var_shape</th>\n",
" <th>buffer_id</th>\n",
" </tr>\n",
" <tr>\n",
" <td>0</td>\n",
" <td>[3125, 32, 32, 3]</td>\n",
" <td>[3125, 10]</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <td>1</td>\n",
" <td>[3125, 32, 32, 3]</td>\n",
" <td>[3125, 10]</td>\n",
" <td>4</td>\n",
" </tr>\n",
" <tr>\n",
" <td>2</td>\n",
" <td>[3125, 32, 32, 3]</td>\n",
" <td>[3125, 10]</td>\n",
" <td>9</td>\n",
" </tr>\n",
" <tr>\n",
" <td>3</td>\n",
" <td>[3125, 32, 32, 3]</td>\n",
" <td>[3125, 10]</td>\n",
" <td>7</td>\n",
" </tr>\n",
" <tr>\n",
" <td>4</td>\n",
" <td>[3125, 32, 32, 3]</td>\n",
" <td>[3125, 10]</td>\n",
" <td>14</td>\n",
" </tr>\n",
" <tr>\n",
" <td>7</td>\n",
" <td>[3125, 32, 32, 3]</td>\n",
" <td>[3125, 10]</td>\n",
" <td>11</td>\n",
" </tr>\n",
" <tr>\n",
" <td>9</td>\n",
" <td>[3125, 32, 32, 3]</td>\n",
" <td>[3125, 10]</td>\n",
" <td>13</td>\n",
" </tr>\n",
" <tr>\n",
" <td>12</td>\n",
" <td>[3125, 32, 32, 3]</td>\n",
" <td>[3125, 10]</td>\n",
" <td>15</td>\n",
" </tr>\n",
" <tr>\n",
" <td>14</td>\n",
" <td>[3125, 32, 32, 3]</td>\n",
" <td>[3125, 10]</td>\n",
" <td>6</td>\n",
" </tr>\n",
" <tr>\n",
" <td>19</td>\n",
" <td>[3125, 32, 32, 3]</td>\n",
" <td>[3125, 10]</td>\n",
" <td>12</td>\n",
" </tr>\n",
" <tr>\n",
" <td>27</td>\n",
" <td>[3125, 32, 32, 3]</td>\n",
" <td>[3125, 10]</td>\n",
" <td>10</td>\n",
" </tr>\n",
" <tr>\n",
" <td>28</td>\n",
" <td>[3125, 32, 32, 3]</td>\n",
" <td>[3125, 10]</td>\n",
" <td>5</td>\n",
" </tr>\n",
" <tr>\n",
" <td>29</td>\n",
" <td>[3125, 32, 32, 3]</td>\n",
" <td>[3125, 10]</td>\n",
" <td>8</td>\n",
" </tr>\n",
" <tr>\n",
" <td>34</td>\n",
" <td>[3125, 32, 32, 3]</td>\n",
" <td>[3125, 10]</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>55</td>\n",
" <td>[3125, 32, 32, 3]</td>\n",
" <td>[3125, 10]</td>\n",
" <td>3</td>\n",
" </tr>\n",
" <tr>\n",
" <td>56</td>\n",
" <td>[3125, 32, 32, 3]</td>\n",
" <td>[3125, 10]</td>\n",
" <td>2</td>\n",
" </tr>\n",
"</table>"
],
"text/plain": [
"[(0, [3125, 32, 32, 3], [3125, 10], 1),\n",
" (1, [3125, 32, 32, 3], [3125, 10], 4),\n",
" (2, [3125, 32, 32, 3], [3125, 10], 9),\n",
" (3, [3125, 32, 32, 3], [3125, 10], 7),\n",
" (4, [3125, 32, 32, 3], [3125, 10], 14),\n",
" (7, [3125, 32, 32, 3], [3125, 10], 11),\n",
" (9, [3125, 32, 32, 3], [3125, 10], 13),\n",
" (12, [3125, 32, 32, 3], [3125, 10], 15),\n",
" (14, [3125, 32, 32, 3], [3125, 10], 6),\n",
" (19, [3125, 32, 32, 3], [3125, 10], 12),\n",
" (27, [3125, 32, 32, 3], [3125, 10], 10),\n",
" (28, [3125, 32, 32, 3], [3125, 10], 5),\n",
" (29, [3125, 32, 32, 3], [3125, 10], 8),\n",
" (34, [3125, 32, 32, 3], [3125, 10], 0),\n",
" (55, [3125, 32, 32, 3], [3125, 10], 3),\n",
" (56, [3125, 32, 32, 3], [3125, 10], 2)]"
]
},
"execution_count": 11,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"%%sql\n",
"DROP TABLE IF EXISTS cifar10_train_packed, cifar10_train_packed_summary;\n",
"\n",
"SELECT madlib.training_preprocessor_dl('cifar10_train', -- Source table\n",
" 'cifar10_train_packed', -- Output table\n",
" 'y', -- Dependent variable\n",
" 'x', -- Independent variable\n",
" NULL, -- Buffer size\n",
" 256.0, -- Normalizing constant\n",
" NULL, -- Number of classes\n",
" 'segments_to_use_4VMs' -- Distribution rules\n",
" );\n",
"\n",
"SELECT __dist_key__, independent_var_shape, dependent_var_shape, buffer_id FROM cifar10_train_packed ORDER BY __dist_key__;"
]
},
{
"cell_type": "code",
"execution_count": 12,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"1 rows affected.\n"
]
},
{
"data": {
"text/html": [
"<table>\n",
" <tr>\n",
" <th>source_table</th>\n",
" <th>output_table</th>\n",
" <th>dependent_varname</th>\n",
" <th>independent_varname</th>\n",
" <th>dependent_vartype</th>\n",
" <th>class_values</th>\n",
" <th>buffer_size</th>\n",
" <th>normalizing_const</th>\n",
" <th>num_classes</th>\n",
" <th>distribution_rules</th>\n",
" <th>__internal_gpu_config__</th>\n",
" </tr>\n",
" <tr>\n",
" <td>cifar10_train</td>\n",
" <td>cifar10_train_packed</td>\n",
" <td>y</td>\n",
" <td>x</td>\n",
" <td>smallint</td>\n",
" <td>[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]</td>\n",
" <td>3125</td>\n",
" <td>256.0</td>\n",
" <td>10</td>\n",
" <td>[2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17]</td>\n",
" <td>[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15]</td>\n",
" </tr>\n",
"</table>"
],
"text/plain": [
"[(u'cifar10_train', u'cifar10_train_packed', u'y', u'x', u'smallint', [0, 1, 2, 3, 4, 5, 6, 7, 8, 9], 3125, 256.0, 10, [2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17], [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15])]"
]
},
"execution_count": 12,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"%%sql\n",
"SELECT * FROM cifar10_train_packed_summary;"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Same for validation dataset:"
]
},
{
"cell_type": "code",
"execution_count": 13,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Done.\n",
"1 rows affected.\n",
"16 rows affected.\n"
]
},
{
"data": {
"text/html": [
"<table>\n",
" <tr>\n",
" <th>__dist_key__</th>\n",
" <th>independent_var_shape</th>\n",
" <th>dependent_var_shape</th>\n",
" <th>buffer_id</th>\n",
" </tr>\n",
" <tr>\n",
" <td>0</td>\n",
" <td>[625, 32, 32, 3]</td>\n",
" <td>[625, 10]</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <td>1</td>\n",
" <td>[625, 32, 32, 3]</td>\n",
" <td>[625, 10]</td>\n",
" <td>4</td>\n",
" </tr>\n",
" <tr>\n",
" <td>2</td>\n",
" <td>[625, 32, 32, 3]</td>\n",
" <td>[625, 10]</td>\n",
" <td>9</td>\n",
" </tr>\n",
" <tr>\n",
" <td>3</td>\n",
" <td>[625, 32, 32, 3]</td>\n",
" <td>[625, 10]</td>\n",
" <td>7</td>\n",
" </tr>\n",
" <tr>\n",
" <td>4</td>\n",
" <td>[625, 32, 32, 3]</td>\n",
" <td>[625, 10]</td>\n",
" <td>14</td>\n",
" </tr>\n",
" <tr>\n",
" <td>7</td>\n",
" <td>[625, 32, 32, 3]</td>\n",
" <td>[625, 10]</td>\n",
" <td>11</td>\n",
" </tr>\n",
" <tr>\n",
" <td>9</td>\n",
" <td>[625, 32, 32, 3]</td>\n",
" <td>[625, 10]</td>\n",
" <td>13</td>\n",
" </tr>\n",
" <tr>\n",
" <td>12</td>\n",
" <td>[625, 32, 32, 3]</td>\n",
" <td>[625, 10]</td>\n",
" <td>15</td>\n",
" </tr>\n",
" <tr>\n",
" <td>14</td>\n",
" <td>[625, 32, 32, 3]</td>\n",
" <td>[625, 10]</td>\n",
" <td>6</td>\n",
" </tr>\n",
" <tr>\n",
" <td>19</td>\n",
" <td>[625, 32, 32, 3]</td>\n",
" <td>[625, 10]</td>\n",
" <td>12</td>\n",
" </tr>\n",
" <tr>\n",
" <td>27</td>\n",
" <td>[625, 32, 32, 3]</td>\n",
" <td>[625, 10]</td>\n",
" <td>10</td>\n",
" </tr>\n",
" <tr>\n",
" <td>28</td>\n",
" <td>[625, 32, 32, 3]</td>\n",
" <td>[625, 10]</td>\n",
" <td>5</td>\n",
" </tr>\n",
" <tr>\n",
" <td>29</td>\n",
" <td>[625, 32, 32, 3]</td>\n",
" <td>[625, 10]</td>\n",
" <td>8</td>\n",
" </tr>\n",
" <tr>\n",
" <td>34</td>\n",
" <td>[625, 32, 32, 3]</td>\n",
" <td>[625, 10]</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>55</td>\n",
" <td>[625, 32, 32, 3]</td>\n",
" <td>[625, 10]</td>\n",
" <td>3</td>\n",
" </tr>\n",
" <tr>\n",
" <td>56</td>\n",
" <td>[625, 32, 32, 3]</td>\n",
" <td>[625, 10]</td>\n",
" <td>2</td>\n",
" </tr>\n",
"</table>"
],
"text/plain": [
"[(0, [625, 32, 32, 3], [625, 10], 1),\n",
" (1, [625, 32, 32, 3], [625, 10], 4),\n",
" (2, [625, 32, 32, 3], [625, 10], 9),\n",
" (3, [625, 32, 32, 3], [625, 10], 7),\n",
" (4, [625, 32, 32, 3], [625, 10], 14),\n",
" (7, [625, 32, 32, 3], [625, 10], 11),\n",
" (9, [625, 32, 32, 3], [625, 10], 13),\n",
" (12, [625, 32, 32, 3], [625, 10], 15),\n",
" (14, [625, 32, 32, 3], [625, 10], 6),\n",
" (19, [625, 32, 32, 3], [625, 10], 12),\n",
" (27, [625, 32, 32, 3], [625, 10], 10),\n",
" (28, [625, 32, 32, 3], [625, 10], 5),\n",
" (29, [625, 32, 32, 3], [625, 10], 8),\n",
" (34, [625, 32, 32, 3], [625, 10], 0),\n",
" (55, [625, 32, 32, 3], [625, 10], 3),\n",
" (56, [625, 32, 32, 3], [625, 10], 2)]"
]
},
"execution_count": 13,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"%%sql\n",
"DROP TABLE IF EXISTS cifar10_val_packed, cifar10_val_packed_summary;\n",
"\n",
"SELECT madlib.validation_preprocessor_dl('cifar10_val', -- Source table\n",
" 'cifar10_val_packed', -- Output table\n",
" 'y', -- Dependent variable\n",
" 'x', -- Independent variable\n",
" 'cifar10_train_packed', -- From training preprocessor step\n",
" NULL, -- Buffer size\n",
" 'segments_to_use_4VMs' -- Distribution rules\n",
" ); \n",
"\n",
"SELECT __dist_key__, independent_var_shape, dependent_var_shape, buffer_id FROM cifar10_val_packed ORDER BY __dist_key__;"
]
},
{
"cell_type": "code",
"execution_count": 14,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"1 rows affected.\n"
]
},
{
"data": {
"text/html": [
"<table>\n",
" <tr>\n",
" <th>source_table</th>\n",
" <th>output_table</th>\n",
" <th>dependent_varname</th>\n",
" <th>independent_varname</th>\n",
" <th>dependent_vartype</th>\n",
" <th>class_values</th>\n",
" <th>buffer_size</th>\n",
" <th>normalizing_const</th>\n",
" <th>num_classes</th>\n",
" <th>distribution_rules</th>\n",
" <th>__internal_gpu_config__</th>\n",
" </tr>\n",
" <tr>\n",
" <td>cifar10_val</td>\n",
" <td>cifar10_val_packed</td>\n",
" <td>y</td>\n",
" <td>x</td>\n",
" <td>smallint</td>\n",
" <td>[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]</td>\n",
" <td>625</td>\n",
" <td>256.0</td>\n",
" <td>10</td>\n",
" <td>[2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17]</td>\n",
" <td>[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15]</td>\n",
" </tr>\n",
"</table>"
],
"text/plain": [
"[(u'cifar10_val', u'cifar10_val_packed', u'y', u'x', u'smallint', [0, 1, 2, 3, 4, 5, 6, 7, 8, 9], 625, 256.0, 10, [2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17], [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15])]"
]
},
"execution_count": 14,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"%%sql\n",
"SELECT * FROM cifar10_val_packed_summary;"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"<a id=\"arch\"></a>\n",
"# 3. Define and load model architectures\n",
"\n",
"Model architecture from https://keras.io/examples/cifar10_cnn/"
]
},
{
"cell_type": "code",
"execution_count": 15,
"metadata": {},
"outputs": [],
"source": [
"num_classes = 10"
]
},
{
"cell_type": "code",
"execution_count": 18,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"WARNING:tensorflow:From /Users/fmcquillan/Library/Python/2.7/lib/python/site-packages/keras/backend/tensorflow_backend.py:517: The name tf.placeholder is deprecated. Please use tf.compat.v1.placeholder instead.\n",
"\n",
"WARNING:tensorflow:From /Users/fmcquillan/Library/Python/2.7/lib/python/site-packages/keras/backend/tensorflow_backend.py:4138: The name tf.random_uniform is deprecated. Please use tf.random.uniform instead.\n",
"\n",
"WARNING:tensorflow:From /Users/fmcquillan/Library/Python/2.7/lib/python/site-packages/keras/backend/tensorflow_backend.py:3976: The name tf.nn.max_pool is deprecated. Please use tf.nn.max_pool2d instead.\n",
"\n",
"WARNING:tensorflow:From /Users/fmcquillan/Library/Python/2.7/lib/python/site-packages/keras/backend/tensorflow_backend.py:133: The name tf.placeholder_with_default is deprecated. Please use tf.compat.v1.placeholder_with_default instead.\n",
"\n",
"WARNING:tensorflow:From /Users/fmcquillan/Library/Python/2.7/lib/python/site-packages/keras/backend/tensorflow_backend.py:3445: calling dropout (from tensorflow.python.ops.nn_ops) with keep_prob is deprecated and will be removed in a future version.\n",
"Instructions for updating:\n",
"Please use `rate` instead of `keep_prob`. Rate should be set to `rate = 1 - keep_prob`.\n",
"_________________________________________________________________\n",
"Layer (type) Output Shape Param # \n",
"=================================================================\n",
"conv2d_1 (Conv2D) (None, 32, 32, 32) 896 \n",
"_________________________________________________________________\n",
"activation_1 (Activation) (None, 32, 32, 32) 0 \n",
"_________________________________________________________________\n",
"conv2d_2 (Conv2D) (None, 30, 30, 32) 9248 \n",
"_________________________________________________________________\n",
"activation_2 (Activation) (None, 30, 30, 32) 0 \n",
"_________________________________________________________________\n",
"max_pooling2d_1 (MaxPooling2 (None, 15, 15, 32) 0 \n",
"_________________________________________________________________\n",
"dropout_1 (Dropout) (None, 15, 15, 32) 0 \n",
"_________________________________________________________________\n",
"conv2d_3 (Conv2D) (None, 15, 15, 64) 18496 \n",
"_________________________________________________________________\n",
"activation_3 (Activation) (None, 15, 15, 64) 0 \n",
"_________________________________________________________________\n",
"conv2d_4 (Conv2D) (None, 13, 13, 64) 36928 \n",
"_________________________________________________________________\n",
"activation_4 (Activation) (None, 13, 13, 64) 0 \n",
"_________________________________________________________________\n",
"max_pooling2d_2 (MaxPooling2 (None, 6, 6, 64) 0 \n",
"_________________________________________________________________\n",
"dropout_2 (Dropout) (None, 6, 6, 64) 0 \n",
"_________________________________________________________________\n",
"flatten_1 (Flatten) (None, 2304) 0 \n",
"_________________________________________________________________\n",
"dense_1 (Dense) (None, 512) 1180160 \n",
"_________________________________________________________________\n",
"activation_5 (Activation) (None, 512) 0 \n",
"_________________________________________________________________\n",
"dropout_3 (Dropout) (None, 512) 0 \n",
"_________________________________________________________________\n",
"dense_2 (Dense) (None, 10) 5130 \n",
"_________________________________________________________________\n",
"activation_6 (Activation) (None, 10) 0 \n",
"=================================================================\n",
"Total params: 1,250,858\n",
"Trainable params: 1,250,858\n",
"Non-trainable params: 0\n",
"_________________________________________________________________\n"
]
}
],
"source": [
"model1 = Sequential()\n",
"\n",
"model1.add(Conv2D(32, (3, 3), padding='same',\n",
" input_shape=x_train.shape[1:]))\n",
"model1.add(Activation('relu'))\n",
"model1.add(Conv2D(32, (3, 3)))\n",
"model1.add(Activation('relu'))\n",
"model1.add(MaxPooling2D(pool_size=(2, 2)))\n",
"model1.add(Dropout(0.25))\n",
"\n",
"model1.add(Conv2D(64, (3, 3), padding='same'))\n",
"model1.add(Activation('relu'))\n",
"model1.add(Conv2D(64, (3, 3)))\n",
"model1.add(Activation('relu'))\n",
"model1.add(MaxPooling2D(pool_size=(2, 2)))\n",
"model1.add(Dropout(0.25))\n",
"\n",
"model1.add(Flatten())\n",
"model1.add(Dense(512))\n",
"model1.add(Activation('relu'))\n",
"model1.add(Dropout(0.5))\n",
"model1.add(Dense(num_classes))\n",
"model1.add(Activation('softmax'))\n",
"\n",
"model1.summary()"
]
},
{
"cell_type": "code",
"execution_count": 19,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"'{\"class_name\": \"Sequential\", \"keras_version\": \"2.2.4\", \"config\": {\"layers\": [{\"class_name\": \"Conv2D\", \"config\": {\"kernel_initializer\": {\"class_name\": \"VarianceScaling\", \"config\": {\"distribution\": \"uniform\", \"scale\": 1.0, \"seed\": null, \"mode\": \"fan_avg\"}}, \"name\": \"conv2d_1\", \"kernel_constraint\": null, \"bias_regularizer\": null, \"bias_constraint\": null, \"dtype\": \"float32\", \"activation\": \"linear\", \"trainable\": true, \"data_format\": \"channels_last\", \"filters\": 32, \"padding\": \"same\", \"strides\": [1, 1], \"dilation_rate\": [1, 1], \"kernel_regularizer\": null, \"bias_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"batch_input_shape\": [null, 32, 32, 3], \"use_bias\": true, \"activity_regularizer\": null, \"kernel_size\": [3, 3]}}, {\"class_name\": \"Activation\", \"config\": {\"activation\": \"relu\", \"trainable\": true, \"name\": \"activation_1\"}}, {\"class_name\": \"Conv2D\", \"config\": {\"kernel_constraint\": null, \"kernel_initializer\": {\"class_name\": \"VarianceScaling\", \"config\": {\"distribution\": \"uniform\", \"scale\": 1.0, \"seed\": null, \"mode\": \"fan_avg\"}}, \"name\": \"conv2d_2\", \"bias_regularizer\": null, \"bias_constraint\": null, \"activation\": \"linear\", \"trainable\": true, \"data_format\": \"channels_last\", \"padding\": \"valid\", \"strides\": [1, 1], \"dilation_rate\": [1, 1], \"kernel_regularizer\": null, \"filters\": 32, \"bias_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"use_bias\": true, \"activity_regularizer\": null, \"kernel_size\": [3, 3]}}, {\"class_name\": \"Activation\", \"config\": {\"activation\": \"relu\", \"trainable\": true, \"name\": \"activation_2\"}}, {\"class_name\": \"MaxPooling2D\", \"config\": {\"name\": \"max_pooling2d_1\", \"trainable\": true, \"data_format\": \"channels_last\", \"pool_size\": [2, 2], \"padding\": \"valid\", \"strides\": [2, 2]}}, {\"class_name\": \"Dropout\", \"config\": {\"rate\": 0.25, \"noise_shape\": null, \"trainable\": true, \"seed\": null, \"name\": \"dropout_1\"}}, {\"class_name\": \"Conv2D\", \"config\": {\"kernel_constraint\": null, \"kernel_initializer\": {\"class_name\": \"VarianceScaling\", \"config\": {\"distribution\": \"uniform\", \"scale\": 1.0, \"seed\": null, \"mode\": \"fan_avg\"}}, \"name\": \"conv2d_3\", \"bias_regularizer\": null, \"bias_constraint\": null, \"activation\": \"linear\", \"trainable\": true, \"data_format\": \"channels_last\", \"padding\": \"same\", \"strides\": [1, 1], \"dilation_rate\": [1, 1], \"kernel_regularizer\": null, \"filters\": 64, \"bias_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"use_bias\": true, \"activity_regularizer\": null, \"kernel_size\": [3, 3]}}, {\"class_name\": \"Activation\", \"config\": {\"activation\": \"relu\", \"trainable\": true, \"name\": \"activation_3\"}}, {\"class_name\": \"Conv2D\", \"config\": {\"kernel_constraint\": null, \"kernel_initializer\": {\"class_name\": \"VarianceScaling\", \"config\": {\"distribution\": \"uniform\", \"scale\": 1.0, \"seed\": null, \"mode\": \"fan_avg\"}}, \"name\": \"conv2d_4\", \"bias_regularizer\": null, \"bias_constraint\": null, \"activation\": \"linear\", \"trainable\": true, \"data_format\": \"channels_last\", \"padding\": \"valid\", \"strides\": [1, 1], \"dilation_rate\": [1, 1], \"kernel_regularizer\": null, \"filters\": 64, \"bias_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"use_bias\": true, \"activity_regularizer\": null, \"kernel_size\": [3, 3]}}, {\"class_name\": \"Activation\", \"config\": {\"activation\": \"relu\", \"trainable\": true, \"name\": \"activation_4\"}}, {\"class_name\": \"MaxPooling2D\", \"config\": {\"name\": \"max_pooling2d_2\", \"trainable\": true, \"data_format\": \"channels_last\", \"pool_size\": [2, 2], \"padding\": \"valid\", \"strides\": [2, 2]}}, {\"class_name\": \"Dropout\", \"config\": {\"rate\": 0.25, \"noise_shape\": null, \"trainable\": true, \"seed\": null, \"name\": \"dropout_2\"}}, {\"class_name\": \"Flatten\", \"config\": {\"trainable\": true, \"name\": \"flatten_1\", \"data_format\": \"channels_last\"}}, {\"class_name\": \"Dense\", \"config\": {\"kernel_initializer\": {\"class_name\": \"VarianceScaling\", \"config\": {\"distribution\": \"uniform\", \"scale\": 1.0, \"seed\": null, \"mode\": \"fan_avg\"}}, \"name\": \"dense_1\", \"kernel_constraint\": null, \"bias_regularizer\": null, \"bias_constraint\": null, \"activation\": \"linear\", \"trainable\": true, \"kernel_regularizer\": null, \"bias_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"units\": 512, \"use_bias\": true, \"activity_regularizer\": null}}, {\"class_name\": \"Activation\", \"config\": {\"activation\": \"relu\", \"trainable\": true, \"name\": \"activation_5\"}}, {\"class_name\": \"Dropout\", \"config\": {\"rate\": 0.5, \"noise_shape\": null, \"trainable\": true, \"seed\": null, \"name\": \"dropout_3\"}}, {\"class_name\": \"Dense\", \"config\": {\"kernel_initializer\": {\"class_name\": \"VarianceScaling\", \"config\": {\"distribution\": \"uniform\", \"scale\": 1.0, \"seed\": null, \"mode\": \"fan_avg\"}}, \"name\": \"dense_2\", \"kernel_constraint\": null, \"bias_regularizer\": null, \"bias_constraint\": null, \"activation\": \"linear\", \"trainable\": true, \"kernel_regularizer\": null, \"bias_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"units\": 10, \"use_bias\": true, \"activity_regularizer\": null}}, {\"class_name\": \"Activation\", \"config\": {\"activation\": \"softmax\", \"trainable\": true, \"name\": \"activation_6\"}}], \"name\": \"sequential_2\"}, \"backend\": \"tensorflow\"}'"
]
},
"execution_count": 19,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"model1.to_json()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Model architecture from https://machinelearningmastery.com/how-to-develop-a-cnn-from-scratch-for-cifar-10-photo-classification/"
]
},
{
"cell_type": "code",
"execution_count": 20,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"WARNING:tensorflow:From /Users/fmcquillan/Library/Python/2.7/lib/python/site-packages/keras/backend/tensorflow_backend.py:174: The name tf.get_default_session is deprecated. Please use tf.compat.v1.get_default_session instead.\n",
"\n",
"WARNING:tensorflow:From /Users/fmcquillan/Library/Python/2.7/lib/python/site-packages/keras/backend/tensorflow_backend.py:1834: The name tf.nn.fused_batch_norm is deprecated. Please use tf.compat.v1.nn.fused_batch_norm instead.\n",
"\n",
"_________________________________________________________________\n",
"Layer (type) Output Shape Param # \n",
"=================================================================\n",
"conv2d_5 (Conv2D) (None, 32, 32, 32) 896 \n",
"_________________________________________________________________\n",
"batch_normalization_1 (Batch (None, 32, 32, 32) 128 \n",
"_________________________________________________________________\n",
"conv2d_6 (Conv2D) (None, 32, 32, 32) 9248 \n",
"_________________________________________________________________\n",
"batch_normalization_2 (Batch (None, 32, 32, 32) 128 \n",
"_________________________________________________________________\n",
"max_pooling2d_3 (MaxPooling2 (None, 16, 16, 32) 0 \n",
"_________________________________________________________________\n",
"dropout_4 (Dropout) (None, 16, 16, 32) 0 \n",
"_________________________________________________________________\n",
"conv2d_7 (Conv2D) (None, 16, 16, 64) 18496 \n",
"_________________________________________________________________\n",
"batch_normalization_3 (Batch (None, 16, 16, 64) 256 \n",
"_________________________________________________________________\n",
"conv2d_8 (Conv2D) (None, 16, 16, 64) 36928 \n",
"_________________________________________________________________\n",
"batch_normalization_4 (Batch (None, 16, 16, 64) 256 \n",
"_________________________________________________________________\n",
"max_pooling2d_4 (MaxPooling2 (None, 8, 8, 64) 0 \n",
"_________________________________________________________________\n",
"dropout_5 (Dropout) (None, 8, 8, 64) 0 \n",
"_________________________________________________________________\n",
"conv2d_9 (Conv2D) (None, 8, 8, 128) 73856 \n",
"_________________________________________________________________\n",
"batch_normalization_5 (Batch (None, 8, 8, 128) 512 \n",
"_________________________________________________________________\n",
"conv2d_10 (Conv2D) (None, 8, 8, 128) 147584 \n",
"_________________________________________________________________\n",
"batch_normalization_6 (Batch (None, 8, 8, 128) 512 \n",
"_________________________________________________________________\n",
"max_pooling2d_5 (MaxPooling2 (None, 4, 4, 128) 0 \n",
"_________________________________________________________________\n",
"dropout_6 (Dropout) (None, 4, 4, 128) 0 \n",
"_________________________________________________________________\n",
"flatten_2 (Flatten) (None, 2048) 0 \n",
"_________________________________________________________________\n",
"dense_3 (Dense) (None, 128) 262272 \n",
"_________________________________________________________________\n",
"batch_normalization_7 (Batch (None, 128) 512 \n",
"_________________________________________________________________\n",
"dropout_7 (Dropout) (None, 128) 0 \n",
"_________________________________________________________________\n",
"dense_4 (Dense) (None, 10) 1290 \n",
"=================================================================\n",
"Total params: 552,874\n",
"Trainable params: 551,722\n",
"Non-trainable params: 1,152\n",
"_________________________________________________________________\n"
]
}
],
"source": [
"model2 = Sequential()\n",
"\n",
"model2.add(Conv2D(32, (3, 3), activation='relu', kernel_initializer='he_uniform', padding='same', input_shape=(32, 32, 3)))\n",
"model2.add(BatchNormalization())\n",
"model2.add(Conv2D(32, (3, 3), activation='relu', kernel_initializer='he_uniform', padding='same'))\n",
"model2.add(BatchNormalization())\n",
"model2.add(MaxPooling2D((2, 2)))\n",
"model2.add(Dropout(0.2))\n",
"model2.add(Conv2D(64, (3, 3), activation='relu', kernel_initializer='he_uniform', padding='same'))\n",
"model2.add(BatchNormalization())\n",
"model2.add(Conv2D(64, (3, 3), activation='relu', kernel_initializer='he_uniform', padding='same'))\n",
"model2.add(BatchNormalization())\n",
"model2.add(MaxPooling2D((2, 2)))\n",
"model2.add(Dropout(0.3))\n",
"model2.add(Conv2D(128, (3, 3), activation='relu', kernel_initializer='he_uniform', padding='same'))\n",
"model2.add(BatchNormalization())\n",
"model2.add(Conv2D(128, (3, 3), activation='relu', kernel_initializer='he_uniform', padding='same'))\n",
"model2.add(BatchNormalization())\n",
"model2.add(MaxPooling2D((2, 2)))\n",
"model2.add(Dropout(0.4))\n",
"model2.add(Flatten())\n",
"model2.add(Dense(128, activation='relu', kernel_initializer='he_uniform'))\n",
"model2.add(BatchNormalization())\n",
"model2.add(Dropout(0.5))\n",
"model2.add(Dense(10, activation='softmax'))\n",
"\n",
"model2.summary()"
]
},
{
"cell_type": "code",
"execution_count": 21,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"'{\"class_name\": \"Sequential\", \"keras_version\": \"2.2.4\", \"config\": {\"layers\": [{\"class_name\": \"Conv2D\", \"config\": {\"kernel_initializer\": {\"class_name\": \"VarianceScaling\", \"config\": {\"distribution\": \"uniform\", \"scale\": 2.0, \"seed\": null, \"mode\": \"fan_in\"}}, \"name\": \"conv2d_5\", \"kernel_constraint\": null, \"bias_regularizer\": null, \"bias_constraint\": null, \"dtype\": \"float32\", \"activation\": \"relu\", \"trainable\": true, \"data_format\": \"channels_last\", \"filters\": 32, \"padding\": \"same\", \"strides\": [1, 1], \"dilation_rate\": [1, 1], \"kernel_regularizer\": null, \"bias_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"batch_input_shape\": [null, 32, 32, 3], \"use_bias\": true, \"activity_regularizer\": null, \"kernel_size\": [3, 3]}}, {\"class_name\": \"BatchNormalization\", \"config\": {\"beta_constraint\": null, \"gamma_initializer\": {\"class_name\": \"Ones\", \"config\": {}}, \"moving_mean_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"name\": \"batch_normalization_1\", \"epsilon\": 0.001, \"trainable\": true, \"moving_variance_initializer\": {\"class_name\": \"Ones\", \"config\": {}}, \"beta_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"scale\": true, \"axis\": -1, \"gamma_constraint\": null, \"gamma_regularizer\": null, \"beta_regularizer\": null, \"momentum\": 0.99, \"center\": true}}, {\"class_name\": \"Conv2D\", \"config\": {\"kernel_constraint\": null, \"kernel_initializer\": {\"class_name\": \"VarianceScaling\", \"config\": {\"distribution\": \"uniform\", \"scale\": 2.0, \"seed\": null, \"mode\": \"fan_in\"}}, \"name\": \"conv2d_6\", \"bias_regularizer\": null, \"bias_constraint\": null, \"activation\": \"relu\", \"trainable\": true, \"data_format\": \"channels_last\", \"padding\": \"same\", \"strides\": [1, 1], \"dilation_rate\": [1, 1], \"kernel_regularizer\": null, \"filters\": 32, \"bias_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"use_bias\": true, \"activity_regularizer\": null, \"kernel_size\": [3, 3]}}, {\"class_name\": \"BatchNormalization\", \"config\": {\"beta_constraint\": null, \"gamma_initializer\": {\"class_name\": \"Ones\", \"config\": {}}, \"moving_mean_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"name\": \"batch_normalization_2\", \"epsilon\": 0.001, \"trainable\": true, \"moving_variance_initializer\": {\"class_name\": \"Ones\", \"config\": {}}, \"beta_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"scale\": true, \"axis\": -1, \"gamma_constraint\": null, \"gamma_regularizer\": null, \"beta_regularizer\": null, \"momentum\": 0.99, \"center\": true}}, {\"class_name\": \"MaxPooling2D\", \"config\": {\"name\": \"max_pooling2d_3\", \"trainable\": true, \"data_format\": \"channels_last\", \"pool_size\": [2, 2], \"padding\": \"valid\", \"strides\": [2, 2]}}, {\"class_name\": \"Dropout\", \"config\": {\"rate\": 0.2, \"noise_shape\": null, \"trainable\": true, \"seed\": null, \"name\": \"dropout_4\"}}, {\"class_name\": \"Conv2D\", \"config\": {\"kernel_constraint\": null, \"kernel_initializer\": {\"class_name\": \"VarianceScaling\", \"config\": {\"distribution\": \"uniform\", \"scale\": 2.0, \"seed\": null, \"mode\": \"fan_in\"}}, \"name\": \"conv2d_7\", \"bias_regularizer\": null, \"bias_constraint\": null, \"activation\": \"relu\", \"trainable\": true, \"data_format\": \"channels_last\", \"padding\": \"same\", \"strides\": [1, 1], \"dilation_rate\": [1, 1], \"kernel_regularizer\": null, \"filters\": 64, \"bias_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"use_bias\": true, \"activity_regularizer\": null, \"kernel_size\": [3, 3]}}, {\"class_name\": \"BatchNormalization\", \"config\": {\"beta_constraint\": null, \"gamma_initializer\": {\"class_name\": \"Ones\", \"config\": {}}, \"moving_mean_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"name\": \"batch_normalization_3\", \"epsilon\": 0.001, \"trainable\": true, \"moving_variance_initializer\": {\"class_name\": \"Ones\", \"config\": {}}, \"beta_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"scale\": true, \"axis\": -1, \"gamma_constraint\": null, \"gamma_regularizer\": null, \"beta_regularizer\": null, \"momentum\": 0.99, \"center\": true}}, {\"class_name\": \"Conv2D\", \"config\": {\"kernel_constraint\": null, \"kernel_initializer\": {\"class_name\": \"VarianceScaling\", \"config\": {\"distribution\": \"uniform\", \"scale\": 2.0, \"seed\": null, \"mode\": \"fan_in\"}}, \"name\": \"conv2d_8\", \"bias_regularizer\": null, \"bias_constraint\": null, \"activation\": \"relu\", \"trainable\": true, \"data_format\": \"channels_last\", \"padding\": \"same\", \"strides\": [1, 1], \"dilation_rate\": [1, 1], \"kernel_regularizer\": null, \"filters\": 64, \"bias_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"use_bias\": true, \"activity_regularizer\": null, \"kernel_size\": [3, 3]}}, {\"class_name\": \"BatchNormalization\", \"config\": {\"beta_constraint\": null, \"gamma_initializer\": {\"class_name\": \"Ones\", \"config\": {}}, \"moving_mean_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"name\": \"batch_normalization_4\", \"epsilon\": 0.001, \"trainable\": true, \"moving_variance_initializer\": {\"class_name\": \"Ones\", \"config\": {}}, \"beta_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"scale\": true, \"axis\": -1, \"gamma_constraint\": null, \"gamma_regularizer\": null, \"beta_regularizer\": null, \"momentum\": 0.99, \"center\": true}}, {\"class_name\": \"MaxPooling2D\", \"config\": {\"name\": \"max_pooling2d_4\", \"trainable\": true, \"data_format\": \"channels_last\", \"pool_size\": [2, 2], \"padding\": \"valid\", \"strides\": [2, 2]}}, {\"class_name\": \"Dropout\", \"config\": {\"rate\": 0.3, \"noise_shape\": null, \"trainable\": true, \"seed\": null, \"name\": \"dropout_5\"}}, {\"class_name\": \"Conv2D\", \"config\": {\"kernel_constraint\": null, \"kernel_initializer\": {\"class_name\": \"VarianceScaling\", \"config\": {\"distribution\": \"uniform\", \"scale\": 2.0, \"seed\": null, \"mode\": \"fan_in\"}}, \"name\": \"conv2d_9\", \"bias_regularizer\": null, \"bias_constraint\": null, \"activation\": \"relu\", \"trainable\": true, \"data_format\": \"channels_last\", \"padding\": \"same\", \"strides\": [1, 1], \"dilation_rate\": [1, 1], \"kernel_regularizer\": null, \"filters\": 128, \"bias_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"use_bias\": true, \"activity_regularizer\": null, \"kernel_size\": [3, 3]}}, {\"class_name\": \"BatchNormalization\", \"config\": {\"beta_constraint\": null, \"gamma_initializer\": {\"class_name\": \"Ones\", \"config\": {}}, \"moving_mean_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"name\": \"batch_normalization_5\", \"epsilon\": 0.001, \"trainable\": true, \"moving_variance_initializer\": {\"class_name\": \"Ones\", \"config\": {}}, \"beta_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"scale\": true, \"axis\": -1, \"gamma_constraint\": null, \"gamma_regularizer\": null, \"beta_regularizer\": null, \"momentum\": 0.99, \"center\": true}}, {\"class_name\": \"Conv2D\", \"config\": {\"kernel_constraint\": null, \"kernel_initializer\": {\"class_name\": \"VarianceScaling\", \"config\": {\"distribution\": \"uniform\", \"scale\": 2.0, \"seed\": null, \"mode\": \"fan_in\"}}, \"name\": \"conv2d_10\", \"bias_regularizer\": null, \"bias_constraint\": null, \"activation\": \"relu\", \"trainable\": true, \"data_format\": \"channels_last\", \"padding\": \"same\", \"strides\": [1, 1], \"dilation_rate\": [1, 1], \"kernel_regularizer\": null, \"filters\": 128, \"bias_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"use_bias\": true, \"activity_regularizer\": null, \"kernel_size\": [3, 3]}}, {\"class_name\": \"BatchNormalization\", \"config\": {\"beta_constraint\": null, \"gamma_initializer\": {\"class_name\": \"Ones\", \"config\": {}}, \"moving_mean_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"name\": \"batch_normalization_6\", \"epsilon\": 0.001, \"trainable\": true, \"moving_variance_initializer\": {\"class_name\": \"Ones\", \"config\": {}}, \"beta_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"scale\": true, \"axis\": -1, \"gamma_constraint\": null, \"gamma_regularizer\": null, \"beta_regularizer\": null, \"momentum\": 0.99, \"center\": true}}, {\"class_name\": \"MaxPooling2D\", \"config\": {\"name\": \"max_pooling2d_5\", \"trainable\": true, \"data_format\": \"channels_last\", \"pool_size\": [2, 2], \"padding\": \"valid\", \"strides\": [2, 2]}}, {\"class_name\": \"Dropout\", \"config\": {\"rate\": 0.4, \"noise_shape\": null, \"trainable\": true, \"seed\": null, \"name\": \"dropout_6\"}}, {\"class_name\": \"Flatten\", \"config\": {\"trainable\": true, \"name\": \"flatten_2\", \"data_format\": \"channels_last\"}}, {\"class_name\": \"Dense\", \"config\": {\"kernel_initializer\": {\"class_name\": \"VarianceScaling\", \"config\": {\"distribution\": \"uniform\", \"scale\": 2.0, \"seed\": null, \"mode\": \"fan_in\"}}, \"name\": \"dense_3\", \"kernel_constraint\": null, \"bias_regularizer\": null, \"bias_constraint\": null, \"activation\": \"relu\", \"trainable\": true, \"kernel_regularizer\": null, \"bias_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"units\": 128, \"use_bias\": true, \"activity_regularizer\": null}}, {\"class_name\": \"BatchNormalization\", \"config\": {\"beta_constraint\": null, \"gamma_initializer\": {\"class_name\": \"Ones\", \"config\": {}}, \"moving_mean_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"name\": \"batch_normalization_7\", \"epsilon\": 0.001, \"trainable\": true, \"moving_variance_initializer\": {\"class_name\": \"Ones\", \"config\": {}}, \"beta_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"scale\": true, \"axis\": -1, \"gamma_constraint\": null, \"gamma_regularizer\": null, \"beta_regularizer\": null, \"momentum\": 0.99, \"center\": true}}, {\"class_name\": \"Dropout\", \"config\": {\"rate\": 0.5, \"noise_shape\": null, \"trainable\": true, \"seed\": null, \"name\": \"dropout_7\"}}, {\"class_name\": \"Dense\", \"config\": {\"kernel_initializer\": {\"class_name\": \"VarianceScaling\", \"config\": {\"distribution\": \"uniform\", \"scale\": 1.0, \"seed\": null, \"mode\": \"fan_avg\"}}, \"name\": \"dense_4\", \"kernel_constraint\": null, \"bias_regularizer\": null, \"bias_constraint\": null, \"activation\": \"softmax\", \"trainable\": true, \"kernel_regularizer\": null, \"bias_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"units\": 10, \"use_bias\": true, \"activity_regularizer\": null}}], \"name\": \"sequential_3\"}, \"backend\": \"tensorflow\"}'"
]
},
"execution_count": 21,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"model2.to_json()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Another model architecture from https://machinelearningmastery.com/how-to-develop-a-cnn-from-scratch-for-cifar-10-photo-classification/"
]
},
{
"cell_type": "code",
"execution_count": 22,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"_________________________________________________________________\n",
"Layer (type) Output Shape Param # \n",
"=================================================================\n",
"conv2d_11 (Conv2D) (None, 32, 32, 32) 896 \n",
"_________________________________________________________________\n",
"conv2d_12 (Conv2D) (None, 32, 32, 32) 9248 \n",
"_________________________________________________________________\n",
"max_pooling2d_6 (MaxPooling2 (None, 16, 16, 32) 0 \n",
"_________________________________________________________________\n",
"dropout_8 (Dropout) (None, 16, 16, 32) 0 \n",
"_________________________________________________________________\n",
"conv2d_13 (Conv2D) (None, 16, 16, 64) 18496 \n",
"_________________________________________________________________\n",
"conv2d_14 (Conv2D) (None, 16, 16, 64) 36928 \n",
"_________________________________________________________________\n",
"max_pooling2d_7 (MaxPooling2 (None, 8, 8, 64) 0 \n",
"_________________________________________________________________\n",
"dropout_9 (Dropout) (None, 8, 8, 64) 0 \n",
"_________________________________________________________________\n",
"conv2d_15 (Conv2D) (None, 8, 8, 128) 73856 \n",
"_________________________________________________________________\n",
"conv2d_16 (Conv2D) (None, 8, 8, 128) 147584 \n",
"_________________________________________________________________\n",
"max_pooling2d_8 (MaxPooling2 (None, 4, 4, 128) 0 \n",
"_________________________________________________________________\n",
"dropout_10 (Dropout) (None, 4, 4, 128) 0 \n",
"_________________________________________________________________\n",
"flatten_3 (Flatten) (None, 2048) 0 \n",
"_________________________________________________________________\n",
"dense_5 (Dense) (None, 128) 262272 \n",
"_________________________________________________________________\n",
"dropout_11 (Dropout) (None, 128) 0 \n",
"_________________________________________________________________\n",
"dense_6 (Dense) (None, 10) 1290 \n",
"=================================================================\n",
"Total params: 550,570\n",
"Trainable params: 550,570\n",
"Non-trainable params: 0\n",
"_________________________________________________________________\n"
]
}
],
"source": [
"model3 = Sequential()\n",
"\n",
"model3.add(Conv2D(32, (3, 3), activation='relu', kernel_initializer='he_uniform', padding='same', input_shape=(32, 32, 3)))\n",
"model3.add(Conv2D(32, (3, 3), activation='relu', kernel_initializer='he_uniform', padding='same'))\n",
"model3.add(MaxPooling2D((2, 2)))\n",
"model3.add(Dropout(0.2))\n",
"model3.add(Conv2D(64, (3, 3), activation='relu', kernel_initializer='he_uniform', padding='same'))\n",
"model3.add(Conv2D(64, (3, 3), activation='relu', kernel_initializer='he_uniform', padding='same'))\n",
"model3.add(MaxPooling2D((2, 2)))\n",
"model3.add(Dropout(0.3))\n",
"model3.add(Conv2D(128, (3, 3), activation='relu', kernel_initializer='he_uniform', padding='same'))\n",
"model3.add(Conv2D(128, (3, 3), activation='relu', kernel_initializer='he_uniform', padding='same'))\n",
"model3.add(MaxPooling2D((2, 2)))\n",
"model3.add(Dropout(0.4))\n",
"model3.add(Flatten())\n",
"model3.add(Dense(128, activation='relu', kernel_initializer='he_uniform'))\n",
"model3.add(Dropout(0.5))\n",
"model3.add(Dense(10, activation='softmax'))\n",
"\n",
"model3.summary()"
]
},
{
"cell_type": "code",
"execution_count": 23,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"'{\"class_name\": \"Sequential\", \"keras_version\": \"2.2.4\", \"config\": {\"layers\": [{\"class_name\": \"Conv2D\", \"config\": {\"kernel_initializer\": {\"class_name\": \"VarianceScaling\", \"config\": {\"distribution\": \"uniform\", \"scale\": 2.0, \"seed\": null, \"mode\": \"fan_in\"}}, \"name\": \"conv2d_11\", \"kernel_constraint\": null, \"bias_regularizer\": null, \"bias_constraint\": null, \"dtype\": \"float32\", \"activation\": \"relu\", \"trainable\": true, \"data_format\": \"channels_last\", \"filters\": 32, \"padding\": \"same\", \"strides\": [1, 1], \"dilation_rate\": [1, 1], \"kernel_regularizer\": null, \"bias_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"batch_input_shape\": [null, 32, 32, 3], \"use_bias\": true, \"activity_regularizer\": null, \"kernel_size\": [3, 3]}}, {\"class_name\": \"Conv2D\", \"config\": {\"kernel_constraint\": null, \"kernel_initializer\": {\"class_name\": \"VarianceScaling\", \"config\": {\"distribution\": \"uniform\", \"scale\": 2.0, \"seed\": null, \"mode\": \"fan_in\"}}, \"name\": \"conv2d_12\", \"bias_regularizer\": null, \"bias_constraint\": null, \"activation\": \"relu\", \"trainable\": true, \"data_format\": \"channels_last\", \"padding\": \"same\", \"strides\": [1, 1], \"dilation_rate\": [1, 1], \"kernel_regularizer\": null, \"filters\": 32, \"bias_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"use_bias\": true, \"activity_regularizer\": null, \"kernel_size\": [3, 3]}}, {\"class_name\": \"MaxPooling2D\", \"config\": {\"name\": \"max_pooling2d_6\", \"trainable\": true, \"data_format\": \"channels_last\", \"pool_size\": [2, 2], \"padding\": \"valid\", \"strides\": [2, 2]}}, {\"class_name\": \"Dropout\", \"config\": {\"rate\": 0.2, \"noise_shape\": null, \"trainable\": true, \"seed\": null, \"name\": \"dropout_8\"}}, {\"class_name\": \"Conv2D\", \"config\": {\"kernel_constraint\": null, \"kernel_initializer\": {\"class_name\": \"VarianceScaling\", \"config\": {\"distribution\": \"uniform\", \"scale\": 2.0, \"seed\": null, \"mode\": \"fan_in\"}}, \"name\": \"conv2d_13\", \"bias_regularizer\": null, \"bias_constraint\": null, \"activation\": \"relu\", \"trainable\": true, \"data_format\": \"channels_last\", \"padding\": \"same\", \"strides\": [1, 1], \"dilation_rate\": [1, 1], \"kernel_regularizer\": null, \"filters\": 64, \"bias_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"use_bias\": true, \"activity_regularizer\": null, \"kernel_size\": [3, 3]}}, {\"class_name\": \"Conv2D\", \"config\": {\"kernel_constraint\": null, \"kernel_initializer\": {\"class_name\": \"VarianceScaling\", \"config\": {\"distribution\": \"uniform\", \"scale\": 2.0, \"seed\": null, \"mode\": \"fan_in\"}}, \"name\": \"conv2d_14\", \"bias_regularizer\": null, \"bias_constraint\": null, \"activation\": \"relu\", \"trainable\": true, \"data_format\": \"channels_last\", \"padding\": \"same\", \"strides\": [1, 1], \"dilation_rate\": [1, 1], \"kernel_regularizer\": null, \"filters\": 64, \"bias_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"use_bias\": true, \"activity_regularizer\": null, \"kernel_size\": [3, 3]}}, {\"class_name\": \"MaxPooling2D\", \"config\": {\"name\": \"max_pooling2d_7\", \"trainable\": true, \"data_format\": \"channels_last\", \"pool_size\": [2, 2], \"padding\": \"valid\", \"strides\": [2, 2]}}, {\"class_name\": \"Dropout\", \"config\": {\"rate\": 0.3, \"noise_shape\": null, \"trainable\": true, \"seed\": null, \"name\": \"dropout_9\"}}, {\"class_name\": \"Conv2D\", \"config\": {\"kernel_constraint\": null, \"kernel_initializer\": {\"class_name\": \"VarianceScaling\", \"config\": {\"distribution\": \"uniform\", \"scale\": 2.0, \"seed\": null, \"mode\": \"fan_in\"}}, \"name\": \"conv2d_15\", \"bias_regularizer\": null, \"bias_constraint\": null, \"activation\": \"relu\", \"trainable\": true, \"data_format\": \"channels_last\", \"padding\": \"same\", \"strides\": [1, 1], \"dilation_rate\": [1, 1], \"kernel_regularizer\": null, \"filters\": 128, \"bias_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"use_bias\": true, \"activity_regularizer\": null, \"kernel_size\": [3, 3]}}, {\"class_name\": \"Conv2D\", \"config\": {\"kernel_constraint\": null, \"kernel_initializer\": {\"class_name\": \"VarianceScaling\", \"config\": {\"distribution\": \"uniform\", \"scale\": 2.0, \"seed\": null, \"mode\": \"fan_in\"}}, \"name\": \"conv2d_16\", \"bias_regularizer\": null, \"bias_constraint\": null, \"activation\": \"relu\", \"trainable\": true, \"data_format\": \"channels_last\", \"padding\": \"same\", \"strides\": [1, 1], \"dilation_rate\": [1, 1], \"kernel_regularizer\": null, \"filters\": 128, \"bias_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"use_bias\": true, \"activity_regularizer\": null, \"kernel_size\": [3, 3]}}, {\"class_name\": \"MaxPooling2D\", \"config\": {\"name\": \"max_pooling2d_8\", \"trainable\": true, \"data_format\": \"channels_last\", \"pool_size\": [2, 2], \"padding\": \"valid\", \"strides\": [2, 2]}}, {\"class_name\": \"Dropout\", \"config\": {\"rate\": 0.4, \"noise_shape\": null, \"trainable\": true, \"seed\": null, \"name\": \"dropout_10\"}}, {\"class_name\": \"Flatten\", \"config\": {\"trainable\": true, \"name\": \"flatten_3\", \"data_format\": \"channels_last\"}}, {\"class_name\": \"Dense\", \"config\": {\"kernel_initializer\": {\"class_name\": \"VarianceScaling\", \"config\": {\"distribution\": \"uniform\", \"scale\": 2.0, \"seed\": null, \"mode\": \"fan_in\"}}, \"name\": \"dense_5\", \"kernel_constraint\": null, \"bias_regularizer\": null, \"bias_constraint\": null, \"activation\": \"relu\", \"trainable\": true, \"kernel_regularizer\": null, \"bias_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"units\": 128, \"use_bias\": true, \"activity_regularizer\": null}}, {\"class_name\": \"Dropout\", \"config\": {\"rate\": 0.5, \"noise_shape\": null, \"trainable\": true, \"seed\": null, \"name\": \"dropout_11\"}}, {\"class_name\": \"Dense\", \"config\": {\"kernel_initializer\": {\"class_name\": \"VarianceScaling\", \"config\": {\"distribution\": \"uniform\", \"scale\": 1.0, \"seed\": null, \"mode\": \"fan_avg\"}}, \"name\": \"dense_6\", \"kernel_constraint\": null, \"bias_regularizer\": null, \"bias_constraint\": null, \"activation\": \"softmax\", \"trainable\": true, \"kernel_regularizer\": null, \"bias_initializer\": {\"class_name\": \"Zeros\", \"config\": {}}, \"units\": 10, \"use_bias\": true, \"activity_regularizer\": null}}], \"name\": \"sequential_4\"}, \"backend\": \"tensorflow\"}'"
]
},
"execution_count": 23,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"model3.to_json()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Load into model architecture table using psycopg2"
]
},
{
"cell_type": "code",
"execution_count": 24,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Done.\n"
]
},
{
"data": {
"text/plain": [
"[]"
]
},
"execution_count": 24,
"metadata": {},
"output_type": "execute_result"
},
{
"name": "stdout",
"output_type": "stream",
"text": [
"3 rows affected.\n"
]
},
{
"data": {
"text/html": [
"<table>\n",
" <tr>\n",
" <th>model_id</th>\n",
" <th>name</th>\n",
" </tr>\n",
" <tr>\n",
" <td>1</td>\n",
" <td>CNN from Keras docs for CIFAR-10</td>\n",
" </tr>\n",
" <tr>\n",
" <td>2</td>\n",
" <td>CNN from Jason Brownlee blog post</td>\n",
" </tr>\n",
" <tr>\n",
" <td>3</td>\n",
" <td>CNN from Jason Brownlee blog post - no batch normalization</td>\n",
" </tr>\n",
"</table>"
],
"text/plain": [
"[(1, u'CNN from Keras docs for CIFAR-10'),\n",
" (2, u'CNN from Jason Brownlee blog post'),\n",
" (3, u'CNN from Jason Brownlee blog post - no batch normalization')]"
]
},
"execution_count": 24,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"import psycopg2 as p2\n",
"#conn = p2.connect('postgresql://gpadmin@35.239.240.26:5432/madlib')\n",
"#conn = p2.connect('postgresql://fmcquillan@localhost:5432/madlib')\n",
"conn = p2.connect('postgresql://gpadmin@localhost:8000/cifar_places')\n",
"cur = conn.cursor()\n",
"\n",
"%sql DROP TABLE IF EXISTS model_arch_library;\n",
"query = \"SELECT madlib.load_keras_model('model_arch_library', %s, NULL, %s)\"\n",
"cur.execute(query,[model1.to_json(), \"CNN from Keras docs for CIFAR-10\"])\n",
"conn.commit()\n",
"\n",
"query = \"SELECT madlib.load_keras_model('model_arch_library', %s, NULL, %s)\"\n",
"cur.execute(query,[model2.to_json(), \"CNN from Jason Brownlee blog post\"])\n",
"conn.commit()\n",
"\n",
"query = \"SELECT madlib.load_keras_model('model_arch_library', %s, NULL, %s)\"\n",
"cur.execute(query,[model3.to_json(), \"CNN from Jason Brownlee blog post - no batch normalization\"])\n",
"conn.commit()\n",
"\n",
"# check model loaded OK\n",
"%sql SELECT model_id, name FROM model_arch_library ORDER BY model_id;"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"<a id=\"mst\"></a>\n",
"# 4. Define and load model selection tuples"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Select the model(s) from the model architecture table that you want to run, along with the compile and fit parameters. Permutations for grid search will be created for the set of model selection parameters will be loaded:"
]
},
{
"cell_type": "code",
"execution_count": 25,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Done.\n",
"1 rows affected.\n",
"16 rows affected.\n"
]
},
{
"data": {
"text/html": [
"<table>\n",
" <tr>\n",
" <th>mst_key</th>\n",
" <th>model_id</th>\n",
" <th>compile_params</th>\n",
" <th>fit_params</th>\n",
" </tr>\n",
" <tr>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>loss='categorical_crossentropy',optimizer='adam(lr=0.0001)',metrics=['accuracy']</td>\n",
" <td>batch_size=64,epochs=5</td>\n",
" </tr>\n",
" <tr>\n",
" <td>2</td>\n",
" <td>1</td>\n",
" <td>loss='categorical_crossentropy',optimizer='adam(lr=0.0001)',metrics=['accuracy']</td>\n",
" <td>batch_size=128,epochs=5</td>\n",
" </tr>\n",
" <tr>\n",
" <td>3</td>\n",
" <td>1</td>\n",
" <td>loss='categorical_crossentropy',optimizer='rmsprop(lr=0.0001, decay=1e-6)',metrics=['accuracy']</td>\n",
" <td>batch_size=64,epochs=5</td>\n",
" </tr>\n",
" <tr>\n",
" <td>4</td>\n",
" <td>1</td>\n",
" <td>loss='categorical_crossentropy',optimizer='rmsprop(lr=0.0001, decay=1e-6)',metrics=['accuracy']</td>\n",
" <td>batch_size=128,epochs=5</td>\n",
" </tr>\n",
" <tr>\n",
" <td>5</td>\n",
" <td>1</td>\n",
" <td>loss='categorical_crossentropy',optimizer='rmsprop(lr=0.001, decay=1e-6)',metrics=['accuracy']</td>\n",
" <td>batch_size=64,epochs=5</td>\n",
" </tr>\n",
" <tr>\n",
" <td>6</td>\n",
" <td>1</td>\n",
" <td>loss='categorical_crossentropy',optimizer='rmsprop(lr=0.001, decay=1e-6)',metrics=['accuracy']</td>\n",
" <td>batch_size=128,epochs=5</td>\n",
" </tr>\n",
" <tr>\n",
" <td>7</td>\n",
" <td>1</td>\n",
" <td>loss='categorical_crossentropy',optimizer='adam(lr=0.001)',metrics=['accuracy']</td>\n",
" <td>batch_size=64,epochs=5</td>\n",
" </tr>\n",
" <tr>\n",
" <td>8</td>\n",
" <td>1</td>\n",
" <td>loss='categorical_crossentropy',optimizer='adam(lr=0.001)',metrics=['accuracy']</td>\n",
" <td>batch_size=128,epochs=5</td>\n",
" </tr>\n",
" <tr>\n",
" <td>9</td>\n",
" <td>2</td>\n",
" <td>loss='categorical_crossentropy',optimizer='adam(lr=0.0001)',metrics=['accuracy']</td>\n",
" <td>batch_size=64,epochs=5</td>\n",
" </tr>\n",
" <tr>\n",
" <td>10</td>\n",
" <td>2</td>\n",
" <td>loss='categorical_crossentropy',optimizer='adam(lr=0.0001)',metrics=['accuracy']</td>\n",
" <td>batch_size=128,epochs=5</td>\n",
" </tr>\n",
" <tr>\n",
" <td>11</td>\n",
" <td>2</td>\n",
" <td>loss='categorical_crossentropy',optimizer='rmsprop(lr=0.0001, decay=1e-6)',metrics=['accuracy']</td>\n",
" <td>batch_size=64,epochs=5</td>\n",
" </tr>\n",
" <tr>\n",
" <td>12</td>\n",
" <td>2</td>\n",
" <td>loss='categorical_crossentropy',optimizer='rmsprop(lr=0.0001, decay=1e-6)',metrics=['accuracy']</td>\n",
" <td>batch_size=128,epochs=5</td>\n",
" </tr>\n",
" <tr>\n",
" <td>13</td>\n",
" <td>2</td>\n",
" <td>loss='categorical_crossentropy',optimizer='rmsprop(lr=0.001, decay=1e-6)',metrics=['accuracy']</td>\n",
" <td>batch_size=64,epochs=5</td>\n",
" </tr>\n",
" <tr>\n",
" <td>14</td>\n",
" <td>2</td>\n",
" <td>loss='categorical_crossentropy',optimizer='rmsprop(lr=0.001, decay=1e-6)',metrics=['accuracy']</td>\n",
" <td>batch_size=128,epochs=5</td>\n",
" </tr>\n",
" <tr>\n",
" <td>15</td>\n",
" <td>2</td>\n",
" <td>loss='categorical_crossentropy',optimizer='adam(lr=0.001)',metrics=['accuracy']</td>\n",
" <td>batch_size=64,epochs=5</td>\n",
" </tr>\n",
" <tr>\n",
" <td>16</td>\n",
" <td>2</td>\n",
" <td>loss='categorical_crossentropy',optimizer='adam(lr=0.001)',metrics=['accuracy']</td>\n",
" <td>batch_size=128,epochs=5</td>\n",
" </tr>\n",
"</table>"
],
"text/plain": [
"[(1, 1, u\"loss='categorical_crossentropy',optimizer='adam(lr=0.0001)',metrics=['accuracy']\", u'batch_size=64,epochs=5'),\n",
" (2, 1, u\"loss='categorical_crossentropy',optimizer='adam(lr=0.0001)',metrics=['accuracy']\", u'batch_size=128,epochs=5'),\n",
" (3, 1, u\"loss='categorical_crossentropy',optimizer='rmsprop(lr=0.0001, decay=1e-6)',metrics=['accuracy']\", u'batch_size=64,epochs=5'),\n",
" (4, 1, u\"loss='categorical_crossentropy',optimizer='rmsprop(lr=0.0001, decay=1e-6)',metrics=['accuracy']\", u'batch_size=128,epochs=5'),\n",
" (5, 1, u\"loss='categorical_crossentropy',optimizer='rmsprop(lr=0.001, decay=1e-6)',metrics=['accuracy']\", u'batch_size=64,epochs=5'),\n",
" (6, 1, u\"loss='categorical_crossentropy',optimizer='rmsprop(lr=0.001, decay=1e-6)',metrics=['accuracy']\", u'batch_size=128,epochs=5'),\n",
" (7, 1, u\"loss='categorical_crossentropy',optimizer='adam(lr=0.001)',metrics=['accuracy']\", u'batch_size=64,epochs=5'),\n",
" (8, 1, u\"loss='categorical_crossentropy',optimizer='adam(lr=0.001)',metrics=['accuracy']\", u'batch_size=128,epochs=5'),\n",
" (9, 2, u\"loss='categorical_crossentropy',optimizer='adam(lr=0.0001)',metrics=['accuracy']\", u'batch_size=64,epochs=5'),\n",
" (10, 2, u\"loss='categorical_crossentropy',optimizer='adam(lr=0.0001)',metrics=['accuracy']\", u'batch_size=128,epochs=5'),\n",
" (11, 2, u\"loss='categorical_crossentropy',optimizer='rmsprop(lr=0.0001, decay=1e-6)',metrics=['accuracy']\", u'batch_size=64,epochs=5'),\n",
" (12, 2, u\"loss='categorical_crossentropy',optimizer='rmsprop(lr=0.0001, decay=1e-6)',metrics=['accuracy']\", u'batch_size=128,epochs=5'),\n",
" (13, 2, u\"loss='categorical_crossentropy',optimizer='rmsprop(lr=0.001, decay=1e-6)',metrics=['accuracy']\", u'batch_size=64,epochs=5'),\n",
" (14, 2, u\"loss='categorical_crossentropy',optimizer='rmsprop(lr=0.001, decay=1e-6)',metrics=['accuracy']\", u'batch_size=128,epochs=5'),\n",
" (15, 2, u\"loss='categorical_crossentropy',optimizer='adam(lr=0.001)',metrics=['accuracy']\", u'batch_size=64,epochs=5'),\n",
" (16, 2, u\"loss='categorical_crossentropy',optimizer='adam(lr=0.001)',metrics=['accuracy']\", u'batch_size=128,epochs=5')]"
]
},
"execution_count": 25,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"%%sql\n",
"DROP TABLE IF EXISTS mst_table, mst_table_summary;\n",
"\n",
"SELECT madlib.load_model_selection_table('model_arch_library', -- model architecture table\n",
" 'mst_table', -- model selection table output\n",
" ARRAY[1,2], -- model ids from model architecture table\n",
" ARRAY[ -- compile params \n",
" $$loss='categorical_crossentropy',optimizer='rmsprop(lr=0.0001, decay=1e-6)',metrics=['accuracy']$$,\n",
" $$loss='categorical_crossentropy',optimizer='rmsprop(lr=0.001, decay=1e-6)',metrics=['accuracy']$$,\n",
" $$loss='categorical_crossentropy',optimizer='adam(lr=0.0001)',metrics=['accuracy']$$,\n",
" $$loss='categorical_crossentropy',optimizer='adam(lr=0.001)',metrics=['accuracy']$$\n",
" ],\n",
" ARRAY[ -- fit params\n",
" $$batch_size=64,epochs=5$$, \n",
" $$batch_size=128,epochs=5$$\n",
" ]\n",
" );\n",
" \n",
"SELECT * FROM mst_table ORDER BY mst_key;"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"This is the name of the model architecture table that corresponds to the model selection table:"
]
},
{
"cell_type": "code",
"execution_count": 26,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"1 rows affected.\n"
]
},
{
"data": {
"text/html": [
"<table>\n",
" <tr>\n",
" <th>model_arch_table</th>\n",
" </tr>\n",
" <tr>\n",
" <td>model_arch_library</td>\n",
" </tr>\n",
"</table>"
],
"text/plain": [
"[(u'model_arch_library',)]"
]
},
"execution_count": 26,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"%%sql\n",
"SELECT * FROM mst_table_summary;"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"<a id=\"train\"></a>\n",
"# 5. Train\n",
"Train multiple models:"
]
},
{
"cell_type": "code",
"execution_count": 6,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Done.\n",
"1 rows affected.\n"
]
},
{
"data": {
"text/html": [
"<table>\n",
" <tr>\n",
" <th>madlib_keras_fit_multiple_model</th>\n",
" </tr>\n",
" <tr>\n",
" <td></td>\n",
" </tr>\n",
"</table>"
],
"text/plain": [
"[('',)]"
]
},
"execution_count": 6,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"%%sql\n",
"DROP TABLE IF EXISTS cifar10_multi_model, cifar10_multi_model_summary, cifar10_multi_model_info;\n",
"\n",
"SELECT madlib.madlib_keras_fit_multiple_model('cifar10_train_packed', -- source_table\n",
" 'cifar10_multi_model', -- model_output_table\n",
" 'mst_table', -- model_selection_table\n",
" 10, -- num_iterations\n",
" TRUE, -- use gpus\n",
" 'cifar10_val_packed', -- validation dataset\n",
" 1 -- metrics compute frequency\n",
" );"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"View the model summary:"
]
},
{
"cell_type": "code",
"execution_count": 27,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"1 rows affected.\n"
]
},
{
"data": {
"text/html": [
"<table>\n",
" <tr>\n",
" <th>source_table</th>\n",
" <th>validation_table</th>\n",
" <th>model</th>\n",
" <th>model_info</th>\n",
" <th>dependent_varname</th>\n",
" <th>independent_varname</th>\n",
" <th>model_arch_table</th>\n",
" <th>num_iterations</th>\n",
" <th>metrics_compute_frequency</th>\n",
" <th>warm_start</th>\n",
" <th>name</th>\n",
" <th>description</th>\n",
" <th>start_training_time</th>\n",
" <th>end_training_time</th>\n",
" <th>madlib_version</th>\n",
" <th>num_classes</th>\n",
" <th>class_values</th>\n",
" <th>dependent_vartype</th>\n",
" <th>normalizing_const</th>\n",
" <th>metrics_iters</th>\n",
" </tr>\n",
" <tr>\n",
" <td>cifar10_train_packed</td>\n",
" <td>cifar10_val_packed</td>\n",
" <td>cifar10_multi_model</td>\n",
" <td>cifar10_multi_model_info</td>\n",
" <td>y</td>\n",
" <td>x</td>\n",
" <td>model_arch_library</td>\n",
" <td>10</td>\n",
" <td>1</td>\n",
" <td>False</td>\n",
" <td>None</td>\n",
" <td>None</td>\n",
" <td>2020-03-24 22:19:52.670763</td>\n",
" <td>2020-03-24 22:48:08.984136</td>\n",
" <td>1.17-dev</td>\n",
" <td>10</td>\n",
" <td>[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]</td>\n",
" <td>smallint</td>\n",
" <td>256.0</td>\n",
" <td>[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]</td>\n",
" </tr>\n",
"</table>"
],
"text/plain": [
"[(u'cifar10_train_packed', u'cifar10_val_packed', u'cifar10_multi_model', u'cifar10_multi_model_info', u'y', u'x', u'model_arch_library', 10, 1, False, None, None, datetime.datetime(2020, 3, 24, 22, 19, 52, 670763), datetime.datetime(2020, 3, 24, 22, 48, 8, 984136), u'1.17-dev', 10, [0, 1, 2, 3, 4, 5, 6, 7, 8, 9], u'smallint', 256.0, [1, 2, 3, 4, 5, 6, 7, 8, 9, 10])]"
]
},
"execution_count": 27,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"%%sql\n",
"SELECT * FROM cifar10_multi_model_summary;"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"View performance of each model:"
]
},
{
"cell_type": "code",
"execution_count": 28,
"metadata": {
"scrolled": true
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"16 rows affected.\n"
]
},
{
"data": {
"text/html": [
"<table>\n",
" <tr>\n",
" <th>mst_key</th>\n",
" <th>model_id</th>\n",
" <th>compile_params</th>\n",
" <th>fit_params</th>\n",
" <th>model_type</th>\n",
" <th>model_size</th>\n",
" <th>metrics_elapsed_time</th>\n",
" <th>metrics_type</th>\n",
" <th>training_metrics_final</th>\n",
" <th>training_loss_final</th>\n",
" <th>training_metrics</th>\n",
" <th>training_loss</th>\n",
" <th>validation_metrics_final</th>\n",
" <th>validation_loss_final</th>\n",
" <th>validation_metrics</th>\n",
" <th>validation_loss</th>\n",
" </tr>\n",
" <tr>\n",
" <td>16</td>\n",
" <td>2</td>\n",
" <td>loss='categorical_crossentropy',optimizer='adam(lr=0.001)',metrics=['accuracy']</td>\n",
" <td>batch_size=128,epochs=5</td>\n",
" <td>madlib_keras</td>\n",
" <td>2159.70019531</td>\n",
" <td>[167.736330986023, 333.425091981888, 500.695713996887, 668.302587985992, 837.287312984467, 1006.06942605972, 1176.67615294456, 1346.787348032, 1518.12181210518, 1690.67020988464]</td>\n",
" <td>[u'accuracy']</td>\n",
" <td>0.957840025425</td>\n",
" <td>0.121589891613</td>\n",
" <td>[0.769860029220581, 0.824000000953674, 0.873139977455139, 0.89300000667572, 0.895640015602112, 0.906700015068054, 0.931919991970062, 0.942839980125427, 0.940620005130768, 0.957840025424957]</td>\n",
" <td>[0.66564804315567, 0.511175155639648, 0.367111206054688, 0.307224303483963, 0.300335615873337, 0.268611431121826, 0.196494549512863, 0.165175542235374, 0.172968357801437, 0.12158989161253]</td>\n",
" <td>0.836000025272</td>\n",
" <td>0.582142531872</td>\n",
" <td>[0.742699980735779, 0.790499985218048, 0.808600008487701, 0.818700015544891, 0.822000026702881, 0.821699976921082, 0.831499993801117, 0.83569997549057, 0.83050000667572, 0.836000025272369]</td>\n",
" <td>[0.731135308742523, 0.629253566265106, 0.586650609970093, 0.561055064201355, 0.600637912750244, 0.576708614826202, 0.567015171051025, 0.560995817184448, 0.577787160873413, 0.582142531871796]</td>\n",
" </tr>\n",
" <tr>\n",
" <td>14</td>\n",
" <td>2</td>\n",
" <td>loss='categorical_crossentropy',optimizer='rmsprop(lr=0.001, decay=1e-6)',metrics=['accuracy']</td>\n",
" <td>batch_size=128,epochs=5</td>\n",
" <td>madlib_keras</td>\n",
" <td>2159.70019531</td>\n",
" <td>[161.545518875122, 327.271953105927, 493.721956014633, 662.059704065323, 830.583410024643, 999.47811293602, 1170.08322310448, 1339.875207901, 1511.35515999794, 1682.88088107109]</td>\n",
" <td>[u'accuracy']</td>\n",
" <td>0.942120015621</td>\n",
" <td>0.166348025203</td>\n",
" <td>[0.768679976463318, 0.83459997177124, 0.865559995174408, 0.88782000541687, 0.900080025196075, 0.898840010166168, 0.929400026798248, 0.926339983940125, 0.941559970378876, 0.942120015621185]</td>\n",
" <td>[0.659707903862, 0.479000419378281, 0.394761860370636, 0.320042163133621, 0.286971271038055, 0.289592266082764, 0.203219100832939, 0.216255784034729, 0.16890250146389, 0.166348025202751]</td>\n",
" <td>0.834399998188</td>\n",
" <td>0.587312161922</td>\n",
" <td>[0.751600027084351, 0.794099986553192, 0.81029999256134, 0.816500008106232, 0.825600028038025, 0.819199979305267, 0.825200021266937, 0.833199977874756, 0.840300023555756, 0.834399998188019]</td>\n",
" <td>[0.725527286529541, 0.628955543041229, 0.603530406951904, 0.578122794628143, 0.565659284591675, 0.587804615497589, 0.575832903385162, 0.586635053157806, 0.558215022087097, 0.587312161922455]</td>\n",
" </tr>\n",
" <tr>\n",
" <td>15</td>\n",
" <td>2</td>\n",
" <td>loss='categorical_crossentropy',optimizer='adam(lr=0.001)',metrics=['accuracy']</td>\n",
" <td>batch_size=64,epochs=5</td>\n",
" <td>madlib_keras</td>\n",
" <td>2159.70019531</td>\n",
" <td>[159.585074901581, 325.616278886795, 492.079638957977, 660.141077041626, 828.460551977158, 997.682931900024, 1168.2648499012, 1338.03905391693, 1509.35755109787, 1680.94471693039]</td>\n",
" <td>[u'accuracy']</td>\n",
" <td>0.957620024681</td>\n",
" <td>0.123506456614</td>\n",
" <td>[0.780160009860992, 0.830079972743988, 0.864920020103455, 0.880159974098206, 0.907660007476807, 0.922760009765625, 0.930760025978088, 0.94489997625351, 0.953960001468658, 0.957620024681091]</td>\n",
" <td>[0.640457689762115, 0.484953910112381, 0.392606198787689, 0.350569307804108, 0.266773730516434, 0.223709508776665, 0.199900239706039, 0.160074487328529, 0.134055703878403, 0.123506456613541]</td>\n",
" <td>0.833199977875</td>\n",
" <td>0.585961103439</td>\n",
" <td>[0.747500002384186, 0.790600001811981, 0.805899977684021, 0.807099997997284, 0.818899989128113, 0.814999997615814, 0.821300029754639, 0.827600002288818, 0.830999970436096, 0.833199977874756]</td>\n",
" <td>[0.733774244785309, 0.621092319488525, 0.600942432880402, 0.603525757789612, 0.582037806510925, 0.593123733997345, 0.593485474586487, 0.585796058177948, 0.578036189079285, 0.585961103439331]</td>\n",
" </tr>\n",
" <tr>\n",
" <td>13</td>\n",
" <td>2</td>\n",
" <td>loss='categorical_crossentropy',optimizer='rmsprop(lr=0.001, decay=1e-6)',metrics=['accuracy']</td>\n",
" <td>batch_size=64,epochs=5</td>\n",
" <td>madlib_keras</td>\n",
" <td>2159.70019531</td>\n",
" <td>[164.595175027847, 330.364078044891, 497.435774087906, 665.216387033463, 833.770098924637, 1002.83351397514, 1173.14754009247, 1343.40405297279, 1514.43769907951, 1686.70381498337]</td>\n",
" <td>[u'accuracy']</td>\n",
" <td>0.950980007648</td>\n",
" <td>0.143490716815</td>\n",
" <td>[0.78983998298645, 0.840439975261688, 0.875959992408752, 0.891099989414215, 0.90090000629425, 0.919920027256012, 0.934400022029877, 0.938539981842041, 0.955479979515076, 0.950980007648468]</td>\n",
" <td>[0.613083124160767, 0.471387982368469, 0.363269150257111, 0.319806933403015, 0.286749541759491, 0.234226956963539, 0.19084843993187, 0.177600309252739, 0.131557434797287, 0.143490716814995]</td>\n",
" <td>0.821799993515</td>\n",
" <td>0.595590293407</td>\n",
" <td>[0.754000008106232, 0.79229998588562, 0.801699995994568, 0.812300026416779, 0.819000005722046, 0.819000005722046, 0.823300004005432, 0.829999983310699, 0.836300015449524, 0.821799993515015]</td>\n",
" <td>[0.721113681793213, 0.621586740016937, 0.596519410610199, 0.595609545707703, 0.600475549697876, 0.613331437110901, 0.595634639263153, 0.574845016002655, 0.569734573364258, 0.59559029340744]</td>\n",
" </tr>\n",
" <tr>\n",
" <td>9</td>\n",
" <td>2</td>\n",
" <td>loss='categorical_crossentropy',optimizer='adam(lr=0.0001)',metrics=['accuracy']</td>\n",
" <td>batch_size=64,epochs=5</td>\n",
" <td>madlib_keras</td>\n",
" <td>2159.70019531</td>\n",
" <td>[155.881345033646, 321.711883068085, 488.33388209343, 656.33606004715, 824.596586942673, 993.720223903656, 1164.30447506905, 1334.05466103554, 1505.45432305336, 1677.10981488228]</td>\n",
" <td>[u'accuracy']</td>\n",
" <td>0.897319972515</td>\n",
" <td>0.302623033524</td>\n",
" <td>[0.585739970207214, 0.694540023803711, 0.738439977169037, 0.788339972496033, 0.815580010414124, 0.834140002727509, 0.851960003376007, 0.870700001716614, 0.883599996566772, 0.897319972515106]</td>\n",
" <td>[1.1557844877243, 0.861163735389709, 0.741564929485321, 0.606875598430634, 0.530352532863617, 0.474545627832413, 0.425946325063705, 0.374209344387054, 0.336798161268234, 0.30262303352356]</td>\n",
" <td>0.815199971199</td>\n",
" <td>0.553332149982</td>\n",
" <td>[0.588599979877472, 0.692600011825562, 0.732900023460388, 0.767099976539612, 0.781899988651276, 0.791299998760223, 0.802100002765656, 0.805999994277954, 0.810199975967407, 0.815199971199036]</td>\n",
" <td>[1.1479709148407, 0.871322154998779, 0.77245706319809, 0.673963844776154, 0.631623148918152, 0.608054459095001, 0.585181176662445, 0.569720149040222, 0.558107197284698, 0.553332149982452]</td>\n",
" </tr>\n",
" <tr>\n",
" <td>11</td>\n",
" <td>2</td>\n",
" <td>loss='categorical_crossentropy',optimizer='rmsprop(lr=0.0001, decay=1e-6)',metrics=['accuracy']</td>\n",
" <td>batch_size=64,epochs=5</td>\n",
" <td>madlib_keras</td>\n",
" <td>2159.70019531</td>\n",
" <td>[172.771174907684, 338.155246973038, 505.790575027466, 673.744323015213, 842.298762083054, 1011.25688695908, 1182.03339600563, 1352.39258003235, 1523.84475708008, 1696.31324291229]</td>\n",
" <td>[u'accuracy']</td>\n",
" <td>0.889580011368</td>\n",
" <td>0.317797064781</td>\n",
" <td>[0.610719978809357, 0.702679991722107, 0.758080005645752, 0.787779986858368, 0.820479989051819, 0.840399980545044, 0.858399987220764, 0.869899988174438, 0.879320025444031, 0.889580011367798]</td>\n",
" <td>[1.1027592420578, 0.840861320495605, 0.687958598136902, 0.603124439716339, 0.51472145318985, 0.460182726383209, 0.407543867826462, 0.375441372394562, 0.346606284379959, 0.317797064781189]</td>\n",
" <td>0.812399983406</td>\n",
" <td>0.564498662949</td>\n",
" <td>[0.608399987220764, 0.697700023651123, 0.739300012588501, 0.758899986743927, 0.782599985599518, 0.793600022792816, 0.799199998378754, 0.806599974632263, 0.810599982738495, 0.812399983406067]</td>\n",
" <td>[1.10815918445587, 0.86056125164032, 0.739441454410553, 0.684951841831207, 0.629340946674347, 0.604862153530121, 0.582197725772858, 0.574008762836456, 0.559266090393066, 0.564498662948608]</td>\n",
" </tr>\n",
" <tr>\n",
" <td>10</td>\n",
" <td>2</td>\n",
" <td>loss='categorical_crossentropy',optimizer='adam(lr=0.0001)',metrics=['accuracy']</td>\n",
" <td>batch_size=128,epochs=5</td>\n",
" <td>madlib_keras</td>\n",
" <td>2159.70019531</td>\n",
" <td>[157.675038099289, 323.760583877563, 489.999938964844, 658.165150880814, 826.338515996933, 995.962205886841, 1166.19140601158, 1335.88773202896, 1507.49120998383, 1679.03732204437]</td>\n",
" <td>[u'accuracy']</td>\n",
" <td>0.865880012512</td>\n",
" <td>0.386452704668</td>\n",
" <td>[0.554459989070892, 0.660399973392487, 0.71670001745224, 0.754540026187897, 0.78276002407074, 0.806519985198975, 0.81879997253418, 0.83898001909256, 0.850740015506744, 0.865880012512207]</td>\n",
" <td>[1.26610136032104, 0.961102485656738, 0.805769920349121, 0.702959299087524, 0.625120878219604, 0.556592226028442, 0.513025283813477, 0.460623860359192, 0.426946371793747, 0.386452704668045]</td>\n",
" <td>0.806100010872</td>\n",
" <td>0.569638252258</td>\n",
" <td>[0.552999973297119, 0.657100021839142, 0.711000025272369, 0.737600028514862, 0.758300006389618, 0.77700001001358, 0.783100008964539, 0.794099986553192, 0.801199972629547, 0.806100010871887]</td>\n",
" <td>[1.26569390296936, 0.972574234008789, 0.835387766361237, 0.750236749649048, 0.694831550121307, 0.648999333381653, 0.622370600700378, 0.599871814250946, 0.581832528114319, 0.569638252258301]</td>\n",
" </tr>\n",
" <tr>\n",
" <td>12</td>\n",
" <td>2</td>\n",
" <td>loss='categorical_crossentropy',optimizer='rmsprop(lr=0.0001, decay=1e-6)',metrics=['accuracy']</td>\n",
" <td>batch_size=128,epochs=5</td>\n",
" <td>madlib_keras</td>\n",
" <td>2159.70019531</td>\n",
" <td>[171.145457983017, 336.337003946304, 504.029928922653, 671.705837965012, 840.568361997604, 1009.40254306793, 1179.99340295792, 1350.53466200829, 1521.91818499565, 1694.26437997818]</td>\n",
" <td>[u'accuracy']</td>\n",
" <td>0.868319988251</td>\n",
" <td>0.377308398485</td>\n",
" <td>[0.549000024795532, 0.662000000476837, 0.71262001991272, 0.75543999671936, 0.783819973468781, 0.801800012588501, 0.819119989871979, 0.837419986724854, 0.854939997196198, 0.868319988250732]</td>\n",
" <td>[1.28990209102631, 0.96648907661438, 0.814616560935974, 0.696749150753021, 0.613618135452271, 0.56260073184967, 0.512484431266785, 0.460049092769623, 0.412180662155151, 0.377308398485184]</td>\n",
" <td>0.803799986839</td>\n",
" <td>0.570892989635</td>\n",
" <td>[0.548399984836578, 0.653999984264374, 0.700100004673004, 0.735899984836578, 0.758899986743927, 0.765999972820282, 0.779900014400482, 0.790300011634827, 0.803600013256073, 0.803799986839294]</td>\n",
" <td>[1.28837704658508, 0.981181442737579, 0.849580764770508, 0.754298150539398, 0.693142831325531, 0.669469833374023, 0.640279293060303, 0.606397569179535, 0.579119145870209, 0.570892989635468]</td>\n",
" </tr>\n",
" <tr>\n",
" <td>8</td>\n",
" <td>1</td>\n",
" <td>loss='categorical_crossentropy',optimizer='adam(lr=0.001)',metrics=['accuracy']</td>\n",
" <td>batch_size=128,epochs=5</td>\n",
" <td>madlib_keras</td>\n",
" <td>4886.20019531</td>\n",
" <td>[165.13839507103, 330.998286962509, 498.064635038376, 665.857858896255, 834.544732093811, 1003.45657801628, 1173.99867010117, 1344.03136301041, 1515.32256889343, 1687.61437892914]</td>\n",
" <td>[u'accuracy']</td>\n",
" <td>0.901880025864</td>\n",
" <td>0.298958897591</td>\n",
" <td>[0.73361998796463, 0.803380012512207, 0.845399975776672, 0.863979995250702, 0.876219987869263, 0.889880001544952, 0.894959986209869, 0.898679971694946, 0.908540010452271, 0.901880025863647]</td>\n",
" <td>[0.760902941226959, 0.566388249397278, 0.448656052350998, 0.407294452190399, 0.36840745806694, 0.333151549100876, 0.314622759819031, 0.304351091384888, 0.28503081202507, 0.298958897590637]</td>\n",
" <td>0.782000005245</td>\n",
" <td>0.749579071999</td>\n",
" <td>[0.707300007343292, 0.752300024032593, 0.762000024318695, 0.773599982261658, 0.780399978160858, 0.786300003528595, 0.784300029277802, 0.784099996089935, 0.788299977779388, 0.782000005245209]</td>\n",
" <td>[0.836693525314331, 0.743824541568756, 0.733612596988678, 0.737680375576019, 0.760832130908966, 0.723663866519928, 0.78948837518692, 0.804735660552979, 0.70469468832016, 0.749579071998596]</td>\n",
" </tr>\n",
" <tr>\n",
" <td>3</td>\n",
" <td>1</td>\n",
" <td>loss='categorical_crossentropy',optimizer='rmsprop(lr=0.0001, decay=1e-6)',metrics=['accuracy']</td>\n",
" <td>batch_size=64,epochs=5</td>\n",
" <td>madlib_keras</td>\n",
" <td>4886.20019531</td>\n",
" <td>[153.837145090103, 319.967153072357, 486.56719994545, 654.53327703476, 822.778059959412, 991.797204971313, 1162.18237304688, 1331.98686599731, 1503.55213904381, 1675.16517400742]</td>\n",
" <td>[u'accuracy']</td>\n",
" <td>0.830699980259</td>\n",
" <td>0.507873356342</td>\n",
" <td>[0.575259983539581, 0.66838002204895, 0.703379988670349, 0.743640005588531, 0.776799976825714, 0.796980023384094, 0.801840007305145, 0.814220011234283, 0.8264200091362, 0.830699980258942]</td>\n",
" <td>[1.19788825511932, 0.950228035449982, 0.852661311626434, 0.741594791412354, 0.646690189838409, 0.594518661499023, 0.582961976528168, 0.546181917190552, 0.528378546237946, 0.507873356342316]</td>\n",
" <td>0.768700003624</td>\n",
" <td>0.684073984623</td>\n",
" <td>[0.57039999961853, 0.656899988651276, 0.682200014591217, 0.707400023937225, 0.735099971294403, 0.744599997997284, 0.745100021362305, 0.754899978637695, 0.758899986743927, 0.768700003623962]</td>\n",
" <td>[1.20627999305725, 0.984861135482788, 0.915386915206909, 0.849376976490021, 0.766118228435516, 0.73919004201889, 0.750212430953979, 0.715151488780975, 0.710894227027893, 0.684073984622955]</td>\n",
" </tr>\n",
" <tr>\n",
" <td>7</td>\n",
" <td>1</td>\n",
" <td>loss='categorical_crossentropy',optimizer='adam(lr=0.001)',metrics=['accuracy']</td>\n",
" <td>batch_size=64,epochs=5</td>\n",
" <td>madlib_keras</td>\n",
" <td>4886.20019531</td>\n",
" <td>[153.238389015198, 319.147723913193, 485.898155927658, 653.912374973297, 821.91964006424, 990.972142934799, 1161.34698009491, 1331.33741092682, 1502.62626290321, 1674.06854605675]</td>\n",
" <td>[u'accuracy']</td>\n",
" <td>0.856920003891</td>\n",
" <td>0.451146841049</td>\n",
" <td>[0.761780023574829, 0.809880018234253, 0.847639977931976, 0.856180012226105, 0.873279988765717, 0.855459988117218, 0.864660024642944, 0.858539998531342, 0.870779991149902, 0.856920003890991]</td>\n",
" <td>[0.700620949268341, 0.555083990097046, 0.447981059551239, 0.41928830742836, 0.381862819194794, 0.444543987512589, 0.415986865758896, 0.422646254301071, 0.402874350547791, 0.451146841049194]</td>\n",
" <td>0.768199980259</td>\n",
" <td>0.752578496933</td>\n",
" <td>[0.71780002117157, 0.746599972248077, 0.770099997520447, 0.769400000572205, 0.775499999523163, 0.763999998569489, 0.77319997549057, 0.769599974155426, 0.773899972438812, 0.768199980258942]</td>\n",
" <td>[0.833690404891968, 0.785688281059265, 0.77972024679184, 0.768506526947021, 0.768417119979858, 0.789122343063354, 0.87133800983429, 0.791547298431396, 0.893152952194214, 0.752578496932983]</td>\n",
" </tr>\n",
" <tr>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>loss='categorical_crossentropy',optimizer='adam(lr=0.0001)',metrics=['accuracy']</td>\n",
" <td>batch_size=64,epochs=5</td>\n",
" <td>madlib_keras</td>\n",
" <td>4886.20019531</td>\n",
" <td>[168.396234035492, 334.120693922043, 501.40336894989, 669.109417915344, 837.907988071442, 1006.88363099098, 1177.267567873, 1347.72842693329, 1518.65019989014, 1691.63165593147]</td>\n",
" <td>[u'accuracy']</td>\n",
" <td>0.902440011501</td>\n",
" <td>0.307300060987</td>\n",
" <td>[0.571120023727417, 0.666620016098022, 0.719539999961853, 0.757499992847443, 0.801400005817413, 0.826300024986267, 0.855199992656708, 0.875140011310577, 0.896160006523132, 0.902440011501312]</td>\n",
" <td>[1.22345066070557, 0.955978691577911, 0.811635494232178, 0.699091494083405, 0.582630336284637, 0.513621211051941, 0.437977999448776, 0.38476750254631, 0.333268582820892, 0.307300060987473]</td>\n",
" <td>0.767599999905</td>\n",
" <td>0.70242357254</td>\n",
" <td>[0.563700020313263, 0.645600020885468, 0.688799977302551, 0.71450001001358, 0.735000014305115, 0.746500015258789, 0.758599996566772, 0.757600009441376, 0.764500021934509, 0.767599999904633]</td>\n",
" <td>[1.24051570892334, 1.01462411880493, 0.90478104352951, 0.8267902135849, 0.766438901424408, 0.734673857688904, 0.706092000007629, 0.708917021751404, 0.692819654941559, 0.702423572540283]</td>\n",
" </tr>\n",
" <tr>\n",
" <td>2</td>\n",
" <td>1</td>\n",
" <td>loss='categorical_crossentropy',optimizer='adam(lr=0.0001)',metrics=['accuracy']</td>\n",
" <td>batch_size=128,epochs=5</td>\n",
" <td>madlib_keras</td>\n",
" <td>4886.20019531</td>\n",
" <td>[169.02210688591, 334.716751098633, 502.072870016098, 669.68922495842, 838.805229902267, 1007.46399402618, 1178.16211009026, 1348.57077288628, 1519.57116508484, 1692.27466797829]</td>\n",
" <td>[u'accuracy']</td>\n",
" <td>0.859300017357</td>\n",
" <td>0.428565859795</td>\n",
" <td>[0.532220005989075, 0.620400011539459, 0.674700021743774, 0.71340000629425, 0.747839987277985, 0.780160009860992, 0.801919996738434, 0.826839983463287, 0.849420011043549, 0.859300017356873]</td>\n",
" <td>[1.31418240070343, 1.07741296291351, 0.936273753643036, 0.825335919857025, 0.737494826316833, 0.649210572242737, 0.589954197406769, 0.524990677833557, 0.465339541435242, 0.428565859794617]</td>\n",
" <td>0.756900012493</td>\n",
" <td>0.719096183777</td>\n",
" <td>[0.529799997806549, 0.603900015354156, 0.656199991703033, 0.683700025081635, 0.703100025653839, 0.719600021839142, 0.730199992656708, 0.741400003433228, 0.747500002384186, 0.756900012493134]</td>\n",
" <td>[1.31718754768372, 1.11032629013062, 0.995527803897858, 0.911838352680206, 0.854842782020569, 0.803986191749573, 0.772469937801361, 0.748935461044312, 0.730905950069427, 0.719096183776855]</td>\n",
" </tr>\n",
" <tr>\n",
" <td>4</td>\n",
" <td>1</td>\n",
" <td>loss='categorical_crossentropy',optimizer='rmsprop(lr=0.0001, decay=1e-6)',metrics=['accuracy']</td>\n",
" <td>batch_size=128,epochs=5</td>\n",
" <td>madlib_keras</td>\n",
" <td>4886.20019531</td>\n",
" <td>[162.9407351017, 328.580847024918, 495.239603042603, 663.518301010132, 831.940176010132, 1001.0917840004, 1171.16344308853, 1341.38065099716, 1512.53006696701, 1684.75480604172]</td>\n",
" <td>[u'accuracy']</td>\n",
" <td>0.829819977283</td>\n",
" <td>0.51047205925</td>\n",
" <td>[0.512880027294159, 0.614199995994568, 0.665300011634827, 0.705659985542297, 0.726400017738342, 0.763320028781891, 0.793179988861084, 0.792519986629486, 0.817960023880005, 0.829819977283478]</td>\n",
" <td>[1.3586277961731, 1.10278081893921, 0.960904538631439, 0.845035135746002, 0.784774601459503, 0.686800301074982, 0.603691697120667, 0.598818957805634, 0.545015513896942, 0.510472059249878]</td>\n",
" <td>0.746500015259</td>\n",
" <td>0.735714316368</td>\n",
" <td>[0.512399971485138, 0.601899981498718, 0.643800020217896, 0.679300010204315, 0.689000010490417, 0.714399993419647, 0.736500024795532, 0.735700011253357, 0.744300007820129, 0.746500015258789]</td>\n",
" <td>[1.36217331886292, 1.12988150119781, 1.00909614562988, 0.918819069862366, 0.883056640625, 0.818843603134155, 0.768383204936981, 0.770775377750397, 0.754891037940979, 0.735714316368103]</td>\n",
" </tr>\n",
" <tr>\n",
" <td>6</td>\n",
" <td>1</td>\n",
" <td>loss='categorical_crossentropy',optimizer='rmsprop(lr=0.001, decay=1e-6)',metrics=['accuracy']</td>\n",
" <td>batch_size=128,epochs=5</td>\n",
" <td>madlib_keras</td>\n",
" <td>4886.20019531</td>\n",
" <td>[162.132050037384, 327.965554952621, 494.437786102295, 662.785852909088, 831.344939947128, 1000.31394791603, 1170.5982530117, 1340.48602604866, 1511.95220208168, 1683.82030010223]</td>\n",
" <td>[u'accuracy']</td>\n",
" <td>0.746420025826</td>\n",
" <td>0.811488032341</td>\n",
" <td>[0.714479982852936, 0.716300010681152, 0.784420013427734, 0.769860029220581, 0.730359971523285, 0.772319972515106, 0.791440010070801, 0.772459983825684, 0.677720010280609, 0.7464200258255]</td>\n",
" <td>[0.831750333309174, 0.864085614681244, 0.660020709037781, 0.700904130935669, 0.816842019557953, 0.718474090099335, 0.635774910449982, 0.702050924301147, 1.18704259395599, 0.811488032341003]</td>\n",
" <td>0.70300000906</td>\n",
" <td>1.0656965971</td>\n",
" <td>[0.679899990558624, 0.676699995994568, 0.729300022125244, 0.713900029659271, 0.696600019931793, 0.724799990653992, 0.736299991607666, 0.736199975013733, 0.661800026893616, 0.703000009059906]</td>\n",
" <td>[0.961720407009125, 1.03706383705139, 0.896331906318665, 0.848886549472809, 0.986389935016632, 0.962011396884918, 0.896553337574005, 0.922386705875397, 1.3008621931076, 1.0656965970993]</td>\n",
" </tr>\n",
" <tr>\n",
" <td>5</td>\n",
" <td>1</td>\n",
" <td>loss='categorical_crossentropy',optimizer='rmsprop(lr=0.001, decay=1e-6)',metrics=['accuracy']</td>\n",
" <td>batch_size=64,epochs=5</td>\n",
" <td>madlib_keras</td>\n",
" <td>4886.20019531</td>\n",
" <td>[165.757286071777, 331.686079978943, 498.744575023651, 666.556679010391, 835.225320100784, 1004.05871200562, 1174.84750103951, 1344.6810259819, 1515.93833899498, 1688.55732393265]</td>\n",
" <td>[u'accuracy']</td>\n",
" <td>0.537280023098</td>\n",
" <td>1.35161483288</td>\n",
" <td>[0.735180020332336, 0.752040028572083, 0.727559983730316, 0.721400022506714, 0.643440008163452, 0.655160009860992, 0.696080029010773, 0.618160009384155, 0.567300021648407, 0.537280023097992]</td>\n",
" <td>[0.76802670955658, 0.751371622085571, 0.805666506290436, 0.850524604320526, 1.10775411128998, 1.05535495281219, 0.927546322345734, 1.24175298213959, 1.2892210483551, 1.35161483287811]</td>\n",
" <td>0.544900000095</td>\n",
" <td>1.33901309967</td>\n",
" <td>[0.70660001039505, 0.716899991035461, 0.697200000286102, 0.698300004005432, 0.631600022315979, 0.638100028038025, 0.69489997625351, 0.619000017642975, 0.570500016212463, 0.544900000095367]</td>\n",
" <td>[0.875513792037964, 0.916396498680115, 0.912582337856293, 0.935619235038757, 1.15493774414062, 1.10954606533051, 0.960697770118713, 1.31051886081696, 1.26705503463745, 1.33901309967041]</td>\n",
" </tr>\n",
"</table>"
],
"text/plain": [
"[(16, 2, u\"loss='categorical_crossentropy',optimizer='adam(lr=0.001)',metrics=['accuracy']\", u'batch_size=128,epochs=5', u'madlib_keras', 2159.70019531, [167.736330986023, 333.425091981888, 500.695713996887, 668.302587985992, 837.287312984467, 1006.06942605972, 1176.67615294456, 1346.787348032, 1518.12181210518, 1690.67020988464], [u'accuracy'], 0.957840025425, 0.121589891613, [0.769860029220581, 0.824000000953674, 0.873139977455139, 0.89300000667572, 0.895640015602112, 0.906700015068054, 0.931919991970062, 0.942839980125427, 0.940620005130768, 0.957840025424957], [0.66564804315567, 0.511175155639648, 0.367111206054688, 0.307224303483963, 0.300335615873337, 0.268611431121826, 0.196494549512863, 0.165175542235374, 0.172968357801437, 0.12158989161253], 0.836000025272, 0.582142531872, [0.742699980735779, 0.790499985218048, 0.808600008487701, 0.818700015544891, 0.822000026702881, 0.821699976921082, 0.831499993801117, 0.83569997549057, 0.83050000667572, 0.836000025272369], [0.731135308742523, 0.629253566265106, 0.586650609970093, 0.561055064201355, 0.600637912750244, 0.576708614826202, 0.567015171051025, 0.560995817184448, 0.577787160873413, 0.582142531871796]),\n",
" (14, 2, u\"loss='categorical_crossentropy',optimizer='rmsprop(lr=0.001, decay=1e-6)',metrics=['accuracy']\", u'batch_size=128,epochs=5', u'madlib_keras', 2159.70019531, [161.545518875122, 327.271953105927, 493.721956014633, 662.059704065323, 830.583410024643, 999.47811293602, 1170.08322310448, 1339.875207901, 1511.35515999794, 1682.88088107109], [u'accuracy'], 0.942120015621, 0.166348025203, [0.768679976463318, 0.83459997177124, 0.865559995174408, 0.88782000541687, 0.900080025196075, 0.898840010166168, 0.929400026798248, 0.926339983940125, 0.941559970378876, 0.942120015621185], [0.659707903862, 0.479000419378281, 0.394761860370636, 0.320042163133621, 0.286971271038055, 0.289592266082764, 0.203219100832939, 0.216255784034729, 0.16890250146389, 0.166348025202751], 0.834399998188, 0.587312161922, [0.751600027084351, 0.794099986553192, 0.81029999256134, 0.816500008106232, 0.825600028038025, 0.819199979305267, 0.825200021266937, 0.833199977874756, 0.840300023555756, 0.834399998188019], [0.725527286529541, 0.628955543041229, 0.603530406951904, 0.578122794628143, 0.565659284591675, 0.587804615497589, 0.575832903385162, 0.586635053157806, 0.558215022087097, 0.587312161922455]),\n",
" (15, 2, u\"loss='categorical_crossentropy',optimizer='adam(lr=0.001)',metrics=['accuracy']\", u'batch_size=64,epochs=5', u'madlib_keras', 2159.70019531, [159.585074901581, 325.616278886795, 492.079638957977, 660.141077041626, 828.460551977158, 997.682931900024, 1168.2648499012, 1338.03905391693, 1509.35755109787, 1680.94471693039], [u'accuracy'], 0.957620024681, 0.123506456614, [0.780160009860992, 0.830079972743988, 0.864920020103455, 0.880159974098206, 0.907660007476807, 0.922760009765625, 0.930760025978088, 0.94489997625351, 0.953960001468658, 0.957620024681091], [0.640457689762115, 0.484953910112381, 0.392606198787689, 0.350569307804108, 0.266773730516434, 0.223709508776665, 0.199900239706039, 0.160074487328529, 0.134055703878403, 0.123506456613541], 0.833199977875, 0.585961103439, [0.747500002384186, 0.790600001811981, 0.805899977684021, 0.807099997997284, 0.818899989128113, 0.814999997615814, 0.821300029754639, 0.827600002288818, 0.830999970436096, 0.833199977874756], [0.733774244785309, 0.621092319488525, 0.600942432880402, 0.603525757789612, 0.582037806510925, 0.593123733997345, 0.593485474586487, 0.585796058177948, 0.578036189079285, 0.585961103439331]),\n",
" (13, 2, u\"loss='categorical_crossentropy',optimizer='rmsprop(lr=0.001, decay=1e-6)',metrics=['accuracy']\", u'batch_size=64,epochs=5', u'madlib_keras', 2159.70019531, [164.595175027847, 330.364078044891, 497.435774087906, 665.216387033463, 833.770098924637, 1002.83351397514, 1173.14754009247, 1343.40405297279, 1514.43769907951, 1686.70381498337], [u'accuracy'], 0.950980007648, 0.143490716815, [0.78983998298645, 0.840439975261688, 0.875959992408752, 0.891099989414215, 0.90090000629425, 0.919920027256012, 0.934400022029877, 0.938539981842041, 0.955479979515076, 0.950980007648468], [0.613083124160767, 0.471387982368469, 0.363269150257111, 0.319806933403015, 0.286749541759491, 0.234226956963539, 0.19084843993187, 0.177600309252739, 0.131557434797287, 0.143490716814995], 0.821799993515, 0.595590293407, [0.754000008106232, 0.79229998588562, 0.801699995994568, 0.812300026416779, 0.819000005722046, 0.819000005722046, 0.823300004005432, 0.829999983310699, 0.836300015449524, 0.821799993515015], [0.721113681793213, 0.621586740016937, 0.596519410610199, 0.595609545707703, 0.600475549697876, 0.613331437110901, 0.595634639263153, 0.574845016002655, 0.569734573364258, 0.59559029340744]),\n",
" (9, 2, u\"loss='categorical_crossentropy',optimizer='adam(lr=0.0001)',metrics=['accuracy']\", u'batch_size=64,epochs=5', u'madlib_keras', 2159.70019531, [155.881345033646, 321.711883068085, 488.33388209343, 656.33606004715, 824.596586942673, 993.720223903656, 1164.30447506905, 1334.05466103554, 1505.45432305336, 1677.10981488228], [u'accuracy'], 0.897319972515, 0.302623033524, [0.585739970207214, 0.694540023803711, 0.738439977169037, 0.788339972496033, 0.815580010414124, 0.834140002727509, 0.851960003376007, 0.870700001716614, 0.883599996566772, 0.897319972515106], [1.1557844877243, 0.861163735389709, 0.741564929485321, 0.606875598430634, 0.530352532863617, 0.474545627832413, 0.425946325063705, 0.374209344387054, 0.336798161268234, 0.30262303352356], 0.815199971199, 0.553332149982, [0.588599979877472, 0.692600011825562, 0.732900023460388, 0.767099976539612, 0.781899988651276, 0.791299998760223, 0.802100002765656, 0.805999994277954, 0.810199975967407, 0.815199971199036], [1.1479709148407, 0.871322154998779, 0.77245706319809, 0.673963844776154, 0.631623148918152, 0.608054459095001, 0.585181176662445, 0.569720149040222, 0.558107197284698, 0.553332149982452]),\n",
" (11, 2, u\"loss='categorical_crossentropy',optimizer='rmsprop(lr=0.0001, decay=1e-6)',metrics=['accuracy']\", u'batch_size=64,epochs=5', u'madlib_keras', 2159.70019531, [172.771174907684, 338.155246973038, 505.790575027466, 673.744323015213, 842.298762083054, 1011.25688695908, 1182.03339600563, 1352.39258003235, 1523.84475708008, 1696.31324291229], [u'accuracy'], 0.889580011368, 0.317797064781, [0.610719978809357, 0.702679991722107, 0.758080005645752, 0.787779986858368, 0.820479989051819, 0.840399980545044, 0.858399987220764, 0.869899988174438, 0.879320025444031, 0.889580011367798], [1.1027592420578, 0.840861320495605, 0.687958598136902, 0.603124439716339, 0.51472145318985, 0.460182726383209, 0.407543867826462, 0.375441372394562, 0.346606284379959, 0.317797064781189], 0.812399983406, 0.564498662949, [0.608399987220764, 0.697700023651123, 0.739300012588501, 0.758899986743927, 0.782599985599518, 0.793600022792816, 0.799199998378754, 0.806599974632263, 0.810599982738495, 0.812399983406067], [1.10815918445587, 0.86056125164032, 0.739441454410553, 0.684951841831207, 0.629340946674347, 0.604862153530121, 0.582197725772858, 0.574008762836456, 0.559266090393066, 0.564498662948608]),\n",
" (10, 2, u\"loss='categorical_crossentropy',optimizer='adam(lr=0.0001)',metrics=['accuracy']\", u'batch_size=128,epochs=5', u'madlib_keras', 2159.70019531, [157.675038099289, 323.760583877563, 489.999938964844, 658.165150880814, 826.338515996933, 995.962205886841, 1166.19140601158, 1335.88773202896, 1507.49120998383, 1679.03732204437], [u'accuracy'], 0.865880012512, 0.386452704668, [0.554459989070892, 0.660399973392487, 0.71670001745224, 0.754540026187897, 0.78276002407074, 0.806519985198975, 0.81879997253418, 0.83898001909256, 0.850740015506744, 0.865880012512207], [1.26610136032104, 0.961102485656738, 0.805769920349121, 0.702959299087524, 0.625120878219604, 0.556592226028442, 0.513025283813477, 0.460623860359192, 0.426946371793747, 0.386452704668045], 0.806100010872, 0.569638252258, [0.552999973297119, 0.657100021839142, 0.711000025272369, 0.737600028514862, 0.758300006389618, 0.77700001001358, 0.783100008964539, 0.794099986553192, 0.801199972629547, 0.806100010871887], [1.26569390296936, 0.972574234008789, 0.835387766361237, 0.750236749649048, 0.694831550121307, 0.648999333381653, 0.622370600700378, 0.599871814250946, 0.581832528114319, 0.569638252258301]),\n",
" (12, 2, u\"loss='categorical_crossentropy',optimizer='rmsprop(lr=0.0001, decay=1e-6)',metrics=['accuracy']\", u'batch_size=128,epochs=5', u'madlib_keras', 2159.70019531, [171.145457983017, 336.337003946304, 504.029928922653, 671.705837965012, 840.568361997604, 1009.40254306793, 1179.99340295792, 1350.53466200829, 1521.91818499565, 1694.26437997818], [u'accuracy'], 0.868319988251, 0.377308398485, [0.549000024795532, 0.662000000476837, 0.71262001991272, 0.75543999671936, 0.783819973468781, 0.801800012588501, 0.819119989871979, 0.837419986724854, 0.854939997196198, 0.868319988250732], [1.28990209102631, 0.96648907661438, 0.814616560935974, 0.696749150753021, 0.613618135452271, 0.56260073184967, 0.512484431266785, 0.460049092769623, 0.412180662155151, 0.377308398485184], 0.803799986839, 0.570892989635, [0.548399984836578, 0.653999984264374, 0.700100004673004, 0.735899984836578, 0.758899986743927, 0.765999972820282, 0.779900014400482, 0.790300011634827, 0.803600013256073, 0.803799986839294], [1.28837704658508, 0.981181442737579, 0.849580764770508, 0.754298150539398, 0.693142831325531, 0.669469833374023, 0.640279293060303, 0.606397569179535, 0.579119145870209, 0.570892989635468]),\n",
" (8, 1, u\"loss='categorical_crossentropy',optimizer='adam(lr=0.001)',metrics=['accuracy']\", u'batch_size=128,epochs=5', u'madlib_keras', 4886.20019531, [165.13839507103, 330.998286962509, 498.064635038376, 665.857858896255, 834.544732093811, 1003.45657801628, 1173.99867010117, 1344.03136301041, 1515.32256889343, 1687.61437892914], [u'accuracy'], 0.901880025864, 0.298958897591, [0.73361998796463, 0.803380012512207, 0.845399975776672, 0.863979995250702, 0.876219987869263, 0.889880001544952, 0.894959986209869, 0.898679971694946, 0.908540010452271, 0.901880025863647], [0.760902941226959, 0.566388249397278, 0.448656052350998, 0.407294452190399, 0.36840745806694, 0.333151549100876, 0.314622759819031, 0.304351091384888, 0.28503081202507, 0.298958897590637], 0.782000005245, 0.749579071999, [0.707300007343292, 0.752300024032593, 0.762000024318695, 0.773599982261658, 0.780399978160858, 0.786300003528595, 0.784300029277802, 0.784099996089935, 0.788299977779388, 0.782000005245209], [0.836693525314331, 0.743824541568756, 0.733612596988678, 0.737680375576019, 0.760832130908966, 0.723663866519928, 0.78948837518692, 0.804735660552979, 0.70469468832016, 0.749579071998596]),\n",
" (3, 1, u\"loss='categorical_crossentropy',optimizer='rmsprop(lr=0.0001, decay=1e-6)',metrics=['accuracy']\", u'batch_size=64,epochs=5', u'madlib_keras', 4886.20019531, [153.837145090103, 319.967153072357, 486.56719994545, 654.53327703476, 822.778059959412, 991.797204971313, 1162.18237304688, 1331.98686599731, 1503.55213904381, 1675.16517400742], [u'accuracy'], 0.830699980259, 0.507873356342, [0.575259983539581, 0.66838002204895, 0.703379988670349, 0.743640005588531, 0.776799976825714, 0.796980023384094, 0.801840007305145, 0.814220011234283, 0.8264200091362, 0.830699980258942], [1.19788825511932, 0.950228035449982, 0.852661311626434, 0.741594791412354, 0.646690189838409, 0.594518661499023, 0.582961976528168, 0.546181917190552, 0.528378546237946, 0.507873356342316], 0.768700003624, 0.684073984623, [0.57039999961853, 0.656899988651276, 0.682200014591217, 0.707400023937225, 0.735099971294403, 0.744599997997284, 0.745100021362305, 0.754899978637695, 0.758899986743927, 0.768700003623962], [1.20627999305725, 0.984861135482788, 0.915386915206909, 0.849376976490021, 0.766118228435516, 0.73919004201889, 0.750212430953979, 0.715151488780975, 0.710894227027893, 0.684073984622955]),\n",
" (7, 1, u\"loss='categorical_crossentropy',optimizer='adam(lr=0.001)',metrics=['accuracy']\", u'batch_size=64,epochs=5', u'madlib_keras', 4886.20019531, [153.238389015198, 319.147723913193, 485.898155927658, 653.912374973297, 821.91964006424, 990.972142934799, 1161.34698009491, 1331.33741092682, 1502.62626290321, 1674.06854605675], [u'accuracy'], 0.856920003891, 0.451146841049, [0.761780023574829, 0.809880018234253, 0.847639977931976, 0.856180012226105, 0.873279988765717, 0.855459988117218, 0.864660024642944, 0.858539998531342, 0.870779991149902, 0.856920003890991], [0.700620949268341, 0.555083990097046, 0.447981059551239, 0.41928830742836, 0.381862819194794, 0.444543987512589, 0.415986865758896, 0.422646254301071, 0.402874350547791, 0.451146841049194], 0.768199980259, 0.752578496933, [0.71780002117157, 0.746599972248077, 0.770099997520447, 0.769400000572205, 0.775499999523163, 0.763999998569489, 0.77319997549057, 0.769599974155426, 0.773899972438812, 0.768199980258942], [0.833690404891968, 0.785688281059265, 0.77972024679184, 0.768506526947021, 0.768417119979858, 0.789122343063354, 0.87133800983429, 0.791547298431396, 0.893152952194214, 0.752578496932983]),\n",
" (1, 1, u\"loss='categorical_crossentropy',optimizer='adam(lr=0.0001)',metrics=['accuracy']\", u'batch_size=64,epochs=5', u'madlib_keras', 4886.20019531, [168.396234035492, 334.120693922043, 501.40336894989, 669.109417915344, 837.907988071442, 1006.88363099098, 1177.267567873, 1347.72842693329, 1518.65019989014, 1691.63165593147], [u'accuracy'], 0.902440011501, 0.307300060987, [0.571120023727417, 0.666620016098022, 0.719539999961853, 0.757499992847443, 0.801400005817413, 0.826300024986267, 0.855199992656708, 0.875140011310577, 0.896160006523132, 0.902440011501312], [1.22345066070557, 0.955978691577911, 0.811635494232178, 0.699091494083405, 0.582630336284637, 0.513621211051941, 0.437977999448776, 0.38476750254631, 0.333268582820892, 0.307300060987473], 0.767599999905, 0.70242357254, [0.563700020313263, 0.645600020885468, 0.688799977302551, 0.71450001001358, 0.735000014305115, 0.746500015258789, 0.758599996566772, 0.757600009441376, 0.764500021934509, 0.767599999904633], [1.24051570892334, 1.01462411880493, 0.90478104352951, 0.8267902135849, 0.766438901424408, 0.734673857688904, 0.706092000007629, 0.708917021751404, 0.692819654941559, 0.702423572540283]),\n",
" (2, 1, u\"loss='categorical_crossentropy',optimizer='adam(lr=0.0001)',metrics=['accuracy']\", u'batch_size=128,epochs=5', u'madlib_keras', 4886.20019531, [169.02210688591, 334.716751098633, 502.072870016098, 669.68922495842, 838.805229902267, 1007.46399402618, 1178.16211009026, 1348.57077288628, 1519.57116508484, 1692.27466797829], [u'accuracy'], 0.859300017357, 0.428565859795, [0.532220005989075, 0.620400011539459, 0.674700021743774, 0.71340000629425, 0.747839987277985, 0.780160009860992, 0.801919996738434, 0.826839983463287, 0.849420011043549, 0.859300017356873], [1.31418240070343, 1.07741296291351, 0.936273753643036, 0.825335919857025, 0.737494826316833, 0.649210572242737, 0.589954197406769, 0.524990677833557, 0.465339541435242, 0.428565859794617], 0.756900012493, 0.719096183777, [0.529799997806549, 0.603900015354156, 0.656199991703033, 0.683700025081635, 0.703100025653839, 0.719600021839142, 0.730199992656708, 0.741400003433228, 0.747500002384186, 0.756900012493134], [1.31718754768372, 1.11032629013062, 0.995527803897858, 0.911838352680206, 0.854842782020569, 0.803986191749573, 0.772469937801361, 0.748935461044312, 0.730905950069427, 0.719096183776855]),\n",
" (4, 1, u\"loss='categorical_crossentropy',optimizer='rmsprop(lr=0.0001, decay=1e-6)',metrics=['accuracy']\", u'batch_size=128,epochs=5', u'madlib_keras', 4886.20019531, [162.9407351017, 328.580847024918, 495.239603042603, 663.518301010132, 831.940176010132, 1001.0917840004, 1171.16344308853, 1341.38065099716, 1512.53006696701, 1684.75480604172], [u'accuracy'], 0.829819977283, 0.51047205925, [0.512880027294159, 0.614199995994568, 0.665300011634827, 0.705659985542297, 0.726400017738342, 0.763320028781891, 0.793179988861084, 0.792519986629486, 0.817960023880005, 0.829819977283478], [1.3586277961731, 1.10278081893921, 0.960904538631439, 0.845035135746002, 0.784774601459503, 0.686800301074982, 0.603691697120667, 0.598818957805634, 0.545015513896942, 0.510472059249878], 0.746500015259, 0.735714316368, [0.512399971485138, 0.601899981498718, 0.643800020217896, 0.679300010204315, 0.689000010490417, 0.714399993419647, 0.736500024795532, 0.735700011253357, 0.744300007820129, 0.746500015258789], [1.36217331886292, 1.12988150119781, 1.00909614562988, 0.918819069862366, 0.883056640625, 0.818843603134155, 0.768383204936981, 0.770775377750397, 0.754891037940979, 0.735714316368103]),\n",
" (6, 1, u\"loss='categorical_crossentropy',optimizer='rmsprop(lr=0.001, decay=1e-6)',metrics=['accuracy']\", u'batch_size=128,epochs=5', u'madlib_keras', 4886.20019531, [162.132050037384, 327.965554952621, 494.437786102295, 662.785852909088, 831.344939947128, 1000.31394791603, 1170.5982530117, 1340.48602604866, 1511.95220208168, 1683.82030010223], [u'accuracy'], 0.746420025826, 0.811488032341, [0.714479982852936, 0.716300010681152, 0.784420013427734, 0.769860029220581, 0.730359971523285, 0.772319972515106, 0.791440010070801, 0.772459983825684, 0.677720010280609, 0.7464200258255], [0.831750333309174, 0.864085614681244, 0.660020709037781, 0.700904130935669, 0.816842019557953, 0.718474090099335, 0.635774910449982, 0.702050924301147, 1.18704259395599, 0.811488032341003], 0.70300000906, 1.0656965971, [0.679899990558624, 0.676699995994568, 0.729300022125244, 0.713900029659271, 0.696600019931793, 0.724799990653992, 0.736299991607666, 0.736199975013733, 0.661800026893616, 0.703000009059906], [0.961720407009125, 1.03706383705139, 0.896331906318665, 0.848886549472809, 0.986389935016632, 0.962011396884918, 0.896553337574005, 0.922386705875397, 1.3008621931076, 1.0656965970993]),\n",
" (5, 1, u\"loss='categorical_crossentropy',optimizer='rmsprop(lr=0.001, decay=1e-6)',metrics=['accuracy']\", u'batch_size=64,epochs=5', u'madlib_keras', 4886.20019531, [165.757286071777, 331.686079978943, 498.744575023651, 666.556679010391, 835.225320100784, 1004.05871200562, 1174.84750103951, 1344.6810259819, 1515.93833899498, 1688.55732393265], [u'accuracy'], 0.537280023098, 1.35161483288, [0.735180020332336, 0.752040028572083, 0.727559983730316, 0.721400022506714, 0.643440008163452, 0.655160009860992, 0.696080029010773, 0.618160009384155, 0.567300021648407, 0.537280023097992], [0.76802670955658, 0.751371622085571, 0.805666506290436, 0.850524604320526, 1.10775411128998, 1.05535495281219, 0.927546322345734, 1.24175298213959, 1.2892210483551, 1.35161483287811], 0.544900000095, 1.33901309967, [0.70660001039505, 0.716899991035461, 0.697200000286102, 0.698300004005432, 0.631600022315979, 0.638100028038025, 0.69489997625351, 0.619000017642975, 0.570500016212463, 0.544900000095367], [0.875513792037964, 0.916396498680115, 0.912582337856293, 0.935619235038757, 1.15493774414062, 1.10954606533051, 0.960697770118713, 1.31051886081696, 1.26705503463745, 1.33901309967041])]"
]
},
"execution_count": 28,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"%%sql\n",
"SELECT * FROM cifar10_multi_model_info ORDER BY validation_metrics_final DESC;"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"<a id=\"plot\"></a>\n",
"# 6. Plot results"
]
},
{
"cell_type": "code",
"execution_count": 6,
"metadata": {},
"outputs": [],
"source": [
"%matplotlib notebook\n",
"import matplotlib.pyplot as plt\n",
"from matplotlib.ticker import MaxNLocator\n",
"from collections import defaultdict\n",
"import pandas as pd\n",
"plt.rcParams.update({'font.size': 12})\n",
"pd.set_option('display.max_colwidth', -1)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Training data"
]
},
{
"cell_type": "code",
"execution_count": 7,
"metadata": {
"scrolled": false
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"16 rows affected.\n",
"1 rows affected.\n"
]
},
{
"data": {
"application/javascript": [
"/* Put everything inside the global mpl namespace */\n",
"window.mpl = {};\n",
"\n",
"\n",
"mpl.get_websocket_type = function() {\n",
" if (typeof(WebSocket) !== 'undefined') {\n",
" return WebSocket;\n",
" } else if (typeof(MozWebSocket) !== 'undefined') {\n",
" return MozWebSocket;\n",
" } else {\n",
" alert('Your browser does not have WebSocket support.' +\n",
" 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n",
" 'Firefox 4 and 5 are also supported but you ' +\n",
" 'have to enable WebSockets in about:config.');\n",
" };\n",
"}\n",
"\n",
"mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
" this.id = figure_id;\n",
"\n",
" this.ws = websocket;\n",
"\n",
" this.supports_binary = (this.ws.binaryType != undefined);\n",
"\n",
" if (!this.supports_binary) {\n",
" var warnings = document.getElementById(\"mpl-warnings\");\n",
" if (warnings) {\n",
" warnings.style.display = 'block';\n",
" warnings.textContent = (\n",
" \"This browser does not support binary websocket messages. \" +\n",
" \"Performance may be slow.\");\n",
" }\n",
" }\n",
"\n",
" this.imageObj = new Image();\n",
"\n",
" this.context = undefined;\n",
" this.message = undefined;\n",
" this.canvas = undefined;\n",
" this.rubberband_canvas = undefined;\n",
" this.rubberband_context = undefined;\n",
" this.format_dropdown = undefined;\n",
"\n",
" this.image_mode = 'full';\n",
"\n",
" this.root = $('<div/>');\n",
" this._root_extra_style(this.root)\n",
" this.root.attr('style', 'display: inline-block');\n",
"\n",
" $(parent_element).append(this.root);\n",
"\n",
" this._init_header(this);\n",
" this._init_canvas(this);\n",
" this._init_toolbar(this);\n",
"\n",
" var fig = this;\n",
"\n",
" this.waiting = false;\n",
"\n",
" this.ws.onopen = function () {\n",
" fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
" fig.send_message(\"send_image_mode\", {});\n",
" if (mpl.ratio != 1) {\n",
" fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
" }\n",
" fig.send_message(\"refresh\", {});\n",
" }\n",
"\n",
" this.imageObj.onload = function() {\n",
" if (fig.image_mode == 'full') {\n",
" // Full images could contain transparency (where diff images\n",
" // almost always do), so we need to clear the canvas so that\n",
" // there is no ghosting.\n",
" fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
" }\n",
" fig.context.drawImage(fig.imageObj, 0, 0);\n",
" };\n",
"\n",
" this.imageObj.onunload = function() {\n",
" fig.ws.close();\n",
" }\n",
"\n",
" this.ws.onmessage = this._make_on_message_function(this);\n",
"\n",
" this.ondownload = ondownload;\n",
"}\n",
"\n",
"mpl.figure.prototype._init_header = function() {\n",
" var titlebar = $(\n",
" '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
" 'ui-helper-clearfix\"/>');\n",
" var titletext = $(\n",
" '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
" 'text-align: center; padding: 3px;\"/>');\n",
" titlebar.append(titletext)\n",
" this.root.append(titlebar);\n",
" this.header = titletext[0];\n",
"}\n",
"\n",
"\n",
"\n",
"mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
"\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
"\n",
"}\n",
"\n",
"mpl.figure.prototype._init_canvas = function() {\n",
" var fig = this;\n",
"\n",
" var canvas_div = $('<div/>');\n",
"\n",
" canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
"\n",
" function canvas_keyboard_event(event) {\n",
" return fig.key_event(event, event['data']);\n",
" }\n",
"\n",
" canvas_div.keydown('key_press', canvas_keyboard_event);\n",
" canvas_div.keyup('key_release', canvas_keyboard_event);\n",
" this.canvas_div = canvas_div\n",
" this._canvas_extra_style(canvas_div)\n",
" this.root.append(canvas_div);\n",
"\n",
" var canvas = $('<canvas/>');\n",
" canvas.addClass('mpl-canvas');\n",
" canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
"\n",
" this.canvas = canvas[0];\n",
" this.context = canvas[0].getContext(\"2d\");\n",
"\n",
" var backingStore = this.context.backingStorePixelRatio ||\n",
"\tthis.context.webkitBackingStorePixelRatio ||\n",
"\tthis.context.mozBackingStorePixelRatio ||\n",
"\tthis.context.msBackingStorePixelRatio ||\n",
"\tthis.context.oBackingStorePixelRatio ||\n",
"\tthis.context.backingStorePixelRatio || 1;\n",
"\n",
" mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
"\n",
" var rubberband = $('<canvas/>');\n",
" rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
"\n",
" var pass_mouse_events = true;\n",
"\n",
" canvas_div.resizable({\n",
" start: function(event, ui) {\n",
" pass_mouse_events = false;\n",
" },\n",
" resize: function(event, ui) {\n",
" fig.request_resize(ui.size.width, ui.size.height);\n",
" },\n",
" stop: function(event, ui) {\n",
" pass_mouse_events = true;\n",
" fig.request_resize(ui.size.width, ui.size.height);\n",
" },\n",
" });\n",
"\n",
" function mouse_event_fn(event) {\n",
" if (pass_mouse_events)\n",
" return fig.mouse_event(event, event['data']);\n",
" }\n",
"\n",
" rubberband.mousedown('button_press', mouse_event_fn);\n",
" rubberband.mouseup('button_release', mouse_event_fn);\n",
" // Throttle sequential mouse events to 1 every 20ms.\n",
" rubberband.mousemove('motion_notify', mouse_event_fn);\n",
"\n",
" rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
" rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
"\n",
" canvas_div.on(\"wheel\", function (event) {\n",
" event = event.originalEvent;\n",
" event['data'] = 'scroll'\n",
" if (event.deltaY < 0) {\n",
" event.step = 1;\n",
" } else {\n",
" event.step = -1;\n",
" }\n",
" mouse_event_fn(event);\n",
" });\n",
"\n",
" canvas_div.append(canvas);\n",
" canvas_div.append(rubberband);\n",
"\n",
" this.rubberband = rubberband;\n",
" this.rubberband_canvas = rubberband[0];\n",
" this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
" this.rubberband_context.strokeStyle = \"#000000\";\n",
"\n",
" this._resize_canvas = function(width, height) {\n",
" // Keep the size of the canvas, canvas container, and rubber band\n",
" // canvas in synch.\n",
" canvas_div.css('width', width)\n",
" canvas_div.css('height', height)\n",
"\n",
" canvas.attr('width', width * mpl.ratio);\n",
" canvas.attr('height', height * mpl.ratio);\n",
" canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
"\n",
" rubberband.attr('width', width);\n",
" rubberband.attr('height', height);\n",
" }\n",
"\n",
" // Set the figure to an initial 600x600px, this will subsequently be updated\n",
" // upon first draw.\n",
" this._resize_canvas(600, 600);\n",
"\n",
" // Disable right mouse context menu.\n",
" $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
" return false;\n",
" });\n",
"\n",
" function set_focus () {\n",
" canvas.focus();\n",
" canvas_div.focus();\n",
" }\n",
"\n",
" window.setTimeout(set_focus, 100);\n",
"}\n",
"\n",
"mpl.figure.prototype._init_toolbar = function() {\n",
" var fig = this;\n",
"\n",
" var nav_element = $('<div/>')\n",
" nav_element.attr('style', 'width: 100%');\n",
" this.root.append(nav_element);\n",
"\n",
" // Define a callback function for later on.\n",
" function toolbar_event(event) {\n",
" return fig.toolbar_button_onclick(event['data']);\n",
" }\n",
" function toolbar_mouse_event(event) {\n",
" return fig.toolbar_button_onmouseover(event['data']);\n",
" }\n",
"\n",
" for(var toolbar_ind in mpl.toolbar_items) {\n",
" var name = mpl.toolbar_items[toolbar_ind][0];\n",
" var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
" var image = mpl.toolbar_items[toolbar_ind][2];\n",
" var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
"\n",
" if (!name) {\n",
" // put a spacer in here.\n",
" continue;\n",
" }\n",
" var button = $('<button/>');\n",
" button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
" 'ui-button-icon-only');\n",
" button.attr('role', 'button');\n",
" button.attr('aria-disabled', 'false');\n",
" button.click(method_name, toolbar_event);\n",
" button.mouseover(tooltip, toolbar_mouse_event);\n",
"\n",
" var icon_img = $('<span/>');\n",
" icon_img.addClass('ui-button-icon-primary ui-icon');\n",
" icon_img.addClass(image);\n",
" icon_img.addClass('ui-corner-all');\n",
"\n",
" var tooltip_span = $('<span/>');\n",
" tooltip_span.addClass('ui-button-text');\n",
" tooltip_span.html(tooltip);\n",
"\n",
" button.append(icon_img);\n",
" button.append(tooltip_span);\n",
"\n",
" nav_element.append(button);\n",
" }\n",
"\n",
" var fmt_picker_span = $('<span/>');\n",
"\n",
" var fmt_picker = $('<select/>');\n",
" fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
" fmt_picker_span.append(fmt_picker);\n",
" nav_element.append(fmt_picker_span);\n",
" this.format_dropdown = fmt_picker[0];\n",
"\n",
" for (var ind in mpl.extensions) {\n",
" var fmt = mpl.extensions[ind];\n",
" var option = $(\n",
" '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
" fmt_picker.append(option)\n",
" }\n",
"\n",
" // Add hover states to the ui-buttons\n",
" $( \".ui-button\" ).hover(\n",
" function() { $(this).addClass(\"ui-state-hover\");},\n",
" function() { $(this).removeClass(\"ui-state-hover\");}\n",
" );\n",
"\n",
" var status_bar = $('<span class=\"mpl-message\"/>');\n",
" nav_element.append(status_bar);\n",
" this.message = status_bar[0];\n",
"}\n",
"\n",
"mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
" // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
" // which will in turn request a refresh of the image.\n",
" this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
"}\n",
"\n",
"mpl.figure.prototype.send_message = function(type, properties) {\n",
" properties['type'] = type;\n",
" properties['figure_id'] = this.id;\n",
" this.ws.send(JSON.stringify(properties));\n",
"}\n",
"\n",
"mpl.figure.prototype.send_draw_message = function() {\n",
" if (!this.waiting) {\n",
" this.waiting = true;\n",
" this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
" }\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype.handle_save = function(fig, msg) {\n",
" var format_dropdown = fig.format_dropdown;\n",
" var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
" fig.ondownload(fig, format);\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
" var size = msg['size'];\n",
" if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
" fig._resize_canvas(size[0], size[1]);\n",
" fig.send_message(\"refresh\", {});\n",
" };\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
" var x0 = msg['x0'] / mpl.ratio;\n",
" var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
" var x1 = msg['x1'] / mpl.ratio;\n",
" var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
" x0 = Math.floor(x0) + 0.5;\n",
" y0 = Math.floor(y0) + 0.5;\n",
" x1 = Math.floor(x1) + 0.5;\n",
" y1 = Math.floor(y1) + 0.5;\n",
" var min_x = Math.min(x0, x1);\n",
" var min_y = Math.min(y0, y1);\n",
" var width = Math.abs(x1 - x0);\n",
" var height = Math.abs(y1 - y0);\n",
"\n",
" fig.rubberband_context.clearRect(\n",
" 0, 0, fig.canvas.width, fig.canvas.height);\n",
"\n",
" fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
" // Updates the figure title.\n",
" fig.header.textContent = msg['label'];\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
" var cursor = msg['cursor'];\n",
" switch(cursor)\n",
" {\n",
" case 0:\n",
" cursor = 'pointer';\n",
" break;\n",
" case 1:\n",
" cursor = 'default';\n",
" break;\n",
" case 2:\n",
" cursor = 'crosshair';\n",
" break;\n",
" case 3:\n",
" cursor = 'move';\n",
" break;\n",
" }\n",
" fig.rubberband_canvas.style.cursor = cursor;\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_message = function(fig, msg) {\n",
" fig.message.textContent = msg['message'];\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
" // Request the server to send over a new figure.\n",
" fig.send_draw_message();\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
" fig.image_mode = msg['mode'];\n",
"}\n",
"\n",
"mpl.figure.prototype.updated_canvas_event = function() {\n",
" // Called whenever the canvas gets updated.\n",
" this.send_message(\"ack\", {});\n",
"}\n",
"\n",
"// A function to construct a web socket function for onmessage handling.\n",
"// Called in the figure constructor.\n",
"mpl.figure.prototype._make_on_message_function = function(fig) {\n",
" return function socket_on_message(evt) {\n",
" if (evt.data instanceof Blob) {\n",
" /* FIXME: We get \"Resource interpreted as Image but\n",
" * transferred with MIME type text/plain:\" errors on\n",
" * Chrome. But how to set the MIME type? It doesn't seem\n",
" * to be part of the websocket stream */\n",
" evt.data.type = \"image/png\";\n",
"\n",
" /* Free the memory for the previous frames */\n",
" if (fig.imageObj.src) {\n",
" (window.URL || window.webkitURL).revokeObjectURL(\n",
" fig.imageObj.src);\n",
" }\n",
"\n",
" fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
" evt.data);\n",
" fig.updated_canvas_event();\n",
" fig.waiting = false;\n",
" return;\n",
" }\n",
" else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
" fig.imageObj.src = evt.data;\n",
" fig.updated_canvas_event();\n",
" fig.waiting = false;\n",
" return;\n",
" }\n",
"\n",
" var msg = JSON.parse(evt.data);\n",
" var msg_type = msg['type'];\n",
"\n",
" // Call the \"handle_{type}\" callback, which takes\n",
" // the figure and JSON message as its only arguments.\n",
" try {\n",
" var callback = fig[\"handle_\" + msg_type];\n",
" } catch (e) {\n",
" console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
" return;\n",
" }\n",
"\n",
" if (callback) {\n",
" try {\n",
" // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
" callback(fig, msg);\n",
" } catch (e) {\n",
" console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
" }\n",
" }\n",
" };\n",
"}\n",
"\n",
"// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
"mpl.findpos = function(e) {\n",
" //this section is from http://www.quirksmode.org/js/events_properties.html\n",
" var targ;\n",
" if (!e)\n",
" e = window.event;\n",
" if (e.target)\n",
" targ = e.target;\n",
" else if (e.srcElement)\n",
" targ = e.srcElement;\n",
" if (targ.nodeType == 3) // defeat Safari bug\n",
" targ = targ.parentNode;\n",
"\n",
" // jQuery normalizes the pageX and pageY\n",
" // pageX,Y are the mouse positions relative to the document\n",
" // offset() returns the position of the element relative to the document\n",
" var x = e.pageX - $(targ).offset().left;\n",
" var y = e.pageY - $(targ).offset().top;\n",
"\n",
" return {\"x\": x, \"y\": y};\n",
"};\n",
"\n",
"/*\n",
" * return a copy of an object with only non-object keys\n",
" * we need this to avoid circular references\n",
" * http://stackoverflow.com/a/24161582/3208463\n",
" */\n",
"function simpleKeys (original) {\n",
" return Object.keys(original).reduce(function (obj, key) {\n",
" if (typeof original[key] !== 'object')\n",
" obj[key] = original[key]\n",
" return obj;\n",
" }, {});\n",
"}\n",
"\n",
"mpl.figure.prototype.mouse_event = function(event, name) {\n",
" var canvas_pos = mpl.findpos(event)\n",
"\n",
" if (name === 'button_press')\n",
" {\n",
" this.canvas.focus();\n",
" this.canvas_div.focus();\n",
" }\n",
"\n",
" var x = canvas_pos.x * mpl.ratio;\n",
" var y = canvas_pos.y * mpl.ratio;\n",
"\n",
" this.send_message(name, {x: x, y: y, button: event.button,\n",
" step: event.step,\n",
" guiEvent: simpleKeys(event)});\n",
"\n",
" /* This prevents the web browser from automatically changing to\n",
" * the text insertion cursor when the button is pressed. We want\n",
" * to control all of the cursor setting manually through the\n",
" * 'cursor' event from matplotlib */\n",
" event.preventDefault();\n",
" return false;\n",
"}\n",
"\n",
"mpl.figure.prototype._key_event_extra = function(event, name) {\n",
" // Handle any extra behaviour associated with a key event\n",
"}\n",
"\n",
"mpl.figure.prototype.key_event = function(event, name) {\n",
"\n",
" // Prevent repeat events\n",
" if (name == 'key_press')\n",
" {\n",
" if (event.which === this._key)\n",
" return;\n",
" else\n",
" this._key = event.which;\n",
" }\n",
" if (name == 'key_release')\n",
" this._key = null;\n",
"\n",
" var value = '';\n",
" if (event.ctrlKey && event.which != 17)\n",
" value += \"ctrl+\";\n",
" if (event.altKey && event.which != 18)\n",
" value += \"alt+\";\n",
" if (event.shiftKey && event.which != 16)\n",
" value += \"shift+\";\n",
"\n",
" value += 'k';\n",
" value += event.which.toString();\n",
"\n",
" this._key_event_extra(event, name);\n",
"\n",
" this.send_message(name, {key: value,\n",
" guiEvent: simpleKeys(event)});\n",
" return false;\n",
"}\n",
"\n",
"mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
" if (name == 'download') {\n",
" this.handle_save(this, null);\n",
" } else {\n",
" this.send_message(\"toolbar_button\", {name: name});\n",
" }\n",
"};\n",
"\n",
"mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
" this.message.textContent = tooltip;\n",
"};\n",
"mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
"\n",
"mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
"\n",
"mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
" // Create a \"websocket\"-like object which calls the given IPython comm\n",
" // object with the appropriate methods. Currently this is a non binary\n",
" // socket, so there is still some room for performance tuning.\n",
" var ws = {};\n",
"\n",
" ws.close = function() {\n",
" comm.close()\n",
" };\n",
" ws.send = function(m) {\n",
" //console.log('sending', m);\n",
" comm.send(m);\n",
" };\n",
" // Register the callback with on_msg.\n",
" comm.on_msg(function(msg) {\n",
" //console.log('receiving', msg['content']['data'], msg);\n",
" // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
" ws.onmessage(msg['content']['data'])\n",
" });\n",
" return ws;\n",
"}\n",
"\n",
"mpl.mpl_figure_comm = function(comm, msg) {\n",
" // This is the function which gets called when the mpl process\n",
" // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
"\n",
" var id = msg.content.data.id;\n",
" // Get hold of the div created by the display call when the Comm\n",
" // socket was opened in Python.\n",
" var element = $(\"#\" + id);\n",
" var ws_proxy = comm_websocket_adapter(comm)\n",
"\n",
" function ondownload(figure, format) {\n",
" window.open(figure.imageObj.src);\n",
" }\n",
"\n",
" var fig = new mpl.figure(id, ws_proxy,\n",
" ondownload,\n",
" element.get(0));\n",
"\n",
" // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
" // web socket which is closed, not our websocket->open comm proxy.\n",
" ws_proxy.onopen();\n",
"\n",
" fig.parent_element = element.get(0);\n",
" fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
" if (!fig.cell_info) {\n",
" console.error(\"Failed to find cell for figure\", id, fig);\n",
" return;\n",
" }\n",
"\n",
" var output_index = fig.cell_info[2]\n",
" var cell = fig.cell_info[0];\n",
"\n",
"};\n",
"\n",
"mpl.figure.prototype.handle_close = function(fig, msg) {\n",
" var width = fig.canvas.width/mpl.ratio\n",
" fig.root.unbind('remove')\n",
"\n",
" // Update the output cell to use the data from the current canvas.\n",
" fig.push_to_output();\n",
" var dataURL = fig.canvas.toDataURL();\n",
" // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
" // the notebook keyboard shortcuts fail.\n",
" IPython.keyboard_manager.enable()\n",
" $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
" fig.close_ws(fig, msg);\n",
"}\n",
"\n",
"mpl.figure.prototype.close_ws = function(fig, msg){\n",
" fig.send_message('closing', msg);\n",
" // fig.ws.close()\n",
"}\n",
"\n",
"mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
" // Turn the data on the canvas into data in the output cell.\n",
" var width = this.canvas.width/mpl.ratio\n",
" var dataURL = this.canvas.toDataURL();\n",
" this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
"}\n",
"\n",
"mpl.figure.prototype.updated_canvas_event = function() {\n",
" // Tell IPython that the notebook contents must change.\n",
" IPython.notebook.set_dirty(true);\n",
" this.send_message(\"ack\", {});\n",
" var fig = this;\n",
" // Wait a second, then push the new image to the DOM so\n",
" // that it is saved nicely (might be nice to debounce this).\n",
" setTimeout(function () { fig.push_to_output() }, 1000);\n",
"}\n",
"\n",
"mpl.figure.prototype._init_toolbar = function() {\n",
" var fig = this;\n",
"\n",
" var nav_element = $('<div/>')\n",
" nav_element.attr('style', 'width: 100%');\n",
" this.root.append(nav_element);\n",
"\n",
" // Define a callback function for later on.\n",
" function toolbar_event(event) {\n",
" return fig.toolbar_button_onclick(event['data']);\n",
" }\n",
" function toolbar_mouse_event(event) {\n",
" return fig.toolbar_button_onmouseover(event['data']);\n",
" }\n",
"\n",
" for(var toolbar_ind in mpl.toolbar_items){\n",
" var name = mpl.toolbar_items[toolbar_ind][0];\n",
" var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
" var image = mpl.toolbar_items[toolbar_ind][2];\n",
" var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
"\n",
" if (!name) { continue; };\n",
"\n",
" var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
" button.click(method_name, toolbar_event);\n",
" button.mouseover(tooltip, toolbar_mouse_event);\n",
" nav_element.append(button);\n",
" }\n",
"\n",
" // Add the status bar.\n",
" var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
" nav_element.append(status_bar);\n",
" this.message = status_bar[0];\n",
"\n",
" // Add the close button to the window.\n",
" var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
" var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
" button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
" button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
" buttongrp.append(button);\n",
" var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
" titlebar.prepend(buttongrp);\n",
"}\n",
"\n",
"mpl.figure.prototype._root_extra_style = function(el){\n",
" var fig = this\n",
" el.on(\"remove\", function(){\n",
"\tfig.close_ws(fig, {});\n",
" });\n",
"}\n",
"\n",
"mpl.figure.prototype._canvas_extra_style = function(el){\n",
" // this is important to make the div 'focusable\n",
" el.attr('tabindex', 0)\n",
" // reach out to IPython and tell the keyboard manager to turn it's self\n",
" // off when our div gets focus\n",
"\n",
" // location in version 3\n",
" if (IPython.notebook.keyboard_manager) {\n",
" IPython.notebook.keyboard_manager.register_events(el);\n",
" }\n",
" else {\n",
" // location in version 2\n",
" IPython.keyboard_manager.register_events(el);\n",
" }\n",
"\n",
"}\n",
"\n",
"mpl.figure.prototype._key_event_extra = function(event, name) {\n",
" var manager = IPython.notebook.keyboard_manager;\n",
" if (!manager)\n",
" manager = IPython.keyboard_manager;\n",
"\n",
" // Check for shift+enter\n",
" if (event.shiftKey && event.which == 13) {\n",
" this.canvas_div.blur();\n",
" // select the cell after this one\n",
" var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n",
" IPython.notebook.select(index + 1);\n",
" }\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_save = function(fig, msg) {\n",
" fig.ondownload(fig, null);\n",
"}\n",
"\n",
"\n",
"mpl.find_output_cell = function(html_output) {\n",
" // Return the cell and output element which can be found *uniquely* in the notebook.\n",
" // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
" // IPython event is triggered only after the cells have been serialised, which for\n",
" // our purposes (turning an active figure into a static one), is too late.\n",
" var cells = IPython.notebook.get_cells();\n",
" var ncells = cells.length;\n",
" for (var i=0; i<ncells; i++) {\n",
" var cell = cells[i];\n",
" if (cell.cell_type === 'code'){\n",
" for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
" var data = cell.output_area.outputs[j];\n",
" if (data.data) {\n",
" // IPython >= 3 moved mimebundle to data attribute of output\n",
" data = data.data;\n",
" }\n",
" if (data['text/html'] == html_output) {\n",
" return [cell, data, j];\n",
" }\n",
" }\n",
" }\n",
" }\n",
"}\n",
"\n",
"// Register the function which deals with the matplotlib target/channel.\n",
"// The kernel may be null if the page has been refreshed.\n",
"if (IPython.notebook.kernel != null) {\n",
" IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
"}\n"
],
"text/plain": [
"<IPython.core.display.Javascript object>"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"data": {
"text/html": [
"<img src=\"\" width=\"720\">"
],
"text/plain": [
"<IPython.core.display.HTML object>"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"name": "stdout",
"output_type": "stream",
"text": [
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n"
]
}
],
"source": [
"df_results = %sql SELECT * FROM cifar10_multi_model_info ORDER BY training_loss_final ASC LIMIT 100;\n",
"df_results = df_results.DataFrame()\n",
"\n",
"df_summary = %sql SELECT * FROM cifar10_multi_model_summary;\n",
"df_summary = df_summary.DataFrame()\n",
"\n",
"#set up plots\n",
"fig, axs = plt.subplots(nrows=1, ncols=2, figsize=(10,5))\n",
"fig.legend(ncol=4)\n",
"fig.tight_layout()\n",
"\n",
"ax_metric = axs[0]\n",
"ax_loss = axs[1]\n",
"\n",
"ax_metric.xaxis.set_major_locator(MaxNLocator(integer=True))\n",
"ax_metric.set_xlabel('Iteration')\n",
"#ax_metric.set_ylabel('Accuracy')\n",
"ax_metric.set_title('Training Accuracy')\n",
"\n",
"ax_loss.xaxis.set_major_locator(MaxNLocator(integer=True))\n",
"ax_loss.set_xlabel('Iteration')\n",
"#ax_loss.set_ylabel('Cross Entropy Loss')\n",
"ax_loss.set_title('Training Loss (Cross Entropy)')\n",
"\n",
"iters = df_summary['metrics_iters'][0]\n",
"\n",
"for mst_key in df_results['mst_key']:\n",
" df_output_info = %sql SELECT training_metrics,training_loss FROM cifar10_multi_model_info WHERE mst_key = $mst_key\n",
" df_output_info = df_output_info.DataFrame()\n",
" training_metrics = df_output_info['training_metrics'][0]\n",
" training_loss = df_output_info['training_loss'][0]\n",
"\n",
" #ax_metric.plot(iters, training_metrics, label=mst_key, marker='o')\n",
" #ax_metric.plot(iters, training_metrics, marker='o')\n",
" ax_metric.plot(iters, training_metrics)\n",
" \n",
" #ax_loss.plot(iters, training_loss, label=mst_key, marker='o')\n",
" #ax_loss.plot(iters, training_loss, marker='o')\n",
" ax_loss.plot(iters, training_loss)\n",
"\n",
"plt.legend();\n",
"# fig.savefig('./lc_keras_fit.png', dpi = 300)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Validation data"
]
},
{
"cell_type": "code",
"execution_count": 8,
"metadata": {
"scrolled": false
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"16 rows affected.\n",
"1 rows affected.\n"
]
},
{
"data": {
"application/javascript": [
"/* Put everything inside the global mpl namespace */\n",
"window.mpl = {};\n",
"\n",
"\n",
"mpl.get_websocket_type = function() {\n",
" if (typeof(WebSocket) !== 'undefined') {\n",
" return WebSocket;\n",
" } else if (typeof(MozWebSocket) !== 'undefined') {\n",
" return MozWebSocket;\n",
" } else {\n",
" alert('Your browser does not have WebSocket support.' +\n",
" 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n",
" 'Firefox 4 and 5 are also supported but you ' +\n",
" 'have to enable WebSockets in about:config.');\n",
" };\n",
"}\n",
"\n",
"mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
" this.id = figure_id;\n",
"\n",
" this.ws = websocket;\n",
"\n",
" this.supports_binary = (this.ws.binaryType != undefined);\n",
"\n",
" if (!this.supports_binary) {\n",
" var warnings = document.getElementById(\"mpl-warnings\");\n",
" if (warnings) {\n",
" warnings.style.display = 'block';\n",
" warnings.textContent = (\n",
" \"This browser does not support binary websocket messages. \" +\n",
" \"Performance may be slow.\");\n",
" }\n",
" }\n",
"\n",
" this.imageObj = new Image();\n",
"\n",
" this.context = undefined;\n",
" this.message = undefined;\n",
" this.canvas = undefined;\n",
" this.rubberband_canvas = undefined;\n",
" this.rubberband_context = undefined;\n",
" this.format_dropdown = undefined;\n",
"\n",
" this.image_mode = 'full';\n",
"\n",
" this.root = $('<div/>');\n",
" this._root_extra_style(this.root)\n",
" this.root.attr('style', 'display: inline-block');\n",
"\n",
" $(parent_element).append(this.root);\n",
"\n",
" this._init_header(this);\n",
" this._init_canvas(this);\n",
" this._init_toolbar(this);\n",
"\n",
" var fig = this;\n",
"\n",
" this.waiting = false;\n",
"\n",
" this.ws.onopen = function () {\n",
" fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
" fig.send_message(\"send_image_mode\", {});\n",
" if (mpl.ratio != 1) {\n",
" fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
" }\n",
" fig.send_message(\"refresh\", {});\n",
" }\n",
"\n",
" this.imageObj.onload = function() {\n",
" if (fig.image_mode == 'full') {\n",
" // Full images could contain transparency (where diff images\n",
" // almost always do), so we need to clear the canvas so that\n",
" // there is no ghosting.\n",
" fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
" }\n",
" fig.context.drawImage(fig.imageObj, 0, 0);\n",
" };\n",
"\n",
" this.imageObj.onunload = function() {\n",
" fig.ws.close();\n",
" }\n",
"\n",
" this.ws.onmessage = this._make_on_message_function(this);\n",
"\n",
" this.ondownload = ondownload;\n",
"}\n",
"\n",
"mpl.figure.prototype._init_header = function() {\n",
" var titlebar = $(\n",
" '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
" 'ui-helper-clearfix\"/>');\n",
" var titletext = $(\n",
" '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
" 'text-align: center; padding: 3px;\"/>');\n",
" titlebar.append(titletext)\n",
" this.root.append(titlebar);\n",
" this.header = titletext[0];\n",
"}\n",
"\n",
"\n",
"\n",
"mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
"\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
"\n",
"}\n",
"\n",
"mpl.figure.prototype._init_canvas = function() {\n",
" var fig = this;\n",
"\n",
" var canvas_div = $('<div/>');\n",
"\n",
" canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
"\n",
" function canvas_keyboard_event(event) {\n",
" return fig.key_event(event, event['data']);\n",
" }\n",
"\n",
" canvas_div.keydown('key_press', canvas_keyboard_event);\n",
" canvas_div.keyup('key_release', canvas_keyboard_event);\n",
" this.canvas_div = canvas_div\n",
" this._canvas_extra_style(canvas_div)\n",
" this.root.append(canvas_div);\n",
"\n",
" var canvas = $('<canvas/>');\n",
" canvas.addClass('mpl-canvas');\n",
" canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
"\n",
" this.canvas = canvas[0];\n",
" this.context = canvas[0].getContext(\"2d\");\n",
"\n",
" var backingStore = this.context.backingStorePixelRatio ||\n",
"\tthis.context.webkitBackingStorePixelRatio ||\n",
"\tthis.context.mozBackingStorePixelRatio ||\n",
"\tthis.context.msBackingStorePixelRatio ||\n",
"\tthis.context.oBackingStorePixelRatio ||\n",
"\tthis.context.backingStorePixelRatio || 1;\n",
"\n",
" mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
"\n",
" var rubberband = $('<canvas/>');\n",
" rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
"\n",
" var pass_mouse_events = true;\n",
"\n",
" canvas_div.resizable({\n",
" start: function(event, ui) {\n",
" pass_mouse_events = false;\n",
" },\n",
" resize: function(event, ui) {\n",
" fig.request_resize(ui.size.width, ui.size.height);\n",
" },\n",
" stop: function(event, ui) {\n",
" pass_mouse_events = true;\n",
" fig.request_resize(ui.size.width, ui.size.height);\n",
" },\n",
" });\n",
"\n",
" function mouse_event_fn(event) {\n",
" if (pass_mouse_events)\n",
" return fig.mouse_event(event, event['data']);\n",
" }\n",
"\n",
" rubberband.mousedown('button_press', mouse_event_fn);\n",
" rubberband.mouseup('button_release', mouse_event_fn);\n",
" // Throttle sequential mouse events to 1 every 20ms.\n",
" rubberband.mousemove('motion_notify', mouse_event_fn);\n",
"\n",
" rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
" rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
"\n",
" canvas_div.on(\"wheel\", function (event) {\n",
" event = event.originalEvent;\n",
" event['data'] = 'scroll'\n",
" if (event.deltaY < 0) {\n",
" event.step = 1;\n",
" } else {\n",
" event.step = -1;\n",
" }\n",
" mouse_event_fn(event);\n",
" });\n",
"\n",
" canvas_div.append(canvas);\n",
" canvas_div.append(rubberband);\n",
"\n",
" this.rubberband = rubberband;\n",
" this.rubberband_canvas = rubberband[0];\n",
" this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
" this.rubberband_context.strokeStyle = \"#000000\";\n",
"\n",
" this._resize_canvas = function(width, height) {\n",
" // Keep the size of the canvas, canvas container, and rubber band\n",
" // canvas in synch.\n",
" canvas_div.css('width', width)\n",
" canvas_div.css('height', height)\n",
"\n",
" canvas.attr('width', width * mpl.ratio);\n",
" canvas.attr('height', height * mpl.ratio);\n",
" canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
"\n",
" rubberband.attr('width', width);\n",
" rubberband.attr('height', height);\n",
" }\n",
"\n",
" // Set the figure to an initial 600x600px, this will subsequently be updated\n",
" // upon first draw.\n",
" this._resize_canvas(600, 600);\n",
"\n",
" // Disable right mouse context menu.\n",
" $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
" return false;\n",
" });\n",
"\n",
" function set_focus () {\n",
" canvas.focus();\n",
" canvas_div.focus();\n",
" }\n",
"\n",
" window.setTimeout(set_focus, 100);\n",
"}\n",
"\n",
"mpl.figure.prototype._init_toolbar = function() {\n",
" var fig = this;\n",
"\n",
" var nav_element = $('<div/>')\n",
" nav_element.attr('style', 'width: 100%');\n",
" this.root.append(nav_element);\n",
"\n",
" // Define a callback function for later on.\n",
" function toolbar_event(event) {\n",
" return fig.toolbar_button_onclick(event['data']);\n",
" }\n",
" function toolbar_mouse_event(event) {\n",
" return fig.toolbar_button_onmouseover(event['data']);\n",
" }\n",
"\n",
" for(var toolbar_ind in mpl.toolbar_items) {\n",
" var name = mpl.toolbar_items[toolbar_ind][0];\n",
" var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
" var image = mpl.toolbar_items[toolbar_ind][2];\n",
" var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
"\n",
" if (!name) {\n",
" // put a spacer in here.\n",
" continue;\n",
" }\n",
" var button = $('<button/>');\n",
" button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
" 'ui-button-icon-only');\n",
" button.attr('role', 'button');\n",
" button.attr('aria-disabled', 'false');\n",
" button.click(method_name, toolbar_event);\n",
" button.mouseover(tooltip, toolbar_mouse_event);\n",
"\n",
" var icon_img = $('<span/>');\n",
" icon_img.addClass('ui-button-icon-primary ui-icon');\n",
" icon_img.addClass(image);\n",
" icon_img.addClass('ui-corner-all');\n",
"\n",
" var tooltip_span = $('<span/>');\n",
" tooltip_span.addClass('ui-button-text');\n",
" tooltip_span.html(tooltip);\n",
"\n",
" button.append(icon_img);\n",
" button.append(tooltip_span);\n",
"\n",
" nav_element.append(button);\n",
" }\n",
"\n",
" var fmt_picker_span = $('<span/>');\n",
"\n",
" var fmt_picker = $('<select/>');\n",
" fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
" fmt_picker_span.append(fmt_picker);\n",
" nav_element.append(fmt_picker_span);\n",
" this.format_dropdown = fmt_picker[0];\n",
"\n",
" for (var ind in mpl.extensions) {\n",
" var fmt = mpl.extensions[ind];\n",
" var option = $(\n",
" '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
" fmt_picker.append(option)\n",
" }\n",
"\n",
" // Add hover states to the ui-buttons\n",
" $( \".ui-button\" ).hover(\n",
" function() { $(this).addClass(\"ui-state-hover\");},\n",
" function() { $(this).removeClass(\"ui-state-hover\");}\n",
" );\n",
"\n",
" var status_bar = $('<span class=\"mpl-message\"/>');\n",
" nav_element.append(status_bar);\n",
" this.message = status_bar[0];\n",
"}\n",
"\n",
"mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
" // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
" // which will in turn request a refresh of the image.\n",
" this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
"}\n",
"\n",
"mpl.figure.prototype.send_message = function(type, properties) {\n",
" properties['type'] = type;\n",
" properties['figure_id'] = this.id;\n",
" this.ws.send(JSON.stringify(properties));\n",
"}\n",
"\n",
"mpl.figure.prototype.send_draw_message = function() {\n",
" if (!this.waiting) {\n",
" this.waiting = true;\n",
" this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
" }\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype.handle_save = function(fig, msg) {\n",
" var format_dropdown = fig.format_dropdown;\n",
" var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
" fig.ondownload(fig, format);\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
" var size = msg['size'];\n",
" if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
" fig._resize_canvas(size[0], size[1]);\n",
" fig.send_message(\"refresh\", {});\n",
" };\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
" var x0 = msg['x0'] / mpl.ratio;\n",
" var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
" var x1 = msg['x1'] / mpl.ratio;\n",
" var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
" x0 = Math.floor(x0) + 0.5;\n",
" y0 = Math.floor(y0) + 0.5;\n",
" x1 = Math.floor(x1) + 0.5;\n",
" y1 = Math.floor(y1) + 0.5;\n",
" var min_x = Math.min(x0, x1);\n",
" var min_y = Math.min(y0, y1);\n",
" var width = Math.abs(x1 - x0);\n",
" var height = Math.abs(y1 - y0);\n",
"\n",
" fig.rubberband_context.clearRect(\n",
" 0, 0, fig.canvas.width, fig.canvas.height);\n",
"\n",
" fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
" // Updates the figure title.\n",
" fig.header.textContent = msg['label'];\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
" var cursor = msg['cursor'];\n",
" switch(cursor)\n",
" {\n",
" case 0:\n",
" cursor = 'pointer';\n",
" break;\n",
" case 1:\n",
" cursor = 'default';\n",
" break;\n",
" case 2:\n",
" cursor = 'crosshair';\n",
" break;\n",
" case 3:\n",
" cursor = 'move';\n",
" break;\n",
" }\n",
" fig.rubberband_canvas.style.cursor = cursor;\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_message = function(fig, msg) {\n",
" fig.message.textContent = msg['message'];\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
" // Request the server to send over a new figure.\n",
" fig.send_draw_message();\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
" fig.image_mode = msg['mode'];\n",
"}\n",
"\n",
"mpl.figure.prototype.updated_canvas_event = function() {\n",
" // Called whenever the canvas gets updated.\n",
" this.send_message(\"ack\", {});\n",
"}\n",
"\n",
"// A function to construct a web socket function for onmessage handling.\n",
"// Called in the figure constructor.\n",
"mpl.figure.prototype._make_on_message_function = function(fig) {\n",
" return function socket_on_message(evt) {\n",
" if (evt.data instanceof Blob) {\n",
" /* FIXME: We get \"Resource interpreted as Image but\n",
" * transferred with MIME type text/plain:\" errors on\n",
" * Chrome. But how to set the MIME type? It doesn't seem\n",
" * to be part of the websocket stream */\n",
" evt.data.type = \"image/png\";\n",
"\n",
" /* Free the memory for the previous frames */\n",
" if (fig.imageObj.src) {\n",
" (window.URL || window.webkitURL).revokeObjectURL(\n",
" fig.imageObj.src);\n",
" }\n",
"\n",
" fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
" evt.data);\n",
" fig.updated_canvas_event();\n",
" fig.waiting = false;\n",
" return;\n",
" }\n",
" else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
" fig.imageObj.src = evt.data;\n",
" fig.updated_canvas_event();\n",
" fig.waiting = false;\n",
" return;\n",
" }\n",
"\n",
" var msg = JSON.parse(evt.data);\n",
" var msg_type = msg['type'];\n",
"\n",
" // Call the \"handle_{type}\" callback, which takes\n",
" // the figure and JSON message as its only arguments.\n",
" try {\n",
" var callback = fig[\"handle_\" + msg_type];\n",
" } catch (e) {\n",
" console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
" return;\n",
" }\n",
"\n",
" if (callback) {\n",
" try {\n",
" // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
" callback(fig, msg);\n",
" } catch (e) {\n",
" console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
" }\n",
" }\n",
" };\n",
"}\n",
"\n",
"// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
"mpl.findpos = function(e) {\n",
" //this section is from http://www.quirksmode.org/js/events_properties.html\n",
" var targ;\n",
" if (!e)\n",
" e = window.event;\n",
" if (e.target)\n",
" targ = e.target;\n",
" else if (e.srcElement)\n",
" targ = e.srcElement;\n",
" if (targ.nodeType == 3) // defeat Safari bug\n",
" targ = targ.parentNode;\n",
"\n",
" // jQuery normalizes the pageX and pageY\n",
" // pageX,Y are the mouse positions relative to the document\n",
" // offset() returns the position of the element relative to the document\n",
" var x = e.pageX - $(targ).offset().left;\n",
" var y = e.pageY - $(targ).offset().top;\n",
"\n",
" return {\"x\": x, \"y\": y};\n",
"};\n",
"\n",
"/*\n",
" * return a copy of an object with only non-object keys\n",
" * we need this to avoid circular references\n",
" * http://stackoverflow.com/a/24161582/3208463\n",
" */\n",
"function simpleKeys (original) {\n",
" return Object.keys(original).reduce(function (obj, key) {\n",
" if (typeof original[key] !== 'object')\n",
" obj[key] = original[key]\n",
" return obj;\n",
" }, {});\n",
"}\n",
"\n",
"mpl.figure.prototype.mouse_event = function(event, name) {\n",
" var canvas_pos = mpl.findpos(event)\n",
"\n",
" if (name === 'button_press')\n",
" {\n",
" this.canvas.focus();\n",
" this.canvas_div.focus();\n",
" }\n",
"\n",
" var x = canvas_pos.x * mpl.ratio;\n",
" var y = canvas_pos.y * mpl.ratio;\n",
"\n",
" this.send_message(name, {x: x, y: y, button: event.button,\n",
" step: event.step,\n",
" guiEvent: simpleKeys(event)});\n",
"\n",
" /* This prevents the web browser from automatically changing to\n",
" * the text insertion cursor when the button is pressed. We want\n",
" * to control all of the cursor setting manually through the\n",
" * 'cursor' event from matplotlib */\n",
" event.preventDefault();\n",
" return false;\n",
"}\n",
"\n",
"mpl.figure.prototype._key_event_extra = function(event, name) {\n",
" // Handle any extra behaviour associated with a key event\n",
"}\n",
"\n",
"mpl.figure.prototype.key_event = function(event, name) {\n",
"\n",
" // Prevent repeat events\n",
" if (name == 'key_press')\n",
" {\n",
" if (event.which === this._key)\n",
" return;\n",
" else\n",
" this._key = event.which;\n",
" }\n",
" if (name == 'key_release')\n",
" this._key = null;\n",
"\n",
" var value = '';\n",
" if (event.ctrlKey && event.which != 17)\n",
" value += \"ctrl+\";\n",
" if (event.altKey && event.which != 18)\n",
" value += \"alt+\";\n",
" if (event.shiftKey && event.which != 16)\n",
" value += \"shift+\";\n",
"\n",
" value += 'k';\n",
" value += event.which.toString();\n",
"\n",
" this._key_event_extra(event, name);\n",
"\n",
" this.send_message(name, {key: value,\n",
" guiEvent: simpleKeys(event)});\n",
" return false;\n",
"}\n",
"\n",
"mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
" if (name == 'download') {\n",
" this.handle_save(this, null);\n",
" } else {\n",
" this.send_message(\"toolbar_button\", {name: name});\n",
" }\n",
"};\n",
"\n",
"mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
" this.message.textContent = tooltip;\n",
"};\n",
"mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
"\n",
"mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
"\n",
"mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
" // Create a \"websocket\"-like object which calls the given IPython comm\n",
" // object with the appropriate methods. Currently this is a non binary\n",
" // socket, so there is still some room for performance tuning.\n",
" var ws = {};\n",
"\n",
" ws.close = function() {\n",
" comm.close()\n",
" };\n",
" ws.send = function(m) {\n",
" //console.log('sending', m);\n",
" comm.send(m);\n",
" };\n",
" // Register the callback with on_msg.\n",
" comm.on_msg(function(msg) {\n",
" //console.log('receiving', msg['content']['data'], msg);\n",
" // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
" ws.onmessage(msg['content']['data'])\n",
" });\n",
" return ws;\n",
"}\n",
"\n",
"mpl.mpl_figure_comm = function(comm, msg) {\n",
" // This is the function which gets called when the mpl process\n",
" // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
"\n",
" var id = msg.content.data.id;\n",
" // Get hold of the div created by the display call when the Comm\n",
" // socket was opened in Python.\n",
" var element = $(\"#\" + id);\n",
" var ws_proxy = comm_websocket_adapter(comm)\n",
"\n",
" function ondownload(figure, format) {\n",
" window.open(figure.imageObj.src);\n",
" }\n",
"\n",
" var fig = new mpl.figure(id, ws_proxy,\n",
" ondownload,\n",
" element.get(0));\n",
"\n",
" // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
" // web socket which is closed, not our websocket->open comm proxy.\n",
" ws_proxy.onopen();\n",
"\n",
" fig.parent_element = element.get(0);\n",
" fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
" if (!fig.cell_info) {\n",
" console.error(\"Failed to find cell for figure\", id, fig);\n",
" return;\n",
" }\n",
"\n",
" var output_index = fig.cell_info[2]\n",
" var cell = fig.cell_info[0];\n",
"\n",
"};\n",
"\n",
"mpl.figure.prototype.handle_close = function(fig, msg) {\n",
" var width = fig.canvas.width/mpl.ratio\n",
" fig.root.unbind('remove')\n",
"\n",
" // Update the output cell to use the data from the current canvas.\n",
" fig.push_to_output();\n",
" var dataURL = fig.canvas.toDataURL();\n",
" // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
" // the notebook keyboard shortcuts fail.\n",
" IPython.keyboard_manager.enable()\n",
" $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
" fig.close_ws(fig, msg);\n",
"}\n",
"\n",
"mpl.figure.prototype.close_ws = function(fig, msg){\n",
" fig.send_message('closing', msg);\n",
" // fig.ws.close()\n",
"}\n",
"\n",
"mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
" // Turn the data on the canvas into data in the output cell.\n",
" var width = this.canvas.width/mpl.ratio\n",
" var dataURL = this.canvas.toDataURL();\n",
" this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
"}\n",
"\n",
"mpl.figure.prototype.updated_canvas_event = function() {\n",
" // Tell IPython that the notebook contents must change.\n",
" IPython.notebook.set_dirty(true);\n",
" this.send_message(\"ack\", {});\n",
" var fig = this;\n",
" // Wait a second, then push the new image to the DOM so\n",
" // that it is saved nicely (might be nice to debounce this).\n",
" setTimeout(function () { fig.push_to_output() }, 1000);\n",
"}\n",
"\n",
"mpl.figure.prototype._init_toolbar = function() {\n",
" var fig = this;\n",
"\n",
" var nav_element = $('<div/>')\n",
" nav_element.attr('style', 'width: 100%');\n",
" this.root.append(nav_element);\n",
"\n",
" // Define a callback function for later on.\n",
" function toolbar_event(event) {\n",
" return fig.toolbar_button_onclick(event['data']);\n",
" }\n",
" function toolbar_mouse_event(event) {\n",
" return fig.toolbar_button_onmouseover(event['data']);\n",
" }\n",
"\n",
" for(var toolbar_ind in mpl.toolbar_items){\n",
" var name = mpl.toolbar_items[toolbar_ind][0];\n",
" var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
" var image = mpl.toolbar_items[toolbar_ind][2];\n",
" var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
"\n",
" if (!name) { continue; };\n",
"\n",
" var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
" button.click(method_name, toolbar_event);\n",
" button.mouseover(tooltip, toolbar_mouse_event);\n",
" nav_element.append(button);\n",
" }\n",
"\n",
" // Add the status bar.\n",
" var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
" nav_element.append(status_bar);\n",
" this.message = status_bar[0];\n",
"\n",
" // Add the close button to the window.\n",
" var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
" var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
" button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
" button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
" buttongrp.append(button);\n",
" var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
" titlebar.prepend(buttongrp);\n",
"}\n",
"\n",
"mpl.figure.prototype._root_extra_style = function(el){\n",
" var fig = this\n",
" el.on(\"remove\", function(){\n",
"\tfig.close_ws(fig, {});\n",
" });\n",
"}\n",
"\n",
"mpl.figure.prototype._canvas_extra_style = function(el){\n",
" // this is important to make the div 'focusable\n",
" el.attr('tabindex', 0)\n",
" // reach out to IPython and tell the keyboard manager to turn it's self\n",
" // off when our div gets focus\n",
"\n",
" // location in version 3\n",
" if (IPython.notebook.keyboard_manager) {\n",
" IPython.notebook.keyboard_manager.register_events(el);\n",
" }\n",
" else {\n",
" // location in version 2\n",
" IPython.keyboard_manager.register_events(el);\n",
" }\n",
"\n",
"}\n",
"\n",
"mpl.figure.prototype._key_event_extra = function(event, name) {\n",
" var manager = IPython.notebook.keyboard_manager;\n",
" if (!manager)\n",
" manager = IPython.keyboard_manager;\n",
"\n",
" // Check for shift+enter\n",
" if (event.shiftKey && event.which == 13) {\n",
" this.canvas_div.blur();\n",
" // select the cell after this one\n",
" var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n",
" IPython.notebook.select(index + 1);\n",
" }\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_save = function(fig, msg) {\n",
" fig.ondownload(fig, null);\n",
"}\n",
"\n",
"\n",
"mpl.find_output_cell = function(html_output) {\n",
" // Return the cell and output element which can be found *uniquely* in the notebook.\n",
" // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
" // IPython event is triggered only after the cells have been serialised, which for\n",
" // our purposes (turning an active figure into a static one), is too late.\n",
" var cells = IPython.notebook.get_cells();\n",
" var ncells = cells.length;\n",
" for (var i=0; i<ncells; i++) {\n",
" var cell = cells[i];\n",
" if (cell.cell_type === 'code'){\n",
" for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
" var data = cell.output_area.outputs[j];\n",
" if (data.data) {\n",
" // IPython >= 3 moved mimebundle to data attribute of output\n",
" data = data.data;\n",
" }\n",
" if (data['text/html'] == html_output) {\n",
" return [cell, data, j];\n",
" }\n",
" }\n",
" }\n",
" }\n",
"}\n",
"\n",
"// Register the function which deals with the matplotlib target/channel.\n",
"// The kernel may be null if the page has been refreshed.\n",
"if (IPython.notebook.kernel != null) {\n",
" IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
"}\n"
],
"text/plain": [
"<IPython.core.display.Javascript object>"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"data": {
"text/html": [
"<img src=\"\" width=\"720\">"
],
"text/plain": [
"<IPython.core.display.HTML object>"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"name": "stdout",
"output_type": "stream",
"text": [
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n"
]
}
],
"source": [
"df_results = %sql SELECT * FROM cifar10_multi_model_info ORDER BY validation_metrics_final DESC LIMIT 100;\n",
"df_results = df_results.DataFrame()\n",
"\n",
"df_summary = %sql SELECT * FROM cifar10_multi_model_summary;\n",
"df_summary = df_summary.DataFrame()\n",
"\n",
"#set up plots\n",
"fig, axs = plt.subplots(nrows=1, ncols=2, figsize=(10,5))\n",
"fig.legend(ncol=4)\n",
"fig.tight_layout()\n",
"\n",
"ax_metric = axs[0]\n",
"ax_loss = axs[1]\n",
"\n",
"ax_metric.xaxis.set_major_locator(MaxNLocator(integer=True))\n",
"ax_metric.set_xlabel('Iteration')\n",
"#ax_metric.set_ylabel('Accuracy')\n",
"ax_metric.set_title('Validation Accuracy')\n",
"\n",
"ax_loss.xaxis.set_major_locator(MaxNLocator(integer=True))\n",
"ax_loss.set_xlabel('Iteration')\n",
"#ax_loss.set_ylabel('Cross Entropy Loss')\n",
"ax_loss.set_title('Validation Loss (Cross Entropy)')\n",
"\n",
"iters = df_summary['metrics_iters'][0]\n",
"\n",
"for mst_key in df_results['mst_key']:\n",
" df_output_info = %sql SELECT validation_metrics,validation_loss FROM cifar10_multi_model_info WHERE mst_key = $mst_key\n",
" df_output_info = df_output_info.DataFrame()\n",
" validation_metrics = df_output_info['validation_metrics'][0]\n",
" validation_loss = df_output_info['validation_loss'][0]\n",
" \n",
" #ax_metric.plot(iters, validation_metrics, label=mst_key, marker='o')\n",
" ax_metric.plot(iters, validation_metrics)\n",
" \n",
" #ax_loss.plot(iters, validation_loss, label=mst_key, marker='o')\n",
" ax_loss.plot(iters, validation_loss)\n",
"\n",
"plt.legend();\n",
"# fig.savefig('./lc_keras_fit.png', dpi = 300)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Plot training and validation curves together"
]
},
{
"cell_type": "code",
"execution_count": 40,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n",
"1 rows affected.\n"
]
},
{
"data": {
"image/png": "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\n",
"text/plain": [
"<Figure size 720x360 with 2 Axes>"
]
},
"metadata": {
"needs_background": "light"
},
"output_type": "display_data"
}
],
"source": [
"# mst tuple(s) to plot\n",
"mst_key_to_plot = 10\n",
"df_results = %sql SELECT * FROM cifar10_multi_model_info WHERE mst_key = $mst_key_to_plot;\n",
"df_results = df_results.DataFrame()\n",
"\n",
"df_summary = %sql SELECT * FROM cifar10_multi_model_summary;\n",
"df_summary = df_summary.DataFrame()\n",
"\n",
"#set up plots\n",
"fig, axs = plt.subplots(nrows=1, ncols=2, figsize=(10,5))\n",
"fig.legend(ncol=4)\n",
"fig.tight_layout()\n",
"\n",
"ax_metric = axs[0]\n",
"ax_loss = axs[1]\n",
"\n",
"ax_metric.xaxis.set_major_locator(MaxNLocator(integer=True))\n",
"ax_metric.set_xlabel('Iteration')\n",
"#ax_metric.set_ylabel('Accuracy')\n",
"ax_metric.set_title('Classification Accuracy')\n",
"\n",
"ax_loss.xaxis.set_major_locator(MaxNLocator(integer=True))\n",
"ax_loss.set_xlabel('Iteration')\n",
"#ax_loss.set_ylabel('Loss')\n",
"ax_loss.set_title('Cross Entropy Loss')\n",
"\n",
"iters = df_summary['metrics_iters'][0]\n",
"\n",
"for mst_key in df_results['mst_key']:\n",
" \n",
" #train\n",
" df_output_info = %sql SELECT training_metrics,training_loss FROM cifar10_multi_model_info WHERE mst_key = $mst_key\n",
" df_output_info = df_output_info.DataFrame()\n",
" training_metrics = df_output_info['training_metrics'][0]\n",
" training_loss = df_output_info['training_loss'][0]\n",
" \n",
" #test\n",
" df_output_info = %sql SELECT validation_metrics,validation_loss FROM cifar10_multi_model_info WHERE mst_key = $mst_key\n",
" df_output_info = df_output_info.DataFrame()\n",
" validation_metrics = df_output_info['validation_metrics'][0]\n",
" validation_loss = df_output_info['validation_loss'][0]\n",
" \n",
" label_train = str(mst_key) + '-train'\n",
" #ax_metric.plot(iters, training_metrics, label=label_train, marker='x')\n",
" #ax_loss.plot(iters, training_loss, label=label_train, marker='x')\n",
" ax_metric.plot(iters, training_metrics, label=label_train)\n",
" ax_loss.plot(iters, training_loss, label=label_train)\n",
" \n",
" label_test = str(mst_key) + '-test'\n",
" #ax_metric.plot(iters, validation_metrics, label=label_test, marker='o')\n",
" #ax_loss.plot(iters, validation_loss, label=label_test, marker='o')\n",
" ax_metric.plot(iters, validation_metrics, label=label_test)\n",
" ax_loss.plot(iters, validation_loss, label=label_test)\n",
"\n",
"plt.legend();\n",
"# fig.savefig('./lc_keras_fit.png', dpi = 300)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"<a id=\"predict\"></a>\n",
"# 7. Inference\n",
"\n",
"## 7a. Run predict on the whole validation dataset\n",
"\n",
"Pick a reasonable model from the previous run."
]
},
{
"cell_type": "code",
"execution_count": 10,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"1 rows affected.\n"
]
},
{
"data": {
"text/html": [
"<table>\n",
" <tr>\n",
" <th>mst_key</th>\n",
" <th>model_id</th>\n",
" <th>compile_params</th>\n",
" <th>fit_params</th>\n",
" <th>model_type</th>\n",
" <th>model_size</th>\n",
" <th>metrics_elapsed_time</th>\n",
" <th>metrics_type</th>\n",
" <th>training_metrics_final</th>\n",
" <th>training_loss_final</th>\n",
" <th>training_metrics</th>\n",
" <th>training_loss</th>\n",
" <th>validation_metrics_final</th>\n",
" <th>validation_loss_final</th>\n",
" <th>validation_metrics</th>\n",
" <th>validation_loss</th>\n",
" </tr>\n",
" <tr>\n",
" <td>10</td>\n",
" <td>2</td>\n",
" <td>loss='categorical_crossentropy',optimizer='adam(lr=0.0001)',metrics=['accuracy']</td>\n",
" <td>batch_size=128,epochs=5</td>\n",
" <td>madlib_keras</td>\n",
" <td>2159.70019531</td>\n",
" <td>[157.675038099289, 323.760583877563, 489.999938964844, 658.165150880814, 826.338515996933, 995.962205886841, 1166.19140601158, 1335.88773202896, 1507.49120998383, 1679.03732204437]</td>\n",
" <td>[u'accuracy']</td>\n",
" <td>0.865880012512</td>\n",
" <td>0.386452704668</td>\n",
" <td>[0.554459989070892, 0.660399973392487, 0.71670001745224, 0.754540026187897, 0.78276002407074, 0.806519985198975, 0.81879997253418, 0.83898001909256, 0.850740015506744, 0.865880012512207]</td>\n",
" <td>[1.26610136032104, 0.961102485656738, 0.805769920349121, 0.702959299087524, 0.625120878219604, 0.556592226028442, 0.513025283813477, 0.460623860359192, 0.426946371793747, 0.386452704668045]</td>\n",
" <td>0.806100010872</td>\n",
" <td>0.569638252258</td>\n",
" <td>[0.552999973297119, 0.657100021839142, 0.711000025272369, 0.737600028514862, 0.758300006389618, 0.77700001001358, 0.783100008964539, 0.794099986553192, 0.801199972629547, 0.806100010871887]</td>\n",
" <td>[1.26569390296936, 0.972574234008789, 0.835387766361237, 0.750236749649048, 0.694831550121307, 0.648999333381653, 0.622370600700378, 0.599871814250946, 0.581832528114319, 0.569638252258301]</td>\n",
" </tr>\n",
"</table>"
],
"text/plain": [
"[(10, 2, u\"loss='categorical_crossentropy',optimizer='adam(lr=0.0001)',metrics=['accuracy']\", u'batch_size=128,epochs=5', u'madlib_keras', 2159.70019531, [157.675038099289, 323.760583877563, 489.999938964844, 658.165150880814, 826.338515996933, 995.962205886841, 1166.19140601158, 1335.88773202896, 1507.49120998383, 1679.03732204437], [u'accuracy'], 0.865880012512, 0.386452704668, [0.554459989070892, 0.660399973392487, 0.71670001745224, 0.754540026187897, 0.78276002407074, 0.806519985198975, 0.81879997253418, 0.83898001909256, 0.850740015506744, 0.865880012512207], [1.26610136032104, 0.961102485656738, 0.805769920349121, 0.702959299087524, 0.625120878219604, 0.556592226028442, 0.513025283813477, 0.460623860359192, 0.426946371793747, 0.386452704668045], 0.806100010872, 0.569638252258, [0.552999973297119, 0.657100021839142, 0.711000025272369, 0.737600028514862, 0.758300006389618, 0.77700001001358, 0.783100008964539, 0.794099986553192, 0.801199972629547, 0.806100010871887], [1.26569390296936, 0.972574234008789, 0.835387766361237, 0.750236749649048, 0.694831550121307, 0.648999333381653, 0.622370600700378, 0.599871814250946, 0.581832528114319, 0.569638252258301])]"
]
},
"execution_count": 10,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"%%sql\n",
"SELECT * FROM cifar10_multi_model_info WHERE mst_key=10;"
]
},
{
"cell_type": "code",
"execution_count": 11,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Done.\n",
"1 rows affected.\n",
"5 rows affected.\n"
]
},
{
"data": {
"text/html": [
"<table>\n",
" <tr>\n",
" <th>id</th>\n",
" <th>estimated_y</th>\n",
" </tr>\n",
" <tr>\n",
" <td>1</td>\n",
" <td>3</td>\n",
" </tr>\n",
" <tr>\n",
" <td>2</td>\n",
" <td>8</td>\n",
" </tr>\n",
" <tr>\n",
" <td>3</td>\n",
" <td>8</td>\n",
" </tr>\n",
" <tr>\n",
" <td>4</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <td>5</td>\n",
" <td>6</td>\n",
" </tr>\n",
"</table>"
],
"text/plain": [
"[(1, 3), (2, 8), (3, 8), (4, 0), (5, 6)]"
]
},
"execution_count": 11,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"%%sql\n",
"DROP TABLE IF EXISTS cifar10_val_predict;\n",
"\n",
"SELECT madlib.madlib_keras_predict('cifar10_multi_model', -- model\n",
" 'cifar10_val', -- test_table\n",
" 'id', -- id column\n",
" 'x', -- independent var\n",
" 'cifar10_val_predict', -- output table\n",
" 'response', -- prediction type\n",
" TRUE, -- use gpus\n",
" 10 -- mst_key to use\n",
" );\n",
"\n",
"SELECT * FROM cifar10_val_predict ORDER BY id LIMIT 5;"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Count missclassifications"
]
},
{
"cell_type": "code",
"execution_count": 12,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"1 rows affected.\n"
]
},
{
"data": {
"text/html": [
"<table>\n",
" <tr>\n",
" <th>count</th>\n",
" </tr>\n",
" <tr>\n",
" <td>1939</td>\n",
" </tr>\n",
"</table>"
],
"text/plain": [
"[(1939L,)]"
]
},
"execution_count": 12,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"%%sql\n",
"SELECT COUNT(*) FROM cifar10_val_predict JOIN cifar10_val USING (id) \n",
"WHERE cifar10_val_predict.estimated_y != cifar10_val.y;"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Accuracy"
]
},
{
"cell_type": "code",
"execution_count": 13,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"1 rows affected.\n"
]
},
{
"data": {
"text/html": [
"<table>\n",
" <tr>\n",
" <th>test_accuracy_percent</th>\n",
" </tr>\n",
" <tr>\n",
" <td>80.61</td>\n",
" </tr>\n",
"</table>"
],
"text/plain": [
"[(Decimal('80.61'),)]"
]
},
"execution_count": 13,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"%%sql\n",
"SELECT round(count(*)*100.0/10000.0,2) as test_accuracy_percent from\n",
" (select cifar10_val.y as actual, cifar10_val_predict.estimated_y as predicted\n",
" from cifar10_val_predict inner join cifar10_val\n",
" on cifar10_val.id=cifar10_val_predict.id) q\n",
"WHERE q.actual=q.predicted;"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## 7b. Select a random image from the validation dataset and run predict\n",
"\n",
"Label map"
]
},
{
"cell_type": "code",
"execution_count": 14,
"metadata": {},
"outputs": [],
"source": [
"label_names = {\n",
" 0 :\"airplane\",\n",
" 1 :\"automobile\",\n",
" 2 :\"bird\",\n",
" 3 :\"cat\",\n",
" 4 :\"deer\",\n",
" 5 :\"dog\",\n",
" 6 :\"frog\",\n",
" 7 :\"horse\",\n",
" 8 :\"ship\",\n",
" 9 :\"truck\"\n",
"}"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Pick a random image"
]
},
{
"cell_type": "code",
"execution_count": 21,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Done.\n",
"1 rows affected.\n"
]
},
{
"data": {
"text/plain": [
"[]"
]
},
"execution_count": 21,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"%%sql\n",
"DROP TABLE IF EXISTS cifar10_val_random;\n",
"CREATE TABLE cifar10_val_random AS\n",
" SELECT * FROM cifar10_val ORDER BY random() LIMIT 1;"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Predict"
]
},
{
"cell_type": "code",
"execution_count": 22,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Done.\n",
"1 rows affected.\n",
"1 rows affected.\n"
]
},
{
"data": {
"text/html": [
"<table>\n",
" <tr>\n",
" <th>id</th>\n",
" <th>prob_0</th>\n",
" <th>prob_1</th>\n",
" <th>prob_2</th>\n",
" <th>prob_3</th>\n",
" <th>prob_4</th>\n",
" <th>prob_5</th>\n",
" <th>prob_6</th>\n",
" <th>prob_7</th>\n",
" <th>prob_8</th>\n",
" <th>prob_9</th>\n",
" </tr>\n",
" <tr>\n",
" <td>4032</td>\n",
" <td>2.626629e-06</td>\n",
" <td>2.7014737e-08</td>\n",
" <td>0.0022699283</td>\n",
" <td>2.0414376e-05</td>\n",
" <td>0.99757725</td>\n",
" <td>1.5412388e-05</td>\n",
" <td>1.7638637e-05</td>\n",
" <td>9.5042335e-05</td>\n",
" <td>1.4481008e-06</td>\n",
" <td>5.417283e-08</td>\n",
" </tr>\n",
"</table>"
],
"text/plain": [
"[(4032, 2.626629e-06, 2.7014737e-08, 0.0022699283, 2.0414376e-05, 0.99757725, 1.5412388e-05, 1.7638637e-05, 9.5042335e-05, 1.4481008e-06, 5.417283e-08)]"
]
},
"execution_count": 22,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"%%sql\n",
"DROP TABLE IF EXISTS cifar10_val_random_predict;\n",
"\n",
"SELECT madlib.madlib_keras_predict('cifar10_multi_model', -- model\n",
" 'cifar10_val_random', -- test_table\n",
" 'id', -- id column\n",
" 'x', -- independent var\n",
" 'cifar10_val_random_predict', -- output table\n",
" 'prob', -- prediction type\n",
" TRUE, -- use gpus\n",
" 10 -- mst_key to use\n",
" );\n",
"\n",
"SELECT * FROM cifar10_val_random_predict;"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Format output and display"
]
},
{
"cell_type": "code",
"execution_count": 23,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Done.\n",
"1 rows affected.\n",
"1 rows affected.\n"
]
},
{
"data": {
"text/html": [
"<table>\n",
" <tr>\n",
" <th>feature_vector</th>\n",
" </tr>\n",
" <tr>\n",
" <td>[2.626629e-06, 2.7014737e-08, 0.0022699283, 2.0414376e-05, 0.99757725, 1.5412388e-05, 1.7638637e-05, 9.5042335e-05, 1.4481008e-06, 5.417283e-08]</td>\n",
" </tr>\n",
"</table>"
],
"text/plain": [
"[([2.626629e-06, 2.7014737e-08, 0.0022699283, 2.0414376e-05, 0.99757725, 1.5412388e-05, 1.7638637e-05, 9.5042335e-05, 1.4481008e-06, 5.417283e-08],)]"
]
},
"execution_count": 23,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"%%sql\n",
"DROP TABLE IF EXISTS cifar10_val_random_predict_array, cifar10_val_random_predict_array_summary;\n",
"SELECT madlib.cols2vec(\n",
" 'cifar10_val_random_predict',\n",
" 'cifar10_val_random_predict_array',\n",
" '*',\n",
" 'id'\n",
");\n",
"select * from cifar10_val_random_predict_array;"
]
},
{
"cell_type": "code",
"execution_count": 24,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"1 rows affected.\n"
]
},
{
"data": {
"text/plain": [
"<matplotlib.image.AxesImage at 0x1607c2710>"
]
},
"execution_count": 24,
"metadata": {},
"output_type": "execute_result"
},
{
"name": "stdout",
"output_type": "stream",
"text": [
"1 rows affected.\n",
" \n",
"deer 0.99757725\n",
"bird 0.0022699283\n",
"horse 9.5042335e-05\n"
]
},
{
"data": {
"image/png": "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\n",
"text/plain": [
"<Figure size 432x288 with 1 Axes>"
]
},
"metadata": {
"needs_background": "light"
},
"output_type": "display_data"
}
],
"source": [
"x = %sql SELECT x FROM cifar10_val_random;\n",
"x = x.DataFrame().to_numpy()\n",
"import numpy as np\n",
"from matplotlib.pyplot import imshow\n",
"%matplotlib inline\n",
"x_np = np.array(x[0][0], dtype=np.uint8)\n",
"imshow(x_np);\n",
"\n",
"x = %sql SELECT * FROM cifar10_val_random_predict_array;\n",
"x = x.DataFrame().to_numpy()\n",
"x = np.array(x[0][0])\n",
"top_3_prob_label_indices = x.argsort()[-3:][::-1]\n",
"print (\" \");\n",
"for index in top_3_prob_label_indices:\n",
" print (label_names[index], x[index])"
]
}
],
"metadata": {
"kernelspec": {
"display_name": "Python 2",
"language": "python",
"name": "python2"
},
"language_info": {
"codemirror_mode": {
"name": "ipython",
"version": 2
},
"file_extension": ".py",
"mimetype": "text/x-python",
"name": "python",
"nbconvert_exporter": "python",
"pygments_lexer": "ipython2",
"version": "2.7.16"
}
},
"nbformat": 4,
"nbformat_minor": 1
}