{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import scipy\n",
    "import scipy.io as sio\n",
    "import matplotlib.pyplot as plt\n",
    "import nibabel as nib\n",
    "\n",
    "import os\n",
    "from os.path import join as opj\n",
    "from os.path import join, exists, split\n",
    "import time\n",
    "import urllib.request\n",
    "import warnings\n",
    "from pprint import pprint\n",
    "import zipfile\n",
    "import glob\n",
    "warnings.filterwarnings('ignore')\n",
    "from transformers import AutoFeatureExtractor, ClapModel\n",
    "import torch\n",
    "import torchaudio\n",
    "\n",
    "from sklearn.linear_model import LogisticRegression, RidgeCV, Ridge\n",
    "from sklearn.metrics import classification_report\n",
    "from sklearn.preprocessing import LabelEncoder\n",
    "\n",
    "\n",
    "import pandas as pd\n",
    "from nilearn import maskers\n",
    "from nilearn import plotting\n",
    "import tqdm\n",
    "\n",
    "from nilearn.glm.first_level import FirstLevelModel\n",
    "from nilearn.image import concat_imgs, mean_img\n",
    "import matplotlib.pyplot as plt\n",
    "import nilearn\n",
    "from nilearn.plotting import plot_design_matrix\n",
    "from nilearn.plotting import plot_contrast_matrix\n",
    "from importlib import reload # python 2.7 does not require this\n",
    "import pickle\n",
    "# from nltools.data import Brain_Data, Adjacency\n",
    "# from nltools.stats import align\n",
    "\n",
    "import seaborn as sns\n",
    "import IPython.display as ipd\n",
    "from sklearn.metrics import confusion_matrix\n",
    "\n",
    "from diffusers import MusicLDMPipeline, AudioPipelineOutput, StableAudioPipeline\n",
    "# from diffusers import DiffusionPipeline, AudioPipelineOutput\n",
    "from IPython.display import Audio\n",
    "\n",
    "\n",
    "os.environ[\"TOKENIZERS_PARALLELISM\"] = \"false\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "BASE_PATH_LOAD = '*'\n",
    "\n",
    "with open(BASE_PATH_LOAD + '/working_data_dict_vae' + '.pkl', 'rb') as file_to_read:\n",
    "    working_data_dict = pickle.load(file_to_read)\n",
    "\n",
    "\n",
    "def load_transformed_data(data_folder):\n",
    "    # Initialize an empty dictionary to store the data\n",
    "    loaded_data_dict = {}\n",
    "\n",
    "    # Loop through all files in the data folder\n",
    "    for filename in os.listdir(data_folder):\n",
    "        # Construct the full path of the file\n",
    "        file_path = os.path.join(data_folder, filename)\n",
    "        \n",
    "        # Extract the subject ID and key from the filename\n",
    "        # Assuming filenames are in the format 'sub_key.ext'\n",
    "        sub, key = filename.split('_', 1)\n",
    "        key = key.rsplit('.', 1)[0]  # Removes extension part to get the key\n",
    "        \n",
    "        #repeat\n",
    "        key = key.rsplit('.', 1)[0]  # Removes extension part to get the key\n",
    "\n",
    "        # Initialize sub dictionary if it doesn't exist\n",
    "        if sub not in loaded_data_dict:\n",
    "            loaded_data_dict[sub] = {}\n",
    "\n",
    "        # Determine the file type and load accordingly\n",
    "        if filename.endswith('.npy'):\n",
    "            loaded_data_dict[sub][key] = np.load(file_path)\n",
    "        elif filename.endswith('.pkl'):\n",
    "            with open(file_path, 'rb') as file:\n",
    "                loaded_data_dict[sub][key] = pickle.load(file)\n",
    "\n",
    "        print(f\"Loaded {key} from {file_path}\")\n",
    "\n",
    "    return loaded_data_dict\n",
    "\n",
    "\n",
    "# -----------------------------------------------------------------------------------------\n",
    "transform_masking=True\n",
    "subject_ids = [\"sub-001\", \"sub-002\", \"sub-003\", \"sub-004\", \"sub-005\"]\n",
    "\n",
    "# mask_path = \"mask_to_save/mask_top_512_voxels.nii.gz\"\n",
    "mask_path = BASE_PATH_LOAD + \"/mask_him_005.nii.gz\"\n",
    "# mask_path = \"mask_01.nii.gz\"\n",
    "if transform_masking:\n",
    "    base_masker=working_data_dict[\"sub-001\"][\"masker\"]\n",
    "    selected_indices=base_masker.transform(nib.load(mask_path))\n",
    "    for sub in subject_ids:\n",
    "        working_data_dict[sub][\"train_fmri_avg\"]=working_data_dict[sub][\"train_fmri\"].squeeze()[:,selected_indices.squeeze().astype(np.uint8)]\n",
    "        working_data_dict[sub][\"test_fmri_avg\"]=working_data_dict[sub][\"test_fmri\"].squeeze()[:,selected_indices.squeeze().astype(np.uint8)]\n",
    "       \n",
    "if transform_masking:\n",
    "    # Ensure the data directory exists\n",
    "    data_folder = 'data'\n",
    "    os.makedirs(data_folder, exist_ok=True)\n",
    "\n",
    "    # Assuming working_data_dict is your main dictionary and 'sub' is defined\n",
    "    for sub in subject_ids:\n",
    "        for key, value in working_data_dict[sub].items():\n",
    "            # Convert the value to a numpy array if it's not already one \n",
    "            print(key)\n",
    "\n",
    "            # Define the path for the output file\n",
    "            file_path = os.path.join(data_folder, f'{sub}_{key}.npy')\n",
    "\n",
    "            # Check if the value is a numpy array\n",
    "            if isinstance(value, np.ndarray):\n",
    "                # Save the numpy array to a file with .npy extension\n",
    "                np.save(file_path + '.npy', value)\n",
    "                print(f\"Saved {key} as an array to {file_path}.npy\")\n",
    "            else:\n",
    "                # Save other types of data using pickle with .pkl extension\n",
    "                with open(file_path + '.pkl', 'wb') as file:\n",
    "                    pickle.dump(value, file, protocol=pickle.HIGHEST_PROTOCOL)\n",
    "                print(f\"Saved {key} using pickle to {file_path}.pkl\")\n",
    "\n",
    "            print(f\"Saved {key} to {file_path}\")      \n",
    "\n",
    "else:\n",
    "    # Use the function\n",
    "    data_folder = 'data'  # Specify the data folder path\n",
    "    working_data_dict = load_transformed_data(data_folder)\n",
    "\n",
    "\n",
    "# -----------------------------------------------------------------------------------------\n",
    "df_captions = pd.read_csv(BASE_PATH_LOAD + '/brain2music-captions.csv')\n",
    "print(df_captions.head())\n",
    "captions_array = df_captions.to_numpy()\n",
    "caption_dict = {item[0].split('_')[0]: item[1] for item in captions_array}\n",
    "\n",
    "for subj in subject_ids:\n",
    "\n",
    "    train_stim_name_list = working_data_dict[subj]['train_stim_name']\n",
    "    train_stim_caption_list = []\n",
    "\n",
    "    for file_path in train_stim_name_list:\n",
    "        genre_number = file_path.split('/')[-1].replace('.wav', '')\n",
    "        caption = caption_dict.get(genre_number, \"Caption not found\")\n",
    "        train_stim_caption_list.append(caption)\n",
    "\n",
    "    working_data_dict[subj]['train_stim_caption'] = train_stim_caption_list\n",
    "\n",
    "\n",
    "for subj in subject_ids:\n",
    "\n",
    "    test_stim_name_list = working_data_dict[subj]['test_stim_name']\n",
    "    test_stim_caption_list = []\n",
    "\n",
    "    for file_path in test_stim_name_list:\n",
    "        genre_number = file_path.split('/')[-1].replace('.wav', '')\n",
    "        caption = caption_dict.get(genre_number, \"Caption not found\")\n",
    "        test_stim_caption_list.append(caption)\n",
    "\n",
    "    working_data_dict[subj]['test_stim_caption'] = test_stim_caption_list\n",
    "\n",
    "\n",
    "# -----------------------------------------------------------------------------------------\n",
    "\n",
    "def process_data(data_dict, key_suffix, features_key, genre_key, stim_name_key, fmri_key, stim_caption_key, feat_vae_key):\n",
    "    # Create DataFrame for fMRI and stimulus names\n",
    "    df = pd.DataFrame(data_dict[fmri_key], dtype=float)\n",
    "    df['Stimulus'] = data_dict[stim_name_key]\n",
    "    \n",
    "    # Group by 'Caption' and calculate the mean for fMRI data\n",
    "    fmri_avg = df.groupby('Stimulus').mean().reset_index()\n",
    "    \n",
    "    # Create DataFrame for audio features and stimulus names\n",
    "    df_features = pd.DataFrame(data_dict[features_key], dtype=float)\n",
    "    df_features['Stimulus'] = data_dict[stim_name_key]\n",
    "    \n",
    "    # Group by 'Caption' and calculate the mean for audio features\n",
    "    features_avg = df_features.groupby('Stimulus').mean().reset_index()\n",
    "    \n",
    "    # Handle genres (assuming genre data is aligned with stimuli names)\n",
    "    df_genre = pd.DataFrame(data_dict[genre_key], columns=['Genre'])\n",
    "    df_genre['Stimulus'] = data_dict[stim_name_key]\n",
    "    \n",
    "    # Since genre should be consistent for the same caption, we can take the first occurrence\n",
    "    genre_avg = df_genre.groupby('Stimulus').first().reset_index()\n",
    "\n",
    "    # Handle genres (assuming genre data is aligned with stimuli names)\n",
    "    df_caption = pd.DataFrame(data_dict[stim_caption_key], columns=['Caption'])\n",
    "    df_caption['Stimulus'] = data_dict[stim_name_key]\n",
    "    \n",
    "    # Since genre should be consistent for the same caption, we can take the first occurrence\n",
    "    caption_avg = df_caption.groupby('Stimulus').first().reset_index()\n",
    "\n",
    "    df_vae = pd.DataFrame(data_dict[feat_vae_key].reshape(data_dict[feat_vae_key].shape[0],-1), dtype=float)\n",
    "    df_vae['Stimulus'] = data_dict[stim_name_key]\n",
    "    \n",
    "    vae_avg = df_vae.groupby('Stimulus').mean().reset_index()\n",
    "    \n",
    "    return {\n",
    "        key_suffix + '_audio_feat': features_avg.drop(columns='Stimulus').values,\n",
    "        key_suffix + '_genre': genre_avg['Genre'].values,\n",
    "        key_suffix + '_stim_name_avg': fmri_avg['Stimulus'].values,\n",
    "        key_suffix + '_caption_avg': caption_avg['Caption'].values,\n",
    "        key_suffix + '_fmri_avg': fmri_avg.drop(columns='Stimulus').values,\n",
    "        key_suffix + '_vae_avg': vae_avg.drop(columns='Stimulus').values\n",
    "    }\n",
    "\n",
    "\n",
    "working_data_dict_avg = {}\n",
    "for sub in subject_ids:\n",
    "    working_data_dict_avg[sub] = {}\n",
    "\n",
    "    # Process training data\n",
    "    working_data_dict_avg[sub].update(\n",
    "        process_data(\n",
    "            working_data_dict[sub],\n",
    "            'train',\n",
    "            'train_audio_feat',\n",
    "            'train_genre',\n",
    "            'train_stim_name',\n",
    "            'train_fmri_avg',\n",
    "            'train_stim_caption',\n",
    "            'train_audio_vae'\n",
    "        )\n",
    "    )\n",
    "\n",
    "    # Process testing data\n",
    "    working_data_dict_avg[sub].update(\n",
    "        process_data(\n",
    "            working_data_dict[sub],\n",
    "            'test',\n",
    "            'test_audio_feat',\n",
    "            'test_genre',\n",
    "            'test_stim_name',\n",
    "            'test_fmri_avg',\n",
    "            'test_stim_caption',\n",
    "            'test_audio_vae'\n",
    "        )\n",
    "    )\n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_audio_feat_aligned = np.concatenate([working_data_dict_avg[sub][\"train_audio_feat\"] for sub in subject_ids],0)\n",
    "test_audio_feat_aligned = np.concatenate([working_data_dict_avg[sub][\"test_audio_feat\"] for sub in subject_ids],0)\n",
    "\n",
    "train_genre_aligned = np.concatenate([working_data_dict_avg[sub][\"train_genre\"] for sub in subject_ids],0)\n",
    "test_genre_aligned = np.concatenate([working_data_dict_avg[sub][\"test_genre\"] for sub in subject_ids],0)\n",
    "\n",
    "train_stim_name_avg_aligned = np.concatenate([working_data_dict_avg[sub][\"train_stim_name_avg\"] for sub in subject_ids],0)\n",
    "test_stim_name_avg_aligned = np.concatenate([working_data_dict_avg[sub][\"test_stim_name_avg\"] for sub in subject_ids],0)\n",
    "\n",
    "X_train_aligned = np.concatenate([working_data_dict_avg[sub][\"train_fmri_avg\"] for sub in subject_ids],0)\n",
    "X_test_aligned = np.concatenate([working_data_dict_avg[sub][\"test_fmri_avg\"] for sub in subject_ids],0)\n",
    "\n",
    "train_vae_avg_aligned = np.concatenate([working_data_dict_avg[sub][\"train_vae_avg\"] for sub in subject_ids],0)\n",
    "test_vae_avg_aligned = np.concatenate([working_data_dict_avg[sub][\"test_vae_avg\"] for sub in subject_ids],0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 5/5 [00:00<00:00, 90394.48it/s]\n"
     ]
    }
   ],
   "source": [
    "subject_train_ids=[]\n",
    "subject_test_ids=[]\n",
    "\n",
    "for p in tqdm.tqdm(subject_ids):\n",
    "\n",
    "    subject_train_ids+=[p]*len(working_data_dict_avg[p][\"train_fmri_avg\"])\n",
    "    subject_test_ids+=[p]*len(working_data_dict_avg[p][\"test_fmri_avg\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(2400, 3043)\n",
      "(300, 3043)\n",
      "(2400, 512)\n",
      "(300, 512)\n",
      "2400\n",
      "300\n"
     ]
    }
   ],
   "source": [
    "print(X_train_aligned.shape)\n",
    "print(X_test_aligned.shape)\n",
    "print(train_audio_feat_aligned.shape)\n",
    "print(test_audio_feat_aligned.shape)\n",
    "print(len(subject_train_ids))\n",
    "print(len(subject_test_ids))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.0018652336098391941\n",
      "-0.0005942661985135746\n",
      "0.5223170936565312\n",
      "0.044180970626801666\n"
     ]
    }
   ],
   "source": [
    "print(X_train_aligned.mean())\n",
    "print(train_audio_feat_aligned.mean())\n",
    "print(X_train_aligned.std())\n",
    "print(train_audio_feat_aligned.std())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "subject_train_ids = [int(i[-1]) for i in subject_train_ids]\n",
    "subject_test_ids = [int(i[-1]) for i in subject_test_ids]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "import torch.nn.functional as F\n",
    "import pytorch_lightning as pl\n",
    "from pytorch_lightning.callbacks import EarlyStopping\n",
    "\n",
    "class Encoder(nn.Module):\n",
    "    def __init__(self, input_dim, hidden_dims, output_dim,act_fn=nn.Identity,alignment_layers_keys=[1,2,5,7],common_dim=1024):\n",
    "        super(Encoder, self).__init__()\n",
    "        self.common_dim=common_dim\n",
    "        self.alignment_layers={}\n",
    "        for k in alignment_layers_keys:\n",
    "            self.alignment_layers[k]=nn.Linear(input_dim, common_dim)      # Lazy\n",
    "        \n",
    "        layers = []\n",
    "        prev_dim = input_dim\n",
    "        # layers.append(nn.LayerNorm(common_dim))     # TODO: remove LayerNorm\n",
    "        if len(hidden_dims):\n",
    "\n",
    "            for hidden_dim in hidden_dims:\n",
    "                layers.append(nn.Linear(common_dim, hidden_dim))\n",
    "                layers.append(act_fn())     # TODO: mettere identity\n",
    "            layers.append(nn.Linear(hidden_dim, output_dim))\n",
    "           \n",
    "        else:\n",
    "            layers.append(act_fn())\n",
    "            layers.append(nn.Linear(common_dim, output_dim))\n",
    "        self.net = nn.Sequential(*layers)   \n",
    "\n",
    "        \n",
    "    def _apply(self, fn):\n",
    "        super(Encoder, self)._apply(fn)        \n",
    "        for k,v in self.alignment_layers.items():\n",
    "            self.alignment_layers[k]._apply(fn)\n",
    "            \n",
    "    \n",
    "    def forward(self, x, k=None):\n",
    "        \n",
    "        def apply_alignment_layers(x, k, alignment_layers):\n",
    "            # Create an empty tensor to store the results\n",
    "            result = torch.empty_like(x)\n",
    "            result = result[:,:self.common_dim]\n",
    "            \n",
    "            # Iterate through each unique key in k\n",
    "            for key in k.unique():\n",
    "                # Create a mask for all elements that match the current key\n",
    "                mask = (k == key.item())\n",
    "                \n",
    "                # Apply the corresponding alignment layer to the masked elements\n",
    "                result[mask] = alignment_layers[key.item()](x[mask])\n",
    "            \n",
    "            return result\n",
    "        \n",
    "        if k is None:\n",
    "            k=torch.ones(len(x))\n",
    "        # Apply alignment layers to x using the custom function\n",
    "        x = apply_alignment_layers(x, k, self.alignment_layers)\n",
    "        # x = self.alignment_layers[k](x)\n",
    "        return self.net(x)\n",
    "    \n",
    "\n",
    "# Funzione per calcolare la similarità coseno\n",
    "def cosine_similarity_matrix(A, B):\n",
    "    A_norm = F.normalize(A, dim=1)\n",
    "    B_norm = F.normalize(B, dim=1)\n",
    "    return torch.mm(A_norm, B_norm.T)\n",
    "\n",
    "# NT-Xent Loss (Contrastive)\n",
    "def contrastive_loss_nt(S, tau):\n",
    "    S_exp = torch.exp(S / tau)\n",
    "    loss = -torch.log(torch.diag(S_exp) / S_exp.sum(dim=1))\n",
    "    return loss.mean()\n",
    "\n",
    "def contrastive_loss(z_i, z_j, tau):\n",
    "    z_i = nn.functional.normalize(z_i, dim=1)\n",
    "    z_j = nn.functional.normalize(z_j, dim=1)\n",
    "    logits = (z_i @ z_j.T) / tau\n",
    "    similarities = z_j @ z_j.T\n",
    "    # targets = torch.nn.functional.softmax(similarities * self.temperature, dim=-1)\n",
    "    targets = torch.arange(logits.shape[0]).long().to(logits.device)\n",
    "    loss = torch.nn.functional.cross_entropy(logits, targets)\n",
    "    return loss\n",
    "\n",
    "tau = 0.10\n",
    "\n",
    "class ContrastiveOTModel(pl.LightningModule):\n",
    "    def __init__(self, input_dim, hidden_dims, output_dim, common_dim=1024, alignment_layers_keys=[1,2,5,7]):\n",
    "        super().__init__()\n",
    "        self.encoder = Encoder(input_dim, hidden_dims, output_dim, alignment_layers_keys=alignment_layers_keys, common_dim=common_dim)\n",
    "        self.dropout = nn.Dropout(p=0.5)    \n",
    "        self.tau = tau\n",
    "\n",
    "        self.train_losses = []\n",
    "        self.train_contrastive_loss=[]\n",
    "        self.val_losses = []\n",
    "        self.val_contrastive_loss=[]\n",
    "    \n",
    "        self.train_history={}\n",
    "        self.val_history={}\n",
    "\n",
    "        self.train_history[\"train_loss\"]=[]\n",
    "        self.train_history[\"train_contrastive_loss\"]=[]\n",
    "        self.val_history[\"val_loss\"]=[]\n",
    "        self.val_history[\"val_contrastive_loss\"]=[]\n",
    "\n",
    "    def forward(self, x, **kwargs):\n",
    "        return self.encoder(x, **kwargs)\n",
    "\n",
    "    def loss_fn(self, x_latent, y_latent):\n",
    "        S = cosine_similarity_matrix(x_latent, y_latent)\n",
    "        contrastive_loss_value = contrastive_loss_nt(S, self.tau) \n",
    "        return contrastive_loss_value, contrastive_loss_value\n",
    "    \n",
    "    def compute_loss(self, x, y, idx):\n",
    "        x_latent = self(x, k=idx)\n",
    "        y_latent = y  \n",
    "        return self.loss_fn(x_latent, y_latent)\n",
    "\n",
    "    def training_step(self, batch, batch_idx):\n",
    "        x, y, idx = batch  \n",
    "        loss, contrastive_loss_value = self.compute_loss(x, y, idx)\n",
    "        self.log(\"train_loss\", loss, on_epoch=True, prog_bar=True)\n",
    "        self.log(\"train_contrastive_loss\", contrastive_loss_value, on_epoch=True)\n",
    "\n",
    "        self.train_losses.append(loss.item())\n",
    "        self.train_contrastive_loss.append(contrastive_loss_value.item())\n",
    "        return loss\n",
    "\n",
    "    def validation_step(self, batch, batch_idx):\n",
    "        x, y, idx = batch\n",
    "        loss, contrastive_loss_value = self.compute_loss(x, y, idx)\n",
    "        self.log(\"val_loss\", loss, on_epoch=True, prog_bar=True)\n",
    "        self.log(\"val_contrastive_loss\", contrastive_loss_value, on_epoch=True)\n",
    "\n",
    "        self.val_losses.append(loss.item())\n",
    "        self.val_contrastive_loss.append(contrastive_loss_value.item())\n",
    "        return loss\n",
    "    \n",
    "    def on_train_epoch_end(self) -> None:\n",
    "        self.train_history[\"train_loss\"].append(np.mean(self.train_losses))\n",
    "        self.train_history[\"train_contrastive_loss\"].append(np.mean(self.train_contrastive_loss))\n",
    "        self.train_losses = []\n",
    "        self.train_contrastive_loss=[]\n",
    "        return super().on_train_epoch_end()\n",
    "    \n",
    "    def on_validation_epoch_end(self) -> None:\n",
    "        self.val_history[\"val_loss\"].append(np.mean(self.val_losses))\n",
    "        self.val_history[\"val_contrastive_loss\"].append(np.mean(self.val_contrastive_loss))\n",
    "        self.val_losses = []\n",
    "        self.val_contrastive_loss=[]\n",
    "        return super().on_validation_epoch_end()\n",
    "\n",
    "    def configure_optimizers(self):\n",
    "        optimizer = torch.optim.AdamW(self.parameters(), lr=1e-3)\n",
    "        scheduler = torch.optim.lr_scheduler.ReduceLROnPlateau(optimizer, mode=\"min\", factor=0.5, patience=10, threshold=0.05, verbose=True)\n",
    "        return {\"optimizer\": optimizer, \"lr_scheduler\": scheduler, \"monitor\": \"val_loss\"}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([512, 3043]) torch.Size([512, 512])\n"
     ]
    }
   ],
   "source": [
    "from torch.utils.data import Dataset, DataLoader\n",
    "\n",
    "train_dataset = torch.utils.data.TensorDataset(torch.tensor(X_train_aligned).float(),torch.tensor(train_audio_feat_aligned).squeeze(1).float(), torch.tensor(subject_train_ids))\n",
    "test_dataset = torch.utils.data.TensorDataset(torch.tensor(X_test_aligned).float(),torch.tensor(test_audio_feat_aligned).squeeze(1).float(), torch.tensor(subject_test_ids))\n",
    "\n",
    "x, y, idx = train_dataset[0]  \n",
    "BS = 512 \n",
    "BS_test = int(BS/2) \n",
    "\n",
    "clip_train_dataloader = DataLoader(train_dataset, batch_size=BS, shuffle=True)\n",
    "clip_test_dataloader = DataLoader(test_dataset, batch_size=BS_test, shuffle=False)\n",
    "\n",
    "x, y, idx = next(iter(clip_train_dataloader))\n",
    "print(x.shape, y.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "pl.seed_everything(55, workers=True)      # 55, 999, 42, 1\n",
    "\n",
    "# Configurazione PyTorch Lightning\n",
    "brain_model = ContrastiveOTModel(input_dim=X_train_aligned.shape[-1], hidden_dims=[512],       # 512 valore migliore\n",
    "                                 output_dim=512, common_dim=3043, alignment_layers_keys=[1,2,3,4,5])\n",
    "\n",
    "early_stop_callback = EarlyStopping(monitor=\"val_loss\", min_delta=0.09, patience=9, verbose=True, mode=\"min\")\n",
    "trainer = pl.Trainer(max_epochs=100, devices=[2], callbacks=[early_stop_callback])\n",
    "trainer.fit(brain_model, clip_train_dataloader, clip_test_dataloader)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x725dda92fd90>]"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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RQBiYWGha4pyE32+xaKpqQl79uzBlClTbI8pFApMmTIFO3fulLEy96HX6wEAYWFhMlciv8zMTNx8883t/rx4s++++w6pqam48847ERUVhTFjxuCDDz6QuyxZTZo0CZs2bUJ+fj4AYP/+/di2bRtuuukmmStzHwUFBSgtLW3390ir1WL8+PH83m1Dr9dDEASnbrzpjpy+bbqzVVZWwmw2d1hSPDo6GseOHZOpKvdhsViwYMECZGRkYPjw4XKXI6vVq1cjLy8POTk5cpfiNk6fPo3ly5fj6aefxp///Gfk5OTgySefhFqtxqxZs+QuTxbPPPMMDAYDkpOToVQqYTab8dJLL2HmzJlyl+Y2SktLAaDT792WY96usbERCxcuxD333OPxO55eqs8HC7q8zMxMHDp0CNu2bZO7FFkVFxdj/vz52LBhA3x9feUux21YLBakpqbi5ZdfBgCMGTMGhw4dwnvvvee1weLLL7/Ep59+is8++wwpKSnYt28fFixYgNjYWK/9TMg+JpMJd911F0RRxPLly+Uux+X6fFdIREQElEolysrK2j1eVlaGmJgYmapyD/PmzcMPP/yAzZs3Iy4uTu5yZLVnzx6Ul5dj7NixUKlUUKlU2LJlC9566y2oVCqYzWa5S5RFv379MGzYsHaPDR06FEVFRTJVJL8//elPeOaZZ3D33XdjxIgRuO+++/DUU08hKytL7tLcRst3K793O2oJFYWFhdiwYYPXtVYAHhAs1Go1xo0bh02bNtkes1gs2LRpEyZOnChjZfIRRRHz5s3DmjVr8NNPPyExMVHukmR3ww034ODBg9i3b5/tkpqaipkzZ2Lfvn1QKpVylyiLjIyMDlOR8/PzkZCQIFNF8quvr4dC0f6rUalUwmKxyFSR+0lMTERMTEy7712DwYDdu3d77fcu0BoqTpw4gY0bNyI8PFzukmThEV0hTz/9NGbNmoXU1FSkp6dj6dKlqKurw+zZs+UuTRaZmZn47LPP8O233yIoKMjW56nVauHn5ydzdfIICgrqMMYkICAA4eHhXj325KmnnsKkSZPw8ssv46677kJ2djZWrFiBFStWyF2abGbMmIGXXnoJ8fHxSElJwd69e7FkyRLMmTNH7tJcqra2FidPnrTdLygowL59+xAWFob4+HgsWLAAL774IgYNGoTExEQsXrwYsbGxuPXWW+Ur2sku95n069cPv/vd75CXl4cffvgBZrPZ9t0bFhYGtVotV9muJ/e0FEd5++23xfj4eFGtVovp6enirl275C5JNgA6vaxcuVLu0twKp5tKvv/+e3H48OGiRqMRk5OTxRUrVshdkqwMBoM4f/58MT4+XvT19RUHDhwo/s///I9oNBrlLs2lNm/e3On3yKxZs0RRlKacLl68WIyOjhY1Go14ww03iMePH5e3aCe73GdSUFDQ5Xfv5s2b5S7dpQRR9LLl5IiIiMhp+vwYCyIiInIfDBZERETkMAwWRERE5DAMFkREROQwDBZERETkMAwWRERE5DAMFkREROQwDBZERETkMAwWRERE5DAMFkREROQwDBZERETkMP8fZYnJvQ01gWUAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(brain_model.train_history[\"train_contrastive_loss\"], label='train')\n",
    "plt.plot(brain_model.val_history[\"val_contrastive_loss\"], label='val')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2/2 [00:00<00:00, 81.89it/s]\n"
     ]
    }
   ],
   "source": [
    "device='cuda:2'\n",
    "x,y,k=next(iter(clip_test_dataloader))\n",
    "\n",
    "y_pred=[]\n",
    "y_true=[]\n",
    "with torch.no_grad():\n",
    "    for x,y,k in tqdm.tqdm(clip_test_dataloader):\n",
    "        y_hat=brain_model(x,k=k).to(device)\n",
    "        y_true.append(y)\n",
    "        y_pred.append(y_hat)\n",
    "y_pred=torch.cat(y_pred,0)\n",
    "y_true=torch.cat(y_true,0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(torch.Size([300, 512]), torch.Size([300, 512]))"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y_pred.shape, y_true.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(tensor(0.0019, device='cuda:2'),\n",
       " tensor(-0.0004),\n",
       " tensor(0.1043, device='cuda:2'),\n",
       " tensor(0.0433))"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y_pred.mean(), y_true.mean(), y_pred.std(), y_true.std()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.neighbors import NearestNeighbors\n",
    "\n",
    "samples_per_subject = 60  \n",
    "top1_count_list = []\n",
    "top3_count_list = []\n",
    "\n",
    "# subject_idx = 1\n",
    "for subject_idx in range(4):\n",
    "    start_idx = subject_idx * samples_per_subject\n",
    "    end_idx = (subject_idx + 1) * samples_per_subject\n",
    "\n",
    "    y_true_np = y_true[start_idx:end_idx].cpu().numpy()\n",
    "    y_pred_np = y_pred[start_idx:end_idx].cpu().numpy()\n",
    "    nbrs = NearestNeighbors(n_neighbors=3, metric='cosine').fit(y_true[0:samples_per_subject].cpu().numpy())\n",
    "\n",
    "    distances, top_indices = nbrs.kneighbors(y_pred_np)\n",
    "    true_indices = torch.arange(len(y_true_np)).cpu().numpy()\n",
    "\n",
    "    # Calcoliamo il numero di volte in cui il candidato stimato è nella top-1 e top-3\n",
    "    top1_count = (top_indices[:, 0] == true_indices).sum()\n",
    "    top3_count = sum(true_idx in top_indices[i] for i, true_idx in enumerate(true_indices))\n",
    "\n",
    "    print(f\"Soggetto {subject_idx + 1}:\")\n",
    "    print(f\"Top-1 accuracy: {top1_count}/{len(y_true_np)} ({top1_count / len(y_true_np) * 100:.2f}%)\")\n",
    "    print(f\"Top-3 accuracy: {top3_count}/{len(y_true_np)} ({top3_count / len(y_true_np) * 100:.2f}%)\")\n",
    "\n",
    "    top1_count_list.append(top1_count)\n",
    "    top3_count_list.append(top3_count)\n",
    "\n",
    "print(\"---------------------------\")\n",
    "print(\"Top-1 accuracy:\", sum(top1_count_list) / len(y_true) * 100)\n",
    "print(\"Top-3 accuracy:\", sum(top3_count_list) / len(y_true) * 100)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Ridge"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "X_train=X_train_aligned.copy()\n",
    "X_test=X_test_aligned.copy()\n",
    "\n",
    "device = torch.device(\"cuda:2\" if torch.cuda.is_available() else \"cpu\")\n",
    "\n",
    "X_train_torch = torch.tensor(X_train, dtype=torch.float32).to(device)\n",
    "X_test_torch = torch.tensor(X_test, dtype=torch.float32).to(device)\n",
    "train_audio_feat_torch = torch.tensor(train_audio_feat_aligned, dtype=torch.float32).to(device)\n",
    "\n",
    "# Modello Ridge per mappare brain activity → latent space\n",
    "brain_to_latent = Ridge(alpha=20)\n",
    "brain_to_latent.fit(X_train, train_audio_feat_aligned)\n",
    "audio_feat_pred_test = brain_to_latent.predict(X_test)\n",
    "audio_feat_pred_test_torch = torch.tensor(audio_feat_pred_test, dtype=torch.float32).to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "from himalaya.ridge import RidgeCV\n",
    "from himalaya.kernel_ridge import KernelRidgeCV\n",
    "from himalaya.backend import set_backend\n",
    "\n",
    "X_train=X_train_aligned.copy()\n",
    "X_test=X_test_aligned.copy()\n",
    "\n",
    "# vm = RidgeCV(alphas=[20], fit_intercept=True) \n",
    "vm = RidgeCV(alphas=[20])  \n",
    "device_id = 2\n",
    "backend = set_backend(\"torch_cuda\")\n",
    "X_train_sbj = backend.asarray(torch.tensor(X_train, dtype=torch.float32).to(f'cuda:{device_id}'))\n",
    "Y_train_sbj = backend.asarray(torch.tensor(train_audio_feat_aligned, dtype=torch.float32).to(f'cuda:{device_id}')) \n",
    "X_test_sbj = backend.asarray(torch.tensor(X_test, dtype=torch.float32).to(f'cuda:{device_id}'))     \n",
    "\n",
    "vm.fit(X_train_sbj, Y_train_sbj)\n",
    "y_pred_sbj = vm.predict(X_test_sbj)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([300, 512])"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y_pred_sbj.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "subject_idx = 1\n",
    "start_idx = subject_idx * samples_per_subject\n",
    "end_idx = (subject_idx + 1) * samples_per_subject\n",
    "\n",
    "y_true_base = test_audio_feat_aligned[start_idx:end_idx]\n",
    "y_pred_base = y_pred_sbj[start_idx:end_idx]\n",
    "nbrs_base = NearestNeighbors(n_neighbors=3, metric='cosine').fit(y_true_base[0:samples_per_subject])\n",
    "\n",
    "distances, top_indices_base = nbrs_base.kneighbors(y_pred_base)\n",
    "true_indices_base = torch.arange(len(y_true_base)).cpu().numpy()\n",
    "\n",
    "# Calcoliamo il numero di volte in cui il candidato stimato è nella top-1 e top-3\n",
    "top1_count_base = (top_indices_base[:, 0] == true_indices_base).sum()\n",
    "top3_count_base = sum(true_idx in top_indices_base[i] for i, true_idx in enumerate(true_indices_base))\n",
    "\n",
    "print(f\"Soggetto {subject_idx + 1}:\")\n",
    "print(f\"Top-1 accuracy: {top1_count_base}/{len(y_true_base)} ({top1_count_base / len(y_true_base) * 100:.2f}%)\")\n",
    "print(f\"Top-3 accuracy: {top3_count_base}/{len(y_true_base)} ({top3_count_base / len(y_true_base) * 100:.2f}%)\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Linear VS Non Linear"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# np.save(\"*\", y_pred.cpu().numpy())\n",
    "y_pred_mlp = np.load(\"*/y_pred_mlp_gtzan.npy\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Paired t-test: t = 8.562745154727587, p = 2.9552845609492437e-16\n",
      "Cohen's d: 0.495\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAxQAAAHqCAYAAACdhAjRAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8ekN5oAAAACXBIWXMAAA9hAAAPYQGoP6dpAACKAElEQVR4nOzdd1QU19sH8O8sZekgTUBBUcGOqBgl9gpq7IklFlATNRGNhVhiwxKxa0zRJBowRqMxlpgixoYGg13ssSCIiSg2utSd9w9e5udKEZZlF5bv55w9Z3bmzr3P7LDsPnvvnRFEURRBRERERESkApm2AyAiIiIiosqLCQUREREREamMCQUREREREamMCQUREREREamMCQUREREREamMCQUREREREamMCQUREREREamMCQUREREREamMCQUREREREamMCQVVaaGhoRAEAeHh4VptUxtxaLPdsnjy5AlGjRoFJycnCIKATp06aTskIo05cOAA9PX18c8//2g7FABAUFAQBEFAbGystkPRKEEQ4O/vr+0wNBJHVFQUZDIZjh8/Xq7tUOXGhIJ0Qnh4OARBkB56enqoVq0amjRpAj8/P4SFhUEURbW2GRQUhH379qm1zvIQHh6OoKAgJCYmajsUtZg+fTp27tyJCRMmYOvWrZgzZ06RZWNjY5X+LgRBgImJCZo0aYKFCxfixYsXBfZJT0/HunXr0L59e1hbW8PAwADVq1dHr169EBoaipycnPI8PLXLfw0CAgK0HUqhXn3vvvo4depUuba/bt06hIaGlmsb6pKTk4Pp06dj+PDhaNCggbQ+/4eBlx+mpqZwd3fH5MmTcf/+fS1GXbFcunQJw4YNQ7169WBkZARbW1t4eHhg/PjxuHjxolQuMTERQUFBlerHlvLi6emJ/v37Y/r06Wr/HCXdoa/tAIjUadiwYejVqxdEUURKSgpu3ryJffv24fvvv0e3bt2wa9cuWFlZSeVHjhyJoUOHwtDQsNRtLVy4EH5+fujfv3+p9itLm6oIDw/HwoUL4e/vr3Ts2ohFHQ4dOgQfHx/Mnz+/xPt0794do0aNAgA8fvwYO3fuRFBQEP7++28cPHhQKnfnzh307t0bt27dQrdu3TB79mzY2toiISEBhw8fxujRo3H9+nWsWLFC7cdV1eW/d19Vr169cm133bp1qF27doX4tfl1du3ahRs3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he736uUfMzMzxVmzZomtWrUSra2tRUNDQ7FWrVri6NGjxVu3binte+vWLbF79+6iubm51G4+FHPJzOIuG3vo0CFx/vz5orOzs2hoaCg2adJE3LZtW6H1rFixQnRxcRENDQ3FBg0aiJs3by60blEUxeXLl4uurq6ivr6+0iUFiyqfkJAgfvDBB2KNGjVEfX19sUaNGuKHH34oPn78+LXHkq9jx45irVq1Co39VampqeKsWbNEV1dX0cDAQLSzsxNHjBghxsbGFihb3Gv7qqIumVqctLQ0cc2aNWLbtm1FKysrUV9fX7S3txd79eolfv/992JOTk6J2lywYIG4fft2sWnTpqKhoaFYs2ZNcd68eWJWVlaBfR4/fiwGBgaKbm5uolwuFy0tLcUmTZqIkydPFq9duyaVK+4SwKV9DYp6HYu6bGX+eywkJERp/cWLF8WuXbuKxsbGYrVq1cSRI0eKd+/eFQEUuERrYUpyyed8v/32m9ijRw+xWrVq0mvq6+srbtiwQanc8ePHxbZt24pmZmaipaWl2KtXL/HKlSuF/k0+evRIHDhwoFitWjXpkqIvv74lfZ+97txkZ2eLn332mejl5SWamJiIJiYmYr169cR3331XPHjw4GuPXRRFcefOnSIA8dy5c0rrC7tsrJ6enujk5CSOGDFCvHnzplL5os5lvtjYWPHtt98WbW1tRWNjY7FVq1binj17ir1E7OvW5SvuMr3l7aeffhJHjx4tNmrUSOm97evrK/78888Fyp8+fVp88803RRMTExGA0t9OYe8fdb2nTp06Jb755puiXC4XbWxsxPfff198/vx5idvMzs4WP/74Y9HBwUGUy+Vi8+bNxf379xc4L3fv3hXHjx8vNmjQQDQ3NxdNTEzEBg0aiPPmzVO6fLkoimJ4eLgIQPztt98KHAeRKIqiIIoVZNYkEZEOiI2NhaurKxYsWFBhexbK2/nz5+Hl5YXg4GDMmjVL2+HojNzcXDRr1gyenp5STyyRJgwYMAD379/H2bNneZUnKhTnUBARkcpevfa/+NJcke7du2sjJJ2lp6eHVatW4ccffyx00j9Rebh48SJ++eUXrF69mskEFYlzKIiISGWenp7o0qULmjZtirS0NPz666/466+/MGTIkBJPBKaS8/X1LXRiOlF5yZ/XRVQcJhRERKSyfv364ddff8XWrVuRk5MD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",
      "text/plain": [
       "<Figure size 800x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from scipy.stats import ttest_rel\n",
    "from matplotlib.lines import Line2D\n",
    "\n",
    "# y_true = y_true\n",
    "y_pred_linear = y_pred.cpu().numpy()\n",
    "# y_pred_mlp = y_pred_mlp\n",
    "\n",
    "def get_corrs(y_true, y_pred):\n",
    "    return [np.corrcoef(y_true[i, :], y_pred[i, :])[0, 1] for i in range(y_true.shape[0])]\n",
    "\n",
    "corr_linear = get_corrs(y_true, y_pred_linear)\n",
    "corr_mlp = get_corrs(y_true, y_pred_mlp)\n",
    "\n",
    "mean_linear = np.mean(corr_linear)\n",
    "mean_mlp = np.mean(corr_mlp)\n",
    "\n",
    "t_stat, p_val = ttest_rel(corr_linear, corr_mlp, alternative='greater')\n",
    "print(f\"Paired t-test: t = {t_stat}, p = {p_val}\")\n",
    "\n",
    "diff = np.array(corr_linear) - np.array(corr_mlp)\n",
    "cohens_d = diff.mean() / diff.std()\n",
    "print(f\"Cohen's d: {cohens_d:.3f}\")\n",
    "\n",
    "plt.figure(figsize=(8, 5))\n",
    "plt.hist(corr_linear, bins=30, alpha=0.5, label='Linear', color='tab:blue')\n",
    "plt.hist(corr_mlp, bins=30, alpha=0.5, label='Non Linear', color='tab:orange')\n",
    "plt.axvline(mean_linear, color='tab:blue', linestyle='--', label=f'Linear Mean = {mean_linear:.3f}')\n",
    "plt.axvline(mean_mlp, color='tab:orange', linestyle='--', label=f'Non Linear Mean = {mean_mlp:.3f}')\n",
    "\n",
    "plt.title(\"Distribution of PC per Img Feature (Brain → Stimulus)\", fontsize=13)\n",
    "plt.xlabel(\"Pearson Correlation (r)\")\n",
    "plt.ylabel(\"Frequency\")\n",
    "\n",
    "stat_legend = [\n",
    "    Line2D([0], [0], color='none', label=f'p-value = {p_val:.2e}'),\n",
    "    Line2D([0], [0], color='none', label=f\"Cohen's d = {cohens_d:.2f}\")\n",
    "]\n",
    "\n",
    "handles, labels = plt.gca().get_legend_handles_labels()\n",
    "plt.legend(handles + stat_legend, labels + [h.get_label() for h in stat_legend])\n",
    "\n",
    "plt.grid(False)\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Similarity Comparison"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 184,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.preprocessing import StandardScaler\n",
    "\n",
    "def compute_cosine_matrix(real_embeddings, predicted_embeddings):\n",
    "\n",
    "    real_embeddings = torch.tensor(real_embeddings, dtype=torch.float32)\n",
    "    predicted_embeddings = torch.tensor(real_embeddings, dtype=torch.float32)\n",
    "    real_embeddings = torch.nn.functional.normalize(real_embeddings, dim=1)\n",
    "    predicted_embeddings = torch.nn.functional.normalize(predicted_embeddings, dim=1)\n",
    "    similarity_matrix = torch.mm(real_embeddings, predicted_embeddings.T)  # Matrice (num_real x num_pred)\n",
    "    \n",
    "    return similarity_matrix.numpy()\n",
    "\n",
    "\n",
    "def compute_normalized_similarities(y_pred, y_gt):\n",
    "    # Normalize by L2 norm\n",
    "    y_pred = torch.tensor(y_pred, dtype=torch.float32)\n",
    "    y_gt = torch.tensor(y_gt, dtype=torch.float32)\n",
    "    y_pred_norm = torch.nn.functional.normalize(y_pred, dim=1)\n",
    "    y_gt_norm = torch.nn.functional.normalize(y_gt, dim=1)\n",
    "\n",
    "    # Compute similarity\n",
    "    sims = y_pred_norm @ y_gt_norm.T\n",
    "\n",
    "    # Normalize similarities\n",
    "    scaler = StandardScaler()\n",
    "    sims_z = scaler.fit_transform(sims.cpu().numpy())\n",
    "\n",
    "    return sims, sims_z"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "feat_ridge_list = []\n",
    "feat_otcl_list = []\n",
    "feat_true_list = []\n",
    "\n",
    "for sub_i in range(3):\n",
    "\n",
    "    start_idx = sub_i * samples_per_subject\n",
    "    end_idx = (sub_i + 1) * samples_per_subject\n",
    "    feat_ridge_list.append(y_pred_sbj.float().cpu()[start_idx:end_idx])\n",
    "    feat_otcl_list.append(y_pred.cpu()[start_idx:end_idx])\n",
    "    feat_true_list.append(y_true.cpu()[start_idx:end_idx])\n",
    "\n",
    "feat_ridge_subj = np.stack(feat_ridge_list, axis=0).mean(axis=0)\n",
    "feat_true_subj = np.stack(feat_true_list, axis=0).mean(axis=0)\n",
    "feat_otcl_subj = np.stack(feat_otcl_list, axis=0).mean(axis=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 187,
   "metadata": {},
   "outputs": [],
   "source": [
    "similarity_matrix_ot, _ = compute_normalized_similarities(feat_otcl_subj, feat_true_subj)\n",
    "similarity_matrix, _ = compute_normalized_similarities(feat_ridge_subj, feat_true_subj)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 189,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABIYAAAHqCAYAAABx4UWGAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8ekN5oAAAACXBIWXMAAA9hAAAPYQGoP6dpAACoJ0lEQVR4nOzdaZwU1dn38X93D9MDM8Ow78iwqIAoKCjBDUUUl6iYuC8IUVQMJpFIlHhHxCWD+xKNRhMUfZK4RXNrIpuocQFFQFAJIDvKvg57D91dzwtuR1vnnKK36S7q9/186sX0NefU6e6q6qtPV9UVcBzHEQAAAAAAAHwnmOsBAAAAAAAAIDeYGAIAAAAAAPApJoYAAAAAAAB8iokhAAAAAAAAn2JiCAAAAAAAwKeYGAIAAAAAAPApJoYAAAAAAAB8iokhAAAAAAAAn2JiCAAAAAAAwKeYGALyyEknnaSTTjrJ9f/effddBQIBvfvuu1kfU23YsWOHrr76arVo0UKBQEC/+tWvcj0kAACArLjvvvvUoUMHhUIh9ejRI9fDAQAmhoBsevbZZxUIBKqXgoICtW7dWoMHD9aqVatyPbyUvfHGG+rbt6+aNWumevXqqUOHDrrwwgs1ceLElPr7/e9/r2effVbDhg3T888/ryuuuELTpk3T7bffrq1bt2Z28AAA4ICwZMkSXXvtterQoYOKiopUv359HXfccXrkkUe0e/fu6v8rLy/Xj3/845TW8fnnn+v8889Xu3btVFRUpNatW+vUU0/VH/7wh5T6mzx5sn7zm9/ouOOO0zPPPKPf//73Wr16tW6//XbNmTMnpT4BIF0FuR4A4Ad33HGH2rdvrz179uijjz7Ss88+qw8++EBffPGFioqKqv9v8uTJORzl/rn//vs1cuRI9e3bV6NGjVK9evW0ePFivfXWW3rhhRd0+umnJ93n22+/rR/96EcaPXp0wnrGjBmjwYMHq0GDBhl8BgAAwOv+/e9/64ILLlA4HNagQYPUrVs3VVVV6YMPPtDIkSM1b948PfXUU2mtY9q0aTr55JN10EEHaejQoWrRooW++uorffTRR3rkkUd0ww03JN3n22+/rWAwqL/85S8qLCyUJM2cOVNjxoxReXk5ZxAByAkmhoBacMYZZ6hXr16SpKuvvlpNmjTRPffco9dff10XXnhh9f99kyDkq2g0qjvvvFOnnnpqjZNY69evT6nf9evXq2vXrukODwAA+MCyZct08cUXq127dnr77bfVsmXL6tjPf/5zLV68WP/+97/TXs/dd9+tsrIyffLJJz/4kSqdnKdu3bp5n/MB8BcuJQNy4IQTTpC07xTo76rpHkNff/21Bg4cqOLiYjVr1kw33nijIpFIjf0+/vjj6tChg+rWratjjjlG77//fo19RiIRjR49Wp06dVI4HFbbtm31m9/8xtjvNzZu3Kht27bpuOOOqzHerFmzhL/Xr1+vq666Ss2bN1dRUZG6d++u8ePHV8e/uVfSsmXL9O9//7v6krvBgwdr5MiRkqT27dtXP758+XLr+AAAwIHv3nvv1Y4dO/SXv/wlYVLoG506ddIvf/nLtNezZMkSHXbYYTWeufz9nOebH886duyocDis8vJy/fa3v03IrQKBgJ555hnt3LmzOrd59tlndfTRR0uShgwZkvA4ANQWzhgCcuCbCY6GDRta/2/37t065ZRTtHLlSv3iF79Qq1at9Pzzz+vtt9/+wf8+8cQTGj58uE444QTdeOONWr58uQYOHKiGDRuqTZs21f8Xj8d1zjnn6IMPPtA111yjLl266PPPP9dDDz2kL7/8Uv/85z+N42nWrJnq1q2rN954QzfccIMaNWpkHftJJ52kxYsXa/jw4Wrfvr1efvllDR48WFu3btUvf/lLdenSRc8//7xuvPFGtWnTRr/+9a8lSYcffriqqqr097//XQ899JCaNGkiSWratKn19QIAAAe+N954Qx06dNCxxx6b1fW0a9dO06dP1xdffKFu3bpZ//fqq6/W+PHjdf755+vXv/61Pv74Y1VUVGj+/Pl67bXXJEnPP/+8nnrqKc2YMUN//vOfJUkHH3yw7rjjDt1222265pprqn88zPZzA4AEDoCseeaZZxxJzltvveVs2LDB+eqrr5xXXnnFadq0qRMOh52vvvoq4f/79u3r9O3bt/rvhx9+2JHkvPTSS9WP7dy50+nUqZMjyXnnnXccx3GcSCTiNG7c2Dn66KOdvXv3Vv/vs88+60hK6PP55593gsGg8/777yes+8knn3QkOR9++KH1Od12222OJKe4uNg544wznLvvvtuZNWvWD/7vm7H/v//3/6ofq6qqcvr06eOUlJQ427Ztq368Xbt2zllnnZXQ/r777nMkOcuWLbOOBwAA+EdlZaUjyTn33HP3u01Necb+mDx5shMKhZxQKOT06dPH+c1vfuNMmjTJqaqqSvi/OXPmOJKcq6++OuHxm266yZHkvP3229WPXXnllU5xcXHC/33yySeOJOeZZ55JeowAkAlcSgbUgv79+6tp06Zq27atzj//fBUXF+v1119POJOnJm+++aZatmyp888/v/qxevXq6Zprrkn4v5kzZ2rTpk0aOnSoCgq+PRHwsssu+8FZSS+//LK6dOmizp07a+PGjdVLv379JEnvvPOOdUxjxozR3/72Nx155JGaNGmSbr31VvXs2VNHHXWU5s+fnzD2Fi1a6JJLLql+rE6dOvrFL36hHTt26D//+Y91PQAAAN+3bds2SVJpaWnW13Xqqadq+vTpOuecczR37lzde++9GjBggFq3bq3XX3+9+v/efPNNSdKIESMS2n9zJnQm7ncEANnExBBQCx5//HFNmTJFr7zyis4880xt3LhR4XDYtd2KFSvUqVMnBQKBhMcPPfTQH/yftO+a+u8qKChQeXl5wmOLFi3SvHnz1LRp04TlkEMOkbR/N1O85JJL9P7772vLli2aPHmyLr30Un366ac6++yztWfPnuoxHXzwwQoGEw8zXbp0SRgzAADA/qpfv74kafv27bWyvqOPPlqvvvqqtmzZohkzZmjUqFHavn27zj//fP33v/+VtC+nCQaDP8jDWrRooQYNGpDzAMh73GMIqAXHHHNMdVWygQMH6vjjj9ell16qhQsXqqSkpFbHEo/Hdfjhh+vBBx+sMd62bdv97qt+/fo69dRTdeqpp6pOnToaP368Pv74Y/Xt2zdTwwUAAKhWv359tWrVSl988UWtrrewsFBHH320jj76aB1yyCEaMmSIXn75ZY0ePbr6f77/Qx4AeAVnDAG1LBQKqaKiQqtXr9Zjjz1m/d927dppyZIlchwn4fGFCxf+4P8kafHixQmPR6PRH1Ty6tixozZv3qxTTjlF/fv3/8Hy/bOR9tc3E19r1qypHtOiRYsUj8cT/m/BggUJYzYhuQIAADX58Y9/rCVLlmj69Ok5WX9NOU88HteiRYsS/m/dunXaunUrOQ+AvMfEEJADJ510ko455hg9/PDD1Zde1eTMM8/U6tWr9corr1Q/tmvXLj311FMJ/9erVy81btxYTz/9tKLRaPXjf/3rX7Vly5aE/73wwgu1atUqPf30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",
      "text/plain": [
       "<Figure size 1200x500 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import torch\n",
    "import torch.nn.functional as F\n",
    "import seaborn as sns\n",
    "\n",
    "sims_otcl_soft = F.softmax(torch.tensor(similarity_matrix_ot)/0.05, dim=1)\n",
    "sims_ridge_soft = F.softmax(torch.tensor(similarity_matrix)/0.05, dim=1)\n",
    "\n",
    "fig, axes = plt.subplots(1, 2, figsize=(12, 5))  # 1 riga, 2 colonne\n",
    "\n",
    "sns.heatmap(sims_ridge_soft, cmap='viridis', vmin=0, vmax=0.5, ax=axes[0])\n",
    "axes[0].set_title(\"Ridge Soft\")\n",
    "sns.heatmap(sims_otcl_soft, cmap='viridis', vmin=0, vmax=0.5, ax=axes[1])\n",
    "axes[1].set_title(\"CL Soft\")\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "speech-meg",
   "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.9.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
