{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "from tqdm import tqdm\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "import torch\n",
    "import torch.nn.functional as F\n",
    "from torch.utils.data import Dataset, DataLoader\n",
    "\n",
    "from sklearn.metrics import accuracy_score, precision_score, recall_score, f1_score, confusion_matrix, classification_report\n",
    "import seaborn as sns\n",
    "\n",
    "from spectral_conv import ConvNet"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "ename": "FileNotFoundError",
     "evalue": "[Errno 2] No such file or directory: '../ECG-Spectral/Spectral/three_class_conv/three_class_data.npy'",
     "output_type": "error",
     "traceback": [
      "\u001b[31m---------------------------------------------------------------------------\u001b[39m",
      "\u001b[31mFileNotFoundError\u001b[39m                         Traceback (most recent call last)",
      "\u001b[36mCell\u001b[39m\u001b[36m \u001b[39m\u001b[32mIn[14]\u001b[39m\u001b[32m, line 1\u001b[39m\n\u001b[32m----> \u001b[39m\u001b[32m1\u001b[39m data = \u001b[43mnp\u001b[49m\u001b[43m.\u001b[49m\u001b[43mload\u001b[49m\u001b[43m(\u001b[49m\u001b[33;43m\"\u001b[39;49m\u001b[33;43m../ECG-Spectral/Spectral/three_class_conv/three_class_data.npy\u001b[39;49m\u001b[33;43m\"\u001b[39;49m\u001b[43m)\u001b[49m\n\u001b[32m      2\u001b[39m labels = np.load(\u001b[33m\"\u001b[39m\u001b[33m../ECG-Spectral/Spectral/three_class_conv/three_class_labels.npy\u001b[39m\u001b[33m\"\u001b[39m)\n\u001b[32m      3\u001b[39m data.shape, labels.shape\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/miniforge3/envs/AD/lib/python3.12/site-packages/numpy/lib/_npyio_impl.py:454\u001b[39m, in \u001b[36mload\u001b[39m\u001b[34m(file, mmap_mode, allow_pickle, fix_imports, encoding, max_header_size)\u001b[39m\n\u001b[32m    452\u001b[39m     own_fid = \u001b[38;5;28;01mFalse\u001b[39;00m\n\u001b[32m    453\u001b[39m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[32m--> \u001b[39m\u001b[32m454\u001b[39m     fid = stack.enter_context(\u001b[38;5;28;43mopen\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43mos\u001b[49m\u001b[43m.\u001b[49m\u001b[43mfspath\u001b[49m\u001b[43m(\u001b[49m\u001b[43mfile\u001b[49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[33;43m\"\u001b[39;49m\u001b[33;43mrb\u001b[39;49m\u001b[33;43m\"\u001b[39;49m\u001b[43m)\u001b[49m)\n\u001b[32m    455\u001b[39m     own_fid = \u001b[38;5;28;01mTrue\u001b[39;00m\n\u001b[32m    457\u001b[39m \u001b[38;5;66;03m# Code to distinguish from NumPy binary files and pickles.\u001b[39;00m\n",
      "\u001b[31mFileNotFoundError\u001b[39m: [Errno 2] No such file or directory: '../ECG-Spectral/Spectral/three_class_conv/three_class_data.npy'"
     ]
    }
   ],
   "source": [
    "data = np.load(\"../ECG-Spectral/Spectral/three_class_conv/three_class_data.npy\")\n",
    "labels = np.load(\"../ECG-Spectral/Spectral/three_class_conv/three_class_labels.npy\")\n",
    "data.shape, labels.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saved 20107 files to ../ECG-Spectral/Spectral/three_class_conv/three_class_spectra\n"
     ]
    }
   ],
   "source": [
    "# Create the output directory\n",
    "output_dir = \"../ECG-Spectral/Spectral/three_class_conv/three_class_spectra\"\n",
    "os.makedirs(output_dir, exist_ok=True)\n",
    "\n",
    "# Loop through data and labels to save each instance individually\n",
    "for idx in range(len(data)):\n",
    "    filename = f\"three_class_file_{idx}_class_{labels[idx]}.npy\"\n",
    "    filepath = os.path.join(output_dir, filename)\n",
    "    np.save(filepath, data[idx])\n",
    "\n",
    "print(f\"Saved {len(data)} files to {output_dir}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "class ThreeClassData(Dataset):\n",
    "    def __init__(self, data_path):\n",
    "        self.data = []\n",
    "        self.labels = []\n",
    "\n",
    "        for file in os.listdir(data_path):\n",
    "            if file.endswith(\".npy\"):\n",
    "                self.data.append(torch.from_numpy(np.load(os.path.join(data_path, file))).unsqueeze(0))\n",
    "                self.labels.append(int(file.split(\".npy\")[0].rsplit(\"_\",1)[1]))\n",
    "\n",
    "        self.data = torch.stack(self.data).float()\n",
    "        self.labels = torch.tensor(self.labels).float()\n",
    "\n",
    "    def __len__(self):\n",
    "        return len(self.data)\n",
    "    \n",
    "    def __getitem__(self, idx):\n",
    "        return self.data[idx], self.labels[idx]\n",
    "    \n",
    "data_path = \"../ECG-Spectral/Spectral/three_class_conv/three_class_spectra\"\n",
    "dataset = ThreeClassData(data_path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "ConvNet(\n",
       "  (layer1): Sequential(\n",
       "    (0): Conv1d(1, 20, kernel_size=(7,), stride=(1,))\n",
       "    (1): BatchNorm1d(20, eps=1e-05, momentum=0.1, affine=True, track_running_stats=True)\n",
       "    (2): ReLU()\n",
       "    (3): MaxPool1d(kernel_size=7, stride=3, padding=0, dilation=1, ceil_mode=False)\n",
       "  )\n",
       "  (layer2): Sequential(\n",
       "    (0): Conv1d(20, 40, kernel_size=(5,), stride=(1,))\n",
       "    (1): BatchNorm1d(40, eps=1e-05, momentum=0.1, affine=True, track_running_stats=True)\n",
       "    (2): ReLU()\n",
       "    (3): MaxPool1d(kernel_size=5, stride=2, padding=0, dilation=1, ceil_mode=False)\n",
       "  )\n",
       "  (layer3): Sequential(\n",
       "    (0): Conv1d(40, 40, kernel_size=(3,), stride=(1,))\n",
       "    (1): BatchNorm1d(40, eps=1e-05, momentum=0.1, affine=True, track_running_stats=True)\n",
       "    (2): ReLU()\n",
       "    (3): MaxPool1d(kernel_size=3, stride=1, padding=0, dilation=1, ceil_mode=False)\n",
       "  )\n",
       "  (fc1): Linear(in_features=8640, out_features=60, bias=True)\n",
       "  (fc2): Linear(in_features=60, out_features=3, bias=True)\n",
       ")"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#Testing model performance on three class data\n",
    "dataloader = DataLoader(dataset,\n",
    "                        batch_size=10,\n",
    "                        shuffle=False)\n",
    "\n",
    "model = ConvNet()\n",
    "model.load_state_dict(torch.load(\"../ECG-Spectral/Spectral/three_class_conv/threeclass_combined_DNA_model.pt\"))\n",
    "model.eval()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Running model evaluation...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Evaluating:   0%|          | 0/2011 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Evaluating: 100%|██████████| 2011/2011 [00:02<00:00, 982.30it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "===================================================\n",
      "OVERALL PERFORMANCE METRICS\n",
      "==================================================\n",
      "Accuracy: 0.9948\n",
      "Precision (Macro): 0.9955\n",
      "Precision (Weighted): 0.9948\n",
      "Recall (Macro): 0.9956\n",
      "Recall (Weighted): 0.9948\n",
      "F1-Score (Macro): 0.9955\n",
      "F1-Score (Weighted): 0.9948\n",
      "===================================================\n",
      "PER-CLASS PERFORMANCE METRICS\n",
      "==================================================\n",
      "Class 0:\n",
      "  Precision: 0.9933\n",
      "  Recall: 0.9942\n",
      "  F1-Score: 0.9937\n",
      "Class 1:\n",
      "  Precision: 0.9940\n",
      "  Recall: 0.9930\n",
      "  F1-Score: 0.9935\n",
      "Class 2:\n",
      "  Precision: 0.9993\n",
      "  Recall: 0.9995\n",
      "  F1-Score: 0.9994\n",
      "===================================================\n",
      "DETAILED CLASSIFICATION REPORT\n",
      "==================================================\n",
      "              precision    recall  f1-score   support\n",
      "\n",
      "     Class 0       0.99      0.99      0.99      8070\n",
      "     Class 1       0.99      0.99      0.99      8037\n",
      "     Class 2       1.00      1.00      1.00      4000\n",
      "\n",
      "    accuracy                           0.99     20107\n",
      "   macro avg       1.00      1.00      1.00     20107\n",
      "weighted avg       0.99      0.99      0.99     20107\n",
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "# Comprehensive Model Evaluation\n",
    "def evaluate_model(model, dataloader, device='cuda:1'):\n",
    "    \"\"\"\n",
    "    Evaluate the model and calculate comprehensive performance metrics\n",
    "    \"\"\"\n",
    "    model.eval()\n",
    "    model.to(device)\n",
    "    all_predictions = []\n",
    "    all_labels = []\n",
    "    all_probabilities = []\n",
    "    \n",
    "    with torch.no_grad():\n",
    "        for batch_data, batch_labels in tqdm(dataloader, desc=\"Evaluating\"):\n",
    "            batch_data = batch_data.to(device)\n",
    "            batch_labels = batch_labels.to(device)\n",
    "            \n",
    "            # Forward pass\n",
    "            outputs = model(batch_data)\n",
    "            probabilities = F.softmax(outputs, dim=1)\n",
    "            predictions = torch.argmax(outputs, dim=1)\n",
    "            \n",
    "            # Store results\n",
    "            all_predictions.extend(predictions.cpu().numpy())\n",
    "            all_labels.extend(batch_labels.cpu().numpy())\n",
    "            all_probabilities.extend(probabilities.cpu().numpy())\n",
    "    return np.array(all_predictions), np.array(all_labels), np.array(all_probabilities)\n",
    "\n",
    "# Run evaluation\n",
    "print(\"Running model evaluation...\")\n",
    "predictions, true_labels, probabilities = evaluate_model(model, dataloader)\n",
    "\n",
    "# Calculate metrics\n",
    "accuracy = accuracy_score(true_labels, predictions)\n",
    "precision_macro = precision_score(true_labels, predictions, average='macro')\n",
    "precision_weighted = precision_score(true_labels, predictions, average='weighted')\n",
    "recall_macro = recall_score(true_labels, predictions, average='macro')\n",
    "recall_weighted = recall_score(true_labels, predictions, average='weighted')\n",
    "f1_macro = f1_score(true_labels, predictions, average='macro')\n",
    "f1_weighted = f1_score(true_labels, predictions, average='weighted')\n",
    "\n",
    "# Print overall metrics\n",
    "print(\"=\" + \"=\"*50)\n",
    "print(\"OVERALL PERFORMANCE METRICS\")\n",
    "print(\"=\"*50)\n",
    "print(f\"Accuracy: {accuracy:.4f}\")\n",
    "print(f\"Precision (Macro): {precision_macro:.4f}\")\n",
    "print(f\"Precision (Weighted): {precision_weighted:.4f}\")\n",
    "print(f\"Recall (Macro): {recall_macro:.4f}\")\n",
    "print(f\"Recall (Weighted): {recall_weighted:.4f}\")\n",
    "print(f\"F1-Score (Macro): {f1_macro:.4f}\")\n",
    "print(f\"F1-Score (Weighted): {f1_weighted:.4f}\")\n",
    "\n",
    "# Get per-class metrics\n",
    "precision_per_class = precision_score(true_labels, predictions, average=None)\n",
    "recall_per_class = recall_score(true_labels, predictions, average=None)\n",
    "f1_per_class = f1_score(true_labels, predictions, average=None)\n",
    "\n",
    "print(\"=\" + \"=\"*50)\n",
    "print(\"PER-CLASS PERFORMANCE METRICS\")\n",
    "print(\"=\"*50)\n",
    "class_names = ['Class 0', 'Class 1', 'Class 2']\n",
    "for i, class_name in enumerate(class_names):\n",
    "    print(f\"{class_name}:\")\n",
    "    print(f\"  Precision: {precision_per_class[i]:.4f}\")\n",
    "    print(f\"  Recall: {recall_per_class[i]:.4f}\")\n",
    "    print(f\"  F1-Score: {f1_per_class[i]:.4f}\")\n",
    "\n",
    "# Detailed classification report\n",
    "print(\"=\" + \"=\"*50)\n",
    "print(\"DETAILED CLASSIFICATION REPORT\")\n",
    "print(\"=\"*50)\n",
    "print(classification_report(true_labels, predictions, target_names=class_names))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "ename": "TypeError",
     "evalue": "Cannot cast array data from dtype('float32') to dtype('int64') according to the rule 'safe'",
     "output_type": "error",
     "traceback": [
      "\u001b[31m---------------------------------------------------------------------------\u001b[39m",
      "\u001b[31mTypeError\u001b[39m                                 Traceback (most recent call last)",
      "\u001b[36mCell\u001b[39m\u001b[36m \u001b[39m\u001b[32mIn[28]\u001b[39m\u001b[32m, line 23\u001b[39m\n\u001b[32m     20\u001b[39m axes[\u001b[32m0\u001b[39m,\u001b[32m1\u001b[39m].set_ylabel(\u001b[33m'\u001b[39m\u001b[33mTrue Label\u001b[39m\u001b[33m'\u001b[39m)\n\u001b[32m     22\u001b[39m \u001b[38;5;66;03m# Class distribution in predictions vs true labels\u001b[39;00m\n\u001b[32m---> \u001b[39m\u001b[32m23\u001b[39m class_counts_true = \u001b[43mnp\u001b[49m\u001b[43m.\u001b[49m\u001b[43mbincount\u001b[49m\u001b[43m(\u001b[49m\u001b[43mtrue_labels\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m     24\u001b[39m class_counts_pred = np.bincount(predictions)\n\u001b[32m     26\u001b[39m x = np.arange(\u001b[38;5;28mlen\u001b[39m(class_names))\n",
      "\u001b[31mTypeError\u001b[39m: Cannot cast array data from dtype('float32') to dtype('int64') according to the rule 'safe'"
     ]
    },
    {
     "data": {
      "image/png": "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9po1a5bp80rcpPv33aRJkzR16lTTdR49ejTJPXnx4kXlzp1bL7/8soxGo6n9kydPKkuWLGrRokWKrxXAk2PKJ/CAH3/8UUWKFEnxEPnOnTtr8eLFat68ufr27audO3cqNDRUx44dS5IYnTx5Us2bN1enTp0UFBSkBQsWqH379qpUqZJKly6tpk2bytPTU3369FGrVq1Uv359Zc2a1aL4jxw5ooYNG6pcuXIaNWqUXFxcdPLkSf3666+PPG7jxo2qV6+eihQpohEjRujWrVuaMWOGatSoob179yZJFt966y0VLlxYoaGh2rt3r+bPny8vLy+NHz8+RXE2bdpU3bt317fffquOHTtKujc6rUSJEqpYsWKS+qdOndLKlSv15ptvqnDhwoqIiNDHH3+sl156SUePHlXevHlVsmRJjRo1SsOGDVPXrl314osvSpLZ3+WVK1dUr149tWzZUm+//ba8vb2TjW/atGnavHmzgoKCFBYWJkdHR3388cdav369lixZorx586boOgEAsCeFCxdWu3btNG/ePA0cOPCRvw8tyZGOHz+uVq1aqVu3burSpYuKFy9u2hcaGio3NzcNHDhQJ0+e1IwZM5QpUyY5ODjo6tWrGjFihHbs2KFFixapcOHCGjZsmOnYOXPmqHTp0nrjjTfk5OSkH3/8Ue+8844SEhIUHByc4usuWbKklixZYlYWFRWlkJAQeXl5mcqWLFmioKAgBQYGavz48bp586bmzJmjmjVrat++faZ8av369WrWrJlKlSql0NBQXblyRR06dFD+/PkfG8u2bdsUGRmp3r17p2i0UkREhKpXr66bN2+qV69eypkzpxYvXqw33nhDK1asUJMmTczqjxs3Tg4ODnr//fcVHR2tCRMmqE2bNtq5c6ckaerUqfrss8/03Xffac6cOcqaNavKlSv32DgeNGLECIWGhqpz586qUqWKYmJi9Ntvv2nv3r169dVXH3pcaubdKdG6dWu99957un79urJmzaq7d+9q+fLlCgkJSXa65/Lly3Xz5k316NFDOXPm1K5duzRjxgz9888/Wr58uSSpW7duOn/+vDZs2JDknkq0cOFC3b59W127dpWLi4ty5MihhIQEszpeXl6aM2eO3nzzTc2YMUO9evVSQkKC2rdvr2zZsmn27NkpukYAT8kIwGg0Go3R0dFGScZGjRqlqP7+/fuN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XD5m9Hm0JgK1HPPmm2/G4MGD45FHHolrr7025s2bF9OnT48DDzwwRo8ene3yIiLimmuuiRtvvDEmT54cTz/9dGy66aYxbNiwWLVqVbZLa5NawjGzYsWK+OpXvxo/+clPsl0KkfvHzEcffRRz5syJsWPHxpw5c+Lee++NBQsWxOGHH57t0gC+lFz/+xuhz8s1LeGY0eflllw/ZvR5tCoJOeVb3/pW0rdv32T58uVrLfvggw8a/jkikvvuu6/h5/POOy/p379/0rlz52SbbbZJLr744qS2trZh+dy5c5Ovfe1rSZcuXZKuXbsme+65Z/Lss88mSZIkb775ZvLtb3876datW7LJJpsku+yyS/LQQw+ts776+vqkV69eybXXXtswtmzZsqSgoCD53e9+9yU/PRsj14+Zz1q4cGESEcnzzz+/0Z+XL68lHTOfeOaZZ5KISN566630HxggR+T63199Xu7J9WPms/R5uaElHTOf0OfRUnXIVpDH2t5///2YPn16XHnllbHpppuutbxbt27rXbdr165x++23R58+fWLevHlx8sknR9euXeO8886LiIhjjz029thjj7jllluiffv2MXfu3OjYsWNERIwePTpqa2vj8ccfj0033TReeuml6NKlyzq3s3DhwqioqIiysrKGsaKiohg6dGjMmjUrjjrqqC/xGyCtlnDMkFta6jFTVVUVeXl5n1sfQC5rCX9/9Xm5pSUcM+SWlnrM6PNoqQRqOeS1116LJElip512Sr3uxRdf3PDP/fr1i3POOSemTJnS8Adw0aJFce655za8d//+/RvmL1q0KL73ve/FgAEDIiJi2223Xe92KioqIiKiuLi40XhxcXHDMppPSzhmyC0t8ZhZtWpVnH/++XH00UdHYWFh6roBckFL+Purz8stLeGYIbe0xGNGn0dL5h5qOSRJko1ed+rUqbHvvvtGr169okuXLnHxxRfHokWLGpaXl5fHSSedFGVlZXH11VfH66+/3rDsv/7rv+KKK66IfffdN8aPHx8vvPDCl/ocNB/HDGm1tGNm9erVceSRR0aSJHHLLbdsdO0A2dbS/v6SfY4Z0mppx4w+j5ZOoJZD+vfvH3l5efHyyy+nWm/WrFlx7LHHxiGHHBIPPvhgPP/883HRRRdFbW1tw5xLLrkk/v73v8ehhx4ajzzySOyyyy5x3333RUTESSedFG+88UYcd9xxMW/evBgyZEjcdNNN69xWr169IiKisrKy0XhlZWXDMppPSzhmyC0t6Zj5pMl66623YsaMGb61BFq0lvD3V5+XW1rCMUNuaUnHjD6PViEbN25j/Q4++ODUN5G87rrrkm233bbR3BNPPDEpKipa73aOOuqo5LDDDlvnsgsuuCAZMGDAOpd9crPa6667rmGsqqrKzWqzKNePmc9ys9rc0BKOmdra2mT48OHJrrvumrz77rvr/zAALUiu//3V5+WeXD9mPkuflxtawjGjz6O1cIZajpk0aVLU1dXF3nvvHf/zP/8Tr776asyfPz9uvPHGKC0tXec6/fv3j0WLFsWUKVPi9ddfjxtvvLHh24KIiJUrV8bpp58ejz32WLz11lvxxBNPxLPPPhs777xzREScddZZ8fDDD8fChQtjzpw58eijjzYs+3d5eXlx1llnxRVXXBEPPPBAzJs3L0aOHBl9+vSJ4cOHN/nvgy+W68dMxMc3SJ07d2689NJLERGxYMGCmDt3rvuxZEmuHzOrV6+O73//+/Hcc8/FnXfeGXV1dVFRUREVFRWNvikFaGly/e+vPi/35PoxE6HPyzW5fszo82hVsp3osbZ//vOfyejRo5Ott946yc/PT/r27ZscfvjhyaOPPtowJ/7tMcfnnntu0r1796RLly7JiBEjkp/+9KcN3yjU1NQkRx11VFJSUpLk5+cnffr0SU4//fRk5cqVSZIkyemnn55st912SUFBQbLFFlskxx13XLJ06dL11ldfX5+MHTs2KS4uTgoKCpJvfOMbyYIFCzLxq2AD5fox8+tf/zqJiLVe48ePz8Bvgw2Ry8fMJ99wr+v12foAWqJc/vubJPq8XJTrx4w+L/fk8jGjz6M1yUuSL3HnQgAAAABoY1zyCQAAAAApCNQAAAAAIAWBGgAAAACkIFADAAAAgBQEagAAAACQgkANAAAAAFIQqAEAAABACgI1AAAAAEhBoAYt1PHHHx/Dhw9v+PlrX/tanHXWWc1ex2OPPRZ5eXmxbNmyjG3j3z/rxmiOOgEAmoI+Lx19HpANAjVoQscff3zk5eVFXl5e5Ofnx/bbbx+XXXZZrFmzJuPbvvfee+Pyyy/foLnN3XT069cvJk6c2CzbAgDIBH3euunzgLaqQ7YLgNbm4IMPjl//+tdRU1MT06ZNi9GjR0fHjh1jzJgxa82tra2N/Pz8Jtnu5ptv3iTvAwDAuunzAPiEM9SgiRUUFESvXr1i6623jtNOOy3KysrigQceiIhPT2m/8soro0+fPrHjjjtGRMTixYvjyCOPjG7dusXmm28eRxxxRLz55psN71lXVxfl5eXRrVu36N69e5x33nmRJEmj7f77pQA1NTVx/vnnR0lJSRQUFMT2228fv/rVr+LNN9+MAw88MCIiNttss8jLy4vjjz8+IiLq6+tjwoQJsc0220Tnzp1j4MCBcc899zTazrRp02KHHXaIzp07x4EHHtiozo1RV1cXJ554YsM2d9xxx/jZz362zrmXXnppbLHFFlFYWBinnnpq1NbWNizbkNoBAL4MfV46+jygNXOGGmRY586d47333mv4eebMmVFYWBgzZsyIiIjVq1fHsGHDorS0NP7v//4vOnToEFdccUUcfPDB8cILL0R+fn5cf/31cfvtt8dtt90WO++8c1x//fVx3333xde//vX1bnfkyJExa9asuPHGG2PgwIGxcOHCWLp0aZSUlMT//M//xPe+971YsGBBFBYWRufOnSMiYsKECfHb3/42Jk+eHP3794/HH388/vM//zO22GKLOOCAA2Lx4sXx3e9+N0aPHh2nnHJKPPfcc/HjH//4S/1+6uvrY8stt4y77747unfvHk8++WSccsop0bt37zjyyCMb/d46deoUjz32WLz55ptxwgknRPfu3ePKK6/coNoBAJqaPu/z6fOAVi0BmsyoUaOSI444IkmSJKmvr09mzJiRFBQUJOecc07D8uLi4qSmpqZhnd/85jfJjjvumNTX1zeM1dTUJJ07d04efvjhJEmSpHfv3sk111zTsHz16tXJlltu2bCtJEmSAw44IDnzzDOTJEmSBQsWJBGRzJgxY511Pvroo0lEJB988EHD2KpVq5JNNtkkefLJJxvNPfHEE5Ojjz46SZIkGTNmTLLLLrs0Wn7++eev9V7/buutt05++tOfrnf5vxs9enTyve99r+HnUaNGJZtvvnmyYsWKhrFbbrkl6dKlS1JXV7dBta/rMwMAbCh93rrp84C2yhlq0MQefPDB6NKlS6xevTrq6+vjmGOOiUsuuaRh+YABAxrdT+Nvf/tbvPbaa9G1a9dG77Nq1ap4/fXXo6qqKt55550YOnRow7IOHTrEkCFD1roc4BNz586N9u3bp/rG7rXXXouPPvoovvnNbzYar62tjT322CMiIubPn9+ojoiI0tLSDd7G+kyaNCluu+22WLRoUaxcuTJqa2tj0KBBjeYMHDgwNtlkk0bbXb58eSxevDiWL1/+hbUDAHxZ+rz09HlAayVQgyZ24IEHxi233BL5+fnRp0+f6NCh8b9mm266aaOfly9fHoMHD44777xzrffaYostNqqGT07tT2P58uUREfHQQw9F3759Gy0rKCjYqDo2xJQpU+Kcc86J66+/PkpLS6Nr165x7bXXxtNPP73B75Gt2gGAtkWfl44+D2jNBGrQxDbddNPYfvvtN3j+nnvuGVOnTo2ePXtGYWHhOuf07t07nn766dh///0jImLNmjUxe/bs2HPPPdc5f8CAAVFfXx9/+ctfoqysbK3ln3xzWldX1zC2yy67REFBQSxatGi933juvPPODTfe/cRTTz31xR/yczzxxBOxzz77xI9+9KOGsddff32teX/7299i5cqVDU3kU089FV26dImSkpLYfPPNv7B2AIAvS5+Xjj4PaM085ROy7Nhjj40ePXrEEUccEf/3f/8XCxcujMceeyz+67/+K/7xj39ERMSZZ54ZV199ddx///3x8ssvx49+9KNYtmzZet+zX79+MWrUqPjBD34Q999/f8N7/v73v4+IiK233jry8vLiwQcfjCVLlsTy5cuja9eucc4558TZZ58dd9xxR7z++usxZ86cuOmmm+KOO+6IiIhTTz01Xn311Tj33HNjwYIFcdddd8Xtt9++QZ/z7bffjrlz5zZ6ffDBB9G/f/947rnn4uGHH45XXnklxo4dG88+++xa69fW1saJJ54YL730UkybNi3Gjx8fp59+erRr126DagcAaG76PH0e0Ipl+yZu0Jp89ma1aZa/8847yciRI5MePXokBQUFybbbbpucfPLJSVVVVZIkH9+c9swzz0wKCwuTbt26JeXl5cnIkSPXe7PaJEmSlStXJmeffXbSu3fvJD8/P9l+++2T2267rWH5ZZddlvTq1SvJy8tLRo0alSTJxzfYnThxYrLjjjsmHTt2TLbYYotk2LBhyV/+8peG9f7whz8k22+/fVJQUJDst99+yW233bZBN6uNiLVev/nNb5JVq1Ylxx9/fFJUVJR069YtOe2005ILLrggGThw4Fq/t3HjxiXdu3dPunTpkpx88snJqlWrGuZ8Ue1u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AwAAAIAUBGoAAAAAkIJADQAAAABSEKgBAAAAQAoCNQAAAABIQaAGAAAAACkI1AAAAAAgBYEaAAAAAKQgUAMAAACAFARqAAAAAJCCQA0AAAAAUhCoAQAAAEAKAjUAAAAASEGgBgAAAAApCNQAAAAAIAWBGgAAAACkIFADAAAAgBQEagAAAACQgkANAAAAAFLIeKA2adKk6NevX3Tq1CmGDh0azzzzzOfOX7ZsWYwePTp69+4dBQUFscMOO8S0adMyXSYAABtBrwcAtEUdMvnmU6dOjfLy8pg8eXIMHTo0Jk6cGMOGDYsFCxZEz54915pfW1sb3/zmN6Nnz55xzz33RN++feOtt96Kbt26ZbJMAAA2gl4PAGir8pIkSTL15kOHDo299torbr755oiIqK+vj5KSkjjjjDPiggsuWGv+5MmT49prr42XX345OnbsuFHbrK6ujqKioqiqqorCwsIvVT8A0HboIdJr7l7PPgIANkYmeoiMXfJZW1sbs2fPjrKysk831q5dlJWVxaxZs9a5zgMPPBClpaUxevToKC4ujt122y2uuuqqqKurW+92ampqorq6utELAIDMao5eT58HAOSqjAVqS5cujbq6uiguLm40XlxcHBUVFetc54033oh77rkn6urqYtq0aTF27Ni4/vrr44orrljvdiZMmBBFRUUNr5KSkib9HAAArK05ej19HgCQq3LqKZ/19fXRs2fP+MUvfhGDBw+OESNGxEUXXRSTJ09e7zpjxoyJqqqqhtfixYubsWIAADZU2l5PnwcA5KqMPZSgR48e0b59+6isrGw0XllZGb169VrnOr17946OHTtG+/btG8Z23nnnqKioiNra2sjPz19rnYKCgigoKGja4gEA+FzN0evp8wCAXJWxM9Ty8/Nj8ODBMXPmzIax+vr6mDlzZpSWlq5znX333Tdee+21qK+vbxh75ZVXonfv3usM0wAAyA69HgDQlmX0ks/y8vK49dZb44477oj58+fHaaedFitWrIgTTjghIiJGjhwZY8aMaZh/2mmnxfvvvx9nnnlmvPLKK/HQQw/FVVddFaNHj85kmQAAbAS9HgDQVmXsks+IiBEjRsSSJUti3LhxUVFREYMGDYrp06c33Lx20aJF0a7dp5leSUlJPPzww3H22WfH7rvvHn379o0zzzwzzj///EyWCQDARtDrAQBtVV6S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P7UM7do1y0PQWzx9Hl/E37yWwX7KffZRy2A/tQxN2edltGPMz8+PwYMHx8yZMxvG6uvrY+bMmVFaWrrOdUpLSxvNj4iYMWPGeucDAND89HkAQFuW8Us+y8vLY9SoUTFkyJDYe++9Y+LEibFixYo44YQTIiJi5MiR0bdv35gwYUJERJx55plxwAEHxPXXXx+HHnpoTJkyJZ577rn4xS9+kelSAQBIQZ8HALRVGQ/URowYEUuWLIlx48ZFRUVFDBo0KKZPn95wQ9pFixY1OuVun332ibvuuisuvvjiuPDCC6N///5x//33x2677bZB2ysoKIjx48ev8/IAcof91DLYT7nPPmoZ7KeWwX5KT5/HuthPLYP9lPvso5bBfmoZMrGf8hLPhgcAAACADeauuwAAAACQgkANAAAAAFIQqAEAAABACgI1AAAAAEihRQZqkyZNin79+kWnTp1i6NCh8cwzz3zu/Lvvvjt22mmn6NSpUwwYMCCmTZvWTJW2bWn206233hr77bdfbLbZZrHZZptFWVnZF+5Xmkbaf58+MWXKlMjLy4vhw4dntkBS76Nly5bF6NGjo3fv3lFQUBA77LCDv3vNIO1+mjhxYuy4447RuXPnKCkpibPPPjtWrVrVTNW2PY8//ngcdthh0adPn8jLy4v777//C9d57LHHYs8994yCgoLYfvvt4/bbb894nejzWgp9Xsugz8t9+ryWQZ+X27LW5yUtzJQpU5L8/PzktttuS/7+978nJ598ctKtW7eksrJynfOfeOKJpH379sk111yTvPTSS8nFF1+cdOzYMZk3b14zV962pN1PxxxzTDJp0qTk+eefT+bPn58cf/zxSVFRUfKPf/yjmStvW9Lup08sXLgw6du3b7LffvslRxxxRPMU20al3Uc1NTXJkCFDkkMOOST561//mixcuDB57LHHkrlz5zZz5W1L2v105513JgUFBcmdd96ZLFy4MHn44YeT3r17J2effXYzV952TJs2LbnooouSe++9N4mI5L777vvc+W+88UayySabJOXl5clLL72U3HTTTUn79u2T6dOnN0/BbZQ+r2XQ57UM+rzcp89rGfR5uS9bfV6LC9T23nvvZPTo0Q0/19XVJX369EkmTJiwzvlHHnlkcuihhzYaGzp0aPLDH/4wo3W2dWn3079bs2ZN0rVr1+SOO+7IVIkkG7ef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",
      "text/plain": [
       "<Figure size 1500x1200 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Confusion Matrix Visualization and Additional Analysis\n",
    "cm = confusion_matrix(true_labels, predictions)\n",
    "\n",
    "# Create figure with subplots\n",
    "fig, axes = plt.subplots(2, 2, figsize=(15, 12))\n",
    "\n",
    "# Plot confusion matrix\n",
    "sns.heatmap(cm, annot=True, fmt='d', cmap='Blues', \n",
    "            xticklabels=class_names, yticklabels=class_names, ax=axes[0,0])\n",
    "axes[0,0].set_title('Confusion Matrix')\n",
    "axes[0,0].set_xlabel('Predicted Label')\n",
    "axes[0,0].set_ylabel('True Label')\n",
    "\n",
    "# Plot normalized confusion matrix\n",
    "cm_normalized = cm.astype('float') / cm.sum(axis=1)[:, np.newaxis]\n",
    "sns.heatmap(cm_normalized, annot=True, fmt='.3f', cmap='Blues',\n",
    "            xticklabels=class_names, yticklabels=class_names, ax=axes[0,1])\n",
    "axes[0,1].set_title('Normalized Confusion Matrix')\n",
    "axes[0,1].set_xlabel('Predicted Label')\n",
    "axes[0,1].set_ylabel('True Label')\n",
    "\n",
    "# Class distribution in predictions vs true labels\n",
    "class_counts_true = np.bincount(true_labels)\n",
    "class_counts_pred = np.bincount(predictions)\n",
    "\n",
    "x = np.arange(len(class_names))\n",
    "width = 0.35\n",
    "\n",
    "axes[1,0].bar(x - width/2, class_counts_true, width, label='True Labels', alpha=0.8)\n",
    "axes[1,0].bar(x + width/2, class_counts_pred, width, label='Predictions', alpha=0.8)\n",
    "axes[1,0].set_xlabel('Class')\n",
    "axes[1,0].set_ylabel('Count')\n",
    "axes[1,0].set_title('Class Distribution: True vs Predicted')\n",
    "axes[1,0].set_xticks(x)\n",
    "axes[1,0].set_xticklabels(class_names)\n",
    "axes[1,0].legend()\n",
    "\n",
    "# Performance metrics comparison\n",
    "metrics_names = ['Precision', 'Recall', 'F1-Score']\n",
    "metrics_values = np.array([precision_per_class, recall_per_class, f1_per_class])\n",
    "\n",
    "x = np.arange(len(class_names))\n",
    "width = 0.25\n",
    "\n",
    "for i, metric_name in enumerate(metrics_names):\n",
    "    axes[1,1].bar(x + i*width, metrics_values[i], width, label=metric_name, alpha=0.8)\n",
    "\n",
    "axes[1,1].set_xlabel('Class')\n",
    "axes[1,1].set_ylabel('Score')\n",
    "axes[1,1].set_title('Per-Class Performance Metrics')\n",
    "axes[1,1].set_xticks(x + width)\n",
    "axes[1,1].set_xticklabels(class_names)\n",
    "axes[1,1].legend()\n",
    "axes[1,1].set_ylim(0, 1.1)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "# Print confusion matrix details\n",
    "print(\"\\\\n\" + \"=\"*50)\n",
    "print(\"CONFUSION MATRIX ANALYSIS\")\n",
    "print(\"=\"*50)\n",
    "print(\"Confusion Matrix:\")\n",
    "print(cm)\n",
    "print(\"\\\\nNormalized Confusion Matrix (by true class):\")\n",
    "print(cm_normalized)\n",
    "\n",
    "# Calculate and display class-wise statistics\n",
    "print(\"\\\\n\" + \"=\"*50)\n",
    "print(\"CLASS DISTRIBUTION ANALYSIS\")\n",
    "print(\"=\"*50)\n",
    "total_samples = len(true_labels)\n",
    "for i, class_name in enumerate(class_names):\n",
    "    true_count = class_counts_true[i]\n",
    "    pred_count = class_counts_pred[i]\n",
    "    true_percentage = (true_count / total_samples) * 100\n",
    "    pred_percentage = (pred_count / total_samples) * 100\n",
    "    \n",
    "    print(f\"{class_name}:\")\n",
    "    print(f\"  True samples: {true_count} ({true_percentage:.2f}%)\")\n",
    "    print(f\"  Predicted samples: {pred_count} ({pred_percentage:.2f}%)\")\n",
    "    print(f\"  Difference: {pred_count - true_count} samples\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Advanced Metrics and Confidence Analysis\n",
    "from sklearn.metrics import cohen_kappa_score, matthews_corrcoef\n",
    "from scipy import stats\n",
    "\n",
    "print(\"=\"*50)\n",
    "print(\"ADVANCED PERFORMANCE METRICS\")\n",
    "print(\"=\"*50)\n",
    "\n",
    "# Cohen's Kappa Score\n",
    "kappa = cohen_kappa_score(true_labels, predictions)\n",
    "print(f\"Cohen's Kappa Score: {kappa:.4f}\")\n",
    "\n",
    "# Matthews Correlation Coefficient (for multiclass, this is less standard but still informative)\n",
    "try:\n",
    "    mcc = matthews_corrcoef(true_labels, predictions)\n",
    "    print(f\"Matthews Correlation Coefficient: {mcc:.4f}\")\n",
    "except:\n",
    "    print(\"Matthews Correlation Coefficient: Not applicable for multiclass\")\n",
    "\n",
    "# Model Confidence Analysis\n",
    "max_probabilities = np.max(probabilities, axis=1)\n",
    "predicted_classes = np.argmax(probabilities, axis=1)\n",
    "\n",
    "print(\"\\\\n\" + \"=\"*50)\n",
    "print(\"MODEL CONFIDENCE ANALYSIS\")\n",
    "print(\"=\"*50)\n",
    "print(f\"Average Confidence: {np.mean(max_probabilities):.4f}\")\n",
    "print(f\"Median Confidence: {np.median(max_probabilities):.4f}\")\n",
    "print(f\"Min Confidence: {np.min(max_probabilities):.4f}\")\n",
    "print(f\"Max Confidence: {np.max(max_probabilities):.4f}\")\n",
    "print(f\"Std Confidence: {np.std(max_probabilities):.4f}\")\n",
    "\n",
    "# Confidence by class\n",
    "print(\"\\\\nConfidence by Predicted Class:\")\n",
    "for i, class_name in enumerate(class_names):\n",
    "    class_mask = predicted_classes == i\n",
    "    if np.sum(class_mask) > 0:\n",
    "        class_confidences = max_probabilities[class_mask]\n",
    "        print(f\"{class_name}: {np.mean(class_confidences):.4f} ± {np.std(class_confidences):.4f}\")\n",
    "\n",
    "# Correct vs Incorrect Predictions Confidence\n",
    "correct_mask = predictions == true_labels\n",
    "correct_confidences = max_probabilities[correct_mask]\n",
    "incorrect_confidences = max_probabilities[~correct_mask]\n",
    "\n",
    "print(\"\\\\nConfidence Analysis:\")\n",
    "print(f\"Correct Predictions - Mean Confidence: {np.mean(correct_confidences):.4f}\")\n",
    "print(f\"Incorrect Predictions - Mean Confidence: {np.mean(incorrect_confidences):.4f}\")\n",
    "\n",
    "# Statistical test to see if there's a significant difference\n",
    "if len(incorrect_confidences) > 0:\n",
    "    t_stat, p_value = stats.ttest_ind(correct_confidences, incorrect_confidences)\n",
    "    print(f\"T-test (correct vs incorrect confidence): t={t_stat:.4f}, p={p_value:.6f}\")\n",
    "\n",
    "# Create confidence distribution plot\n",
    "plt.figure(figsize=(12, 8))\n",
    "\n",
    "plt.subplot(2, 2, 1)\n",
    "plt.hist(max_probabilities, bins=50, alpha=0.7, edgecolor='black')\n",
    "plt.xlabel('Maximum Probability (Confidence)')\n",
    "plt.ylabel('Frequency')\n",
    "plt.title('Distribution of Model Confidence')\n",
    "\n",
    "plt.subplot(2, 2, 2)\n",
    "plt.hist(correct_confidences, bins=30, alpha=0.7, label='Correct', edgecolor='black')\n",
    "plt.hist(incorrect_confidences, bins=30, alpha=0.7, label='Incorrect', edgecolor='black')\n",
    "plt.xlabel('Maximum Probability (Confidence)')\n",
    "plt.ylabel('Frequency')\n",
    "plt.title('Confidence: Correct vs Incorrect Predictions')\n",
    "plt.legend()\n",
    "\n",
    "plt.subplot(2, 2, 3)\n",
    "confidence_by_class = [max_probabilities[predicted_classes == i] for i in range(len(class_names))]\n",
    "plt.boxplot(confidence_by_class, labels=class_names)\n",
    "plt.ylabel('Confidence')\n",
    "plt.title('Confidence Distribution by Predicted Class')\n",
    "\n",
    "plt.subplot(2, 2, 4)\n",
    "# Confidence threshold analysis\n",
    "thresholds = np.arange(0.5, 1.0, 0.05)\n",
    "accuracies_at_threshold = []\n",
    "coverage_at_threshold = []\n",
    "\n",
    "for threshold in thresholds:\n",
    "    high_conf_mask = max_probabilities >= threshold\n",
    "    if np.sum(high_conf_mask) > 0:\n",
    "        high_conf_accuracy = accuracy_score(true_labels[high_conf_mask], predictions[high_conf_mask])\n",
    "        coverage = np.sum(high_conf_mask) / len(predictions)\n",
    "    else:\n",
    "        high_conf_accuracy = 0\n",
    "        coverage = 0\n",
    "    \n",
    "    accuracies_at_threshold.append(high_conf_accuracy)\n",
    "    coverage_at_threshold.append(coverage)\n",
    "\n",
    "plt.plot(thresholds, accuracies_at_threshold, 'b-', label='Accuracy', marker='o')\n",
    "plt.plot(thresholds, coverage_at_threshold, 'r-', label='Coverage', marker='s')\n",
    "plt.xlabel('Confidence Threshold')\n",
    "plt.ylabel('Score')\n",
    "plt.title('Accuracy vs Coverage at Different Confidence Thresholds')\n",
    "plt.legend()\n",
    "plt.grid(True, alpha=0.3)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "# Print summary statistics\n",
    "print(\"\\\\n\" + \"=\"*50)\n",
    "print(\"FINAL SUMMARY\")\n",
    "print(\"=\"*50)\n",
    "print(f\"Total Samples Evaluated: {len(true_labels)}\")\n",
    "print(f\"Overall Accuracy: {accuracy:.4f}\")\n",
    "print(f\"Macro F1-Score: {f1_macro:.4f}\")\n",
    "print(f\"Weighted F1-Score: {f1_weighted:.4f}\")\n",
    "print(f\"Cohen's Kappa: {kappa:.4f}\")\n",
    "print(f\"Average Model Confidence: {np.mean(max_probabilities):.4f}\")\n",
    "print(f\"Number of Misclassifications: {np.sum(predictions != true_labels)}\")\n",
    "print(f\"Error Rate: {np.sum(predictions != true_labels) / len(true_labels):.4f}\")\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "SimBA",
   "language": "python",
   "name": "simba"
  },
  "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.13.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
