{"cells":[{"cell_type":"markdown","source":[" # Quick comparison of PCN and CPCN on MNIST"],"metadata":{}},{"cell_type":"code","execution_count":1,"source":["import matplotlib.pyplot as plt\n","import seaborn as sns\n","import pydove as dv\n","\n","import numpy as np\n","import torch\n","import torchvision\n","\n","from tqdm.notebook import tqdm\n","\n","from cpcn.linear import LinearCPCNetwork\n","from cpcn.pcn import PCNetwork\n","from cpcn.util import make_onehot, evaluate"],"outputs":[],"metadata":{}},{"cell_type":"markdown","source":[" ## Choose device"],"metadata":{}},{"cell_type":"code","execution_count":2,"source":["# device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n","device = \"cpu\""],"outputs":[],"metadata":{}},{"cell_type":"markdown","source":[" ## Load dataset"],"metadata":{}},{"cell_type":"code","execution_count":3,"source":["trainset = torchvision.datasets.MNIST(\"data/\", train=True, download=True)\n","testset = torchvision.datasets.MNIST(\"data/\", train=False, download=True)\n","\n","# split out a validation set and normalize\n","mu = 33.3184\n","sigma = 78.5675\n","normalized = (trainset.data - mu) / sigma\n","train_size = 5_000\n","validation_size = 1_000\n","dataset = {\n","    \"train\": (normalized[:train_size], trainset.targets[:train_size]),\n","    \"validation\": (normalized[-validation_size:], trainset.targets[-validation_size:]),\n","    \"test\": ((testset.data - mu) / sigma, testset.targets),\n","}\n","\n","# flatten images; make labels one hot\n","for key, item in dataset.items():\n","    dataset[key] = (\n","        item[0].reshape(item[0].shape[0], -1).to(device),\n","        make_onehot(item[1]).to(device),\n","    )"],"outputs":[],"metadata":{}},{"cell_type":"markdown","source":[" ## Train PCN"],"metadata":{}},{"cell_type":"markdown","source":[" ### Setup loaders"],"metadata":{}},{"cell_type":"code","execution_count":4,"source":["# for reproducibility\n","torch.manual_seed(123)\n","\n","batch_size = 128\n","\n","train_loader = torch.utils.data.DataLoader(\n","    torch.utils.data.TensorDataset(*dataset[\"train\"]),\n","    batch_size=batch_size,\n","    shuffle=True,\n",")\n","validation_loader = torch.utils.data.DataLoader(\n","    torch.utils.data.TensorDataset(*dataset[\"validation\"]), batch_size=batch_size,\n",")\n","test_loader = torch.utils.data.DataLoader(\n","    torch.utils.data.TensorDataset(*dataset[\"test\"]), batch_size=batch_size,\n",")"],"outputs":[],"metadata":{}},{"cell_type":"markdown","source":[" ### Setup network"],"metadata":{}},{"cell_type":"code","execution_count":5,"source":["n_epochs = 50\n","dims = [784, 50, 20, 10]\n","it_inference = 50\n","lr_inference = 0.1\n","\n","torch.manual_seed(123)\n","\n","net = PCNetwork(\n","    dims,\n","    activation=lambda _: _,\n","    lr_inference=lr_inference,\n","    it_inference=it_inference,\n","    variances=1.0,\n",")\n","net = net.to(device)"],"outputs":[],"metadata":{}},{"cell_type":"markdown","source":[" ### Run the actual training"],"metadata":{}},{"cell_type":"code","execution_count":6,"source":["losses = np.zeros(n_epochs)\n","accuracies = np.zeros(n_epochs)\n","train_losses = np.zeros((n_epochs, len(train_loader)))\n","\n","optimizer = torch.optim.Adam(net.slow_parameters(), lr=0.001)\n","\n","# train a linear classifier on the output from the last hidden layer\n","classifier = torch.nn.Sequential(torch.nn.Linear(*dims[-2:]))\n","classifier_optimizer = torch.optim.Adam(classifier.parameters(), lr=0.001)\n","classifier_criterion = torch.nn.MSELoss()\n","\n","# pbar = tqdm(range(n_epochs), desc=\"val: loss ?.??? acc ?.??\")\n","pbar = tqdm(range(n_epochs))\n","for epoch in pbar:\n","    # train\n","    for i, (x, y) in enumerate(train_loader):\n","        net.forward_constrained(x, y)\n","\n","        classifier_optimizer.zero_grad()\n","        optimizer.zero_grad()\n","\n","        loss = net.loss()\n","        loss.backward()\n","\n","        # propagate through the classifier\n","        classifier_out = classifier(net.z[-2])\n","        classifier_loss = classifier_criterion(classifier_out, y)\n","        classifier_loss.backward()\n","\n","        optimizer.step()\n","        classifier_optimizer.step()\n","\n","        train_losses[epoch, i] = loss.item()\n","\n","    # evaluate\n","    losses[epoch], accuracies[epoch] = evaluate(\n","        net, validation_loader, classifier=classifier\n","    )\n","    # pbar.set_description(f\"val: loss {losses[epoch]:.2g} acc {accuracies[epoch]:.2f}\")\n","    pbar.set_postfix(\n","        {\"val_loss\": f\"{losses[epoch]:.2g}\", \"val_acc\": f\"{accuracies[epoch]:.2f}\"}\n","    )\n","\n","train_losses = np.sum(train_losses, axis=1) / len(train_loader.dataset)"],"outputs":[{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"88b5159f6c1e4717978ed6aa30fd2210"},"text/plain":["  0%|          | 0/50 [00:00<?, ?it/s]"]},"metadata":{}}],"metadata":{}},{"cell_type":"markdown","source":[" ## Show learning curves"],"metadata":{}},{"cell_type":"code","execution_count":7,"source":["with dv.FigureManager(1, 2) as (_, (ax1, ax2)):\n","    ax1.semilogy(train_losses, label=\"train\")\n","    ax1.semilogy(losses, label=\"val\")\n","    ax1.set_xlabel(\"epoch\")\n","    ax1.set_ylabel(\"predictive-coding loss\")\n","    ax1.legend(frameon=False)\n","\n","    ax2.plot(100 * accuracies)\n","    ax2.set_xlabel(\"epoch\")\n","    ax2.set_ylabel(\"accuracy on validation set (%)\")\n","    ax2.set_ylim(0, 100)"],"outputs":[{"output_type":"display_data","data":{"image/png":"iVBORw0KGgoAAAANSUhEUgAAA1gAAAEYCAYAAABBWFftAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/YYfK9AAAACXBIWXMAAAsTAAALEwEAmpwYAABwQUlEQVR4nO3dd3hUZfbA8e9Jb6SQEEpC7703QQRFRQV7L2tnLeuq66667rq6P3Wt667uWhZ7V8QGVhApIoLSe28JgRRKSK/n98cdIEAgk2Qmk0zO53nmmcydmXvPvYS8c+Z93/OKqmKMMcYYY4wxpvYCfB2AMcYYY4wxxvgLS7CMMcYYY4wxxkMswTLGGGOMMcYYD7EEyxhjjDHGGGM8xBIsY4wxxhhjjPEQS7CMMcYYY4wxxkMswTLGGGMAEXldRDJEZFWFbU1FZIaIbHTdx1V47s8isklE1ovImb6J2hhjTH1jCZYxxhjjeBMYd9S2+4GZqtoZmOl6jIj0AC4Herre86KIBNZdqMYYY+orS7CMMcYYQFXnAnuP2nwe8Jbr57eA8yts/1BVi1R1K7AJGFIXcRpjjKnfgnwdgDeIyLeqevS3kJVRrwdjjDGmtsSHx26uqrsAVHWXiCS6ticBCyq8LtW17RgiMhGY6HoYpqq93DiutU/GGFP/Vdo++WsPVoKvAzDGGOPXKmtUK02KVHWSqg5S1UFAoXfDMsYY42v+mmAZY4wxnpAuIi0BXPcZru2pQOsKr0sG0uo4NmOMMfWQJVjGGGPM8U0FrnX9fC3wRYXtl4tIqIi0BzoDv/ggPmOMMfWMX87BMsYYY6pLRD4ARgMJIpIKPAQ8AUwWkRuBHcAlAKq6WkQmA2uAUuB2VS3zSeDGGGPqFVH1v3m0IrLINda9Kv538sYY4398WeTCo6x9MsYYv9KoilwYY4wxxhhjTJ2r90MERSQSeBEoBmar6ns+DskYY4wxxhhjKuWTHiwReV1EMkRk1VHbx4nIehHZJCL3uzZfCExR1ZuBc+s8WGOMMcYYY4xxk6+GCL4JHLEQsIgEAi8AZwE9gCtEpAdO6dsU18vqzQTizZm5zNmQ6eswjDHGGGOMMfWITxIsVZ0L7D1q8xBgk6puUdVi4EPgPJy1RpJdr6k3c8beXbCd295d7OswjDHG6/bv38+LL75Y7fedffbZ7N+/3/MBGWOMMfVYvUlYgCQO91SBk1glAZ8CF4nIS8C0471ZRCaKyCIRWQQkeDVSICEqlLziMgqK602nmjHGeMXxEqyyshP//fv666+JjY31UlTGGGNM/VSfilxUVuZQVTUPuL6qN6vqJGASOGVwPRzbMRKiQgDYk1dEckiEtw9njDE+c//997N582b69etHcHAwUVFRtGzZkmXLlrFmzRrOP/98UlJSKCws5M4772TixIkAtGvXjkWLFpGbm8tZZ53FyJEjmT9/PklJSXzxxReEh4f7+MyMMcYYz6tPCVYq0LrC42QgzUexVCkhKhSArNxikuMswTLGeN/fp61mTdoBj+6zR6toHprQ84SveeKJJ1i1ahXLli1j9uzZnHPOOaxatYr27dsD8Prrr9O0aVMKCgoYPHgwF110EfHx8UfsY+PGjXzwwQe88sorXHrppXzyySdcffXVHj0XY4wxpj6oT0MEfwU6i0h7EQkBLgem+jim44p3JVh7cot8HIkxxtStIUOGHEquAJ5//nn69u3LsGHDSElJYePGjce8p3379vTr1w+AgQMHsm3btjqK1hhjjKlbPunBEpEPgNFAgoikAg+p6msi8jvgOyAQeF1VV/siPnfERzpDBLMswTLG1JGqeprqSmRk5KGfZ8+ezffff8/PP/9MREQEo0ePprCw8Jj3hIaGHvo5MDCQgoKCOonVGGOMqWs+SbBU9YrjbP8a+LqOw6mRikMEjTHGnzVp0oScnJxKn8vOziYuLo6IiAjWrVvHggUL6jg6Y4wxpn6pT3Owak1EJgATgBhvHys8JJDIkED2WIJljPFz8fHxjBgxgl69ehEeHk7z5s0PPTdu3Dhefvll+vTpQ9euXRk2bJgPIzXGGGN8T1TV1zF4nIgsUtVBbry0Vid/ytOz6Jscy/NX9K/NbowxxpxYZVVmG6S6ap+MMcbUiUrbp/pU5KLBiY8MYU+ezcEyxhhjjDHGOCzBqoX4qFCycmyIoDHGGGOMMcZhCVYtJESFWg+WMcYYY4wx5hBLsGohISqEvXnFlJXbUHljjDHGGGOMJVi1khAVSrnCvnwbJmiMMcYYY4zxswRLRCaIyCTqoEw7QHyUs9iwlWo3xhhjjDHGgJ8lWKo6TVUnAtl1cbz4SGex4T25Ng/LGGMOioqK8nUIxhhjjM/4VYJV15o1cXqwMi3BMsYYY4wxxgBBvg6gITvcg2VDBI0x/uu+++6jbdu23HbbbQA8/PDDiAhz585l3759lJSU8Oijj3Leeef5OFJjjDHG9yzBqoWY8GCCAoQs68EyxtSFb+6H3Ss9u88WveGsJ074kssvv5y77rrrUII1efJkvv32W+6++26io6PJyspi2LBhnHvuuYhUuqi9McYY02hYglULAQFC08gQ68Eyxvi1/v37k5GRQVpaGpmZmcTFxdGyZUvuvvtu5s6dS0BAADt37iQ9PZ0WLVr4OlxjjDHGpyzBqqV4W2zYGFNXquhp8qaLL76YKVOmsHv3bi6//HLee+89MjMzWbx4McHBwbRr147CwkKfxWeMMcbUF5Zg1VJCVAiZ1oNljPFzl19+OTfffDNZWVnMmTOHyZMnk5iYSHBwMLNmzWL79u2+DtEYY4ypF/wqwRKRCcAE6mgdLHAWG96alVdXhzPGGJ/o2bMnOTk5JCUl0bJlS6666iomTJjAoEGD6NevH926dfN1iMYYY0y94FcJlqpOA6aJyKK6OmZCVAhZuUWoqk3uNsb4tZUrDxfYSEhI4Oeff670dbm5uXUVkjHGGFPv2DpYtRQfFUphSTn5xWW+DsUYY4wxxhjjY5Zg1VJ8pLPYsFUSNMYYY0x9Vl6uqKqvwzDG7/nVEEFfSGjiLDacmVtEm/gIH0djjDHGGHOs7IISzn7uR/bmFdO6aThtmkbQumkEreMiaNM0go6JUbRPiPR1mMb4BUuwaikh0kmw9thiw8YYY4ypp578dh27sgu4cmgb0g8UkbI3n/mb9xwxxeG+cd24dXRHH0Z5fPM3ZREdHkyvpDqrY2ZMjVmCVUsJTVxDBPNsiKAxxviSiAwHrgZOBloCBcAq4CvgXVXN9mF4xnhMebmSXVBCnGuaQlV+3baX9xfu4KaR7fnr+B6Htqsqe/OK2bE3n1fnbeXJb9cRGxHMFUPaeCv0GtmUkct1b/5K26YRTL97VIMrKrZzfwHbs/IY0r4pQYE2O6cxsASrlpq6/rhl5VgPljHG+IqIfAOkAV8AjwEZQBjQBRgDfCEiz6rqVN9FaUztqCoz12bwzPT1bM7M5Y3rhjCyc8IJ31NUWsafP11JUmw4d5/e5YjnRIT4qFDio0L516Ux5BaW8pfPVhIbHsxZvVt65RzKypV1uw/Qo2W0W4lSWbly75TlFJeWszEjlxWp2fRtHeuV2LzloS9W8f3aDBKiQjm3bysuHJBEz1bunb9pmCyNrqXQoECahAVZD5YxxvjWNap6o6pOVdU0VS1V1VxVXaKq/1TV0cB8XwdpTE39vHkPF700n5veXkRhSRltmkZw67uLWbf7wAnf99LszWzKyOXRC3oRGXr879VDggJ46eoB9Gsdy50fLuOnTVmePgVWpmZz/gs/cc7z83hx9ma33vPGT1tZsmM/j5zXk9CgAKYsTvV4XBWpKh/+soOX52xmQ3qOR4qCLE/NZlDbOAa1jePdBdsZ/595nP6vubwwaxM79xd4IGpT34g/VZOpsNDwGFXt7MZbPHLypz4zm+6tonnhygGe2J0xxpgj1ehrXhE5DYgAvlXVkhofXORu4CacNmMlcL1rvx8B7YBtwKWqus+NfS1S1UFuHNZ/GmdzXOXlyr9nbiRlbz6dEqPo0rwJnROjaN00gsAA59d+Rep+nv5uPT9uzKJFdBh3ju3MxQOTycwp4oIXfyJQhM9uH0Hz6LBj9r8pI4ezn5vHuF4teP6K/m7FtD+/mMv+t4DUffm8f/Mwj/QW5RaV8uz0Dbw5fyvxUaF0aR7FT5v28OJVAzj7BD1lW7PyOOu5uYzslMArvxnEnR8uY86GTBY+cBphwYG1jutoqsojX67l9Z+2HtqWHBfOad0SGdMtkWEd4qt93IycQoY8NpO/je/BDSPbsz+/mK9X7uazpan8us35k3H32C7cOdadj62N1+z1GbSICaNbi2hfh3K0Stsnv0qwDqrrBuySl+cTGCB8OHG4J3ZnjDHmSNVOsETkn0AxUA70V9Wza3RgkSRgHtBDVQtEZDLwNdAD2KuqT4jI/UCcqt7nxv4swTKHPD9zI8/O2EBCVAhZFZZ7CQkKoGOzKGLCg1iwZS9xEcHcPqYTVw9re8QH/NVp2Vz68s+0S4hk8m+HH9FDVV6uXD5pAevTc/j+D6fQzFX12B3pBwq56KX55BWV8vEtJ9EpMarG5zh99W4emrqa3QcKuWpoG/50ZjdCgwK48pUFrNl1gI8mDq80iTsY/7rdB5jxh1NoHh3Gjxszuea1X3jhygGc08ezQxhVlb9PW8Ob87dxw4j23DyqPbPWZfLDugzmbcqksKSc8OBATunSjH9c2PvQFJGqzFqfwfVv/MpHE4cxtEP8Ec+l7M3nyW/X8eWKXbx27SBO697co+fkL1L35XPqM3M4qVM8b14/xNfhHK3S9smGCHpAQlSorYNljDE+JCLPiEjF8mJtgAeAv7p+ro0gIFxEgnB6rtKA84C3XM+/BZxfy2OYRmbm2nT+9f0Gzu/Xil//MpYVD5/Bp7edxFMX9eHa4W1pHu18trjztM7MvXcMN53c4Zjek56tYvjvVQNYtzuH372/hNKy8kPPfbQohV+27eUvZ3evVnIF0Dw6jHdvHEpggHDNawtrNIwtbX8BE99exMR3FhMTHsyUW07i0fN7ExMeTFhwIJN+M4iEqFBuensRaZXs/+2ft/HLtr08OL7Hod65kzom0DImjCmLU6odz4mUlysPfrGKN+dv4+aT2/Pg+O60jAnnyqFtePXaQSz72xm8cf1gLhqYxLerdzN5kfvHX73Tqa3To9WxPS+tm0bwzCV96dEymj9MXk7K3nyPnZM/eXbGBorLylmZmt1g1nGzBMsD4qNCyLIy7cYY40ufAR+JyB0iEgi8DSwAlgGTarpTVd0JPAPsAHYB2ao6HWiuqrtcr9kFJNYufNOYbMnM5a4Pl9GjZTSPX9gHESE6LJgBbeK4dHBr/nJOD968fggz/nAKd5/ehSZhwcfd15iuiTxyXi9mrc/koamrUVUyDhTyj6/XMqxDUy4ZlFyjGNslRPLWDUPILSzl8kk/89nSVEoqJHDHk5FTyKNfruHUf85m7sZM7j+rG9PuGMnAtnFHvC4hKpTXrh1MQXEZN721iLyi0kPP7diTz5Pfrmd012ZcPPBw/IEBwoUDkpizIZP0A4U1Oq+jlZcrf/l8Fe8u2MEtp3TkgbO7H1N8Iiw4kDFdE3n0/N60aRrBsh373d7/6rQDtIuPOO6/YVhwIC9dPYDycuV37y+huLTqa9yYrN+dw2dLd9IiOow9ecXsynb/331lajZXv7qQvT6ok2AJlgfER4ayL7/kiG+OjDHG1B1V/UlVxwH7gW9d24aqal9Vfb6m+xWROJzeqvZAKyBSRK6u5j4misgiEVkEnLjkm/F7OYUlTHxnMcFBAfzvmoGEh9R+LtGVQ9tw6+iOvLdwB5PmbuHv09ZQVFrOPy7oXatKdT1bxfDmDYMJCwrk7o+Wc8pTs3ht3tYjkqGD0g8U8vdpqzn5yVm8/tNWzu7dkhl3n8Itp3Qk+Dilybu2aMJ/r+zPut0HuPPDZZSVK+Xlyr2fLCcoQHj8wmPjv2hAMuUKny3dWePzOqi8XPnzpyv54Jcd3D6mI/eN61rl9erXOpZlKfvdPsbqtAP0bHXitbvaxkfy9CV9WJ6azT++XlvlPnOLSpm5Np1py9P4eFEK7y7Yzqs/buGFWZt4dvp6Zq3LcDu+quQXl7J+d47H9lddT3+3jqiQIB6/sDcAK3e6v9rGlyvTmLcpiye/Weet8I7LyrR7QIKr631vXjGJlUwyNcYY412u4XtnAunABcAfRORm4K+quqIWux4LbFXVTNdxPgVOAtJFpKWq7hKRljhl4SulqpNw9aK5kizTSJWXK/dMXs7WrDzeuXEIyXERHtv3n87oSuq+Ah53fZj84xld6NCs5nOnDhrYtinf3TWK2RsyeHnOFh75cg3Pz9zINcPacu1J7SgtL+el2Zv58NcUysqVC/sncfuYTrRLiHRr/6O7JvLQhJ48NHU1T367jtZNI1iwZS9PXNibljHhx7y+Q7MoBraNY8riVH47qkONE8iycuW+T1YwZXEqvz+1E3ef3sWtffVvE8vU5Wnsyi6oNL6KsgtK2LE3n8sGt65yv+N6teSGEe15/aetDG7XtNI5ZqrKd645bekHTjxy6u6xXfj9aZ1qXQr+4amrmbwolbN7t+Av5/QgKfbE5+xJv27by/drM/jTmV0Z3jGewABh1c5szuzZwq33H+xp/GhRCpcObn1ML6o3WYLlAQkH18LKtQTLGGN85HOc4YARwFWqeq2ItAL+T0RUVW+u4X53AMNEJAJn4eLTgEVAHnAt8ITr/ovahW8ag//O2sT0Nek8OL4HJ3X0bGdmQIDw9MV92JNbRG5RKRNHdfTovk/t1pxTuzVnyY59TJqzhRdmb2LSj1tAoVyVSwYlc+spnWgTX/2k8dqT2rE5M5dJc7cQEhjAyZ0TTpiUXDwwmT9/upLlqdn0q2aVw6zcIqYtT2PK4lRWpx3grrGduWtsl6rf6HLweMt27Kdl7xMnG2vSnBL6PSuZf1WZ+8/qxtKUfdz3yQq6t2xyRIK8c3/BofW0ureM5umL+9IqNozQoEBCgwMIDQokLNjpKfzzpyv51/cb2LYnjycu6k1oUM16STMOFPLZ0p30Sormh3UZ/LAug9tHd+LmUcfOB3TX7PUZPDx1NU9e1OeYoh8VqSpPfrOOZk1CuX5EO8KCA+mcGMWKVPd6sErLylmRms2lg5KZuyGLv36+imm/G1FnCz1bguUBB3uw9uTZPCxjjPGRtqo6XkRCcOZeoappwE0i0q+mO1XVhSIyBVgClAJLcXqjooDJInIjThJ2SS3jNw1cdn4JP6xPp0V0OJ2bRxEfGXJE78HBohYX9E/ihhHtvBJDWHAg7900lLJy9doHyQFt4nj5moFsyczlrfnbCAgQbhzZvta9cX8b34Pte/JZsmNfpUMDKzqnT0v+Pm01UxanuJVgFRSXMWNtOp8v3cmcDZmUlSs9Wkbz1EV9uNSN3qWKerSKJiQwgGUp+6tcjHl1mpMMVDVE8KCQoACnQuLzP3Lbe0v4/PYRBAUIb87fxrMzNqAKfzm7O9ePaHfCf99/XtKXDgmRPDN9Azv3FfC/awYS52bVw4re/nk7peXKf68YQHBQAI99tYZ/ztjAx4tT+dv4HpzWPbFaPWSZOUXcM3k5e/KKufGtRbx309DjLgPww7oMFm3fxyPn9yIixElXeifF8MO6DFS1yuOuT8+hoKSMEZ0SGN01kdveW8LbP2/nhpHt3Y63NizB8oD4Qz1YlmAZY4yPTBKRZTjlzf9Z8QlVXVabHavqQ8BDR20uwunNMoZlKfu5/b0lR1Tbi4sIpnNiEzo1j6JdfAT/mbmJnq2iq0weaktECAr03v4P6tAsir+f18tj+wsKDOD16waTW1hKTMTxi3oARIcFM65nC6YuS+Ov5/Q4bm/K7uxC/jl9Pd+s2k1uUSktY8K4+eQOXNA/ia4tmtQoztCgQLq3imapG/Ow1qQdoHl0aLWqOLaKDefZy/px/Ru/8vsPlpK6r4A1uw5wardE/u+8nm4lsiLC707tTJv4SP748XIuePEnXr9ucLWGjOYXl/Luwu2c0aP5oeGeL141kJ82ZfHQ1NXc9PYiRndtxt/P7Unb+KqHg6oq905ZTm5RKe/cOIQ/f7qSa9/4hY8mDj/m36KsXHnq2/W0jY/g8goJcO/kGD5enMqu7EJaVTFU8eA8uf6t42jdNJxRXZrx7IwNnNOnZaVrxnmaFbnwgPgoVw+WlWo3xhifUNX/qGo/Ve2vqu/6Oh7TOKgqb/y0lUteng/AuzcO5Z0bh/C38T0Y16slivLVil384+t1hAYH8PLVA72yQK6/CAyQKpOrgy4e2JoDhaV8vza90uc3pOdw4Ys/MW1FGmf1asH7Nw/lp/tO5f6zutU4uTqof+tYVqZmV1ncbFVattu9VxWN6ZrI78Z0YvqadPbkFfHSVQN47dpB1e4lPLdvKz64eSgHCku58KX5LNyyx+33frJkJ/vzS7jp5A5HbB/RKYFv7jyZv57TnUXb9nHRS/PZlFF1EYx3Fmxn1vpMHji7Oyd3bsb7Nw0jNCiAq15dyNasvCNe+8WynaxPz+GeM7oeUSClV5JzLd0pdLF0x37iI0No3TQcEeH/zu1JcVk5j31VdRERT/CrHiwRmQBMAKr/21wL0WFBhAQGkGk9WMYY4xMi8lfgBVXdd5znTwUiVPXLuo3M+KsDhSXcN2UF36zazdjuiTxzSV9iI5wRLSd3bnbodapKVm4xkaGBh4Y6mdob3jGeVjFhTFmcyvg+rY54buGWPdz89iJCgwOZcstJhz6Ye0r/NrG8OX8b69NzjptAFZaUsTkzz+2CDEe7+/Qu9EmOYXjH+BOW6a/KwLZN+fy2EVz/5i9c/dpCXrpqIGN7nHhB4/Jy5fV5W+nbOpZBlRSGCA4M4KaTO3Bqt0Qum7SAK15ZyIcTh9HxOD1kG9NzeOyrtYzu2ozfDG8LQJv4CN67aSiX/m8BV72ygMm3DCc5LoKi0jL+OX0DPVtFM/6oIZg9Wka7Xehi6Y599Gsde6i3uF1CJLee0pHnZm7kssGtGdHJuwVd/aoHS1WnqepEwP0ajh4gIsRHhVgPljHG+M5K4EsRmSkiT4vIvSLyNxF5R0RW4nz5ttDHMRo/sWpnNhP+M4/pa9J54OxuvPKbQYeSq6OJCM2ahFpy5WHOmljJzD1qTayvVuzimtd+oVmTUD691fPJFVQodHGCYYLrdudQVq416sEC5/zO6NmiVsnVQW3iI/j01hF0axHNPR8vZ1f2iReOnrkug61Zedw0sv0Jh7N2aBbFBzcPRVW58pUFbDuqJwqgqLSM33+4jMjQIJ66uM8R++uU2IS3bxhCTlEpV7+6kIwDhby/cAc79xdw37huBAQcux6ZO4UusgtK2JyZR/82sUdsv3V0R9o0jeDBL1ZRVFp2wn3Ull8lWL6UEBXKHuvBMsYYn1DVL1R1BHALsBoIBA4A7wJDVPXug6XWjampwpIy3pq/jQtfmk9RSTkfTRzGxFEdvTqnyhzfRQOPXBPrtXlb+d0HS+iTHMMnt55E66aeK4NfUZumETSNDDnhgsOrdh4scOFeBUFvi4kI5vkr+lNSVs49k5dTXq7Hfe0rP24hKTacs3pV3fvWKbEJ7900jJIy5YpXFrBjT/4Rz/9z+gbW7jrAUxf1IbHJsXOfeiXF8Ob1Q8jIKeLq1xby3x82MbxDPCd3rryHqXdSDKt2ZqN6/PiXH5x/1ebI3rew4ED+fl5PtmTm8eqPW6s8t9qwBMtD4qNCyLIeLGOM8SlV3aiqb6rq46r6b1X9TlVP/HWtMSeQX1zKVyt2cfv7SxjwyAwemrqaYR3i+er3IxnUrqmvw2vU2idEMqhtHB8vSuGxr9bwyJdrOKNHc969aehxexQ9QUTomxxzwh6s1WkHiAkPJjmu7taNqkr7hEj+Nr4H8zfv4dV5Wyp9zYrU/fyydW+VlQor6tqiCe/eOJSCkjKueGUBqfucJGv+pixe+XELVw5tc8JhiQPbxvHqbwaxbU8+e/KKue+sbsf90qJ3cgx78orZlV1Y6fPgzL8SgT7Jx/YejumayLieLfjPDxtJ2Ztfybs9wxIsD4mPtB4sY4wxxh/kFpXyxbKd3PLOYgY8MoPb31/Cwi17uXBAEu/dNJQ3rxt8qMCV8a2LByazOTOPV37cyrXD2/LiVXVTSKR/mzg2ZeZyoLCk0ufXpGXTs1V0vevdvGxwa87o0Zynv1t/qIx8Ra/+uJWo0CC3FkeuqEeraN69cSg5hSVc8coC1u46wB8mL6d9QiR/Pad7le8/qVMCb98whMcv7H3C0vvuFLpYlrKPzolRxx1e+bcJPQgQ4e/T1lQZV01ZguUhCU1CyMorPmGXpTHGGGPqt69W7OKUp2Zx54fLWLJjH5cNas2HE4ex8IHTePT83ozolHDM3BDjO+f0aUm/1rE8cHY3Hj63J4F19G/Tr3UsqrAi5dgP+iVl5azdnVNvhgdWJCI8cVEf4iJCuPPDZRSWHJ6LlLa/gK9W7uLywa1rNPerV1IM79w4lP15JZzz/I9k5Rbx3GX93Z5/OKxDPFcMaXPC11QsdFEZVWVZyn76tz62OMdBrWLDuWtsZxKiQiguPXElyJqyGZcekhAZSnFpOTlFpUR7YEKiMcaY6hOREar6U1XbjDlaZk4Rf/tiFd+s2k3vpBheuGoAQ9o1tWSqnmsSFsznt4+o8+P2PVToYh8jj5ovtDkzl+LS8hoXuPC2ppEhPHNJX37z+i88/vXaQ+uZvTl/GwDX1WIh7L6tY3nrxiHc/NYibh3dkd6VDNOrjaoKXWzfk8++/BL6HVXg4mgTR3X0aFxHswTLQxKaOGN99+QWW4JljDG+8x9ggBvbjAGcb7w/X7aTv09bQ35xGfeO68rEkzu4Pf/ENE4x4cF0aBZZ6Tys1TsPAPWnwEVlRnVpxg0j2vP6T1sZ3S2Rwe2a8sHCHZzVq0W119s62oA2cfz6l7Fe+3Kid1IMP6zLQFWPGYK5NMVZqePoCoJ1rcoES0TuBN4AcoBXgf7A/ao63cuxNSjxkc5Y7KzcItonVL2itTHGGM8RkeHASUAzEflDhaeicSoKGnOM3dmF/OWzlcxcl0H/NrE8fXEfOiXWbhFa03j0ax3L3A2Zx3zQX5WWTVhwAB2Osy5UfXHvuK7M35zFnz5ewWWDk8kpKj1mYeGa8mbPb+/kGD5enMqu7EJaxR5ZRGTpjv1EhgTS2cf/j935euYGVT0AnAE0A64HnvBqVA1QfNTBHiwrdGGMMT4QAkThfHHYpMLtAHCxD+My9VBJWTlv/7yN05+dw0+bs/jrOd2ZcstJllyZaunfJo6s3GJS9x1ZqHR12gG6u+YK1WdhwYH8+/J+HCgs4YVZmxncLu6EBSbqixMVuliWsp8+ybE+v/buDBE8GOHZwBuqulzqW0mUeqBZ1MEeLCvVbowxdU1V5wBzRORNVd0uIpGqeuyql6ZRU1V+WJfBP75ey+bMPIZ3iOfxC3vTzkaemBro70pGlqbsP7TmVnm5sjbtAOf1b+XDyNzXrUU094/rxv99ucbr85I85WChi5Wp2ZzZ8/BaXYUlZaxJO8DEUZ7phasNdxKsxSIyHWgP/FlEmgDeKbnRgMVFOj1YWdaDZYwxvtRKRL7B6c1qIyJ9gd+q6m0+jsv42Kqd2fzj67XM37yHDgmRTLpmIKf3aF7vymibhqNriyaEBgWwbMd+zu3rJFQ79uaTU1RabwtcVOaGke05s1cLkmLrz5pdJ3Kw0MXRPVirdmZTWq71ohfOnQTrRqAfsEVV80WkKc4wQVNBcGAAcRHB7LEeLGOM8aV/A2cCUwFcoy5G+TQi41O7swt5+rv1fLo0ldjwYB6e0IOrhrUl2IpYmFoKDgygd1IMy1yFFcAZHgjQqwElWECDSa4OqqzQxcGCI1VVEKwL7iRYw4FlqponIlfjVGJ6zrthNUzxUaHWg2WMMT6mqilH9UqUHe+1xr8t3LKH6974lbJy5eaTO3D7mE7EhFulX+M5/dvE8tbP2ykuLSckKIDVadkEBQhdWtTvAhcNXWWFLpbu2E9SbDiJTcJ8HJ17RS5eAvJdwyzuBbYDb3s1qhoSkQkiMgnwydcG8ZEh1oNljDG+lSIiJwEqIiEi8kdgra+DMnUvO7+Euz9aRvPoUGbecwoPnN3dkivjcf1ax1FcWs663U7P1eq0A3RKjCI0yIqXelNlhS6Wpez3eXn2g9xJsEpVVYHzgOdU9Tmcykz1jqpOU9WJQOWrj3lZQpNQsvKsB8sYY3zoFuB2IAlIxRnifrsvAzJ1T1X56xeryMgp4rnL+x8qQGCMpx0cjrZ0x35UldVp2Yc+/BvvqVjoAiD9QCE79xfQv02cjyNzuDNEMEdE/gxcA5wsIoGAfQVUiYTIELJyLMEyxhhfUdUs4Cpfx2F86/NlO5m2PI0/ntGFvvVgwrvxX61iwmjWJJRlKfsZ16sFWbnF9XqBYX9xdKGLpTv2A9SLAhfgXg/WZUARznpYu3G+FXzaq1E1BJtnwY/PHrEpISqUA4WlFJdakUVjjPEFEXlKRKJFJFhEZopIlmv+sGkkUvbm87fPVzO4XRy3ju7k63CMnxMR+reOZVnKflanOR/2G1IFwYasd1IMq3Zmo6osS9lPcKDUm+S2ygTLlVS9B8SIyHigUFXr5RysOrV1Dsx6DEoKD22Kd62FtTfP5mEZY4yPnKGqB4DxOEMEuwB/8m1Ipq6UlpVz90fLAHj20n4+X2zUNA792sSyNSuPeRv3ANC9Zb2cSeN3eifHsCevmF3ZhSzdsY8erWIIC64fc9+qTLBE5FLgF+AS4FJgoYhc7O3A6r1WA6C8FNJXH9oUH2VrYRljjI8dHMJ+NvCBqu71ZTCmbr00ezOLtu/j/87vafOuTJ05OCztkyWptE+IpEmYzaSpCwfnui1L2c+K1OxDCz/XB+7MwfoLMFhVMwBEpBnwPTDFm4HVe636O/dpSyB5IOAMEQRLsIwxxoemicg6oAC4zdVmFVbxHuMHlqXs598zNzKhbyvO75fk63BMI9InORYRyC4oYWTnBF+H02gcLHTxyeJUCkrK6k0FQXBvDlbAweTKZY+b7/NvMckQ2Qx2Ljm0KeFQD5YNETTGGF9Q1ftx1m8cpKolQD5OFVzjx/KKSrnrw6U0bxLKo+f34qh10IzxqqjQILokOsMC68scoMbgYKGLH9Y7aUp9KXAB7iVK34rIdyJynYhcB3wFfO3dsBoAEWeYYFrFBMvpwdpjPVjGGOMzqrpPVctcP+e55hIbP1VWrjw0dTXb9+bz7GX9bK0r4xMHe0+swEXd6p0Ugyo0jQyhTT0aFuxOkYs/AZOAPkBfYJKq3uftwBqEpAGQuR6KcgCICAkkLDiAPVbkwhhjjPG6ORsyOfu5H5myOJVbT+nIsA7xvg7JNFKjuzajSWgQfZMtwapLvV3Xu3/r2HrVc+3OHCxU9RPgEy/H0vC0GgAo7FoO7UYiIsRHhtpaWMYYY4wXrd+dw2Nfr2XuhkxaNw3nhSsHcHbvFr4OyzRi43q1ZGz35gQF2iyaunSw0EV9Gh4IJ0iwRCQH0MqeAlRVbZBp0gDnfucSaDcSgIQmoWRZD5YxxviMiCQBbanQxqnqXN9FZDwlI6eQf83YwEe/phAVGsRfz+nONcPbEhpUP0ozm8bNkqu61ycpht+N6cQlg1r7OpQjHDfBUlUr4l+VyASIaQNpSw9tSogMYVe2FawyxhhfEJEngcuANUCZa7MClmA1cFMWp/LQF6soKi3n2pPa8ftTOxMXGeLrsIwxPhQUGMAfz+zq6zCO4dYQQXMCSf2PKXSxyrWStzHGmDp3PtBVVW2sth8pLi3n0a/W0Kl5E/59WT/aJ0T6OiRjjDku68usrVb9Yd82yHfWsoyPCmFPbjGqlY2uNMYY42VbOLzYsPETP23KYn9+CXeM6WTJlTGm3rMerNpq5ZqHlbYEOo0lPiqU0nIlu6CE2AgbumCMMXUsH1gmIjOBQ71Yqvp734VkamvaijSahAVxchdbxNUYU//5VYIlIhOACUDd1chs1c+537kUOo09YrFhS7CMMabOTXXdjJ8oLClj+up0zurVwopZGGMahCoTrONUE8wGFgH3qOoWbwRWE6o6DZgmIovq7KBhMRDf+dA8rIqLDXdKjKqzMIwxxoCqviUiIUAX16b1qlriy5hM7czZkEluUSnj+7bydSjGGOMWd3qwngXSgPdxSrRfDrQA1gOvA6O9FVyDkTQAtswBDidYWblWqt0YY+qaiIwG3gK24bRZrUXkWivT3nBNW55G08gQTupoiwgbYxoGd4pcjFPV/6lqjqoeUNVJwNmq+hEQ5+X4GoZWAyB3NxxII941RHBPnhWwMsYYH/gncIaqnqKqo4AzgX/5OCZTQ/nFpcxcm8G4Xi0ItjWGjDENhDt/rcpF5FIRCXDdLq3wnJXKg8MLDqctJS4ihACBrBxLsIwxxgeCVXX9wQequgGrKthgzVybQUFJGRP62PBAY0zD4U6CdRVwDZABpLt+vlpEwoHfeTG2hqN5L5BA2LmEwAChaWQIWXk2RNAYY3xgkYi8JiKjXbdXgMW13amIxIrIFBFZJyJrRWS4iDQVkRkistF1b6M6POzLFWk0axLKkPZNfR2KMca4rcoES1W3qOoEVU1Q1WaunzepaoGqzquLIOu9kAhI7HGo0EXz6DC2ZeX5OChjjGmUbgVWA78H7gTWALd4YL/PAd+qajegL7AWuB+YqaqdgZmux8ZDcgpLmLU+k3N6tyQwQHwdjjHGuM2dKoLNgJuBdhVfr6o3eC+sBiipP6ydBqqM6tKMV+ZuITu/hJgIG5lijDF1RVWLcIozPeupfYpINDAKuM51jGKgWETO43Chp7eA2cB9njpuYzdjTTrFpeVM6NvS16EYY0y1uDNE8AucdaW+B76qcDMVtRoABftg31bO6NGc0nJl1voMX0dljDGNgohMdt2vFJEVR99qufsOQCbwhogsFZFXRSQSaK6quwBc94nHiW2iiCxyLSFiK+W6adryNJJiw+nf2kZeGmMaFnfKtEeoqn0jV5WDhS52LqFvz4tIbBLK9DW7Ob9/km/jMsaYxuFO1/14L+w7CBgA3KGqC0XkOaoxHNBVfXcSQJ2u09iA7c8v5seNWdwwsj0BNjzQGNPAuNOD9aWInO31SBq6xB4QFAZpSwkIEE7v0ZzZ6zMpLCnzdWTGGOP3DvYkAbep6vaKN+C2Wu4+FUhV1YWux1NwEq50EWkJ4Lq3YQse8t3q3ZSWq1UPNMY0SO4kWHfiJFkFInJARHJE5IC3A2twAoOhRW9IWwrAGT1bkF9cxvzNWT4OzBhjGpXTK9l2Vm12qKq7gRQR6eradBpO8YypwLWubdfiDKk3HjBt+S7axkfQKyna16EYY0y1VTlEUFWb1EUgfqHVAFj6LpSXMbxDPE1Cg5i+Op1TuzX3dWTGGOPXRORWnJ6qDkfNuWoC/OSBQ9wBvCciIcAW4HqcLykni8iNwA7gEg8cp9HLyi1i/uYsbh3dEREbHmiMaXiOm2CJSDdVXSciAyp7XlWXeC+sBqpVf/jlf5C1gZDE7ozulsj3a9MpK1crMWuMMd71PvAN8DhHzo/KUdW9td25qi4DBlXy1Gm13bc50jcrd1GuMKGvDQ80xjRMJ+rBugenPPs/K3lOgVO9ElFDVqHQBYndOaNHc6YtT2Ppjn0MameLJBpjjLeoajaQDVwBICKJQBgQJSJRqrrDl/EZ901bsYtOiVF0bW4DaIwxDdNx52Cp6s2u+zGV3Cy5qkx8ZwhpcmjB4dFdmxEcKExfk+7jwIwxpnEQkQkishHYCswBtuH0bJkGYHd2Ib9u28uEPq1seKAxpsE60RDBC0/0RlX91PPhNHABAdCqn9ODBTQJC+akjgl8t3o3fz6rmzUWxhjjfY8Cw4DvVbW/iIzB1atl6r9Pl6aiCuNtcWFjTAN2oiqCE1y3G4HXgKtct1eBq70fWgPVqj+kr4LSYgDO6Nmc7Xvy2ZiR6+PAjDGmUShR1T1AgIgEqOosoJ+PYzJuyMot4qVZmxnVpRkdm0X5OhxjjKmxEw0RvF5Vr8eZb9VDVS9S1YuAnnUWXUOUNADKiiFjNQCnd2+OCHy3arePAzPGmEZhv4hEAXNxqv49B5T6OCbjhqe/XU9BSRl/G9/D16EYY0ytuLMOVrsKCzgCpANdvBRPw9eqQqELIDE6jP6tY20eljHG1I3zgALgbuBbYDPOaAxTj61I3c/kxSlcP6IdnRKt98oY07C5k2DNFpHvROQ6EbkW+AqY5eW4Gq7YNhARDzsWHNp0Rs8WrNyZTdr+Ah8GZowx/k9V81S1TFVLVfUtVX3eNWTQ1FPl5crDU1cTHxnCHad19nU4xhhTa1UmWKr6O+BloC/OOPZJqnqHl+NquESgx/mw+lPYuxWAM3o4Cw3PsF4sY4zxChHJEZEDx7v5Oj5zfJ8v28mSHfu5d1w3osOCfR2OMcbUmjs9WADzgR+AmcBP3gvHT5xyLwQEw6zHAOjQLIpOiVFMX2PzsIwxxhtUtYmqRgP/xlloOAlIBu7DqSxo6qHcolIe/2YdfZNjuHhAsq/DMcYYj6gywRKRS4FfgIuBS4GFInKxtwNr0Jq0gGG3wsqPYdcKwOnFWrBlL9n5JT4Ozhhj/NqZqvqiquao6gFVfQm4yNdBmcr994dNZOYU8fC5PQkIsKVMjDH+wZ0erL8Ag1X1WlX9DTAEeNC7YdWMa4HJSUCMr2NhxJ0QFgsz/w9w5mGVlSs/rLdhgsYY40VlInKViASKSICIXAWU+Tooc6ytWXm8Nm8LFw9Mpn+bOF+HY4wxHuNOghWgqhkVHu9x8311TlWnqepEINvXsRAeCyf/ATbNgG3z6JMUQ/PoUKavtgTLGGO86Eqc0Rbprtslrm2mnnnkyzWEBgVy77iuvg7FGGM8yp1E6dsKVQSvw6ki+I13w/ITQyZCk1bw/cMECJzeozlzNmRSWGJfphpjjDeo6jZVPU9VE1S1maqer6rbfB2XOdKsdRn8sC6D35/WicQmYb4OxxhjPMqdKoJ/Av4H9MGpJDhJVe/1dmB+ITgcRt8Pqb/Cuq84o0cL8ovLmL0+09eRGWOMXxGRe133/xGR54+++To+c1hxaTn/9+UaOiREct1J7X0djjHGeFxQVS8QkfbA16r6qetxuIi0s28E3dTvKpj/H5j5fwyb+BPJceH8a8YGxnZPJCiwXo60NMaYhmit636RT6MwVfpu9W62ZuXx6m8GERJk7aAxxv+485ftY6C8wuMy1zbjjsAgOO1ByFpPyOqP+Os53VmfnsP7v+zwdWTGGOM3VHWa6/6tym6+js8c9sWyNFpEhzGmW6KvQzHGGK+osgcLCFLV4oMPVLVYREK8GJP/6X4utBoAsx7nzDsu4qSO8fxz+gYm9GlFXKRdSmOMqS0RmQbo8Z5X1XPrMBxzHNn5JczZkMG1w9sRaGXZjTF+yp0EK1NEzlXVqQAich6Q5d2w/IwIjH0Y3j4X+fU1HppwLWc9N5dnZ2zgkfN7+To6Y4zxB8/4OgBTtW9W7aKkTDmvX5KvQzHGGK9xJ8G6BXhPRP4LCJACXOPVqPxRh1Ogwxj48Z90HXANVw9ry7sLtnPVsDZ0axHt6+iMMaZBU9U5vo7BVG3q8jTaJ0TSK8naPWOM/3KniuBmVR0G9AB6qOpJqrrZ+6H5obEPQcFemPE3/nB6F6LDg/n71DWoHndUizHGmGoQkc4iMkVE1ojIloM3X8dlIP1AIT9v2cO5fVshYsMDjTH+y+3yPaqaC3zgxVj8X6v+MOJOWPwmsVumcc/pXfh5yx6+XbXb15EZY4y/eAN4CSgFxgBvA+/4NCIDwJcrdqEK5/Zr5etQjDHGq6pbH9UGTdfWqQ9C8hCYeidXdCqlW4smPPrVWlt82BhjPCNcVWcCoqrbVfVh4FQfx2SAqct20ispmo7NonwdijHGeFV1E6ylXomiMQkMhotfh4BAgj65nofO7sjO/QW8MtdGsBhjjAcUikgAsFFEficiFwBWD9zHtmXlsTw1m3P7Wu+VMcb/uZVguRYX7qqqN3g7oEYhtjWc/xLsXsHwTf/mrF4teHH2ZnZlF/g6MmOMaejuAiKA3wMDgauBa30ZkHGKW4jABEuwjDGNQJUJlohMAJYB37oe9xORqV6Oy/91OxuG3Q6/TOKRLlsoV+Xxr9f5OipjjGnoSlU1V1VTVfV6Vb1IVRf4OqjGTFX5YtlOBrdrSsuYcF+HY4wxXudOD9bDwBBgP4CqLgPaeSugRmXsw9BqAAkz7+FPQ0KZujyNr1fu8nVUxhjTkD0rIutE5BER6enrYAys2XWAzZl5nGfFLYwxjYQ7CVapqmZ7PZLGKCgELnkDgBt2P8KQ1pHcM3k5q3ba5TbGmJpQ1THAaCATmCQiK0Xkr76NqnGbuiyNoADh7F4tfR2KMcbUCXcSrFUiciUQ6Fpf5D/AfC/H1XjEtYPz/kNA2hLebPMNsRHBTHx7EZk5Rb6OzBhjGiRV3a2qzwO34Axx/5tvI2q8ysuVacvTGNWlGXGRIb4Oxxhj6oQ7CdYdQE+gCHgfyMaZRGw8pcd5MPhmIha/zLRO08jJz+O37yyiqNRKtxtjTHWISHcReVhEVgH/xflCMNnHYTVai7bvIy270KoHGmMalSA3XtNVVf8C/MXbwTRq4x6HwGASFrzIj/G/MiHlRh74NIpnLuljK94bY4z73gA+AM5Q1TRfB9PYTV2+k7DgAE7v0dzXoRhjTJ1xpwfLJgzXhcBgJ8m67D1iC1KYEfEgucs+5dUft/o6MmOMaTBUdZiqPmfJle+VlJXz1YpdjO3enMhQd77PNcYY/1BlgmUThutY9/Fwy1xCm3fhfyH/Jnj6/cxeneLrqIwxxphqmbcpi335JZzXL8nXoRhjTJ1ya6FhmzBcx+LaITd8R8ngW7gu6DuaTT6XbRtX+ToqY4wxxm1Tl6URHRbEqC4Jvg7FGGPqlDsLDduEYV8ICiH4nCfZM/4NWks6se+NY/fGJb6OyhhjjKlSYUkZ01fv5qxeLQkNCvR1OMYYU6fc6cF6A9iHM2H4FFV9SVUzvByXcYkfdCG7LvmaYoIIee98Ujcu83VIxhhTb4lIFxF5RUSmi8gPB2++jquxmb0+k7ziMsb3tbWvjDGNT5WzTlV1WF0EYo6va89+bJJPiZ18AaHvnc+2K76gXde+vg7LGGPqo4+Bl4FXAI+tdSEigcAiYKeqjheRpsBHQDtgG3Cpqu7z1PEauq9W7iIuIpjhHeJ9HYoxxtS54/Zgichk1/1KEVlR4bZSRFbUXYgGoFOPAeRd9glBlBH2wQVsWLfS1yEZY0x9VOoaafGLqi4+ePPAfu8E1lZ4fD8wU1U7AzNdjw3O8MCZa9MZ16slQYFuTfU2xhi/cqK/fHe67scDEyrcDj42daxt90HkX/4JERQR+eEFrF672tchGWNMfTNNRG4TkZYi0vTgrTY7FJFk4Bzg1QqbzwPecv38FnB+bY7hT2avzyC/uIxzetvwQGNM43TcBEtVd7l+vE1Vt1e8AbfVTXjmaEndhpB/+RSiyaPJhxewbPUaX4dkjDH1ybXAn3AKMi123RbVcp//Bu4Fyitsa36wnXTdJx7vzSIyUUQWicgiwO9L6n25YhdNI0MY1qFWea0xxjRY7vTdn17JtrM8HYhxX4tuwym+fArxcoDoyRcxf6kNFzTGGABVbV/JrUNN9yci44GM2gwzVNVJqjpIVQcBWTXdT0NQUFzGD+syGNerhQ0PNMY0Wieag3WriKwEuh01B2srYJ/ofSy+2wiKL/uIlrKXfp+fxqKXJ1Kyd7uvwzLGGJ8SkWAR+b2ITHHdficiwbXY5QjgXBHZBnwInCoi7wLpItLSdcyWgFXXxYYHGmMMgKhq5U+IxABxwOMcOXk3R1X31kFsNSYii1zfFFal8pNvQAp3rWPVRw/Rd98MRKCo+0VEjrkHErv5OjRjjPEUcfuFIq8CwRyeH3UNUKaqN9U6CJHRwB9dVQSfBvao6hMicj/QVFXvdWMfft0+/e79Jfy8eQ8LHzjNerCMMY1Bpe3Tccu0q2o2kC0izwF7VTUHQESaiMhQVV3onThNdYS17Maguz5i+vxfSf/uWS5e+wWsnQxdz4GRd0HyYBC3P5sYY0xDN1hVK65j8YOILPfCcZ4AJovIjcAO4BIvHKNBKSguY+baDC4YkGTJlTGmUatyHSzgJWBAhcd5lWwzPnbGSYPZ1uVVbnpvNoMzpzBx0/dErP8KopOhw2jX7RSIOu48bGOM8QdlItJRVTcDiEgHPLQelqrOBma7ft4DnOaJ/fqL2eszKCgpY7wNDzTGNHLuJFiiFcYRqmq5iLjzPlPH2iVE8sbtZ/Hkt+0ZNG88v226hBsSttBk3Zew7F3nRYk9nGSr8xnOvfVuGWP8y5+AWSKyBWfoRlvget+G1Dh8uXIXCVEhDGlv1QONMY3bcedgHXqByKc439i95Np0GzBGVc/3amS14O9j3N0xc206f5qygpzCEu4Y3YFbu+UTvH0ObJkNOxZAaSF0Gw/nPAtNmvs6XGOMOZFqfRMkIqFAV9f71qlqkVeiqgF/bZ8KissY8MgMLhyQxGMX9PZ1OMYYU1cqbZ/cGSR9C3ASsBNIBYYCEz0Xl/GG07o3Z8bdoxjXqyXPztzMhE9yWdHuevjNF3Dfdjj9Edg4A14cCiunQBWJtjHGNBSqWqSqK1R1eX1KrvzZLNfwwHP62PBAY4ypsgerIfLXbwhrasaadP7y2Uqycou4eVQH7h7bhbDgQMjcAJ/fCjsXOb1Z4/9lc7SMMfWR34xl9tf26fb3lrBw6x4WPjCWwAC/+ecyxpiqVPoH70Rl2u9V1adE5D9U8odeVX/v2fgq55qg/BcgRlUvdvM9ftmA1UZ2QQn/+GotHy1KoUNCJE9c1McZJ19eBj//F354DEIi4OxnoNdFNjfLGFOf+M0fJH9sn/KLSxn4yPdcNDCJR8+34YHGmEal2kME17ruFwGLK7lVfUSR10UkQ0RWHbV9nIisF5FNrvVDjktVt6jqje4czxxfTHgwT17ch3dvHEpxWTmX/u9n7p2ynL0FZTDiTrjlR2jaET65Ed48B356DnatgPJyX4dujDFuE5FPROQcEbE64XVk1rpMZ3hg71a+DsUYY+oFrw4RFJFRQC7wtqr2cm0LBDYAp+PM6foVuAIIxFnUuKIbVDXD9b4p1oPlGXlFpTw/cyOvzdtKVFgQ957ZjcsHtyZAy2Dhy7D0Xch05dcRCU559w5joOMYiEn2bfDGmMaoOgsNj8WpGjgM+Bh4U1XXeSuw6vLH9skZHriXhQ+cZsMDjTGNTbWHCE7jBH/gVfVct44q0g74skKCNRx4WFXPdD3+s2t/RydXR+/nhAmWiEzkcPGNBFVt50Z4DaYB84YN6Tk8+PkqFm7dS9/WsTx6Xi96J8c4Tx7Y5VQc3DLLuc9Nd7b3OA/G/xsirAyvMabOVPtTu4jE4Hx59xcgBXgFeFdVSzwcW3Xj8qsEK7+4lAGPzOCSga155Pxevg7HGGPqWrWHCD4D/BPYChTgNE6v4PRIrTrB+6qShNPYHZTq2lYpEYkXkZeB/geTscqo6iRVHeRquLJqEV+j0aV5Ez6cOIx/X9aPnfsKOPeFeTz4+Sqy80sguiX0uwIunAT3rIdb58Ooe2Hd1/DySNg2z9fhG2NMpUQkHrgOuAlYCjwHDABm+DAsvzRrXSaFJeVWPdAYYyo47oLBqjoHQEQeUdVRFZ6aJiJza3HMyjK9E/WU7cEpFW+8QEQ4v38SY7ol8q8ZG3j75218tnQnFw1I4prhbemU2MQpeNG8p3PrehZ8chO8OR5G/RFOuQ8Cg319GsYYAxxau7Eb8A4wQVV3uZ76SEQW+S4y//T1yl0kRIUyuJ2NajDGmIPcmQTczFXJDwARaQ80q8UxU4HWFR4nA2m12J/xgJjwYB4+tydf3nEyp/dozge/pDD22blc+coCvl21i9IyV7GLpAHw27nQ7yqY+zS8cRbs21a9g5WVOj1hH10Nn9wMezZ7/HyMMY3Wf1W1h6o+XiG5AsDNoXnGTYUlZcxan8GZPZvb3CtjjKmgyiIXIjIOmARscW1qB/xWVb9z6wDHzsEKwilycRrO4sW/Aleq6uoaxH+8Y/rVGHdfyMot4qNfU3h/4Q527i+gRXQYVw5tw2WDW9M8Osx50cop8OUfAHXKu/c4D4LDjr/TPZth6Tuw7API3Q2RiVCcB2VFMPB6pzcsqja5uzHGT1WnyMXtwHuqut/1OA64QlVf9FJs1eJP7dPMtenc+NYi3rphCKd0sb/dxphGqXpFLo54kUgozpALgHWqWuTWEUU+AEYDCUA68JCqviYiZwP/xqkc+LqqPubO/tzlTw2Yr5WVKzPXpvPOgu38uDGLAIFTujTj4oGtGdsjkdCcVPj0ZkhZCAhEJ0HT9q5bB4hrDyUFsOw92PYjSAB0PhMG/AY6nw75e2HOk7D4TQgOd0rGD78dQiJ9ferGmPqjOgnWMlXtd9S2para3+NR1YA/tU/3TVnB1yt3sfjB0wkJsqr4xphGqWYJlohEAH8A2qrqzSLSGeiqql96PsbaEZEJwARgjKp2duMt9b4Bq0+2ZuUxZXEKny7Zya7sQmLCgzmvXysu7t+C3gd+RLLWw96tsHcL7NsKeZmH3xzXHgZcA32vdApoHC1rI8z8O6ydBlHNYfSfoc+llmgZY6B6CdYKoK+6GjfX0iArVLWnt4KrDn9JsMrKlSGPfc+ITgk8f0W9yF2NMcYXapxgfYSzsPBvVLWXiIQDPx/9DWF94i8NWH1VVq78tCmLKYtT+W71bopKy+navAnj+7TkrN4t6ZQY5bywKMdJuMpKoFV/CHDjG84dC2HGg4d7xOI7QvNe0KIXtOjj/BzdClSh6AAU7DvyFhYLnU5zCnMYY/xFdRKsp3GGsr+M8zf+FiBFVe/xTmjV4y/t06/b9nLJyz/z3yv7M76PLTBsjGm0apxgLVLVQRWHWIjIclXt64UgPcJfGrCGILughC9XpPHZkp0s2r4PgC7NozirV0vO7t2SLs2jkOomO6rO2lspv8DuFZC+6shCGsGRUFoIWlb5+1sPhTMfh+SBNTonY0y9U50EKwD4Lc48XwGmA6+qHu8PRt3yl/bp0S/X8PbP21n84FiahFklWWNMo1XjBGs+TkP1k6oOEJGOwAeqOsTzMXqGvzRgDc3u7EK+W72br1fu4pdte1GFDs0iOatXC07r3py+ybE1rzRVeADSVzvJ1p7NztDB8DhnwePwONetKaQsgJmPQF4G9L4Uxj4EMcmePVFjTF3zmy5pf2ifVJVTnp5Nx2aRvHF9vf0oYIwxdaHGCdbpwF+BHjjfBI4ArlPV2R4O0GP8oQFr6DJyCpm+Op1vVu1iwZa9lJUr8ZEhjO6ayGndEzm5c4L3vvUsyoF5/4L5/3WKapx0h1M8IzTKO8czxnhbdXqwOgOP47RZh8qaqmqH476pDvlD+7Ru9wHG/ftHHr+wN1cMaePrcIwxxpeqn2C5hlpcDMwEhrl2skBVs7wRoaf4QwPmT7LzS5izMZMf1qYza30m2QUlBAUIQzs0ZWCbOFrGhtMiJoyWMWG0jA4nOjyo+sMKK7N/B3z/MKz6BKJawBmPQO9Laj8/q7wcVn8Khdkw+Mbax2mMqUp1Eqx5wEPAv3CKHl2P09Y95KXYqsUf2qfnZ27kX99vYOEDp5HY5ARLcxhjjP+rcQ/WXFUd5ZWQvMQfGjB/VVpWztKU/cxcm8EP69LZmJHL0b+C4cGBtIwJ46KBydx8cofal//dsRC+vR/SlkCXcTD+X06hjJpI+dXZ185FzuNL34Ee59YuPmNMVaqTYC1W1YEislJVe7u2/aiqJ3svPPf5Q/t0zvM/EhYcyCe3nuTrUIwxxtdqnGA9CBQAHwF5B7er6l5PRucJVqa94SkpKycjp4jd2YXszi5kV3YBu7MLWbc7h3mbsuiUGMWj5/diWIf42h2ovAwWvuzMzwoMhjMfg/7XuN+blZ3q9Iat/NjpDTvtQfj1Vaf4xq0/V1563p+UFMBXf4TOY6HnBb6LI+UXmHoH/OYLaNLCd3GYuladBOsn4GRgCvADzoL2T6hqVy/FVi0NPcFK3ZfPyCdn8cDZ3Zg4qqOvwzHGGF+rcYK1tZLNWl/Gs1emoTdgxjFrXQYPfrGK1H0FXDwwmQfO7k7TyJDa7XTPZpj6e9g+DzqMgXOfh9gTzCEozoOfnoOfngfUNZ/rLmc+V9ZGePlkaDscrvrEvTL0DVF5OUy5HtZ8Dgic9wL0v8o3sbxxjvNvN/7fMOh638RgfKE6CdZgYC0QCzwCRANPq+oC74RWPQ29fXrjp638fdoaZv1xNO0TbJ1CY0yjV7MEqyFq6A2YOayguIznf9jIK3O3EBUWxANndeeSQcm1m6NVXg6LXoMZDzk9WKc9BC37QG4G5KY7CyTnpjuPdy6B3N3Q6yIY+/Cxydivr8FXf4BxT8KwW2p1rvXWD4/B3Kdg9ANOlcbNP/gmwdk2D948x/m5+wS47N26Pb7xJbf+w7sWFX5CVf/k5XhqrKG3T1dMWsCevCKm332Kr0Mxxpj6oMY9WGHAbcBInD/4PwIvq2qhpyP0lIbegJljrd+dw18+W8mi7fsY2DaOsd2b06NVND1bRZMQFVqzne7bDtPuhC2zjnpCIDIBopo7CdWIu6DN0Mr3oQofXA6bZ8Fv50Bi95rFUl+tmAyf3gz9robz/gulRTD5Gtg4Hc56GoZOrLtY3poAGeugw2jY8B3cuwUCg+ru+I3dvm3QpBUE1bIXuWaq04P1A3Ca1tNvDxty+7Qvr5hBj33Prad05I9n1osRl8YY42s1TrAmAznAwa+LrwDiVPUSj4bnQQ25ATPHV16ufLw4hRdmbWbH3vxD25tHh9KjZTQ9W8UwtENTRnZKcL+H6+CixuVlEJXoJFUR8dX74J6bCS8Nd+Zm3TwTgmqY8NU3Kb/Am+MheRBc8/nhD9alRfDx9bD+KzjjMTjpd96PZfvP8MY453gxyfDxtXDDd9BmmPePbZzf8X/1hFP/4ix5UPeqk2D9E+gMfMyR84Y/9UJc1daQ26cpi1P548fLmfa7kfROjvF1OMYYUx9U2j658ymyq6r2rfB4logs90xMxrgvIEC4bHAbLhvchuz8ElbvymZN2gHWpB1gddoB5m7M4r+zNjG8Qzx/m9CD7i2jq96pCHQcU7vAoprBuf+FDy6DHx51ysHXZ4XZsHMxtB15/N6IfdvhwyudaouXvXvk64JC4dK34JObYPpfoKwYTv6Dd2Oe8yRENoNBN0BZkbO+2aaZlmDVlQ3fOtd92zxfJVjV0RTYA5xaYZsC9SLBasimr95Ny5gweiW58bfVGGMaMXcSrKUiMuzgBGERGQr85N2wjDmxmIhgTuqYwEkdEw5tKywp4+NFKTw7YwPnPP8jlw1uwz1ndKn5EMLq6DrO+fA//z/Q+XRoX82VDVSdXjRvD3nL2Q3vXAAZa5yeuj6XOwUrmvc8/JrCA86wx9JiuG4yRDQ9dj+BwXDRa879zL9DWQmMvs87Maf84gzjPP0RCIkAIiBpEGye6fSoGO9b95Vzn/qr87vqiXXqvERVrfqJFxQUlzF3YyaXDWrtmXUKjTHGj7nzaW4o8BsR2eF63AZYKyIrcaoJ9vFadMZUQ1hwINcMb8e5fZP498wNvPPzdr5cnsYdp3XiupPa1349raqc8Rhs/RE+uwWu+QyKcpyEJmeXUzQjZ5dTOKMoB4pznQqFFW8BgdCiNyQPgdZDoPVQZzicpz7M7N0Cb58P+Xuc+VPb58Evk2DBC9CqP/S/GnpeCJ/9FjLXw9WfQLMux99fYBBc8D8ICIbZ/4CEztDrQs/EWtGcJ51ksOKizp1Og9lPQP7eyhNA4znFeU6CG5kIeRmwZ5Pzb11PicgbVDK8TlVv8EE4fmPuxkwKS8o5o6ctj2CMMVVxZw5W2xM9r6rbPRpRLdg6WKaiTRm5PPbVGmatz6RdfAQ3jGxPv9axdGsR7b1kK20pvDoWykuP3C4BzgfUqEQIi4HQJhAS6bpFOfelRc7QvZ2LocQ1x6xJKyfZat7LGYoYedQtJNK9BGz3Knj3Qqen6eopkDTQ2Z63x1nba+k7kL7KiVPL4Zxnj0xoTqS8DCaNdhK3239xSth7SupiePVUp4LjyLsPb0/5FV4bCxe/7lR4NN6z9kv46Co4+xn4+o9w3ou+KNNfnTlYFX8hwoALgDRV/b3Ho6qBhjoH657Jy/l+bTqL/jqW4EA/XZLCGGOqz8q0V8L/Tt4cY/b6DP7x9Vo2pOcCEBIYQPdW0fRLjqFPcix9W8fSsVmk54a97FgImWuhSUunaEaTFk4yFBDo3vvLSp1kJ+UXSFno3LJTKn9tUDi0GwlDboZOYys/xo4F8N6lTuJzzWfQrJLqX6qwazkse9+ZdzXyLrdP1znGQnj9DBj5Bxj7UPXeeyLvXeoMS7tr5ZGJW3kZPNUBuo2H81/w3PHMsT671Slo8sdN8EwnZ6HpCc/VdRQ1/s8pIgHA96p6apUvrgMNsX0qLStn0GPfc2rXRJ69rJ+vwzHGmPqkxkUujGnQRndN5JQuzdi5v4AVqdksT9nPspT9TFmcyls/Ox2wSbHhnNGzOWf2bMHgdk0JDKhFstVm6PHLursjMAha9XNuB8uglxRCfpazRlfewftMyN4Ja76A9y+F2LZOr1P/aw4Pm9swHSb/BmKSnEqAsa0rP6bI4WPWRJuh0PdKZw5av6sgoVPN9lPRziWw8Ts49cFje8UCAp1y7Ztn1vs5QQ1aWalT4KLzmU6hk+TBTuLfsHTGGdpuauiXbXvZn1/CGT2b+zoUY4xpECzBMo2CiJAcF0FyXARn924JQFm5sjkzlyXb9/H92nTeW7iDN37aRtPIEMZ2T+TMni0Y0SmBsGA3e568KTjMmY8Vk3zsc2c+Bmunwa+vwoy/wax/OMPmEnvA9w85BSyu+sQZYuhNYx+GdV/Ct/fBVVNqn/TMfRrCYmHIcdba6nQarPkcMtZC8x61O5apXMpCKNgL3VwLPCcPgdmPO5Uow+pnmW4RyeHI3p/dgJcqsDQOb/y0jSahQYzq4uW/IcYY4ycswTKNVmCA0KV5E7o0b8LlQ9qQV1TKnA2ZfLd6N9+s3M3kRamEBgXQKTGKzolRdEqMolNiEzolRtE2PqL+zEMIDHaKS/S6ENJXO4nW8o9g2XtOKfYrPoCwOiir3KQ5jP4zfPdnWP/14Q/lNbFrubOPMX85fuwdT3PuN89sGAlW5gYn+Rz35ImLh9Qn67+GwBAnmQVoPRhQZ55gx3ox4u4YqtrE1zH4k6U79jFjTTr3nN6FiBD7yGCMMe6wOVjGVKK4tJyft+xh7oZMNmbksjkjl537Cw49HxwoJMWGExsRQlxEMHERIYd+jo0MoV9yLL2Son1XzrgwG7bOdeZlBYfX3XHLSuDlk6Ekzyl4UdNjf3gVbPvRmXt1op6SF4Y6c91+83nNjlNXcjPg1dNg/w4YfDOc84yvI6qaKjzfD+I7O4VRwCnh/0QbJ5H2Vln+ylWnyMUFwA+qmu16HAuMVtXPvRNa9TS09umqVxewblcOc+8dQ2SoJVjGGHMUm4NljLtCggI4pUszTqkwJCa3qJTNGblsyshloyvh2p9fTGZuERvSc9mfX0xecdmh13dOjOKigclc0D+J5tFhdXsCYTHQfULdHhOc3rSzn4K3JsBPz8Ho+6u/j2XvO0MNRz9Q9TC0jqc5PXbF+a41suqh4jxnjlxellMOf/VnMO5x51rVZxlrYd+2IxcWDouGxO6QWq/nYT2kqp8dfKCq+0XkIeBz34XUMP20KYufNu3hb+N7WHJljDHVYH8xjXFTVGgQfVs7VQePp6i0jL15xfywLoNPFqfyxDfreOrbdYzs3IyLBiRxZs8W9WNOlze1H+WspzXvX9D3cohr5/57N82EqXc4BSwqlmU/nk6nOut4bZ8PncfWNGLvKS+DKTc6Qx4vf995/NFVsGVO/Yy3ovWuxYW7nn3k9tZDnCSxvBwC6skw2SNVFlSt2joRaQ28DbQAyoFJqvqciDQFPgLaAduAS1V1X22OVV+oKk99t55WMWFcOdRqhBhjTHXUy9bRmIYqNCiQljHhXDW0LZ/eNoIf7jmF28d0YnNGLnd+uIzBj37PXR8u5euVu8gtKq16hw3VGY+CBMK3D7j/nl3LnYqHzbrDpe84Veuq0nYEBIU587DqUkmBs8jxiajCN/fChm/grKeg61nQ+XQIjXHWHqvv1n0FSYOcZQYqSh7iDEHds9E3cVVtkYg8KyIdRaSDiPwLWFzLfZYC96hqd2AYcLuI9ADuB2a61l2c6XrsF2asSWd5yn7uGtvF/78UMsYYD/OrBEtEJojIJKB+lrcyjU6HZlHcc0ZXfrx3DO/fPJSzerdgzoZMbntvCQP+bwbXv/ELH/yyg8ycIl+H6lkxSXDKn5xekI0zqn79vu3w3iVO1cCrPna/KEdwOLQ9yen5qislhfDmeHimC3x2C+xeWfnr5v/HGb540u+ddcoAgkKhx7nOEMji/LqLuboOpDmLZnc7+9jnWg9x7lMW1m1M7rsDKMbpWZoMFAC312aHqrpLVZe4fs4B1gJJwHnAW66XvQWcX5vj1Bdl5coz09fTISGSCwck+TocY4xpcPxqiKCqTgOmicgiX8diTEUBAcJJHRM4qWMCpWXlLN6+j+lr0pm+ZjezPl3JA7KSPkkxdGnehPbNIumQEEn7BKdaYYP99njYbbD0XZj6e6eEe68LK593lL8X3rsYSgvhhqkQ3bJ6x+l4Gkz/C2SnVl7GPn8vfDoRcnc7PV5tRzhJWWRC9c9JFb68G3Yuckrhr5kKyz9whjQOv8OpticCqz6FGQ86i/KO/fuR++h9CSx9x1njq+cF1Y+hLqz/2rnvWkklyPhOEB7nrIc14Dd1G5cbVDUPL/YkiUg7oD+wEGiuqrtcx90lIoneOm5dmrp8JxvSc/nvlf0Jqi/VUo0xpgGxKoLG+JCqsj49h+mr05m/OYstmXlkVOjNEoFWMeG0T4ikXUIE7eIjXT9H0jougpCgev7hZ+di+Px2yFwLsW2c3px+Vx0uSFFSCG+fB2lLnIWQ242o/jEy1sKLw2DC8zDw2iOfO5AG71wAe7c6PS+pi6DUVQ2yWTcn0Wo3ErqNd3qXqrLgJfj2fjjlfhjzZyjYB4vfhIX/g5xdzvDGXhc5a3glDXDOKfioAiflZfBsD0geBJe/V/3zrQvvXOgUuLhjceXrmb13iVMR8fY668WqThXBGcAlqrrf9TgO+FBVz6x1ECJRwBzgMVX9VET2q2pshef3qWpcJe+bCBxc0C1BVdu5cTiftE/FpeWMfXYOUaFBfHnHSAJqs+i6Mcb4v0r/SFqCZUw9k1tUyrasPLZk5bE1M48tWblsy8pja1YeBwoPz9sKEEiKC2dAmzjGdE1kVJdmNI10Y95SXSsvd3prfnzWqT4XkQDDboFBN8K0O51Fki95o+a9OapOwtJ6MFz69uHte7c4yVv+XrjiQ2h/MpQWw65lsG2eUxhjxwIozoHkwc68rxP1nm2eBe9e5MyluvSdIws8lBbD6k9h/n8hfaXTy3PjDIhoWvm+vn0Afn0F/rjB6Q2qTwqz4amOzr/RGY9W/po5T8OsR+G+7RAeWxdRVSfBWqqq/avaVu0ARIKBL4HvVPVZ17b1OCXgd4lIS2C2qnatYj/1un16d8F2/vr5Kt64fjBjuvpFh5wxxniTJViV8L+TN35LVdmXX8LWrDy278ljW1Yem7PyWLB5D3vyihGBfq1jGdM1kTFdE+nZKrp+ffusCjt+dqoLbpwOAUFQXgpnPg7Db6vdvj+/HdZNgz9tgcAgZ8Hldy5w1uW6+hOnN6kyZaWw9gv44g4IjXISpzZDj33d3q3wyhiIagE3zYDQ46xlq+oMnWvaHqJO8OF052J45VQ49z/VG2anCns2O2uEbf/JOVZidxh0g7PmWYAHhpOu+gSm3ADXfwtth1f+mi2zneT16k+c43pfdRKsxcAFqrrD9bgt8JmqHueXwK19Cs4cq72qeleF7U8De1T1CRG5H2iqqvdWsa962z4VFJdxytOzaBsfweTfDvfdOn7GGNNwWIJVCf87edPolJcrK3dmM2t9BrPWZ7IidT+qkBAVyrAOTRnaIZ5h7ZvSKTGq/nxg2r0Sfn4RmnZwimHU1sGk4MYZgDhzuoIj4JrPILFb1e9PXwMfXunM4zr7KSdhOagoF1473RluOHGWE3NtqcJ/Bjhzxq6dduLX5mbC2qmuXrefIDfd2R7V3Ol5S/3V2RbTxhki2f8aaNK85rFNudFJoP644fgJW1GOs+DwqHudoZLeV50EaxwwCWcoH8AoYKKqflfjg4uMBH4EVuKUaQd4AGce1mSgDbADZ2jiCctL1uf26X9zNvP4N+uY/NvhDGl/nN5XY4wxFVmCVQn/O3nT6GXlFjF3QyZzNmSyYMse0g84c7riI0MY0r4pQ9s3pUuLJuzLKyH9QCEZOUVkHCgkPaeQjANFBIiQHBdO66YRJMeFkxwXQeumzuPosHq6OG7+Xniqg9Obsv0nJ/n4zRcQ19b9fRTsg09ugk3fw8DrnNLqAcEw+Rqn6MPVn0LHMZ6LedY/YM5TcM+6Y0uhV4xp0mhnPlSTls58sbYjoN3JEN/RmR9VVuKUVF/0Omyd4/QMdp8AA693XhtYjVpGpcXwdEen0uF5L5z4tS+NhKhmThLrfdX6ZkBEEnDKqQvws6pmeSWqGqiv7VNOYQknPzWLfq1jefP6IXV5aGOMacgqbZ/8qoqgMcbpubpwQDIXDkhGVdm+J5+FW/ewcMteFm7dyzerdh/x+pDAAJo1CaV5dCgdm0VRpkrK3nwWbt17zFpd0WFBJMc5iVeSK/lKjgunXXwkXZr7sIcsoqkzDHDTDGjey0mGqtuLEx4HV06GHx5xhjGmr3EKY6z7Es78h2eTK4BeF8OcJ52Kg5UNkSwvh09/C9k74TdTnQWcK7u+gcHQ83znlrXRKbqx9F1nMeCwGGh/CnQ81Ym/qkWft8+DogOVVw88WuvBsHJKfV1wuAzIAMKAHiKCqs71cUz12ts/b2d/fgn3nH7CKWTGGGPcYD1YxjQyKXvz2b4nn4QmITRvEkZsRHCliZGqkl1QQsreAlL25ZOyN5+d+wtI3VdA6r58UvcVkF9cduj1fZJj+O2ojozr1YJAX8z9WvWJUzBj/L9qXzhi9Wfw+W1Qkg99r4DzX6o8uamt/41yFmSeOOvY5+Y8BbMeg7OfObyOlrtKCmD9N84CzJtnwYGdzvamHZxkq9UAQKGs2OkBKyt2bptnOZUW791yuNLj8Sz7AD6/BW79GZr3qF581VedIYI3AXcCycAynJ6sn1X1VO+EVj31sX3KLy5l5JOz6JMcY71XxhhTPTZEsBL+d/LG1BFVZX9+Can7CliWup/XftzCtj35tIuP4OZRHbhoQHLDXcMLnEIZa6bCyLuPLbXuKfP/A9P/CncscYb8HbRxhlMKvc9lcMHLtUvuVJ2erc0/OLdt86Ak7/ivH/Abp/hGVfZsduaRTXjOGVLpXdVJsFYCg4EFqtpPRLoBf1fVy7wWXTXUx/bptXlbeeTLNXxy63AGtrW5V8YYUw2WYFXC/07eGB8pK1e+W72bl+dsZkVqNglRoVw/oh1XD2tLTHg9nbvla9k74V89YfSfYfR9zrZ92+B/p0BMa7hxetU9SdVVWgzZKc7QwsAQ1831c0Cw+8P9VJ35Wl3OgvOrmK9Ve9VJsH5V1cEisgwYqqpFIrJMVft5LbpqqG/tU2GJUzmwfUIkH048TtVIY4wxx+P/c7BEZAIwAYjxdSzGNDaBAcLZvVtyVq8W/LxlDy/P2cLT363npdmbufakttw4soNX1+nak1tEcFBA/S3EUZmYJKcQxcqP4ZR7obQQProGULjsbc8nVwBBIUf2ltWUiKuK4S+135dnpYpILPA5MENE9gFpPo2oHpuyOJX0A0U8e2k/X4dijDF+w68SLFWdBkwTkUW+jsWYxkpEOKljAid1TGB1WjYvztrMi7M388ZP27hmeFtuPrkDCVGhtTpGWbmyMSOHxdv3sXj7PpZs38e2PflEhQYx+bfD6dEq2kNnUwd6Xwxf3gW7lsMvk2D3CqfYhifKwXtb8mDY8K1TxfF4iyrXMVU9uGL1wyIyC+cLt299GFK9VVJWzstzNtO/TSwndYz3dTjGGOM3bIigMcbrNqTn8N8fNvHlijRCggK4emhbJp7SgcQm7s9tys4v4auVu/h29W6Wbt9HjqvCYUJUCAPaxNGvTSxvz98OwGe3n0TLmHCvnIvH5e+FZ7pAfCfIXAun3AdjHvB1VO7Z+iO8NR6umgKdT/fmkerJAm61V5/apymLU/njx8t57dpBnNa9FmunGWNM42VzsCrhfydvTD22OTOXF2Zt4otlaQQFCGf0bMHANrEMaBtH95bRBAceOf+nqLSMWesy+XzpTn5Yl0FxWTkdEiIZ3jGegW3jGNg2jjZNIw5VQVy76wCXvPwzyXHhTL5leMMZLvj+5bDhG2cdrysnH3+B3/qmOA8ebw0n/wFO/as3j2QJloeVlSunPzuH0OBAvv79yPqzCLkxxjQslmBVwv9O3pgGYFtWHi/P2cys9RmHFkIOCw6gT1Is/dvG0qNlNL9s3cuXK3aRXVBCQlQI5/ZN4oL+SfRKij7hh8EfN2Zy/Ru/MqxDPK9fN5iQoHq3RtOxUn6Bn55zqvfVk6F2bnv5ZKcs/rVTD28rL4PM9bBzMeTuhlF/qu1R/ObTf31pn75ckcbv3l/KC1cO4Jw+Lb15KGOM8WeWYFXC/07emAZEVUnLLmTJ9n0s2bGPpTv2szotm5IyJSw4gDN7tuD8/kmc3CmBoED3E6WDQ58uGpDMM5f0sW/nvemre2D5h3D+i05CtXMJpC2F4lzn+YgEuGc9BNZqyq/f/APWh/ZJVTnruR8pKStn+t2n+GbdOmOM8Q/+X0XQGNOwiAhJseEkxYYzoW8rwCkbvSkjl3YJkUSF1uxP1MUDk9m5r4B/fb+B5Lhw7j69iyfDNhW1Hga/vgqTf+OUeW/RG/pdCUkDnVvTju6Xfjd1YubaDNbtzuGfl/S15MoYY7zAEixjTL0SFhxIr6Tar7Tw+9M6kbovn+dmbiQpLpxLB7Wu9HWlZeXV6h0zR+lxnnPftAO06AVBtasQabxLVfnPrE20bhrOuf1a+TocY4zxS5ZgGWP8kojwjwt7s/tAIQ98upJlKfvJLyplb34J+/KK2ZdfzL68YvKKy4gMCaRFTBgtY8JpHh1Gy5gwWsSEER8ZQnFZOQXFZRSUOLdC18/hIUH0aNmEnq1iSI4Lb7zDEINCoM8lvo7CuGnepiyWp+znsQt6HVNUxhhjjGfYHCxjjF/LKSzhxjcXsXbXAeIiQ4iLDKFpRDBxEc7P0WHB7C8oZnd2IbsPFLI7u5D0A4WUn+CvQ3hwIEWlZYde0yQsiB4to+nZKoYeraIZ1SWhWiXoTZX8Jnv1ZftUXq5c+r+fSdmXz9x7xxAa1ECqVRpjTP1lc7CMMY1Pk7BgJt8yvFrvKS0rJyu3mL15xYQGBxAeHOjcQgIJDQpARCgoLmN9eg6r07JZk3aA1WkHeP+X7RSWlBMSGMAF/ZO4eVR7OiU2qfJ4KXvzyS4o8cjQSGOO58XZm1i0fR9PXtTbkitjjPEi68EyxhgPKStXNqTn8N7C7Xy8KJWi0nLGdk/k5pM7MKR900PDCFWVdbtzmL46ne9W72bNrgMA/OH0Ltxxaie3hhvmFZXy7IwNlJSV0yspht5JMXROjPLX+WTWg1VL8zdncfWrCxnfpxXPXd6v8Q5pNcYYz7Iy7ZXwv5M3xtQLe3KLeGfBdt7+eTt784rp2zqWK4e0ZmN6LtPXpLNjbz4iMLBNHGf0bM66XTl8unQnE0d14M9ndTvhB+Bd2QXc+OYi1u0+QHhwIHnFZQCEBgXQvWU0vZNi6Ns6lvF9WhIW7Bc9FX6TDfiifco4UMjZz88jJjyIqb8bSWQNq3MaY4w5hv8nWCIyAZgAjFHVzm68xX9O3hhTLxUUlzFlSSqv/biFbXvyCQkMYESneM7o2YKx3ZvTrIlTda+8XHl42mre/nk7Vw5tw6Pn9SKgkhLaq3Zmc+Nbv5JXVMZ/r+zPqM7N2Lonj1U7s1mZms3KndmsTjtAblEpSbHhPDi+O2f2bOHxHouycmXVzmzmbcpic2YuD57Tg7jIEI8eowJLsGqotKycq15dyPLU/Uz93Ui6NK96yKoxxhi3+X+CdZD1YBlj6puycmV1WjYdmkUdd30vVeWp79bz0uzNnN+vFc9c0veIIX/TV+/mzg+X0TQyhNeuG0S3FtGV7qe8XPl5yx7+b9oa1qfnMLJTAg9N6EHnWn643rm/gHkbM5m7MYufNmWxP78EABFcizr3rdX+T8ASrBp6+rt1vDBrM/+8pC8XDUz2xC6NMcYcZglWJfzv5I0xDd4Lszbx9HfrOaNHc/5zZX9CAgN4bd5WHvt6LX2SYnjl2kFuVSksLSvnvYU7+Of09eQVl3Ht8HbcObYzMeHB1YpnRep+/vzpSlanOXPFEpuEcnLnZozqksCITgm8Pm8rL87ezPs3D+Wkjgk1OucqWIJVA7PWZXD9m79y+eDWPHFRn9ruzhhjzLEswaqE/528McYvvDV/Gw9NXc3JnRNo0zSC9xbu4KxeLXj20n6Eh1RvXtXevGKemb6eD37ZQdOIEP54ZlcuGZhcZUGM8nJl0o9beOa79SREhXLjyPaM6tKMLs2jjhhyWFhSxpn/nkuACN/cebI35n1ZglVNO/cXcM7zP9IqJpxPbzvJX+biGWNMfWMJViX87+SNMX7j40Up3PfJCsoVfntKB+47s1ul87LctWpnNg9PXc2i7ftoGx/B78Z04oL+SZUmWruzC/nD5GXM37yHs3q14PELexMbcfw5VvM2ZnH1awu549RO3HNG1xrHeByWYFVDcWk5l/7vZzZl5PLlHSNplxBZ010ZY4w5MUuwKuF/J2+M8Ss/bswkt7CUs3q39Mj+VJWZazP498wNrNp5oNJE69tVu7n/0xUUlZTz8Lk9uHRQa7eKZPzho2VMW5HG178/udbzvY5iCVY1/H3aat74aRsvXTXAY783xhhjKmUJViX87+SNMcYNRydabZpGcPuYjixLyeaDX3bQKyma5y7vT8dmUW7vc09uEWOfnUPHZlFM/u3wWvW2HcUSrGqYujyN9bsP8Kczu9V0F8YYY9xjCVYl/O/kjTGmGo5OtERg4qgO3HN6V0KCqr9o8ceLUvjTlBU8dkEvrhra1lNhWoJljDGmPrIEqxL+d/LGGFMDqsqcDZlEhQYxqF3TWu3nylcWsiotm5l/OIXE6KqrHbrBEixjjDH1UaXtU/W/njTGGON3RITRXRNrlVwd3M9jF/SiqLScv3+5xkPRGWOMMQ2HJVjGGGM8qkOzKO4Y04mvVuzih3Xpvg7HGGOMqVOWYBljjPG4357Skc6JUTz4+Wryikp9HY4xxhhTZ4J8HYAxxhj/ExIUwBMX9WbVzgO2yK0xxphGxRIsY4wxXjGwbVMGtq3dnC5jjDGmobEhgsYYY4wxxhjjIZZgGWOMMcYYY4yHWIJljDHGGGOMMR7iV3OwRGQCMAGI8XUsxhhjjDHGmMbHr3qwVHWaqk4Esn0dizHGGGOMMabx8asEyxhjjKlLIjJORNaLyCYRud/X8RhjjPE9S7CMMcaYGhCRQOAF4CygB3CFiPTwbVTGGGN8zRIsY4wxpmaGAJtUdYuqFgMfAuf5OCZjjDE+5ldFLirIcvN14tUojDHG+LMkIKXC41Rg6NEvEpGJwETXwzA3923tkzHGNFB+mWCp6jhfx2CMMcbvVZYE6TEbVCcBk7wfjjHGmPrAhggaY4wxNZMKtK7wOBlI81Esxhhj6glLsIwxxpia+RXoLCLtRSQEuByY6uOYjDHG+JhfDhE0xhhjvE1VS0Xkd8B3QCDwuqqu9nFYxhhjfExUjxkubowxxhhjjDGmBmyIoDHGGGOMMcZ4iCVYxhhjjDHGGOMhlmAZY4wxxhhjjIdYgmWMMcYYY4wxHtKoqwiKyLdAQi12kQBkeSgcf2DX4zC7FofZtTiSXY/D3L0WWY1tAXlrnzzKrsWR7HocZtfiMLsWR6pV+2RVBGtBRBap6iBfx1Ff2PU4zK7FYXYtjmTX4zC7Ft5j1/YwuxZHsutxmF2Lw+xaHKm218OGCBpjjDHGGGOMh1iCZYwxxhhjjDEeYglW7UzydQD1jF2Pw+xaHGbX4kh2PQ6za+E9dm0Ps2txJLseh9m1OMyuxZFqdT1sDpYxxhhjjDHGeIj1YBljjDHGGGOMh1iCZYwxxhhjjDEeYglWDYnIOBFZLyKbROR+X8dTl0TkdRHJEJFVFbY1FZEZIrLRdR/nyxjrioi0FpFZIrJWRFaLyJ2u7Y31eoSJyC8istx1Pf7u2t4orweAiASKyFIR+dL1uFFeCxHZJiIrRWSZiCxybWuU18LbrH2y9gmsfTqatU/HsvbJ4Y32yRKsGhCRQOAF4CygB3CFiPTwbVR16k3g6EXV7gdmqmpnYKbrcWNQCtyjqt2BYcDtrt+Fxno9ioBTVbUv0A8YJyLDaLzXA+BOYG2Fx435WoxR1X4V1hZpzNfCK6x9svapAmufjmTt07GsfTrMo+2TJVg1MwTYpKpbVLUY+BA4z8cx1RlVnQvsPWrzecBbrp/fAs6vy5h8RVV3qeoS1885OH+okmi810NVNdf1MNh1Uxrp9RCRZOAc4NUKmxvltTgOuxaeZ+2TtU+AtU9Hs/bpSNY+ValW18ISrJpJAlIqPE51bWvMmqvqLnD+qAOJPo6nzolIO6A/sJBGfD1cQw6WARnADFVtzNfj38C9QHmFbY31WigwXUQWi8hE17bGei28ydqnYzX63zNrnxzWPh3h31j7dJDH26cgDwfYWEgl26zefSMmIlHAJ8BdqnpApLJfkcZBVcuAfiISC3wmIr18HJJPiMh4IENVF4vIaB+HUx+MUNU0EUkEZojIOl8H5KesfTJHsPbpMGufHNY+HcPj7ZP1YNVMKtC6wuNkIM1HsdQX6SLSEsB1n+HjeOqMiATjNF7vqeqnrs2N9nocpKr7gdk48yEa4/UYAZwrIttwhmmdKiLv0jivBaqa5rrPAD7DGcrWKK+Fl1n7dKxG+3tm7VPlrH2y9qkib7RPlmDVzK9AZxFpLyIhwOXAVB/H5GtTgWtdP18LfOHDWOqMOF8FvgasVdVnKzzVWK9HM9c3g4hIODAWWEcjvB6q+mdVTVbVdjh/I35Q1atphNdCRCJFpMnBn4EzgFU0wmtRB6x9Olaj/D2z9ulI1j4dZu3TYd5qn0TVRg7UhIicjTN+NRB4XVUf821EdUdEPgBGAwlAOvAQ8DkwGWgD7AAuUdWjJxr7HREZCfwIrOTwOOYHcMa5N8br0QdnMmggzhc4k1X1/0QknkZ4PQ5yDcH4o6qOb4zXQkQ64HwrCM7Q9PdV9bHGeC3qgrVP1j6BtU9Hs/apctY+ead9sgTLGGOMMcYYYzzEhggaY4wxxhhjjIdYgmWMMcYYY4wxHmIJljHGGGOMMcZ4iCVYxhhjjDHGGOMhlmAZY4wxxhhjjIdYgmVMIyMio0XkS1/HYYwxxhxkbZPxJ5ZgGWOMMcYYY4yHWIJlTD0lIleLyC8iskxE/icigSKSKyL/FJElIjJTRJq5XttPRBaIyAoR+UxE4lzbO4nI9yKy3PWejq7dR4nIFBFZJyLviYj47ESNMcY0GNY2GVM1S7CMqYdEpDtwGTBCVfsBZcBVQCSwRFUHAHOAh1xveRu4T1X7ACsrbH8PeEFV+wInAbtc2/sDdwE9gA7ACC+fkjHGmAbO2iZj3BPk6wCMMZU6DRgI/Or6Ai8cyADKgY9cr3kX+FREYoBYVZ3j2v4W8LGINAGSVPUzAFUtBHDt7xdVTXU9Xga0A+Z5/ayMMcY0ZNY2GeMGS7CMqZ8EeEtV/3zERpEHj3qdVrGP4ymq8HMZ9rfAGGNM1axtMsYNNkTQmPppJnCxiCQCiEhTEWmL83/2YtdrrgTmqWo2sE9ETnZtvwaYo6oHgFQROd+1j1ARiajLkzDGGONXrG0yxg32zYAx9ZCqrhGRvwLTRSQAKAFuB/KAniKyGMjGGQsPcC3wsquR2gJc79p+DfA/Efk/1z4uqcPTMMYY40esbTLGPaJ6ol5cY0x9IiK5qhrl6ziMMcaYg6xtMuZINkTQGGOMMcYYYzzEerCMMcYYY4wxxkOsB8sYY4wxxhhjPMQSLGOMMcYYY4zxEEuwjDHGGGOMMcZDLMEyxhhjjDHGGA+xBMsYY4wxxhhjPOT/AaubffbhKCK5AAAAAElFTkSuQmCC","text/plain":["<Figure size 864x288 with 2 Axes>"]},"metadata":{"needs_background":"light"}}],"metadata":{}},{"cell_type":"markdown","source":[" ## Train CPCN"],"metadata":{}},{"cell_type":"code","execution_count":8,"source":["z_it = 100\n","z_lr = 0.05\n","\n","torch.manual_seed(123)\n","\n","# match the PCN network\n","g_a = 0.5 * np.ones(len(dims) - 2)\n","g_a[-1] *= 2\n","\n","g_b = 0.5 * np.ones(len(dims) - 2)\n","g_b[0] *= 2\n","\n","cpcn_net = LinearCPCNetwork(\n","    dims, z_lr=z_lr, z_it=z_it, g_a=g_a, g_b=g_b, c_m=0, l_s=g_b\n",")\n","cpcn_net = cpcn_net.to(device)"],"outputs":[],"metadata":{}},{"cell_type":"code","execution_count":9,"source":["cpcn_losses = np.zeros(n_epochs)\n","cpcn_accuracies = np.zeros(n_epochs)\n","cpcn_train_losses = np.zeros((n_epochs, len(train_loader)))\n","\n","cpcn_optimizer = torch.optim.Adam(cpcn_net.slow_parameters(), lr=0.001)\n","\n","# train a linear classifier on the output from the last hidden layer\n","cpcn_classifier = torch.nn.Sequential(torch.nn.Linear(*dims[-2:]))\n","cpcn_classifier_optimizer = torch.optim.Adam(cpcn_classifier.parameters(), lr=0.001)\n","cpcn_classifier_criterion = torch.nn.MSELoss()\n","\n","# pbar = tqdm(range(n_epochs), desc=\"val: loss ?.??? acc ?.??\")\n","pbar = tqdm(range(n_epochs))\n","for epoch in pbar:\n","    # train\n","    for i, (x, y) in enumerate(train_loader):\n","        cpcn_net.forward_constrained(x, y)\n","        loss = cpcn_net.loss()\n","\n","        cpcn_net.calculate_weight_grad()\n","        cpcn_classifier_optimizer.zero_grad()\n","\n","        # propagate through the classifier\n","        cpcn_classifier_out = cpcn_classifier(cpcn_net.z[-2])\n","        cpcn_classifier_loss = cpcn_classifier_criterion(cpcn_classifier_out, y)\n","        cpcn_classifier_loss.backward()\n","\n","        cpcn_optimizer.step()\n","        cpcn_classifier_optimizer.step()\n","\n","        cpcn_train_losses[epoch, i] = loss.item()\n","\n","    # evaluate\n","    cpcn_losses[epoch], cpcn_accuracies[epoch] = evaluate(\n","        cpcn_net, validation_loader, classifier=cpcn_classifier\n","    )\n","    # pbar.set_description(f\"val: loss {losses[epoch]:.2g} acc {accuracies[epoch]:.2f}\")\n","    pbar.set_postfix(\n","        {\n","            \"val_loss\": f\"{cpcn_losses[epoch]:.2g}\",\n","            \"val_acc\": f\"{cpcn_accuracies[epoch]:.2f}\",\n","        }\n","    )\n","\n","cpcn_train_losses = np.sum(cpcn_train_losses, axis=1) / len(train_loader.dataset)"],"outputs":[{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"edd348b512b84087ab6c3b96a7d0edf2"},"text/plain":["  0%|          | 0/50 [00:00<?, ?it/s]"]},"metadata":{}}],"metadata":{}},{"cell_type":"markdown","source":[" ## Show CPCN learning curves"],"metadata":{}},{"cell_type":"code","execution_count":10,"source":["with dv.FigureManager(1, 2) as (_, (ax1, ax2)):\n","    ax1.semilogy(train_losses, c=\"C0\", ls=\"--\", alpha=0.7, label=\"Whittington&Bogacz\")\n","    ax1.semilogy(losses, c=\"C1\", ls=\"--\", alpha=0.7)\n","\n","    ax1.semilogy(cpcn_train_losses, c=\"C0\", label=\"train\")\n","    ax1.semilogy(cpcn_losses, c=\"C1\", label=\"val\")\n","    ax1.set_xlabel(\"epoch\")\n","    ax1.set_ylabel(\"predictive-coding loss\")\n","    ax1.legend(frameon=False)\n","\n","    ax2.plot(100 * accuracies, c=\"C0\", ls=\"--\", alpha=0.7, label=\"Whittington&Bogacz\")\n","    ax2.plot(100 * cpcn_accuracies, c=\"C0\")\n","    ax2.set_xlabel(\"epoch\")\n","    ax2.set_ylabel(\"accuracy on validation set (%)\")\n","    ax2.set_ylim(0, 100)"],"outputs":[{"output_type":"display_data","data":{"image/png":"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","text/plain":["<Figure size 864x288 with 2 Axes>"]},"metadata":{"needs_background":"light"}}],"metadata":{}}],"nbformat":4,"nbformat_minor":2,"metadata":{"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},"orig_nbformat":4}}