{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import util\n",
    "import subspace_clustering\n",
    "import numpy as np\n",
    "import sklearn.datasets\n",
    "import matplotlib.pyplot as plt\n",
    "from numba import jit"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "data = util.load_normalized_datasets([util.Dataset.MNIST])[0]\n",
    "alg = subspace_clustering.K_Subspaces_algo(10, 1, max_iter=10)\n",
    "data = data[0]\n",
    "# centers_full, original_cost = alg.get_original_solution(data)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def assign_points_batch(data, centers, k):\n",
    "        dim = 1\n",
    "        dists_to_centers = np.zeros((data.shape[0], k))\n",
    "        for i, center in enumerate(centers):\n",
    "            # UUt = np.outer(center,center)\n",
    "            center_fixed_dim = center.reshape((dim, data.shape[1]))\n",
    "            UUt = np.matmul(center_fixed_dim.T,center_fixed_dim)\n",
    "            diff = np.eye(data.shape[1]) - UUt\n",
    "            proj = diff@data.T\n",
    "            dist =  np.linalg.norm(proj, axis=0)**2\n",
    "            dists_to_centers[:,i] = dist\n",
    "        clusters = np.argmin(dists_to_centers, axis=1)\n",
    "        clusters_list = [data[clusters==i] for i in range(k)]\n",
    "        return clusters_list\n",
    "\n",
    "# clusters = assign_points_batch(alg, data, centers_full, 10)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration  0\n",
      "iteration  1\n",
      "iteration  2\n",
      "iteration  3\n",
      "iteration  4\n",
      "iteration  5\n",
      "early stopped with [455.5201744433054, 135.8599501196483, 132.47131826462768, 132.47131826462766, 132.4713182646277, 132.47131826462766]\n",
      "[455.5201744433054, 135.8599501196483, 132.47131826462768, 132.47131826462766, 132.4713182646277, 132.47131826462766]\n",
      "[[[ 0.33945699 -0.94062158]]\n",
      "\n",
      " [[-0.51334406 -0.85818289]]]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x2a6abfac400>]"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAioAAAGfCAYAAABx3/noAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/P9b71AAAACXBIWXMAAA9hAAAPYQGoP6dpAABbvklEQVR4nO3dd3iTZfvG8W+6GR0UCmWUvVqRLciUUWihoCiioiCgoiIucACKIgIC4utGcaPiwIUKZZU9BBERFSkbZJbdQaEz+f3xSH+slnSkT5Ken+PowZuSJhd9a3L2fu77uiw2m82GiIiIiBPyMLsAERERkdwoqIiIiIjTUlARERERp6WgIiIiIk5LQUVEREScloKKiIiIOC0FFREREXFaCioiIiLitBRURERExGkpqIiIiIjT8nLkg69atYpp06bx+++/c+TIEebMmUOfPn1y/n7w4MF8+umnF31NVFQUCxcutPs5rFYrhw8fxt/fH4vFUlSli4iIiAPZbDZSUlKoUqUKHh65r5s4NKikpqbSpEkT7rnnHm655ZYr3ic6OppPPvkk57avr2++nuPw4cOEhYUVqk4RERExx4EDB6hWrVquf+/QoNKjRw969OiR5318fX0JDQ0t8HP4+/sDxj80ICCgwI8jIiIixSc5OZmwsLCc9/HcODSo2GPFihVUrFiRcuXK0aVLFyZOnEj58uVzvX96ejrp6ek5t1NSUgAICAhQUBEREXExV9u2Yepm2ujoaD777DOWLl3K1KlTWblyJT169CA7OzvXr5k8eTKBgYE5H7rsIyIi4r4sNpvNVixPZLFctpn2Unv27KFOnTosWbKErl27XvE+l66onF86SkpK0oqKiIiIi0hOTiYwMPCq799OdTy5du3aVKhQgV27duV6H19f35zLPLrcIyIi4t6cKqgcPHiQkydPUrlyZbNLERERESfg0M20Z86cuWh1ZO/evWzevJng4GCCg4MZP348ffv2JTQ0lN27d/P0009Tt25doqKiHFmWiIiIuAiHBpWNGzfSuXPnnNsjR44EYNCgQbz77rv89ddffPrppyQmJlKlShW6d+/OhAkT8t1LRURERNxTsW2mdRR7N+OIiIiI83DJzbQiIiIiF1JQEREREaeloCIiIiJOS0FFREREnJaCioiIiDgtBRUpmMxMuPVW+OknsysRERE3pqAiBfPOO/D9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JQVAl4BERERcUEpKCoGBgbn+fb6CSkhICCEhIYUuKjebN2+mXLlydocUgCpVqnDgwAH8/f2xWCwOq80ZJCcnExYWxoEDBwgICDC7HKej70/e9P3Jnb43edP3J2/6/uQtt++PzWYjJSWFKlWq5Pn1Djv1s3//fk6dOsX+/fvJzs5m8+bNANStW5eyZcsyd+5cjh49yvXXX4+fnx9xcXG89NJLPPnkk/l6Hg8PD6pVq+aAf4HzCggI0H8MedD3J2/6/uRO35u86fuTN31/8nal709eKynnOSyoPP/883z66ac5t5s1awbA8uXL6dSpE97e3kyfPp0RI0Zgs9moW7cur776KkOHDnVUSSIiIuJiHBZUZs6cmWcPlejo6IsavYmIiIhcyvQ+KmI/X19fxo0bl689PCWJvj950/cnd/re5E3fn7zp+5O3wn5/LLarnQsSERERMYlWVERERMRpKaiIiIiI01JQEREREaeloCIiIiJOS0FFREREnJaCiguLjY2ldevWlCpVinLlytGnTx+zS3I66enpNG3aFIvFktMduaTbt28f9957L7Vq1aJUqVLUqVOHcePGkZGRYXZpppk+fTo1a9bEz8+P1q1bs2HDBrNLcgqTJ0/muuuuw9/fn4oVK9KnTx+2b99udllOacqUKVgsFh5//HGzS3Eqhw4dYsCAAZQvX55SpUpx7bXXsnHjxnw9hoKKi/r+++8ZOHAgQ4YM4c8//2Tt2rXceeedZpfldJ5++umrzpEoabZt24bVauW9997jn3/+4bXXXmPGjBk888wzZpdmitmzZzNy5EjGjRvHpk2baNKkCVFRURw7dszs0ky3cuVKhg8fzvr164mLiyMzM5Pu3buTmppqdmlO5bfffuO9996jcePGZpfiVE6fPk27du3w9vZmwYIFbN26lf/973+UK1cufw9kE5eTmZlpq1q1qu3DDz80uxSnNn/+fFvDhg1t//zzjw2w/fHHH2aX5LRefvllW61atcwuwxStWrWyDR8+POd2dna2rUqVKrbJkyebWJVzOnbsmA2wrVy50uxSnEZKSoqtXr16tri4ONsNN9xge+yxx8wuyWmMGjXK1r59+0I/jlZUXNCmTZs4dOgQHh4eNGvWjMqVK9OjRw+2bNlidmlO4+jRowwdOpTPP/+c0qVLm12O00tKSiI4ONjsMopdRkYGv//+O5GRkTmf8/DwIDIyknXr1plYmXNKSkoCKJE/K7kZPnw4MTExF/0MieHnn3+mZcuW9OvXj4oVK9KsWTM++OCDfD+OgooL2rNnDwAvvPACY8eOZd68eZQrV45OnTpx6tQpk6szn81mY/DgwTz44IO0bNnS7HKc3q5du3jrrbd44IEHzC6l2J04cYLs7GwqVap00ecrVapEQkKCSVU5J6vVyuOPP067du1o1KiR2eU4ha+//ppNmzYxefJks0txSnv27OHdd9+lXr16LFq0iGHDhvHoo49eNLDYHgoqTmT06NFYLJY8P87vLwB49tln6du3Ly1atOCTTz7BYrHw7bffmvyvcBx7vz9vvfUWKSkpjBkzxuySi5W9358LHTp0iOjoaPr166fJ5ZKn4cOHs2XLFr7++muzS3EKBw4c4LHHHuOLL77Az8/P7HKcktVqpXnz5rz00ks0a9aM+++/n6FDhzJjxox8PY7DpidL/j3xxBMMHjw4z/vUrl2bI0eOABAREZHzeV9fX2rXrs3+/fsdWaKp7P3+LFu2jHXr1l02AKtly5bcdddd+U7zrsLe7895hw8fpnPnzrRt25b333/fwdU5pwoVKuDp6cnRo0cv+vzRo0cJDQ01qSrn8/DDDzNv3jxWrVpFtWrVzC7HKfz+++8cO3aM5s2b53wuOzubVatW8fbbb5Oeno6np6eJFZqvcuXKF71PAYSHh/P999/n63EUVJxISEgIISEhV71fixYt8PX1Zfv27bRv3x6AzMxM9u3bR40aNRxdpmns/f68+eabTJw4Mef24cOHiYqKYvbs2bRu3dqRJZrK3u8PGCspnTt3zlmN8/AomYurPj4+tGjRgqVLl+Yc77darSxdupSHH37Y3OKcgM1m45FHHmHOnDmsWLGCWrVqmV2S0+jatSt///33RZ8bMmQIDRs2ZNSoUSU+pAC0a9fusuPsO3bsyPf7lIKKCwoICODBBx9k3LhxhIWFUaNGDaZNmwZAv379TK7OfNWrV7/odtmyZQGoU6eOfhvECCmdOnWiRo0avPLKKxw/fjzn70riKsLIkSMZNGgQLVu2pFWrVrz++uukpqYyZMgQs0sz3fDhw/nyyy/56aef8Pf3z9m3ExgYSKlSpUyuzlz+/v6X7dUpU6YM5cuX1x6e/4wYMYK2bdvy0ksvcdttt7Fhwwbef//9fK/gKqi4qGnTpuHl5cXAgQM5d+4crVu3ZtmyZfk/ny4lTlxcHLt27WLXrl2XBTebzWZSVea5/fbbOX78OM8//zwJCQk0bdqUhQsXXrbBtiR69913AejUqdNFn//kk0+ueplR5LrrrmPOnDmMGTOGF198kVq1avH6669z11135etxLLaS+MokIiIiLqFkXpgWERERl6CgIiIiIk5LQUVEREScloKKiIiIOC0FFREREXFaCioiIiLitBRURERExGkpqIiIiIjTUlARERERp6WgIiIiIk5LQUVERESc1v8Ba6GoxyAwN38AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "data_blobs = sklearn.datasets.make_blobs(n_samples=100, n_features=2, centers=3, cluster_std=0.5, center_box=(-10.0, 10.0), shuffle=True, random_state=None)[0]\n",
    "alg = subspace_clustering.K_Subspaces_algo(2, 1)\n",
    "alg.fit(data_blobs)\n",
    "centers = alg.centers\n",
    "print(centers)\n",
    "vector = centers[0][0]\n",
    "range = 5\n",
    "center1_y = [-range*vector[1]/vector[0], range*vector[1]/vector[0]]\n",
    "center1_x = [-range,range]\n",
    "\n",
    "center2_y = [-range*centers[1][0][1]/centers[1][0][0], range*centers[1][0][1]/centers[1][0][0]]\n",
    "\n",
    "center2 = centers[1][0]\n",
    "plt.scatter(data_blobs[:,0], data_blobs[:,1])\n",
    "plt.plot( center1_x, center1_y, color='red')\n",
    "plt.plot( center1_x, center2_y)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration  0\n",
      "iteration  1\n",
      "iteration  2\n",
      "iteration  3\n",
      "iteration  4\n",
      "iteration  5\n",
      "early stopped with [2640.733649351484, 1989.9899691159783, 1966.4197900565646, 1949.2809184456942, 1941.5232169490814, 1937.8775750257116]\n",
      "[2640.733649351484, 1989.9899691159783, 1966.4197900565646, 1949.2809184456942, 1941.5232169490814, 1937.8775750257116]\n"
     ]
    }
   ],
   "source": [
    "data_subset = data[0:10000]\n",
    "centers_full, original_cost = alg.get_original_solution(data_subset)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "# @jit(nopython=True)\n",
    "def get_dists_to_nearest_center( data, centers,dim):\n",
    "    # if centers is None:\n",
    "    #     centers = self.centers\n",
    "    dists_to_centers = np.zeros((data.shape[0], len(centers)))\n",
    "    for i, center in enumerate(centers):\n",
    "        # UUt = np.outer(center,center)\n",
    "        center_fixed_dim = center.reshape((dim, data.shape[1]))\n",
    "        UUt = np.matmul(center_fixed_dim.T,center_fixed_dim)\n",
    "        diff = np.eye(data.shape[1]) - UUt\n",
    "        proj = diff@data.T\n",
    "        dist =  np.linalg.norm(proj, axis=0)**2\n",
    "        dists_to_centers[:,i] = dist\n",
    "    clusters = np.argmin(dists_to_centers, axis=1)\n",
    "    min_dists = np.min(dists_to_centers, axis=1)\n",
    "    return min_dists, clusters\n",
    "\n",
    "def fast_inner_stuff():\n",
    "    pass\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "#@jit(nopython=True)\n",
    "def get_dists_to_nearest_center2( data, centers,dim):\n",
    "    # if centers is None:\n",
    "    #     centers = self.centers\n",
    "    dists_to_centers = np.zeros((data.shape[0], len(centers)))\n",
    "    for i, center in enumerate(centers):\n",
    "        # UUt = np.outer(center,center)\n",
    "        center_fixed_dim = center.reshape((dim, data.shape[1]))\n",
    "        UUt = np.matmul(center_fixed_dim.T,center_fixed_dim)\n",
    "        diff = np.eye(data.shape[1]) - UUt\n",
    "        for j in range(data.shape[0]):\n",
    "            proj = diff@data[j]\n",
    "            dist =  np.linalg.norm(proj)**2\n",
    "            dists_to_centers[j,i] = dist\n",
    "        # proj = diff@data.T\n",
    "        # dist =  np.linalg.norm(proj, axis=0)**2\n",
    "        # dists_to_centers[:,i] = dist\n",
    "    clusters = np.argmin(dists_to_centers, axis=1)\n",
    "    min_dists = np.min(dists_to_centers, axis=1)\n",
    "    return min_dists, clusters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "dists, clusters = get_dists_to_nearest_center(data_subset, centers_full,1)\n",
    "#dists2, clusters2 = get_dists_to_nearest_center2(data_subset, centers_full,1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "c:\\Users\\au616584\\Anaconda3\\envs\\subspace\\lib\\site-packages\\tqdm\\auto.py:22: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using device: cpu\n",
      "early stopped with [44.61883, 42.709797, 42.709816, 42.709835, 42.709812, 42.709843]\n",
      "early stopped with [56.81381, 42.709812, 42.709827, 42.70983, 42.709827, 42.709824]\n",
      "early stopped with [161.79314, 44.61239, 42.709805, 42.70983, 42.709824, 42.709827, 42.709827]\n",
      "[[[-0.6589334  -0.7522013 ]]\n",
      "\n",
      " [[-0.31743008 -0.9482817 ]]]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x2a6d065bcd0>]"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import subspace_z_alg\n",
    "data_blobs = sklearn.datasets.make_blobs(n_samples=100, n_features=2, centers=3, cluster_std=0.5, center_box=(-10.0, 10.0), shuffle=True, random_state=None)[0]\n",
    "alg = subspace_z_alg.Kz_Subspaces_algo(2, 3,1,100,40)\n",
    "alg.get_original_solution(data_blobs)\n",
    "centers = alg.centers\n",
    "print(centers)\n",
    "vector = centers[0][0]\n",
    "range = 5\n",
    "center1_y = [-range*vector[1]/vector[0], range*vector[1]/vector[0]]\n",
    "center1_x = [-range,range]\n",
    "\n",
    "center2_y = [-range*centers[1][0][1]/centers[1][0][0], range*centers[1][0][1]/centers[1][0][0]]\n",
    "\n",
    "center2 = centers[1][0]\n",
    "plt.scatter(data_blobs[:,0], data_blobs[:,1])\n",
    "plt.plot( center1_x, center1_y, color='red')\n",
    "plt.plot( center1_x, center2_y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using device: cpu\n",
      "early stopped with [400924.97, 65199.37, 62834.797, 62833.79, 62833.72, 62832.555, 62832.53]\n",
      "early stopped with [69357.45, 58155.47, 57770.984, 57684.53, 57665.234, 57660.734]\n",
      "early stopped with [75947.1, 62760.61, 62760.082, 62759.72, 62759.53, 62759.438]\n",
      "Using device: cpu\n",
      "early stopped with [84837.03, 62858.043, 62787.13, 62787.438, 62785.215, 62785.67]\n",
      "early stopped with [77375.77, 60673.695, 59044.645, 58078.73, 57742.688, 57661.777, 57643.223, 57640.242]\n",
      "early stopped with [79868.9, 62748.832, 62731.836, 62731.99, 62732.277, 62732.14]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(array([[[-0.5356308 , -0.12497271, -0.30766025, -0.7764191 ],\n",
       "         [-0.44936636, -0.7929619 ,  0.09300004,  0.40078956]],\n",
       " \n",
       "        [[-0.2877386 ,  0.41114727,  0.6718457 , -0.54478234],\n",
       "         [-0.35095885, -0.59322304,  0.572633  ,  0.44385323]]],\n",
       "       dtype=float32),\n",
       " 57640.242)"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data = sklearn.datasets.make_blobs(n_samples=100000, n_features=4, centers=3, cluster_std=0.5, center_box=(-10.0, 10.0), shuffle=True, random_state=None)[0]\n",
    "\n",
    "alg1 = subspace_z_alg.Kz_Subspaces_algo(2, 1,2,100,40, lr=0.01)\n",
    "alg1.get_original_solution(data)\n",
    "alg2 = subspace_z_alg.Kz_Subspaces_algo(2, 1,2,50,40, lr=0.005)\n",
    "alg2.get_original_solution(data)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "subspace",
   "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.10.8 | packaged by conda-forge | (main, Nov 24 2022, 14:07:00) [MSC v.1916 64 bit (AMD64)]"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "3f94b3ea8b08becd1766c9f3a63569b610389292faace546d6478dffb17875b9"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
