{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "d63bb90e",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from numpy import linalg as LA\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.linear_model import LinearRegression\n",
    "from helpers import *\n",
    "\n",
    "def nearest_neighbor(p, data, already_list=False):\n",
    "    if already_list:\n",
    "        data_test_list = data\n",
    "    else:\n",
    "        data_test_list = list(data)\n",
    "    new_samples = sample(data_test_list, p)\n",
    "    new_samples = np.array(new_samples)\n",
    "    \n",
    "    distances_matrix = np.zeros((p,p))\n",
    "    for i in range(p):\n",
    "        x1 = new_samples[i].flatten()\n",
    "        for j in range(p):\n",
    "            x2 = new_samples[j].flatten()\n",
    "            distances_matrix[i,j] = LA.norm(x1 - x2, ord = 2)\n",
    "    mins = np.where(distances_matrix>0,distances_matrix,distances_matrix.max()).min(1)\n",
    "    #avg_mins = np.mean(np.array(mins))\n",
    "    avg_mins = np.min(np.array(mins))\n",
    "    \n",
    "    return avg_mins\n",
    "\n",
    "p_matrix = [5, 10, 20, 30, 50, 75, 100, 1000, 5000, 10000, 50000]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bfb2aa43",
   "metadata": {},
   "source": [
    "# MNIST Effective Dim"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "ed0c9ed2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The intercept is 7.578619705668785\n",
      "The slope is [-0.13535334]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from random import sample\n",
    "from tensorflow.keras.datasets import mnist\n",
    "(x_train, y_train), (x_test, y_test) = mnist.load_data()\n",
    "x_train.shape\n",
    "\n",
    "effective_dimensions_mnist = []\n",
    "for p in p_matrix:\n",
    "    effective_dimensions_mnist.append(nearest_neighbor(p, x_train))\n",
    "    x = np.array(np.log(p_matrix)).reshape((-1, 1))\n",
    "y = np.array(np.log(effective_dimensions_mnist))\n",
    "model = LinearRegression().fit(x, y)\n",
    "\n",
    "plt.plot(np.log(p_matrix), np.log(effective_dimensions_mnist))\n",
    "plt.title('Effective Dimension of MNIST on Log-Log Scale')\n",
    "plt.xlabel('Log(P)')\n",
    "plt.ylabel('Log(Nearest-Neighbor Distance)')\n",
    "\n",
    "print('The intercept is', model.intercept_)\n",
    "print('The slope is', model.coef_)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0e05739c",
   "metadata": {},
   "source": [
    "# CIFAR 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "d44972e5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The intercept is 7.821002514800786\n",
      "The slope is [-0.23524268]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from keras.datasets import cifar10\n",
    "(trainX, trainy), (testX, testy) = cifar10.load_data()\n",
    "gray = lambda rgb : np.dot(rgb[... , :3] , [0.299 , 0.587, 0.114]) \n",
    "imgs = gray(trainX)\n",
    "\n",
    "effective_dimensions = []\n",
    "for p in p_matrix:\n",
    "    effective_dimensions.append(nearest_neighbor(p, imgs))\n",
    "    \n",
    "x = np.array(np.log(p_matrix)).reshape((-1, 1))\n",
    "y = np.array(np.log(effective_dimensions))\n",
    "model = LinearRegression().fit(x, y)\n",
    "\n",
    "plt.plot(np.log(p_matrix), np.log(effective_dimensions))\n",
    "plt.title('Effective Dimension of CIFAR10 on Log-Log Scale')\n",
    "plt.xlabel('Log(P)')\n",
    "plt.ylabel('Log(Nearest-Neighbor Distance)')\n",
    "\n",
    "print('The intercept is', model.intercept_)\n",
    "print('The slope is', model.coef_)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1167f256",
   "metadata": {},
   "source": [
    "# CIFAR10 patch space"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "cd5d40c1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The intercept is 6.155886779122236\n",
      "The slope is [-0.17320581]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "num_patches, patch_size = 100000, 12\n",
    "inputs_list = random_patch_generator(n=num_patches, imgs=imgs, size=patch_size)\n",
    "\n",
    "effective_dimensions_patch = []\n",
    "for p in p_matrix:\n",
    "    effective_dimensions_patch.append(nearest_neighbor(p, inputs_list, already_list=True))\n",
    "    \n",
    "x = np.array(np.log(p_matrix)).reshape((-1, 1))\n",
    "y = np.array(np.log(effective_dimensions_patch))\n",
    "model = LinearRegression().fit(x, y)\n",
    "\n",
    "plt.plot(np.log(p_matrix), np.log(effective_dimensions_patch))\n",
    "plt.title('Effective Dimension of CIFAR10 on Log-Log Scale')\n",
    "plt.xlabel('Log(P)')\n",
    "plt.ylabel('Log(Nearest-Neighbor Distance)')\n",
    "\n",
    "print('The intercept is', model.intercept_)\n",
    "print('The slope is', model.coef_)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3cb080c7",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.8.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
