{"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":{}},{"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":"342ad6bd2c6c45ba93595e2817dd883d"},"text/plain":["  0%|          | 0/3000 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["Training PCN took 102.0 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":"d21d6929fa0d4964af6ceae5ce9356e4"},"text/plain":["  0%|          | 0/3000 [00:00<?, ?it/s]"]},"metadata":{}},{"output_type":"stream","name":"stdout","text":["Training BioPCN took 82.6 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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ny0qKrKVlZW2d+/edufOnTYnJ8f26dPH5ufn25qaGjt16lR7yy23WGutvfHGG+1//vOf0P1GjRpl3333XWuttXfffbe97bbbQuX57ne/a621dt68eXbGjBmha2655Rbbo0ePUHkb+9vf/mYzMjLsmDFjbGZmpp06daoNBALWWmsvvfRS+/jjj1trrX3sscfs5Zdfbq219pJLLrH//Oc/rbXWPvLII6H619bW2uLiYmuttQcOHLADBgyw9fX1dvXq1Xbw4MH2wIED1lpr8/Pzm5Th5ZdftlOnTrU1NTXH+8gatHu70BZbc9uevVdeaTdt2mRtIGDtunW2vr7efvTRR/aFF16w8+bNs6+++qp94YUXbEFBQegHWF5ebpcsWWI//vhj++yzz9r58+fbNWvW2BdeeCF03fz58+2+ffvsiy++aHNzc+0///lP++6779rnn3/efvLJJ3bJkiX25ZdftnV1dXbHjh32+eeft2vXrLEbZs2yVQsW2MrKSrtz5067d+9em5eXZ5999lm7ceNG+/zzz9tnnnnGVlVVhcpTUlJiP/vsM/v+++/blStX2tdee82++eabzf33IBJR1Pao7TnVLSLTrZ8oa9VjJXIynn766Ra/57XXXnvccxq+OVy4cCHf/e53ycnJYeHChSQnJzNlyhQAJk2aRM+ePQH3Ldf27duZOnXqSZdrxowZJCe7FRyGDx/Ojh07yMvLY/r06aSlpQFw9dVXH/Eb/eLiYoqKipg+fToAN954I1dffXXo9auuugqA0047je3btwPw0ksvUVxczGuvvcbnPvc55s2bR0pKChdffDGLFy8G3HCM3//+91hrueWWW/jVr37FnXfeyaJFi3j++ecB+OIXvxj6lnPRokW8+OKLAFx33XV8//vfB9zvwB/96Ee8//77eDwecnJy2LdvH/Pnz2f27NlkZGQAhOoJsGnTJm6//Xbmz59PlFJ2n5zMTDcXyuuFoUPZuWMHhYWFnH/++cybN4+RI0fi8/l47733GDp0KNHR0axZs4aMjAyqq6u5+OKLWblyJcXFxZxzzjn4/X7KyspIS0vD6/Uya9YsjDFMnDiRfv36sXv3bqqqqigsLGTUqFF4PB569+6N3+9n0aJFTLvpJqLfeAN69KBX376hVOwjRoxg/fr1TJkyhfXr17N3717i4+PZtWsXW7duZcCAAfTp04d9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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}}