{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "f617ecc5",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "<frozen importlib._bootstrap>:219: RuntimeWarning: scipy._lib.messagestream.MessageStream size changed, may indicate binary incompatibility. Expected 56 from C header, got 64 from PyObject\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    "import os\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import joblib as jl\n",
    "import cebra.datasets\n",
    "from cebra import CEBRA\n",
    "import torch\n",
    "import scipy.io as sio\n",
    "from sklearn.decomposition import PCA\n",
    "from sklearn.linear_model import LinearRegression\n",
    "import sklearn.metrics\n",
    "import time"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "122b7983",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "./data/LFP_12PMd/Mihili_20140218_Beta.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 13.059302914567425\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.612  r2-2D= 0.5343\n",
      "20% Test  Data Temp= 0.065  r2-3D= -0.27  r2-2D= -0.2387\n",
      "./data/LFP_12PMd/Mihili_20140304_Beta.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 12.71996827347126\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.343  r2-2D= 0.3096\n",
      "20% Test  Data Temp= 0.065  r2-3D= -0.138  r2-2D= -0.1292\n",
      "./data/LFP_12PMd/Chewie_20161007_Beta.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 12.021728042329908\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.546  r2-2D= 0.4314\n",
      "20% Test  Data Temp= 0.065  r2-3D= -0.11  r2-2D= -0.0662\n",
      "./data/LFP_12PMd/Chewie_20161007_Gamma.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 13.19779113153925\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.893  r2-2D= 0.8918\n",
      "20% Test  Data Temp= 0.065  r2-3D= 0.692  r2-2D= 0.691\n",
      "./data/LFP_12PMd/Chewie_20161014_Gamma.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 12.202588769997195\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.479  r2-2D= 0.4765\n",
      "20% Test  Data Temp= 0.065  r2-3D= 0.455  r2-2D= 0.4544\n",
      "./data/LFP_12PMd/Chewie_20160929_LMP.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 11.330321638774269\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.886  r2-2D= 0.8741\n",
      "20% Test  Data Temp= 0.065  r2-3D= 0.715  r2-2D= 0.712\n",
      "./data/LFP_12PMd/Mihili_20140303_Gamma.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 11.615782911554124\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.836  r2-2D= 0.8026\n",
      "20% Test  Data Temp= 0.065  r2-3D= 0.397  r2-2D= 0.3953\n",
      "./data/LFP_12PMd/Mihili_20140303_Beta.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 12.154933602721925\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.886  r2-2D= 0.8773\n",
      "20% Test  Data Temp= 0.065  r2-3D= -0.48  r2-2D= -0.4635\n",
      "./data/LFP_12PMd/Chewie_20161021_Beta.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 10.066437829406546\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.39  r2-2D= 0.3033\n",
      "20% Test  Data Temp= 0.065  r2-3D= -0.242  r2-2D= -0.1547\n",
      "./data/LFP_12PMd/Chewie_20160929_Gamma.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 12.511188454284838\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.579  r2-2D= 0.4192\n",
      "20% Test  Data Temp= 0.065  r2-3D= 0.52  r2-2D= 0.3972\n",
      "./data/LFP_12PMd/Chewie_20161006_Beta.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 12.142185452380826\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.301  r2-2D= 0.2608\n",
      "20% Test  Data Temp= 0.065  r2-3D= -0.202  r2-2D= -0.1911\n",
      "./data/LFP_12PMd/Mihili_20140307_Gamma.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 13.779812376469646\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.876  r2-2D= 0.8704\n",
      "20% Test  Data Temp= 0.065  r2-3D= 0.406  r2-2D= 0.3984\n",
      "./data/LFP_12PMd/Chewie_20161021_LMP.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 10.552588502109504\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.33  r2-2D= 0.2606\n",
      "20% Test  Data Temp= 0.065  r2-3D= 0.313  r2-2D= 0.2578\n",
      "./data/LFP_12PMd/Chewie_20161006_Gamma.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 11.532046080463505\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.848  r2-2D= 0.8476\n",
      "20% Test  Data Temp= 0.065  r2-3D= 0.75  r2-2D= 0.7489\n",
      "./data/LFP_12PMd/Mihili_20140217_Gamma.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 12.056960241545857\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.865  r2-2D= 0.8598\n",
      "20% Test  Data Temp= 0.065  r2-3D= 0.507  r2-2D= 0.5201\n",
      "./data/LFP_12PMd/Mihili_20140307_LMP.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 12.137827393314755\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.793  r2-2D= 0.7907\n",
      "20% Test  Data Temp= 0.065  r2-3D= 0.441  r2-2D= 0.4331\n",
      "./data/LFP_12PMd/Mihili_20140217_Beta.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 13.626338598048994\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.148  r2-2D= 0.1105\n",
      "20% Test  Data Temp= 0.065  r2-3D= -0.149  r2-2D= -0.1114\n",
      "./data/LFP_12PMd/Mihili_20140307_Beta.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 12.478734663586245\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.203  r2-2D= 0.1938\n",
      "20% Test  Data Temp= 0.065  r2-3D= -0.073  r2-2D= -0.0801\n",
      "./data/LFP_12PMd/Mihili_20140218_LMP.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 12.2426981599368\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.899  r2-2D= 0.8985\n",
      "20% Test  Data Temp= 0.065  r2-3D= 0.485  r2-2D= 0.4846\n",
      "./data/LFP_12PMd/Chewie_20161006_LMP.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 11.84261799198104\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.898  r2-2D= 0.8745\n",
      "20% Test  Data Temp= 0.065  r2-3D= 0.698  r2-2D= 0.6691\n",
      "./data/LFP_12PMd/Mihili_20140306_Beta.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 12.656510422690902\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.113  r2-2D= 0.093\n",
      "20% Test  Data Temp= 0.065  r2-3D= -0.045  r2-2D= -0.0461\n",
      "./data/LFP_12PMd/Mihili_20140217_LMP.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 12.819402876913069\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.914  r2-2D= 0.9025\n",
      "20% Test  Data Temp= 0.065  r2-3D= 0.323  r2-2D= 0.3297\n",
      "./data/LFP_12PMd/Chewie_20161007_LMP.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 12.69991470351684\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.902  r2-2D= 0.9002\n",
      "20% Test  Data Temp= 0.065  r2-3D= 0.74  r2-2D= 0.7407\n",
      "./data/LFP_12PMd/Chewie_20161021_Gamma.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 11.212770901816995\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.857  r2-2D= 0.8503\n",
      "20% Test  Data Temp= 0.065  r2-3D= 0.72  r2-2D= 0.7175\n",
      "./data/LFP_12PMd/Chewie_20161005_Gamma.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 12.765391667132995\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.542  r2-2D= 0.4236\n",
      "20% Test  Data Temp= 0.065  r2-3D= 0.439  r2-2D= 0.3064\n",
      "./data/LFP_12PMd/Chewie_20161005_Beta.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 12.406787669369532\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.681  r2-2D= 0.6776\n",
      "20% Test  Data Temp= 0.065  r2-3D= -0.266  r2-2D= -0.264\n",
      "./data/LFP_12PMd/Mihili_20140304_Gamma.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 13.067223251067347\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.741  r2-2D= 0.7308\n",
      "20% Test  Data Temp= 0.065  r2-3D= 0.302  r2-2D= 0.3025\n",
      "./data/LFP_12PMd/Chewie_20161014_LMP.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 11.834639449525392\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.541  r2-2D= 0.4208\n",
      "20% Test  Data Temp= 0.065  r2-3D= 0.461  r2-2D= 0.3619\n",
      "./data/LFP_12PMd/Chewie_20160929_Beta.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 12.318114859127792\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.815  r2-2D= 0.7421\n",
      "20% Test  Data Temp= 0.065  r2-3D= -0.477  r2-2D= -0.3948\n",
      "./data/LFP_12PMd/Mihili_20140306_Gamma.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 13.28545025785877\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.828  r2-2D= 0.8225\n",
      "20% Test  Data Temp= 0.065  r2-3D= 0.487  r2-2D= 0.4841\n",
      "./data/LFP_12PMd/Mihili_20140306_LMP.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 13.119939650284849\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.88  r2-2D= 0.7296\n",
      "20% Test  Data Temp= 0.065  r2-3D= 0.38  r2-2D= 0.3905\n",
      "./data/LFP_12PMd/Chewie_20161014_Beta.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 12.22648798608747\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.054  r2-2D= 0.0248\n",
      "20% Test  Data Temp= 0.065  r2-3D= -0.037  r2-2D= -0.0298\n",
      "./data/LFP_12PMd/Chewie_20161005_LMP.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 12.266234946936525\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.557  r2-2D= 0.4427\n",
      "20% Test  Data Temp= 0.065  r2-3D= 0.411  r2-2D= 0.3294\n",
      "./data/LFP_12PMd/Mihili_20140304_LMP.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 12.876048693565252\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.904  r2-2D= 0.9003\n",
      "20% Test  Data Temp= 0.065  r2-3D= 0.237  r2-2D= 0.23\n",
      "./data/LFP_12PMd/Mihili_20140303_LMP.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 13.28121412583272\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.912  r2-2D= 0.9061\n",
      "20% Test  Data Temp= 0.065  r2-3D= 0.251  r2-2D= 0.2498\n",
      "./data/LFP_12PMd/Mihili_20140218_Gamma.mat_embed_5000itr_PMd.npz\n",
      "XY distance>> 12.90010073027057\n",
      "Z distance>> 90.0\n",
      "80% Train Data Temp= 0.065  r2-3D= 0.865  r2-2D= 0.8621\n",
      "20% Test  Data Temp= 0.065  r2-3D= 0.442  r2-2D= 0.4398\n"
     ]
    }
   ],
   "source": [
    "dur = 40\n",
    "iterations = 5*1000\n",
    "batch_size = 512\n",
    "learning_rate = 0.001\n",
    "output_dimension = 3\n",
    "# LFP_ch = \"Gamma\" ### \"LMP\" or \"Gamma\" or \"Beta\"\n",
    "# Temp_para = [0.02, 0.03, 0.04] ## 0.05, 0.055, 0.06, 0.065, 0.07, 0.08, 0.09, 0.1, 0.11\n",
    "Temp_para = [0.065]\n",
    "def split_data(neural, continuous_index):\n",
    "            L = neural.shape[0]\n",
    "            split_idx = round(L*0.8) \n",
    "            neural_train = neural[:split_idx]\n",
    "            neural_test = neural[split_idx:]\n",
    "            continuous_index_train = continuous_index[:split_idx]\n",
    "            continuous_index_test = continuous_index[split_idx:]\n",
    "            return neural_train,neural_test,continuous_index_train,continuous_index_test\n",
    "        \n",
    "angle_to_new_value = {-180: 4,-135: 5,-90: 6,-45: 7,0: 0,45: 1,90: 2,135: 3,180: 4}\n",
    "\n",
    "directory = \"./data/LFP_12PMd/\"\n",
    "files = os.listdir(directory)\n",
    "for file in files:\n",
    "#     if LFP_ch in file:\n",
    "    mat_contents = sio.loadmat(os.path.join(directory, file))\n",
    "    filename_parts = file.split(\"_neural_con_dis_index\")\n",
    "    new_filename = filename_parts[0] + \"_embed_\"+str(iterations)+\"itr_PMd.npz\"\n",
    "    file_save = os.path.join(directory, new_filename)\n",
    "    print(file_save)\n",
    "\n",
    "    neural = mat_contents['lfp_PMd']\n",
    "    continuous_index_XY = mat_contents['continuous_index']\n",
    "    discrete_index = mat_contents['discrete_index'] ## angles range from -180deg to +180deg\n",
    "    vectorized_map = np.vectorize(lambda x: angle_to_new_value[x])\n",
    "    discrete_index = 45*vectorized_map(discrete_index)\n",
    "\n",
    "    L = neural.shape[0]\n",
    "    N_values_hist = round(L/5)\n",
    "    random_indices = np.random.choice(L, size=N_values_hist, replace=False)\n",
    "    indices_X = continuous_index_XY[random_indices, 0]\n",
    "    indices_Y = continuous_index_XY[random_indices, 1]\n",
    "    index_diffs_X = np.abs(indices_X[:, None] - indices_X[None, :]) \n",
    "    index_diffs_Y = np.abs(indices_Y[:, None] - indices_Y[None, :])\n",
    "    l_dist_XY = index_diffs_X + index_diffs_Y\n",
    "    l_dist_XY_1d = l_dist_XY[~np.eye(N_values_hist, dtype=bool)].flatten()\n",
    "    print('XY distance>>', np.median(l_dist_XY_1d))\n",
    "    angles = np.squeeze(discrete_index[random_indices])\n",
    "    angle_diffs = np.abs(angles[:, None] - angles[None, :]) \n",
    "    circular_angle_diffs = np.minimum(angle_diffs, 360 - angle_diffs)\n",
    "    l_dist_Z_1d = circular_angle_diffs[~np.eye(N_values_hist, dtype=bool)].flatten()\n",
    "    print('Z distance>>', np.median(l_dist_Z_1d))\n",
    "\n",
    "    XY_scale = 10\n",
    "    continuous_index_XY = continuous_index_XY*XY_scale\n",
    "    #####>>>>>>>>>>>>>>>>>>>>>>>> Only for NMR\n",
    "    XYZ_threshold = np.median(l_dist_XY_1d)*XY_scale + np.median(l_dist_Z_1d)\n",
    "    #####>>>>>>>>>>>>>>>>>>>>>>>> Only for NMR\n",
    "\n",
    "    for temp in range(len(Temp_para)): \n",
    "\n",
    "        continuous_index = np.column_stack((continuous_index_XY, discrete_index))\n",
    "\n",
    "        neural_train, neural_test, continuous_index_train, \\\n",
    "                    continuous_index_test = split_data(neural, continuous_index)\n",
    "\n",
    "        #####>>>>>>>>>>>>>>>>>>>>>>>>  Only for NMR\n",
    "        L_train = neural_train.shape[0]\n",
    "        conr_2para = np.full((L_train,), 0.001)\n",
    "        conr_2para[:2] = [XYZ_threshold, Temp_para[temp]]\n",
    "        continuous_index_train = np.column_stack((continuous_index_train, conr_2para))\n",
    "        #####>>>>>>>>>>>>>>>>>>>>>>>> Only for NMR\n",
    "        try: \n",
    "            cebra_veldir_model = CEBRA(model_architecture='offset10-model',\n",
    "                       batch_size = batch_size,\n",
    "                       learning_rate = learning_rate,\n",
    "                       output_dimension = output_dimension,\n",
    "                       max_iterations=iterations,\n",
    "                       distance='cosine',\n",
    "                       conditional='time_delta',\n",
    "                       verbose=False,\n",
    "                       time_offsets=10)\n",
    "            start_time = time.time()\n",
    "            cebra_veldir_model.fit(neural_train, continuous_index_train)\n",
    "            end_time = time.time()\n",
    "            execution_time = np.round((end_time - start_time), 2)\n",
    "\n",
    "            cebra_veldir_train = cebra_veldir_model.transform(neural_train)\n",
    "            cebra_veldir_test  = cebra_veldir_model.transform(neural_test)\n",
    "\n",
    "            train_loss = cebra_veldir_model.state_dict_['loss']\n",
    "            X = cebra_veldir_train\n",
    "            y = continuous_index_train[:,0:2]\n",
    "            reg_3d = LinearRegression().fit(X, y)       #### 1st fit ####\n",
    "            pred_vel = reg_3d.predict(X)\n",
    "            vel_train_r2 = sklearn.metrics.r2_score(y, pred_vel)\n",
    "\n",
    "            pca = PCA(n_components=2)\n",
    "            pca_2d = pca.fit(X)                         #### 2nd fit ####\n",
    "            X_2d = pca_2d.transform(X)\n",
    "            reg_2d = LinearRegression().fit(X_2d, y)    #### 3rd fit ####\n",
    "            pred_vel = reg_2d.predict(X_2d)\n",
    "            vel_train_r2_pca = sklearn.metrics.r2_score(y, pred_vel)\n",
    "            vel_train_r2_pca = np.round(vel_train_r2_pca, 4)\n",
    "\n",
    "            print('80% Train Data Temp=', str(Temp_para[temp]), \\\n",
    "                  ' r2-3D=', str(np.round(vel_train_r2, 3)), ' r2-2D=', str(vel_train_r2_pca))\n",
    "            ###************* use previous trained \"reg_3d & pca_2d & reg_2d\" ###***************\n",
    "            ###************* use previous trained \"reg_3d & pca_2d & reg_2d\" ###***************\n",
    "            X = cebra_veldir_test\n",
    "            y = continuous_index_test[:,0:2]\n",
    "            pred_vel = reg_3d.predict(X)\n",
    "            vel_test_r2 = sklearn.metrics.r2_score(y, pred_vel)\n",
    "\n",
    "            X_2d = pca_2d.transform(X)\n",
    "            pred_vel = reg_2d.predict(X_2d)\n",
    "            vel_test_r2_pca = sklearn.metrics.r2_score(y, pred_vel)\n",
    "            vel_test_r2_pca = np.round(vel_test_r2_pca, 4)\n",
    "\n",
    "            print('20% Test  Data Temp=', str(Temp_para[temp]), \\\n",
    "                  ' r2-3D=', str(np.round(vel_test_r2, 3)), ' r2-2D=', str(vel_test_r2_pca))\n",
    "\n",
    "            new_filename = file[:19] + \"_Temp_\"+str(Temp_para[temp])+ \\\n",
    "                \"_iterations_\"+str(iterations)+ \\\n",
    "                \"_80%train_\"+str(vel_train_r2_pca)+ \\\n",
    "                \"_20%test_\"+str(vel_test_r2_pca)+\".npz\"\n",
    "            file_save = os.path.join('./data/Fig3_4_LFP/nmr/emb_PMd',new_filename)\n",
    "            np.savez(file_save,\n",
    "                     execution_time = execution_time,\n",
    "                     temperature = Temp_para[temp],\n",
    "                     iterations = iterations, \n",
    "                     train_loss = train_loss,\n",
    "                     cebra_veldir_train=cebra_veldir_train,\n",
    "                     cebra_veldir_test=cebra_veldir_test,\n",
    "                     continuous_index_train=continuous_index_train,\n",
    "                     continuous_index_test=continuous_index_test,\n",
    "                     vel_train_r2 = vel_train_r2,\n",
    "                     vel_test_r2 = vel_test_r2,\n",
    "                     vel_train_r2_pca = vel_train_r2_pca,\n",
    "                     vel_test_r2_pca = vel_test_r2_pca)\n",
    "        except Exception as e:\n",
    "            print(' Temp=', str(Temp_para[temp]), ' fail')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.18"
  },
  "vscode": {
   "interpreter": {
    "hash": "dc327929684d2c13e929b2699e1b37518dbb61b921da51c352c926069002ee0e"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
