{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/julia/miniconda3/envs/bs2/lib/python3.8/site-packages/scipy/__init__.py:146: UserWarning: A NumPy version >=1.16.5 and <1.23.0 is required for this version of SciPy (detected version 1.24.3\n",
      "  warnings.warn(f\"A NumPy version >={np_minversion} and <{np_maxversion}\"\n",
      "/home/julia/miniconda3/envs/bs2/lib/python3.8/site-packages/ot/backend.py:2998: UserWarning: To use TensorflowBackend, you need to activate the tensorflow numpy API. You can activate it by running: \n",
      "from tensorflow.python.ops.numpy_ops import np_config\n",
      "np_config.enable_numpy_behavior()\n",
      "  register_backend(TensorflowBackend())\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import os\n",
    "from sklearn import metrics\n",
    "import wandb\n",
    "import pickle\n",
    "import joblib\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib\n",
    "matplotlib.rcParams['pdf.fonttype'] = 42\n",
    "from scipy.spatial import procrustes\n",
    "from braivest.model.emgVAE import emgVAE\n",
    "import tensorflow as tf\n",
    "import ot\n",
    "from sklearn.linear_model import LinearRegression\n",
    "from scipy.stats import linregress\n",
    "from optuna_utils import * \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "test_low = np.load('artifacts/synthetic_spiral:v4/test_low.npy')\n",
    "test = np.load('artifacts/synthetic_spiral:v4/test_datasets.npy')[-2]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "runs_path = '/mnt/home/tt1131/neighbor_vae_expts/runs_and_models/spiral/run21_spiral_TNVAE/models'\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "metrics_spiral = pd.read_csv('metrics_spiral')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Unnamed: 0</th>\n",
       "      <th>n_layers</th>\n",
       "      <th>layer_dims</th>\n",
       "      <th>kl</th>\n",
       "      <th>batch_size</th>\n",
       "      <th>lr</th>\n",
       "      <th>loss</th>\n",
       "      <th>val_loss</th>\n",
       "      <th>neighbor_loss</th>\n",
       "      <th>val_neighbor_loss</th>\n",
       "      <th>mse</th>\n",
       "      <th>val_mse</th>\n",
       "      <th>silhouette</th>\n",
       "      <th>skew</th>\n",
       "      <th>kurtosis</th>\n",
       "      <th>study_idx</th>\n",
       "      <th>run_idx</th>\n",
       "      <th>abs_procrustes</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>138</th>\n",
       "      <td>138</td>\n",
       "      <td>4</td>\n",
       "      <td>50</td>\n",
       "      <td>0.001</td>\n",
       "      <td>256</td>\n",
       "      <td>0.001</td>\n",
       "      <td>0.049731</td>\n",
       "      <td>0.049731</td>\n",
       "      <td>0.270034</td>\n",
       "      <td>0.270034</td>\n",
       "      <td>0.044809</td>\n",
       "      <td>0.044809</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>138.0</td>\n",
       "      <td>0.126597</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>352</th>\n",
       "      <td>352</td>\n",
       "      <td>3</td>\n",
       "      <td>100</td>\n",
       "      <td>0.001</td>\n",
       "      <td>512</td>\n",
       "      <td>0.001</td>\n",
       "      <td>0.050229</td>\n",
       "      <td>0.050229</td>\n",
       "      <td>0.275526</td>\n",
       "      <td>0.275526</td>\n",
       "      <td>0.045310</td>\n",
       "      <td>0.045310</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>64.0</td>\n",
       "      <td>0.128367</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>753</th>\n",
       "      <td>753</td>\n",
       "      <td>2</td>\n",
       "      <td>50</td>\n",
       "      <td>0.001</td>\n",
       "      <td>128</td>\n",
       "      <td>0.001</td>\n",
       "      <td>0.049706</td>\n",
       "      <td>0.049706</td>\n",
       "      <td>0.245055</td>\n",
       "      <td>0.245055</td>\n",
       "      <td>0.044765</td>\n",
       "      <td>0.044765</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>2.0</td>\n",
       "      <td>177.0</td>\n",
       "      <td>0.128598</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>338</th>\n",
       "      <td>338</td>\n",
       "      <td>2</td>\n",
       "      <td>100</td>\n",
       "      <td>0.001</td>\n",
       "      <td>128</td>\n",
       "      <td>0.001</td>\n",
       "      <td>0.050869</td>\n",
       "      <td>0.050869</td>\n",
       "      <td>0.272715</td>\n",
       "      <td>0.272715</td>\n",
       "      <td>0.045866</td>\n",
       "      <td>0.045866</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>1.0</td>\n",
       "      <td>50.0</td>\n",
       "      <td>0.130142</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>139</th>\n",
       "      <td>139</td>\n",
       "      <td>4</td>\n",
       "      <td>50</td>\n",
       "      <td>0.001</td>\n",
       "      <td>128</td>\n",
       "      <td>0.001</td>\n",
       "      <td>0.049953</td>\n",
       "      <td>0.049953</td>\n",
       "      <td>0.304168</td>\n",
       "      <td>0.304168</td>\n",
       "      <td>0.045210</td>\n",
       "      <td>0.045210</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>0.0</td>\n",
       "      <td>139.0</td>\n",
       "      <td>0.130491</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     Unnamed: 0  n_layers  layer_dims     kl  batch_size     lr      loss  \\\n",
       "138         138         4          50  0.001         256  0.001  0.049731   \n",
       "352         352         3         100  0.001         512  0.001  0.050229   \n",
       "753         753         2          50  0.001         128  0.001  0.049706   \n",
       "338         338         2         100  0.001         128  0.001  0.050869   \n",
       "139         139         4          50  0.001         128  0.001  0.049953   \n",
       "\n",
       "     val_loss  neighbor_loss  val_neighbor_loss       mse   val_mse  \\\n",
       "138  0.049731       0.270034           0.270034  0.044809  0.044809   \n",
       "352  0.050229       0.275526           0.275526  0.045310  0.045310   \n",
       "753  0.049706       0.245055           0.245055  0.044765  0.044765   \n",
       "338  0.050869       0.272715           0.272715  0.045866  0.045866   \n",
       "139  0.049953       0.304168           0.304168  0.045210  0.045210   \n",
       "\n",
       "     silhouette  skew  kurtosis  study_idx  run_idx  abs_procrustes  \n",
       "138         NaN   NaN       NaN        0.0    138.0        0.126597  \n",
       "352         NaN   NaN       NaN        1.0     64.0        0.128367  \n",
       "753         NaN   NaN       NaN        2.0    177.0        0.128598  \n",
       "338         NaN   NaN       NaN        1.0     50.0        0.130142  \n",
       "139         NaN   NaN       NaN        0.0    139.0        0.130491  "
      ]
     },
     "execution_count": 47,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "metrics_spiral.sort_values('abs_procrustes').head(5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(metrics_spiral.shape[0]):\n",
    "    study_idx = metrics_spiral.loc[i, 'study_idx']\n",
    "    run_idx= metrics_spiral.loc[i, 'run_idx']\n",
    "    study = joblib.load(os.path.join(runs_path, \"study_r_{}.pkl\".format(int(study_idx))))\n",
    "    trial = study.trials[int(run_idx)]\n",
    "    encodings = model_encode(runs_path, trial.number, int(study_idx), 31, trial.params, test)\n",
    "    encodings_window = np.lib.stride_tricks.sliding_window_view(encodings, 100, axis=0).reshape(-1, 200)\n",
    "    metrics_spiral.loc[i, 'inst_var'] = np.mean(np.var(encodings_window, axis=1))\n",
    "    reg = LinearRegression().fit(encodings, test_low)\n",
    "    r2 = reg.score(encodings, test_low)\n",
    "    metrics_spiral.loc[i, 'r2']  = r2\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [],
   "source": [
    "metrics_spiral_avg = pd.DataFrame(columns = ['n_layers', 'layer_dims', 'kl', 'batch_size', 'lr', 'val_loss', 'val_neighbor_loss', 'val_mse', 'r2'])\n",
    "for layers in metrics_spiral['n_layers'].unique():\n",
    "    for layer_dim in metrics_spiral['layer_dims'].unique():\n",
    "        for kl in metrics_spiral['kl'].unique():\n",
    "            for bs in metrics_spiral['batch_size'].unique():\n",
    "                for lr in metrics_spiral['lr'].unique():\n",
    "                    query = metrics_spiral[(metrics_spiral['n_layers'] == layers) & (metrics_spiral['layer_dims'] == layer_dim) & (metrics_spiral['kl'] == kl) & (metrics_spiral['batch_size']== bs) & (metrics_spiral['lr'] == lr)]\n",
    "                    metrics_spiral_avg.loc[len(metrics_spiral_avg.index)] = [layers, layer_dim, kl, bs, lr, query['val_loss'].mean(), query['val_neighbor_loss'].mean(), query['val_mse'].mean(), query['r2'].mean()]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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GRg3bhw+/PBDlJeXY+nSpQBalsG+//57/POf//T43JYtWzB27Fg8+uijfdFtIiIi6qf6NDDKzs5GXV0d3njjDVRWVuLRRx/F/v373bvMKisrvc40amhowN69e/H+++8HrB8qlQpr1671WnIjonsTxzRR/3O3xnWfnmNEREREFEz6PCUIERERUbBgYERERETUioERERERUSsGRkRERESt+mVgtHHjRjz00ENQq9VIT0/H8ePHu6x/7NgxpKenQ61WIyUlBX//+987rbtz505IJJI7nrhNRIHly7iurKzEc889hyFDhkAqlSIvL8+rzubNmzFx4kREREQgIiICmZmZOH36dC9+AyJqz5dx/fHHH+Ppp59GTEwM9Ho9xo0bhwMHDnjV27t3L9LS0qBSqZCWloZ9+/b51Kd+Fxjt2rULeXl5yM/PR1FRESZOnIgZM2Z4bft3uXLlCmbOnImJEyeiqKgIr7/+Ol5++WXs3bvXq+61a9fw61//GhMnTuztr0FEbfg6ri0WC2JiYpCfn4+RI0d2WOfo0aOYP38+jhw5gsLCQgwcOBBTp07F999/35tfhYha+Tquv/zySzz99NPYv38/zp49iylTpmDWrFkoKipy1yksLER2djZycnJw/vx55OTkICsrC//5z3+63zHRzzz22GNi6dKlHmWpqali9erVHdZftWqVSE1N9Sh76aWXxOOPP+5RZrfbxYQJE8Q//vEPsWjRIjF79uyA9puIOufruG5r8uTJ4pVXXrljPbvdLnQ6nfjoo4962k0i8oE/49olLS1NrF+/3v0+KytLTJ8+3aPOtGnTxLPPPtvtNvvVjJHVasXZs2cxdepUj/KpU6fi5MmTHX6msLDQq/60adPw1VdfwWazucveeOMNxMTEMA0J0V3Wk3HdE0ajETabDZGRkQFrk4g6Fohx7XQ60djY6DFmO/uf7svfij49+TrQamtr4XA4vJLQxsbGeiWrdamqquqwvt1uR21tLeLj43HixAls2bIFxcXFvdV1IupET8Z1T6xevRoPPvggMjMzA9YmEXUsEOP63XffRXNzM7Kystxlnf1P9+VvRb8KjFzaZ94VQnSZjbej+q7yxsZGPP/889i8eTOio6MD31ki6hZfx7Uv3n77bezYsQNHjx6FWq0OSJtEdGc9Hdc7duzAunXr8K9//QsDBgwISJsu/Sowio6O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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.clf()\n",
    "res = linregress(metrics_spiral_avg['val_loss'], metrics_spiral_avg['r2'])\n",
    "ax = sns.regplot(data = metrics_spiral_avg, x= 'val_loss', y='r2', x_ci=None, scatter_kws={'alpha': 0.4}, label = 'r = {0:.2f}'.format(res.rvalue))\n",
    "plt.xlabel(\"Validation Loss\")\n",
    "plt.ylabel(\"Regression R2\")\n",
    "ax.spines[['right', 'top']].set_visible(False)\n",
    "plt.xticks([0.04, 0.12, 0.20])\n",
    "plt.ylim((0.7, 0.9))\n",
    "plt.yticks((0.7, 0.8, 0.9))\n",
    "ax.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'plt' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[1], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m plt\u001b[39m.\u001b[39mclf()\n\u001b[1;32m      2\u001b[0m res \u001b[39m=\u001b[39m linregress(metrics_spiral_avg[\u001b[39m'\u001b[39m\u001b[39mval_neighbor_loss\u001b[39m\u001b[39m'\u001b[39m], metrics_spiral_avg[\u001b[39m'\u001b[39m\u001b[39mr2\u001b[39m\u001b[39m'\u001b[39m])\n\u001b[1;32m      3\u001b[0m ax \u001b[39m=\u001b[39m sns\u001b[39m.\u001b[39mregplot(data \u001b[39m=\u001b[39m metrics_spiral_avg, x\u001b[39m=\u001b[39m \u001b[39m'\u001b[39m\u001b[39mval_neighbor_loss\u001b[39m\u001b[39m'\u001b[39m, y\u001b[39m=\u001b[39m\u001b[39m'\u001b[39m\u001b[39mr2\u001b[39m\u001b[39m'\u001b[39m, x_ci\u001b[39m=\u001b[39m\u001b[39mNone\u001b[39;00m, scatter_kws\u001b[39m=\u001b[39m{ \u001b[39m'\u001b[39m\u001b[39malpha\u001b[39m\u001b[39m'\u001b[39m: \u001b[39m0.4\u001b[39m}, label \u001b[39m=\u001b[39m \u001b[39m'\u001b[39m\u001b[39mr = \u001b[39m\u001b[39m{0:.2f}\u001b[39;00m\u001b[39m'\u001b[39m\u001b[39m.\u001b[39mformat(res\u001b[39m.\u001b[39mrvalue))\n",
      "\u001b[0;31mNameError\u001b[0m: name 'plt' is not defined"
     ]
    }
   ],
   "source": [
    "plt.clf()\n",
    "res = linregress(metrics_spiral_avg['val_neighbor_loss'], metrics_spiral_avg['r2'])\n",
    "ax = sns.regplot(data = metrics_spiral_avg, x= 'val_neighbor_loss', y='r2', x_ci=None, scatter_kws={ 'alpha': 0.4}, label = 'r = {0:.2f}'.format(res.rvalue))\n",
    "plt.ylabel(\"Regression R2\")\n",
    "ax.spines[['right', 'top']].set_visible(False)\n",
    "ax.legend()\n",
    "plt.xticks((0.2, 0.5, 0.8))\n",
    "plt.ylim((0.7, 0.9))\n",
    "plt.yticks(())\n",
    "plt.show()\n",
    "#plt.savefig('revised_images/figure2/spiral_regression_nl.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "bs2",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.17"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
