{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "heading_collapsed": true
   },
   "source": [
    "# Code"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "hidden": true
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import random\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.metrics.pairwise import euclidean_distances\n",
    "from numpy import linalg as LA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "hidden": true
   },
   "outputs": [],
   "source": [
    "def unpickle(file):\n",
    "    import pickle\n",
    "    with open(file, 'rb') as fo:\n",
    "        dict = pickle.load(fo, encoding='bytes')\n",
    "    return dict\n",
    "\n",
    "def kpp2_opt(data, k, d): \n",
    "    ''' \n",
    "    initialized the centroids for K-means++ \n",
    "    inputs: \n",
    "        data - numpy array of data points\n",
    "        k - number of clusters  \n",
    "    '''\n",
    "    ## initialize the centroids list and add \n",
    "    ## a randomly selected data point to the list \n",
    "    n = data.shape[0]\n",
    "    centroids = np.zeros((k, d))\n",
    "    centroids_idx = np.random.randint(n)\n",
    "    centroids[0,:] = data[centroids_idx, :]\n",
    "    seen = {centroids_idx}\n",
    "   \n",
    "    ## compute remaining k - 1 centroids \n",
    "    for c_id in range(k - 1): \n",
    "          \n",
    "        ## initialize a list to store distances of data \n",
    "        ## points from nearest centroid \n",
    "    \n",
    "        dist = (euclidean_distances(points, centroids[0:c_id+1, :])**2).min(axis = 1)\n",
    "        probabilities = dist/dist.sum()\n",
    "        sampled_center = int(np.random.choice(n, p=probabilities, size=1))\n",
    "        while sampled_center in seen:\n",
    "            sampled_center = int(np.random.choice(n, p=probabilities, size=1))\n",
    "        seen.add(sampled_center)\n",
    "        next_centroid = data[sampled_center, :] \n",
    "        centroids[c_id+1,:] = next_centroid\n",
    "    return centroids \n",
    "\n",
    "\n",
    "def distance(p1, p2): \n",
    "    return np.sum((p1 - p2)**2) \n",
    "\n",
    "\n",
    "\n",
    "\n",
    "# return k means cost given centers\n",
    "def k_means_cost(points, centers):\n",
    "    distance = euclidean_distances(points, centers)\n",
    "    distance = distance**2\n",
    "    labels = np.argmin(distance, axis=1)\n",
    "    return labels, np.min(distance, axis = 1).sum()\n",
    "\n",
    "def kmeans_cost_label(points, labels, d, num_labels):\n",
    "    centers = np.zeros((num_labels, d))\n",
    "    good_indices = []\n",
    "    for i in range(num_labels):\n",
    "        to_index = np.where(labels == i)[0]\n",
    "        if len(to_index) > 0:\n",
    "            curr_points = points[to_index]\n",
    "            centers[i,:] = np.average(curr_points, axis = 0)\n",
    "            good_indices.append(i)\n",
    "        else:\n",
    "            pass\n",
    "    centers = centers[good_indices,:]\n",
    "        \n",
    "    return k_means_cost(points, centers)\n",
    "       \n",
    "# return k means labels given centers\n",
    "\n",
    "def k_means_labels(points, centers):\n",
    "    distance = euclidean_distances(points, centers)\n",
    "    distance = distance**2\n",
    "    labels = np.argmin(distance, axis=1)\n",
    "    return labels\n",
    "\n",
    "# return k means cost given centers\n",
    "def k_means_cost(points, centers):\n",
    "    distance = euclidean_distances(points, centers)\n",
    "    distance = distance**2\n",
    "    labels = np.argmin(distance, axis=1)\n",
    "    return labels, np.min(distance, axis = 1).sum()\n",
    "\n",
    "# return k means cost given labels of points\n",
    "def kmeans_cost_label(points, labels, d, num_labels):\n",
    "    centers = np.zeros((num_labels, d))\n",
    "    good_indices = []\n",
    "    for i in range(num_labels):\n",
    "        to_index = np.where(labels == i)[0]\n",
    "        if len(to_index) > 0:\n",
    "            curr_points = points[to_index]\n",
    "            centers[i,:] = np.average(curr_points, axis = 0)\n",
    "            good_indices.append(i)\n",
    "        else:\n",
    "            pass\n",
    "    centers = centers[good_indices,:]\n",
    "        \n",
    "    return k_means_cost(points, centers)\n",
    "\n",
    "# return k means centers given labels\n",
    "\n",
    "def kmeans_centers(points, labels, d, num_labels):\n",
    "    centers = np.zeros((num_labels, d))\n",
    "    good_indices = []\n",
    "    for i in range(num_labels):\n",
    "        to_index = np.where(labels == i)[0]\n",
    "        if len(to_index) > 0:\n",
    "            curr_points = points[to_index]\n",
    "            centers[i,:] = np.average(curr_points, axis = 0)\n",
    "            good_indices.append(i)\n",
    "        else:\n",
    "            pass\n",
    "    centers = centers[good_indices,:]\n",
    "        \n",
    "    return centers\n",
    "       \n",
    "\n",
    "\n",
    "def distance(p1, p2): \n",
    "    return np.sum((p1 - p2)**2) \n",
    "\n",
    "\n",
    "\n",
    "from numba import jit \n",
    "@jit(nopython=True)\n",
    "def algo2new(points, eps):\n",
    "    \n",
    "    n = len(points)\n",
    "    \n",
    "    if n <= 10:\n",
    "        return points.mean()\n",
    "    \n",
    "    to_return = 0.0\n",
    "    for i in range(1):\n",
    "        points = np.random.permutation(points)\n",
    "        X1 = points[:n//2]\n",
    "        X2 = points[n//2:]\n",
    "        X1 = np.sort(X1)\n",
    "\n",
    "        counter = int((1-5*eps)*(n//2))\n",
    "        \n",
    "        if counter == 1:\n",
    "            to_return += X2.mean()\n",
    "        else:\n",
    "            X1_left = X1[:-counter+1]\n",
    "            X1_right = X1[counter-1:]\n",
    "\n",
    "            good_indx = np.argmin(X1_right-X1_left)\n",
    "            a = X1_left[good_indx]\n",
    "            b = X1_right[good_indx]\n",
    "            to_index = np.where((a <= X2) & (X2 <= b))[0]\n",
    "            if len(to_index) == 0:\n",
    "                to_return += 0.0\n",
    "            else:\n",
    "                to_return += X2[to_index].mean()\n",
    "    return to_return#/25.0\n",
    "    \n",
    "\n",
    "def algo2(points, eps):\n",
    "    n = len(points)\n",
    "    \n",
    "    to_return = 0.0\n",
    "    if n < 10:\n",
    "        return sum(points)/n\n",
    "\n",
    "    for i in range(25):\n",
    "        # randomly partition points into two groups of equal size\n",
    "        points = np.random.permutation(points)\n",
    "        X1 = points[:n//2]\n",
    "        X2 = points[n//2:]\n",
    "        X1 = np.sort(X1)\n",
    "\n",
    "        # find interval of X1 with (1-eps) fraction of points\n",
    "        # call this interval [a,b]\n",
    "        counter = int((1-5*eps)*(n//2))\n",
    "        curr_len = float('inf')\n",
    "        a = 0\n",
    "        b = 0\n",
    "        for i in range(n//2-counter+1):\n",
    "            curr_int_left = X1[i]\n",
    "            curr_int_right = X1[i+counter-1]\n",
    "            if curr_int_right -  curr_int_left < curr_len:\n",
    "                a = curr_int_left\n",
    "                b = curr_int_right\n",
    "                curr_len = b - a\n",
    "        X2_filtered = [x for x in X2 if a <= x <= b]\n",
    "\n",
    "\n",
    "        # return average of points in X2 that are in [a,b]\n",
    "        if len(X2_filtered) == 0:\n",
    "            to_return += 0.0\n",
    "        else:\n",
    "            to_return += sum(X2_filtered)/len(X2_filtered)\n",
    "    return to_return/25.0\n",
    "\n",
    "# main algo of paper\n",
    "def algo3(points, oracle_labels, k, eps):\n",
    "    n,d = points.shape\n",
    "    centers = np.zeros((k, d))\n",
    "    labels_so_far = []\n",
    "\n",
    "    # loop over each label\n",
    "    for i in range(k):\n",
    "\n",
    "        # get labels that haven't been processed so far\n",
    "        good_indices = np.where(~np.isin(oracle_labels, labels_so_far))[0]\n",
    "        curr_labels = oracle_labels[good_indices]\n",
    "        \n",
    "        if len(curr_labels) > 0:\n",
    "\n",
    "            # get most common label\n",
    "            label_counts = np.bincount(curr_labels)\n",
    "            most_common_label = np.argmax(label_counts)\n",
    "            points_with_labels = points[np.where(oracle_labels == most_common_label)[0]]\n",
    "\n",
    "\n",
    "            # for most common label, loop over each dimension and run alg 2\n",
    "            for j in range(d):\n",
    "                curr_dim_points = points_with_labels[:,j]\n",
    "                curr_dim_center = algo2new(curr_dim_points, eps)\n",
    "                centers[most_common_label, j] = curr_dim_center\n",
    "            \n",
    "            labels_so_far.append(most_common_label)\n",
    "\n",
    "                \n",
    "        else:\n",
    "            pass\n",
    "    return centers\n",
    "\n",
    "# sampling baseline\n",
    "def sampling_baseline(points, labels, d, num_labels, rate = 50):\n",
    "    rate = rate/100.0\n",
    "    centers = np.zeros((num_labels, d))\n",
    "    good_indices = []\n",
    "    for i in range(num_labels):\n",
    "        to_index = np.where(labels == i)[0]\n",
    "        size_to_keep = int(rate*len(to_index))\n",
    "        if size_to_keep > 0:\n",
    "            to_index = np.random.permutation(to_index)\n",
    "            curr_points = points[to_index[:size_to_keep]]\n",
    "            centers[i,:] = np.average(curr_points, axis = 0)\n",
    "            good_indices.append(i)\n",
    "        else:\n",
    "            pass\n",
    "    centers = centers[good_indices,:]\n",
    "    return k_means_cost(points, centers)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# CIFAR-10 Experiments"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(10000, 3072)"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Load CIFAR-10 data\n",
    "# Download from https://www.cs.toronto.edu/~kriz/cifar.html\n",
    "data = unpickle(\"test_batch\")\n",
    "points = data[b'data']\n",
    "points.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Predictions from ResNet18\n",
    "\n",
    "predictions = np.array([3, 8, 8, 0, 6, 6, 1, 6, 3, 1, 0, 9, 5, 7, 9, 8, 5, 7, 8, 6, 7, 0, 4, 9, 5, 2, 4, 0, 9, 6, 6, 5, 8, 5, 9, 8, 4, 9, 9, 5, 4, 6, 5, 6, 0, 9, 3, 0, 7, 6, 9, 8, 3, 3, 8, 8, 7, 7, 5, 3, 7, 3, 6, 1, 6, 2, 1, 2, 3, 7, 2, 6, 8, 8, 0, 2, 9, 3, 3, 8, 8, 1, 1, 7, 2, 5, 2, 3, 8, 9, 0, 3, 8, 6, 4, 6, 6, 0, 0, 7, 4, 5, 6, 3, 1, 1, 3, 6, 8, 7, 4, 0, 6, 2, 1, 3, 0, 4, 6, 7, 8, 3, 1, 2, 8, 2, 8, 3, 3, 2, 4, 1, 8, 9, 1, 2, 9, 7, 2, 0, 6, 5, 6, 3, 8, 7, 6, 3, 5, 2, 8, 9, 6, 0, 0, 5, 2, 9, 5, 4, 2, 1, 6, 6, 0, 2, 8, 4, 5, 0, 9, 0, 9, 8, 9, 9, 3, 7, 5, 0, 0, 5, 2, 2, 3, 8, 6, 3, 3, 0, 5, 8, 0, 1, 7, 2, 8, 8, 7, 8, 5, 1, 8, 7, 1, 3, 0, 5, 7, 9, 7, 4, 5, 9, 8, 0, 7, 9, 8, 2, 7, 6, 9, 4, 3, 9, 5, 4, 3, 6, 5, 1, 5, 8, 8, 0, 4, 0, 5, 5, 1, 1, 0, 9, 0, 3, 1, 8, 2, 2, 5, 3, 9, 9, 4, 0, 3, 0, 8, 9, 8, 1, 5, 7, 8, 8, 0, 4, 7, 0, 2, 3, 6, 3, 8, 5, 0, 3, 4, 3, 9, 0, 6, 1, 9, 9, 1, 0, 7, 9, 1, 2, 6, 1, 3, 4, 6, 0, 0, 6, 6, 6, 3, 2, 6, 1, 9, 2, 9, 6, 8, 6, 8, 2, 4, 0, 7, 7, 5, 5, 3, 5, 2, 3, 3, 1, 7, 5, 4, 6, 1, 9, 3, 6, 6, 9, 3, 8, 0, 7, 2, 6, 2, 5, 8, 5, 4, 6, 8, 9, 9, 1, 0, 2, 2, 4, 3, 2, 8, 0, 9, 5, 8, 1, 9, 4, 1, 3, 0, 1, 4, 7, 9, 4, 2, 7, 0, 7, 8, 6, 6, 9, 0, 9, 5, 8, 7, 2, 2, 5, 1, 2, 6, 2, 9, 6, 2, 3, 0, 3, 9, 8, 7, 8, 8, 5, 0, 1, 8, 2, 7, 9, 3, 6, 1, 9, 0, 7, 5, 7, 4, 5, 8, 0, 2, 9, 3, 4, 0, 6, 2, 5, 3, 7, 3, 7, 2, 5, 3, 1, 1, 4, 9, 9, 5, 7, 5, 0, 2, 2, 2, 9, 7, 3, 9, 4, 4, 5, 4, 6, 5, 6, 1, 4, 3, 4, 4, 3, 7, 8, 4, 7, 8, 0, 5, 7, 6, 0, 5, 4, 1, 6, 8, 3, 5, 0, 9, 9, 4, 0, 1, 0, 8, 1, 1, 8, 0, 2, 2, 0, 2, 6, 5, 4, 9, 4, 7, 9, 9, 4, 5, 6, 6, 1, 5, 3, 8, 9, 5, 8, 5, 7, 0, 7, 0, 5, 0, 0, 4, 6, 9, 0, 9, 5, 6, 6, 6, 2, 9, 0, 1, 7, 6, 7, 5, 9, 1, 6, 2, 5, 3, 5, 8, 5, 9, 4, 6, 4, 3, 2, 0, 7, 6, 2, 2, 3, 9, 7, 9, 2, 6, 7, 1, 3, 6, 6, 8, 8, 7, 5, 4, 0, 8, 4, 0, 9, 3, 4, 8, 9, 6, 9, 2, 6, 1, 4, 7, 3, 2, 3, 8, 5, 0, 2, 1, 6, 4, 3, 3, 9, 6, 9, 8, 8, 5, 8, 6, 6, 3, 1, 7, 7, 1, 2, 7, 9, 9, 4, 4, 1, 2, 5, 6, 8, 7, 6, 8, 3, 0, 3, 5, 3, 0, 7, 9, 1, 3, 4, 4, 5, 3, 9, 5, 6, 9, 2, 1, 1, 4, 1, 9, 4, 7, 6, 3, 0, 9, 0, 1, 3, 6, 3, 6, 3, 2, 0, 3, 1, 0, 5, 9, 6, 4, 0, 9, 2, 9, 9, 3, 6, 3, 2, 2, 7, 8, 3, 8, 2, 7, 5, 7, 2, 4, 8, 7, 4, 2, 9, 8, 8, 6, 8, 8, 7, 4, 3, 3, 8, 4, 9, 4, 8, 8, 1, 8, 8, 1, 2, 6, 5, 4, 0, 7, 9, 1, 4, 1, 4, 1, 7, 2, 7, 0, 7, 9, 7, 6, 6, 2, 5, 9, 0, 9, 1, 2, 2, 6, 8, 2, 1, 5, 6, 6, 0, 1, 2, 7, 0, 5, 4, 0, 1, 6, 4, 0, 2, 5, 6, 0, 5, 9, 1, 7, 6, 7, 0, 3, 9, 6, 8, 0, 0, 5, 5, 7, 7, 2, 4, 7, 2, 7, 1, 4, 7, 4, 4, 8, 4, 7, 7, 2, 5, 7, 2, 0, 8, 9, 5, 8, 3, 6, 2, 0, 8, 7, 3, 7, 6, 5, 3, 1, 8, 2, 2, 5, 5, 1, 2, 9, 2, 7, 0, 7, 2, 1, 3, 2, 0, 2, 4, 3, 9, 8, 1, 0, 7, 7, 0, 7, 8, 4, 6, 3, 3, 0, 1, 1, 7, 0, 1, 2, 1, 4, 2, 3, 8, 4, 2, 3, 7, 8, 4, 0, 0, 9, 0, 0, 1, 1, 4, 4, 6, 7, 6, 1, 1, 3, 7, 3, 5, 2, 6, 6, 5, 8, 7, 1, 6, 8, 8, 5, 3, 0, 4, 0, 1, 4, 8, 8, 0, 6, 9, 9, 9, 0, 3, 8, 6, 0, 0, 4, 2, 3, 2, 7, 2, 2, 5, 9, 8, 9, 1, 7, 6, 0, 5, 0, 1, 3, 8, 3, 9, 6, 1, 4, 7, 2, 3, 7, 8, 9, 1, 1, 6, 6, 6, 3, 9, 1, 9, 9, 4, 2, 1, 7, 0, 6, 8, 1, 9, 2, 9, 5, 4, 7, 8, 3, 1, 2, 0, 1, 5, 8, 3, 6, 3, 8, 1, 3, 8, 5, 0, 8, 4, 8, 1, 1, 8, 9, 6, 0, 8, 6, 1, 3, 4, 1, 6, 0, 3, 1, 1, 0, 0, 3, 5, 0, 0, 6, 6, 3, 3, 6, 3, 3, 6, 0, 7, 2, 2, 5, 5, 2, 0, 8, 5, 2, 1, 1, 1, 3, 2, 0, 3, 1, 5, 3, 7, 6, 8, 9, 1, 6, 4, 9, 1, 9, 0, 9, 6, 3, 6, 8, 7, 3, 8, 0, 0, 0, 6, 6, 6, 9, 2, 5, 4, 4, 6, 3, 6, 0, 8, 6, 0, 2, 2, 7, 5, 1, 2, 7, 8, 8, 0, 9, 4, 9, 7, 2, 0, 2, 8, 3, 8, 9, 1, 5, 5, 7, 7, 5, 3, 8, 3, 3, 6, 2, 8, 4, 3, 7, 9, 2, 4, 1, 6, 9, 0, 5, 8, 6, 1, 8, 6, 1, 4, 2, 9, 2, 7, 7, 2, 0, 8, 6, 9, 1, 7, 1, 8, 8, 0, 7, 5, 8, 0, 3, 4, 3, 7, 7, 9, 2, 3, 1, 9, 1, 1, 6, 3, 3, 3, 1, 0, 6, 1, 4, 1, 0, 0, 1, 1, 6, 5, 4, 6, 2, 0, 7, 9, 8, 7, 2, 0, 6, 8, 1, 4, 3, 7, 0, 6, 1, 8, 5, 7, 8, 4, 8, 3, 9, 9, 9, 8, 7, 6, 6, 5, 5, 1, 5, 9, 1, 4, 1, 5, 7, 0, 1, 5, 2, 0, 8, 8, 5, 6, 7, 5, 4, 4, 7, 2, 5, 8, 2, 4, 9, 2, 1, 8, 1, 9, 8, 0, 8, 1, 0, 4, 3, 3, 1, 8, 4, 6, 3, 3, 5, 2, 2, 8, 5, 8, 9, 5, 8, 8, 8, 9, 1, 6, 5, 9, 4, 4, 8, 0, 7, 2, 9, 7, 4, 1, 6, 6, 8, 9, 9, 2, 5, 6, 0, 8, 6, 1, 9, 4, 5, 9, 5, 0, 7, 5, 0, 0, 4, 4, 6, 6, 5, 5, 2, 8, 1, 7, 3, 1, 4, 5, 6, 3, 1, 4, 7, 0, 9, 4, 3, 8, 2, 8, 4, 7, 2, 3, 1, 5, 2, 9, 8, 9, 7, 9, 5, 1, 4, 0, 8, 2, 3, 8, 9, 1, 1, 3, 2, 4, 9, 3, 1, 7, 4, 6, 2, 8, 9, 5, 3, 9, 5, 5, 6, 5, 2, 4, 6, 3, 1, 0, 7, 2, 5, 4, 7, 6, 1, 1, 9, 8, 1, 0, 1, 3, 1, 1, 1, 7, 3, 9, 6, 8, 4, 6, 8, 4, 9, 4, 7, 9, 7, 6, 8, 4, 9, 7, 0, 1, 6, 1, 5, 1, 0, 4, 3, 4, 1, 4, 0, 8, 4, 6, 2, 2, 6, 5, 3, 6, 2, 1, 1, 8, 6, 0, 4, 0, 1, 9, 7, 1, 3, 7, 7, 8, 7, 7, 3, 9, 7, 7, 7, 0, 1, 2, 8, 6, 4, 0, 7, 9, 8, 6, 8, 4, 1, 1, 7, 0, 2, 8, 5, 8, 1, 6, 2, 4, 1, 2, 7, 2, 8, 1, 8, 1, 8, 6, 0, 2, 4, 1, 3, 6, 7, 7, 4, 4, 3, 3, 4, 5, 2, 4, 3, 7, 8, 4, 4, 4, 3, 4, 3, 2, 8, 4, 5, 5, 4, 1, 4, 2, 5, 1, 6, 4, 3, 4, 4, 0, 8, 8, 4, 5, 7, 3, 6, 9, 1, 6, 7, 2, 0, 1, 4, 5, 3, 0, 0, 2, 7, 3, 6, 0, 6, 2, 9, 1, 7, 7, 5, 2, 5, 6, 4, 1, 4, 3, 3, 3, 0, 3, 5, 5, 8, 9, 7, 3, 1, 3, 3, 3, 4, 4, 2, 3, 3, 8, 1, 7, 7, 0, 7, 4, 3, 1, 4, 2, 4, 3, 9, 9, 4, 9, 9, 1, 8, 1, 6, 7, 5, 5, 4, 9, 7, 6, 5, 9, 3, 4, 0, 7, 8, 5, 5, 0, 0, 9, 9, 8, 2, 5, 4, 8, 3, 6, 3, 6, 0, 6, 6, 6, 9, 6, 6, 8, 6, 2, 4, 5, 8, 1, 2, 7, 6, 5, 7, 0, 8, 2, 0, 8, 6, 9, 2, 8, 9, 4, 0, 9, 4, 9, 5, 7, 5, 5, 9, 5, 3, 0, 1, 9, 7, 2, 4, 1, 0, 8, 2, 3, 1, 7, 8, 0, 4, 8, 6, 2, 4, 0, 0, 9, 0, 8, 4, 3, 1, 3, 9, 0, 5, 6, 5, 0, 1, 4, 8, 1, 0, 5, 2, 1, 0, 2, 8, 1, 5, 6, 7, 7, 2, 6, 2, 5, 0, 1, 4, 2, 5, 2, 6, 2, 2, 1, 7, 2, 0, 5, 5, 3, 0, 4, 8, 5, 7, 6, 3, 8, 1, 0, 1, 3, 5, 0, 5, 6, 9, 5, 3, 6, 0, 1, 4, 4, 4, 4, 2, 2, 5, 8, 1, 5, 9, 8, 1, 1, 5, 3, 9, 9, 7, 6, 5, 0, 8, 4, 7, 2, 9, 2, 8, 4, 7, 1, 5, 9, 6, 8, 9, 2, 4, 9, 6, 7, 8, 1, 4, 8, 9, 7, 2, 5, 3, 7, 1, 0, 2, 9, 5, 5, 8, 5, 4, 2, 8, 3, 4, 5, 7, 7, 8, 6, 2, 8, 2, 3, 5, 6, 8, 0, 2, 3, 7, 0, 1, 9, 1, 3, 7, 5, 3, 3, 2, 9, 6, 8, 6, 9, 3, 0, 9, 8, 1, 7, 8, 5, 0, 0, 1, 3, 9, 1, 5, 3, 4, 4, 0, 9, 9, 9, 9, 8, 2, 4, 2, 2, 5, 1, 9, 1, 0, 9, 4, 2, 1, 6, 0, 3, 0, 2, 3, 9, 8, 5, 5, 7, 2, 8, 7, 4, 8, 3, 5, 0, 5, 7, 4, 4, 2, 2, 7, 5, 6, 0, 2, 7, 6, 2, 3, 0, 7, 7, 8, 9, 1, 4, 6, 0, 6, 6, 5, 5, 6, 3, 9, 3, 6, 3, 7, 6, 4, 9, 5, 6, 4, 1, 6, 3, 8, 2, 3, 9, 0, 5, 1, 5, 4, 5, 7, 5, 7, 8, 9, 1, 3, 2, 5, 6, 8, 4, 6, 5, 3, 9, 9, 8, 5, 5, 6, 4, 5, 9, 7, 3, 4, 1, 4, 3, 3, 6, 5, 5, 2, 8, 0, 0, 1, 8, 3, 1, 3, 3, 8, 3, 8, 5, 8, 6, 3, 5, 5, 5, 8, 2, 5, 3, 7, 1, 8, 2, 2, 4, 3, 7, 2, 9, 6, 2, 2, 4, 3, 0, 2, 0, 1, 3, 2, 2, 7, 0, 1, 0, 7, 7, 2, 0, 1, 6, 5, 0, 9, 2, 0, 1, 2, 6, 0, 1, 6, 6, 5, 3, 4, 0, 0, 9, 1, 0, 2, 5, 9, 7, 8, 6, 4, 6, 0, 2, 0, 1, 9, 3, 6, 9, 0, 7, 2, 3, 4, 8, 0, 2, 6, 8, 9, 5, 1, 9, 3, 7, 2, 7, 9, 6, 9, 5, 7, 8, 5, 9, 8, 3, 9, 8, 0, 3, 5, 7, 1, 2, 0, 7, 5, 8, 2, 2, 5, 3, 8, 6, 1, 9, 3, 1, 4, 3, 4, 4, 9, 0, 9, 3, 9, 2, 9, 4, 0, 2, 8, 4, 8, 6, 8, 2, 0, 5, 9, 6, 9, 3, 1, 3, 4, 4, 2, 7, 2, 4, 4, 0, 2, 8, 4, 5, 1, 2, 6, 8, 1, 7, 6, 8, 7, 4, 3, 5, 1, 3, 7, 2, 5, 6, 1, 7, 9, 0, 3, 3, 9, 8, 9, 5, 0, 0, 7, 6, 3, 3, 8, 1, 4, 0, 1, 5, 4, 3, 2, 6, 0, 8, 8, 6, 3, 3, 4, 8, 7, 5, 1, 6, 0, 5, 9, 9, 4, 5, 9, 5, 8, 3, 3, 2, 5, 1, 9, 5, 3, 1, 1, 8, 9, 7, 0, 6, 3, 2, 0, 2, 6, 9, 3, 9, 1, 6, 6, 7, 2, 6, 3, 2, 5, 5, 2, 7, 5, 2, 0, 8, 0, 7, 7, 1, 7, 4, 0, 4, 2, 6, 1, 5, 9, 7, 6, 2, 7, 0, 5, 6, 0, 1, 1, 8, 4, 5, 3, 9, 2, 4, 8, 9, 8, 1, 7, 2, 7, 0, 3, 2, 6, 7, 9, 4, 0, 1, 0, 4, 3, 0, 8, 0, 7, 6, 1, 8, 8, 5, 9, 2, 5, 4, 4, 9, 0, 6, 1, 2, 5, 1, 6, 7, 1, 5, 8, 8, 0, 3, 9, 4, 0, 6, 4, 9, 2, 4, 3, 0, 6, 6, 5, 6, 6, 7, 8, 4, 8, 8, 3, 2, 8, 0, 2, 5, 6, 8, 7, 8, 9, 9, 0, 6, 6, 8, 1, 1, 7, 4, 4, 2, 5, 6, 9, 6, 2, 4, 1, 8, 2, 3, 1, 6, 8, 6, 8, 5, 9, 0, 1, 0, 2, 9, 2, 9, 0, 9, 7, 8, 5, 8, 6, 6, 8, 1, 6, 5, 8, 7, 9, 2, 1, 6, 7, 5, 6, 3, 0, 9, 8, 9, 7, 8, 9, 9, 3, 6, 4, 4, 8, 8, 1, 7, 3, 0, 6, 2, 4, 1, 2, 2, 9, 2, 2, 9, 7, 4, 1, 9, 1, 4, 3, 1, 2, 8, 9, 3, 2, 2, 8, 6, 9, 0, 5, 1, 5, 8, 2, 1, 0, 3, 2, 4, 8, 4, 0, 6, 4, 2, 9, 8, 4, 7, 6, 2, 4, 7, 7, 6, 4, 2, 2, 3, 2, 4, 9, 0, 0, 9, 6, 5, 8, 5, 2, 4, 8, 8, 6, 0, 5, 7, 6, 3, 7, 0, 4, 0, 3, 8, 4, 8, 0, 4, 9, 2, 5, 6, 8, 1, 6, 0, 8, 4, 3, 1, 4, 5, 2, 4, 3, 6, 0, 7, 1, 3, 5, 7, 1, 8, 0, 4, 8, 2, 7, 7, 0, 6, 2, 4, 3, 3, 1, 2, 1, 6, 4, 6, 7, 4, 7, 3, 8, 1, 3, 1, 4, 6, 5, 3, 7, 4, 5, 4, 9, 7, 7, 2, 3, 3, 6, 7, 4, 1, 6, 1, 0, 6, 9, 6, 0, 2, 0, 6, 3, 7, 0, 0, 0, 0, 7, 5, 3, 2, 7, 8, 5, 5, 2, 2, 8, 9, 1, 2, 2, 0, 3, 4, 9, 1, 6, 9, 0, 0, 3, 6, 2, 6, 7, 5, 1, 8, 9, 0, 5, 0, 5, 4, 3, 8, 5, 2, 0, 8, 5, 9, 2, 3, 6, 5, 7, 3, 7, 2, 8, 8, 4, 2, 1, 6, 2, 9, 9, 8, 2, 3, 1, 0, 5, 2, 3, 7, 9, 5, 9, 1, 1, 3, 2, 7, 4, 4, 1, 9, 4, 5, 5, 2, 7, 7, 6, 1, 2, 3, 7, 5, 4, 5, 7, 7, 0, 0, 1, 2, 4, 3, 7, 9, 8, 7, 0, 9, 0, 3, 7, 6, 3, 8, 4, 5, 6, 5, 7, 4, 2, 9, 2, 4, 9, 2, 0, 1, 1, 3, 7, 9, 5, 1, 6, 0, 3, 3, 7, 2, 4, 5, 2, 3, 6, 0, 3, 0, 4, 4, 3, 8, 1, 2, 3, 2, 7, 1, 3, 5, 6, 8, 6, 6, 5, 4, 2, 9, 1, 3, 2, 0, 4, 1, 5, 5, 2, 6, 5, 6, 9, 7, 9, 4, 8, 3, 1, 9, 8, 1, 9, 0, 3, 0, 4, 7, 7, 2, 6, 5, 6, 9, 7, 7, 5, 7, 0, 8, 6, 3, 8, 3, 8, 9, 3, 2, 9, 2, 7, 4, 1, 9, 7, 0, 8, 1, 6, 0, 6, 5, 1, 4, 2, 8, 2, 8, 3, 3, 1, 4, 9, 8, 1, 1, 7, 9, 9, 4, 6, 8, 5, 3, 2, 2, 0, 8, 5, 1, 9, 7, 9, 1, 0, 5, 1, 0, 3, 8, 9, 3, 0, 8, 0, 7, 9, 4, 8, 3, 0, 7, 0, 7, 0, 5, 5, 4, 3, 0, 9, 9, 0, 2, 2, 0, 8, 4, 4, 5, 2, 2, 1, 1, 5, 3, 4, 3, 4, 0, 8, 4, 8, 7, 5, 6, 5, 1, 7, 2, 4, 0, 5, 6, 8, 7, 6, 3, 1, 3, 6, 6, 4, 5, 5, 5, 1, 8, 7, 3, 0, 2, 7, 1, 1, 1, 6, 5, 2, 1, 2, 3, 9, 8, 3, 1, 7, 4, 8, 4, 7, 5, 8, 6, 0, 3, 0, 8, 2, 4, 4, 9, 4, 6, 1, 3, 7, 7, 9, 0, 1, 3, 1, 3, 2, 4, 0, 7, 1, 3, 1, 3, 2, 1, 8, 0, 1, 9, 7, 5, 5, 2, 9, 0, 6, 8, 4, 1, 5, 7, 2, 4, 7, 7, 4, 9, 0, 7, 0, 6, 7, 1, 8, 5, 8, 8, 7, 0, 0, 3, 2, 5, 7, 0, 6, 4, 4, 9, 1, 8, 6, 3, 9, 4, 9, 3, 3, 7, 5, 9, 7, 3, 4, 5, 8, 2, 8, 9, 5, 3, 1, 9, 2, 2, 0, 1, 1, 8, 1, 1, 9, 8, 9, 9, 0, 2, 6, 9, 1, 9, 0, 1, 9, 2, 9, 9, 9, 0, 9, 9, 2, 1, 7, 0, 5, 6, 3, 9, 8, 3, 0, 2, 7, 7, 4, 8, 3, 0, 4, 2, 5, 5, 7, 6, 6, 6, 5, 6, 5, 4, 3, 8, 8, 0, 9, 6, 9, 0, 6, 9, 6, 1, 4, 7, 9, 0, 3, 5, 4, 7, 6, 9, 8, 2, 3, 9, 3, 3, 7, 8, 3, 5, 3, 9, 6, 1, 4, 7, 4, 8, 7, 7, 1, 3, 0, 3, 2, 5, 4, 1, 3, 5, 4, 7, 0, 3, 7, 0, 2, 1, 5, 8, 7, 3, 5, 7, 8, 5, 7, 8, 1, 3, 4, 7, 2, 8, 3, 2, 9, 7, 4, 1, 6, 5, 9, 8, 5, 5, 4, 1, 0, 9, 4, 4, 9, 0, 4, 8, 0, 8, 2, 9, 5, 9, 7, 7, 6, 7, 9, 2, 1, 3, 7, 7, 8, 2, 2, 0, 2, 5, 3, 6, 4, 7, 2, 3, 7, 8, 7, 2, 5, 0, 0, 7, 0, 9, 6, 1, 8, 5, 9, 7, 0, 9, 1, 6, 8, 1, 2, 3, 8, 6, 4, 8, 9, 7, 4, 4, 1, 2, 4, 9, 8, 7, 9, 5, 1, 2, 1, 3, 6, 4, 5, 7, 4, 5, 8, 5, 2, 8, 7, 8, 2, 3, 6, 1, 5, 3, 9, 5, 1, 9, 0, 9, 2, 0, 6, 2, 4, 8, 5, 7, 6, 1, 2, 9, 4, 5, 0, 3, 3, 7, 4, 7, 1, 4, 3, 0, 3, 8, 5, 0, 0, 6, 2, 2, 8, 4, 5, 4, 5, 6, 4, 7, 9, 4, 2, 0, 6, 4, 2, 0, 3, 4, 6, 1, 1, 5, 3, 2, 2, 6, 3, 4, 5, 0, 1, 7, 2, 3, 9, 6, 5, 0, 2, 9, 7, 1, 7, 2, 2, 0, 8, 6, 4, 3, 2, 7, 7, 0, 4, 1, 6, 5, 1, 3, 4, 3, 9, 0, 0, 2, 5, 0, 4, 0, 1, 1, 8, 4, 9, 4, 2, 4, 3, 3, 4, 0, 4, 3, 5, 8, 9, 1, 5, 8, 1, 8, 2, 4, 4, 2, 4, 1, 1, 6, 6, 8, 5, 2, 2, 5, 0, 8, 2, 3, 6, 2, 9, 6, 1, 4, 5, 9, 0, 1, 0, 0, 8, 1, 1, 6, 6, 2, 5, 4, 9, 5, 8, 6, 9, 1, 7, 6, 0, 9, 3, 5, 3, 2, 3, 3, 4, 9, 7, 1, 4, 4, 6, 1, 3, 8, 8, 0, 6, 7, 7, 6, 7, 2, 8, 2, 4, 6, 2, 7, 3, 0, 3, 6, 2, 6, 3, 2, 0, 9, 5, 1, 1, 5, 3, 2, 4, 3, 2, 1, 0, 4, 5, 5, 2, 8, 9, 4, 3, 1, 8, 0, 1, 3, 3, 7, 4, 2, 9, 7, 6, 8, 1, 8, 9, 9, 3, 1, 7, 3, 0, 0, 2, 8, 3, 9, 2, 7, 4, 6, 0, 1, 6, 1, 6, 7, 5, 5, 2, 5, 9, 4, 0, 2, 3, 4, 9, 4, 1, 0, 0, 2, 5, 5, 9, 2, 8, 9, 5, 7, 9, 1, 4, 6, 2, 8, 3, 4, 8, 9, 3, 1, 1, 6, 9, 8, 4, 6, 6, 5, 2, 6, 4, 2, 3, 1, 6, 6, 8, 5, 2, 0, 7, 1, 6, 2, 5, 9, 4, 8, 1, 6, 9, 2, 7, 3, 3, 2, 9, 7, 0, 2, 9, 3, 4, 1, 7, 9, 5, 8, 9, 7, 3, 3, 0, 3, 7, 4, 2, 4, 7, 0, 1, 8, 1, 0, 4, 6, 1, 9, 9, 2, 1, 2, 5, 6, 9, 7, 7, 0, 4, 2, 0, 2, 5, 6, 7, 6, 7, 1, 4, 2, 0, 2, 1, 7, 5, 6, 5, 5, 9, 2, 7, 8, 5, 9, 5, 8, 5, 4, 3, 7, 9, 8, 1, 2, 2, 8, 9, 5, 0, 3, 4, 0, 2, 0, 1, 4, 2, 8, 5, 5, 7, 9, 8, 3, 7, 9, 1, 5, 6, 9, 8, 7, 2, 0, 9, 0, 8, 5, 9, 4, 2, 9, 8, 1, 9, 1, 8, 3, 7, 6, 4, 2, 3, 7, 0, 5, 5, 8, 8, 8, 7, 9, 6, 2, 7, 4, 2, 7, 6, 7, 1, 7, 3, 6, 8, 4, 6, 6, 7, 1, 5, 9, 7, 1, 7, 0, 1, 6, 3, 3, 9, 0, 1, 2, 3, 2, 2, 5, 4, 9, 8, 7, 4, 4, 9, 7, 6, 7, 7, 1, 2, 3, 2, 1, 9, 0, 3, 3, 1, 5, 6, 6, 2, 4, 6, 8, 8, 9, 6, 2, 1, 0, 7, 5, 8, 2, 1, 5, 8, 1, 4, 2, 5, 0, 6, 0, 9, 5, 2, 8, 4, 1, 9, 0, 4, 4, 8, 2, 9, 0, 7, 9, 8, 7, 1, 6, 2, 9, 2, 5, 9, 7, 6, 7, 7, 1, 1, 2, 4, 2, 0, 6, 8, 9, 6, 2, 2, 9, 0, 2, 4, 2, 0, 5, 8, 6, 8, 2, 7, 7, 7, 1, 8, 1, 6, 5, 9, 7, 8, 9, 6, 4, 8, 1, 9, 4, 0, 4, 1, 4, 3, 6, 2, 2, 0, 0, 0, 7, 0, 7, 4, 3, 2, 7, 7, 4, 5, 4, 3, 5, 5, 4, 0, 0, 0, 7, 7, 1, 6, 5, 0, 7, 7, 4, 6, 1, 8, 5, 9, 2, 5, 6, 2, 2, 7, 5, 5, 8, 1, 0, 6, 8, 7, 8, 8, 5, 7, 5, 4, 9, 7, 3, 3, 8, 8, 3, 9, 4, 7, 2, 0, 8, 0, 7, 0, 3, 2, 5, 2, 4, 3, 0, 4, 8, 2, 4, 0, 6, 4, 5, 6, 0, 8, 8, 2, 6, 1, 1, 6, 1, 4, 2, 1, 1, 2, 4, 4, 4, 7, 8, 8, 5, 1, 8, 2, 3, 3, 9, 6, 6, 3, 0, 7, 3, 3, 2, 7, 4, 5, 6, 0, 2, 1, 8, 1, 0, 9, 3, 1, 0, 5, 4, 2, 3, 3, 6, 7, 6, 0, 0, 5, 7, 4, 7, 7, 0, 6, 1, 3, 9, 9, 9, 0, 3, 8, 4, 0, 8, 4, 1, 0, 2, 2, 4, 1, 1, 7, 4, 3, 4, 1, 4, 7, 1, 0, 0, 9, 0, 5, 2, 8, 8, 5, 5, 0, 4, 0, 8, 6, 2, 5, 9, 2, 9, 1, 1, 5, 4, 7, 5, 8, 6, 6, 1, 5, 7, 3, 4, 1, 8, 9, 9, 8, 9, 8, 6, 8, 5, 8, 9, 4, 6, 2, 6, 3, 7, 4, 0, 0, 1, 7, 5, 1, 3, 1, 3, 1, 6, 8, 7, 3, 6, 9, 1, 2, 0, 1, 7, 2, 6, 1, 9, 0, 0, 8, 9, 9, 2, 8, 6, 5, 5, 6, 0, 3, 3, 0, 4, 4, 7, 5, 0, 1, 6, 8, 8, 1, 2, 1, 5, 4, 5, 9, 6, 7, 1, 0, 6, 9, 2, 7, 7, 3, 9, 9, 1, 9, 7, 0, 1, 3, 5, 4, 6, 3, 8, 8, 0, 4, 8, 3, 6, 7, 2, 0, 4, 5, 2, 6, 8, 4, 9, 9, 9, 6, 0, 4, 2, 8, 1, 1, 0, 0, 3, 7, 4, 1, 1, 9, 7, 7, 4, 6, 8, 6, 0, 2, 8, 5, 3, 5, 3, 5, 7, 9, 8, 4, 4, 3, 1, 4, 8, 4, 6, 5, 3, 6, 8, 9, 5, 7, 6, 2, 0, 4, 9, 9, 0, 5, 2, 3, 6, 1, 1, 0, 2, 8, 2, 1, 1, 7, 5, 2, 3, 4, 1, 2, 9, 2, 1, 3, 4, 8, 9, 0, 0, 4, 1, 0, 2, 2, 0, 6, 8, 7, 3, 3, 8, 9, 0, 2, 5, 3, 6, 1, 3, 8, 5, 9, 3, 4, 4, 0, 1, 3, 6, 1, 7, 9, 9, 6, 2, 4, 7, 8, 3, 4, 7, 0, 2, 8, 4, 8, 3, 8, 8, 8, 3, 3, 5, 7, 3, 0, 4, 1, 5, 9, 7, 0, 6, 8, 4, 9, 0, 1, 8, 9, 6, 3, 9, 2, 4, 4, 0, 3, 5, 5, 4, 3, 1, 1, 8, 2, 2, 9, 3, 7, 8, 9, 2, 3, 1, 7, 3, 2, 3, 0, 1, 9, 5, 5, 3, 4, 3, 8, 0, 0, 3, 1, 3, 7, 7, 4, 3, 8, 4, 8, 9, 9, 4, 2, 4, 3, 6, 4, 6, 4, 6, 6, 2, 8, 7, 4, 8, 0, 5, 9, 3, 2, 0, 7, 5, 1, 9, 7, 9, 1, 8, 4, 2, 1, 6, 4, 3, 8, 1, 4, 8, 6, 1, 7, 1, 4, 2, 4, 3, 6, 9, 7, 8, 2, 5, 3, 4, 5, 4, 3, 7, 3, 5, 7, 1, 5, 7, 8, 3, 6, 0, 2, 5, 2, 3, 7, 4, 3, 1, 6, 8, 6, 8, 3, 2, 7, 7, 9, 7, 1, 4, 7, 5, 6, 1, 7, 3, 0, 0, 6, 6, 8, 6, 6, 0, 3, 4, 7, 4, 9, 4, 9, 9, 3, 4, 1, 4, 0, 3, 7, 1, 2, 2, 8, 4, 7, 8, 5, 5, 6, 5, 6, 0, 6, 4, 9, 3, 2, 7, 3, 8, 5, 9, 4, 1, 6, 9, 9, 4, 5, 9, 8, 1, 6, 9, 5, 9, 0, 9, 7, 2, 2, 4, 2, 6, 4, 8, 1, 9, 5, 6, 3, 1, 8, 6, 0, 7, 6, 5, 9, 2, 9, 6, 1, 2, 8, 1, 6, 4, 9, 0, 3, 9, 1, 0, 5, 3, 1, 6, 9, 8, 9, 0, 6, 1, 6, 2, 3, 5, 6, 1, 0, 7, 2, 4, 8, 3, 3, 8, 6, 9, 1, 9, 0, 6, 2, 5, 9, 5, 4, 1, 9, 2, 0, 7, 3, 5, 1, 8, 3, 0, 5, 2, 0, 8, 3, 9, 6, 0, 3, 5, 3, 4, 1, 5, 0, 7, 3, 9, 4, 5, 5, 1, 4, 2, 4, 9, 9, 7, 1, 7, 0, 1, 2, 1, 5, 3, 8, 4, 1, 5, 1, 9, 9, 7, 0, 1, 7, 6, 2, 6, 5, 0, 0, 1, 3, 8, 9, 9, 0, 8, 8, 5, 9, 2, 9, 1, 3, 6, 7, 6, 7, 8, 6, 2, 4, 2, 3, 3, 5, 4, 1, 6, 5, 1, 6, 1, 7, 1, 6, 2, 3, 0, 4, 2, 9, 7, 3, 5, 6, 0, 9, 8, 1, 1, 3, 5, 6, 5, 3, 8, 7, 5, 0, 7, 7, 5, 7, 1, 9, 9, 1, 1, 9, 3, 5, 5, 3, 0, 3, 0, 6, 6, 0, 4, 8, 9, 4, 5, 1, 1, 2, 7, 9, 0, 1, 2, 5, 4, 4, 7, 4, 8, 3, 3, 7, 4, 5, 7, 0, 1, 2, 9, 8, 1, 7, 3, 5, 9, 1, 9, 1, 1, 3, 6, 7, 4, 8, 3, 3, 6, 7, 0, 1, 7, 7, 3, 5, 3, 2, 1, 7, 6, 8, 4, 4, 5, 7, 3, 4, 7, 7, 3, 6, 0, 7, 2, 6, 7, 4, 1, 8, 0, 2, 2, 1, 5, 4, 0, 9, 3, 4, 2, 2, 3, 8, 5, 0, 0, 4, 6, 3, 9, 2, 0, 5, 7, 5, 5, 1, 7, 3, 1, 6, 7, 9, 0, 1, 2, 1, 4, 6, 1, 5, 9, 5, 0, 4, 9, 5, 9, 7, 1, 6, 8, 3, 6, 5, 0, 8, 1, 7, 5, 6, 9, 3, 2, 3, 9, 3, 6, 1, 0, 9, 0, 9, 8, 7, 7, 5, 2, 3, 5, 5, 7, 8, 7, 6, 9, 1, 9, 8, 6, 5, 6, 7, 3, 6, 7, 2, 5, 9, 6, 6, 7, 0, 1, 0, 1, 3, 2, 6, 6, 1, 2, 5, 1, 9, 9, 8, 6, 8, 3, 8, 9, 0, 4, 8, 3, 3, 6, 4, 3, 9, 7, 2, 3, 5, 6, 4, 6, 0, 3, 7, 5, 0, 2, 7, 2, 7, 2, 9, 2, 3, 0, 6, 6, 3, 4, 5, 5, 9, 1, 1, 4, 4, 3, 5, 4, 8, 0, 0, 3, 9, 3, 7, 7, 2, 8, 3, 6, 3, 1, 9, 6, 3, 8, 3, 8, 4, 7, 5, 7, 5, 2, 1, 2, 6, 1, 5, 2, 0, 7, 5, 0, 0, 0, 1, 4, 3, 3, 8, 4, 3, 1, 7, 1, 0, 4, 2, 4, 1, 4, 0, 1, 2, 1, 7, 7, 9, 8, 7, 5, 4, 0, 9, 0, 0, 8, 2, 0, 0, 2, 4, 8, 6, 2, 4, 6, 3, 5, 1, 5, 3, 7, 2, 2, 9, 8, 0, 0, 0, 3, 4, 4, 6, 1, 6, 7, 4, 4, 3, 9, 7, 0, 8, 0, 4, 6, 5, 7, 9, 7, 0, 5, 7, 7, 3, 1, 9, 3, 0, 9, 5, 3, 7, 9, 4, 4, 1, 7, 7, 1, 4, 1, 2, 8, 7, 0, 0, 4, 7, 2, 9, 7, 6, 9, 3, 5, 8, 0, 3, 6, 8, 3, 2, 4, 7, 1, 1, 3, 9, 7, 5, 1, 0, 8, 7, 0, 1, 6, 9, 3, 2, 7, 7, 8, 1, 0, 3, 6, 6, 7, 5, 2, 0, 1, 5, 5, 1, 4, 1, 3, 0, 8, 6, 2, 1, 3, 6, 9, 1, 9, 0, 4, 1, 0, 1, 9, 8, 6, 9, 2, 4, 7, 2, 2, 7, 4, 9, 1, 5, 2, 6, 3, 4, 4, 1, 4, 8, 2, 6, 6, 1, 6, 3, 6, 3, 8, 4, 6, 7, 1, 9, 3, 6, 7, 6, 0, 7, 1, 9, 5, 2, 6, 7, 7, 6, 5, 9, 1, 3, 6, 0, 2, 0, 1, 1, 8, 6, 5, 0, 0, 0, 5, 7, 7, 8, 5, 5, 5, 1, 6, 1, 5, 1, 0, 6, 2, 3, 2, 1, 7, 5, 1, 9, 8, 3, 3, 9, 7, 3, 0, 2, 3, 9, 4, 4, 3, 1, 6, 8, 6, 6, 8, 5, 4, 3, 6, 7, 7, 4, 6, 9, 6, 2, 4, 0, 1, 3, 6, 4, 9, 2, 6, 0, 3, 8, 7, 5, 3, 3, 8, 3, 2, 6, 3, 6, 5, 7, 4, 5, 7, 9, 0, 0, 6, 7, 2, 0, 5, 5, 7, 5, 5, 9, 4, 6, 4, 2, 3, 5, 6, 4, 1, 6, 3, 1, 6, 7, 0, 5, 0, 1, 9, 7, 3, 5, 2, 3, 9, 5, 6, 4, 0, 0, 0, 8, 0, 3, 2, 4, 5, 3, 7, 9, 6, 9, 3, 1, 2, 6, 7, 4, 5, 1, 3, 7, 0, 9, 3, 8, 5, 8, 5, 8, 5, 6, 5, 0, 8, 3, 8, 1, 8, 1, 5, 0, 9, 9, 6, 3, 6, 5, 4, 4, 7, 4, 7, 4, 3, 2, 4, 4, 5, 7, 5, 4, 5, 8, 0, 5, 4, 0, 5, 4, 3, 2, 2, 4, 2, 9, 4, 8, 8, 6, 2, 6, 1, 7, 0, 4, 3, 8, 5, 9, 7, 6, 7, 1, 0, 2, 3, 5, 6, 7, 1, 6, 2, 8, 3, 5, 2, 5, 7, 5, 7, 7, 1, 7, 4, 5, 3, 4, 0, 4, 2, 7, 0, 2, 2, 6, 6, 2, 5, 0, 6, 2, 6, 1, 2, 9, 0, 0, 1, 5, 5, 1, 6, 7, 8, 9, 6, 3, 3, 6, 0, 9, 9, 2, 2, 6, 1, 4, 6, 2, 5, 7, 8, 8, 3, 6, 4, 3, 2, 3, 4, 4, 4, 8, 9, 2, 6, 0, 9, 7, 9, 8, 7, 7, 3, 8, 2, 9, 3, 3, 7, 5, 8, 7, 3, 7, 0, 7, 1, 6, 2, 4, 0, 0, 2, 9, 8, 2, 8, 0, 4, 5, 5, 0, 1, 2, 9, 6, 1, 0, 1, 0, 6, 5, 0, 5, 7, 4, 4, 8, 3, 3, 3, 7, 2, 5, 8, 3, 5, 7, 3, 7, 0, 5, 4, 3, 6, 9, 3, 5, 5, 8, 2, 4, 2, 2, 6, 7, 6, 0, 5, 5, 8, 4, 3, 6, 1, 3, 5, 4, 7, 3, 0, 7, 2, 0, 1, 3, 4, 9, 6, 4, 5, 9, 7, 7, 6, 7, 4, 3, 1, 6, 9, 4, 8, 0, 5, 9, 6, 4, 4, 2, 1, 4, 6, 3, 0, 8, 9, 7, 6, 8, 4, 8, 1, 4, 5, 9, 4, 7, 1, 4, 5, 2, 1, 2, 6, 4, 7, 1, 5, 9, 2, 1, 4, 8, 7, 7, 0, 2, 3, 4, 6, 7, 7, 2, 4, 4, 4, 3, 6, 6, 1, 9, 9, 7, 9, 4, 3, 2, 9, 8, 5, 0, 6, 9, 0, 9, 7, 8, 5, 4, 4, 9, 4, 2, 6, 6, 9, 9, 7, 9, 9, 0, 5, 1, 1, 0, 6, 9, 9, 5, 6, 5, 5, 9, 7, 9, 4, 5, 4, 3, 3, 9, 8, 8, 5, 4, 8, 4, 0, 4, 0, 7, 2, 8, 0, 2, 0, 7, 4, 0, 6, 2, 3, 1, 7, 3, 6, 4, 0, 6, 9, 5, 6, 6, 3, 0, 5, 2, 6, 3, 3, 0, 0, 8, 5, 4, 2, 9, 5, 0, 5, 4, 8, 2, 7, 6, 5, 7, 8, 2, 0, 1, 8, 2, 4, 8, 4, 3, 0, 7, 0, 1, 9, 4, 0, 3, 4, 5, 5, 2, 8, 3, 0, 9, 7, 5, 2, 4, 3, 7, 8, 2, 3, 1, 0, 0, 9, 1, 2, 1, 4, 6, 7, 1, 0, 5, 2, 5, 9, 2, 5, 6, 7, 1, 9, 3, 6, 1, 0, 2, 9, 4, 2, 9, 3, 8, 2, 9, 8, 5, 1, 0, 1, 5, 2, 5, 6, 8, 8, 3, 5, 0, 4, 1, 3, 7, 0, 3, 3, 9, 2, 3, 9, 9, 8, 5, 9, 7, 2, 0, 9, 4, 7, 1, 7, 6, 4, 4, 8, 9, 0, 7, 1, 2, 4, 0, 3, 7, 5, 1, 9, 3, 5, 2, 4, 1, 1, 3, 3, 9, 2, 7, 8, 8, 8, 1, 3, 1, 5, 9, 0, 9, 2, 4, 0, 6, 9, 1, 1, 3, 4, 9, 5, 3, 3, 2, 3, 4, 1, 5, 9, 8, 7, 5, 8, 7, 3, 5, 2, 5, 8, 9, 7, 2, 0, 0, 7, 5, 3, 5, 7, 7, 6, 2, 8, 2, 7, 7, 6, 1, 3, 8, 6, 2, 0, 4, 4, 8, 6, 4, 0, 2, 5, 4, 9, 2, 4, 4, 6, 9, 3, 0, 5, 2, 0, 8, 2, 6, 4, 7, 9, 5, 7, 2, 3, 2, 1, 9, 9, 7, 2, 5, 1, 8, 1, 6, 3, 0, 8, 8, 5, 6, 9, 9, 9, 6, 3, 0, 8, 8, 5, 3, 3, 1, 1, 0, 7, 0, 3, 0, 4, 4, 6, 5, 3, 2, 9, 6, 6, 7, 9, 7, 7, 0, 8, 7, 2, 7, 7, 7, 4, 0, 1, 6, 0, 5, 3, 0, 2, 4, 9, 7, 3, 3, 2, 8, 8, 5, 3, 8, 0, 8, 0, 0, 0, 2, 0, 9, 0, 7, 7, 7, 2, 2, 0, 4, 0, 3, 7, 8, 4, 7, 9, 6, 1, 1, 6, 9, 3, 8, 9, 5, 8, 3, 1, 3, 3, 7, 5, 5, 2, 7, 5, 7, 9, 6, 3, 0, 8, 4, 3, 6, 1, 0, 3, 6, 4, 7, 1, 3, 2, 0, 9, 1, 8, 8, 6, 8, 1, 7, 1, 0, 8, 7, 6, 4, 5, 8, 2, 1, 2, 6, 8, 1, 1, 8, 8, 8, 9, 0, 0, 4, 3, 3, 5, 6, 6, 5, 1, 4, 4, 7, 8, 0, 1, 4, 8, 4, 6, 2, 2, 2, 6, 3, 4, 0, 8, 1, 3, 8, 3, 8, 9, 1, 6, 1, 9, 8, 2, 0, 4, 7, 4, 0, 0, 7, 6, 8, 9, 8, 6, 2, 8, 8, 0, 1, 1, 0, 7, 7, 2, 4, 7, 7, 2, 6, 6, 7, 4, 5, 4, 0, 9, 4, 7, 2, 5, 3, 2, 2, 7, 6, 2, 6, 4, 1, 6, 8, 3, 8, 5, 5, 2, 3, 4, 5, 2, 7, 5, 1, 5, 3, 7, 8, 8, 9, 2, 0, 9, 2, 6, 0, 0, 1, 4, 1, 3, 5, 1, 8, 9, 6, 2, 6, 9, 9, 6, 5, 9, 1, 4, 2, 8, 9, 5, 4, 7, 0, 3, 7, 1, 6, 9, 0, 1, 4, 0, 5, 1, 6, 3, 0, 2, 3, 5, 5, 2, 0, 2, 3, 1, 6, 2, 7, 0, 8, 9, 2, 6, 4, 7, 5, 5, 8, 8, 7, 8, 5, 7, 4, 4, 0, 0, 7, 0, 4, 0, 4, 4, 2, 5, 4, 0, 7, 3, 7, 0, 4, 6, 2, 9, 1, 1, 5, 0, 9, 1, 0, 6, 5, 7, 0, 9, 0, 6, 2, 2, 4, 1, 3, 7, 6, 1, 0, 4, 6, 0, 4, 4, 2, 7, 6, 4, 3, 5, 9, 4, 5, 2, 0, 5, 7, 2, 3, 9, 4, 5, 8, 1, 9, 3, 2, 8, 5, 8, 6, 6, 3, 4, 0, 2, 3, 2, 6, 1, 8, 2, 1, 3, 3, 2, 2, 3, 3, 5, 0, 2, 1, 2, 8, 0, 8, 2, 2, 7, 3, 5, 9, 8, 3, 6, 1, 0, 8, 6, 7, 5, 8, 9, 4, 8, 0, 0, 2, 0, 1, 8, 3, 7, 2, 8, 2, 9, 3, 8, 9, 6, 8, 9, 5, 4, 8, 9, 5, 5, 7, 2, 9, 8, 8, 1, 2, 3, 1, 5, 0, 2, 3, 0, 8, 2, 2, 8, 7, 6, 5, 3, 9, 6, 2, 5, 1, 1, 7, 7, 7, 5, 8, 3, 6, 0, 8, 0, 6, 6, 4, 6, 9, 1, 1, 7, 0, 6, 8, 9, 0, 6, 9, 0, 1, 1, 7, 2, 1, 0, 4, 5, 0, 3, 6, 3, 3, 8, 1, 8, 1, 6, 1, 5, 4, 5, 1, 8, 9, 1, 3, 1, 7, 2, 9, 8, 9, 4, 6, 0, 9, 4, 0, 4, 6, 2, 1, 5, 0, 1, 5, 6, 0, 3, 4, 6, 9, 3, 7, 9, 0, 3, 6, 5, 7, 0, 5, 1, 2, 2, 9, 7, 0, 0, 1, 4, 4, 5, 5, 9, 6, 3, 6, 2, 6, 9, 3, 2, 3, 2, 4, 9, 5, 2, 1, 6, 6, 4, 7, 6, 5, 3, 8, 1, 4, 6, 4, 4, 5, 6, 2, 0, 5, 2, 7, 5, 2, 5, 2, 5, 9, 0, 6, 7, 9, 8, 3, 2, 1, 4, 3, 4, 5, 5, 6, 8, 6, 0, 8, 9, 8, 0, 0, 7, 6, 6, 7, 5, 9, 8, 7, 9, 5, 6, 0, 4, 8, 0, 2, 9, 1, 3, 9, 8, 3, 7, 4, 5, 0, 2, 1, 9, 1, 0, 5, 8, 4, 7, 3, 1, 4, 3, 3, 1, 0, 0, 8, 8, 8, 1, 4, 7, 3, 9, 6, 9, 1, 6, 0, 7, 7, 1, 3, 3, 3, 1, 0, 2, 7, 1, 2, 2, 9, 6, 3, 5, 9, 4, 8, 0, 4, 8, 0, 1, 3, 7, 0, 4, 0, 0, 8, 6, 4, 3, 9, 8, 2, 2, 8, 3, 1, 1, 2, 8, 2, 6, 9, 6, 8, 4, 6, 1, 5, 2, 6, 9, 2, 0, 7, 1, 8, 9, 3, 9, 9, 0, 7, 7, 5, 4, 2, 6, 4, 5, 7, 7, 8, 7, 2, 6, 2, 4, 4, 4, 0, 7, 1, 5, 3, 6, 2, 0, 2, 3, 8, 6, 2, 4, 3, 5, 2, 9, 1, 0, 0, 6, 5, 5, 7, 9, 9, 6, 5, 5, 0, 5, 7, 1, 6, 6, 4, 1, 3, 4, 1, 5, 0, 0, 4, 5, 8, 3, 8, 3, 0, 5, 0, 5, 3, 1, 6, 7, 0, 9, 1, 5, 7, 6, 5, 5, 5, 6, 0, 0, 1, 7, 3, 1, 9, 2, 4, 1, 3, 7, 8, 0, 0, 9, 6, 6, 0, 6, 5, 8, 2, 7, 4, 0, 2, 7, 7, 8, 8, 7, 0, 4, 9, 1, 4, 4, 3, 5, 4, 6, 2, 3, 1, 0, 3, 3, 3, 6, 3, 1, 2, 0, 9, 7, 9, 3, 8, 7, 3, 1, 7, 7, 3, 2, 2, 8, 9, 5, 9, 2, 1, 7, 4, 4, 0, 5, 3, 1, 5, 4, 2, 8, 4, 9, 8, 7, 8, 4, 2, 3, 4, 0, 5, 4, 1, 8, 2, 5, 4, 5, 2, 5, 3, 7, 9, 7, 1, 4, 1, 3, 1, 4, 5, 5, 1, 7, 1, 3, 0, 1, 2, 5, 7, 0, 6, 3, 5, 7, 5, 5, 8, 9, 4, 6, 3, 6, 6, 8, 2, 6, 4, 8, 4, 1, 3, 9, 2, 3, 3, 0, 1, 6, 4, 2, 8, 2, 4, 3, 1, 4, 4, 4, 4, 1, 5, 5, 7, 6, 5, 4, 5, 6, 5, 6, 2, 4, 7, 2, 4, 6, 5, 0, 2, 3, 9, 2, 3, 8, 0, 7, 0, 6, 8, 1, 2, 8, 9, 1, 5, 4, 2, 3, 5, 5, 3, 6, 5, 0, 3, 2, 1, 3, 3, 7, 7, 4, 9, 4, 5, 9, 5, 1, 7, 6, 6, 4, 8, 5, 1, 2, 8, 4, 2, 3, 3, 3, 0, 4, 8, 7, 7, 9, 3, 8, 4, 3, 9, 1, 8, 3, 1, 3, 8, 0, 3, 5, 4, 6, 9, 2, 7, 2, 0, 7, 2, 9, 7, 5, 0, 7, 0, 3, 5, 3, 3, 8, 7, 7, 1, 6, 5, 8, 9, 0, 1, 9, 4, 0, 0, 9, 7, 2, 2, 8, 5, 9, 8, 2, 8, 0, 6, 6, 8, 6, 9, 5, 1, 1, 5, 3, 5, 0, 7, 6, 1, 4, 6, 1, 1, 8, 1, 1, 2, 3, 4, 9, 9, 3, 2, 7, 4, 3, 6, 9, 6, 9, 8, 8, 6, 7, 4, 7, 2, 5, 8, 0, 9, 0, 7, 8, 1, 2, 3, 2, 4, 2, 9, 0, 3, 8, 9, 6, 5, 5, 2, 4, 1, 0, 6, 1, 8, 4, 5, 5, 5, 0, 8, 9, 0, 5, 7, 9, 6, 3, 4, 6, 4, 9, 7, 1, 2, 5, 2, 1, 0, 7, 3, 9, 8, 1, 9, 7, 7, 3, 1, 4, 1, 1, 3, 8, 8, 1, 9, 3, 8, 9, 5, 1, 1, 6, 2, 7, 2, 6, 4, 6, 9, 6, 0, 1, 3, 9, 3, 8, 8, 8, 2, 9, 1, 6, 6, 0, 5, 0, 7, 7, 7, 9, 4, 5, 0, 0, 3, 5, 5, 8, 1, 1, 2, 7, 1, 3, 4, 6, 9, 1, 0, 7, 1, 9, 5, 8, 1, 9, 9, 7, 9, 8, 3, 0, 2, 6, 0, 2, 2, 4, 0, 8, 4, 8, 1, 5, 7, 2, 7, 9, 5, 2, 2, 9, 2, 6, 5, 4, 6, 5, 6, 5, 1, 8, 2, 6, 8, 6, 7, 0, 8, 0, 0, 9, 9, 6, 8, 0, 6, 6, 0, 7, 9, 8, 0, 5, 0, 9, 6, 0, 4, 7, 1, 7, 8, 8, 2, 3, 9, 3, 5, 5, 3, 1, 5, 3, 0, 2, 5, 2, 7, 3, 8, 4, 4, 6, 1, 9, 3, 1, 7, 0, 1, 4, 3, 0, 2, 9, 4, 3, 0, 3, 4, 7, 2, 3, 0, 1, 3, 7, 9, 9, 0, 7, 5, 6, 7, 1, 2, 3, 7, 3, 6, 8, 4, 9, 8, 4, 9, 2, 3, 4, 0, 2, 5, 6, 0, 3, 8, 5, 8, 3, 7, 4, 9, 5, 6, 3, 8, 6, 1, 8, 5, 5, 8, 3, 5, 9, 0, 4, 3, 0, 5, 1, 9, 3, 8, 0, 6, 0, 2, 3, 7, 8, 0, 6, 9, 1, 5, 0, 2, 7, 9, 3, 9, 3, 5, 2, 2, 2, 8, 8, 5, 0, 0, 7, 0, 4, 1, 6, 7, 0, 9, 2, 6, 7, 4, 2, 0, 0, 5, 3, 3, 2, 6, 4, 2, 7, 8, 0, 1, 0, 1, 3, 6, 4, 8, 0, 6, 0, 9, 1, 6, 5, 1, 0, 1, 3, 0, 4, 7, 9, 9, 3, 7, 5, 7, 1, 6, 6, 9, 8, 1, 4, 2, 2, 1, 7, 0, 1, 2, 1, 1, 3, 4, 6, 9, 1, 3, 2, 0, 8, 7, 3, 5, 6, 2, 6, 9, 3, 8, 9, 3, 0, 5, 7, 2, 0, 2, 2, 9, 3, 8, 7, 1, 1, 2, 2, 2, 6, 9, 1, 2, 6, 1, 2, 1, 8, 9, 2, 2, 1, 9, 9, 4, 4, 5, 5, 0, 3, 3, 7, 1, 7, 7, 1, 8, 6, 3, 5, 5, 1, 6, 2, 7, 8, 4, 3, 3, 5, 9, 6, 8, 5, 1, 0, 6, 7, 2, 9, 6, 2, 0, 8, 7, 1, 2, 6, 9, 1, 6, 4, 7, 1, 9, 0, 0, 5, 2, 8, 3, 8, 4, 8, 4, 0, 8, 3, 3, 1, 3, 3, 0, 5, 0, 4, 1, 7, 2, 0, 1, 3, 9, 1, 6, 1, 6, 1, 2, 8, 7, 0, 9, 5, 0, 8, 0, 1, 7, 9, 7, 1, 9, 2, 1, 9, 7, 3, 6, 0, 2, 0, 0, 9, 9, 8, 9, 4, 5, 4, 3, 0, 7, 8, 7, 3, 7, 3, 4, 6, 5, 9, 5, 2, 4, 2, 7, 9, 6, 7, 4, 7, 1, 2, 3, 1, 1, 3, 2, 8, 3, 7, 7, 0, 8, 1, 5, 2, 3, 5, 3, 6, 3, 5, 9, 8, 4, 2, 8, 0, 4, 1, 7, 8, 4, 9, 3, 2, 6, 6, 8, 8, 6, 7, 3, 8, 1, 1, 5, 3, 7, 9, 9, 9, 8, 5, 9, 9, 6, 8, 8, 4, 8, 1, 0, 1, 8, 8, 6, 5, 9, 0, 6, 1, 6, 6, 6, 3, 5, 6, 5, 5, 3, 3, 6, 8, 9, 4, 4, 3, 8, 5, 6, 0, 8, 5, 7, 8, 4, 6, 5, 5, 1, 8, 3, 0, 2, 9, 3, 3, 5, 3, 3, 2, 7, 7, 9, 2, 0, 5, 3, 6, 1, 1, 3, 9, 9, 3, 6, 7, 1, 8, 3, 9, 8, 7, 8, 8, 0, 3, 2, 4, 8, 7, 3, 7, 1, 8, 7, 3, 5, 4, 4, 3, 8, 6, 1, 1, 6, 3, 2, 2, 8, 9, 8, 3, 3, 8, 1, 1, 0, 5, 2, 0, 5, 0, 5, 0, 6, 3, 9, 6, 6, 3, 9, 4, 8, 3, 4, 3, 1, 1, 2, 9, 7, 8, 5, 5, 8, 6, 9, 0, 8, 3, 2, 1, 3, 3, 5, 5, 3, 8, 9, 4, 6, 4, 2, 4, 3, 8, 9, 6, 2, 6, 5, 5, 2, 7, 7, 4, 4, 9, 3, 8, 3, 7, 7, 8, 5, 3, 9, 1, 6, 7, 3, 3, 3, 8, 5, 6, 1, 3, 7, 9, 6, 1, 6, 4, 9, 0, 5, 7, 4, 9, 1, 0, 0, 2, 7, 8, 3, 2, 2, 6, 1, 6, 6, 4, 4, 2, 1, 8, 4, 4, 7, 8, 5, 8, 9, 3, 3, 2, 3, 9, 3, 0, 1, 1, 1, 1, 6, 8, 7, 1, 0, 0, 4, 5, 0, 3, 0, 6, 2, 0, 9, 8, 2, 8, 5, 8, 2, 9, 6, 0, 6, 1, 8, 7, 6, 2, 2, 6, 5, 6, 9, 2, 5, 4, 9, 8, 5, 3, 9, 3, 5, 7, 1, 8, 5, 8, 6, 2, 5, 1, 3, 0, 4, 1, 0, 3, 4, 9, 2, 1, 4, 4, 5, 9, 8, 7, 2, 1, 6, 9, 7, 3, 6, 1, 8, 0, 2, 2, 4, 9, 0, 5, 5, 4, 2, 3, 1, 0, 0, 0, 4, 4, 9, 1, 3, 3, 0, 2, 1, 1, 0, 4, 1, 9, 4, 8, 1, 1, 1, 5, 9, 8, 1, 6, 7, 2, 9, 9, 7, 8, 8, 1, 9, 7, 8, 9, 1, 6, 6, 3, 3, 1, 3, 0, 8, 8, 3, 6, 6, 7, 9, 0, 7, 6, 4, 8, 2, 0, 6, 6, 8, 6, 3, 1, 1, 8, 6, 7, 0, 5, 4, 3, 2, 2, 7, 8, 2, 0, 1, 7, 4, 8, 7, 6, 6, 7, 0, 0, 4, 9, 0, 6, 5, 1, 5, 8, 6, 8, 1, 9, 6, 7, 6, 5, 0, 6, 0, 1, 3, 1, 1, 5, 2, 4, 3, 3, 8, 1, 6, 6, 1, 8, 8, 6, 2, 7, 4, 6, 8, 9, 6, 3, 5, 5, 3, 1, 4, 1, 9, 5, 1, 7, 7, 7, 5, 2, 3, 3, 6, 6, 6, 4, 0, 7, 1, 7, 6, 0, 1, 1, 2, 4, 1, 2, 2, 4, 9, 8, 2, 8, 7, 6, 3, 4, 7, 2, 3, 1, 5, 3, 0, 4, 3, 4, 9, 4, 7, 9, 1, 7, 8, 5, 1, 8, 3, 2, 5, 7, 2, 7, 9, 6, 8, 6, 0, 3, 5, 9, 0, 4, 8, 5, 6, 3, 3, 8, 0, 4, 8, 6, 7, 2, 7, 1, 7, 4, 1, 2, 4, 2, 2, 8, 7, 2, 2, 6, 7, 7, 6, 8, 9, 9, 3, 5, 2, 9, 8, 7, 2, 3, 3, 7, 4, 3, 2, 1, 9, 8, 1, 5, 3, 2, 6, 5, 9, 1, 5, 4, 3, 6, 2, 0, 9, 7, 8, 0, 8, 9, 1, 2, 5, 7, 2, 0, 6, 6, 1, 6, 3, 1, 5, 0, 0, 5, 4, 6, 5, 6, 4, 8, 3, 4, 5, 5, 0, 6, 6, 7, 5, 0, 9, 9, 6, 1, 0, 4, 6, 5, 6, 9, 3, 6, 6, 8, 2, 1, 0, 1, 9, 3, 7, 4, 3, 0, 2, 7, 6, 4, 3, 0, 8, 3, 0, 0, 9, 6, 6, 6, 8, 7, 6, 1, 8, 1, 2, 2, 4, 8, 5, 2, 6, 5, 3, 9, 1, 0, 7, 2, 4, 4, 0, 0, 6, 2, 2, 4, 0, 5, 9, 7, 1, 8, 4, 5, 5, 9, 0, 5, 7, 8, 0, 9, 8, 9, 1, 6, 3, 8, 0, 3, 4, 4, 8, 4, 8, 9, 8, 6, 0, 0, 8, 2, 0, 4, 2, 5, 6, 0, 5, 8, 4, 1, 9, 0, 1, 4, 5, 8, 4, 9, 6, 0, 7, 7, 6, 8, 9, 6, 2, 0, 4, 9, 4, 9, 3, 9, 6, 6, 7, 0, 9, 7, 1, 8, 6, 0, 6, 4, 4, 1, 9, 4, 6, 7, 9, 8, 3, 9, 2, 1, 2, 7, 6, 1, 0, 0, 5, 6, 0, 4, 3, 3, 8, 8, 0, 6, 9, 5, 2, 8, 7, 0, 6, 5, 9, 7, 2, 5, 6, 9, 6, 2, 2, 4, 1, 0, 5, 9, 8, 9, 3, 5, 9, 3, 8, 1, 6, 3, 7, 5, 6, 2, 0, 2, 8, 2, 8, 7, 7, 8, 1, 0, 8, 9, 7, 0, 3, 8, 0, 5, 9, 5, 8, 4, 2, 0, 9, 2, 2, 4, 4, 9, 2, 2, 5, 3, 1, 3, 2, 0, 0, 4, 0, 6, 5, 8, 0, 5, 8, 6, 4, 8, 5, 2, 9, 7, 9, 7, 1, 0, 1, 9, 0, 9, 2, 7, 9, 6, 4, 0, 6, 2, 4, 1, 5, 7, 2, 8, 5, 9, 0, 3, 2, 3, 2, 7, 6, 5, 2, 5, 9, 0, 5, 9, 9, 8, 7, 5, 4, 0, 6, 2, 2, 3, 1, 0, 4, 1, 8, 8, 4, 9, 4, 4, 3, 3, 9, 2, 0, 1, 1, 8, 4, 4, 8, 3, 6, 9, 5, 7, 6, 2, 5, 4, 7, 3, 3, 9, 0, 1, 5, 9, 5, 7, 6, 0, 4, 2, 2, 5, 6, 3, 8, 9, 5, 6, 1, 4, 5, 4, 6, 7, 2, 1, 0, 2, 0, 4, 9, 8, 8, 9, 1, 1, 5, 0, 0, 8, 7, 1, 7, 4, 5, 4, 3, 3, 2, 0, 6, 6, 0, 1, 3, 9, 8, 3, 7, 8, 9, 4, 8, 9, 0, 9, 7, 1, 6, 2, 9, 5, 2, 9, 5, 9, 8, 7, 7, 9, 6, 3, 3, 9, 3, 1, 2, 5, 1, 8, 2, 0, 9, 5, 1, 8, 8, 6, 7, 3, 7, 1, 3, 9, 0, 9, 3, 6, 7, 2, 5, 3, 0, 5, 9, 7, 3, 5, 0, 6, 5, 1, 8, 2, 7, 5, 9, 0, 0, 0, 0, 8, 7, 3, 7, 8, 9, 3, 7, 9, 7, 8, 7, 9, 8, 5, 4, 8, 7, 7, 6, 3, 8, 2, 9, 9, 3, 7, 9, 9, 5, 5, 8, 7, 3, 5, 3, 5, 9, 7, 6, 7, 3, 6, 4, 3, 9, 4, 2, 1, 9, 6, 0, 2, 6, 7, 4, 7, 9, 0, 7, 4, 5, 5, 3, 1, 1, 2, 6, 8, 2, 1, 7, 8, 5, 9, 6, 1, 1, 5, 0, 6, 0, 9, 2, 6, 3, 8, 9, 5, 5, 6, 2, 9, 1, 3, 1, 8, 7, 1, 7, 5, 2, 4, 9, 7, 5, 2, 9, 9, 4, 3, 2, 1, 3, 8, 7, 9, 0, 4, 5, 7, 5, 2, 8, 7, 6, 9, 6, 1, 3, 8, 5, 6, 6, 9, 5, 7, 8, 0, 3, 0, 7, 4, 8, 2, 5, 1, 5, 2, 2, 6, 2, 1, 7, 2, 6, 5, 1, 3, 7, 7, 1, 3, 7, 0, 8, 4, 4, 5, 7, 9, 5, 4, 3, 9, 6, 8, 2, 3, 3, 1, 6, 1, 7, 0, 3, 4, 2, 9, 4, 5, 8, 2, 7, 0, 9, 6, 8, 0, 8, 2, 8, 5, 7, 7, 2, 2, 0, 0, 0, 7, 4, 1, 6, 6, 8, 8, 1, 0, 9, 0, 1, 2, 3, 0, 9, 2, 6, 2, 6, 3, 4, 0, 8, 4, 1, 4, 0, 6, 5, 0, 9, 9, 1, 9, 1, 2, 3, 5, 4, 2, 9, 6, 0, 9, 6, 6, 8, 0, 6, 9, 4, 6, 8, 0, 5, 4, 9, 2, 0, 9, 6, 4, 2, 4, 6, 3, 9, 7, 7, 3, 6, 5, 0, 1, 9, 0, 3, 1, 9, 0, 9, 7, 8, 6, 7, 6, 8, 2, 4, 5, 3, 0, 3, 2, 1, 7, 5, 9, 3, 4, 5, 5, 1, 5, 0, 1, 1, 1, 9, 7, 5, 4, 9, 7, 8, 1, 0, 2, 8, 5, 6, 7, 2, 2, 4, 8, 4, 4, 6, 6, 5, 8, 1, 8, 4, 6, 5, 9, 2, 2, 1, 4, 9, 1, 6, 7, 2, 0, 1, 7, 6, 5, 2, 2, 5, 6, 0, 0, 0, 1, 5, 3, 3, 5, 8, 7, 5, 6, 5, 8, 0, 5, 9, 4, 6, 5, 1, 1, 0, 5, 3, 9, 4, 8, 1, 7, 7, 9, 9, 4, 3, 6, 3, 2, 8, 2, 7, 6, 7, 0, 2, 1, 2, 9, 4, 6, 9, 6, 1, 0, 1, 8, 7, 9, 0, 4, 7, 4, 3, 6, 9, 5, 9, 0, 7, 4, 5, 8, 1, 4, 7, 9, 9, 8, 8, 6, 3, 7, 0, 8, 9, 6, 2, 4, 3, 2, 9, 7, 4, 2, 8, 5, 6, 1, 6, 5, 9, 9, 1, 3, 2, 0, 3, 0, 2, 0, 7, 3, 9, 3, 5, 7, 6, 5, 9, 5, 6, 1, 2, 4, 0, 2, 7, 8, 4, 4, 2, 9, 5, 9, 2, 9, 3, 2, 4, 3, 2, 2, 8, 8, 6, 8, 1, 6, 8, 9, 8, 5, 9, 4, 9, 1, 5, 7, 1, 6, 0, 1, 5, 2, 8, 1, 1, 3, 8, 1, 8, 1, 8, 5, 1, 9, 0, 5, 0, 4, 0, 5, 1, 2, 0, 4, 9, 5, 1, 2, 4, 7, 8, 7, 2, 4, 5, 3, 7, 0, 6, 1, 5, 9, 8, 0, 2, 0, 7, 6, 0, 6, 9, 7, 5, 0, 4, 6, 0, 6, 3, 6, 8, 1, 1, 8, 9, 7, 2, 9, 0, 2, 2, 9, 0, 6, 5, 7, 7, 9, 1, 7, 9, 8, 4, 5, 0, 8, 0, 2, 5, 2, 1, 4, 4, 8, 9, 7, 8, 3, 6, 6, 0, 1, 1, 1, 8, 1, 7, 4, 0, 7, 8, 2, 1, 2, 5, 4, 6, 0, 5, 7, 4, 4, 3, 9, 5, 8, 8, 0, 8, 7, 4, 1, 8, 4, 9, 5, 3, 1, 7, 7, 7, 7, 0, 3, 8, 2, 3, 0, 5, 7, 0, 8, 0, 0, 9, 2, 0, 3, 4, 8, 2, 2, 6, 4, 3, 6, 2, 9, 4, 0, 1, 7, 5, 5, 7, 3, 0, 4, 6, 0, 7, 5, 8, 0, 8, 4, 7, 0, 3, 5, 3, 8, 3, 5, 1, 7])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "95508450189.66388\n",
      "90858481163.16968\n"
     ]
    }
   ],
   "source": [
    "# predictor cost\n",
    "predictor_cost = kmeans_cost_label(points, predictions, 3072, 10)[1]\n",
    "print(predictor_cost)\n",
    "\n",
    "# predictor + our alg\n",
    "pvals = np.linspace(.01, .15, 15)\n",
    "our_alg_cost = np.inf\n",
    "for p in pvals:\n",
    "    curr_cost = k_means_cost(points, algo3(points, predictions, 10, p))[1]\n",
    "    if curr_cost < our_alg_cost:\n",
    "        our_alg_cost = curr_cost\n",
    "print(our_alg_cost)\n",
    "\n",
    "# k means ++ cost\n",
    "kpp_cost = 0.0\n",
    "for j in range(20):\n",
    "    kmeans_pp_centers = kpp2_opt(points, 10, 3072)\n",
    "    kpp_cost += k_means_cost(points, kmeans_pp_centers)[1]/20.0\n",
    "print(kpp_cost)\n",
    "\n",
    "# sampling cost\n",
    "\n",
    "sampling_cost = np.inf\n",
    "for i in range(1, 51):\n",
    "    curr_error = sampling_baseline(points, predictions, 3072, 10, i)[1]\n",
    "    if curr_error < sampling_cost:\n",
    "        sampling_cost = curr_error\n",
    "print(sampling_cost)\n",
    "\n",
    "# our alg + k means ++\n",
    "\n",
    "kmeans_pp_centers = kpp2_opt(points, 10, 3072)\n",
    "kpp_labels = k_means_labels(points, kmeans_pp_centers)\n",
    "kpp_alg_cost = np.inf\n",
    "for p in pvals:\n",
    "    curr_cost = k_means_cost(points, algo3(points, kpp_labels, 10, p))[1]\n",
    "    if curr_cost < kpp_alg_cost:\n",
    "        kpp_alg_cost = curr_cost\n",
    "print(kpp_alg_cost)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.01\n",
      "0.02\n",
      "0.03\n",
      "0.04\n",
      "0.05\n",
      "0.060000000000000005\n",
      "0.06999999999999999\n",
      "0.08\n",
      "0.09\n",
      "0.09999999999999999\n",
      "0.11\n",
      "0.12\n",
      "0.13\n",
      "0.14\n",
      "0.15000000000000002\n",
      "0.16\n",
      "0.17\n",
      "0.18000000000000002\n",
      "0.19\n",
      "0.2\n",
      "0.21000000000000002\n",
      "0.22\n",
      "0.23\n",
      "0.24000000000000002\n",
      "0.25\n",
      "0.26\n",
      "0.27\n",
      "0.28\n",
      "0.29000000000000004\n",
      "0.3\n",
      "0.31\n",
      "0.32\n",
      "0.33\n",
      "0.34\n",
      "0.35000000000000003\n",
      "0.36000000000000004\n",
      "0.37\n",
      "0.38\n",
      "0.39\n",
      "0.4\n",
      "0.41000000000000003\n",
      "0.42000000000000004\n",
      "0.43\n",
      "0.44\n",
      "0.45\n",
      "0.46\n",
      "0.47000000000000003\n",
      "0.48000000000000004\n",
      "0.49\n",
      "0.5\n",
      "0.51\n",
      "0.52\n",
      "0.53\n",
      "0.54\n",
      "0.55\n",
      "0.56\n",
      "0.5700000000000001\n",
      "0.5800000000000001\n",
      "0.59\n",
      "0.6\n",
      "0.61\n",
      "0.62\n",
      "0.63\n",
      "0.64\n",
      "0.65\n",
      "0.66\n",
      "0.67\n",
      "0.68\n",
      "0.6900000000000001\n",
      "0.7000000000000001\n",
      "0.7100000000000001\n",
      "0.72\n",
      "0.73\n",
      "0.74\n",
      "0.75\n",
      "0.76\n",
      "0.77\n",
      "0.78\n",
      "0.79\n",
      "0.8\n",
      "0.81\n",
      "0.8200000000000001\n",
      "0.8300000000000001\n",
      "0.8400000000000001\n",
      "0.85\n",
      "0.86\n",
      "0.87\n",
      "0.88\n",
      "0.89\n",
      "0.9\n",
      "0.91\n",
      "0.92\n",
      "0.93\n",
      "0.9400000000000001\n",
      "0.9500000000000001\n",
      "0.9600000000000001\n",
      "0.97\n",
      "0.98\n",
      "0.99\n",
      "1.0\n"
     ]
    }
   ],
   "source": [
    "\n",
    "# Subsampling experiment\n",
    "\n",
    "def kmeans_centers(points, labels, d, num_labels):\n",
    "    centers = np.zeros((num_labels, d))\n",
    "    good_indices = []\n",
    "    for i in range(num_labels):\n",
    "        to_index = np.where(labels == i)[0]\n",
    "        if len(to_index) > 0:\n",
    "            curr_points = points[to_index]\n",
    "            centers[i,:] = np.average(curr_points, axis = 0)\n",
    "            good_indices.append(i)\n",
    "        else:\n",
    "            pass\n",
    "    centers = centers[good_indices,:]\n",
    "        \n",
    "    return centers\n",
    "       \n",
    "qvals = np.linspace(0.01, 1.0, 100)\n",
    "fraction_cost = []\n",
    "\n",
    "for q in qvals:\n",
    "    to_keep = int(points.shape[0]*q)\n",
    "    centers = kmeans_centers(points[:to_keep,:],predictions[:to_keep], 3072, 10)\n",
    "    \n",
    "    \n",
    "    our_alg_cost = float('inf')\n",
    "    for p in pvals:\n",
    "        curr_cost = k_means_cost(points, algo3(points[:to_keep,:], predictions[:to_keep], 10, p))[1]\n",
    "        if curr_cost < our_alg_cost:\n",
    "            our_alg_cost = curr_cost\n",
    "    fraction_cost.append(our_alg_cost)\n",
    "            "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(10,7))\n",
    "plt.title(\"Dataset: CIFAR-10, k=10\", fontsize=20)\n",
    "\n",
    "plt.plot(qvals[1:], (fraction_cost[1:]/fraction_cost[-1]-1.0)*100, '.--', linewidth=2.5, markersize=5)\n",
    "\n",
    "plt.xlabel(\"Fraction Queried\", fontsize=20)\n",
    "plt.ylabel(\"Percent Increase in Clustering Cost\", fontsize=20)\n",
    "\n",
    "plt.xticks(fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "# plt.xlim([0.01, 1.03])\n",
    "\n",
    "plt.savefig(\"cifar_fraction_neurips.pdf\", bbox_inches = 'tight', pad_inches = 0)\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "84749033547.69467\n",
      "4.389723062515259\n"
     ]
    }
   ],
   "source": [
    "# Time taken for alpha = 0.01\n",
    "start = time.time()\n",
    "kmeans_pp_centers = kpp2_opt(points, 10, 3072)\n",
    "kpp_labels = k_means_labels(points, kmeans_pp_centers)\n",
    "curr_cost = k_means_cost(points, algo3(points, kpp_labels, 10, 0.01))[1]\n",
    "print(curr_cost)\n",
    "print(time.time()-start)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
