{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "9afa92f6",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy import stats\n",
    "from statsmodels.stats.multitest import multipletests\n",
    "# Define the three folders\n",
    "nmr_folder = './data/Fig5_6_Natural/RTRandom_MM_emb_nmr'\n",
    "cebra_folder = './data/Fig5_6_Natural/RTRandom_MM_emb_cebra'\n",
    "pivae_folder = './data/Fig5_6_Natural/RTRandom_MM_emb_pivae'\n",
    "\n",
    "# Function to extract the relevant variables from files\n",
    "def extract_data(folder, iterations, file_prefix='iterations_'):\n",
    "    vel_train_r2_pca = []\n",
    "    vel_test_r2_pca = []\n",
    "    execution_time = []\n",
    "    vel_train_r2 = []\n",
    "    vel_test_r2 = []\n",
    "    for file_name in os.listdir(folder):\n",
    "        if f'{file_prefix}{iterations}' in file_name:\n",
    "            file_path = os.path.join(folder, file_name)\n",
    "            data = np.load(file_path)\n",
    "            \n",
    "            vel_train_r2_pca.append(data['vel_train_r2_pca'])\n",
    "            vel_test_r2_pca.append(data['vel_test_r2_pca'])\n",
    "            execution_time.append(data['execution_time'])\n",
    "            vel_train_r2.append(data['vel_train_r2'])\n",
    "            vel_test_r2.append(data['vel_test_r2'])\n",
    "            \n",
    "    return np.array(vel_train_r2_pca), np.array(vel_test_r2_pca),\\\n",
    "            np.array(execution_time), np.array(vel_train_r2), np.array(vel_test_r2)\n",
    "\n",
    "# Iteration lists for each folder\n",
    "iterations_list_nmr_cebra = [10000]\n",
    "iterations_list_pivae = [30]\n",
    "labels = ['10000(30)']\n",
    "x = np.arange(len(labels))  # Label locations\n",
    "width = 0.15  # Width of the bars\n",
    "bar_gap = 0.05  # Distance between paired bars\n",
    "plt.rcParams.update({'font.size': 15, 'font.family': 'DejaVu Sans'})\n",
    "# Comparison data structure\n",
    "comparison_data = {'NMR': {}, 'CEBRA': {}, 'piVAE': {}}\n",
    "\n",
    "# Extract data for NMR and CEBRA folders\n",
    "for iterations in iterations_list_nmr_cebra:\n",
    "    nmr_vel_train_r2_pca, nmr_vel_test_r2_pca, \\\n",
    "        nmr_exec_time, nmr_vel_train_r2, \\\n",
    "        nmr_vel_test_r2 = extract_data(nmr_folder, iterations)\n",
    "    \n",
    "    cebra_vel_train_r2_pca, cebra_vel_test_r2_pca, \\\n",
    "       cebra_exec_time, \\\n",
    "    cebra_vel_train_r2, cebra_vel_test_r2 = extract_data(cebra_folder, iterations)\n",
    "    \n",
    "    comparison_data['NMR'][iterations] = (nmr_vel_train_r2_pca, nmr_vel_test_r2_pca, nmr_exec_time, \\\n",
    "                                          nmr_vel_train_r2, nmr_vel_test_r2)\n",
    "    comparison_data['CEBRA'][iterations] = (cebra_vel_train_r2_pca, cebra_vel_test_r2_pca, \\\n",
    "                                            cebra_exec_time, \\\n",
    "                                            cebra_vel_train_r2, cebra_vel_test_r2)\n",
    "\n",
    "# Extract data for piVAE folder with the adjusted file format\n",
    "for iterations in iterations_list_pivae:\n",
    "    pivae_vel_train_r2_pca, pivae_vel_test_r2_pca, \\\n",
    "        pivae_exec_time, \\\n",
    "    pivae_vel_train_r2, pivae_vel_test_r2 = extract_data(pivae_folder, iterations, file_prefix='iterations_')\n",
    "    \n",
    "    comparison_data['piVAE'][iterations] = (pivae_vel_train_r2_pca, pivae_vel_test_r2_pca, \\\n",
    "                                            pivae_exec_time, \\\n",
    "                                            pivae_vel_train_r2, pivae_vel_test_r2)\n",
    "\n",
    "# Jitter function (for visualization, if needed)\n",
    "def jitter(x, jitter_amount=0.05):\n",
    "    return x + np.random.uniform(-jitter_amount, jitter_amount, size=len(x))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "22dbe6f5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Vel train r2 NMR = 0.7923 ± 0.0020\n",
      "Vel train r2 CEBRA = 0.6538 ± 0.0037\n",
      "Vel train r2 piVAE = 0.5606 ± 0.1167\n",
      "NMR over CEBRA = 21.1809%\n",
      "t-statistic NC: 151.7164 p-value: 2.75e-30\n",
      "t-statistic Np: 8.6320 p-value: 1.60e-07\n",
      "t-statistic Cp: 3.4948 p-value: 0.0073\n"
     ]
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(5, 3))\n",
    "x = np.arange(len(labels))\n",
    "\n",
    "nmr_select_data = []\n",
    "cebra_select_data = []\n",
    "pivae_select_data = []\n",
    "\n",
    "idx = 0 # vel_train_r2_pca\n",
    "iterations_mapping = {10000: 30}  \n",
    "\n",
    "for iterations in iterations_mapping.keys():\n",
    "    nmr_data = comparison_data['NMR'][iterations][idx]\n",
    "    cebra_data = comparison_data['CEBRA'][iterations][idx]\n",
    "    pivae_data = comparison_data['piVAE'][iterations_mapping[iterations]][idx]\n",
    "    \n",
    "    nmr_select_data.append(nmr_data)\n",
    "    cebra_select_data.append(cebra_data)\n",
    "    pivae_select_data.append(pivae_data)\n",
    "\n",
    "rects1 = ax.bar(x - width - bar_gap, [np.mean(data) for data in nmr_select_data], width,\n",
    "                edgecolor='gray', linewidth=1.5, fill=False)\n",
    "rects2 = ax.bar(x, [np.mean(data) for data in cebra_select_data], width,\n",
    "                edgecolor='gray', linewidth=1.5, fill=False)\n",
    "rects3 = ax.bar(x + width + bar_gap, [np.mean(data) for data in pivae_select_data], width,\n",
    "                edgecolor='gray', linewidth=1.5, fill=False)\n",
    "\n",
    "# Add scatter plots for each individual data point for NMR, CEBRA, and piVAE\n",
    "for i, iterations in enumerate(iterations_mapping.keys()):\n",
    "    ax.scatter(jitter([x[i] - width - bar_gap] * len(nmr_select_data[i])), nmr_select_data[i],\n",
    "               edgecolor='black', alpha=0.5, color='#1f77b4', zorder=3, label='NMR' if i == 0 else \"\")\n",
    "    ax.scatter(jitter([x[i]] * len(cebra_select_data[i])), cebra_select_data[i],\n",
    "               edgecolor='black', alpha=0.5, color='#ff7f0e', zorder=3, label='CEBRA' if i == 0 else \"\")\n",
    "    ax.scatter(jitter([x[i] + width + bar_gap] * len(pivae_select_data[i])), pivae_select_data[i],\n",
    "               edgecolor='black', alpha=0.5, color='#2ca02c', zorder=3, label='piVAE' if i == 0 else \"\")\n",
    "    \n",
    "ax.set_xlabel('Iterations (piVAE equivalents)')\n",
    "ax.set_ylabel('vel-r2 train')\n",
    "ax.set_xticks(x)\n",
    "ax.set_xticklabels(labels)\n",
    "# plt.legend(loc='center left', bbox_to_anchor=(1, 0.5))\n",
    "plt.ylim(0, 0.85)\n",
    "ax.spines['top'].set_visible(False)\n",
    "ax.spines['right'].set_visible(False)\n",
    "plt.tight_layout()\n",
    "plt.savefig('./NMR_Figs/Fig6_RTRandom_3models_r2_train.pdf', bbox_inches='tight')\n",
    "plt.show()\n",
    "\n",
    "nmr_vel_train_r2_2d = nmr_select_data[i]\n",
    "cebra_vel_train_r2_2d = cebra_select_data[i]\n",
    "pivae_vel_train_r2_2d = pivae_select_data[i]\n",
    "###### unpaired: ind(epent)      paired: rel(ated)     p-value*3 for multiple comparisons correction\n",
    "t_stat_unpaired, p_val_unpaired = stats.ttest_rel(nmr_select_data[i], cebra_select_data[i])\n",
    "\n",
    "print(f'Vel train r2 NMR = {np.mean(nmr_vel_train_r2_2d):.4f} ± {np.std(nmr_vel_train_r2_2d):.4f}')\n",
    "print(f'Vel train r2 CEBRA = {np.mean(cebra_vel_train_r2_2d):.4f} ± {np.std(cebra_vel_train_r2_2d):.4f}')\n",
    "print(f'Vel train r2 piVAE = {np.mean(pivae_vel_train_r2_2d):.4f} ± {np.std(pivae_vel_train_r2_2d):.4f}')\n",
    "nmr2cebra = 100*(np.mean(nmr_vel_train_r2_2d)-np.mean(cebra_vel_train_r2_2d))/np.mean(cebra_vel_train_r2_2d)\n",
    "print(f'NMR over CEBRA = {nmr2cebra:.4f}%')\n",
    "t_stat_NC, p_val_NC = stats.ttest_rel(nmr_vel_train_r2_2d, cebra_vel_train_r2_2d) \n",
    "print(f\"t-statistic NC: {t_stat_NC:.4f} p-value: {p_val_NC*3:.2e}\")\n",
    "t_stat_Np, p_val_Np = stats.ttest_rel(nmr_vel_train_r2_2d, pivae_vel_train_r2_2d) \n",
    "print(f\"t-statistic Np: {t_stat_Np:.4f} p-value: {p_val_Np*3:.2e}\")\n",
    "t_stat_Cp, p_val_Cp = stats.ttest_rel(cebra_vel_train_r2_2d, pivae_vel_train_r2_2d) \n",
    "print(f\"t-statistic Cp: {t_stat_Cp:.4f} p-value: {p_val_Cp*3:.4f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "59a80cd2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Vel test r2 NMR = 0.7737 ± 0.0049\n",
      "Vel test r2 CEBRA = 0.6452 ± 0.0059\n",
      "Vel test r2 piVAE = 0.5336 ± 0.1094\n",
      "NMR over CEBRA = 19.9140%\n",
      "t-statistic NC: 71.3693 p-value: 4.47e-24\n",
      "t-statistic Np: 9.6277 p-value: 2.90e-08\n",
      "t-statistic Cp: 4.4657 p-value: 0.0008\n"
     ]
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(5, 3))\n",
    "x = np.arange(len(labels))\n",
    "\n",
    "nmr_select_data = []\n",
    "cebra_select_data = []\n",
    "pivae_select_data = []\n",
    "\n",
    "idx = 1 # vel_test_r2_pca\n",
    "iterations_mapping = {10000: 30}  \n",
    "\n",
    "for iterations in iterations_mapping.keys():\n",
    "    nmr_data = comparison_data['NMR'][iterations][idx]\n",
    "    cebra_data = comparison_data['CEBRA'][iterations][idx]\n",
    "    pivae_data = comparison_data['piVAE'][iterations_mapping[iterations]][idx]\n",
    "    \n",
    "    nmr_select_data.append(nmr_data)\n",
    "    cebra_select_data.append(cebra_data)\n",
    "    pivae_select_data.append(pivae_data)\n",
    "\n",
    "rects1 = ax.bar(x - width - bar_gap, [np.mean(data) for data in nmr_select_data], width,\n",
    "                edgecolor='gray', linewidth=1.5, fill=False)\n",
    "rects2 = ax.bar(x, [np.mean(data) for data in cebra_select_data], width,\n",
    "                edgecolor='gray', linewidth=1.5, fill=False)\n",
    "rects3 = ax.bar(x + width + bar_gap, [np.mean(data) for data in pivae_select_data], width,\n",
    "                edgecolor='gray', linewidth=1.5, fill=False)\n",
    "\n",
    "# Add scatter plots for each individual data point for NMR, CEBRA, and piVAE\n",
    "for i, iterations in enumerate(iterations_mapping.keys()):\n",
    "    ax.scatter(jitter([x[i] - width - bar_gap] * len(nmr_select_data[i])), nmr_select_data[i],\n",
    "               edgecolor='black', alpha=0.5, color='#1f77b4', zorder=3, label='NMR' if i == 0 else \"\")\n",
    "    ax.scatter(jitter([x[i]] * len(cebra_select_data[i])), cebra_select_data[i],\n",
    "               edgecolor='black', alpha=0.5, color='#ff7f0e', zorder=3, label='CEBRA' if i == 0 else \"\")\n",
    "    ax.scatter(jitter([x[i] + width + bar_gap] * len(pivae_select_data[i])), pivae_select_data[i],\n",
    "               edgecolor='black', alpha=0.5, color='#2ca02c', zorder=3, label='piVAE' if i == 0 else \"\")\n",
    "    \n",
    "ax.set_xlabel('Iterations (piVAE equivalents)')\n",
    "ax.set_ylabel('vel-r2 test')\n",
    "ax.set_xticks(x)\n",
    "ax.set_xticklabels(labels)\n",
    "plt.legend(loc='center left', bbox_to_anchor=(1, 0.5))\n",
    "plt.ylim(0, 0.85)\n",
    "ax.spines['top'].set_visible(False)\n",
    "ax.spines['right'].set_visible(False)\n",
    "plt.tight_layout()\n",
    "# plt.savefig('./NMR_Figs/Fig6_RTRandom_3models_r2_test.pdf', bbox_inches='tight')\n",
    "plt.show()\n",
    "\n",
    "nmr_vel_test_r2_2d = nmr_select_data[i]\n",
    "cebra_vel_test_r2_2d = cebra_select_data[i]\n",
    "pivae_vel_test_r2_2d = pivae_select_data[i]\n",
    "###### unpaired: ind(epent)      paired: rel(ated)     p-value*3 for multiple comparisons correction\n",
    "t_stat_unpaired, p_val_unpaired = stats.ttest_rel(nmr_select_data[i], cebra_select_data[i])\n",
    "\n",
    "print(f'Vel test r2 NMR = {np.mean(nmr_vel_test_r2_2d):.4f} ± {np.std(nmr_vel_test_r2_2d):.4f}')\n",
    "print(f'Vel test r2 CEBRA = {np.mean(cebra_vel_test_r2_2d):.4f} ± {np.std(cebra_vel_test_r2_2d):.4f}')\n",
    "print(f'Vel test r2 piVAE = {np.mean(pivae_vel_test_r2_2d):.4f} ± {np.std(pivae_vel_test_r2_2d):.4f}')\n",
    "nmr2cebra = 100*(np.mean(nmr_vel_test_r2_2d)-np.mean(cebra_vel_test_r2_2d))/np.mean(cebra_vel_test_r2_2d)\n",
    "print(f'NMR over CEBRA = {nmr2cebra:.4f}%')\n",
    "t_stat_NC, p_val_NC = stats.ttest_rel(nmr_vel_test_r2_2d, cebra_vel_test_r2_2d) \n",
    "print(f\"t-statistic NC: {t_stat_NC:.4f} p-value: {p_val_NC*3:.2e}\")\n",
    "t_stat_Np, p_val_Np = stats.ttest_rel(nmr_vel_test_r2_2d, pivae_vel_test_r2_2d) \n",
    "print(f\"t-statistic Np: {t_stat_Np:.4f} p-value: {p_val_Np*3:.2e}\")\n",
    "t_stat_Cp, p_val_Cp = stats.ttest_rel(cebra_vel_test_r2_2d, pivae_vel_test_r2_2d) \n",
    "print(f\"t-statistic Cp: {t_stat_Cp:.4f} p-value: {p_val_Cp*3:.4f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "4cf20759",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "increased by> -11.4 %\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Vel test r2 NMR = 145.9090 ± 8.8192\n",
      "Vel test r2 CEBRA = 164.7500 ± 20.9037\n",
      "NMR over CEBRA = -11.4361%\n",
      "t-statistic NC: -3.4886 p-value: 0.0025\n"
     ]
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(4, 3))\n",
    "nmr_select_data = []\n",
    "cebra_select_data = []\n",
    "select_idx = 2\n",
    "for iterations in iterations_list_nmr_cebra:\n",
    "    nmr_data = comparison_data['NMR'][iterations][select_idx]  # Extract vel_test_r2_pca for NMR\n",
    "    cebra_data = comparison_data['CEBRA'][iterations][select_idx]  # Extract vel_test_r2_pca for CEBRA\n",
    "    nmr_select_data.append(nmr_data)\n",
    "    cebra_select_data.append(cebra_data)\n",
    "\n",
    "rects1 = ax.bar(x - (width + bar_gap) / 2, [np.mean(data) for data in nmr_select_data], width,\n",
    "                edgecolor='gray', linewidth=1.5, fill=False)\n",
    "rects2 = ax.bar(x + (width + bar_gap) / 2, [np.mean(data) for data in cebra_select_data], width,\n",
    "                edgecolor='gray', linewidth=1.5, fill=False)\n",
    "ax.set_xlabel('epochs')\n",
    "ax.set_ylabel('time(s)')\n",
    "# ax.set_title('vel-r2 test')\n",
    "ax.set_xticks(x)\n",
    "ax.set_xticklabels(labels)\n",
    "for i, iteration in enumerate(iterations_list_nmr_cebra):\n",
    "    ax.scatter(jitter([x[i] - (width + bar_gap) / 2] * len(nmr_select_data[i])), nmr_select_data[i],\n",
    "           edgecolor='black', alpha=0.5, color='#1f77b4', zorder=3, label='NMR')\n",
    "    ax.scatter(jitter([x[i] + (width + bar_gap) / 2] * len(cebra_select_data[i])), cebra_select_data[i],\n",
    "           edgecolor='black', alpha=0.5, color='#ff7f0e', zorder=3, label='CEBRA')\n",
    "    ratio = np.mean(nmr_select_data[i]-cebra_select_data[i])/(np.mean(cebra_select_data[i]))\n",
    "    print('increased by>', str(np.round(ratio*100, 1)), '%')\n",
    "plt.legend(loc='center left', bbox_to_anchor=(1, 0.5))\n",
    "ax.spines['top'].set_visible(False)\n",
    "ax.spines['right'].set_visible(False)\n",
    "plt.tight_layout()\n",
    "# plt.savefig('./NMR_Figs/Fig6_RTRandom_2models_time.pdf', bbox_inches='tight')\n",
    "plt.show()\n",
    "\n",
    "nmr_vel_test_r2_2d = nmr_select_data[i]\n",
    "cebra_vel_test_r2_2d = cebra_select_data[i]\n",
    "###### unpaired: ind(epent)      paired: rel(ated) \n",
    "t_stat_unpaired, p_val_unpaired = stats.ttest_rel(nmr_select_data[i], cebra_select_data[i])\n",
    "\n",
    "print(f'Vel test r2 NMR = {np.mean(nmr_vel_test_r2_2d):.4f} ± {np.std(nmr_vel_test_r2_2d):.4f}')\n",
    "print(f'Vel test r2 CEBRA = {np.mean(cebra_vel_test_r2_2d):.4f} ± {np.std(cebra_vel_test_r2_2d):.4f}')\n",
    "\n",
    "nmr2cebra = 100*(np.mean(nmr_vel_test_r2_2d)-np.mean(cebra_vel_test_r2_2d))/np.mean(cebra_vel_test_r2_2d)\n",
    "print(f'NMR over CEBRA = {nmr2cebra:.4f}%')\n",
    "t_stat_NC, p_val_NC = stats.ttest_rel(nmr_vel_test_r2_2d, cebra_vel_test_r2_2d) \n",
    "print(f\"t-statistic NC: {t_stat_NC:.4f} p-value: {p_val_NC:.4f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d3964ce2",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python [conda env:cebra] *",
   "language": "python",
   "name": "conda-env-cebra-py"
  },
  "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.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
