{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Extract and save bottleneck feature vectors with an example model\n",
    "Step 2 in  \n",
    "1. Generate Nosaic MNIST (`python make_nmnist.py`).\n",
    "2. Extract and save features in TFRecords format (save_featureTFR_nmnist.ipynb).\n",
    "3. Plot SAT curve (plot_SAT_curve.ipynb)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from __future__ import absolute_import\n",
    "from __future__ import division\n",
    "from __future__ import print_function\n",
    "\n",
    "import os, time\n",
    "import PIL\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import tensorflow as tf\n",
    "\n",
    "from datasets.data_processing import decode_nosaic_mnist, reshape_for_featext,\\\n",
    "    normalize_images_nosaic_mnist, binarize_labels_nosaic_mnist,\\\n",
    "    read_tfrecords_nosaic_mnist, decode_feat\n",
    "from models.backbones_fe import ResNetModel, get_ressize_dependent_params\n",
    "from models.losses import get_loss_fe"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Utility functions\n",
    "def set_gpu_devices(gpu):\n",
    "    physical_devices = tf.config.experimental.list_physical_devices('GPU')\n",
    "    assert len(physical_devices) > 0, \"Not enough GPU hardware devices available\"\n",
    "    tf.config.experimental.set_visible_devices(physical_devices[gpu], 'GPU')\n",
    "    tf.config.experimental.set_memory_growth(physical_devices[gpu], True)\n",
    "\n",
    "    \n",
    "def np_to_tfr_fe(x, y, writer):\n",
    "    \"\"\"Save a np.array to a tfrecord file. DO NOT FORGET writer.close().\n",
    "    Args:\n",
    "        x: data: np.ndarray, dtype=float32\n",
    "        y: label: int, dtype=int64\n",
    "        writer: tf.io.TFRecordWriter object. Don't forget writer.close()\n",
    "    \"\"\"\n",
    "    def _bytes_feature(value):\n",
    "        return tf.train.Feature(bytes_list=tf.train.BytesList(value=[value]))\n",
    "    def _int64_feature(value):\n",
    "        return tf.train.Feature(int64_list=tf.train.Int64List(value=[value]))\n",
    "    def _float_feature(value):\n",
    "        return tf.train.Feature(float_list=tf.train.FloatList(value=[value]))\n",
    "\n",
    "    # Make an Example object that has one record data\n",
    "    example = tf.train.Example(features=tf.train.Features(feature={\n",
    "        'video': _bytes_feature(x.tostring()),\n",
    "        'label': _int64_feature(y)\n",
    "        }))\n",
    "\n",
    "    # Serialize the example object and make a TFRecord file\n",
    "    writer.write(example.SerializeToString())\n",
    "\n",
    "    \n",
    "def _read_tfrecords_nmnist(record_file_train, record_file_test, batch_size):\n",
    "    \"\"\"Reads TFRecord file and make parsed dataset tensors.\"\"\"\n",
    "    def _parse_image_function(example_proto):\n",
    "        return tf.io.parse_single_example(example_proto, {\n",
    "                    'video': tf.io.FixedLenFeature([], tf.string),\n",
    "                    'label': tf.io.FixedLenFeature([],tf.int64)\n",
    "                    })\n",
    "\n",
    "    raw_image_dataset = tf.data.TFRecordDataset(record_file_train)\n",
    "    raw_image_dataset_test = tf.data.TFRecordDataset(record_file_test)\n",
    "    parsed_image_dataset_train = raw_image_dataset.map(_parse_image_function)\n",
    "    parsed_image_dataset_test = raw_image_dataset_test.map(_parse_image_function)\n",
    "\n",
    "    parsed_image_dataset_train = parsed_image_dataset_train.batch(batch_size, drop_remainder=False)\n",
    "    parsed_image_dataset_test = parsed_image_dataset_test.batch(batch_size, drop_remainder=False) \n",
    "\n",
    "    return parsed_image_dataset_train, parsed_image_dataset_test\n",
    "\n",
    "\n",
    "def _checkpoint_logger(model, flag_resume, root_ckptlogs,\n",
    "    subproject_name, exp_phase, comment, time_stamp, path_resume=None, \n",
    "    max_to_keep=3, config_path=None):\n",
    "    \"\"\"Make ckpt and manager objects, and restore the latest checkpoint if necessary.\n",
    "    Args:\n",
    "        model: A tf.keras.Model object.\n",
    "        flag_resume: A boolean. Whether to resume training from the latest ckpt.\n",
    "        root_ckptlogs: A string. Used for path to ckpts.\n",
    "        subproject_name: A string. Used for path to ckpts.\n",
    "        comment: A string. Used for path to ckpts.\n",
    "        time_stamp: A string. Used for path to ckpts.\n",
    "        path_resume: A string or None. The path to ckpt logs to be resumed. \n",
    "            path_resume is ignored if flag_resume=False.\n",
    "        max_to_keep: An int. Set max_to_keep=0 or None to keep all the ckpts.\n",
    "        config_path: A string. \n",
    "    Returns:\n",
    "        ckpt: tf.train.Checkpoint object.\n",
    "        ckpt_manager: tf.train.CheckpointManager object.\n",
    "    Remark:\n",
    "        Path to checkpoint files is \n",
    "            'root_ckptlogs'/'subproject_name'_'exp_phase'/'comment'_'time_stamp'/ckptXXX\n",
    "    \"\"\"\n",
    "    # Naming rule\n",
    "    dir_ckptlogs = \"{}/{}_{}/{}_{}\".format(\n",
    "        root_ckptlogs, subproject_name, exp_phase, comment, time_stamp)\n",
    "\n",
    "    if not os.path.exists(path_resume):\n",
    "        os.makedirs(path_resume)\n",
    "\n",
    "    # Create ckpt\n",
    "    ckpt = tf.train.Checkpoint(net=model)\n",
    "\n",
    "    # If resume\n",
    "    if flag_resume:\n",
    "        assert os.path.exists(path_resume), \"Not exist: path_ckpt = {}\".format(\n",
    "            path_resume)\n",
    "\n",
    "        # Create ckpt and manager for restore\n",
    "        ckpt_manager_restore = tf.train.CheckpointManager(\n",
    "            ckpt, path_resume, max_to_keep=max_to_keep)\n",
    "\n",
    "        # Restore the latest ckpt log.\n",
    "        ckpt.restore(ckpt_manager_restore.latest_checkpoint)\n",
    "        print(\"Restored from {}\".format(ckpt_manager_restore.latest_checkpoint))        \n",
    "    \n",
    "    # Create manager\n",
    "    ckpt_manager = tf.train.CheckpointManager(\n",
    "        ckpt, dir_ckptlogs, max_to_keep=max_to_keep)\n",
    "\n",
    "    return ckpt, ckpt_manager\n",
    "\n",
    "\n",
    "def ext_and_save(parsed_image_datasets, record_files, list_numdata):\n",
    "    # Extraction and save TFR\n",
    "    global_iter = 0\n",
    "    for parsed_image_dataset, record_file, num_data in zip(parsed_image_datasets, record_files, list_numdata):\n",
    "        with tf.io.TFRecordWriter(record_file) as writer:\n",
    "\n",
    "            # Start loop\n",
    "            for iter_b, feats in enumerate(parsed_image_dataset):\n",
    "                # 1. Decode features, normalize images, and binarize classification labels\n",
    "                x_batch, y_batch = decode_nosaic_mnist(feats)\n",
    "                y_batch = binarize_labels_nosaic_mnist(y_batch)  \n",
    "                iter_bs = y_batch.shape[0]\n",
    "                labels_batch = np.int64(y_batch.numpy())\n",
    "\n",
    "                x_batch, y_batch = reshape_for_featext(x_batch, y_batch, (28, 28, 1)) \n",
    "                    # (bs*duration, 28,28,1), (bs*duration,)\n",
    "                x_batch = normalize_images_nosaic_mnist(x_batch)\n",
    "\n",
    "                # 2. Extract features\n",
    "                _, losses, _, feats_batch = get_loss_fe(\n",
    "                model, \n",
    "                x_batch, \n",
    "                y_batch, \n",
    "                training=False, \n",
    "                param_wd=None, \n",
    "                flag_wd=False,\n",
    "                calc_grad=False\n",
    "                )\n",
    "\n",
    "                # Reshape (batch, duration, final size)\n",
    "                feats_batch = tf.reshape(feats_batch, (iter_bs, duration, final_size))\n",
    "                feats_batch = np.float32(feats_batch.numpy())\n",
    "\n",
    "                # 3. Save images\n",
    "                assert len(feats_batch) == len(labels_batch), \"{}, {}\".format(feats_batch.shape, labels_batch.shape)\n",
    "                for feat, label in zip(feats_batch, labels_batch):\n",
    "                    assert (label == 1) or (label == 0)\n",
    "                    np_to_tfr_fe(x=feat, y=label, writer=writer) \n",
    "\n",
    "                global_iter += 1\n",
    "\n",
    "                # 4. Verbose\n",
    "                if (iter_b+1) % 10 == 0:\n",
    "                    print(\"\")\n",
    "                    print(\"Global Iter={:7d} Iter={:5d}/{:5d} xent loss={:7.5f}: writing {}\"\n",
    "                        .format(\n",
    "                            global_iter,\n",
    "                            iter_b + 1,\n",
    "                            (num_data // batch_size) + 1 if num_data % batch_size != 0 else num_data // batch_size,\n",
    "                            losses[1],\n",
    "                            record_file))\n",
    "                    print(feat.shape)\n",
    "                    print(labels_batch)\n",
    "    print(\"Done\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# User Defined Parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# User defined\n",
    "tfr_train = './data-directory/nosaic_mnist_train.tfrecords' # NMNIST data\n",
    "tfr_test = './data-directory/nosaic_mnist_test.tfrecords' # NMNIST data\n",
    "tfr_feat_train = './data-directory/nosaic_mnist_feat_train.tfrecords' # extracted features to be saved here\n",
    "tfr_feat_test = './data-directory/nosaic_mnist_feat_test.tfrecords' # extracted features to be saved here\n",
    "batch_size = 50 # 64\n",
    "gpu = 0 # GPU number\n",
    "assert not os.path.exists(tfr_feat_train), tfr_feat_train + \"exists. Remove or rename.\"\n",
    "assert not os.path.exists(tfr_feat_test), tfr_feat_test + \"exists. Remove or rename.\""
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Start Extraction"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Fixed parameters\n",
    "duration = 20\n",
    "path_resume = \"./example_ckpts/feature_extractor/ResNetv1\"\n",
    "resnet_size = 110\n",
    "resnet_version = 1\n",
    "nb_cls = 2\n",
    "final_size = 128\n",
    "root_ckptlogs = \"./tmp\"\n",
    "subproject_name = \"_\"\n",
    "exp_phase = \"_\"\n",
    "comment = \"_\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "set_gpu_devices(gpu) # GPU number"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "<BatchDataset shapes: {label: (None,), video: (None,)}, types: {label: tf.int64, video: tf.string}>\n",
      "<BatchDataset shapes: {label: (None,), video: (None,)}, types: {label: tf.int64, video: tf.string}>\n"
     ]
    }
   ],
   "source": [
    "# Read Nosaic MNIST\n",
    "# Make sure to run ./make_nmnist.py in advance\n",
    "parsed_image_dataset_train, parsed_image_dataset_test = _read_tfrecords_nmnist(\n",
    "        record_file_train=tfr_train, \n",
    "        record_file_test=tfr_test, \n",
    "        batch_size=batch_size)\n",
    "\n",
    "print(parsed_image_dataset_train)\n",
    "print(parsed_image_dataset_test)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Restored from ./example_ckpts/feature_extractor/ResNetv1/ckpt_step6400_mbac0.98195-17\n"
     ]
    }
   ],
   "source": [
    "# Load model\n",
    "dict_resparams = get_ressize_dependent_params(resnet_version, resnet_size)\n",
    "\n",
    "model = ResNetModel(\n",
    "    resnet_size=resnet_size,\n",
    "    bottleneck=dict_resparams[\"bottleneck\"],\n",
    "    num_classes=nb_cls,\n",
    "    kernel_size=dict_resparams[\"kernel_size\"],\n",
    "    conv_stride=dict_resparams[\"conv_stride\"],\n",
    "    first_pool_size=dict_resparams[\"first_pool_size\"],\n",
    "    first_pool_stride=dict_resparams[\"first_pool_stride\"],\n",
    "    block_sizes=dict_resparams[\"block_sizes\"],\n",
    "    block_strides=dict_resparams[\"block_strides\"],\n",
    "    final_size=final_size,\n",
    "    resnet_version=resnet_version,\n",
    "    data_format='channels_last',\n",
    "    dtype=tf.float32\n",
    ")\n",
    "\n",
    "# Checkpoint\n",
    "now = \"0\"\n",
    "_, ckpt_manager = _checkpoint_logger(\n",
    "    model, \n",
    "    True, \n",
    "    root_ckptlogs, \n",
    "    subproject_name, \n",
    "    exp_phase,\n",
    "    comment, \n",
    "    now, \n",
    "    path_resume)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "test data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Global Iter=     10 Iter=   10/  200 xent=0.14915: writing ./data-directory/nosaic_mnist_feat_test.tfrecords\n",
      "(20, 128)\n",
      "[0 0 1 1 0 0 1 0 0 1 0 0 1 1 1 0 0 0 0 1 1 0 0 0 1 1 0 1 0 1 0 0 0 0 1 1 1\n",
      " 0 0 1 0 0 0 0 1 1 0 1 0 0]\n",
      "\n",
      "Global Iter=     20 Iter=   20/  200 xent=0.08344: writing ./data-directory/nosaic_mnist_feat_test.tfrecords\n",
      "(20, 128)\n",
      "[1 0 0 1 1 1 1 1 0 1 1 0 0 0 0 1 0 0 1 0 0 1 1 1 1 1 1 0 1 0 0 0 1 1 1 0 0\n",
      " 0 1 0 0 1 1 1 1 0 0 0 1 0]\n",
      "\n",
      "Global Iter=     30 Iter=   30/  200 xent=0.09182: writing ./data-directory/nosaic_mnist_feat_test.tfrecords\n",
      "(20, 128)\n",
      "[0 1 0 0 0 1 1 1 0 0 1 1 1 1 1 0 1 0 1 0 0 1 1 0 0 1 1 0 1 0 1 0 0 0 1 1 0\n",
      " 1 0 0 1 1 0 0 1 1 1 1 1 1]\n",
      "\n",
      "Global Iter=     40 Iter=   40/  200 xent=0.05922: writing ./data-directory/nosaic_mnist_feat_test.tfrecords\n",
      "(20, 128)\n",
      "[1 1 1 1 1 1 0 1 0 0 0 0 0 0 1 0 1 0 1 0 0 1 0 1 0 1 0 0 1 0 1 1 0 0 0 0 0\n",
      " 1 0 0 1 1 0 1 0 0 1 0 1 0]\n",
      "\n",
      "Global Iter=     50 Iter=   50/  200 xent=0.07530: writing ./data-directory/nosaic_mnist_feat_test.tfrecords\n",
      "(20, 128)\n",
      "[0 1 1 0 1 0 0 1 0 0 0 0 1 1 1 1 1 1 1 0 0 1 1 0 1 1 0 1 0 1 1 1 0 1 0 0 1\n",
      " 1 1 1 1 0 0 1 1 0 1 1 0 1]\n",
      "\n",
      "Global Iter=     60 Iter=   60/  200 xent=0.10878: writing ./data-directory/nosaic_mnist_feat_test.tfrecords\n",
      "(20, 128)\n",
      "[0 1 0 0 1 0 1 1 0 1 1 1 1 1 0 0 0 0 1 0 1 1 1 0 0 1 0 0 0 1 0 1 1 1 0 0 1\n",
      " 1 1 0 1 0 0 1 1 1 0 0 1 0]\n",
      "\n",
      "Global Iter=     70 Iter=   70/  200 xent=0.14683: writing ./data-directory/nosaic_mnist_feat_test.tfrecords\n",
      "(20, 128)\n",
      "[1 0 0 0 1 0 1 0 1 0 0 1 0 0 1 1 0 0 0 0 1 1 1 0 0 1 1 1 0 1 0 1 1 0 0 1 1\n",
      " 1 0 1 0 1 1 0 0 1 1 0 1 1]\n",
      "\n",
      "Global Iter=     80 Iter=   80/  200 xent=0.08554: writing ./data-directory/nosaic_mnist_feat_test.tfrecords\n",
      "(20, 128)\n",
      "[0 1 0 1 1 1 1 0 1 0 0 0 1 0 0 1 1 0 1 0 1 1 1 1 1 1 1 1 0 1 0 0 1 0 0 0 0\n",
      " 1 1 1 0 1 1 1 1 0 1 1 0 0]\n",
      "\n",
      "Global Iter=     90 Iter=   90/  200 xent=0.10813: writing ./data-directory/nosaic_mnist_feat_test.tfrecords\n",
      "(20, 128)\n",
      "[0 0 0 0 1 1 0 1 0 0 1 0 0 0 1 1 1 0 0 0 0 1 0 1 0 0 0 1 1 0 0 1 1 1 1 0 0\n",
      " 1 0 1 0 1 0 0 0 1 1 0 0 0]\n",
      "\n",
      "Global Iter=    100 Iter=  100/  200 xent=0.10489: writing ./data-directory/nosaic_mnist_feat_test.tfrecords\n",
      "(20, 128)\n",
      "[1 1 1 0 1 0 1 0 1 1 1 0 1 0 0 0 1 1 0 0 0 0 0 1 0 1 1 0 0 0 1 1 0 1 0 0 1\n",
      " 1 0 1 0 1 1 1 1 0 1 0 1 0]\n",
      "\n",
      "Global Iter=    110 Iter=  110/  200 xent=0.06655: writing ./data-directory/nosaic_mnist_feat_test.tfrecords\n",
      "(20, 128)\n",
      "[0 1 1 0 0 1 0 1 1 1 1 0 0 0 1 0 0 0 1 1 0 1 1 1 0 1 0 0 1 1 1 0 1 0 0 1 1\n",
      " 0 0 1 1 0 0 0 1 1 0 1 1 1]\n",
      "\n",
      "Global Iter=    120 Iter=  120/  200 xent=0.08763: writing ./data-directory/nosaic_mnist_feat_test.tfrecords\n",
      "(20, 128)\n",
      "[1 0 0 0 0 0 1 1 1 1 1 0 0 0 0 1 1 1 0 1 1 1 0 1 0 1 1 0 1 0 1 0 0 0 1 1 1\n",
      " 1 1 0 0 0 0 1 1 1 1 1 0 0]\n",
      "\n",
      "Global Iter=    130 Iter=  130/  200 xent=0.10039: writing ./data-directory/nosaic_mnist_feat_test.tfrecords\n",
      "(20, 128)\n",
      "[1 1 0 0 1 1 1 0 1 0 1 1 0 0 1 1 0 1 0 1 1 0 0 0 0 0 1 1 1 0 1 0 1 1 0 0 0\n",
      " 1 0 1 1 0 1 1 0 1 1 0 1 1]\n",
      "\n",
      "Global Iter=    140 Iter=  140/  200 xent=0.17931: writing ./data-directory/nosaic_mnist_feat_test.tfrecords\n",
      "(20, 128)\n",
      "[1 0 0 0 0 1 1 0 0 1 1 0 1 1 1 1 1 1 0 1 0 0 0 0 0 0 0 0 1 0 1 1 1 0 0 1 1\n",
      " 1 1 1 1 0 0 0 0 1 0 0 1 0]\n",
      "\n",
      "Global Iter=    150 Iter=  150/  200 xent=0.07487: writing ./data-directory/nosaic_mnist_feat_test.tfrecords\n",
      "(20, 128)\n",
      "[1 0 0 0 1 0 1 0 0 1 0 1 0 1 0 0 1 1 1 1 0 0 0 1 0 0 1 0 1 0 0 0 0 0 0 1 1\n",
      " 1 1 0 1 0 0 0 0 1 0 0 0 0]\n",
      "\n",
      "Global Iter=    160 Iter=  160/  200 xent=0.13309: writing ./data-directory/nosaic_mnist_feat_test.tfrecords\n",
      "(20, 128)\n",
      "[1 1 1 1 0 0 1 1 1 0 0 0 1 1 1 1 0 0 1 0 0 1 0 1 0 0 1 0 1 1 1 1 0 0 0 1 0\n",
      " 0 1 1 1 0 0 1 1 0 1 0 0 1]\n",
      "\n",
      "Global Iter=    170 Iter=  170/  200 xent=0.07669: writing ./data-directory/nosaic_mnist_feat_test.tfrecords\n",
      "(20, 128)\n",
      "[1 1 0 1 0 0 1 1 0 0 1 0 1 1 1 1 1 1 0 1 0 1 0 1 0 0 0 0 1 0 0 0 1 0 0 0 1\n",
      " 1 1 1 0 1 0 0 1 0 0 0 0 0]\n",
      "\n",
      "Global Iter=    180 Iter=  180/  200 xent=0.10440: writing ./data-directory/nosaic_mnist_feat_test.tfrecords\n",
      "(20, 128)\n",
      "[0 1 0 1 1 1 1 0 0 0 1 1 0 1 1 0 0 1 1 1 0 0 1 1 1 1 0 1 1 1 1 1 0 0 1 0 1\n",
      " 0 0 0 1 1 0 1 1 0 1 1 1 0]\n",
      "\n",
      "Global Iter=    190 Iter=  190/  200 xent=0.08978: writing ./data-directory/nosaic_mnist_feat_test.tfrecords\n",
      "(20, 128)\n",
      "[1 0 1 1 1 1 1 0 0 1 0 0 1 0 1 1 1 1 1 1 1 1 0 1 1 0 0 0 0 0 1 0 1 1 1 0 1\n",
      " 0 0 0 0 0 0 0 1 1 1 1 1 1]\n",
      "\n",
      "Global Iter=    200 Iter=  200/  200 xent=0.06919: writing ./data-directory/nosaic_mnist_feat_test.tfrecords\n",
      "(20, 128)\n",
      "[1 0 1 1 0 1 1 1 0 0 0 0 1 1 1 0 1 0 1 1 1 1 0 0 0 1 1 1 1 0 1 1 0 1 0 1 0\n",
      " 0 0 0 1 0 1 0 0 1 0 0 0 1]\n",
      "Done\n"
     ]
    }
   ],
   "source": [
    "# Feature Extraction and Save TFR\n",
    "parsed_image_datasets = [parsed_image_dataset_test]\n",
    "record_files = [tfr_feat_test]\n",
    "list_numdata = [10000]\n",
    "\n",
    "ext_and_save(parsed_image_datasets, record_files, list_numdata)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "training data (takes a little long time)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Global Iter=     10 Iter=   10/ 1200 xent=0.05374: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 0 1 1 0 1 0 0 0 0 0 1 0 0 1 1 0 1 1 1 0 0 0 0 0 0 0 1 0 0 0 0 1 0 1 1\n",
      " 0 1 0 0 0 0 1 0 0 1 0 0 0]\n",
      "\n",
      "Global Iter=     20 Iter=   20/ 1200 xent=0.10946: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 0 0 0 0 1 0 1 1 1 1 0 0 0 0 0 1 0 1 0 1 0 1 1 1 0 1 0 0 1 1 0 1 0 1 0\n",
      " 1 1 1 1 1 0 0 1 0 0 0 1 0]\n",
      "\n",
      "Global Iter=     30 Iter=   30/ 1200 xent=0.07291: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 1 0 1 0 0 1 0 0 1 0 0 0 0 0 0 1 1 1 1 0 0 0 0 0 0 0 0 1 0 1 1 1 1 0 0\n",
      " 0 1 0 1 1 1 0 0 1 1 0 0 0]\n",
      "\n",
      "Global Iter=     40 Iter=   40/ 1200 xent=0.08148: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 0 1 0 0 1 1 0 0 1 0 0 1 1 1 1 0 0 0 1 0 1 0 1 0 1 1 1 0 0 1 0 0 0 1 1 1\n",
      " 1 0 1 1 1 1 1 0 0 0 0 0 0]\n",
      "\n",
      "Global Iter=     50 Iter=   50/ 1200 xent=0.07375: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 0 0 0 0 1 0 0 1 1 1 0 0 1 1 0 1 1 0 1 1 1 1 1 1 1 0 1 1 1 1 0 1 1 0 0 1\n",
      " 1 1 0 1 1 0 1 1 1 1 0 0 1]\n",
      "\n",
      "Global Iter=     60 Iter=   60/ 1200 xent=0.09624: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 1 0 1 1 1 1 0 1 0 0 0 1 0 1 0 1 1 1 1 1 1 1 0 1 1 0 1 1 1 1 0 1 1 0 0\n",
      " 1 1 0 1 0 0 0 1 1 0 1 0 0]\n",
      "\n",
      "Global Iter=     70 Iter=   70/ 1200 xent=0.06681: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 0 0 1 1 1 1 0 1 1 1 1 0 0 1 0 0 1 0 0 1 1 1 0 0 0 0 1 1 0 1 0 1 1 0 1 1\n",
      " 1 1 1 0 0 1 1 0 1 0 0 1 0]\n",
      "\n",
      "Global Iter=     80 Iter=   80/ 1200 xent=0.08375: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 1 0 1 0 0 0 1 1 1 1 1 1 0 1 1 0 1 1 0 1 1 1 1 0 1 1 1 0 0 0 0 0 0 1 0\n",
      " 0 1 1 0 1 1 1 0 0 0 1 1 1]\n",
      "\n",
      "Global Iter=     90 Iter=   90/ 1200 xent=0.10609: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 0 1 1 1 0 1 0 0 0 1 0 0 1 1 0 1 1 1 1 0 1 1 0 1 0 1 0 0 0 0 1 0 1 0 1 0\n",
      " 1 1 1 0 0 0 0 1 1 0 0 0 0]\n",
      "\n",
      "Global Iter=    100 Iter=  100/ 1200 xent=0.09375: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 1 0 0 1 1 0 0 0 1 1 0 0 0 1 0 0 0 1 1 1 1 1 1 0 1 0 1 1 0 0 1 1 0 0 1\n",
      " 1 1 0 0 0 1 1 1 1 1 1 0 0]\n",
      "\n",
      "Global Iter=    110 Iter=  110/ 1200 xent=0.08283: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 0 1 0 0 1 0 1 1 0 1 0 1 1 1 1 1 0 0 0 0 1 1 1 0 0 1 1 1 1 1 1 0 1 0 0\n",
      " 1 1 1 1 1 1 0 0 1 1 0 1 1]\n",
      "\n",
      "Global Iter=    120 Iter=  120/ 1200 xent=0.09077: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 0 1 0 0 0 0 1 1 1 1 1 0 1 0 1 0 1 0 0 0 0 1 0 1 1 1 0 1 0 1 1 0 0 0 0 1\n",
      " 1 1 0 1 0 0 0 1 0 1 0 0 1]\n",
      "\n",
      "Global Iter=    130 Iter=  130/ 1200 xent=0.11432: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 0 1 0 0 1 1 0 1 0 1 0 1 1 1 1 0 0 1 1 0 0 0 0 0 0 1 1 1 0 1 0 0 0 1 0 1\n",
      " 0 0 1 0 0 1 0 0 1 1 1 1 0]\n",
      "\n",
      "Global Iter=    140 Iter=  140/ 1200 xent=0.12386: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 1 1 0 1 0 0 0 1 0 1 1 1 0 0 0 0 0 1 0 0 1 0 0 1 1 1 1 1 1 1 0 1 1 0 1\n",
      " 0 1 1 0 1 0 0 0 1 1 0 0 0]\n",
      "\n",
      "Global Iter=    150 Iter=  150/ 1200 xent=0.07827: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 1 1 0 0 0 1 1 1 1 1 0 0 0 0 1 0 1 0 1 1 0 0 0 1 1 0 0 1 1 0 0 1 1 0 0\n",
      " 1 0 1 0 0 0 0 1 1 0 1 0 1]\n",
      "\n",
      "Global Iter=    160 Iter=  160/ 1200 xent=0.08086: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 0 1 1 0 0 0 1 0 0 1 1 0 1 0 1 1 1 1 1 0 1 1 0 0 1 0 1 1 0 0 0 1 0 0 1\n",
      " 0 0 0 1 1 1 1 1 1 0 0 0 1]\n",
      "\n",
      "Global Iter=    170 Iter=  170/ 1200 xent=0.08376: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 0 1 0 0 0 1 0 0 1 0 0 1 0 1 0 0 0 0 0 1 1 0 1 0 0 1 1 0 1 1 0 0 0 0 1 1\n",
      " 1 1 1 1 1 1 1 0 0 0 0 1 0]\n",
      "\n",
      "Global Iter=    180 Iter=  180/ 1200 xent=0.08779: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 0 1 1 0 1 1 1 1 1 1 1 1 0 0 1 1 1 0 1 0 1 0 0 0 0 0 0 0 0 1 1 1 0 0 1\n",
      " 1 0 0 1 0 1 0 0 1 0 0 1 0]\n",
      "\n",
      "Global Iter=    190 Iter=  190/ 1200 xent=0.07115: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 0 0 1 1 0 1 0 0 1 1 0 1 0 1 1 1 0 1 0 1 0 1 0 0 1 1 1 0 0 1 1 0 1 0 0\n",
      " 1 0 0 0 1 0 0 0 0 0 1 0 0]\n",
      "\n",
      "Global Iter=    200 Iter=  200/ 1200 xent=0.07488: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 1 0 1 1 0 1 0 0 1 0 0 1 0 1 1 1 1 0 1 0 1 0 0 0 1 1 1 0 1 0 1 1 1 0 0\n",
      " 1 0 0 1 0 1 0 1 0 1 1 1 1]\n",
      "\n",
      "Global Iter=    210 Iter=  210/ 1200 xent=0.06429: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 1 0 0 0 1 0 0 1 1 0 1 1 1 0 0 1 1 1 0 1 0 0 1 0 0 1 0 1 1 1 0 1 0 0 1\n",
      " 1 0 1 0 0 1 0 0 1 1 1 0 1]\n",
      "\n",
      "Global Iter=    220 Iter=  220/ 1200 xent=0.08225: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 0 0 1 1 1 0 0 0 0 0 0 1 1 0 1 1 0 1 0 1 1 1 1 1 1 0 1 0 1 0 0 1 0 1 0\n",
      " 1 1 0 1 1 0 0 1 1 1 0 1 1]\n",
      "\n",
      "Global Iter=    230 Iter=  230/ 1200 xent=0.07345: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 0 1 1 0 1 0 0 0 0 0 0 0 1 0 0 1 0 1 0 1 0 1 1 0 1 1 1 1 1 0 0 1 0 0 0 1\n",
      " 1 1 0 0 1 0 0 1 1 0 0 0 0]\n",
      "\n",
      "Global Iter=    240 Iter=  240/ 1200 xent=0.09763: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 1 0 1 1 1 1 0 1 0 0 0 1 0 0 1 0 1 1 1 0 0 1 0 1 0 1 0 0 1 0 0 1 0 0 1\n",
      " 0 0 0 1 1 0 1 1 0 1 0 1 1]\n",
      "\n",
      "Global Iter=    250 Iter=  250/ 1200 xent=0.12678: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 0 0 1 0 1 0 0 0 0 1 0 0 1 1 0 1 1 1 0 1 0 1 1 1 1 1 0 0 0 0 0 1 0 0 0\n",
      " 1 1 1 0 1 0 1 0 0 0 1 1 0]\n",
      "\n",
      "Global Iter=    260 Iter=  260/ 1200 xent=0.07419: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 1 1 0 1 1 0 1 1 0 1 1 1 0 1 1 1 0 0 1 1 1 0 1 1 1 1 1 1 1 0 0 1 1 1 0\n",
      " 0 0 1 1 1 1 0 0 0 0 0 0 1]\n",
      "\n",
      "Global Iter=    270 Iter=  270/ 1200 xent=0.09354: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 0 0 0 0 0 1 0 1 1 1 1 1 1 1 1 1 1 1 0 1 1 1 1 0 1 1 1 0 1 0 0 1 1 1 0 1\n",
      " 0 1 0 0 0 1 1 0 1 0 1 0 0]\n",
      "\n",
      "Global Iter=    280 Iter=  280/ 1200 xent=0.13955: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 0 1 1 1 1 1 1 1 1 1 1 0 1 1 1 0 1 0 0 1 0 0 1 0 1 1 0 1 1 1 1 1 1 0 0\n",
      " 1 1 0 0 0 1 0 0 1 1 0 1 0]\n",
      "\n",
      "Global Iter=    290 Iter=  290/ 1200 xent=0.08933: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 1 0 0 0 1 1 1 1 0 0 1 1 0 1 1 0 1 1 0 1 0 0 1 1 0 0 0 0 0 1 1 0 0 0 1\n",
      " 0 1 1 0 0 1 0 1 1 0 1 1 1]\n",
      "\n",
      "Global Iter=    300 Iter=  300/ 1200 xent=0.07433: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 0 1 0 0 1 0 0 0 1 0 0 0 1 1 1 0 1 1 0 0 0 1 0 1 1 0 0 1 1 1 0 0 1 0 1\n",
      " 0 1 0 1 1 0 1 0 0 0 0 1 1]\n",
      "\n",
      "Global Iter=    310 Iter=  310/ 1200 xent=0.06669: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 1 1 0 1 0 1 0 1 1 1 0 0 1 0 0 1 1 0 1 0 0 1 1 0 0 1 0 1 0 0 1 0 1 1 0\n",
      " 0 0 1 0 0 1 0 1 0 1 1 0 1]\n",
      "\n",
      "Global Iter=    320 Iter=  320/ 1200 xent=0.10874: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 1 0 1 0 0 0 1 0 1 0 0 1 0 0 1 1 1 0 1 0 0 1 0 1 0 0 0 1 0 0 0 0 0 0 0\n",
      " 1 1 1 0 1 0 0 1 0 0 0 1 1]\n",
      "\n",
      "Global Iter=    330 Iter=  330/ 1200 xent=0.08370: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 1 1 0 0 0 0 0 0 0 0 1 1 0 0 0 1 1 1 1 0 0 1 0 0 1 1 0 0 0 0 0 0 1 0 0\n",
      " 1 1 1 1 0 1 0 0 0 1 1 1 1]\n",
      "\n",
      "Global Iter=    340 Iter=  340/ 1200 xent=0.09775: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 0 0 0 1 0 0 1 1 0 1 0 1 0 0 0 0 0 1 1 0 0 0 0 1 0 1 0 0 0 0 1 1 1 1 0\n",
      " 1 1 0 0 1 1 1 0 0 1 0 0 0]\n",
      "\n",
      "Global Iter=    350 Iter=  350/ 1200 xent=0.12134: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 1 1 0 1 1 0 1 0 0 0 1 0 1 0 1 0 1 1 0 1 1 1 1 1 1 0 0 1 1 0 1 0 1 0 1\n",
      " 0 1 1 1 1 0 1 1 0 0 0 1 1]\n",
      "\n",
      "Global Iter=    360 Iter=  360/ 1200 xent=0.07592: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 0 0 1 1 0 1 0 1 0 1 0 1 1 1 1 0 1 1 1 1 1 0 0 0 0 0 0 0 0 0 1 1 1 1 0\n",
      " 0 1 1 0 0 0 0 1 1 0 0 0 1]\n",
      "\n",
      "Global Iter=    370 Iter=  370/ 1200 xent=0.07577: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 1 0 1 1 1 0 1 0 1 1 1 1 1 0 1 1 0 0 0 1 1 1 1 1 1 0 1 0 0 1 0 0 0 1 0\n",
      " 1 0 1 0 0 0 0 0 1 0 0 1 0]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Global Iter=    380 Iter=  380/ 1200 xent=0.13454: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 0 1 1 1 0 1 1 1 0 0 1 0 0 0 0 1 0 0 1 1 1 1 1 1 0 0 1 1 1 1 0 1 0 0 1\n",
      " 1 1 0 0 1 1 1 0 0 0 0 1 1]\n",
      "\n",
      "Global Iter=    390 Iter=  390/ 1200 xent=0.08360: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 0 1 1 1 1 1 0 1 0 1 1 0 1 1 1 1 1 0 1 0 1 0 1 0 0 1 0 0 0 0 1 0 0 1 0\n",
      " 0 0 0 1 0 1 0 1 1 1 1 1 1]\n",
      "\n",
      "Global Iter=    400 Iter=  400/ 1200 xent=0.10064: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 1 1 0 1 1 1 1 0 0 0 1 1 0 1 1 1 0 0 0 1 0 0 1 0 0 1 1 0 1 1 1 0 0 1 0\n",
      " 1 0 1 0 1 1 1 0 1 1 1 1 1]\n",
      "\n",
      "Global Iter=    410 Iter=  410/ 1200 xent=0.12797: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 1 0 0 1 0 0 1 1 1 0 0 1 0 1 1 1 1 0 1 0 0 0 0 1 0 0 0 1 0 1 0 1 1 0 0\n",
      " 1 1 0 1 0 1 1 0 1 1 1 1 0]\n",
      "\n",
      "Global Iter=    420 Iter=  420/ 1200 xent=0.11315: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 0 1 0 0 1 0 1 0 0 1 1 1 1 0 1 0 0 1 1 1 1 0 0 1 0 0 0 1 0 1 1 1 1 1 0 1\n",
      " 1 0 1 0 1 0 1 0 1 0 1 1 1]\n",
      "\n",
      "Global Iter=    430 Iter=  430/ 1200 xent=0.06828: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 0 0 0 1 0 0 0 1 1 0 1 1 0 0 0 0 1 0 1 1 0 1 1 1 0 1 0 1 1 1 0 1 0 1 0 1\n",
      " 1 1 0 1 0 1 1 1 1 0 0 1 1]\n",
      "\n",
      "Global Iter=    440 Iter=  440/ 1200 xent=0.08403: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 1 0 1 0 1 0 1 0 1 1 0 0 1 0 1 0 0 1 0 0 0 0 0 1 0 1 0 1 1 1 0 1 1 1 1\n",
      " 1 1 1 1 0 1 1 0 1 1 0 0 1]\n",
      "\n",
      "Global Iter=    450 Iter=  450/ 1200 xent=0.08037: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 1 0 0 0 0 0 1 0 0 1 0 1 0 0 1 0 1 1 0 0 1 0 1 1 0 1 0 1 1 0 1 0 0 1 0\n",
      " 0 0 1 0 0 0 1 1 1 1 1 0 1]\n",
      "\n",
      "Global Iter=    460 Iter=  460/ 1200 xent=0.09500: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 1 0 1 0 1 1 1 1 1 1 0 0 1 1 1 0 1 0 1 1 1 0 1 0 0 0 1 1 0 1 0 1 1 0 0\n",
      " 0 1 1 1 0 0 1 0 1 0 1 1 1]\n",
      "\n",
      "Global Iter=    470 Iter=  470/ 1200 xent=0.06647: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 0 0 0 0 1 1 0 0 0 0 1 1 1 1 0 0 1 0 0 1 1 1 0 1 1 1 1 0 0 1 1 0 0 1 1\n",
      " 1 1 1 0 1 0 0 0 0 1 1 0 1]\n",
      "\n",
      "Global Iter=    480 Iter=  480/ 1200 xent=0.06205: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 0 1 1 0 1 1 1 0 1 1 1 1 1 1 1 0 0 0 1 0 0 0 0 1 1 0 0 1 0 0 1 0 1 0 0\n",
      " 0 1 1 1 0 1 1 1 1 0 1 0 0]\n",
      "\n",
      "Global Iter=    490 Iter=  490/ 1200 xent=0.13414: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 1 1 1 1 0 0 1 0 0 1 0 0 0 0 1 1 1 1 0 1 1 1 0 0 0 0 0 0 0 1 0 1 1 0 1\n",
      " 1 1 1 1 1 0 0 1 0 0 0 0 0]\n",
      "\n",
      "Global Iter=    500 Iter=  500/ 1200 xent=0.14366: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 0 1 1 0 0 1 0 0 0 1 1 1 1 0 0 1 1 1 1 1 1 1 0 0 0 0 0 0 0 0 1 0 0 1 1 1\n",
      " 1 1 1 0 1 0 1 1 0 1 1 1 0]\n",
      "\n",
      "Global Iter=    510 Iter=  510/ 1200 xent=0.18594: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 0 0 0 0 1 0 0 0 0 0 1 1 1 0 1 1 1 1 0 0 1 1 0 0 0 0 0 1 0 0 1 1 1 1 0\n",
      " 0 0 0 1 1 0 1 1 1 0 0 1 0]\n",
      "\n",
      "Global Iter=    520 Iter=  520/ 1200 xent=0.12773: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 1 0 0 1 1 0 0 0 0 0 1 0 1 1 1 1 1 1 1 0 1 0 1 0 0 1 1 0 1 0 1 0 0 0 1\n",
      " 1 0 1 0 1 1 1 0 1 0 0 1 0]\n",
      "\n",
      "Global Iter=    530 Iter=  530/ 1200 xent=0.12883: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 0 0 1 0 0 0 1 1 1 0 0 1 1 1 0 1 1 0 0 0 0 0 1 0 1 1 0 1 1 1 1 1 1 0 1\n",
      " 0 0 1 1 1 0 0 1 1 0 0 0 0]\n",
      "\n",
      "Global Iter=    540 Iter=  540/ 1200 xent=0.07028: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 0 1 1 1 0 1 1 0 1 1 1 1 0 1 1 0 1 0 1 0 0 0 0 0 0 0 1 0 1 1 0 0 0 1 0 0\n",
      " 0 1 1 1 0 1 0 0 0 0 0 1 1]\n",
      "\n",
      "Global Iter=    550 Iter=  550/ 1200 xent=0.08085: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 0 1 0 1 1 0 0 0 0 0 1 1 0 0 0 1 0 1 1 1 1 1 1 0 1 0 1 1 1 1 0 1 0 0 0 0\n",
      " 1 1 0 0 0 0 0 0 1 0 1 1 0]\n",
      "\n",
      "Global Iter=    560 Iter=  560/ 1200 xent=0.07390: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 1 0 1 0 1 1 0 1 1 1 1 1 0 1 1 1 0 0 1 1 1 1 0 0 0 1 1 1 1 0 0 1 1 0 1\n",
      " 1 0 1 1 0 1 1 1 1 0 0 0 1]\n",
      "\n",
      "Global Iter=    570 Iter=  570/ 1200 xent=0.06774: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 1 1 0 0 0 1 0 1 0 1 1 0 1 1 0 1 1 1 1 0 0 1 0 0 0 1 1 1 1 1 1 1 1 1 0\n",
      " 1 0 0 0 1 1 1 0 0 1 0 1 1]\n",
      "\n",
      "Global Iter=    580 Iter=  580/ 1200 xent=0.10840: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 1 1 0 0 0 1 1 1 1 1 0 1 0 0 1 1 1 1 1 1 1 0 1 1 0 0 1 0 0 1 0 1 1 0 0\n",
      " 1 1 1 0 1 0 0 1 0 0 1 1 1]\n",
      "\n",
      "Global Iter=    590 Iter=  590/ 1200 xent=0.09253: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 1 0 0 0 1 0 1 1 0 1 1 0 1 0 1 0 1 0 0 1 0 0 1 0 0 1 0 1 1 0 1 1 1 1 1\n",
      " 0 0 0 1 0 1 0 0 1 0 1 1 1]\n",
      "\n",
      "Global Iter=    600 Iter=  600/ 1200 xent=0.08204: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 1 0 1 0 1 1 0 1 1 0 0 0 0 0 0 1 0 1 1 1 0 1 1 1 1 1 0 1 0 0 1 1 0 0 0\n",
      " 0 1 0 1 0 1 1 1 0 0 1 1 1]\n",
      "\n",
      "Global Iter=    610 Iter=  610/ 1200 xent=0.11419: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 0 0 0 0 0 0 1 0 0 1 1 1 0 1 1 1 1 1 0 1 1 1 1 1 1 1 1 1 0 0 1 1 0 1 0\n",
      " 1 1 0 1 0 0 1 1 1 1 0 0 0]\n",
      "\n",
      "Global Iter=    620 Iter=  620/ 1200 xent=0.08106: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 0 1 0 0 1 1 0 1 1 1 1 1 0 0 0 0 1 1 1 0 0 1 0 1 1 0 0 0 1 0 0 0 0 0 1\n",
      " 0 1 0 1 1 1 1 1 0 1 1 1 0]\n",
      "\n",
      "Global Iter=    630 Iter=  630/ 1200 xent=0.13204: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 0 1 0 1 0 0 1 1 1 1 0 0 1 0 1 0 0 1 0 1 0 1 1 1 0 1 0 1 0 0 0 0 0 0 1\n",
      " 1 0 0 1 0 0 0 0 0 0 1 0 1]\n",
      "\n",
      "Global Iter=    640 Iter=  640/ 1200 xent=0.10768: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 1 1 1 1 0 1 1 1 1 1 0 0 1 1 1 1 0 1 0 1 0 1 0 1 0 0 0 1 1 1 0 0 1 0 1\n",
      " 1 1 0 0 1 0 0 1 0 0 0 0 0]\n",
      "\n",
      "Global Iter=    650 Iter=  650/ 1200 xent=0.09732: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 0 1 1 1 1 1 0 1 1 0 0 1 1 1 1 0 0 0 0 1 0 1 1 0 1 1 1 1 1 0 0 1 0 1 1\n",
      " 0 0 1 0 1 1 1 0 0 0 0 0 1]\n",
      "\n",
      "Global Iter=    660 Iter=  660/ 1200 xent=0.06262: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 0 1 0 1 1 0 1 0 0 0 1 1 0 0 0 0 0 1 1 1 0 0 1 1 1 0 1 1 1 1 0 0 0 0 0\n",
      " 0 0 1 1 1 0 0 1 1 0 0 0 1]\n",
      "\n",
      "Global Iter=    670 Iter=  670/ 1200 xent=0.14343: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 0 1 0 1 0 1 1 1 0 0 0 1 0 0 1 0 0 1 1 0 0 1 1 0 0 0 1 1 1 1 1 0 0 0 0\n",
      " 0 0 1 0 0 1 1 1 1 0 0 0 0]\n",
      "\n",
      "Global Iter=    680 Iter=  680/ 1200 xent=0.06199: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 0 0 1 1 0 1 0 1 0 0 1 1 0 0 0 1 1 1 0 1 1 0 0 1 0 0 0 1 1 0 1 1 0 1 1 0\n",
      " 1 1 1 0 0 1 1 0 0 1 0 1 1]\n",
      "\n",
      "Global Iter=    690 Iter=  690/ 1200 xent=0.05771: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 1 1 1 1 1 0 0 0 0 0 1 1 0 1 1 1 0 1 0 1 1 0 0 0 0 1 0 0 1 0 1 0 1 1 0\n",
      " 0 0 0 1 1 1 0 1 0 0 0 0 1]\n",
      "\n",
      "Global Iter=    700 Iter=  700/ 1200 xent=0.13137: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 0 0 0 1 0 1 1 0 0 0 1 0 0 1 1 0 1 1 1 1 1 0 0 1 0 0 0 0 1 0 1 0 0 1 0\n",
      " 1 0 1 0 0 0 0 1 1 1 0 0 1]\n",
      "\n",
      "Global Iter=    710 Iter=  710/ 1200 xent=0.07744: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 1 0 0 1 0 0 1 1 0 1 0 1 0 1 1 1 1 0 1 1 0 1 1 0 1 1 0 0 0 0 0 0 1 1 1\n",
      " 0 1 1 0 0 0 1 1 0 1 0 0 1]\n",
      "\n",
      "Global Iter=    720 Iter=  720/ 1200 xent=0.06916: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 1 1 1 1 0 0 1 0 1 1 1 0 0 1 0 0 1 0 1 1 1 1 0 0 1 1 1 0 1 1 1 0 0 1 0\n",
      " 0 1 0 1 0 0 0 0 1 0 0 1 0]\n",
      "\n",
      "Global Iter=    730 Iter=  730/ 1200 xent=0.10092: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 1 0 1 1 1 1 1 0 1 1 1 0 0 0 0 1 1 0 1 0 0 0 1 0 0 0 1 0 1 0 1 0 1 0 1\n",
      " 1 1 0 0 0 1 1 1 0 0 0 0 0]\n",
      "\n",
      "Global Iter=    740 Iter=  740/ 1200 xent=0.07737: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 0 0 1 1 0 0 1 0 1 0 0 0 1 0 0 1 0 0 1 1 0 1 0 0 0 1 1 1 1 0 0 0 0 0 0\n",
      " 1 0 1 1 0 1 0 1 1 1 1 1 0]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Global Iter=    750 Iter=  750/ 1200 xent=0.07894: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 0 1 1 1 0 0 1 1 1 1 0 0 1 1 1 1 1 0 1 1 1 1 0 0 0 0 0 0 0 1 1 1 0 1 1\n",
      " 0 0 0 1 0 1 0 0 1 0 0 0 1]\n",
      "\n",
      "Global Iter=    760 Iter=  760/ 1200 xent=0.08136: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 0 1 1 0 0 0 1 0 0 0 1 0 0 0 0 0 1 0 0 1 1 1 0 0 1 1 1 0 1 1 0 0 0 1 0\n",
      " 1 0 1 0 0 0 0 0 1 0 1 0 0]\n",
      "\n",
      "Global Iter=    770 Iter=  770/ 1200 xent=0.14751: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 0 0 1 1 0 0 1 0 1 0 0 1 1 1 0 1 1 0 1 0 1 1 1 0 1 1 0 1 0 1 0 1 1 1 1\n",
      " 1 1 0 0 1 1 1 0 0 0 1 1 1]\n",
      "\n",
      "Global Iter=    780 Iter=  780/ 1200 xent=0.07671: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 0 1 0 0 0 1 1 0 1 0 0 0 0 1 0 1 1 1 1 1 1 1 1 1 0 0 1 0 0 1 1 1 1 0 1\n",
      " 0 1 0 1 1 0 0 1 1 1 1 0 1]\n",
      "\n",
      "Global Iter=    790 Iter=  790/ 1200 xent=0.07241: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 0 0 1 1 1 0 1 0 0 0 1 0 1 0 0 0 0 1 0 0 0 0 1 1 1 0 0 0 0 1 0 0 1 0 1\n",
      " 1 1 0 1 1 0 1 0 0 0 1 0 0]\n",
      "\n",
      "Global Iter=    800 Iter=  800/ 1200 xent=0.08835: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 1 1 1 0 1 1 0 0 1 1 1 0 0 0 1 0 0 0 1 0 0 1 1 0 1 0 0 0 0 0 1 0 0 1 0\n",
      " 0 1 0 1 1 1 1 1 0 0 1 1 1]\n",
      "\n",
      "Global Iter=    810 Iter=  810/ 1200 xent=0.07039: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 0 1 1 1 1 1 0 0 0 1 1 0 0 0 0 1 1 0 0 0 1 0 1 1 1 1 0 0 1 0 1 1 0 0 1\n",
      " 1 1 0 1 1 0 1 0 0 0 1 0 0]\n",
      "\n",
      "Global Iter=    820 Iter=  820/ 1200 xent=0.13635: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 0 1 1 0 0 0 0 0 0 1 0 1 0 1 1 0 1 1 0 1 0 0 0 0 0 0 1 1 0 0 0 0 0 0 0\n",
      " 0 0 0 0 0 0 0 1 1 0 0 1 1]\n",
      "\n",
      "Global Iter=    830 Iter=  830/ 1200 xent=0.07703: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 0 0 0 1 1 1 1 0 0 0 1 1 0 1 0 0 0 0 1 1 1 0 0 0 1 1 0 0 1 1 0 0 1 0 1 0\n",
      " 1 1 1 0 0 1 1 0 1 1 1 1 1]\n",
      "\n",
      "Global Iter=    840 Iter=  840/ 1200 xent=0.08158: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 1 0 0 1 0 1 1 1 1 0 0 0 1 1 1 1 1 0 0 1 0 0 1 0 1 1 0 1 1 1 0 1 0 1 1\n",
      " 0 1 0 1 0 0 1 1 0 1 1 1 0]\n",
      "\n",
      "Global Iter=    850 Iter=  850/ 1200 xent=0.16907: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 1 1 0 0 0 0 1 0 1 0 0 1 1 0 1 0 0 0 0 0 0 1 0 0 1 1 1 0 1 1 1 1 0 0 0\n",
      " 0 1 0 1 0 1 1 1 0 0 0 1 0]\n",
      "\n",
      "Global Iter=    860 Iter=  860/ 1200 xent=0.08382: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 0 1 1 1 1 0 1 1 1 1 1 0 1 1 1 1 0 0 0 1 1 1 0 1 1 1 0 1 0 0 0 0 0 0 0\n",
      " 1 0 1 0 1 0 0 1 0 1 0 1 0]\n",
      "\n",
      "Global Iter=    870 Iter=  870/ 1200 xent=0.07799: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 1 1 0 0 0 1 0 1 1 0 1 1 1 1 1 0 0 1 0 1 0 0 1 0 1 1 0 0 1 1 0 1 0 0 1\n",
      " 1 0 1 1 1 1 1 1 0 1 0 0 0]\n",
      "\n",
      "Global Iter=    880 Iter=  880/ 1200 xent=0.09140: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 0 0 0 0 1 1 0 1 1 0 1 0 0 0 1 0 0 0 1 0 1 0 0 0 1 0 0 0 0 0 0 0 0 0 0\n",
      " 1 1 0 1 1 1 1 1 0 0 0 0 0]\n",
      "\n",
      "Global Iter=    890 Iter=  890/ 1200 xent=0.07672: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 0 1 1 1 0 1 1 0 1 0 0 1 1 1 0 0 1 1 1 1 1 0 0 1 1 0 0 0 0 0 1 0 0 1 0 1\n",
      " 0 0 0 1 0 0 0 1 1 0 1 1 0]\n",
      "\n",
      "Global Iter=    900 Iter=  900/ 1200 xent=0.09816: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 1 1 1 0 1 0 0 1 1 1 0 0 1 0 0 1 1 0 0 0 0 1 1 0 0 1 1 1 1 0 0 1 1 1 1\n",
      " 1 0 1 0 1 1 0 0 0 0 0 0 1]\n",
      "\n",
      "Global Iter=    910 Iter=  910/ 1200 xent=0.08781: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 0 0 0 1 1 1 0 1 0 1 1 0 1 0 1 1 0 0 1 0 1 1 1 0 1 1 0 0 0 0 1 0 0 1 1\n",
      " 0 1 1 0 1 0 0 0 1 1 0 1 0]\n",
      "\n",
      "Global Iter=    920 Iter=  920/ 1200 xent=0.08546: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 0 1 1 1 1 0 1 1 1 0 0 1 0 0 1 1 0 0 1 0 1 0 0 0 0 1 0 1 0 1 0 0 0 1 1\n",
      " 0 0 1 0 0 0 0 0 0 0 0 1 0]\n",
      "\n",
      "Global Iter=    930 Iter=  930/ 1200 xent=0.08929: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 0 0 0 1 1 1 0 1 1 1 0 0 0 1 0 1 0 0 0 1 1 1 1 1 1 1 1 1 1 1 1 0 0 0 0 1\n",
      " 1 0 1 1 0 1 1 1 0 1 1 1 1]\n",
      "\n",
      "Global Iter=    940 Iter=  940/ 1200 xent=0.08034: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 0 1 1 1 0 0 0 0 0 0 1 0 0 0 1 0 0 0 1 1 0 1 0 1 1 1 0 1 1 0 0 0 0 1 1 0\n",
      " 1 1 0 0 1 0 1 0 0 1 1 1 0]\n",
      "\n",
      "Global Iter=    950 Iter=  950/ 1200 xent=0.06437: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 1 0 0 0 0 1 1 1 1 1 1 1 0 1 1 0 1 1 0 1 1 1 1 0 1 0 1 1 1 0 0 0 0 0 0\n",
      " 1 0 1 1 1 1 1 0 1 1 0 0 0]\n",
      "\n",
      "Global Iter=    960 Iter=  960/ 1200 xent=0.08116: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 0 1 1 1 0 0 0 0 1 1 1 1 1 0 1 0 0 0 0 0 1 1 1 0 1 0 1 1 0 1 1 0 1 1 1 0\n",
      " 0 1 1 1 0 1 0 1 1 1 1 0 1]\n",
      "\n",
      "Global Iter=    970 Iter=  970/ 1200 xent=0.09419: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 0 1 0 0 1 0 0 0 0 1 1 1 0 1 0 1 1 1 0 0 0 0 1 0 1 0 0 0 1 1 1 1 1 0 0\n",
      " 0 1 0 1 0 1 0 1 1 1 0 0 0]\n",
      "\n",
      "Global Iter=    980 Iter=  980/ 1200 xent=0.09533: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 0 0 0 1 0 1 0 1 0 1 1 1 0 1 1 1 0 1 0 1 0 0 0 0 0 1 0 0 1 0 1 1 1 0 0 1\n",
      " 1 0 0 1 1 0 1 0 0 0 1 0 0]\n",
      "\n",
      "Global Iter=    990 Iter=  990/ 1200 xent=0.10745: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 0 0 1 0 0 0 0 0 0 1 0 1 1 0 1 0 1 1 0 0 0 0 1 1 1 0 0 0 0 0 0 0 0 0 0\n",
      " 1 1 1 1 1 0 1 0 1 1 0 1 0]\n",
      "\n",
      "Global Iter=   1000 Iter= 1000/ 1200 xent=0.07515: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 0 0 0 1 0 0 0 1 0 1 1 0 0 0 0 0 1 1 1 1 1 0 1 1 1 0 1 0 0 0 0 1 0 0 1 1\n",
      " 1 0 0 0 1 1 1 1 1 0 0 1 0]\n",
      "\n",
      "Global Iter=   1010 Iter= 1010/ 1200 xent=0.11981: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 0 0 0 0 1 1 0 0 0 1 1 0 0 1 0 0 0 1 0 1 0 1 1 0 1 0 1 1 1 1 0 1 1 0 0\n",
      " 1 1 0 0 1 1 0 1 1 1 0 0 0]\n",
      "\n",
      "Global Iter=   1020 Iter= 1020/ 1200 xent=0.06190: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 1 1 0 1 0 0 1 1 1 1 0 0 1 1 1 0 0 0 1 1 1 0 1 0 0 0 1 1 0 0 0 1 1 1 1\n",
      " 1 1 1 1 1 1 0 0 1 1 1 0 1]\n",
      "\n",
      "Global Iter=   1030 Iter= 1030/ 1200 xent=0.14446: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 0 0 1 1 0 1 1 0 1 0 1 0 1 0 1 1 0 1 1 0 0 0 0 1 0 0 1 0 1 1 0 0 1 0 1\n",
      " 0 1 1 1 0 0 1 1 0 1 1 0 1]\n",
      "\n",
      "Global Iter=   1040 Iter= 1040/ 1200 xent=0.07891: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 0 0 1 1 0 1 0 1 0 0 1 0 1 1 1 0 0 0 0 0 0 1 1 1 0 0 1 1 1 1 1 1 1 0 1\n",
      " 0 1 1 0 0 0 0 1 0 0 1 1 1]\n",
      "\n",
      "Global Iter=   1050 Iter= 1050/ 1200 xent=0.09269: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 0 1 0 1 1 0 0 1 0 1 0 1 0 0 0 1 0 0 0 1 1 0 1 1 1 0 1 1 0 1 1 0 0 0 0\n",
      " 1 0 1 0 0 1 1 0 0 0 0 1 1]\n",
      "\n",
      "Global Iter=   1060 Iter= 1060/ 1200 xent=0.10440: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 1 1 0 1 1 1 1 0 0 0 1 0 0 1 1 0 0 1 1 0 1 0 1 1 0 1 1 0 1 1 0 0 1 1 0\n",
      " 0 0 0 0 0 1 1 0 0 0 1 1 0]\n",
      "\n",
      "Global Iter=   1070 Iter= 1070/ 1200 xent=0.06154: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 0 1 0 1 1 0 1 0 1 1 0 0 0 1 0 0 1 0 0 1 0 0 1 1 0 1 0 1 1 0 0 1 1 1 0\n",
      " 0 1 1 0 0 0 0 0 0 0 0 0 0]\n",
      "\n",
      "Global Iter=   1080 Iter= 1080/ 1200 xent=0.07213: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 1 1 0 1 1 1 0 0 0 1 1 1 0 1 0 0 1 1 0 0 0 1 0 1 1 0 1 1 1 0 0 0 0 1 1\n",
      " 1 1 1 0 0 1 1 1 0 0 1 0 1]\n",
      "\n",
      "Global Iter=   1090 Iter= 1090/ 1200 xent=0.11748: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 1 0 0 1 0 0 0 0 1 1 1 0 0 1 0 0 1 0 0 1 0 0 0 0 1 1 1 0 0 0 1 0 0 1 0\n",
      " 1 1 1 0 0 1 1 0 1 1 1 0 1]\n",
      "\n",
      "Global Iter=   1100 Iter= 1100/ 1200 xent=0.08815: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 1 1 0 0 0 1 1 1 1 1 1 0 0 1 1 1 1 1 0 0 1 0 1 0 0 1 0 1 0 1 1 1 0 1 1\n",
      " 1 0 0 0 1 1 0 0 0 1 0 1 0]\n",
      "\n",
      "Global Iter=   1110 Iter= 1110/ 1200 xent=0.07748: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 0 1 1 0 0 1 1 1 1 1 1 0 1 0 1 1 0 1 1 1 1 1 0 1 1 0 0 0 1 1 1 1 1 0 1\n",
      " 1 1 1 0 1 1 1 0 1 1 0 0 1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Global Iter=   1120 Iter= 1120/ 1200 xent=0.17395: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 1 0 1 1 0 0 1 0 1 1 1 1 0 0 1 0 0 1 1 1 0 1 1 1 0 1 0 1 0 0 1 0 1 0 1\n",
      " 0 1 0 0 1 0 1 1 0 0 1 0 0]\n",
      "\n",
      "Global Iter=   1130 Iter= 1130/ 1200 xent=0.14167: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 0 1 0 0 1 0 0 1 1 0 0 1 1 0 1 1 1 1 1 0 0 1 0 0 0 1 0 1 0 0 0 0 1 1 0\n",
      " 0 0 1 0 1 0 0 0 0 1 1 1 0]\n",
      "\n",
      "Global Iter=   1140 Iter= 1140/ 1200 xent=0.09108: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 1 0 0 0 0 1 0 0 1 0 1 1 0 0 1 1 0 1 1 0 1 1 0 0 1 0 1 1 1 1 0 1 1 1 1\n",
      " 0 0 1 0 0 0 0 0 0 0 1 0 1]\n",
      "\n",
      "Global Iter=   1150 Iter= 1150/ 1200 xent=0.12183: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 0 0 1 0 1 0 0 1 0 1 1 0 1 0 1 1 0 1 1 0 0 0 1 1 1 0 1 0 1 1 0 1 1 1 0\n",
      " 1 1 0 1 0 0 1 0 1 1 1 1 0]\n",
      "\n",
      "Global Iter=   1160 Iter= 1160/ 1200 xent=0.11861: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 0 1 0 1 1 0 0 0 0 0 0 1 0 0 1 0 1 0 1 0 1 1 1 1 1 1 0 1 1 0 0 1 1 1 1\n",
      " 0 1 1 0 0 0 0 0 1 0 1 1 1]\n",
      "\n",
      "Global Iter=   1170 Iter= 1170/ 1200 xent=0.08380: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 1 0 0 1 0 1 0 0 0 1 0 0 0 1 1 0 0 1 1 0 0 1 1 0 1 1 1 1 0 1 1 1 1 1 1\n",
      " 1 0 1 1 0 1 1 0 1 0 0 0 0]\n",
      "\n",
      "Global Iter=   1180 Iter= 1180/ 1200 xent=0.07368: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 0 0 0 0 0 0 1 1 1 1 1 0 1 1 1 1 1 0 0 1 1 0 1 0 0 1 1 1 1 1 0 0 1 0 0 1\n",
      " 0 1 1 1 1 1 0 1 1 1 1 1 1]\n",
      "\n",
      "Global Iter=   1190 Iter= 1190/ 1200 xent=0.08047: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[1 1 0 1 1 0 1 1 1 1 1 0 1 0 0 1 1 0 0 0 1 1 1 1 1 1 1 1 0 1 1 0 1 0 1 1 0\n",
      " 0 1 0 1 0 1 1 1 0 1 1 0 1]\n",
      "\n",
      "Global Iter=   1200 Iter= 1200/ 1200 xent=0.09719: writing ./data-directory/nosaic_mnist_feat_train.tfrecords\n",
      "(20, 128)\n",
      "[0 1 0 0 0 0 0 1 1 1 1 0 0 1 0 1 0 1 1 0 0 0 1 1 0 0 0 0 1 0 0 0 0 1 0 1 1\n",
      " 0 1 1 0 0 0 0 0 1 0 0 0 1]\n",
      "Done\n"
     ]
    }
   ],
   "source": [
    "# Feature Extraction and Save TFR\n",
    "parsed_image_datasets = [parsed_image_dataset_train]\n",
    "record_files = [tfr_feat_train]\n",
    "list_numdata = [60000] # = train 50000 + valid 10000\n",
    "\n",
    "ext_and_save(parsed_image_datasets, record_files, list_numdata)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### <font color=red>Extraction done. See ./data-directory</font>"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Appendix: Read Feature TFR"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Runs without error only after saving `tfr_feat_train` and `tfr_feat_test`."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "import time"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iter 100\n",
      "iter 200\n",
      "iter 300\n",
      "iter 400\n",
      "iter 500\n",
      "iter 600\n",
      "iter 700\n",
      "iter 800\n",
      "iter 900\n",
      "iter 1000\n",
      "iter 1100\n",
      "iter 1200\n",
      "iter 1300\n",
      "iter 1400\n",
      "iter 1500\n",
      "iter 1600\n",
      "iter 1700\n",
      "iter 1800\n",
      "iter 1900\n",
      "iter 2000\n",
      "iter 2100\n",
      "iter 2200\n",
      "iter 2300\n",
      "iter 2400\n",
      "iter 2500\n",
      "iter 2600\n",
      "iter 2700\n",
      "iter 2800\n",
      "iter 2900\n",
      "iter 3000\n",
      "iter 3100\n",
      "iter 3200\n",
      "iter 3300\n",
      "iter 3400\n",
      "iter 3500\n",
      "iter 3600\n",
      "iter 3700\n",
      "iter 3800\n",
      "iter 3900\n",
      "iter 4000\n",
      "iter 4100\n",
      "iter 4200\n",
      "iter 4300\n",
      "iter 4400\n",
      "iter 4500\n",
      "iter 4600\n",
      "iter 4700\n",
      "iter 4800\n",
      "iter 4900\n",
      "iter 5000\n",
      "iter 5100\n",
      "iter 5200\n",
      "iter 5300\n",
      "iter 5400\n",
      "iter 5500\n",
      "iter 5600\n",
      "iter 5700\n",
      "iter 5800\n",
      "iter 5900\n",
      "iter 6000\n",
      "iter 6100\n",
      "iter 6200\n",
      "iter 6300\n",
      "iter 6400\n",
      "iter 6500\n",
      "iter 6600\n",
      "iter 6700\n",
      "iter 6800\n",
      "iter 6900\n",
      "iter 7000\n",
      "iter 7100\n",
      "iter 7200\n",
      "iter 7300\n",
      "iter 7400\n",
      "iter 7500\n",
      "iter 7600\n",
      "iter 7700\n",
      "iter 7800\n",
      "iter 7900\n",
      "iter 8000\n",
      "iter 8100\n",
      "iter 8200\n",
      "iter 8300\n",
      "iter 8400\n",
      "iter 8500\n",
      "iter 8600\n",
      "iter 8700\n",
      "iter 8800\n",
      "iter 8900\n",
      "iter 9000\n",
      "iter 9100\n",
      "iter 9200\n",
      "iter 9300\n",
      "iter 9400\n",
      "iter 9500\n",
      "iter 9600\n",
      "iter 9700\n",
      "iter 9800\n",
      "iter 9900\n",
      "iter 10000\n",
      "=================================\n",
      "total num of validation datapoints:  10000\n",
      "iter 100\n",
      "iter 200\n",
      "iter 300\n",
      "iter 400\n",
      "iter 500\n",
      "iter 600\n",
      "iter 700\n",
      "iter 800\n",
      "iter 900\n",
      "iter 1000\n",
      "iter 1100\n",
      "iter 1200\n",
      "iter 1300\n",
      "iter 1400\n",
      "iter 1500\n",
      "iter 1600\n",
      "iter 1700\n",
      "iter 1800\n",
      "iter 1900\n",
      "iter 2000\n",
      "iter 2100\n",
      "iter 2200\n",
      "iter 2300\n",
      "iter 2400\n",
      "iter 2500\n",
      "iter 2600\n",
      "iter 2700\n",
      "iter 2800\n",
      "iter 2900\n",
      "iter 3000\n",
      "iter 3100\n",
      "iter 3200\n",
      "iter 3300\n",
      "iter 3400\n",
      "iter 3500\n",
      "iter 3600\n",
      "iter 3700\n",
      "iter 3800\n",
      "iter 3900\n",
      "iter 4000\n",
      "iter 4100\n",
      "iter 4200\n",
      "iter 4300\n",
      "iter 4400\n",
      "iter 4500\n",
      "iter 4600\n",
      "iter 4700\n",
      "iter 4800\n",
      "iter 4900\n",
      "iter 5000\n",
      "iter 5100\n",
      "iter 5200\n",
      "iter 5300\n",
      "iter 5400\n",
      "iter 5500\n",
      "iter 5600\n",
      "iter 5700\n",
      "iter 5800\n",
      "iter 5900\n",
      "iter 6000\n",
      "iter 6100\n",
      "iter 6200\n",
      "iter 6300\n",
      "iter 6400\n",
      "iter 6500\n",
      "iter 6600\n",
      "iter 6700\n",
      "iter 6800\n",
      "iter 6900\n",
      "iter 7000\n",
      "iter 7100\n",
      "iter 7200\n",
      "iter 7300\n",
      "iter 7400\n",
      "iter 7500\n",
      "iter 7600\n",
      "iter 7700\n",
      "iter 7800\n",
      "iter 7900\n",
      "iter 8000\n",
      "iter 8100\n",
      "iter 8200\n",
      "iter 8300\n",
      "iter 8400\n",
      "iter 8500\n",
      "iter 8600\n",
      "iter 8700\n",
      "iter 8800\n",
      "iter 8900\n",
      "iter 9000\n",
      "iter 9100\n",
      "iter 9200\n",
      "iter 9300\n",
      "iter 9400\n",
      "iter 9500\n",
      "iter 9600\n",
      "iter 9700\n",
      "iter 9800\n",
      "iter 9900\n",
      "iter 10000\n",
      "=================================\n",
      "total num of test datapoints:  10000\n",
      "iter 100\n",
      "iter 200\n",
      "iter 300\n",
      "iter 400\n",
      "iter 500\n",
      "iter 600\n",
      "iter 700\n",
      "iter 800\n",
      "iter 900\n",
      "iter 1000\n",
      "iter 1100\n",
      "iter 1200\n",
      "iter 1300\n",
      "iter 1400\n",
      "iter 1500\n",
      "iter 1600\n",
      "iter 1700\n",
      "iter 1800\n",
      "iter 1900\n",
      "iter 2000\n",
      "iter 2100\n",
      "iter 2200\n",
      "iter 2300\n",
      "iter 2400\n",
      "iter 2500\n",
      "iter 2600\n",
      "iter 2700\n",
      "iter 2800\n",
      "iter 2900\n",
      "iter 3000\n",
      "iter 3100\n",
      "iter 3200\n",
      "iter 3300\n",
      "iter 3400\n",
      "iter 3500\n",
      "iter 3600\n",
      "iter 3700\n",
      "iter 3800\n",
      "iter 3900\n",
      "iter 4000\n",
      "iter 4100\n",
      "iter 4200\n",
      "iter 4300\n",
      "iter 4400\n",
      "iter 4500\n",
      "iter 4600\n",
      "iter 4700\n",
      "iter 4800\n",
      "iter 4900\n",
      "iter 5000\n",
      "iter 5100\n",
      "iter 5200\n",
      "iter 5300\n",
      "iter 5400\n",
      "iter 5500\n",
      "iter 5600\n",
      "iter 5700\n",
      "iter 5800\n",
      "iter 5900\n",
      "iter 6000\n",
      "iter 6100\n",
      "iter 6200\n",
      "iter 6300\n",
      "iter 6400\n",
      "iter 6500\n",
      "iter 6600\n",
      "iter 6700\n",
      "iter 6800\n",
      "iter 6900\n",
      "iter 7000\n",
      "iter 7100\n",
      "iter 7200\n",
      "iter 7300\n",
      "iter 7400\n",
      "iter 7500\n",
      "iter 7600\n",
      "iter 7700\n",
      "iter 7800\n",
      "iter 7900\n",
      "iter 8000\n",
      "iter 8100\n",
      "iter 8200\n",
      "iter 8300\n",
      "iter 8400\n",
      "iter 8500\n",
      "iter 8600\n",
      "iter 8700\n",
      "iter 8800\n",
      "iter 8900\n",
      "iter 9000\n",
      "iter 9100\n",
      "iter 9200\n",
      "iter 9300\n",
      "iter 9400\n",
      "iter 9500\n",
      "iter 9600\n",
      "iter 9700\n",
      "iter 9800\n",
      "iter 9900\n",
      "iter 10000\n",
      "iter 10100\n",
      "iter 10200\n",
      "iter 10300\n",
      "iter 10400\n",
      "iter 10500\n",
      "iter 10600\n",
      "iter 10700\n",
      "iter 10800\n",
      "iter 10900\n",
      "iter 11000\n",
      "iter 11100\n",
      "iter 11200\n",
      "iter 11300\n",
      "iter 11400\n",
      "iter 11500\n",
      "iter 11600\n",
      "iter 11700\n",
      "iter 11800\n",
      "iter 11900\n",
      "iter 12000\n",
      "iter 12100\n",
      "iter 12200\n",
      "iter 12300\n",
      "iter 12400\n",
      "iter 12500\n",
      "iter 12600\n",
      "iter 12700\n",
      "iter 12800\n",
      "iter 12900\n",
      "iter 13000\n",
      "iter 13100\n",
      "iter 13200\n",
      "iter 13300\n",
      "iter 13400\n",
      "iter 13500\n",
      "iter 13600\n",
      "iter 13700\n",
      "iter 13800\n",
      "iter 13900\n",
      "iter 14000\n",
      "iter 14100\n",
      "iter 14200\n",
      "iter 14300\n",
      "iter 14400\n",
      "iter 14500\n",
      "iter 14600\n",
      "iter 14700\n",
      "iter 14800\n",
      "iter 14900\n",
      "iter 15000\n",
      "iter 15100\n",
      "iter 15200\n",
      "iter 15300\n",
      "iter 15400\n",
      "iter 15500\n",
      "iter 15600\n",
      "iter 15700\n",
      "iter 15800\n",
      "iter 15900\n",
      "iter 16000\n",
      "iter 16100\n",
      "iter 16200\n",
      "iter 16300\n",
      "iter 16400\n",
      "iter 16500\n",
      "iter 16600\n",
      "iter 16700\n",
      "iter 16800\n",
      "iter 16900\n",
      "iter 17000\n",
      "iter 17100\n",
      "iter 17200\n",
      "iter 17300\n",
      "iter 17400\n",
      "iter 17500\n",
      "iter 17600\n",
      "iter 17700\n",
      "iter 17800\n",
      "iter 17900\n",
      "iter 18000\n",
      "iter 18100\n",
      "iter 18200\n",
      "iter 18300\n",
      "iter 18400\n",
      "iter 18500\n",
      "iter 18600\n",
      "iter 18700\n",
      "iter 18800\n",
      "iter 18900\n",
      "iter 19000\n",
      "iter 19100\n",
      "iter 19200\n",
      "iter 19300\n",
      "iter 19400\n",
      "iter 19500\n",
      "iter 19600\n",
      "iter 19700\n",
      "iter 19800\n",
      "iter 19900\n",
      "iter 20000\n",
      "iter 20100\n",
      "iter 20200\n",
      "iter 20300\n",
      "iter 20400\n",
      "iter 20500\n",
      "iter 20600\n",
      "iter 20700\n",
      "iter 20800\n",
      "iter 20900\n",
      "iter 21000\n",
      "iter 21100\n",
      "iter 21200\n",
      "iter 21300\n",
      "iter 21400\n",
      "iter 21500\n",
      "iter 21600\n",
      "iter 21700\n",
      "iter 21800\n",
      "iter 21900\n",
      "iter 22000\n",
      "iter 22100\n",
      "iter 22200\n",
      "iter 22300\n",
      "iter 22400\n",
      "iter 22500\n",
      "iter 22600\n",
      "iter 22700\n",
      "iter 22800\n",
      "iter 22900\n",
      "iter 23000\n",
      "iter 23100\n",
      "iter 23200\n",
      "iter 23300\n",
      "iter 23400\n",
      "iter 23500\n",
      "iter 23600\n",
      "iter 23700\n",
      "iter 23800\n",
      "iter 23900\n",
      "iter 24000\n",
      "iter 24100\n",
      "iter 24200\n",
      "iter 24300\n",
      "iter 24400\n",
      "iter 24500\n",
      "iter 24600\n",
      "iter 24700\n",
      "iter 24800\n",
      "iter 24900\n",
      "iter 25000\n",
      "iter 25100\n",
      "iter 25200\n",
      "iter 25300\n",
      "iter 25400\n",
      "iter 25500\n",
      "iter 25600\n",
      "iter 25700\n",
      "iter 25800\n",
      "iter 25900\n",
      "iter 26000\n",
      "iter 26100\n",
      "iter 26200\n",
      "iter 26300\n",
      "iter 26400\n",
      "iter 26500\n",
      "iter 26600\n",
      "iter 26700\n",
      "iter 26800\n",
      "iter 26900\n",
      "iter 27000\n",
      "iter 27100\n",
      "iter 27200\n",
      "iter 27300\n",
      "iter 27400\n",
      "iter 27500\n",
      "iter 27600\n",
      "iter 27700\n",
      "iter 27800\n",
      "iter 27900\n",
      "iter 28000\n",
      "iter 28100\n",
      "iter 28200\n",
      "iter 28300\n",
      "iter 28400\n",
      "iter 28500\n",
      "iter 28600\n",
      "iter 28700\n",
      "iter 28800\n",
      "iter 28900\n",
      "iter 29000\n",
      "iter 29100\n",
      "iter 29200\n",
      "iter 29300\n",
      "iter 29400\n",
      "iter 29500\n",
      "iter 29600\n",
      "iter 29700\n",
      "iter 29800\n",
      "iter 29900\n",
      "iter 30000\n",
      "iter 30100\n",
      "iter 30200\n",
      "iter 30300\n",
      "iter 30400\n",
      "iter 30500\n",
      "iter 30600\n",
      "iter 30700\n",
      "iter 30800\n",
      "iter 30900\n",
      "iter 31000\n",
      "iter 31100\n",
      "iter 31200\n",
      "iter 31300\n",
      "iter 31400\n",
      "iter 31500\n",
      "iter 31600\n",
      "iter 31700\n",
      "iter 31800\n",
      "iter 31900\n",
      "iter 32000\n",
      "iter 32100\n",
      "iter 32200\n",
      "iter 32300\n",
      "iter 32400\n",
      "iter 32500\n",
      "iter 32600\n",
      "iter 32700\n",
      "iter 32800\n",
      "iter 32900\n",
      "iter 33000\n",
      "iter 33100\n",
      "iter 33200\n",
      "iter 33300\n",
      "iter 33400\n",
      "iter 33500\n",
      "iter 33600\n",
      "iter 33700\n",
      "iter 33800\n",
      "iter 33900\n",
      "iter 34000\n",
      "iter 34100\n",
      "iter 34200\n",
      "iter 34300\n",
      "iter 34400\n",
      "iter 34500\n",
      "iter 34600\n",
      "iter 34700\n",
      "iter 34800\n",
      "iter 34900\n",
      "iter 35000\n",
      "iter 35100\n",
      "iter 35200\n",
      "iter 35300\n",
      "iter 35400\n",
      "iter 35500\n",
      "iter 35600\n",
      "iter 35700\n",
      "iter 35800\n",
      "iter 35900\n",
      "iter 36000\n",
      "iter 36100\n",
      "iter 36200\n",
      "iter 36300\n",
      "iter 36400\n",
      "iter 36500\n",
      "iter 36600\n",
      "iter 36700\n",
      "iter 36800\n",
      "iter 36900\n",
      "iter 37000\n",
      "iter 37100\n",
      "iter 37200\n",
      "iter 37300\n",
      "iter 37400\n",
      "iter 37500\n",
      "iter 37600\n",
      "iter 37700\n",
      "iter 37800\n",
      "iter 37900\n",
      "iter 38000\n",
      "iter 38100\n",
      "iter 38200\n",
      "iter 38300\n",
      "iter 38400\n",
      "iter 38500\n",
      "iter 38600\n",
      "iter 38700\n",
      "iter 38800\n",
      "iter 38900\n",
      "iter 39000\n",
      "iter 39100\n",
      "iter 39200\n",
      "iter 39300\n",
      "iter 39400\n",
      "iter 39500\n",
      "iter 39600\n",
      "iter 39700\n",
      "iter 39800\n",
      "iter 39900\n",
      "iter 40000\n",
      "iter 40100\n",
      "iter 40200\n",
      "iter 40300\n",
      "iter 40400\n",
      "iter 40500\n",
      "iter 40600\n",
      "iter 40700\n",
      "iter 40800\n",
      "iter 40900\n",
      "iter 41000\n",
      "iter 41100\n",
      "iter 41200\n",
      "iter 41300\n",
      "iter 41400\n",
      "iter 41500\n",
      "iter 41600\n",
      "iter 41700\n",
      "iter 41800\n",
      "iter 41900\n",
      "iter 42000\n",
      "iter 42100\n",
      "iter 42200\n",
      "iter 42300\n",
      "iter 42400\n",
      "iter 42500\n",
      "iter 42600\n",
      "iter 42700\n",
      "iter 42800\n",
      "iter 42900\n",
      "iter 43000\n",
      "iter 43100\n",
      "iter 43200\n",
      "iter 43300\n",
      "iter 43400\n",
      "iter 43500\n",
      "iter 43600\n",
      "iter 43700\n",
      "iter 43800\n",
      "iter 43900\n",
      "iter 44000\n",
      "iter 44100\n",
      "iter 44200\n",
      "iter 44300\n",
      "iter 44400\n",
      "iter 44500\n",
      "iter 44600\n",
      "iter 44700\n",
      "iter 44800\n",
      "iter 44900\n",
      "iter 45000\n",
      "iter 45100\n",
      "iter 45200\n",
      "iter 45300\n",
      "iter 45400\n",
      "iter 45500\n",
      "iter 45600\n",
      "iter 45700\n",
      "iter 45800\n",
      "iter 45900\n",
      "iter 46000\n",
      "iter 46100\n",
      "iter 46200\n",
      "iter 46300\n",
      "iter 46400\n",
      "iter 46500\n",
      "iter 46600\n",
      "iter 46700\n",
      "iter 46800\n",
      "iter 46900\n",
      "iter 47000\n",
      "iter 47100\n",
      "iter 47200\n",
      "iter 47300\n",
      "iter 47400\n",
      "iter 47500\n",
      "iter 47600\n",
      "iter 47700\n",
      "iter 47800\n",
      "iter 47900\n",
      "iter 48000\n",
      "iter 48100\n",
      "iter 48200\n",
      "iter 48300\n",
      "iter 48400\n",
      "iter 48500\n",
      "iter 48600\n",
      "iter 48700\n",
      "iter 48800\n",
      "iter 48900\n",
      "iter 49000\n",
      "iter 49100\n",
      "iter 49200\n",
      "iter 49300\n",
      "iter 49400\n",
      "iter 49500\n",
      "iter 49600\n",
      "iter 49700\n",
      "iter 49800\n",
      "iter 49900\n",
      "iter 50000\n",
      "=================================\n",
      "total num of training datapoints:  50000\n"
     ]
    }
   ],
   "source": [
    "# Read Feature TFR\n",
    "feat_dim = final_size\n",
    "bs_tmp = 1\n",
    "dtype_feat = tf.float32\n",
    "dtype_label = tf.int32\n",
    "pid_tr, pid_val, pid_test =\\\n",
    "    read_tfrecords_nosaic_mnist(tfr_feat_train, tfr_feat_test, bs_tmp)\n",
    "\n",
    "# Show\n",
    "show_pid = pid_val\n",
    "for i, features in enumerate(show_pid):\n",
    "    vb, lb = decode_feat(features, duration, feat_dim, dtype_feat=tf.float32, dtype_label=tf.int32)\n",
    "    if (i+1) % 100 == 0:\n",
    "        #time.sleep(0.01)\n",
    "        print(\"iter {}\".format(i+1))\n",
    "        #print(vb)\n",
    "        #print(lb)\n",
    "print(\"=================================\\ntotal num of validation datapoints: \", i+1)\n",
    "\n",
    "show_pid = pid_test\n",
    "for i, features in enumerate(show_pid):\n",
    "    vb, lb = decode_feat(features, duration, feat_dim, dtype_feat=tf.float32, dtype_label=tf.int32)\n",
    "    if (i+1) % 100 == 0:\n",
    "        #time.sleep(0.01)\n",
    "        print(\"iter {}\".format(i+1))\n",
    "        #print(vb)\n",
    "        #print(lb)\n",
    "print(\"=================================\\ntotal num of test datapoints: \", i+1)\n",
    "\n",
    "show_pid = pid_tr\n",
    "for i, features in enumerate(show_pid):\n",
    "    vb, lb = decode_feat(features, duration, feat_dim, dtype_feat=tf.float32, dtype_label=tf.int32)\n",
    "    if (i+1) % 100 == 0:\n",
    "        #time.sleep(0.01)\n",
    "        print(\"iter {}\".format(i+1))\n",
    "        #print(vb)\n",
    "        #print(lb)\n",
    "print(\"=================================\\ntotal num of training datapoints: \", i+1)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.5.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
