{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "0322c98b",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-01T11:43:46.127326Z",
     "start_time": "2024-10-01T11:43:44.346395Z"
    }
   },
   "outputs": [],
   "source": [
    "import ast\n",
    "from pathlib import Path\n",
    "from time import time\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "from tqdm.notebook import trange\n",
    "\n",
    "from kgi import apply_kgi_to_model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "6b436357",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-01T11:43:46.138367Z",
     "start_time": "2024-10-01T11:43:46.127207Z"
    }
   },
   "outputs": [],
   "source": [
    "# attempt to enable LaTeX rendering\n",
    "# change to `False` if you get an error during plotting (latex not installed)\n",
    "plt.rcParams['text.usetex'] = True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "1deb815f",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-01T11:43:46.138756Z",
     "start_time": "2024-10-01T11:43:46.131025Z"
    }
   },
   "outputs": [],
   "source": [
    "def default_init_to_he_uniform(model):\n",
    "    \"\"\" Change PyTorch's default initialization to He uniform \"\"\"\n",
    "    # PyTorch default uses 1/sqrt(m) as the bound\n",
    "    # He uniform uses sqrt(3)/sqrt(m) as the bound\n",
    "    sqrt3 = np.sqrt(3)\n",
    "    for layer in model.modules():\n",
    "        if isinstance(layer, torch.nn.Linear):\n",
    "            layer.weight.data *= sqrt3\n",
    "            layer.bias.data *= sqrt3\n",
    "\n",
    "\n",
    "class MLP(nn.Module):\n",
    "    \"\"\" MLP model \"\"\"\n",
    "\n",
    "    def __init__(self, input_size, hidden_size, num_hidden_layers=1, activation=torch.relu):\n",
    "        super(MLP, self).__init__()\n",
    "        self.input_layer = nn.Linear(input_size, hidden_size)\n",
    "        self.hidden_layers = nn.ModuleList(\n",
    "            [nn.Linear(hidden_size, hidden_size) for _ in range(num_hidden_layers)]\n",
    "        )\n",
    "        self.output_layer = nn.Linear(hidden_size, 3)\n",
    "        self.act = activation\n",
    "        default_init_to_he_uniform(self)\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = self.input_layer(x)\n",
    "        x = self.act(x)\n",
    "        for layer in self.hidden_layers:\n",
    "            x = layer(x)\n",
    "            x = self.act(x)\n",
    "        x = self.output_layer(x)\n",
    "        return x"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "82dbd134",
   "metadata": {},
   "source": [
    "# Data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "outputs": [],
   "source": [
    "def extract_values_from_string(input_str):\n",
    "    \"\"\" df.Composition stores strings; parse to numbers \"\"\"\n",
    "    input_list = ast.literal_eval(input_str)\n",
    "    elements = ['Ag', 'Al', 'Au']\n",
    "    row_values = {element: 0.0 for element in elements}\n",
    "    for item in input_list:\n",
    "        element, value = item.split(':')\n",
    "        row_values[element.strip()] = float(value.strip())\n",
    "    return [row_values[element] for element in elements]"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2024-10-01T11:43:46.139102Z",
     "start_time": "2024-10-01T11:43:46.135228Z"
    }
   },
   "id": "bb987e56c4374b6b"
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "b2ec6c4f",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-01T11:43:46.407019Z",
     "start_time": "2024-10-01T11:43:46.139877Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Data (10000, 1000)\n",
      "Labels (10000, 3)\n"
     ]
    }
   ],
   "source": [
    "# truncate tail\n",
    "truncate = 2000\n",
    "# decimate data\n",
    "decimate = 2\n",
    "\n",
    "df = pd.read_pickle('datasets/muons.pkl')\n",
    "# read data\n",
    "x_in = df.Spectra\n",
    "x_list = [a for a in x_in]\n",
    "x_arr = np.array(x_list)[:, :truncate:decimate]\n",
    "# normalize data\n",
    "min_vals = np.min(x_arr, axis=1, keepdims=True)\n",
    "max_vals = np.max(x_arr, axis=1, keepdims=True)\n",
    "x_arr = (x_arr - min_vals) / (max_vals - min_vals)\n",
    "# read labels\n",
    "y_arr = []\n",
    "for comp in df.Composition:\n",
    "    y_arr.append(extract_values_from_string(comp))\n",
    "y_arr = np.array(y_arr)\n",
    "print(\"Data\", x_arr.shape)\n",
    "print(\"Labels\", y_arr.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 600x440 with 1 Axes>",
      "image/png": "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"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(dpi=200, figsize=(3, 2.2))\n",
    "index = 19\n",
    "plt.plot(x_arr[index], c='b', lw=.7)\n",
    "plt.xticks(np.arange(0, 1001, 250), np.arange(0, 1001, 250) * 4)\n",
    "plt.text(.45, 7 / 8, \"Label:\", ha=\"left\", transform=plt.gca().transAxes)\n",
    "plt.text(.45, 6 / 8, f\"\\u2022 Silver - {y_arr[index][0] * 100}\\%\", ha=\"left\", transform=plt.gca().transAxes)\n",
    "plt.text(.45, 5 / 8, f\"\\u2022 Gold - {y_arr[index][1] * 100}\\%\", ha=\"left\", transform=plt.gca().transAxes)\n",
    "plt.text(.45, 4 / 8, f\"\\u2022 Aluminum - {y_arr[index][2] * 100}\\%\", ha=\"left\", transform=plt.gca().transAxes)\n",
    "plt.xlabel(\"Energy (keV)\")\n",
    "plt.ylabel(\"Normalized intensity\")\n",
    "plt.savefig(\"figs/muons_data.pdf\", bbox_inches='tight', pad_inches=0.01)\n",
    "plt.show()"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2024-10-01T11:43:47.638918Z",
     "start_time": "2024-10-01T11:43:46.408979Z"
    }
   },
   "id": "b019a30b6d1d213d"
  },
  {
   "cell_type": "markdown",
   "id": "87ff3890",
   "metadata": {},
   "source": [
    "# Training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "outputs": [],
   "source": [
    "train_lim = 6000\n",
    "device = \"cpu\"\n",
    "x_train = torch.from_numpy(x_arr[:train_lim]).to(device)\n",
    "y_train = torch.from_numpy(y_arr[:train_lim]).float().to(device)\n",
    "x_test = torch.from_numpy(x_arr[train_lim:]).to(device)\n",
    "y_test = torch.from_numpy(y_arr[train_lim:]).float().to(device)"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2024-10-01T11:43:47.640245Z",
     "start_time": "2024-10-01T11:43:47.628830Z"
    }
   },
   "id": "fce863f02c1396f3"
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "d4f15f40",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-01T11:43:47.653638Z",
     "start_time": "2024-10-01T11:43:47.640600Z"
    }
   },
   "outputs": [],
   "source": [
    "def train(kgi, hidden_size, num_hidden_layers, seed, activation=torch.relu,\n",
    "          num_epochs=1000, log_loss_every=1, pbar=True, bin_threshold=0.01):\n",
    "    \"\"\" Train a model \"\"\"\n",
    "    torch.manual_seed(seed)\n",
    "    model = MLP(x_train.size(1), hidden_size=hidden_size, num_hidden_layers=num_hidden_layers,\n",
    "                activation=activation)\n",
    "    if kgi:\n",
    "        if activation is torch.nn.functional.tanh:\n",
    "            apply_kgi_to_model(model,\n",
    "                               knot_low=[0.2] + [-0.8] * (num_hidden_layers + 1),\n",
    "                               knot_high=[0.8] * (num_hidden_layers + 2),\n",
    "                               perturb_factor=0.2, kgi_by_bias=False)\n",
    "        else:\n",
    "            apply_kgi_to_model(model, knot_low=0., knot_high=1.,\n",
    "                               perturb_factor=0.2, kgi_by_bias=False)\n",
    "    model.to(device)\n",
    "    model.train()\n",
    "    criterion = nn.KLDivLoss(reduction=\"batchmean\")\n",
    "    optimizer = torch.optim.Adam(model.parameters(), lr=1e-4)\n",
    "\n",
    "    # training loop\n",
    "    loss_hist = []\n",
    "    batch_size = 512\n",
    "    for epoch in trange(num_epochs, disable=not pbar):\n",
    "        # shuffle data\n",
    "        perm = torch.randperm(x_train.size(0))\n",
    "        x_train_perm = x_train[perm]\n",
    "        y_train_perm = y_train[perm]\n",
    "        epoch_loss = 0.\n",
    "        for i in range(0, x_train.size(0), batch_size):\n",
    "            x_batch = x_train_perm[i:i + batch_size]\n",
    "            y_batch = y_train_perm[i:i + batch_size]\n",
    "            y_pred = model(x_batch)\n",
    "            y_pred = torch.log_softmax(y_pred, dim=-1)\n",
    "            loss = criterion(y_pred, y_batch)\n",
    "            optimizer.zero_grad()\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "            epoch_loss += loss.item()\n",
    "        epoch_loss /= len(range(0, x_train.size(0), batch_size))\n",
    "        if (epoch + 1) % log_loss_every == 0:\n",
    "            loss_hist.append(epoch_loss)\n",
    "\n",
    "    # evaluation\n",
    "    model.eval()\n",
    "    with torch.no_grad():\n",
    "        y_pred_all = model(x_test)\n",
    "        y_pred_all = torch.softmax(y_pred_all, dim=-1)\n",
    "        cosine_similarity = torch.einsum(\"ik,ik->i\", y_pred_all, y_test).mean()\n",
    "        diff = torch.abs(y_pred_all - y_test)\n",
    "        success_per_sample = torch.all(diff < bin_threshold, dim=1)  # noqa\n",
    "        bin_accuracy = success_per_sample.float().mean()\n",
    "    return model, loss_hist, cosine_similarity, bin_accuracy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "4036cdec",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-01T11:43:47.654072Z",
     "start_time": "2024-10-01T11:43:47.644403Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0_False exists\n",
      "0_True exists\n",
      "1_False exists\n",
      "1_True exists\n",
      "2_False exists\n",
      "2_True exists\n",
      "3_False exists\n",
      "3_True exists\n",
      "4_False exists\n",
      "4_True exists\n",
      "5_False exists\n",
      "5_True exists\n",
      "6_False exists\n",
      "6_True exists\n",
      "7_False exists\n",
      "7_True exists\n",
      "8_False exists\n",
      "8_True exists\n",
      "9_False exists\n",
      "9_True exists\n"
     ]
    }
   ],
   "source": [
    "seeds = list(range(10))  # use `seeds = [0]` for fast test\n",
    "epochs = 5000  # use a smaller one for fast test\n",
    "out_dir = Path(\"results/muons_paper\")\n",
    "act_ = torch.nn.functional.relu\n",
    "hidden_size_ = 128\n",
    "num_hidden_layers_ = 2\n",
    "\n",
    "out_dir.mkdir(exist_ok=True, parents=True)\n",
    "for seed_ in seeds:\n",
    "    for kgi_ in [False, True]:\n",
    "        name_ = f\"{seed_}_{kgi_}\"\n",
    "        if not (out_dir / name_).exists():\n",
    "            t0 = time()\n",
    "            _, hist_, cos_sim, bin_acc = train(kgi_, hidden_size_, num_hidden_layers_, seed_, act_,\n",
    "                                               num_epochs=epochs, log_loss_every=1, pbar=False)\n",
    "            np.savetxt(out_dir / name_, hist_, header=f\"{cos_sim} {bin_acc}\")\n",
    "            print(f\"{name_} trained in {(time() - t0) / 60:.1f} min, loss={hist_[-1]:.2e}\")\n",
    "        else:\n",
    "            print(f\"{name_} exists\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "9775a6d4",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-01T11:43:47.819759Z",
     "start_time": "2024-10-01T11:43:47.649819Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 640x480 with 1 Axes>",
      "image/png": "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"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# quick plot\n",
    "hist_no_kgi = np.loadtxt('results/muons_paper/0_False')\n",
    "hist_kgi = np.loadtxt('results/muons_paper/0_True')\n",
    "plt.plot(hist_no_kgi[:5000], label='No KGI')\n",
    "plt.plot(hist_kgi[:5000], label='KGI')\n",
    "plt.yscale(\"log\")\n",
    "plt.legend()\n",
    "plt.ylabel('KL Div')\n",
    "plt.xlabel('Epoch')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "source": [],
   "metadata": {
    "collapsed": false
   },
   "id": "66deb68eb1e7cfd7"
  },
  {
   "cell_type": "markdown",
   "source": [
    "# Analysis"
   ],
   "metadata": {
    "collapsed": false
   },
   "id": "fb2439859e081cae"
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "afb258d5",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-10-01T11:43:47.866507Z",
     "start_time": "2024-10-01T11:43:47.817887Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "No KGI\n",
      "\n",
      "No KGI\n",
      "Loss: 1.26 ± 1.26\n",
      "slowness: 0.63 ± 0.05\n",
      "Acc: 88.5 ± 3.7%\n",
      "KGI\n",
      "\n",
      "KGI\n",
      "Loss: 0.88 ± 0.88\n",
      "slowness: 0.59 ± 0.04\n",
      "Acc: 90.1 ± 4.2%\n",
      "\n",
      "Copy to table\n",
      "$\\mu$SR & $1.26\\!\\pm\\!0.33$ & $0.88\\!\\pm\\!0.30$ & $0.63\\!\\pm\\!0.05$ & $0.59\\!\\pm\\!0.04$ & Acc. & $88.51\\!\\pm\\!3.66\\%$ & $90.06\\!\\pm\\!4.16\\%$\n"
     ]
    }
   ],
   "source": [
    "def print_metrics(kgi):\n",
    "    losses = []\n",
    "    slowness = []\n",
    "    metrics = []\n",
    "    for seed in seeds:\n",
    "        # read history\n",
    "        name = f\"{seed}_{kgi}\"\n",
    "        hist = np.loadtxt(out_dir / name)\n",
    "        # use average of last 10 epochs\n",
    "        final_loss = hist[-10:].mean()\n",
    "        losses.append(final_loss)\n",
    "        # AUC for convergence slowness\n",
    "        init_loss = hist[:10].mean()\n",
    "        slowness.append(hist.mean() / init_loss)\n",
    "        # read relative error\n",
    "        with open(out_dir / name) as fs:\n",
    "            err_str = fs.readline()\n",
    "        err = float(err_str.split(\" \")[2])\n",
    "        metrics.append(err)\n",
    "    losses = np.array(losses) * 10000\n",
    "    slowness = np.array(slowness) * 100\n",
    "    metrics = np.array(metrics) * 100\n",
    "    # excluding top-k losses\n",
    "    idx = np.argsort(losses)[:-3]\n",
    "    losses = losses[idx]\n",
    "    slowness = slowness[idx]\n",
    "    metrics = metrics[idx]\n",
    "    print(\"KGI\" if kgi else \"No KGI\")\n",
    "    # print in latex format\n",
    "    print(\"\\nKGI\" if kgi else \"\\nNo KGI\")\n",
    "    print(f\"Loss: {losses.mean():.2f} ± {losses.mean():.2f}\")\n",
    "    print(f\"slowness: {slowness.mean():.2f} ± {slowness.std():.2f}\")\n",
    "    print(f\"Acc: {metrics.mean():.1f} ± {metrics.std():.1f}%\")\n",
    "    return losses.mean(), losses.std(), slowness.mean(), slowness.std(), metrics.mean(), metrics.std()\n",
    "\n",
    "\n",
    "lmf, lsf, smf, ssf, amf, asf = print_metrics(False)\n",
    "lmt, lst, smt, sst, amt, ast = print_metrics(True)\n",
    "lmf, lsf, lmt, lst = lmf, lsf, lmt, lst\n",
    "print(\"\\nCopy to table\")\n",
    "print(f\"$\\mu$SR & \"\n",
    "      f\"${lmf:.2f}\\!\\pm\\!{lsf:.2f}$ & ${lmt:.2f}\\!\\pm\\!{lst:.2f}$ & \"\n",
    "      f\"${smf:.2f}\\!\\pm\\!{ssf:.2f}$ & ${smt:.2f}\\!\\pm\\!{sst:.2f}$ & Acc. & \"\n",
    "      f\"${amf:.2f}\\!\\pm\\!{asf:.2f}\\%$ & ${amt:.2f}\\!\\pm\\!{ast:.2f}\\%$\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "outputs": [],
   "source": [],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2024-10-01T11:43:47.866733Z",
     "start_time": "2024-10-01T11:43:47.856703Z"
    }
   },
   "id": "a2ec1bf7f85bb9dc"
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
