{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "34ecc147",
   "metadata": {},
   "source": [
    "## sst2 - The Stanford Sentiment Treebank: predict whether a movie review is positive or negative"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1b7c050e",
   "metadata": {},
   "source": [
    "### Importing the required libraries"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "39ca6749",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pickle\n",
    "import torch\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from datasets import load_dataset\n",
    "from torch.utils.data import TensorDataset, random_split\n",
    "from torch.utils.data import DataLoader, RandomSampler, SequentialSampler\n",
    "from transformers import AutoTokenizer\n",
    "from transformers import AutoModelForSequenceClassification\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "from sklearn.linear_model import LogisticRegression\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ad368ef2",
   "metadata": {},
   "source": [
    "### Checking if gpu is available"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "5f88d053",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "There are 5 GPU(s) available.\n",
      "We will use the GPU: Tesla V100S-PCIE-32GB\n"
     ]
    }
   ],
   "source": [
    "if torch.cuda.is_available():       \n",
    "    device = torch.device(\"cuda\")\n",
    "    print('There are %d GPU(s) available.' % torch.cuda.device_count())\n",
    "    print('We will use the GPU:', torch.cuda.get_device_name(0))\n",
    "else:\n",
    "    print('No GPU available, using the CPU instead.')\n",
    "    device = torch.device(\"cpu\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1950a617",
   "metadata": {},
   "source": [
    "### Loading the dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "718d1161",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "DatasetDict({\n",
       "    train: Dataset({\n",
       "        features: ['sentence', 'label', 'idx'],\n",
       "        num_rows: 67349\n",
       "    })\n",
       "    validation: Dataset({\n",
       "        features: ['sentence', 'label', 'idx'],\n",
       "        num_rows: 872\n",
       "    })\n",
       "    test: Dataset({\n",
       "        features: ['sentence', 'label', 'idx'],\n",
       "        num_rows: 1821\n",
       "    })\n",
       "})"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from datasets import load_dataset\n",
    "dataset = load_dataset('glue', 'sst2')\n",
    "dataset"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7f816f3a",
   "metadata": {},
   "source": [
    "### Using the tokenizer from huggingface"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "bed31e45",
   "metadata": {},
   "outputs": [],
   "source": [
    "from transformers import AutoTokenizer\n",
    "\n",
    "tokenizer = AutoTokenizer.from_pretrained(\"gchhablani/bert-base-cased-finetuned-sst2\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5d3e5c51",
   "metadata": {},
   "source": [
    "### Loading the pre-trained and fine-tuned models from huggingface and moving them to device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "eb5abdb7",
   "metadata": {
    "collapsed": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Some weights of BertForSequenceClassification were not initialized from the model checkpoint at bert-base-cased and are newly initialized: ['classifier.bias', 'classifier.weight']\n",
      "You should probably TRAIN this model on a down-stream task to be able to use it for predictions and inference.\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "BertForSequenceClassification(\n",
       "  (bert): BertModel(\n",
       "    (embeddings): BertEmbeddings(\n",
       "      (word_embeddings): Embedding(28996, 768, padding_idx=0)\n",
       "      (position_embeddings): Embedding(512, 768)\n",
       "      (token_type_embeddings): Embedding(2, 768)\n",
       "      (LayerNorm): LayerNorm((768,), eps=1e-12, elementwise_affine=True)\n",
       "      (dropout): Dropout(p=0.1, inplace=False)\n",
       "    )\n",
       "    (encoder): BertEncoder(\n",
       "      (layer): ModuleList(\n",
       "        (0-11): 12 x BertLayer(\n",
       "          (attention): BertAttention(\n",
       "            (self): BertSelfAttention(\n",
       "              (query): Linear(in_features=768, out_features=768, bias=True)\n",
       "              (key): Linear(in_features=768, out_features=768, bias=True)\n",
       "              (value): Linear(in_features=768, out_features=768, bias=True)\n",
       "              (dropout): Dropout(p=0.1, inplace=False)\n",
       "            )\n",
       "            (output): BertSelfOutput(\n",
       "              (dense): Linear(in_features=768, out_features=768, bias=True)\n",
       "              (LayerNorm): LayerNorm((768,), eps=1e-12, elementwise_affine=True)\n",
       "              (dropout): Dropout(p=0.1, inplace=False)\n",
       "            )\n",
       "          )\n",
       "          (intermediate): BertIntermediate(\n",
       "            (dense): Linear(in_features=768, out_features=3072, bias=True)\n",
       "            (intermediate_act_fn): GELUActivation()\n",
       "          )\n",
       "          (output): BertOutput(\n",
       "            (dense): Linear(in_features=3072, out_features=768, bias=True)\n",
       "            (LayerNorm): LayerNorm((768,), eps=1e-12, elementwise_affine=True)\n",
       "            (dropout): Dropout(p=0.1, inplace=False)\n",
       "          )\n",
       "        )\n",
       "      )\n",
       "    )\n",
       "    (pooler): BertPooler(\n",
       "      (dense): Linear(in_features=768, out_features=768, bias=True)\n",
       "      (activation): Tanh()\n",
       "    )\n",
       "  )\n",
       "  (dropout): Dropout(p=0.1, inplace=False)\n",
       "  (classifier): Linear(in_features=768, out_features=2, bias=True)\n",
       ")"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "preTrainedModel = AutoModelForSequenceClassification.from_pretrained(\"bert-base-cased\",\n",
    "                                                      num_labels = 2,\n",
    "                                                      output_attentions = True,\n",
    "                                                      output_hidden_states = True,)\n",
    "preTrainedModel.cuda()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "c17072a2",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "┌ Warning: `vendor()` is deprecated, use `BLAS.get_config()` and inspect the output instead\n",
      "│   caller = npyinitialize() at numpy.jl:67\n",
      "└ @ PyCall ~/.julia/packages/PyCall/L0fLP/src/numpy.jl:67\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-------------avgN = 7.2770394381415455\n",
      "-------------Density = 9.80263997980668\n",
      "-------------avgN = 7.23016639828234\n",
      "-------------Density = 10.637589273782833\n",
      "Generate eigenpairs\n",
      "Generate eigenpairs\n"
     ]
    }
   ],
   "source": [
    "from my_utils.utils import SAGMAN_V2, SAGMAN_V2_bi_lip, extract_embeddings_advanced_v5\n",
    "\n",
    "\n",
    "input_embeddings, output_embeddings = extract_embeddings_advanced_v5(preTrainedModel, tokenizer, dataset['train']['sentence'], dataset['train']['label'])\n",
    "\n",
    "TopEig, TopEdgeList, TopNodeList, node_score, internal_edge = SAGMAN_V2_bi_lip(\n",
    "                            input_embeddings, \n",
    "                            output_embeddings, \n",
    "                            k=20,\n",
    "                            SPF_cors=3,\n",
    "                        )\n",
    "\n",
    "def compute_weights_from_ranking(ranking: np.ndarray) -> np.ndarray:\n",
    "    n = len(ranking)\n",
    "    rank_for_sample = np.zeros(n, dtype=int)\n",
    "    for r, sample_id in enumerate(ranking):\n",
    "        rank_for_sample[sample_id] = r\n",
    "    max_rank = n - 1\n",
    "    weights = 1.0 - (rank_for_sample / max_rank)\n",
    "    return weights\n",
    "\n",
    "sample_weights = compute_weights_from_ranking(TopNodeList)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "d0b16418",
   "metadata": {},
   "outputs": [],
   "source": [
    "sample_weights = torch.tensor(sample_weights, dtype=torch.float).to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "74ec293c",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Some weights of BertForSequenceClassification were not initialized from the model checkpoint at bert-base-cased and are newly initialized: ['classifier.bias', 'classifier.weight']\n",
      "You should probably TRAIN this model on a down-stream task to be able to use it for predictions and inference.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "f1532c89f254419d873cd6eab7ca9a64",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Map:   0%|          | 0/67349 [00:00<?, ? examples/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training Epoch 1:   0%|          | 0/4210 [07:21<?, ?it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 Training Loss: 0.1206\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Evaluating Epoch 1: 100%|██████████| 109/109 [00:03<00:00, 32.39it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1 Validation Loss: 0.2549, Accuracy: 0.9174\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training Epoch 1:   0%|          | 0/4210 [10:55<?, ?it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 Training Loss: 0.0665\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Evaluating Epoch 2: 100%|██████████| 109/109 [00:03<00:00, 30.60it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 2 Validation Loss: 0.2865, Accuracy: 0.9128\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training Epoch 2:   0%|          | 0/4210 [10:42<?, ?it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 Training Loss: 0.0416\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Evaluating Epoch 3: 100%|██████████| 109/109 [00:03<00:00, 31.73it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 3 Validation Loss: 0.3157, Accuracy: 0.9151\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "from transformers import AutoTokenizer, AutoModelForSequenceClassification, AdamW, get_scheduler\n",
    "from tqdm import tqdm\n",
    "from transformers import DataCollatorWithPadding\n",
    "\n",
    "fineTunedModel = AutoModelForSequenceClassification.from_pretrained(\"bert-base-cased\",\n",
    "                                                      num_labels = 2,\n",
    "                                                      output_attentions = True,\n",
    "                                                      output_hidden_states = True,)\n",
    "fineTunedModel.cuda()\n",
    "\n",
    "def tokenize_function(examples):\n",
    "    return tokenizer(examples['sentence'], padding=\"max_length\", truncation=True, max_length=128)\n",
    "\n",
    "tokenized_datasets = dataset.map(tokenize_function, batched=True)\n",
    "\n",
    "data_collator = DataCollatorWithPadding(tokenizer=tokenizer)\n",
    "\n",
    "\n",
    "# Prepare dataloaders\n",
    "# train_dataset = tokenized_datasets[\"train\"].remove_columns([\"idx\", \"sentence\"])\n",
    "train_dataset = tokenized_datasets[\"train\"].remove_columns([\"sentence\"])\n",
    "eval_dataset = tokenized_datasets[\"validation\"].remove_columns([\"idx\", \"sentence\"])\n",
    "train_dataloader = DataLoader(train_dataset, batch_size=16, shuffle=True,collate_fn=data_collator)\n",
    "eval_dataloader = DataLoader(eval_dataset, batch_size=8,collate_fn=data_collator)\n",
    "\n",
    "\n",
    "# Optimizer\n",
    "optimizer = AdamW(fineTunedModel.parameters(), lr=2e-5, betas=(0.9, 0.999), eps=1e-8)\n",
    "\n",
    "# Scheduler\n",
    "num_training_steps = len(train_dataloader) * 3  # 3 epochs\n",
    "lr_scheduler = get_scheduler(\n",
    "    \"linear\", optimizer=optimizer, num_warmup_steps=0, num_training_steps=num_training_steps\n",
    ")\n",
    "\n",
    "# Move model to GPU\n",
    "fineTunedModel.to(device)\n",
    "num_epochs = 3\n",
    "for epoch in range(num_epochs):\n",
    "    # Training\n",
    "    fineTunedModel.train()\n",
    "    total_train_loss = 0\n",
    "    train_progress_bar = tqdm(train_dataloader, desc=f\"Training Epoch {epoch+1}\")\n",
    "    \n",
    "    for batch in train_dataloader:\n",
    "        # Move data to device\n",
    "        batch = {k: v.to(device) for k, v in batch.items()}\n",
    "        \n",
    "        batch_indices = batch['idx']\n",
    "        batch_weights = sample_weights[batch_indices]\n",
    "        # Forward pass\n",
    "        del batch['idx']\n",
    "        outputs = fineTunedModel(**batch)\n",
    "        # loss = outputs.loss\n",
    "        # total_train_loss += loss.item()\n",
    "        # # Backward pass\n",
    "        # optimizer.zero_grad()\n",
    "        # loss.backward()\n",
    "\n",
    "        logits = outputs.logits  # Get logits from the model output\n",
    "        loss_fn = torch.nn.CrossEntropyLoss(reduction='none')  # Use per-sample weights\n",
    "        losses = loss_fn(logits, batch['labels'])\n",
    "        weighted_loss = (losses * batch_weights).mean()  # Apply weights and compute mean\n",
    "        total_train_loss += weighted_loss.item()\n",
    "        weighted_loss.backward()\n",
    "\n",
    "        torch.nn.utils.clip_grad_norm_(fineTunedModel.parameters(), 1.0)  # Gradient clipping\n",
    "        optimizer.step()\n",
    "        lr_scheduler.step()\n",
    "    \n",
    "    avg_train_loss = total_train_loss / len(train_dataloader)\n",
    "    print(f\"Epoch {epoch+1} Training Loss: {avg_train_loss:.4f}\")\n",
    "\n",
    "    # Evaluation\n",
    "    fineTunedModel.eval()\n",
    "    total_eval_loss = 0\n",
    "    correct_predictions = 0\n",
    "    total_predictions = 0\n",
    "\n",
    "    eval_progress_bar = tqdm(eval_dataloader, desc=f\"Evaluating Epoch {epoch+1}\")\n",
    "    with torch.no_grad():\n",
    "        for batch in eval_progress_bar:\n",
    "            batch = {k: v.to(device) for k, v in batch.items()}\n",
    "            outputs = fineTunedModel(**batch)\n",
    "            loss = outputs.loss\n",
    "            total_eval_loss += loss.item()\n",
    "\n",
    "            logits = outputs.logits\n",
    "            predictions = torch.argmax(logits, dim=-1)\n",
    "            correct_predictions += (predictions == batch[\"labels\"]).sum().item()\n",
    "            total_predictions += batch[\"labels\"].size(0)\n",
    "    \n",
    "    avg_eval_loss = total_eval_loss / len(eval_dataloader)\n",
    "    accuracy = correct_predictions / total_predictions\n",
    "    print(f\"Epoch {epoch+1} Validation Loss: {avg_eval_loss:.4f}, Accuracy: {accuracy:.4f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "3853735d",
   "metadata": {},
   "outputs": [],
   "source": [
    "fineTunedModel.save_pretrained(\"bert-cola-SAGMAN\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "95067354",
   "metadata": {},
   "source": [
    "### Forming dataloaders"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "8a18b09f",
   "metadata": {},
   "outputs": [],
   "source": [
    "tokenised_dataset = tokenizer(dataset['test']['sentence'], padding=True, return_tensors='pt')\n",
    "input_ids = tokenised_dataset['input_ids']\n",
    "token_type_ids = tokenised_dataset['token_type_ids']\n",
    "attention_masks = tokenised_dataset['attention_mask']\n",
    "labels = torch.tensor(dataset['test']['label'])\n",
    "\n",
    "# Set the batch size.  \n",
    "batch_size = 16 \n",
    "\n",
    "# Create the DataLoader.\n",
    "test_data = TensorDataset(input_ids, token_type_ids, attention_masks, labels)\n",
    "test_sampler = SequentialSampler(test_data)\n",
    "test_dataloader = DataLoader(test_data, sampler=test_sampler, batch_size=batch_size)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "6f85a1ca",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Some weights of BertForSequenceClassification were not initialized from the model checkpoint at bert-base-cased and are newly initialized: ['classifier.bias', 'classifier.weight']\n",
      "You should probably TRAIN this model on a down-stream task to be able to use it for predictions and inference.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "3898495a23994e8b81d6c032969a582b",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Map:   0%|          | 0/67349 [00:00<?, ? examples/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Created `train_dataloader` with 4210 batches!\n",
      "\n",
      "Created `val_dataloader` with 55 batches!\n",
      "Created `test_dataloader` with 114 batches!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training Epoch 3:   0%|          | 0/4210 [1:50:11<?, ?it/s]\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[13], line 66\u001b[0m\n\u001b[1;32m     64\u001b[0m outputs \u001b[38;5;241m=\u001b[39m fineTunedModel(\u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mbatch)\n\u001b[1;32m     65\u001b[0m loss \u001b[38;5;241m=\u001b[39m outputs\u001b[38;5;241m.\u001b[39mloss\n\u001b[0;32m---> 66\u001b[0m total_train_loss \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m \u001b[43mloss\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mitem\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     67\u001b[0m \u001b[38;5;66;03m# Backward pass\u001b[39;00m\n\u001b[1;32m     68\u001b[0m optimizer\u001b[38;5;241m.\u001b[39mzero_grad()\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "from transformers import AutoTokenizer, AutoModelForSequenceClassification, AdamW, get_scheduler\n",
    "from tqdm import tqdm\n",
    "from transformers import DataCollatorWithPadding\n",
    "\n",
    "\n",
    "fineTunedModel = AutoModelForSequenceClassification.from_pretrained(\"bert-base-cased\",\n",
    "                                                      num_labels = 2,\n",
    "                                                      output_attentions = True,\n",
    "                                                      output_hidden_states = True,)\n",
    "fineTunedModel.cuda()\n",
    "\n",
    "def tokenize_function(examples):\n",
    "    return tokenizer(examples['sentence'], padding=\"max_length\", truncation=True, max_length=128)\n",
    "\n",
    "tokenized_datasets = dataset.map(tokenize_function, batched=True)\n",
    "\n",
    "data_collator = DataCollatorWithPadding(tokenizer=tokenizer)\n",
    "# Move pytorch dataset into dataloader.\n",
    "train_dataloader = DataLoader(dataset['train'], batch_size=16, shuffle=True, collate_fn=data_collator)\n",
    "print('Created `train_dataloader` with %d batches!'%len(train_dataloader))\n",
    "\n",
    "print()\n",
    "\n",
    "valid_dataloader = DataLoader(dataset['validation'], batch_size=16, shuffle=False, collate_fn=data_collator)\n",
    "print('Created `val_dataloader` with %d batches!'%len(valid_dataloader))\n",
    "\n",
    "test_dataloader = DataLoader(dataset['test'], batch_size=16, shuffle=False, collate_fn=data_collator)\n",
    "print('Created `test_dataloader` with %d batches!'%len(test_dataloader))\n",
    "\n",
    "# Prepare dataloaders\n",
    "# train_dataset = tokenized_datasets[\"train\"].remove_columns([\"idx\", \"sentence\"])\n",
    "train_dataset = tokenized_datasets[\"train\"].remove_columns([\"sentence\"])\n",
    "eval_dataset = tokenized_datasets[\"validation\"].remove_columns([\"idx\", \"sentence\"])\n",
    "train_dataloader = DataLoader(train_dataset, batch_size=16, shuffle=True,collate_fn=data_collator)\n",
    "eval_dataloader = DataLoader(eval_dataset, batch_size=8,collate_fn=data_collator)\n",
    "\n",
    "\n",
    "# Optimizer\n",
    "optimizer = AdamW(fineTunedModel.parameters(), lr=2e-5, betas=(0.9, 0.999), eps=1e-8)\n",
    "\n",
    "# Scheduler\n",
    "num_training_steps = len(train_dataloader) * 3  # 3 epochs\n",
    "lr_scheduler = get_scheduler(\n",
    "    \"linear\", optimizer=optimizer, num_warmup_steps=0, num_training_steps=num_training_steps\n",
    ")\n",
    "\n",
    "# Move model to GPU\n",
    "fineTunedModel.to(device)\n",
    "num_epochs = 3\n",
    "for epoch in range(num_epochs):\n",
    "    # Training\n",
    "    fineTunedModel.train()\n",
    "    total_train_loss = 0\n",
    "    train_progress_bar = tqdm(train_dataloader, desc=f\"Training Epoch {epoch+1}\")\n",
    "    \n",
    "    for batch in train_dataloader:\n",
    "        # Move data to device\n",
    "        batch = {k: v.to(device) for k, v in batch.items()}\n",
    "        \n",
    "        batch_indices = batch['idx']\n",
    "        # batch_weights = sample_weights[batch_indices]\n",
    "        # Forward pass\n",
    "        del batch['idx']\n",
    "        outputs = fineTunedModel(**batch)\n",
    "        loss = outputs.loss\n",
    "        total_train_loss += loss.item()\n",
    "        # Backward pass\n",
    "        optimizer.zero_grad()\n",
    "        loss.backward()\n",
    "\n",
    "        # logits = outputs.logits  # Get logits from the model output\n",
    "        # loss_fn = torch.nn.CrossEntropyLoss(reduction='none')  # Use per-sample weights\n",
    "        # losses = loss_fn(logits, batch['labels'])\n",
    "        # weighted_loss = (losses * batch_weights).mean()  # Apply weights and compute mean\n",
    "        # total_train_loss += weighted_loss.item()\n",
    "        # weighted_loss.backward()\n",
    "\n",
    "        torch.nn.utils.clip_grad_norm_(fineTunedModel.parameters(), 1.0)  # Gradient clipping\n",
    "        optimizer.step()\n",
    "        lr_scheduler.step()\n",
    "    \n",
    "    avg_train_loss = total_train_loss / len(train_dataloader)\n",
    "    print(f\"Epoch {epoch+1} Training Loss: {avg_train_loss:.4f}\")\n",
    "\n",
    "    # Evaluation\n",
    "    fineTunedModel.eval()\n",
    "    total_eval_loss = 0\n",
    "    correct_predictions = 0\n",
    "    total_predictions = 0\n",
    "\n",
    "    eval_progress_bar = tqdm(eval_dataloader, desc=f\"Evaluating Epoch {epoch+1}\")\n",
    "    with torch.no_grad():\n",
    "        for batch in eval_progress_bar:\n",
    "            batch = {k: v.to(device) for k, v in batch.items()}\n",
    "            outputs = fineTunedModel(**batch)\n",
    "            loss = outputs.loss\n",
    "            total_eval_loss += loss.item()\n",
    "\n",
    "            logits = outputs.logits\n",
    "            predictions = torch.argmax(logits, dim=-1)\n",
    "            correct_predictions += (predictions == batch[\"labels\"]).sum().item()\n",
    "            total_predictions += batch[\"labels\"].size(0)\n",
    "    \n",
    "    avg_eval_loss = total_eval_loss / len(eval_dataloader)\n",
    "    accuracy = correct_predictions / total_predictions\n",
    "    print(f\"Epoch {epoch+1} Validation Loss: {avg_eval_loss:.4f}, Accuracy: {accuracy:.4f}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "2d256716",
   "metadata": {},
   "outputs": [],
   "source": [
    "fineTunedModel.save_pretrained(\"bert-sst2-SAGMAN\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "2e448fbb",
   "metadata": {},
   "outputs": [],
   "source": [
    "def getLabels(model, data_loader):\n",
    "    predictions = []\n",
    "    for batch in data_loader:\n",
    "        batch = tuple(t.to(device) for t in batch)\n",
    "        b_input_ids, b_token_type_ids, b_input_mask, b_labels = batch\n",
    "  \n",
    "        with torch.no_grad():\n",
    "            results = model(b_input_ids, token_type_ids=b_token_type_ids, attention_mask=b_input_mask, return_dict=True)\n",
    "            logits = results.logits\n",
    "            pred = torch.argmax(logits, dim = 1)\n",
    "            predictions.extend(pred.tolist())\n",
    "    return predictions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "9e0eaf31",
   "metadata": {},
   "outputs": [],
   "source": [
    "# import numpy as np\n",
    "# import pandas as pd\n",
    "# predictions = getLabels(fineTunedModel, test_dataloader)\n",
    "# filename = 'fSST-2.tsv'\n",
    "# result = pd.DataFrame(predictions, columns=['prediction'])\n",
    "# result.insert(0, 'index', range(0, len(result)))\n",
    "# result.to_csv(filename, sep='\\t', index=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ae0884db",
   "metadata": {},
   "source": [
    "### Getting CLS hidden states for all layers [13, number of sampes, 768] to check layer-wise accuracy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "e176e852",
   "metadata": {},
   "outputs": [],
   "source": [
    "def getCLSHiddenStates(model, prediction_dataloader):\n",
    "    model.eval()\n",
    "    totalHiddenStates = [0]*13\n",
    "    flag = True\n",
    "    \n",
    "    for batch in prediction_dataloader:\n",
    "        # Add batch to GPU\n",
    "        batch = tuple(t.to(device) for t in batch)\n",
    "  \n",
    "        # Unpack the inputs from our dataloader\n",
    "        b_input_ids, b_token_type_ids, b_input_mask, b_labels = batch\n",
    "  \n",
    "        with torch.no_grad():\n",
    "            result = model(b_input_ids,\n",
    "                           token_type_ids=None,\n",
    "                           attention_mask=b_input_mask,\n",
    "                           output_hidden_states = True,\n",
    "                           return_dict=True)\n",
    "            \n",
    "        hidden_states = result.hidden_states\n",
    "        if flag == True:\n",
    "            for i in range(len(hidden_states)):\n",
    "                totalHiddenStates[i] = hidden_states[i][:,0,:].to(\"cpu\")\n",
    "            flag = False\n",
    "        else:\n",
    "            for i in range(len(hidden_states)):\n",
    "                temp = hidden_states[i][:,0,:].to(\"cpu\")\n",
    "                totalHiddenStates[i] = torch.cat((totalHiddenStates[i], temp), 0)   \n",
    "    return totalHiddenStates"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "528ddd51",
   "metadata": {
    "collapsed": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n"
     ]
    },
    {
     "ename": "ValueError",
     "evalue": "text input must be of type `str` (single example), `List[str]` (batch or single pretokenized example) or `List[List[str]]` (batch of pretokenized examples).",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mValueError\u001b[0m                                Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[17], line 11\u001b[0m\n\u001b[1;32m      9\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m     10\u001b[0m     end \u001b[38;5;241m=\u001b[39m (i\u001b[38;5;241m+\u001b[39m\u001b[38;5;241m1\u001b[39m)\u001b[38;5;241m*\u001b[39m\u001b[38;5;241m10000\u001b[39m\n\u001b[0;32m---> 11\u001b[0m tokenised_dataset \u001b[38;5;241m=\u001b[39m \u001b[43mtokenizer\u001b[49m\u001b[43m(\u001b[49m\u001b[43mdataset\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mtrain\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m[\u001b[49m\u001b[43mst\u001b[49m\u001b[43m:\u001b[49m\u001b[43mend\u001b[49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mpadding\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mreturn_tensors\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mpt\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m)\u001b[49m\n\u001b[1;32m     12\u001b[0m input_ids \u001b[38;5;241m=\u001b[39m tokenised_dataset[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124minput_ids\u001b[39m\u001b[38;5;124m'\u001b[39m]\n\u001b[1;32m     13\u001b[0m token_type_ids \u001b[38;5;241m=\u001b[39m tokenised_dataset[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mtoken_type_ids\u001b[39m\u001b[38;5;124m'\u001b[39m]\n",
      "File \u001b[0;32m~/.pyenv/versions/3.11.7/lib/python3.11/site-packages/transformers/tokenization_utils_base.py:2860\u001b[0m, in \u001b[0;36mPreTrainedTokenizerBase.__call__\u001b[0;34m(self, text, text_pair, text_target, text_pair_target, add_special_tokens, padding, truncation, max_length, stride, is_split_into_words, pad_to_multiple_of, padding_side, return_tensors, return_token_type_ids, return_attention_mask, return_overflowing_tokens, return_special_tokens_mask, return_offsets_mapping, return_length, verbose, **kwargs)\u001b[0m\n\u001b[1;32m   2858\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_in_target_context_manager:\n\u001b[1;32m   2859\u001b[0m         \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_switch_to_input_mode()\n\u001b[0;32m-> 2860\u001b[0m     encodings \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_call_one\u001b[49m\u001b[43m(\u001b[49m\u001b[43mtext\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mtext\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mtext_pair\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mtext_pair\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mall_kwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   2861\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m text_target \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[1;32m   2862\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_switch_to_target_mode()\n",
      "File \u001b[0;32m~/.pyenv/versions/3.11.7/lib/python3.11/site-packages/transformers/tokenization_utils_base.py:2920\u001b[0m, in \u001b[0;36mPreTrainedTokenizerBase._call_one\u001b[0;34m(self, text, text_pair, add_special_tokens, padding, truncation, max_length, stride, is_split_into_words, pad_to_multiple_of, padding_side, return_tensors, return_token_type_ids, return_attention_mask, return_overflowing_tokens, return_special_tokens_mask, return_offsets_mapping, return_length, verbose, split_special_tokens, **kwargs)\u001b[0m\n\u001b[1;32m   2917\u001b[0m         \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;01mFalse\u001b[39;00m\n\u001b[1;32m   2919\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m _is_valid_text_input(text):\n\u001b[0;32m-> 2920\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mValueError\u001b[39;00m(\n\u001b[1;32m   2921\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mtext input must be of type `str` (single example), `List[str]` (batch or single pretokenized example) \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m   2922\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mor `List[List[str]]` (batch of pretokenized examples).\u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m   2923\u001b[0m     )\n\u001b[1;32m   2925\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m text_pair \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m \u001b[38;5;129;01mand\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m _is_valid_text_input(text_pair):\n\u001b[1;32m   2926\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mValueError\u001b[39;00m(\n\u001b[1;32m   2927\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mtext input must be of type `str` (single example), `List[str]` (batch or single pretokenized example) \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m   2928\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mor `List[List[str]]` (batch of pretokenized examples).\u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m   2929\u001b[0m     )\n",
      "\u001b[0;31mValueError\u001b[0m: text input must be of type `str` (single example), `List[str]` (batch or single pretokenized example) or `List[List[str]]` (batch of pretokenized examples)."
     ]
    }
   ],
   "source": [
    "num_rows = dataset['train'].num_rows\n",
    "hiddenStates = [0]*13\n",
    "flag = True\n",
    "for i in range(0, num_rows//10000 +1):\n",
    "    print(i)\n",
    "    st = i*10000\n",
    "    if(i==num_rows//10000):\n",
    "        end = num_rows\n",
    "    else:\n",
    "        end = (i+1)*10000\n",
    "    tokenised_dataset = tokenizer(dataset['train'][st:end], padding=True, return_tensors='pt')\n",
    "    input_ids = tokenised_dataset['input_ids']\n",
    "    token_type_ids = tokenised_dataset['token_type_ids']\n",
    "    attention_masks = tokenised_dataset['attention_mask']\n",
    "    labels = torch.tensor(dataset['train']['label'][st:end])\n",
    "  \n",
    "    \n",
    "    batch_size = 16 \n",
    "    train_data = TensorDataset(input_ids, token_type_ids, attention_masks, labels)\n",
    "    train_sampler = SequentialSampler(train_data)\n",
    "    train_dataloader = DataLoader(train_data, sampler=train_sampler, batch_size=batch_size)\n",
    "    \n",
    "    hS = getCLSHiddenStates(preTrainedModel, train_dataloader)\n",
    "    if flag==True:\n",
    "        for j in range(13):\n",
    "            hiddenStates[j] = hS[j]\n",
    "        flag = False\n",
    "    else:\n",
    "        for j in range(13):\n",
    "            hiddenStates[j] = torch.cat((hiddenStates[j], hS[j]), dim = 0)\n",
    "\n",
    "preTrainedCLSHiddenStatesTrain = torch.stack(hiddenStates, dim = 0)\n",
    "#torch.save(preTrainedCLSHiddenStatesTrain, 'preTrainedCLSHiddenStatesTrain_sst2.pt')\n",
    "preTrainedCLSHiddenStatesTrain.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "676b42a7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n"
     ]
    },
    {
     "ename": "ValueError",
     "evalue": "text input must be of type `str` (single example), `List[str]` (batch or single pretokenized example) or `List[List[str]]` (batch of pretokenized examples).",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mValueError\u001b[0m                                Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[19], line 11\u001b[0m\n\u001b[1;32m      9\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m     10\u001b[0m     end \u001b[38;5;241m=\u001b[39m (i\u001b[38;5;241m+\u001b[39m\u001b[38;5;241m1\u001b[39m)\u001b[38;5;241m*\u001b[39m\u001b[38;5;241m10000\u001b[39m\n\u001b[0;32m---> 11\u001b[0m tokenised_dataset \u001b[38;5;241m=\u001b[39m \u001b[43mtokenizer\u001b[49m\u001b[43m(\u001b[49m\u001b[43mdataset\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mtrain\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m[\u001b[49m\u001b[43mst\u001b[49m\u001b[43m:\u001b[49m\u001b[43mend\u001b[49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mpadding\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mreturn_tensors\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[38;5;124;43mpt\u001b[39;49m\u001b[38;5;124;43m'\u001b[39;49m\u001b[43m)\u001b[49m\n\u001b[1;32m     12\u001b[0m input_ids \u001b[38;5;241m=\u001b[39m tokenised_dataset[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124minput_ids\u001b[39m\u001b[38;5;124m'\u001b[39m]\n\u001b[1;32m     13\u001b[0m token_type_ids \u001b[38;5;241m=\u001b[39m tokenised_dataset[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mtoken_type_ids\u001b[39m\u001b[38;5;124m'\u001b[39m]\n",
      "File \u001b[0;32m~/.pyenv/versions/3.11.7/lib/python3.11/site-packages/transformers/tokenization_utils_base.py:2860\u001b[0m, in \u001b[0;36mPreTrainedTokenizerBase.__call__\u001b[0;34m(self, text, text_pair, text_target, text_pair_target, add_special_tokens, padding, truncation, max_length, stride, is_split_into_words, pad_to_multiple_of, padding_side, return_tensors, return_token_type_ids, return_attention_mask, return_overflowing_tokens, return_special_tokens_mask, return_offsets_mapping, return_length, verbose, **kwargs)\u001b[0m\n\u001b[1;32m   2858\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_in_target_context_manager:\n\u001b[1;32m   2859\u001b[0m         \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_switch_to_input_mode()\n\u001b[0;32m-> 2860\u001b[0m     encodings \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_call_one\u001b[49m\u001b[43m(\u001b[49m\u001b[43mtext\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mtext\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mtext_pair\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mtext_pair\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mall_kwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   2861\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m text_target \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[1;32m   2862\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_switch_to_target_mode()\n",
      "File \u001b[0;32m~/.pyenv/versions/3.11.7/lib/python3.11/site-packages/transformers/tokenization_utils_base.py:2920\u001b[0m, in \u001b[0;36mPreTrainedTokenizerBase._call_one\u001b[0;34m(self, text, text_pair, add_special_tokens, padding, truncation, max_length, stride, is_split_into_words, pad_to_multiple_of, padding_side, return_tensors, return_token_type_ids, return_attention_mask, return_overflowing_tokens, return_special_tokens_mask, return_offsets_mapping, return_length, verbose, split_special_tokens, **kwargs)\u001b[0m\n\u001b[1;32m   2917\u001b[0m         \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;01mFalse\u001b[39;00m\n\u001b[1;32m   2919\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m _is_valid_text_input(text):\n\u001b[0;32m-> 2920\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mValueError\u001b[39;00m(\n\u001b[1;32m   2921\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mtext input must be of type `str` (single example), `List[str]` (batch or single pretokenized example) \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m   2922\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mor `List[List[str]]` (batch of pretokenized examples).\u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m   2923\u001b[0m     )\n\u001b[1;32m   2925\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m text_pair \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m \u001b[38;5;129;01mand\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m _is_valid_text_input(text_pair):\n\u001b[1;32m   2926\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mValueError\u001b[39;00m(\n\u001b[1;32m   2927\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mtext input must be of type `str` (single example), `List[str]` (batch or single pretokenized example) \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m   2928\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mor `List[List[str]]` (batch of pretokenized examples).\u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m   2929\u001b[0m     )\n",
      "\u001b[0;31mValueError\u001b[0m: text input must be of type `str` (single example), `List[str]` (batch or single pretokenized example) or `List[List[str]]` (batch of pretokenized examples)."
     ]
    }
   ],
   "source": [
    "num_rows = dataset['train'].num_rows\n",
    "hiddenStates = [0]*13\n",
    "flag = True\n",
    "for i in range(0, num_rows//10000 +1):\n",
    "    print(i)\n",
    "    st = i*10000\n",
    "    if(i==num_rows//10000):\n",
    "        end = num_rows\n",
    "    else:\n",
    "        end = (i+1)*10000\n",
    "    tokenised_dataset = tokenizer(dataset['train'][st:end], padding=True, return_tensors='pt')\n",
    "    input_ids = tokenised_dataset['input_ids']\n",
    "    token_type_ids = tokenised_dataset['token_type_ids']\n",
    "    attention_masks = tokenised_dataset['attention_mask']\n",
    "    labels = torch.tensor(dataset['train']['label'][st:end])\n",
    "  \n",
    "    \n",
    "    batch_size = 16 \n",
    "    train_data = TensorDataset(input_ids, token_type_ids, attention_masks, labels)\n",
    "    train_sampler = SequentialSampler(train_data)\n",
    "    train_dataloader = DataLoader(train_data, sampler=train_sampler, batch_size=batch_size)\n",
    "    \n",
    "    hS = getCLSHiddenStates(fineTunedModel, train_dataloader)\n",
    "    if flag==True:\n",
    "        for j in range(13):\n",
    "            hiddenStates[j] = hS[j]\n",
    "        flag = False\n",
    "    else:\n",
    "        for j in range(13):\n",
    "            hiddenStates[j] = torch.cat((hiddenStates[j], hS[j]), dim = 0)\n",
    "\n",
    "fineTunedCLSHiddenStatesTrain = torch.stack(hiddenStates, dim = 0)\n",
    "#torch.save(fineTunedCLSHiddenStatesTrain, 'fineTunedCLSHiddenStatesTrain_sst2.pt')\n",
    "fineTunedCLSHiddenStatesTrain.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "99c293a0",
   "metadata": {},
   "outputs": [
    {
     "ename": "AttributeError",
     "evalue": "'list' object has no attribute 'shape'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mAttributeError\u001b[0m                            Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[20], line 3\u001b[0m\n\u001b[1;32m      1\u001b[0m fineTunedCLSHiddenStatesTrain \u001b[38;5;241m=\u001b[39m hiddenStates\n\u001b[1;32m      2\u001b[0m \u001b[38;5;66;03m#torch.save(fineTunedCLSHiddenStatesTrain, 'fineTunedCLSHiddenStatesTrain_qqp.pt')\u001b[39;00m\n\u001b[0;32m----> 3\u001b[0m \u001b[43mfineTunedCLSHiddenStatesTrain\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mshape\u001b[49m\n",
      "\u001b[0;31mAttributeError\u001b[0m: 'list' object has no attribute 'shape'"
     ]
    }
   ],
   "source": [
    "fineTunedCLSHiddenStatesTrain = hiddenStates\n",
    "#torch.save(fineTunedCLSHiddenStatesTrain, 'fineTunedCLSHiddenStatesTrain_qqp.pt')\n",
    "fineTunedCLSHiddenStatesTrain.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "b57d2185",
   "metadata": {},
   "outputs": [
    {
     "ename": "ValueError",
     "evalue": "You should supply an encoding or a list of encodings to this method that includes input_ids, but you provided ['sentence', 'label', 'idx']",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mValueError\u001b[0m                                Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[21], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m hiddenStates \u001b[38;5;241m=\u001b[39m \u001b[43mgetCLSHiddenStates\u001b[49m\u001b[43m(\u001b[49m\u001b[43mpreTrainedModel\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mtest_dataloader\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m      2\u001b[0m preTrainedCLSHiddenStatesTest \u001b[38;5;241m=\u001b[39m hiddenStates\n\u001b[1;32m      3\u001b[0m \u001b[38;5;66;03m#torch.save(preTrainedCLSHiddenStatesTest, 'preTrainedCLSHiddenStatesTest_sst2.pt')\u001b[39;00m\n",
      "Cell \u001b[0;32mIn[15], line 6\u001b[0m, in \u001b[0;36mgetCLSHiddenStates\u001b[0;34m(model, prediction_dataloader)\u001b[0m\n\u001b[1;32m      3\u001b[0m totalHiddenStates \u001b[38;5;241m=\u001b[39m [\u001b[38;5;241m0\u001b[39m]\u001b[38;5;241m*\u001b[39m\u001b[38;5;241m13\u001b[39m\n\u001b[1;32m      4\u001b[0m flag \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;01mTrue\u001b[39;00m\n\u001b[0;32m----> 6\u001b[0m \u001b[43m\u001b[49m\u001b[38;5;28;43;01mfor\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[43mbatch\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;129;43;01min\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[43mprediction_dataloader\u001b[49m\u001b[43m:\u001b[49m\n\u001b[1;32m      7\u001b[0m \u001b[43m    \u001b[49m\u001b[38;5;66;43;03m# Add batch to GPU\u001b[39;49;00m\n\u001b[1;32m      8\u001b[0m \u001b[43m    \u001b[49m\u001b[43mbatch\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43m \u001b[49m\u001b[38;5;28;43mtuple\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43mt\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mto\u001b[49m\u001b[43m(\u001b[49m\u001b[43mdevice\u001b[49m\u001b[43m)\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43;01mfor\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[43mt\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;129;43;01min\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[43mbatch\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     10\u001b[0m \u001b[43m    \u001b[49m\u001b[38;5;66;43;03m# Unpack the inputs from our dataloader\u001b[39;49;00m\n",
      "File \u001b[0;32m~/.pyenv/versions/3.11.7/lib/python3.11/site-packages/torch/utils/data/dataloader.py:633\u001b[0m, in \u001b[0;36m_BaseDataLoaderIter.__next__\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    630\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_sampler_iter \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[1;32m    631\u001b[0m     \u001b[38;5;66;03m# TODO(https://github.com/pytorch/pytorch/issues/76750)\u001b[39;00m\n\u001b[1;32m    632\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_reset()  \u001b[38;5;66;03m# type: ignore[call-arg]\u001b[39;00m\n\u001b[0;32m--> 633\u001b[0m data \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_next_data\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    634\u001b[0m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_num_yielded \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m \u001b[38;5;241m1\u001b[39m\n\u001b[1;32m    635\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_dataset_kind \u001b[38;5;241m==\u001b[39m _DatasetKind\u001b[38;5;241m.\u001b[39mIterable \u001b[38;5;129;01mand\u001b[39;00m \\\n\u001b[1;32m    636\u001b[0m         \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_IterableDataset_len_called \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m \u001b[38;5;129;01mand\u001b[39;00m \\\n\u001b[1;32m    637\u001b[0m         \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_num_yielded \u001b[38;5;241m>\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_IterableDataset_len_called:\n",
      "File \u001b[0;32m~/.pyenv/versions/3.11.7/lib/python3.11/site-packages/torch/utils/data/dataloader.py:677\u001b[0m, in \u001b[0;36m_SingleProcessDataLoaderIter._next_data\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    675\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21m_next_data\u001b[39m(\u001b[38;5;28mself\u001b[39m):\n\u001b[1;32m    676\u001b[0m     index \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_next_index()  \u001b[38;5;66;03m# may raise StopIteration\u001b[39;00m\n\u001b[0;32m--> 677\u001b[0m     data \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_dataset_fetcher\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mfetch\u001b[49m\u001b[43m(\u001b[49m\u001b[43mindex\u001b[49m\u001b[43m)\u001b[49m  \u001b[38;5;66;03m# may raise StopIteration\u001b[39;00m\n\u001b[1;32m    678\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_pin_memory:\n\u001b[1;32m    679\u001b[0m         data \u001b[38;5;241m=\u001b[39m _utils\u001b[38;5;241m.\u001b[39mpin_memory\u001b[38;5;241m.\u001b[39mpin_memory(data, \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_pin_memory_device)\n",
      "File \u001b[0;32m~/.pyenv/versions/3.11.7/lib/python3.11/site-packages/torch/utils/data/_utils/fetch.py:54\u001b[0m, in \u001b[0;36m_MapDatasetFetcher.fetch\u001b[0;34m(self, possibly_batched_index)\u001b[0m\n\u001b[1;32m     52\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m     53\u001b[0m     data \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdataset[possibly_batched_index]\n\u001b[0;32m---> 54\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mcollate_fn\u001b[49m\u001b[43m(\u001b[49m\u001b[43mdata\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/.pyenv/versions/3.11.7/lib/python3.11/site-packages/transformers/data/data_collator.py:271\u001b[0m, in \u001b[0;36mDataCollatorWithPadding.__call__\u001b[0;34m(self, features)\u001b[0m\n\u001b[1;32m    270\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21m__call__\u001b[39m(\u001b[38;5;28mself\u001b[39m, features: List[Dict[\u001b[38;5;28mstr\u001b[39m, Any]]) \u001b[38;5;241m-\u001b[39m\u001b[38;5;241m>\u001b[39m Dict[\u001b[38;5;28mstr\u001b[39m, Any]:\n\u001b[0;32m--> 271\u001b[0m     batch \u001b[38;5;241m=\u001b[39m \u001b[43mpad_without_fast_tokenizer_warning\u001b[49m\u001b[43m(\u001b[49m\n\u001b[1;32m    272\u001b[0m \u001b[43m        \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mtokenizer\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    273\u001b[0m \u001b[43m        \u001b[49m\u001b[43mfeatures\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    274\u001b[0m \u001b[43m        \u001b[49m\u001b[43mpadding\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mpadding\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    275\u001b[0m \u001b[43m        \u001b[49m\u001b[43mmax_length\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mmax_length\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    276\u001b[0m \u001b[43m        \u001b[49m\u001b[43mpad_to_multiple_of\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mpad_to_multiple_of\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    277\u001b[0m \u001b[43m        \u001b[49m\u001b[43mreturn_tensors\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mreturn_tensors\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    278\u001b[0m \u001b[43m    \u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    279\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mlabel\u001b[39m\u001b[38;5;124m\"\u001b[39m \u001b[38;5;129;01min\u001b[39;00m batch:\n\u001b[1;32m    280\u001b[0m         batch[\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mlabels\u001b[39m\u001b[38;5;124m\"\u001b[39m] \u001b[38;5;241m=\u001b[39m batch[\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mlabel\u001b[39m\u001b[38;5;124m\"\u001b[39m]\n",
      "File \u001b[0;32m~/.pyenv/versions/3.11.7/lib/python3.11/site-packages/transformers/data/data_collator.py:66\u001b[0m, in \u001b[0;36mpad_without_fast_tokenizer_warning\u001b[0;34m(tokenizer, *pad_args, **pad_kwargs)\u001b[0m\n\u001b[1;32m     63\u001b[0m tokenizer\u001b[38;5;241m.\u001b[39mdeprecation_warnings[\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mAsking-to-pad-a-fast-tokenizer\u001b[39m\u001b[38;5;124m\"\u001b[39m] \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;01mTrue\u001b[39;00m\n\u001b[1;32m     65\u001b[0m \u001b[38;5;28;01mtry\u001b[39;00m:\n\u001b[0;32m---> 66\u001b[0m     padded \u001b[38;5;241m=\u001b[39m \u001b[43mtokenizer\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mpad\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mpad_args\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mpad_kwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     67\u001b[0m \u001b[38;5;28;01mfinally\u001b[39;00m:\n\u001b[1;32m     68\u001b[0m     \u001b[38;5;66;03m# Restore the state of the warning.\u001b[39;00m\n\u001b[1;32m     69\u001b[0m     tokenizer\u001b[38;5;241m.\u001b[39mdeprecation_warnings[\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mAsking-to-pad-a-fast-tokenizer\u001b[39m\u001b[38;5;124m\"\u001b[39m] \u001b[38;5;241m=\u001b[39m warning_state\n",
      "File \u001b[0;32m~/.pyenv/versions/3.11.7/lib/python3.11/site-packages/transformers/tokenization_utils_base.py:3297\u001b[0m, in \u001b[0;36mPreTrainedTokenizerBase.pad\u001b[0;34m(self, encoded_inputs, padding, max_length, pad_to_multiple_of, padding_side, return_attention_mask, return_tensors, verbose)\u001b[0m\n\u001b[1;32m   3295\u001b[0m \u001b[38;5;66;03m# The model's main input name, usually `input_ids`, has been passed for padding\u001b[39;00m\n\u001b[1;32m   3296\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mmodel_input_names[\u001b[38;5;241m0\u001b[39m] \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;129;01min\u001b[39;00m encoded_inputs:\n\u001b[0;32m-> 3297\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mValueError\u001b[39;00m(\n\u001b[1;32m   3298\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mYou should supply an encoding or a list of encodings to this method \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m   3299\u001b[0m         \u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mthat includes \u001b[39m\u001b[38;5;132;01m{\u001b[39;00m\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mmodel_input_names[\u001b[38;5;241m0\u001b[39m]\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m, but you provided \u001b[39m\u001b[38;5;132;01m{\u001b[39;00m\u001b[38;5;28mlist\u001b[39m(encoded_inputs\u001b[38;5;241m.\u001b[39mkeys())\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m   3300\u001b[0m     )\n\u001b[1;32m   3302\u001b[0m required_input \u001b[38;5;241m=\u001b[39m encoded_inputs[\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mmodel_input_names[\u001b[38;5;241m0\u001b[39m]]\n\u001b[1;32m   3304\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m required_input \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m \u001b[38;5;129;01mor\u001b[39;00m (\u001b[38;5;28misinstance\u001b[39m(required_input, Sized) \u001b[38;5;129;01mand\u001b[39;00m \u001b[38;5;28mlen\u001b[39m(required_input) \u001b[38;5;241m==\u001b[39m \u001b[38;5;241m0\u001b[39m):\n",
      "\u001b[0;31mValueError\u001b[0m: You should supply an encoding or a list of encodings to this method that includes input_ids, but you provided ['sentence', 'label', 'idx']"
     ]
    }
   ],
   "source": [
    "hiddenStates = getCLSHiddenStates(preTrainedModel, test_dataloader)\n",
    "preTrainedCLSHiddenStatesTest = hiddenStates\n",
    "#torch.save(preTrainedCLSHiddenStatesTest, 'preTrainedCLSHiddenStatesTest_sst2.pt')\n",
    "preTrainedCLSHiddenStatesTest.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "b1b939bb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([1821, 768])"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "hiddenStates = getCLSHiddenStates(fineTunedModel, test_dataloader)\n",
    "fineTunedCLSHiddenStatesTest = hiddenStates\n",
    "#torch.save(fineTunedCLSHiddenStatesTest_noNouns, 'fineTunedCLSHiddenStatesTest_sst2.pt')\n",
    "fineTunedCLSHiddenStatesTest.shape"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "55af5b38",
   "metadata": {},
   "source": [
    "### Forming logistic regressions at each layer to find the layer-wise accuracy for pre-trained and fine-tuned model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "f0432e9f",
   "metadata": {},
   "outputs": [],
   "source": [
    "sc_x = StandardScaler()\n",
    "for i in range(13):\n",
    "    xtrain = sc_x.fit_transform(preTrainedCLSHiddenStatesTrain[i])\n",
    "    xtest = sc_x.fit_transform(preTrainedCLSHiddenStatesTest[i])\n",
    "    logreg = LogisticRegression(max_iter=1000)\n",
    "    logreg.fit(xtrain, dataset['train']['label']) \n",
    "    \n",
    "    preTrain_pred=logreg.predict(xtest)\n",
    "    filename = 'p{0}/SST-2.tsv'.format(i)\n",
    "    result = pd.DataFrame(preTrain_pred, columns=['prediction'])\n",
    "    result.insert(0, 'index', range(0, len(result)))\n",
    "    result.to_csv(filename, sep='\\t', index=False)\n",
    "    \n",
    "    \n",
    "    xtrain = sc_x.fit_transform(fineTunedCLSHiddenStatesTrain[i]) \n",
    "    xtest = sc_x.fit_transform(fineTunedCLSHiddenStatesTest[i])\n",
    "    logreg = LogisticRegression(max_iter=1000)\n",
    "    logreg.fit(xtrain, dataset['train']['label'])\n",
    "    \n",
    "    fineTuned_pred=logreg.predict(xtest)\n",
    "    filename = 'f{0}/SST-2.tsv'.format(i)\n",
    "    result = pd.DataFrame(fineTuned_pred, columns=['prediction'])\n",
    "    result.insert(0, 'index', range(0, len(result)))\n",
    "    result.to_csv(filename, sep='\\t', index=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "70ee631c",
   "metadata": {},
   "source": [
    "### Finding the accuracy of the final layer using the classifier of the fine-tuned model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "48eed55a",
   "metadata": {},
   "outputs": [],
   "source": [
    "params = list(fineTunedModel.named_parameters())\n",
    "dense = torch.nn.Linear(768, 768,device=device, bias = True)\n",
    "activation = torch.nn.Tanh()\n",
    "dropout = torch.nn.Dropout(p=0.1)\n",
    "classifier = torch.nn.Linear(in_features=768, out_features=2,  bias = True)\n",
    "with torch.no_grad():\n",
    "    dense.weight = params[-4][1]\n",
    "    dense.bias = params[-3][1]\n",
    "    classifier.weight = params[-2][1]\n",
    "    classifier.bias = params[-1][1]\n",
    "\n",
    "pooled_output = activation(dense(fineTunedCLSHiddenStatesTest[-1,:,:].to('cuda:0')))\n",
    "dropout_op = dropout(pooled_output)\n",
    "logits = classifier(dropout_op)\n",
    "predictions = torch.argmax(logits, dim = 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "bdd5b8f8",
   "metadata": {},
   "outputs": [],
   "source": [
    "predictions = predictions.to('cpu')\n",
    "filename = 'SST-2.tsv'\n",
    "result = pd.DataFrame(predictions, columns=['prediction'])\n",
    "result.insert(0, 'index', range(0, len(result)))\n",
    "result.to_csv(filename, sep='\\t', index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8facb3c4",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "2d714566",
   "metadata": {},
   "source": [
    "### Obtaining hidden states to find the CKA metric between the pre-trained and fine-tuned model on test dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "00aabcba",
   "metadata": {},
   "outputs": [],
   "source": [
    "def getHiddenStates(model, prediction_dataloader):\n",
    "    model.eval()\n",
    "    totalHiddenStates = [0]*13\n",
    "    flag = True\n",
    "    for batch in prediction_dataloader:\n",
    "        # Add batch to GPU\n",
    "        batch = tuple(t.to(device) for t in batch)\n",
    "  \n",
    "        # Unpack the inputs from our dataloader\n",
    "        b_input_ids, b_token_type_ids, b_input_mask, b_labels = batch\n",
    "  \n",
    "        with torch.no_grad():\n",
    "            result = model(b_input_ids,\n",
    "                           token_type_ids=None,\n",
    "                           attention_mask=b_input_mask,\n",
    "                           output_hidden_states = True,\n",
    "                           return_dict=True)\n",
    "            \n",
    "        hidden_states = result.hidden_states\n",
    "        if flag == True:\n",
    "            for i in range(len(hidden_states)):\n",
    "                totalHiddenStates[i] = hidden_states[i].to(\"cpu\").mean(dim = 1)\n",
    "            flag = False\n",
    "        else:\n",
    "            for i in range(len(hidden_states)):\n",
    "                temp = hidden_states[i].to(\"cpu\").mean(dim = 1)\n",
    "                totalHiddenStates[i] = torch.cat((totalHiddenStates[i], temp), 0)   \n",
    "    return totalHiddenStates     "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "455892b6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([13, 1821, 768])"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "hiddenStates = getHiddenStates(preTrainedModel, test_dataloader)\n",
    "preTrainedHiddenStates = torch.stack(hiddenStates, dim = 0)\n",
    "#torch.save(preTrainedHiddenStates, 'preTrainedHiddenStates_sst2.pt')\n",
    "preTrainedHiddenStates.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "45813bfc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([13, 1821, 768])"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "hiddenStates = getHiddenStates(fineTunedModel, test_dataloader)\n",
    "fineTunedHiddenStates = torch.stack(hiddenStates, dim = 0)\n",
    "#torch.save(fineTunedHiddenStates, 'fineTunedHiddenStates_sst2.pt')\n",
    "fineTunedHiddenStates.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "34e1923f",
   "metadata": {},
   "outputs": [],
   "source": [
    "from CKA import CKA, CudaCKA\n",
    "cuda_cka = CudaCKA(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "e4b0ef48",
   "metadata": {},
   "outputs": [],
   "source": [
    "cka_matrix = torch.empty((13, 13))\n",
    "for i in range(13):\n",
    "    for j in range(13):\n",
    "        X = preTrainedHiddenStates[i].to(device)\n",
    "        Y = fineTunedHiddenStates[j].to(device)\n",
    "        cka_matrix[i][j] = cuda_cka.linear_CKA(X, Y)\n",
    "#torch.save(cka_matrix, 'sst2-ckaMatrix.pt')\n",
    "cka_matrix = cka_matrix.numpy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "18d26018",
   "metadata": {
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(10, 8))\n",
    "im = ax.imshow(cka_matrix, cmap=\"inferno\", vmin=0.0, vmax=1.0)\n",
    "\n",
    "plt.xticks(np.arange(0,13), fontsize = 14)\n",
    "plt.yticks(np.arange(0,13), fontsize = 14)\n",
    "\n",
    "cka_matrix = np.round(cka_matrix, 2)\n",
    "for x in range(13):\n",
    "    for y in range(13):\n",
    "        plt.annotate(str(cka_matrix[x][y]), xy=(y, x), horizontalalignment='center', verticalalignment='center', fontsize=13)\n",
    "\n",
    "plt.ylabel('Pre-trained BERT', fontsize = 17)\n",
    "plt.xlabel('Fine-tuned BERT', fontsize = 17)\n",
    "\n",
    "#fig.colorbar(im)\n",
    "\n",
    "plt.tight_layout()\n",
    "\n",
    "plt.show()\n",
    "\n",
    "#plt.savefig('SST-2_preTrained_fineTuned.pdf',  bbox_inches='tight')\n",
    "#plt.savefig('SST-2_preTrained_fineTuned.jpg',  bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ee566e3c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "b98ced51",
   "metadata": {},
   "source": [
    "### STIR"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "4bf074e0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([13, 1821, 768]) torch.Size([13, 1821, 768])\n"
     ]
    }
   ],
   "source": [
    "preTrainedHiddenStates = torch.load('./preTrainedHiddenStates_sst2.pt').to(device)\n",
    "fineTunedHiddenStates  = torch.load('./fineTunedHiddenStates_sst2.pt').to(device)\n",
    "print(preTrainedHiddenStates.shape,fineTunedHiddenStates.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "ea71269f",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "distinm1 = []\n",
    "distinm2 = []\n",
    "for i in range(13):\n",
    "    distinm1.append(torch.cdist(preTrainedHiddenStates[i], preTrainedHiddenStates[i]))\n",
    "    distinm2.append(torch.cdist(fineTunedHiddenStates[i], fineTunedHiddenStates[i]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "33af4b74",
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(13):\n",
    "    for j in range(distinm1[0].shape[0]):\n",
    "        distinm1[i][j][j] = 100000.0\n",
    "        distinm2[i][j][j] = 100000.0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "a4f1d8fb",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_rows = preTrainedHiddenStates.shape[1]\n",
    "minDistIndForm1 = []\n",
    "for i in range(13):\n",
    "    temp = []\n",
    "    for j in range(num_rows):\n",
    "        temp.append(torch.argmin(distinm1[i][j]))\n",
    "    minDistIndForm1.append(temp)\n",
    "    \n",
    "minDistIndForm2 = []\n",
    "for i in range(13):\n",
    "    temp = []\n",
    "    for j in range(num_rows):\n",
    "        temp.append(torch.argmin(distinm2[i][j]))\n",
    "    minDistIndForm2.append(temp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "9c4ba400",
   "metadata": {},
   "outputs": [],
   "source": [
    "from CKA import CKA, CudaCKA\n",
    "cuda_cka = CudaCKA(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "8eeb44d5",
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "def calculate(noOfSamples, noOfTimes):\n",
    "    STIRm2m1 = []\n",
    "    STIRm1m2 = []\n",
    "    CKA = []\n",
    "    for i in range(13):\n",
    "        stirm2m1 = 0\n",
    "        stirm1m2 = 0\n",
    "        cka = 0\n",
    "        for j in range(noOfTimes):\n",
    "            num_list = random.sample(range(0, num_rows), noOfSamples)\n",
    "            X = []\n",
    "            X_ = []\n",
    "            Y = []\n",
    "            Y_ = []\n",
    "            for k in range(len(num_list)):\n",
    "                X.append(fineTunedHiddenStates[i][num_list[k]])\n",
    "                X_.append(fineTunedHiddenStates[i][minDistIndForm1[i][num_list[k]]])\n",
    "                Y.append(preTrainedHiddenStates[i][num_list[k]])\n",
    "                Y_.append(preTrainedHiddenStates[i][minDistIndForm2[i][num_list[k]]])\n",
    "                \n",
    "            X = torch.stack(X, dim = 0)\n",
    "            X_ = torch.stack(X_, dim = 0)\n",
    "            Y = torch.stack(Y, dim = 0)\n",
    "            Y_ = torch.stack(Y_, dim = 0)\n",
    "            \n",
    "            stirm2m1 = stirm2m1 + cuda_cka.linear_CKA(X, X_)\n",
    "            stirm1m2 = stirm1m2 + cuda_cka.linear_CKA(Y, Y_)\n",
    "            cka = cka + cuda_cka.linear_CKA(Y, X)\n",
    "        \n",
    "        STIRm2m1.append(stirm2m1/noOfTimes)\n",
    "        STIRm1m2.append(stirm1m2/noOfTimes)\n",
    "        CKA.append(cka/noOfTimes)\n",
    "    return STIRm2m1, STIRm1m2, CKA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "2e9c35a9",
   "metadata": {},
   "outputs": [],
   "source": [
    "STIRm2m1, STIRm1m2, CKA = calculate(num_rows//2, 20)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "02848bf7",
   "metadata": {},
   "outputs": [],
   "source": [
    "STIRm2m1 = torch.stack(STIRm2m1, dim = 0)\n",
    "STIRm1m2 = torch.stack(STIRm1m2,dim = 0)\n",
    "CKA = torch.stack(CKA, dim = 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "a1db5a05",
   "metadata": {},
   "outputs": [],
   "source": [
    "STIRm2m1 = STIRm2m1.to(\"cpu\")\n",
    "STIRm2m1 = STIRm2m1.numpy()\n",
    "STIRm1m2 = STIRm1m2.to(\"cpu\")\n",
    "STIRm1m2 = STIRm1m2.numpy()\n",
    "CKA = CKA .to(\"cpu\")\n",
    "CKA = CKA .numpy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "df1507d7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "STIRm2m1: [0.99338883 0.975769   0.9307553  0.9191861  0.89499635 0.8257434\n",
      " 0.7566971  0.68214387 0.5824626  0.36684075 0.28045017 0.24026899\n",
      " 0.24635683]\n",
      "STIRm1m2: [0.99335617 0.97374135 0.929573   0.916683   0.88047427 0.7792632\n",
      " 0.7221131  0.6934799  0.6211273  0.54723984 0.4351077  0.39416084\n",
      " 0.31508932]\n",
      "CKA: [0.99999875 0.9987583  0.9917032  0.9903614  0.97698706 0.9328828\n",
      " 0.9046883  0.8712171  0.8088601  0.4858152  0.24788252 0.20091882\n",
      " 0.1536989 ]\n"
     ]
    }
   ],
   "source": [
    "print('STIRm2m1:', STIRm2m1)\n",
    "print('STIRm1m2:', STIRm1m2)\n",
    "print('CKA:', CKA)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "87f25638",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA2kAAAK8CAYAAAB1DPeOAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAA9hAAAPYQGoP6dpAAEAAElEQVR4nOzdZ3RU1duG8eukQBJKIIQeQu8dpFdRQEVAOkgVEOwd66uCih3/ig0UkCJIBwsoIL33Kr33EgKhJISUeT9sEggEMpPMZFLu31pnZTJzyjMOYO7sfZ5t2Ww2GyIiIiIiIpImeLi7ABEREREREblJIU1ERERERCQNUUgTERERERFJQxTSRERERERE0hCFNBERERERkTREIU1ERERERCQNUUgTERERERFJQxTSRERERERE0hAvdxeQ0cXGxnLy5Ely5MiBZVnuLkdERERERNzEZrNx+fJlChUqhIfH3cfLFNJc7OTJkxQpUsTdZYiIiIiISBpx7NgxgoKC7vq6QpqL5ciRAzAfRM6cOd1aS1RUFPPnz6dFixZ4e3u7tRZxDn2mGZM+14xHn2nGpM8149FnmvGktc/00qVLFClSJD4j3I1CmovFTXHMmTNnmghpfn5+5MyZM038IZWU02eaMelzzXj0mWZM+lwzHn2mGU9a/UyTug1KjUNERERERETSEIU0ERERERGRNEQhTUREREREJA1RSBMREREREUlDFNJERERERETSEIU0ERERERGRNEQhTUREREREJA1RSBMREREREUlDFNJERERERETSEIU0ERERERGRNEQhTUREREREJA1RSBMREREREUlDFNJERERERETSEIU0ERERERGRNEQhTUREREREJA1RSBMREREREUlDFNJERERERETSkHQX0k6fPs3EiRN55ZVXaNq0KTlz5sSyLCzLSvG5L126xNtvv0358uXx9fUlICCAZs2aMXXqVCdUnjbkOHzY3SWIiIiIiMg9eLm7AEdNnjyZl19+2ennPX78OI0aNeLw4cN4e3tTsWJFLl68yOLFi1m8eDGLFi1ixIgRTr9uqgkLw/Opp2g2eTKxa9fCjz+Cv7+7q3Kt7duhcmV3VyEiIiIi4pB0N5KWM2dOmjVrxmuvvcZvv/3G+PHjnXLeLl26cPjwYapWrcqBAwfYvHkzhw4dYtq0aXh7ezNy5EjGjBnjlGululWr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duzYwYYNG9i+fTt58uSJH02LC3yOypYtG61atQJg5Mg7px5ERkYyduxYALp06WL3eTt27EiWLFmIjo5mzJgxd7x++fLl+MWxW8QtFCkiIiIZmmVZvFrv1WQffy36GiHhIQ4d06ABrFsHlSvD6dPQpAlMmuTghUuVgmLFICoKbvzyWkTSF7tD2oULF+IfFy5cOMFra9asiX8cN4r2xBNPxE9HLFGiBD179oy/j8zeRaYT8/777+Pl5cXKlSt5880349caCA8Pp3///hw6dAh/f39ei1st8oavv/6aYsWK0bBhwzvOWaBAAV588UUA3n77bZYtWxb/WlhYGH369OHcuXNky5aNV19N/j/WIiIikr54ebqmBf+9FCsGK1dC69YQGQndu8P//R/Extp5AssyUx7BTHkUkXTHoZAWN53x9nnX69evv2P/hx9+OMH3t94fdjXZd8NCpUqVGDlyJJ6ennz22WcUKlSI++67j4IFC/Lrr7/i6+vLtGnTCAwMTHDcxYsXOXLkCMePH0/0vEOHDuXRRx8lNDSUJk2aUKZMGWrVqkXBggWZOXMmfn5+TJ48meLFiye7dhERERF75MgBs2ZBXNPpoUOhUycHGorETXlU8xCRdClZDV5vX0j61pEnMCHu9u6PWbJkSfRxcvTt25dVq1bRoUMHPD092b59Ozly5KB3795s2bKF5s2bO3xOb29v/vjjD3755RcaNWrEuXPn2LZtG/nz5+fJJ59k69atPProoymqW0RERMRenp7w2Wcwdqxp2jhzJjRsCMeO2XFws2amj//u3XCXtWVFJO2yO6TdOjL1119/xT8+fvw4a9eujb/fDG42+LjVuXPn4h/7+/snu+A4tWvXZvr06Zw+fZrIyEiOHz/O2LFj77oG2+DBg7HZbBw+fPiu57Qsiz59+rBs2TIuXLhAZGQkhw4d4qeffqJUqVIprllERETEUb17w6JFkDcvbNkCtWrB2rVJHJQr182OIwsWuLhCEXE2u0NalSpVsNls2Gw2VqxYQbdu3fj+++957LHHErSltyyLZs2a3XF8XAt/y7IIDravy5GIiIiImIYi69ebhiJnztjZUCRuyqPuSxNJd+wOaXFT/eJGzKZOncoLL7zA5s2b71gb7fbOijabjaVLl8bvV7Zs2ZTWLSIiIpKpFC1qGoq0aXOzocg779yjoUhc85B//4WYmFSrU0RSzu6Q1rNnT4KCgoCbQS1ui2NZFs2bN6datWoJjl20aBEnT56M/76Owwt+iIiIiEhcQ5G4Nao//hg6doQrVxLZuVYt8PeHCxdg48ZUrVNEUsbukJYtWzYmT55Mzpw549vsx21gRssKFizIzz//fMex33//fYJ71hKbDikiIiIiSfPwgE8/hXHjTEORWbOgUaNEGop4ecGDD5rHmvIokq441N2xfv36bNq0iR49esSHNZvNRvbs2enVqxfr1q2jSJEiCY7ZtWsXCxcuxM/Pj2zZslGpUiVNdxQRERFJoV69YPFiyJfvZkORW5auNeKmPKoVv0i64vAKjcWLF2f8+PHYbDZCQ0OJjo4mb968eHgknvfKly9PWFhYigsVERERkYTq14d168x9atu2QdOmMHq0uV8NgLhliVavhkuXIGdOd5UqIg5I1jppYO4/y5MnD/nz579rQBMRERER14prKNK2rWko0qPHLQ1FiheH0qVN45BFi9xdqojYye50VbZsWd544w1WrlyZoFmIiIiIiLhX9uxmses33zTfJ2goEteKX1MeRdINu0Pavn37+PLLL2ncuDEFChSgX79+/PHHH1y7ds2V9YmIiIi4TaBfID5ePsk61sfLh0C/QCdXdHceHvDJJzB+/M2GIg0bwrnqui9NJL2x+540Hx+f+EB27tw5xo4dy9ixY/Hx8aF58+a0bduW1q1bExiYev8YiYiIiLhSsH8we57bQ0h4yB2vRUdHs2LFCirUrEDrya2JtkXza7tfKZ+3PGACXrB/cGqXTM+eULIktGsHW7dC3Tebss/TC48DB+DAAfOiiKRpdoe00NBQFixYwO+//85ff/3F2bNnAYiIiODPP//kzz//xMPDg7p16/LYY4/Rpk0bSpcu7bLCRURERFJDsH9womErKiqKU36neKD4A3Sq2InfdvzG4sOL6V6leyJnSV0JG4rkYLnVgCYsNaNpTz/t7vJEJAl2T3f08fGhdevWjBo1ilOnTrFixQoGDRpEmTJl4lvxx8TEsGrVKl5//XXKlStHxYoVefvtt1m7dq0r34OIiIiIWz1T6xkAJm2fxMVrF91bzA1xDUUeewzm2cyUx/++nm8aiohImpastoyWZVG/fn0+++wzdu/eza5du/j000+pV69e/KLVNpuN3bt389lnn1G/fn0KFSrEwIEDmTt3Ltev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",
      "text/plain": [
       "<Figure size 1000x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "xs = np.arange(13)\n",
    "plt.rcParams[\"figure.figsize\"] = [10,8]\n",
    "\n",
    "series = np.array(STIRm2m1)\n",
    "smask = np.isfinite(series)\n",
    "plt.plot(xs[smask], series[smask], linestyle='-', marker='s', markersize=10, color='green')\n",
    "\n",
    "series = np.array(STIRm1m2)\n",
    "smask = np.isfinite(series)\n",
    "plt.plot(xs[smask], series[smask], linestyle='-', marker='o', markersize=10, color='blue')\n",
    "\n",
    "series = np.array(CKA)\n",
    "smask = np.isfinite(series)\n",
    "plt.plot(xs[smask], series[smask], linestyle='-', marker='p', markersize=10, color='red')\n",
    "\n",
    "plt.legend(['STIR(Fine-tuned|Pre-trained)', 'STIR(Pre-trained|Fine-tuned)', 'CKA(Pre-trained, Fine-tuned)'], fontsize=18)\n",
    "plt.xlabel('Layer Depth', fontsize = 19, fontweight = 'bold')\n",
    "plt.ylabel('CKA/STIR', fontsize = 19, fontweight ='bold')\n",
    "\n",
    "plt.grid(True)\n",
    "plt.xticks(fontsize=17)\n",
    "plt.yticks(fontsize=17)\n",
    "#plt.tight_layout()\n",
    "#plt.show()\n",
    "plt.savefig('SST2 STIR.pdf', bbox_inches='tight')\n",
    "plt.savefig('SST2 STIR.jpg', bbox_inches='tight')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "07a51b9f",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.11.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
