{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "from openTSNE import TSNE\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os.path as path"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_train = [\n",
    "    pd.read_csv(path.join(path.dirname(\"~/rvqe/notebooks/data/\"), f\"mnist.train.{d}.csv\"), header=None)\n",
    "    for d in range(0, 10)\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_validate = [\n",
    "    pd.read_csv(path.join(path.dirname(\"~/rvqe/notebooks/data/\"), f\"mnist.validate.{d}.csv\"), header=None)\n",
    "    for d in range(0, 10)\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [],
   "source": [
    "data_test = [\n",
    "    pd.read_csv(path.join(path.dirname(\"~/rvqe/notebooks/data/\"), f\"mnist.test.{d}.csv\"), header=None)\n",
    "    for d in range(0, 10)\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [],
   "source": [
    "def embedding(dim: int):\n",
    "    tsne = TSNE(\n",
    "        n_components=dim,\n",
    "        perplexity=40,\n",
    "        metric=\"euclidean\",\n",
    "        negative_gradient_method=\"bh\",\n",
    "        verbose=True,\n",
    "        n_jobs=3,\n",
    "        random_state=42,\n",
    "    )\n",
    "    \n",
    "    return tsne.fit(pd.concat(data_train, ignore_index=True).to_numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/johannes/miniconda3/envs/rvqe/lib/python3.8/site-packages/sklearn/base.py:193: FutureWarning: From version 0.24, get_params will raise an AttributeError if a parameter cannot be retrieved as an instance attribute. Previously it would return None.\n",
      "  warnings.warn('From version 0.24, get_params will raise an '\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------------------------------------------------------------------------------\n",
      "TSNE(callbacks=None, callbacks_every_iters=50, dof=1, early_exaggeration=12,\n",
      "     early_exaggeration_iter=250, exaggeration=None, final_momentum=0.8,\n",
      "     initial_momentum=0.5, initialization='pca', ints_in_interval=1,\n",
      "     learning_rate='auto', max_grad_norm=None, metric='euclidean',\n",
      "     metric_params=None, min_num_intervals=50, n_components=2,\n",
      "     n_interpolation_points=3, n_iter=500, n_jobs=3,\n",
      "     negative_gradient_method='bh', neighbors=None, perplexity=40,\n",
      "     random_state=42, theta=0.5, verbose=True)\n",
      "--------------------------------------------------------------------------------\n",
      "===> Finding 120 nearest neighbors using Annoy approximate search using euclidean distance...\n",
      "   --> Time elapsed: 15.36 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 2.06 seconds\n",
      "===> Calculating PCA-based initialization...\n",
      "   --> Time elapsed: 0.11 seconds\n",
      "===> Running optimization with exaggeration=12.00, lr=4584.17 for 250 iterations...\n",
      "Iteration   50, KL divergence 6.1254, 50 iterations in 9.7886 sec\n",
      "Iteration  100, KL divergence 5.6561, 50 iterations in 9.3628 sec\n",
      "Iteration  150, KL divergence 5.5283, 50 iterations in 9.0726 sec\n",
      "Iteration  200, KL divergence 5.4674, 50 iterations in 9.2153 sec\n",
      "Iteration  250, KL divergence 5.4301, 50 iterations in 8.9861 sec\n",
      "   --> Time elapsed: 46.43 seconds\n",
      "===> Running optimization with exaggeration=1.00, lr=4584.17 for 500 iterations...\n",
      "Iteration   50, KL divergence 3.9062, 50 iterations in 8.9833 sec\n",
      "Iteration  100, KL divergence 3.4111, 50 iterations in 9.0491 sec\n",
      "Iteration  150, KL divergence 3.1596, 50 iterations in 8.5640 sec\n",
      "Iteration  200, KL divergence 3.0002, 50 iterations in 8.4004 sec\n",
      "Iteration  250, KL divergence 2.8875, 50 iterations in 8.2673 sec\n",
      "Iteration  300, KL divergence 2.8030, 50 iterations in 8.6231 sec\n",
      "Iteration  350, KL divergence 2.7375, 50 iterations in 8.8227 sec\n",
      "Iteration  400, KL divergence 2.6856, 50 iterations in 9.0437 sec\n",
      "Iteration  450, KL divergence 2.6435, 50 iterations in 8.8529 sec\n",
      "Iteration  500, KL divergence 2.6088, 50 iterations in 8.5665 sec\n",
      "   --> Time elapsed: 87.17 seconds\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/johannes/miniconda3/envs/rvqe/lib/python3.8/site-packages/sklearn/base.py:193: FutureWarning: From version 0.24, get_params will raise an AttributeError if a parameter cannot be retrieved as an instance attribute. Previously it would return None.\n",
      "  warnings.warn('From version 0.24, get_params will raise an '\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--------------------------------------------------------------------------------\n",
      "TSNE(callbacks=None, callbacks_every_iters=50, dof=1, early_exaggeration=12,\n",
      "     early_exaggeration_iter=250, exaggeration=None, final_momentum=0.8,\n",
      "     initial_momentum=0.5, initialization='pca', ints_in_interval=1,\n",
      "     learning_rate='auto', max_grad_norm=None, metric='euclidean',\n",
      "     metric_params=None, min_num_intervals=50, n_components=3,\n",
      "     n_interpolation_points=3, n_iter=500, n_jobs=3,\n",
      "     negative_gradient_method='bh', neighbors=None, perplexity=40,\n",
      "     random_state=42, theta=0.5, verbose=True)\n",
      "--------------------------------------------------------------------------------\n",
      "===> Finding 120 nearest neighbors using Annoy approximate search using euclidean distance...\n",
      "   --> Time elapsed: 15.99 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 2.14 seconds\n",
      "===> Calculating PCA-based initialization...\n",
      "   --> Time elapsed: 0.09 seconds\n",
      "===> Running optimization with exaggeration=12.00, lr=4584.17 for 250 iterations...\n",
      "Iteration   50, KL divergence 6.0167, 50 iterations in 25.4627 sec\n",
      "Iteration  100, KL divergence 5.5386, 50 iterations in 20.7475 sec\n",
      "Iteration  150, KL divergence 5.4387, 50 iterations in 20.6869 sec\n",
      "Iteration  200, KL divergence 5.3975, 50 iterations in 21.7323 sec\n",
      "Iteration  250, KL divergence 5.3762, 50 iterations in 21.5772 sec\n",
      "   --> Time elapsed: 110.21 seconds\n",
      "===> Running optimization with exaggeration=1.00, lr=4584.17 for 500 iterations...\n",
      "Iteration   50, KL divergence 3.5901, 50 iterations in 21.4888 sec\n",
      "Iteration  100, KL divergence 3.1391, 50 iterations in 20.1891 sec\n",
      "Iteration  150, KL divergence 2.9117, 50 iterations in 19.7278 sec\n",
      "Iteration  200, KL divergence 2.7673, 50 iterations in 19.4789 sec\n",
      "Iteration  250, KL divergence 2.6653, 50 iterations in 21.3576 sec\n",
      "Iteration  300, KL divergence 2.5888, 50 iterations in 19.4769 sec\n",
      "Iteration  350, KL divergence 2.5291, 50 iterations in 19.7095 sec\n",
      "Iteration  400, KL divergence 2.4814, 50 iterations in 19.8951 sec\n",
      "Iteration  450, KL divergence 2.4426, 50 iterations in 20.8562 sec\n",
      "Iteration  500, KL divergence 2.4103, 50 iterations in 20.9945 sec\n",
      "   --> Time elapsed: 203.18 seconds\n"
     ]
    }
   ],
   "source": [
    "embeddings = {\n",
    "    d: embedding(d)\n",
    "    for d in [2, 3]\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.60 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.02 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 67195.3654, 50 iterations in 2.2987 sec\n",
      "Iteration  100, KL divergence 67143.1887, 50 iterations in 2.4547 sec\n",
      "Iteration  150, KL divergence 67130.5326, 50 iterations in 2.3515 sec\n",
      "Iteration  200, KL divergence 67125.9478, 50 iterations in 2.2406 sec\n",
      "Iteration  250, KL divergence 67118.2154, 50 iterations in 2.2671 sec\n",
      "   --> Time elapsed: 11.61 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.72 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.03 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 65042.3243, 50 iterations in 5.8327 sec\n",
      "Iteration  100, KL divergence 64978.8025, 50 iterations in 5.2946 sec\n",
      "Iteration  150, KL divergence 64942.1729, 50 iterations in 5.3076 sec\n",
      "Iteration  200, KL divergence 64918.1342, 50 iterations in 5.2671 sec\n",
      "Iteration  250, KL divergence 64909.4331, 50 iterations in 5.1166 sec\n",
      "   --> Time elapsed: 26.82 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.66 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.02 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 77102.8241, 50 iterations in 2.5606 sec\n",
      "Iteration  100, KL divergence 77032.4251, 50 iterations in 2.6139 sec\n",
      "Iteration  150, KL divergence 77021.5757, 50 iterations in 2.3723 sec\n",
      "Iteration  200, KL divergence 77006.2809, 50 iterations in 2.3412 sec\n",
      "Iteration  250, KL divergence 77005.7945, 50 iterations in 2.3530 sec\n",
      "   --> Time elapsed: 12.24 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.71 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.02 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 74396.9802, 50 iterations in 6.0641 sec\n",
      "Iteration  100, KL divergence 74290.4335, 50 iterations in 5.5475 sec\n",
      "Iteration  150, KL divergence 74261.5761, 50 iterations in 5.1823 sec\n",
      "Iteration  200, KL divergence 74256.3790, 50 iterations in 5.1259 sec\n",
      "Iteration  250, KL divergence 74246.8153, 50 iterations in 5.1829 sec\n",
      "   --> Time elapsed: 27.10 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.73 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.03 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 68655.6757, 50 iterations in 2.8207 sec\n",
      "Iteration  100, KL divergence 68499.8525, 50 iterations in 2.5971 sec\n",
      "Iteration  150, KL divergence 68466.4588, 50 iterations in 2.3163 sec\n",
      "Iteration  200, KL divergence 68438.9859, 50 iterations in 2.2819 sec\n",
      "Iteration  250, KL divergence 68428.5662, 50 iterations in 2.3009 sec\n",
      "   --> Time elapsed: 12.32 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.61 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.02 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 66182.7529, 50 iterations in 5.8938 sec\n",
      "Iteration  100, KL divergence 65947.5713, 50 iterations in 5.0401 sec\n",
      "Iteration  150, KL divergence 65869.6180, 50 iterations in 5.1890 sec\n",
      "Iteration  200, KL divergence 65815.3674, 50 iterations in 5.2092 sec\n",
      "Iteration  250, KL divergence 65797.3699, 50 iterations in 5.4063 sec\n",
      "   --> Time elapsed: 26.74 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.68 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.02 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 72183.7384, 50 iterations in 2.7287 sec\n",
      "Iteration  100, KL divergence 71926.3329, 50 iterations in 2.5076 sec\n",
      "Iteration  150, KL divergence 71865.1329, 50 iterations in 2.5086 sec\n",
      "Iteration  200, KL divergence 71845.5124, 50 iterations in 2.7554 sec\n",
      "Iteration  250, KL divergence 71838.3357, 50 iterations in 2.6286 sec\n",
      "   --> Time elapsed: 13.13 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.69 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.03 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 69051.3727, 50 iterations in 5.7752 sec\n",
      "Iteration  100, KL divergence 68740.7174, 50 iterations in 5.4301 sec\n",
      "Iteration  150, KL divergence 68623.9716, 50 iterations in 5.8437 sec\n",
      "Iteration  200, KL divergence 68570.1968, 50 iterations in 5.3360 sec\n",
      "Iteration  250, KL divergence 68532.9062, 50 iterations in 5.3298 sec\n",
      "   --> Time elapsed: 27.72 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.66 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.02 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 67001.8318, 50 iterations in 2.9426 sec\n",
      "Iteration  100, KL divergence 66908.4984, 50 iterations in 2.3380 sec\n",
      "Iteration  150, KL divergence 66896.5267, 50 iterations in 2.2874 sec\n",
      "Iteration  200, KL divergence 66891.6740, 50 iterations in 2.3393 sec\n",
      "Iteration  250, KL divergence 66891.6945, 50 iterations in 2.3660 sec\n",
      "   --> Time elapsed: 12.27 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.70 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.03 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 64395.3578, 50 iterations in 6.0151 sec\n",
      "Iteration  100, KL divergence 64201.9593, 50 iterations in 5.2292 sec\n",
      "Iteration  150, KL divergence 64180.1154, 50 iterations in 5.0319 sec\n",
      "Iteration  200, KL divergence 64175.5875, 50 iterations in 5.1502 sec\n",
      "Iteration  250, KL divergence 64165.7202, 50 iterations in 5.0126 sec\n",
      "   --> Time elapsed: 26.44 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.53 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.02 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 61886.3613, 50 iterations in 3.0207 sec\n",
      "Iteration  100, KL divergence 61760.0873, 50 iterations in 2.5725 sec\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration  150, KL divergence 61732.0696, 50 iterations in 2.2772 sec\n",
      "Iteration  200, KL divergence 61701.9171, 50 iterations in 2.2900 sec\n",
      "Iteration  250, KL divergence 61687.4507, 50 iterations in 2.2767 sec\n",
      "   --> Time elapsed: 12.44 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.53 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.02 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 59565.6736, 50 iterations in 5.7168 sec\n",
      "Iteration  100, KL divergence 59310.1519, 50 iterations in 5.0976 sec\n",
      "Iteration  150, KL divergence 59196.2099, 50 iterations in 5.4170 sec\n",
      "Iteration  200, KL divergence 59154.2938, 50 iterations in 5.2532 sec\n",
      "Iteration  250, KL divergence 59131.0257, 50 iterations in 5.3458 sec\n",
      "   --> Time elapsed: 26.83 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.69 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.03 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 67113.8218, 50 iterations in 2.7998 sec\n",
      "Iteration  100, KL divergence 67060.6978, 50 iterations in 2.4042 sec\n",
      "Iteration  150, KL divergence 67049.8537, 50 iterations in 2.2905 sec\n",
      "Iteration  200, KL divergence 67047.7223, 50 iterations in 2.2721 sec\n",
      "Iteration  250, KL divergence 67044.6566, 50 iterations in 2.2784 sec\n",
      "   --> Time elapsed: 12.05 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.66 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.03 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 64890.8140, 50 iterations in 6.0134 sec\n",
      "Iteration  100, KL divergence 64837.0515, 50 iterations in 5.3129 sec\n",
      "Iteration  150, KL divergence 64827.3055, 50 iterations in 5.4752 sec\n",
      "Iteration  200, KL divergence 64826.8157, 50 iterations in 5.2156 sec\n",
      "Iteration  250, KL divergence 64823.2215, 50 iterations in 5.2032 sec\n",
      "   --> Time elapsed: 27.22 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.77 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.03 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 72028.1814, 50 iterations in 2.8038 sec\n",
      "Iteration  100, KL divergence 71846.3375, 50 iterations in 2.5836 sec\n",
      "Iteration  150, KL divergence 71822.7708, 50 iterations in 2.3794 sec\n",
      "Iteration  200, KL divergence 71815.5053, 50 iterations in 2.3839 sec\n",
      "Iteration  250, KL divergence 71805.3681, 50 iterations in 2.3665 sec\n",
      "   --> Time elapsed: 12.52 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.67 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.02 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 69650.2412, 50 iterations in 5.7720 sec\n",
      "Iteration  100, KL divergence 69395.4272, 50 iterations in 5.2094 sec\n",
      "Iteration  150, KL divergence 69332.0371, 50 iterations in 5.4035 sec\n",
      "Iteration  200, KL divergence 69300.9020, 50 iterations in 5.2902 sec\n",
      "Iteration  250, KL divergence 69276.1194, 50 iterations in 5.4914 sec\n",
      "   --> Time elapsed: 27.17 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.68 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.02 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 68894.0822, 50 iterations in 2.9677 sec\n",
      "Iteration  100, KL divergence 68498.0909, 50 iterations in 2.5659 sec\n",
      "Iteration  150, KL divergence 68424.7464, 50 iterations in 2.3847 sec\n",
      "Iteration  200, KL divergence 68396.1255, 50 iterations in 2.3821 sec\n",
      "Iteration  250, KL divergence 68376.4547, 50 iterations in 2.4309 sec\n",
      "   --> Time elapsed: 12.73 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.77 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.04 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 66026.4497, 50 iterations in 6.5382 sec\n",
      "Iteration  100, KL divergence 65704.5037, 50 iterations in 6.4121 sec\n",
      "Iteration  150, KL divergence 65584.3819, 50 iterations in 7.3495 sec\n",
      "Iteration  200, KL divergence 65532.3610, 50 iterations in 5.6010 sec\n",
      "Iteration  250, KL divergence 65515.3720, 50 iterations in 5.3928 sec\n",
      "   --> Time elapsed: 31.29 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.59 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.02 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 68503.0078, 50 iterations in 3.0348 sec\n",
      "Iteration  100, KL divergence 68358.7969, 50 iterations in 2.5628 sec\n",
      "Iteration  150, KL divergence 68313.6450, 50 iterations in 2.3870 sec\n",
      "Iteration  200, KL divergence 68287.0630, 50 iterations in 2.3227 sec\n",
      "Iteration  250, KL divergence 68271.4321, 50 iterations in 2.4488 sec\n",
      "   --> Time elapsed: 12.76 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.64 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.02 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 66031.0439, 50 iterations in 6.0408 sec\n",
      "Iteration  100, KL divergence 65839.0694, 50 iterations in 5.2437 sec\n",
      "Iteration  150, KL divergence 65789.1764, 50 iterations in 5.2192 sec\n",
      "Iteration  200, KL divergence 65764.8105, 50 iterations in 5.3780 sec\n",
      "Iteration  250, KL divergence 65746.1484, 50 iterations in 6.1396 sec\n",
      "   --> Time elapsed: 28.02 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.08 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5268.4989, 50 iterations in 2.1390 sec\n",
      "Iteration  100, KL divergence 5260.1644, 50 iterations in 2.1799 sec\n",
      "Iteration  150, KL divergence 5255.1140, 50 iterations in 2.1130 sec\n",
      "Iteration  200, KL divergence 5255.1011, 50 iterations in 2.0076 sec\n",
      "Iteration  250, KL divergence 5255.1011, 50 iterations in 1.9305 sec\n",
      "   --> Time elapsed: 10.37 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.08 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5119.6932, 50 iterations in 4.4286 sec\n",
      "Iteration  100, KL divergence 5103.0526, 50 iterations in 4.6177 sec\n",
      "Iteration  150, KL divergence 5102.9200, 50 iterations in 3.9235 sec\n",
      "Iteration  200, KL divergence 5102.9202, 50 iterations in 3.9309 sec\n",
      "Iteration  250, KL divergence 5102.9202, 50 iterations in 3.9112 sec\n",
      "   --> Time elapsed: 20.81 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.07 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5128.0500, 50 iterations in 2.2333 sec\n",
      "Iteration  100, KL divergence 5121.5710, 50 iterations in 2.1124 sec\n",
      "Iteration  150, KL divergence 5121.5644, 50 iterations in 2.2283 sec\n",
      "Iteration  200, KL divergence 5121.5645, 50 iterations in 1.8682 sec\n",
      "Iteration  250, KL divergence 5121.5645, 50 iterations in 1.8269 sec\n",
      "   --> Time elapsed: 10.27 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.07 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 4955.2170, 50 iterations in 4.8067 sec\n",
      "Iteration  100, KL divergence 4941.2322, 50 iterations in 4.5144 sec\n",
      "Iteration  150, KL divergence 4936.1968, 50 iterations in 3.9911 sec\n",
      "Iteration  200, KL divergence 4936.1659, 50 iterations in 3.9437 sec\n",
      "Iteration  250, KL divergence 4936.1657, 50 iterations in 3.9027 sec\n",
      "   --> Time elapsed: 21.16 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.07 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5455.2735, 50 iterations in 2.2868 sec\n",
      "Iteration  100, KL divergence 5441.0278, 50 iterations in 2.3868 sec\n",
      "Iteration  150, KL divergence 5437.4699, 50 iterations in 2.0677 sec\n",
      "Iteration  200, KL divergence 5437.4638, 50 iterations in 2.0480 sec\n",
      "Iteration  250, KL divergence 5437.4637, 50 iterations in 1.8204 sec\n",
      "   --> Time elapsed: 10.61 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.07 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5266.8753, 50 iterations in 4.8665 sec\n",
      "Iteration  100, KL divergence 5236.1851, 50 iterations in 3.9494 sec\n",
      "Iteration  150, KL divergence 5226.8111, 50 iterations in 3.8757 sec\n",
      "Iteration  200, KL divergence 5226.4426, 50 iterations in 3.9276 sec\n",
      "Iteration  250, KL divergence 5226.2808, 50 iterations in 4.1603 sec\n",
      "   --> Time elapsed: 20.78 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.07 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5564.7636, 50 iterations in 2.4513 sec\n",
      "Iteration  100, KL divergence 5538.3521, 50 iterations in 2.2240 sec\n",
      "Iteration  150, KL divergence 5530.9156, 50 iterations in 1.9913 sec\n",
      "Iteration  200, KL divergence 5526.5552, 50 iterations in 1.9077 sec\n",
      "Iteration  250, KL divergence 5526.5036, 50 iterations in 1.8856 sec\n",
      "   --> Time elapsed: 10.46 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.07 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5388.4523, 50 iterations in 4.5393 sec\n",
      "Iteration  100, KL divergence 5334.6613, 50 iterations in 4.0857 sec\n",
      "Iteration  150, KL divergence 5310.2060, 50 iterations in 3.9517 sec\n",
      "Iteration  200, KL divergence 5303.9730, 50 iterations in 3.9290 sec\n",
      "Iteration  250, KL divergence 5298.3056, 50 iterations in 3.9794 sec\n",
      "   --> Time elapsed: 20.49 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.07 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5413.4045, 50 iterations in 2.2742 sec\n",
      "Iteration  100, KL divergence 5386.9086, 50 iterations in 2.2464 sec\n",
      "Iteration  150, KL divergence 5383.5751, 50 iterations in 1.9423 sec\n",
      "Iteration  200, KL divergence 5383.5703, 50 iterations in 1.8969 sec\n",
      "Iteration  250, KL divergence 5383.5690, 50 iterations in 1.8832 sec\n",
      "   --> Time elapsed: 10.24 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.07 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5234.5127, 50 iterations in 4.8844 sec\n",
      "Iteration  100, KL divergence 5206.7414, 50 iterations in 4.6477 sec\n",
      "Iteration  150, KL divergence 5198.6265, 50 iterations in 4.8570 sec\n",
      "Iteration  200, KL divergence 5190.8494, 50 iterations in 4.3498 sec\n",
      "Iteration  250, KL divergence 5187.8083, 50 iterations in 3.9332 sec\n",
      "   --> Time elapsed: 22.67 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.08 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5459.8994, 50 iterations in 2.2585 sec\n",
      "Iteration  100, KL divergence 5440.2723, 50 iterations in 1.9631 sec\n",
      "Iteration  150, KL divergence 5436.2348, 50 iterations in 2.7060 sec\n",
      "Iteration  200, KL divergence 5433.5996, 50 iterations in 1.8723 sec\n",
      "Iteration  250, KL divergence 5433.5956, 50 iterations in 1.8966 sec\n",
      "   --> Time elapsed: 10.70 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.09 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5271.4571, 50 iterations in 4.5082 sec\n",
      "Iteration  100, KL divergence 5229.7312, 50 iterations in 4.0314 sec\n",
      "Iteration  150, KL divergence 5209.9142, 50 iterations in 3.9559 sec\n",
      "Iteration  200, KL divergence 5205.8235, 50 iterations in 4.0888 sec\n",
      "Iteration  250, KL divergence 5205.8036, 50 iterations in 4.4706 sec\n",
      "   --> Time elapsed: 21.06 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.07 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5328.0238, 50 iterations in 2.2758 sec\n",
      "Iteration  100, KL divergence 5314.9020, 50 iterations in 2.0992 sec\n",
      "Iteration  150, KL divergence 5312.7533, 50 iterations in 1.8322 sec\n",
      "Iteration  200, KL divergence 5312.7523, 50 iterations in 1.8483 sec\n",
      "Iteration  250, KL divergence 5312.7523, 50 iterations in 1.8296 sec\n",
      "   --> Time elapsed: 9.89 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.07 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5152.2461, 50 iterations in 4.5986 sec\n",
      "Iteration  100, KL divergence 5130.2601, 50 iterations in 3.9196 sec\n",
      "Iteration  150, KL divergence 5127.4834, 50 iterations in 3.9099 sec\n",
      "Iteration  200, KL divergence 5127.2719, 50 iterations in 4.1254 sec\n",
      "Iteration  250, KL divergence 5127.2613, 50 iterations in 4.0730 sec\n",
      "   --> Time elapsed: 20.63 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.08 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5345.7692, 50 iterations in 2.1435 sec\n",
      "Iteration  100, KL divergence 5331.8151, 50 iterations in 2.2838 sec\n",
      "Iteration  150, KL divergence 5329.5552, 50 iterations in 1.8476 sec\n",
      "Iteration  200, KL divergence 5329.4657, 50 iterations in 1.8913 sec\n",
      "Iteration  250, KL divergence 5329.4038, 50 iterations in 2.1843 sec\n",
      "   --> Time elapsed: 10.35 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.07 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5167.0100, 50 iterations in 4.7387 sec\n",
      "Iteration  100, KL divergence 5135.1282, 50 iterations in 3.9004 sec\n",
      "Iteration  150, KL divergence 5128.9941, 50 iterations in 3.9543 sec\n",
      "Iteration  200, KL divergence 5127.7839, 50 iterations in 3.9295 sec\n",
      "Iteration  250, KL divergence 5127.7333, 50 iterations in 3.8921 sec\n",
      "   --> Time elapsed: 20.42 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.07 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5629.8691, 50 iterations in 2.1833 sec\n",
      "Iteration  100, KL divergence 5600.2853, 50 iterations in 2.2528 sec\n",
      "Iteration  150, KL divergence 5594.2677, 50 iterations in 1.8510 sec\n",
      "Iteration  200, KL divergence 5589.8420, 50 iterations in 1.8541 sec\n",
      "Iteration  250, KL divergence 5589.8194, 50 iterations in 1.8787 sec\n",
      "   --> Time elapsed: 10.02 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.07 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5398.4883, 50 iterations in 4.7459 sec\n",
      "Iteration  100, KL divergence 5362.6670, 50 iterations in 4.2952 sec\n",
      "Iteration  150, KL divergence 5343.1884, 50 iterations in 3.8750 sec\n",
      "Iteration  200, KL divergence 5334.6037, 50 iterations in 3.8737 sec\n",
      "Iteration  250, KL divergence 5330.9379, 50 iterations in 3.8679 sec\n",
      "   --> Time elapsed: 20.66 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.08 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5479.5305, 50 iterations in 2.0715 sec\n",
      "Iteration  100, KL divergence 5452.9460, 50 iterations in 2.1049 sec\n",
      "Iteration  150, KL divergence 5449.5566, 50 iterations in 1.8184 sec\n",
      "Iteration  200, KL divergence 5447.1404, 50 iterations in 1.8380 sec\n",
      "Iteration  250, KL divergence 5447.1555, 50 iterations in 1.8405 sec\n",
      "   --> Time elapsed: 9.67 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.07 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5247.7007, 50 iterations in 4.8664 sec\n",
      "Iteration  100, KL divergence 5207.9532, 50 iterations in 3.9938 sec\n",
      "Iteration  150, KL divergence 5201.6852, 50 iterations in 3.9763 sec\n",
      "Iteration  200, KL divergence 5199.7515, 50 iterations in 4.0286 sec\n",
      "Iteration  250, KL divergence 5194.1089, 50 iterations in 4.0318 sec\n",
      "   --> Time elapsed: 20.90 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.14 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 11022.1026, 50 iterations in 2.6147 sec\n",
      "Iteration  100, KL divergence 11001.1201, 50 iterations in 2.1266 sec\n",
      "Iteration  150, KL divergence 11000.3193, 50 iterations in 1.9815 sec\n",
      "Iteration  200, KL divergence 11000.3145, 50 iterations in 2.1311 sec\n",
      "Iteration  250, KL divergence 11000.3161, 50 iterations in 2.1305 sec\n",
      "   --> Time elapsed: 10.99 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.12 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.01 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 10726.0526, 50 iterations in 5.0199 sec\n",
      "Iteration  100, KL divergence 10702.4016, 50 iterations in 4.5886 sec\n",
      "Iteration  150, KL divergence 10700.6037, 50 iterations in 4.3356 sec\n",
      "Iteration  200, KL divergence 10700.5890, 50 iterations in 3.9813 sec\n",
      "Iteration  250, KL divergence 10700.4882, 50 iterations in 4.0709 sec\n",
      "   --> Time elapsed: 22.00 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.15 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.01 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 12562.0005, 50 iterations in 2.3050 sec\n",
      "Iteration  100, KL divergence 12538.3093, 50 iterations in 2.2734 sec\n",
      "Iteration  150, KL divergence 12527.6751, 50 iterations in 1.8682 sec\n",
      "Iteration  200, KL divergence 12523.4344, 50 iterations in 1.8956 sec\n",
      "Iteration  250, KL divergence 12523.0895, 50 iterations in 1.9226 sec\n",
      "   --> Time elapsed: 10.27 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.13 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 12147.5757, 50 iterations in 5.0421 sec\n",
      "Iteration  100, KL divergence 12114.1348, 50 iterations in 4.0916 sec\n",
      "Iteration  150, KL divergence 12110.9021, 50 iterations in 4.3462 sec\n",
      "Iteration  200, KL divergence 12106.2953, 50 iterations in 4.0641 sec\n",
      "Iteration  250, KL divergence 12102.2079, 50 iterations in 4.3167 sec\n",
      "   --> Time elapsed: 21.86 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.12 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 12055.1184, 50 iterations in 2.2532 sec\n",
      "Iteration  100, KL divergence 12008.5425, 50 iterations in 1.9794 sec\n",
      "Iteration  150, KL divergence 11987.8597, 50 iterations in 1.9435 sec\n",
      "Iteration  200, KL divergence 11982.5849, 50 iterations in 1.9199 sec\n",
      "Iteration  250, KL divergence 11980.5197, 50 iterations in 1.9311 sec\n",
      "   --> Time elapsed: 10.03 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.17 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.01 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 11644.5847, 50 iterations in 4.7686 sec\n",
      "Iteration  100, KL divergence 11562.3134, 50 iterations in 4.9697 sec\n",
      "Iteration  150, KL divergence 11539.2307, 50 iterations in 4.1153 sec\n",
      "Iteration  200, KL divergence 11536.1511, 50 iterations in 4.3152 sec\n",
      "Iteration  250, KL divergence 11532.7913, 50 iterations in 4.7733 sec\n",
      "   --> Time elapsed: 22.94 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.17 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.01 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 11958.8962, 50 iterations in 2.4970 sec\n",
      "Iteration  100, KL divergence 11926.0917, 50 iterations in 2.2085 sec\n",
      "Iteration  150, KL divergence 11918.2424, 50 iterations in 1.9023 sec\n",
      "Iteration  200, KL divergence 11917.8404, 50 iterations in 2.1765 sec\n",
      "Iteration  250, KL divergence 11917.6888, 50 iterations in 2.0466 sec\n",
      "   --> Time elapsed: 10.83 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.12 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 11587.9634, 50 iterations in 4.9968 sec\n",
      "Iteration  100, KL divergence 11505.1547, 50 iterations in 4.7175 sec\n",
      "Iteration  150, KL divergence 11469.7108, 50 iterations in 4.3248 sec\n",
      "Iteration  200, KL divergence 11462.6030, 50 iterations in 4.2736 sec\n",
      "Iteration  250, KL divergence 11458.0737, 50 iterations in 4.1688 sec\n",
      "   --> Time elapsed: 22.48 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.15 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.01 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 11303.7898, 50 iterations in 2.4646 sec\n",
      "Iteration  100, KL divergence 11268.7279, 50 iterations in 2.0937 sec\n",
      "Iteration  150, KL divergence 11266.2633, 50 iterations in 2.2968 sec\n",
      "Iteration  200, KL divergence 11266.1884, 50 iterations in 1.9795 sec\n",
      "Iteration  250, KL divergence 11266.1881, 50 iterations in 1.8758 sec\n",
      "   --> Time elapsed: 10.71 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.11 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 10941.2719, 50 iterations in 4.9301 sec\n",
      "Iteration  100, KL divergence 10894.0700, 50 iterations in 4.1076 sec\n",
      "Iteration  150, KL divergence 10875.8765, 50 iterations in 4.1097 sec\n",
      "Iteration  200, KL divergence 10872.1096, 50 iterations in 4.3567 sec\n",
      "Iteration  250, KL divergence 10870.5585, 50 iterations in 4.4879 sec\n",
      "   --> Time elapsed: 21.99 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.11 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 10322.3566, 50 iterations in 2.3381 sec\n",
      "Iteration  100, KL divergence 10274.6364, 50 iterations in 2.3139 sec\n",
      "Iteration  150, KL divergence 10273.5640, 50 iterations in 2.0314 sec\n",
      "Iteration  200, KL divergence 10272.6247, 50 iterations in 1.8820 sec\n",
      "Iteration  250, KL divergence 10270.5314, 50 iterations in 1.9501 sec\n",
      "   --> Time elapsed: 10.52 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.11 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 10034.9889, 50 iterations in 4.9245 sec\n",
      "Iteration  100, KL divergence 9966.2499, 50 iterations in 4.0407 sec\n",
      "Iteration  150, KL divergence 9941.5855, 50 iterations in 4.0961 sec\n",
      "Iteration  200, KL divergence 9929.7049, 50 iterations in 4.1797 sec\n",
      "Iteration  250, KL divergence 9928.1115, 50 iterations in 4.0380 sec\n",
      "   --> Time elapsed: 21.28 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.13 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.01 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 10778.0939, 50 iterations in 2.4412 sec\n",
      "Iteration  100, KL divergence 10757.4021, 50 iterations in 2.1392 sec\n",
      "Iteration  150, KL divergence 10755.3984, 50 iterations in 1.8426 sec\n",
      "Iteration  200, KL divergence 10755.3971, 50 iterations in 1.8416 sec\n",
      "Iteration  250, KL divergence 10755.3971, 50 iterations in 1.8497 sec\n",
      "   --> Time elapsed: 10.11 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.12 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.01 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 10480.7884, 50 iterations in 4.7781 sec\n",
      "Iteration  100, KL divergence 10448.1991, 50 iterations in 4.0311 sec\n",
      "Iteration  150, KL divergence 10439.2725, 50 iterations in 4.0515 sec\n",
      "Iteration  200, KL divergence 10439.0591, 50 iterations in 3.9793 sec\n",
      "Iteration  250, KL divergence 10438.7717, 50 iterations in 4.0596 sec\n",
      "   --> Time elapsed: 20.90 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "   --> Time elapsed: 0.13 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.01 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 11789.2299, 50 iterations in 2.2374 sec\n",
      "Iteration  100, KL divergence 11743.5261, 50 iterations in 2.3099 sec\n",
      "Iteration  150, KL divergence 11733.3577, 50 iterations in 1.9023 sec\n",
      "Iteration  200, KL divergence 11732.9224, 50 iterations in 1.8602 sec\n",
      "Iteration  250, KL divergence 11728.0688, 50 iterations in 1.8834 sec\n",
      "   --> Time elapsed: 10.19 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.14 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 11445.3856, 50 iterations in 4.8985 sec\n",
      "Iteration  100, KL divergence 11392.8711, 50 iterations in 3.9835 sec\n",
      "Iteration  150, KL divergence 11374.4769, 50 iterations in 4.0385 sec\n",
      "Iteration  200, KL divergence 11366.9625, 50 iterations in 4.0225 sec\n",
      "Iteration  250, KL divergence 11361.9449, 50 iterations in 4.0400 sec\n",
      "   --> Time elapsed: 20.98 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.13 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.01 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 11757.6106, 50 iterations in 2.4088 sec\n",
      "Iteration  100, KL divergence 11669.0288, 50 iterations in 2.1449 sec\n",
      "Iteration  150, KL divergence 11643.3406, 50 iterations in 1.8544 sec\n",
      "Iteration  200, KL divergence 11635.8862, 50 iterations in 1.8490 sec\n",
      "Iteration  250, KL divergence 11633.3491, 50 iterations in 1.8622 sec\n",
      "   --> Time elapsed: 10.12 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.14 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.01 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 11340.4646, 50 iterations in 5.0098 sec\n",
      "Iteration  100, KL divergence 11222.5240, 50 iterations in 4.0401 sec\n",
      "Iteration  150, KL divergence 11188.0061, 50 iterations in 4.0625 sec\n",
      "Iteration  200, KL divergence 11174.6559, 50 iterations in 4.1145 sec\n",
      "Iteration  250, KL divergence 11167.5021, 50 iterations in 4.1000 sec\n",
      "   --> Time elapsed: 21.33 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.13 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 11685.7974, 50 iterations in 2.3499 sec\n",
      "Iteration  100, KL divergence 11661.3976, 50 iterations in 2.2056 sec\n",
      "Iteration  150, KL divergence 11661.2564, 50 iterations in 2.1254 sec\n",
      "Iteration  200, KL divergence 11660.3757, 50 iterations in 1.8621 sec\n",
      "Iteration  250, KL divergence 11654.0581, 50 iterations in 1.8578 sec\n",
      "   --> Time elapsed: 10.40 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.12 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 11364.8917, 50 iterations in 4.6144 sec\n",
      "Iteration  100, KL divergence 11308.1328, 50 iterations in 3.9868 sec\n",
      "Iteration  150, KL divergence 11266.6697, 50 iterations in 4.0487 sec\n",
      "Iteration  200, KL divergence 11256.9655, 50 iterations in 4.1146 sec\n",
      "Iteration  250, KL divergence 11253.0935, 50 iterations in 4.0738 sec\n",
      "   --> Time elapsed: 20.84 seconds\n"
     ]
    }
   ],
   "source": [
    "for table_list, tag in [\n",
    "    (data_train, \"train\"),\n",
    "    (data_validate, \"validate\"),\n",
    "    (data_test, \"test\")\n",
    "]:\n",
    "    for d, table in enumerate(table_list):\n",
    "        for dim in embeddings:\n",
    "            embedding = embeddings[dim]\n",
    "            embedded_table = pd.DataFrame(\n",
    "                embedding.transform(table.to_numpy())\n",
    "            )\n",
    "            embedded_table.to_csv(\n",
    "                path.join(path.dirname(\"~/rvqe/notebooks/data/\"), f\"mnist.{tag}.{d}.tSNE-{dim}.csv\"),\n",
    "                header=None,\n",
    "                index=None\n",
    "            )\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_all = pd.concat(data_train, ignore_index=True).to_numpy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.58 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.02 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 67195.3654, 50 iterations in 2.2806 sec\n",
      "Iteration  100, KL divergence 67143.1887, 50 iterations in 2.2107 sec\n",
      "Iteration  150, KL divergence 67130.5326, 50 iterations in 2.2270 sec\n",
      "Iteration  200, KL divergence 67125.9478, 50 iterations in 2.1793 sec\n",
      "Iteration  250, KL divergence 67118.2154, 50 iterations in 2.3060 sec\n",
      "   --> Time elapsed: 11.20 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.74 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.03 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 77102.8241, 50 iterations in 2.4101 sec\n",
      "Iteration  100, KL divergence 77032.4251, 50 iterations in 2.3850 sec\n",
      "Iteration  150, KL divergence 77021.5757, 50 iterations in 2.3372 sec\n",
      "Iteration  200, KL divergence 77006.2809, 50 iterations in 2.3485 sec\n",
      "Iteration  250, KL divergence 77005.7945, 50 iterations in 2.3202 sec\n",
      "   --> Time elapsed: 11.80 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.62 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.02 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 68655.6757, 50 iterations in 2.2762 sec\n",
      "Iteration  100, KL divergence 68499.8525, 50 iterations in 2.2748 sec\n",
      "Iteration  150, KL divergence 68466.4588, 50 iterations in 2.2294 sec\n",
      "Iteration  200, KL divergence 68438.9859, 50 iterations in 2.2418 sec\n",
      "Iteration  250, KL divergence 68428.5662, 50 iterations in 2.2527 sec\n",
      "   --> Time elapsed: 11.28 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.65 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.02 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 72183.7384, 50 iterations in 2.3746 sec\n",
      "Iteration  100, KL divergence 71926.3329, 50 iterations in 2.3203 sec\n",
      "Iteration  150, KL divergence 71865.1329, 50 iterations in 2.5102 sec\n",
      "Iteration  200, KL divergence 71845.5124, 50 iterations in 2.4854 sec\n",
      "Iteration  250, KL divergence 71838.3357, 50 iterations in 2.4005 sec\n",
      "   --> Time elapsed: 12.09 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.61 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.02 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 67001.8318, 50 iterations in 2.2337 sec\n",
      "Iteration  100, KL divergence 66908.4984, 50 iterations in 2.2964 sec\n",
      "Iteration  150, KL divergence 66896.5267, 50 iterations in 2.3297 sec\n",
      "Iteration  200, KL divergence 66891.6740, 50 iterations in 2.2722 sec\n",
      "Iteration  250, KL divergence 66891.6945, 50 iterations in 2.2172 sec\n",
      "   --> Time elapsed: 11.35 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.53 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.02 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 61886.3613, 50 iterations in 2.1792 sec\n",
      "Iteration  100, KL divergence 61760.0873, 50 iterations in 2.2638 sec\n",
      "Iteration  150, KL divergence 61732.0696, 50 iterations in 2.2346 sec\n",
      "Iteration  200, KL divergence 61701.9171, 50 iterations in 2.2388 sec\n",
      "Iteration  250, KL divergence 61687.4507, 50 iterations in 2.2503 sec\n",
      "   --> Time elapsed: 11.17 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.59 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.02 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 67113.8218, 50 iterations in 2.1916 sec\n",
      "Iteration  100, KL divergence 67060.6978, 50 iterations in 2.1717 sec\n",
      "Iteration  150, KL divergence 67049.8537, 50 iterations in 2.1736 sec\n",
      "Iteration  200, KL divergence 67047.7223, 50 iterations in 2.2305 sec\n",
      "Iteration  250, KL divergence 67044.6566, 50 iterations in 2.2306 sec\n",
      "   --> Time elapsed: 11.00 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.60 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.02 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 72028.1814, 50 iterations in 2.2605 sec\n",
      "Iteration  100, KL divergence 71846.3375, 50 iterations in 2.2276 sec\n",
      "Iteration  150, KL divergence 71822.7708, 50 iterations in 2.1979 sec\n",
      "Iteration  200, KL divergence 71815.5053, 50 iterations in 2.2221 sec\n",
      "Iteration  250, KL divergence 71805.3681, 50 iterations in 2.2383 sec\n",
      "   --> Time elapsed: 11.15 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.59 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.02 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 68894.0822, 50 iterations in 2.2698 sec\n",
      "Iteration  100, KL divergence 68498.0909, 50 iterations in 2.2502 sec\n",
      "Iteration  150, KL divergence 68424.7464, 50 iterations in 2.2167 sec\n",
      "Iteration  200, KL divergence 68396.1255, 50 iterations in 2.2657 sec\n",
      "Iteration  250, KL divergence 68376.4547, 50 iterations in 2.4016 sec\n",
      "   --> Time elapsed: 11.40 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.59 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.02 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 68503.0078, 50 iterations in 2.2904 sec\n",
      "Iteration  100, KL divergence 68358.7969, 50 iterations in 2.2862 sec\n",
      "Iteration  150, KL divergence 68313.6450, 50 iterations in 2.2318 sec\n",
      "Iteration  200, KL divergence 68287.0630, 50 iterations in 2.3120 sec\n",
      "Iteration  250, KL divergence 68271.4321, 50 iterations in 2.3548 sec\n",
      "   --> Time elapsed: 11.48 seconds\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": [
    "for d in range(10):\n",
    "    plt.scatter(*zip(*(\n",
    "            embeddings[2].transform(data_train[d].to_numpy())\n",
    "        )),\n",
    "        color=['#1f77b4',\n",
    "               '#ff7f0e',\n",
    "               '#2ca02c',\n",
    "               '#d62728',\n",
    "               '#9467bd',\n",
    "               '#8c564b',\n",
    "               '#e377c2',\n",
    "               '#7f7f7f',\n",
    "               '#bcbd22',\n",
    "               '#17becf'][d]  \n",
    "       )\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.08 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5268.4989, 50 iterations in 1.8139 sec\n",
      "Iteration  100, KL divergence 5260.1644, 50 iterations in 1.7937 sec\n",
      "Iteration  150, KL divergence 5255.1140, 50 iterations in 1.7629 sec\n",
      "Iteration  200, KL divergence 5255.1011, 50 iterations in 1.7506 sec\n",
      "Iteration  250, KL divergence 5255.1011, 50 iterations in 1.7540 sec\n",
      "   --> Time elapsed: 8.88 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.07 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5128.0500, 50 iterations in 1.7990 sec\n",
      "Iteration  100, KL divergence 5121.5710, 50 iterations in 1.7833 sec\n",
      "Iteration  150, KL divergence 5121.5644, 50 iterations in 1.7928 sec\n",
      "Iteration  200, KL divergence 5121.5645, 50 iterations in 1.8015 sec\n",
      "Iteration  250, KL divergence 5121.5645, 50 iterations in 1.8215 sec\n",
      "   --> Time elapsed: 9.00 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.08 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.01 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5455.2735, 50 iterations in 1.8249 sec\n",
      "Iteration  100, KL divergence 5441.0278, 50 iterations in 2.0205 sec\n",
      "Iteration  150, KL divergence 5437.4699, 50 iterations in 1.7768 sec\n",
      "Iteration  200, KL divergence 5437.4638, 50 iterations in 1.8332 sec\n",
      "Iteration  250, KL divergence 5437.4637, 50 iterations in 1.8626 sec\n",
      "   --> Time elapsed: 9.32 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.07 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.01 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5564.7636, 50 iterations in 1.7686 sec\n",
      "Iteration  100, KL divergence 5538.3521, 50 iterations in 1.8030 sec\n",
      "Iteration  150, KL divergence 5530.9156, 50 iterations in 1.7824 sec\n",
      "Iteration  200, KL divergence 5526.5552, 50 iterations in 1.7611 sec\n",
      "Iteration  250, KL divergence 5526.5036, 50 iterations in 1.7478 sec\n",
      "   --> Time elapsed: 8.86 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.07 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5413.4045, 50 iterations in 1.7934 sec\n",
      "Iteration  100, KL divergence 5386.9086, 50 iterations in 1.7564 sec\n",
      "Iteration  150, KL divergence 5383.5751, 50 iterations in 1.7632 sec\n",
      "Iteration  200, KL divergence 5383.5703, 50 iterations in 1.7649 sec\n",
      "Iteration  250, KL divergence 5383.5690, 50 iterations in 1.7544 sec\n",
      "   --> Time elapsed: 8.83 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.07 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5459.8994, 50 iterations in 1.7462 sec\n",
      "Iteration  100, KL divergence 5440.2723, 50 iterations in 1.7418 sec\n",
      "Iteration  150, KL divergence 5436.2348, 50 iterations in 1.7457 sec\n",
      "Iteration  200, KL divergence 5433.5996, 50 iterations in 1.7585 sec\n",
      "Iteration  250, KL divergence 5433.5956, 50 iterations in 1.7501 sec\n",
      "   --> Time elapsed: 8.74 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.07 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5328.0238, 50 iterations in 1.7282 sec\n",
      "Iteration  100, KL divergence 5314.9020, 50 iterations in 1.7233 sec\n",
      "Iteration  150, KL divergence 5312.7533, 50 iterations in 1.7407 sec\n",
      "Iteration  200, KL divergence 5312.7523, 50 iterations in 1.7328 sec\n",
      "Iteration  250, KL divergence 5312.7523, 50 iterations in 1.7358 sec\n",
      "   --> Time elapsed: 8.66 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.07 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5345.7692, 50 iterations in 1.7446 sec\n",
      "Iteration  100, KL divergence 5331.8151, 50 iterations in 1.7974 sec\n",
      "Iteration  150, KL divergence 5329.5552, 50 iterations in 1.7889 sec\n",
      "Iteration  200, KL divergence 5329.4657, 50 iterations in 1.7558 sec\n",
      "Iteration  250, KL divergence 5329.4038, 50 iterations in 1.7920 sec\n",
      "   --> Time elapsed: 8.88 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.08 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5629.8691, 50 iterations in 1.7871 sec\n",
      "Iteration  100, KL divergence 5600.2853, 50 iterations in 1.8551 sec\n",
      "Iteration  150, KL divergence 5594.2677, 50 iterations in 1.8482 sec\n",
      "Iteration  200, KL divergence 5589.8420, 50 iterations in 1.7999 sec\n",
      "Iteration  250, KL divergence 5589.8194, 50 iterations in 1.7845 sec\n",
      "   --> Time elapsed: 9.08 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.08 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 5479.5305, 50 iterations in 1.7628 sec\n",
      "Iteration  100, KL divergence 5452.9460, 50 iterations in 1.8111 sec\n",
      "Iteration  150, KL divergence 5449.5566, 50 iterations in 1.7760 sec\n",
      "Iteration  200, KL divergence 5447.1404, 50 iterations in 1.8269 sec\n",
      "Iteration  250, KL divergence 5447.1555, 50 iterations in 1.7803 sec\n",
      "   --> Time elapsed: 8.96 seconds\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": [
    "for d in range(10):\n",
    "    plt.scatter(*zip(*(\n",
    "            embeddings[2].transform(data_validate[d].to_numpy())\n",
    "        )),\n",
    "        color=['#1f77b4',\n",
    "               '#ff7f0e',\n",
    "               '#2ca02c',\n",
    "               '#d62728',\n",
    "               '#9467bd',\n",
    "               '#8c564b',\n",
    "               '#e377c2',\n",
    "               '#7f7f7f',\n",
    "               '#bcbd22',\n",
    "               '#17becf'][d]  \n",
    "       )\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.12 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 11022.1026, 50 iterations in 1.8223 sec\n",
      "Iteration  100, KL divergence 11001.1201, 50 iterations in 1.8549 sec\n",
      "Iteration  150, KL divergence 11000.3193, 50 iterations in 1.8219 sec\n",
      "Iteration  200, KL divergence 11000.3145, 50 iterations in 1.8120 sec\n",
      "Iteration  250, KL divergence 11000.3161, 50 iterations in 1.8689 sec\n",
      "   --> Time elapsed: 9.18 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.15 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.01 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 12562.0005, 50 iterations in 1.9429 sec\n",
      "Iteration  100, KL divergence 12538.3093, 50 iterations in 1.8899 sec\n",
      "Iteration  150, KL divergence 12527.6751, 50 iterations in 1.8420 sec\n",
      "Iteration  200, KL divergence 12523.4344, 50 iterations in 1.8410 sec\n",
      "Iteration  250, KL divergence 12523.0895, 50 iterations in 1.8459 sec\n",
      "   --> Time elapsed: 9.36 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.14 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 12055.1184, 50 iterations in 1.8459 sec\n",
      "Iteration  100, KL divergence 12008.5425, 50 iterations in 1.8330 sec\n",
      "Iteration  150, KL divergence 11987.8597, 50 iterations in 1.8236 sec\n",
      "Iteration  200, KL divergence 11982.5849, 50 iterations in 1.8273 sec\n",
      "Iteration  250, KL divergence 11980.5197, 50 iterations in 1.8431 sec\n",
      "   --> Time elapsed: 9.17 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.14 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 11958.8962, 50 iterations in 1.8565 sec\n",
      "Iteration  100, KL divergence 11926.0917, 50 iterations in 1.8605 sec\n",
      "Iteration  150, KL divergence 11918.2424, 50 iterations in 1.8519 sec\n",
      "Iteration  200, KL divergence 11917.8404, 50 iterations in 1.9316 sec\n",
      "Iteration  250, KL divergence 11917.6888, 50 iterations in 1.8669 sec\n",
      "   --> Time elapsed: 9.37 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.16 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.01 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 11303.7898, 50 iterations in 1.9177 sec\n",
      "Iteration  100, KL divergence 11268.7279, 50 iterations in 2.0104 sec\n",
      "Iteration  150, KL divergence 11266.2633, 50 iterations in 1.9880 sec\n",
      "Iteration  200, KL divergence 11266.1884, 50 iterations in 1.9870 sec\n",
      "Iteration  250, KL divergence 11266.1881, 50 iterations in 2.1388 sec\n",
      "   --> Time elapsed: 10.04 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.12 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 10322.3566, 50 iterations in 1.8612 sec\n",
      "Iteration  100, KL divergence 10274.6364, 50 iterations in 1.8413 sec\n",
      "Iteration  150, KL divergence 10273.5640, 50 iterations in 1.8688 sec\n",
      "Iteration  200, KL divergence 10272.6247, 50 iterations in 1.8519 sec\n",
      "Iteration  250, KL divergence 10270.5314, 50 iterations in 1.9828 sec\n",
      "   --> Time elapsed: 9.41 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.13 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 10778.0939, 50 iterations in 1.9336 sec\n",
      "Iteration  100, KL divergence 10757.4021, 50 iterations in 1.8308 sec\n",
      "Iteration  150, KL divergence 10755.3984, 50 iterations in 1.9196 sec\n",
      "Iteration  200, KL divergence 10755.3971, 50 iterations in 1.8991 sec\n",
      "Iteration  250, KL divergence 10755.3971, 50 iterations in 1.8613 sec\n",
      "   --> Time elapsed: 9.45 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.14 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 11789.2299, 50 iterations in 1.8305 sec\n",
      "Iteration  100, KL divergence 11743.5261, 50 iterations in 1.8292 sec\n",
      "Iteration  150, KL divergence 11733.3577, 50 iterations in 1.8223 sec\n",
      "Iteration  200, KL divergence 11732.9224, 50 iterations in 1.8201 sec\n",
      "Iteration  250, KL divergence 11728.0688, 50 iterations in 1.9904 sec\n",
      "   --> Time elapsed: 9.29 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.14 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 11757.6106, 50 iterations in 1.8820 sec\n",
      "Iteration  100, KL divergence 11669.0288, 50 iterations in 1.9123 sec\n",
      "Iteration  150, KL divergence 11643.3406, 50 iterations in 1.8587 sec\n",
      "Iteration  200, KL divergence 11635.8862, 50 iterations in 2.0597 sec\n",
      "Iteration  250, KL divergence 11633.3491, 50 iterations in 1.8533 sec\n",
      "   --> Time elapsed: 9.57 seconds\n",
      "===> Finding 15 nearest neighbors in existing embedding using Annoy approximate search...\n",
      "   --> Time elapsed: 0.13 seconds\n",
      "===> Calculating affinity matrix...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=4.00, lr=0.10 for 0 iterations...\n",
      "   --> Time elapsed: 0.00 seconds\n",
      "===> Running optimization with exaggeration=1.50, lr=0.10 for 250 iterations...\n",
      "Iteration   50, KL divergence 11685.7974, 50 iterations in 1.8508 sec\n",
      "Iteration  100, KL divergence 11661.3976, 50 iterations in 1.8550 sec\n",
      "Iteration  150, KL divergence 11661.2564, 50 iterations in 1.8327 sec\n",
      "Iteration  200, KL divergence 11660.3757, 50 iterations in 1.8240 sec\n",
      "Iteration  250, KL divergence 11654.0581, 50 iterations in 1.8669 sec\n",
      "   --> Time elapsed: 9.23 seconds\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": [
    "for d in range(10):\n",
    "    plt.scatter(*zip(*(\n",
    "            embeddings[2].transform(data_test[d].to_numpy())\n",
    "        )),\n",
    "        color=['#1f77b4',\n",
    "               '#ff7f0e',\n",
    "               '#2ca02c',\n",
    "               '#d62728',\n",
    "               '#9467bd',\n",
    "               '#8c564b',\n",
    "               '#e377c2',\n",
    "               '#7f7f7f',\n",
    "               '#bcbd22',\n",
    "               '#17becf'][d]  \n",
    "       )\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.8.2 64-bit ('rvqe': conda)",
   "language": "python",
   "name": "python38264bitrvqecondad2f0a40244f0466880e7e0a1d328b6ec"
  },
  "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.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
