{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Experiment to Visualize LFP Decision Boundaries on Toy Data"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import copy\n",
    "import os\n",
    "import random\n",
    "\n",
    "# os.environ['CUDA_LAUNCH_BLOCKING'] = \"1\"\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import torch\n",
    "from tqdm import tqdm\n",
    "\n",
    "from experiment_utils.utils.utils import register_backward_normhooks\n",
    "from lfprop.propagation import propagator_lxt as propagator\n",
    "from lfprop.rewards import rewards"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Experiment Variables"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset_name = \"blobs\"  # swirls, circles, blobs # DONE: none\n",
    "n_channels = 2\n",
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "batch_size = 1\n",
    "lr = 1.0\n",
    "momentum = 0.0\n",
    "reward_names = [\"maximizesingleneuronreward\", \"minimizesingleneuronreward\"]\n",
    "loss_names = [\"maximizesingleneuronloss\", \"minimizesingleneuronloss\"]\n",
    "norm_backward = False\n",
    "epochs = 10\n",
    "n_datasets = 1\n",
    "datasample_versions = [[([[1.0, 1.0]], [1])], [([[1.0, 1.0]], [1])]]\n",
    "weight_initializations = [(0.5, 0.5), (-1.0, -1.0)]\n",
    "\n",
    "savepath = \"<path to save results in>\"\n",
    "data_path = \"<path where dataset is saved>\"\n",
    "\n",
    "retrain_models = True\n",
    "redraw_data = True"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Training Utility"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "class SingleNeuronModel(torch.nn.Module):\n",
    "    \"\"\"\n",
    "    SingleNeuronModel\n",
    "    \"\"\"\n",
    "\n",
    "    def __init__(self, n_channels, activation_kwargs=None):\n",
    "        super().__init__()\n",
    "\n",
    "        if activation_kwargs is None:\n",
    "            activation_kwargs = {}\n",
    "\n",
    "        # Classifier\n",
    "        self.classifier = torch.nn.Sequential(\n",
    "            torch.nn.Linear(n_channels, 1, bias=False),\n",
    "        )\n",
    "        self.act = torch.nn.SiLU()\n",
    "\n",
    "    def forward(self, x):\n",
    "        \"\"\"\n",
    "        Forwards input through network\n",
    "        \"\"\"\n",
    "\n",
    "        # Forward through network\n",
    "        x = torch.flatten(x, 1)\n",
    "        self.pre_act_x = self.classifier(x)\n",
    "        self.post_act_x = self.act(self.pre_act_x)\n",
    "\n",
    "        # Return output\n",
    "        return self.post_act_x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "class Trainer:\n",
    "    def __init__(\n",
    "        self,\n",
    "        model,\n",
    "        train_data,\n",
    "        optimizer,\n",
    "        criterion,\n",
    "        device,\n",
    "        lfp_composite=None,\n",
    "        norm_backward=False,\n",
    "    ):\n",
    "        self.model = model\n",
    "        self.train_data = train_data\n",
    "        self.optimizer = optimizer\n",
    "        self.criterion = criterion\n",
    "        self.device = device\n",
    "        self.lfp_composite = lfp_composite\n",
    "        self.norm_backward = norm_backward\n",
    "        self.global_epoch = 0\n",
    "        self.global_step = 0\n",
    "\n",
    "        self.param_log = []\n",
    "        self.pre_act_output_log = []\n",
    "        self.post_act_output_log = []\n",
    "\n",
    "    def grad_step(self, inputs, labels):\n",
    "        # Backward norm\n",
    "        if self.norm_backward:\n",
    "            norm_handles = register_backward_normhooks(self.model)\n",
    "        else:\n",
    "            norm_handles = []\n",
    "\n",
    "        self.model.train()\n",
    "        with torch.enable_grad():\n",
    "            self.optimizer.zero_grad()\n",
    "            out = self.model(inputs)\n",
    "\n",
    "            reward = self.criterion(out, labels)\n",
    "            reward.backward()\n",
    "\n",
    "            self.optimizer.step()\n",
    "\n",
    "        self.model.eval()\n",
    "\n",
    "        for handle in norm_handles:\n",
    "            handle.remove()\n",
    "\n",
    "        self.global_step += 1\n",
    "\n",
    "    def lfp_step(self, inputs, labels):\n",
    "        self.model.train()\n",
    "\n",
    "        with torch.enable_grad():\n",
    "            self.optimizer.zero_grad()\n",
    "            with self.lfp_composite.context(self.model) as modified:\n",
    "                inputs = inputs.detach().requires_grad_(True)\n",
    "                outputs = modified(inputs)\n",
    "\n",
    "                # Calculate reward\n",
    "                # Do like this to avoid tensors being kept in memory\n",
    "                reward = torch.from_numpy(self.criterion(outputs, labels).detach().cpu().numpy()).to(device)\n",
    "\n",
    "                # Write LFP Values into .grad attributes\n",
    "                torch.autograd.grad((outputs,), (inputs,), grad_outputs=(reward,), retain_graph=False)[0]\n",
    "\n",
    "                for name, param in self.model.named_parameters():\n",
    "                    param.grad = -param.feedback\n",
    "\n",
    "                self.optimizer.step()\n",
    "\n",
    "        self.model.eval()\n",
    "\n",
    "        self.global_step += 1\n",
    "\n",
    "    def train(\n",
    "        self,\n",
    "        epochs,\n",
    "        verbose=False,\n",
    "        savepath=None,\n",
    "        savename=\"ckpt\",\n",
    "        saveappendage=\"last\",\n",
    "        fromscratch=False,\n",
    "    ):\n",
    "        if not fromscratch and savepath:\n",
    "            self.load(savepath, savename, saveappendage)\n",
    "\n",
    "        if verbose:\n",
    "            (inputs, labels) = self.train_data[0]\n",
    "            inputs = torch.tensor(inputs).to(device)\n",
    "            labels = torch.tensor(labels).to(device)\n",
    "\n",
    "            print(inputs, labels)\n",
    "\n",
    "            output = self.model(inputs)\n",
    "            self.pre_act_output_log.append(self.model.pre_act_x.view(-1).detach().cpu().numpy())\n",
    "            self.post_act_output_log.append(output.view(-1).detach().cpu().numpy())\n",
    "\n",
    "            pred = output > 0\n",
    "            print(f\"Preds: {pred}, Labels: {labels}\")\n",
    "\n",
    "        self.param_log.append([p for p in self.model.parameters()][0].data.view(-1).detach().cpu().numpy())\n",
    "\n",
    "        for epoch in range(epochs):\n",
    "            with tqdm(total=len(self.train_data), disable=not verbose) as pbar:\n",
    "                for index, (inputs, labels) in enumerate(self.train_data):\n",
    "                    inputs = torch.tensor(inputs).to(device)\n",
    "                    labels = torch.tensor(labels).to(device)\n",
    "\n",
    "                    print(inputs, labels)\n",
    "\n",
    "                    if self.lfp_composite is None:\n",
    "                        # Grad Step\n",
    "                        self.grad_step(inputs, labels)\n",
    "                    else:\n",
    "                        # LFP Step\n",
    "                        self.lfp_step(inputs, labels)\n",
    "\n",
    "                    pbar.update(1)\n",
    "                    self.param_log.append([p for p in self.model.parameters()][0].data.view(-1).detach().cpu().numpy())\n",
    "                    output = self.model(inputs)\n",
    "                    self.pre_act_output_log.append(self.model.pre_act_x.view(-1).detach().cpu().numpy())\n",
    "                    self.post_act_output_log.append(output.view(-1).detach().cpu().numpy())\n",
    "\n",
    "                    if verbose:\n",
    "                        pred = output > 0\n",
    "                        print(f\"Preds: {pred}, Labels: {labels}\")\n",
    "\n",
    "            self.global_epoch += 1\n",
    "\n",
    "            if savepath:\n",
    "                self.save(savepath, savename, \"last\")\n",
    "\n",
    "    def save(self, savepath, savename, saveappendage):\n",
    "        checkpoint = {\n",
    "            \"epoch\": self.global_epoch,\n",
    "            \"step\": self.global_step,\n",
    "            \"random_state\": {\n",
    "                \"torch\": torch.get_rng_state(),\n",
    "                \"cuda\": torch.cuda.get_rng_state(self.device),\n",
    "                \"numpy\": np.random.get_state(),\n",
    "                \"random\": random.getstate(),\n",
    "            },\n",
    "        }\n",
    "        if self.model:\n",
    "            checkpoint[\"model\"] = self.model.state_dict()\n",
    "        if self.optimizer:\n",
    "            checkpoint[\"optimizer\"] = self.optimizer.state_dict()\n",
    "        if self.param_log:\n",
    "            checkpoint[\"param_log\"] = self.param_log\n",
    "        if self.pre_act_output_log:\n",
    "            checkpoint[\"pre_act_output_log\"] = self.pre_act_output_log\n",
    "        if self.post_act_output_log:\n",
    "            checkpoint[\"post_act_output_log\"] = self.post_act_output_log\n",
    "\n",
    "        torch.save(checkpoint, os.path.join(savepath, f\"{savename}-{saveappendage}.pt\"))\n",
    "\n",
    "    def load(self, savepath, savename, saveappendage):\n",
    "        if os.path.exists(os.path.join(savepath, f\"{savename}-{saveappendage}.pt\")):\n",
    "            checkpoint = torch.load(os.path.join(savepath, f\"{savename}-{saveappendage}.pt\"))\n",
    "            if self.model:\n",
    "                self.model.load_state_dict(checkpoint[\"model\"])\n",
    "            if self.optimizer:\n",
    "                self.optimizer.load_state_dict(checkpoint[\"optimizer\"])\n",
    "            if \"param_log\" in checkpoint:\n",
    "                self.param_log = checkpoint[\"param_log\"]\n",
    "            if \"pre_act_output_log\" in checkpoint:\n",
    "                self.pre_act_output_log = checkpoint[\"pre_act_output_log\"]\n",
    "            if \"post_act_output_log\" in checkpoint:\n",
    "                self.post_act_output_log = checkpoint[\"post_act_output_log\"]\n",
    "            self.global_epoch = checkpoint[\"epoch\"]\n",
    "            self.global_step = checkpoint[\"step\"]\n",
    "\n",
    "            torch.set_rng_state(checkpoint[\"random_state\"][\"torch\"])\n",
    "            torch.cuda.set_rng_state(checkpoint[\"random_state\"][\"cuda\"], device)\n",
    "            np.random.set_state(checkpoint[\"random_state\"][\"numpy\"])\n",
    "            random.setstate(checkpoint[\"random_state\"][\"random\"])\n",
    "\n",
    "        else:\n",
    "            print(\"No checkpoint found... not loading anything.\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Paths, Dataset, Model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "metadata": {}
   },
   "outputs": [],
   "source": [
    "os.makedirs(data_path, exist_ok=True)\n",
    "\n",
    "propagation_composites = {\n",
    "    \"lfp-epsilon\": propagator.LFPEpsilonComposite(\n",
    "        norm_backward=norm_backward,\n",
    "    ),\n",
    "    \"vanilla-gradient\": None,\n",
    "}\n",
    "\n",
    "if retrain_models or not os.path.exists(os.path.join(savepath, \"init-ckpts\", \"initmodel-0.pt\")):\n",
    "    init_models = [SingleNeuronModel(2).to(device) for w in weight_initializations]\n",
    "    for w, w_in in enumerate(weight_initializations):\n",
    "        for p in init_models[w].parameters():\n",
    "            p.data.view(-1)[0] = w_in[0]\n",
    "            p.data.view(-1)[1] = w_in[1]\n",
    "    os.makedirs(os.path.join(savepath, \"init-ckpts\"), exist_ok=True)\n",
    "    for m, model in enumerate(init_models):\n",
    "        torch.save(\n",
    "            model.state_dict(),\n",
    "            os.path.join(savepath, \"init-ckpts\", f\"initmodel-{m}.pt\"),\n",
    "        )\n",
    "else:\n",
    "    init_models = [SingleNeuronModel(2).to(device) for w in weight_initializations]\n",
    "    for m, model in enumerate(init_models):\n",
    "        statedict = torch.load(os.path.join(savepath, \"init-ckpts\", f\"initmodel-{m}.pt\"))\n",
    "        model.load_state_dict(statedict)\n",
    "\n",
    "trainers = {}\n",
    "for r, reward_name in enumerate(reward_names):\n",
    "    loss_name = loss_names[r]\n",
    "    trainers[r] = {}\n",
    "    for name, prop_comp in propagation_composites.items():\n",
    "        trainers[r][name] = []\n",
    "        for w, weight_init in enumerate(weight_initializations):\n",
    "            model = copy.deepcopy(init_models[w])\n",
    "            trainers[r][name].append(\n",
    "                Trainer(\n",
    "                    model=model,\n",
    "                    train_data=datasample_versions[w],\n",
    "                    optimizer=torch.optim.SGD(model.parameters(), lr=lr, momentum=momentum),\n",
    "                    criterion=(\n",
    "                        rewards.get_reward(reward_name, device)\n",
    "                        if prop_comp is not None\n",
    "                        else rewards.get_reward(loss_name, device)\n",
    "                    ),\n",
    "                    device=device,\n",
    "                    lfp_composite=prop_comp,\n",
    "                    norm_backward=norm_backward,\n",
    "                )\n",
    "            )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "metadata": {}
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Reward 0...\n",
      "lfp-epsilon\n",
      "(0.5, 0.5): Trainer 0\n",
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 17.69it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "100%|██████████| 1/1 [00:00<00:00, 229.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 204.52it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 236.17it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 238.58it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 235.09it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 220.83it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 158.42it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 207.27it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 220.64it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n",
      "(-1.0, -1.0): Trainer 1\n",
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 216.47it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 138.67it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 220.87it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 216.36it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 217.16it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 213.53it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 212.18it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 192.55it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 215.11it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 209.33it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n",
      "vanilla-gradient\n",
      "(0.5, 0.5): Trainer 0\n",
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 49.69it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 166.11it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 281.19it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 269.64it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 253.49it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 248.49it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 250.93it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 254.08it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 265.78it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "100%|██████████| 1/1 [00:00<00:00, 278.23it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n",
      "(-1.0, -1.0): Trainer 1\n",
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 266.47it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "100%|██████████| 1/1 [00:00<00:00, 278.91it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 244.38it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 251.44it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 273.92it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "100%|██████████| 1/1 [00:00<00:00, 288.37it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 280.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 275.20it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 277.20it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 224.52it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n",
      "Reward 1...\n",
      "lfp-epsilon\n",
      "(0.5, 0.5): Trainer 0\n",
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 175.37it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 185.51it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 163.09it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 179.01it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "100%|██████████| 1/1 [00:00<00:00, 182.49it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 188.74it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 177.29it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0')"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 174.12it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 170.85it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 180.69it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n",
      "(-1.0, -1.0): Trainer 1\n",
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 186.37it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "100%|██████████| 1/1 [00:00<00:00, 197.36it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 183.86it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 169.00it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 204.46it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 184.80it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 182.02it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 202.56it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 199.75it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 199.84it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n",
      "vanilla-gradient\n",
      "(0.5, 0.5): Trainer 0\n",
      "tensor([[1., 1.]], device='cuda:0') "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 230.61it/s]\n",
      "100%|██████████| 1/1 [00:00<00:00, 274.26it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[True]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 253.03it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 259.60it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 271.95it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "100%|██████████| 1/1 [00:00<00:00, 303.98it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 281.99it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 262.50it/s]\n",
      "100%|██████████| 1/1 [00:00<00:00, 274.86it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 270.39it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n",
      "(-1.0, -1.0): Trainer 1\n",
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 286.79it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 299.91it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 260.81it/s]\n",
      "100%|██████████| 1/1 [00:00<00:00, 280.18it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "100%|██████████| 1/1 [00:00<00:00, 275.81it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 273.00it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 298.93it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 218.81it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0')"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1/1 [00:00<00:00, 236.82it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n",
      "100%|██████████| 1/1 [00:00<00:00, 274.57it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1., 1.]], device='cuda:0') tensor([1], device='cuda:0')\n",
      "Preds: tensor([[False]], device='cuda:0'), Labels: tensor([1], device='cuda:0')\n"
     ]
    }
   ],
   "source": [
    "for r, trainers_r in trainers.items():\n",
    "    print(f\"Reward {r}...\")\n",
    "    for name, trainer_list in trainers_r.items():\n",
    "        print(name)\n",
    "\n",
    "        for t, trainer in enumerate(trainer_list):\n",
    "            print(f\"{weight_initializations[t]}: Trainer {t}\")\n",
    "            ckpt_path = os.path.join(savepath, f\"ckpts-lr-{lr}\")\n",
    "            os.makedirs(ckpt_path, exist_ok=True)\n",
    "            savename = f\"{name}-model-{t}\"\n",
    "            saveappendage = \"last\"\n",
    "            if retrain_models or not os.path.exists(os.path.join(ckpt_path, f\"{savename}-{saveappendage}.pt\")):\n",
    "                trainer.train(\n",
    "                    epochs=epochs,\n",
    "                    verbose=True,\n",
    "                    savepath=ckpt_path,\n",
    "                    savename=savename,\n",
    "                    saveappendage=saveappendage,\n",
    "                    fromscratch=True,\n",
    "                )\n",
    "            else:\n",
    "                trainer.load(savepath=ckpt_path, savename=savename, saveappendage=saveappendage)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Plot Settings\n",
    "# Set font properties.\n",
    "import matplotlib.cm as cm\n",
    "import matplotlib.font_manager as font_manager\n",
    "\n",
    "font_path = plt.matplotlib.get_data_path() + \"/fonts/ttf/cmr10.ttf\"\n",
    "cmfont = font_manager.FontProperties(fname=font_path)\n",
    "plt.rcParams[\"font.family\"] = \"serif\"\n",
    "plt.rcParams[\"font.serif\"] = cmfont.get_name()\n",
    "plt.rcParams[\"mathtext.fontset\"] = \"cm\"\n",
    "\n",
    "# Set font size.\n",
    "plt.rcParams[\"font.size\"] = 15\n",
    "\n",
    "# Disable unicode minus.\n",
    "plt.rcParams[\"axes.unicode_minus\"] = False\n",
    "\n",
    "# Use mathtext for axes formatters.\n",
    "plt.rcParams[\"axes.formatter.use_mathtext\"] = True\n",
    "\n",
    "plt.rcParams[\"axes.linewidth\"] = 1.5"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Plot Progression of Activations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "lfp-epsilon maximizesingleneuronreward\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_636793/2070531345.py:33: MatplotlibDeprecationWarning: The get_cmap function was deprecated in Matplotlib 3.7 and will be removed two minor releases later. Use ``matplotlib.colormaps[name]`` or ``matplotlib.colormaps.get_cmap(obj)`` instead.\n",
      "  cmap = cm.get_cmap(\"Reds\", 256)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "vanilla-gradient maximizesingleneuronloss\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "lfp-epsilon minimizesingleneuronreward\n"
     ]
    },
    {
     "data": {
      "image/png": "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boRMpr86df78eWg0GrRp06ZUjklERPbpZnw6Zm69YFC2eFAL1KniZqOIqCg26VPyyy+/lEq9O3fuxPXr17Fy5UopIQGAAwcOwMGBGTERUUWSkaPBpA1nkJ6jkcomda2D3k39i9iLbMmqZ+oHDx7g66+/xs6dO3Hjxg3IZDLUqVMHL730EsaOHQsfHx+z6z5x4gTGjx+PZ555BiNGjJDKRVHEsWPH8MYbb1jiRyAiojJAFEW8ve0CbsanS2VP1PHGzJ71bRgVPY7VhpnfsWMHXnnlFaSkpODRQwqCAC8vL/z000/o16+fWfX7+PggKSmpwHV16tQp1h09HGaeiEzFYebt06qjtzFvzxVpuaqnE3a98SS83RxtGFX5VmaGmf/1118xePBg1KtXD6+99hqaN28OLy8v5OTkICYmBqdPn8avv/6KgQMH4rfffsPzzz9v8jESExNLIXIiIipr/rmZiAV78xISpVyG70YEMyEpA0o9KUlISMCECRPw1VdfYcqUKQVuM3bsWHz55Zf48MMPMXLkSFy/ft3ozhwiIqLHiU7Owush56DL1yA/t38TtKxeyWYxUfGVekfXFStWYO7cuYUmJLmcnJywaNEiTJkyBd98801ph0VEROVMtlqLyRvO4H6GSiob0rY6hrYzfZJXso1ST0rCwsLw+uuvF3v7OXPm4MyZM6UYERERlUdz/7iEsLsp0nLzap6Y83wTG0ZEpir1pKSwOWcK4+joaDSHDRERUVE2n4pEyKkoadnLVYnvRgTDScGRussSu5v7BoA07DsREdHjnI9Kxkc78mb+lQnA10NbIbCSsw2jInOUelISEREBjUbz+A0fysnJQWRkZClGRERE5UVieg4mbzgDlVYnlb3TuyGeqGv+uFdkO6WelDz55JP4+OOPi7399OnT0a1bt9ILiIiIygWNVoc3NhnO/NunmT8mdCl40leyf6V+S/Brr72GevXqISsrC3PnzoW7u3uB20VGRmLmzJk4evQorl27VtphERFRGbfof9dw4nbeoJn1fN3wxUstOPNvGVbqSYm7uzu2bNmCXr16Yf369ejZsydatWqFypUrIycnB3FxcThx4gSOHj0KQD9PjaenZ2mHRUREZdjuCzFYefS2tOzm6IDvRwbDjTP/lmlW+e116dIFR48exfDhwxESEoLNmzcbrBdFETVr1kRISAjat29v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",
      "text/plain": [
       "<Figure size 600x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "vanilla-gradient minimizesingleneuronloss\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from matplotlib.colors import ListedColormap\n",
    "\n",
    "\n",
    "def plot_activations_over_epochs(pre_act_output_logs, post_act_output_logs, fname, criterion, colormap=\"Set1\"):\n",
    "    fig, axes = plt.subplots(2, 1, figsize=(6, 4), sharex=True, height_ratios=[0.8, 0.2])\n",
    "    fig.subplots_adjust(hspace=0.05)\n",
    "\n",
    "    xpoints = torch.arange(-10, 5, 0.001)\n",
    "    ypoints = torch.nn.SiLU()(xpoints.to(device))\n",
    "    axes[0].plot(\n",
    "        xpoints.detach().cpu().numpy(),\n",
    "        ypoints.detach().cpu().numpy(),\n",
    "        linewidth=2.5,\n",
    "        alpha=1,\n",
    "        label=\"Activation\",\n",
    "    )\n",
    "\n",
    "    crit = rewards.get_reward(criterion, device)\n",
    "    cpoints = crit(ypoints, torch.ones_like(ypoints))\n",
    "    axes[0].plot(\n",
    "        xpoints.detach().cpu().numpy(),\n",
    "        cpoints.detach().cpu().numpy(),\n",
    "        linewidth=2.5,\n",
    "        alpha=1,\n",
    "        label=\"Criterion\",\n",
    "    )\n",
    "\n",
    "    axes[0].hlines([0], xmin=-100, xmax=100, color=(0.5, 0.5, 0.5, 1), linewidth=1.5, zorder=0)\n",
    "    ylim = axes[0].get_ylim()\n",
    "    ylim = (ylim[0] - 0.1, ylim[1] + 0.5)\n",
    "\n",
    "    if \"min\" in criterion:\n",
    "        axes[0].vlines(\n",
    "            [xpoints[ypoints.argmin().detach().cpu().numpy()]],\n",
    "            ymin=ylim[0],\n",
    "            ymax=ylim[1],\n",
    "            color=\"forestgreen\",\n",
    "            linewidth=1.5,\n",
    "            zorder=0,\n",
    "        )\n",
    "        axes[0].text(\n",
    "            xpoints[ypoints.argmin().detach().cpu().numpy()],\n",
    "            ylim[1] - 0.25,\n",
    "            \"Minimum\",\n",
    "            horizontalalignment=\"left\",\n",
    "            verticalalignment=\"top\",\n",
    "            fontsize=11.5,\n",
    "            color=\"forestgreen\",\n",
    "        )\n",
    "    else:\n",
    "        axes[0].arrow(\n",
    "            4.5,\n",
    "            ylim[1] - 0.25,\n",
    "            0.4,\n",
    "            0.0,\n",
    "            color=\"forestgreen\",\n",
    "            width=0.1,\n",
    "            head_width=0.3,\n",
    "            head_length=0.1,\n",
    "            head_starts_at_zero=True,\n",
    "            length_includes_head=True,\n",
    "            zorder=100,\n",
    "        )\n",
    "        axes[0].text(\n",
    "            4.5,\n",
    "            ylim[1] - 0.25,\n",
    "            \"Maximum\",\n",
    "            horizontalalignment=\"right\",\n",
    "            verticalalignment=\"center\",\n",
    "            fontsize=11.5,\n",
    "            color=\"forestgreen\",\n",
    "        )\n",
    "\n",
    "    cmap = cm.get_cmap(\"Reds\", 256)\n",
    "    newcolors = cmap(np.linspace(0.3, 1.0, 256))\n",
    "    pastel = 0.0\n",
    "    newcolors = (1 - pastel) * newcolors + pastel * np.ones((256, 4))\n",
    "    trainer_cm = ListedColormap(newcolors.clip(max=1)[::-1])\n",
    "\n",
    "    for w, (pre_act_output_log, post_act_output_log) in enumerate(list(zip(pre_act_output_logs, post_act_output_logs))):\n",
    "        toplot_idx = np.arange(0, len(pre_act_output_log), 1).astype(int)\n",
    "        axes[1].scatter(\n",
    "            pre_act_output_log,\n",
    "            post_act_output_log,\n",
    "            c=toplot_idx,\n",
    "            marker=\"\",\n",
    "            cmap=trainer_cm,\n",
    "        )\n",
    "\n",
    "        for p, pre_val in enumerate(pre_act_output_log):\n",
    "            if p > 0:\n",
    "                axes[1].arrow(\n",
    "                    pre_act_output_log[p - 1][0],\n",
    "                    p,\n",
    "                    (pre_act_output_log[p][0] - pre_act_output_log[p - 1][0]),\n",
    "                    0.0,\n",
    "                    color=trainer_cm(p / len(pre_act_output_log)),\n",
    "                    width=0.25,\n",
    "                    head_width=1.1,\n",
    "                    head_length=0.1,\n",
    "                    head_starts_at_zero=True,\n",
    "                    length_includes_head=True,\n",
    "                    zorder=100 - p,\n",
    "                )\n",
    "            else:\n",
    "                axes[1].scatter(pre_act_output_log[p], p + 1, c=1, marker=\"d\", cmap=trainer_cm)\n",
    "                if pre_act_output_log[p + 1] <= pre_act_output_log[p]:\n",
    "                    axes[1].text(\n",
    "                        pre_act_output_log[p] + 0.1,\n",
    "                        p + 1 + 0.1,\n",
    "                        f\"W{w + 1}\",\n",
    "                        horizontalalignment=\"left\",\n",
    "                        verticalalignment=\"bottom\",\n",
    "                        fontsize=11.5,\n",
    "                        color=trainer_cm(1 / len(pre_act_output_log)),\n",
    "                    )\n",
    "                else:\n",
    "                    axes[1].text(\n",
    "                        pre_act_output_log[p] - 0.1,\n",
    "                        p + 1 + 0.1,\n",
    "                        f\"W{w + 1}\",\n",
    "                        horizontalalignment=\"right\",\n",
    "                        verticalalignment=\"bottom\",\n",
    "                        fontsize=11.5,\n",
    "                        color=trainer_cm(1 / len(pre_act_output_log)),\n",
    "                    )\n",
    "\n",
    "    # cbar = plt.colorbar(sc)\n",
    "    # cbar.set_label('Iteration')\n",
    "\n",
    "    axes[0].set_ylim(ylim)\n",
    "    axes[0].set_ylabel(\"Output\")\n",
    "    axes[1].xaxis.tick_bottom()\n",
    "    axes[1].set_ylabel(\"Iteration\")\n",
    "    axes[1].set_xlabel(\"Pre-Activation Output\")\n",
    "    # ax.set_ylim([0.3, 1.01])\n",
    "    # ax.set_yticks([0.4, 0.6, 0.8, 1.0])\n",
    "    # ax.set_yticklabels([40, 60, 80, 100])\n",
    "    axes[1].tick_params(length=6, width=2)\n",
    "    axes[1].set_xticks([-10, -5, 0, 5])\n",
    "    axes[1].set_xlim([-10, 5])\n",
    "\n",
    "    axes[0].tick_params(axis=\"x\", length=0, width=0)\n",
    "    axes[0].legend()\n",
    "    plt.show()\n",
    "    fig.savefig(fname)\n",
    "\n",
    "\n",
    "for r, reward_name in enumerate(reward_names):\n",
    "    for name in propagation_composites.keys():\n",
    "        criterion = reward_name if name != \"vanilla-gradient\" else loss_names[r]\n",
    "        print(name, criterion)\n",
    "        plot_activations_over_epochs(\n",
    "            [tr.pre_act_output_log for tr in trainers[r][name]],\n",
    "            [tr.post_act_output_log for tr in trainers[r][name]],\n",
    "            fname=os.path.join(savepath, f\"activations-crit-{criterion}-{name}.svg\"),\n",
    "            criterion=criterion,\n",
    "        )"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "lfp-KukTaqIE-py3.11",
   "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.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
