{"cells":[{"cell_type":"markdown","source":[" # Comparison of PCN and BioPCN on MNIST with two hidden (linear) layers"],"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 time\n","\n","from cpcn import *\n","from cpcn.graph import *"],"outputs":[],"metadata":{}},{"cell_type":"markdown","source":[" ## Setup"],"metadata":{}},{"cell_type":"code","execution_count":2,"source":["device = torch.device(\"cpu\")\n","\n","# for reproducibility\n","torch.manual_seed(123)\n","\n","# get train, validation, and test loaders for MNIST\n","dataset = load_mnist(n_validation=1000, device=device)"],"outputs":[],"metadata":{}},{"cell_type":"markdown","source":[" ## Train PCN"],"metadata":{}},{"cell_type":"code","execution_count":3,"source":["n_batches = 3000\n","dims = [784, 10, 5, 10]\n","z_it = 50\n","z_lr = 0.07\n","rho = 0.02\n","# rho = 0.0012\n","\n","t0 = time.time()\n","torch.manual_seed(123)\n","\n","net0 = PCNetwork(\n","    dims,\n","    activation=lambda _: _,\n","    z_lr=z_lr,\n","    z_it=z_it,\n","    variances=1.0,\n","    constrained=True,\n","    rho=rho,\n","    bias=False,\n",")\n","\n","net = PCWrapper(net0, \"linear\").to(device)\n","optimizer = torch.optim.SGD(net.pc_net.parameters(), lr=0.008)\n","predictor_optimizer = torch.optim.Adam(net.predictor.parameters())\n","trainer = Trainer(dataset[\"train\"])\n","trainer.metrics[\"accuracy\"] = one_hot_accuracy\n","for batch in tqdmw(trainer(n_batches)):\n","    if batch.every(10):\n","        batch.evaluate(dataset[\"validation\"]).run(net)\n","\n","    ns = batch.feed(net)\n","    optimizer.step()\n","    predictor_optimizer.step()\n","\n","results = trainer.history\n","print(f\"Training PCN took {time.time() - t0:.1f} seconds.\")"],"outputs":[{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"4453ab1c98e447dbad7e9962be5b775d"},"text/plain":["  0%|          | 0/3000 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["Training PCN took 97.8 seconds.\n"]}],"metadata":{}},{"cell_type":"markdown","source":[" ### Show PCN learning curves"],"metadata":{}},{"cell_type":"code","execution_count":4,"source":["_ = show_learning_curves(results)"],"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":{}},{"cell_type":"markdown","source":[" ## Train BioPCN"],"metadata":{}},{"cell_type":"code","execution_count":5,"source":["z_it = 50\n","z_lr = 0.02\n","Q_lr_factor = 2.0\n","\n","t0 = time.time()\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","biopcn_net0 = LinearBioPCN(\n","    dims,\n","    z_lr=z_lr,\n","    z_it=z_it,\n","    g_a=g_a,\n","    g_b=g_b,\n","    c_m=0,\n","    l_s=g_b,\n","    rho=rho,\n","    bias_a=False,\n","    bias_b=False,\n","    q0_scale=np.sqrt(1 + dims[2] / dims[1]),\n",")\n","\n","biopcn_net = PCWrapper(biopcn_net0, \"linear\").to(device)\n","biopcn_optimizer = multi_lr(\n","    torch.optim.SGD,\n","    biopcn_net.pc_net.parameter_groups(),\n","    lr_factors={\"Q\": Q_lr_factor},\n","    lr=0.008,\n",")\n","biopcn_predictor_optimizer = torch.optim.Adam(biopcn_net.predictor.parameters())\n","biopcn_trainer = Trainer(dataset[\"train\"])\n","biopcn_trainer.metrics = trainer.metrics\n","for batch in tqdmw(biopcn_trainer(n_batches)):\n","    if batch.every(10):\n","        batch.evaluate(dataset[\"validation\"]).run(biopcn_net)\n","\n","    ns = batch.feed(biopcn_net)\n","    biopcn_optimizer.step()\n","    biopcn_predictor_optimizer.step()\n","\n","biopcn_results = biopcn_trainer.history\n","print(f\"Training BioPCN took {time.time() - t0:.1f} seconds.\")"],"outputs":[{"output_type":"display_data","data":{"application/vnd.jupyter.widget-view+json":{"version_major":2,"version_minor":0,"model_id":"8e972d55f9f04d099a326740f2ab141e"},"text/plain":["  0%|          | 0/3000 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["Training BioPCN took 79.3 seconds.\n"]}],"metadata":{}},{"cell_type":"markdown","source":[" ### Show BioPCN learning curves"],"metadata":{}},{"cell_type":"code","execution_count":6,"source":["with dv.FigureManager(1, 2) as (_, axs):\n","    show_learning_curves(\n","        results,\n","        show_train=False,\n","        labels=(\"\", \"Whittington&Bogacz\"),\n","        colors=(\"C0\", \"gray\"),\n","        axs=axs,\n","    )\n","    show_learning_curves(\n","        biopcn_results,\n","        show_train=False,\n","        labels=(\"\", \"BioPCN\"),\n","        colors=(\"C0\", \"red\"),\n","        axs=axs,\n","    )"],"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}}