{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Import Libraries"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "f859ec79",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "import torch.autograd as autograd         # computation graph\n",
    "from torch import Tensor                  # tensor node in the computation graph\n",
    "import torch.nn as nn                     # neural networks\n",
    "import torch.optim as optim               # optimizers e.g. gradient descent, ADAM, etc.\n",
    "import time\n",
    "from pyDOE import lhs         #Latin Hypercube Sampling\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.ticker\n",
    "import copy\n",
    "\n",
    "#Set default dtype to float32\n",
    "torch.set_default_dtype(torch.float)\n",
    "\n",
    "#PyTorch random number generator\n",
    "torch.manual_seed(1234)\n",
    "\n",
    "# Random number generators in other libraries\n",
    "np.random.seed(1234)\n",
    "\n",
    "# Device configuration\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "\n",
    "print(device)\n",
    "\n",
    "if device == 'cuda': print(torch.cuda.get_device_name()) "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "af578760",
   "metadata": {},
   "source": [
    "# *Data Prep*\n",
    "\n",
    "Training and Testing data is prepared from the solution file"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a02f96d6",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "x_f = np.linspace(-1, 1, 1000).reshape(-1, 1)   \n",
    "\n",
    "\n",
    "x_b = np.array([[-1.0], [1.0]])               \n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a55015c5",
   "metadata": {},
   "source": [
    "# Physics Informed Neural Network"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "72038037",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "class Sequentialmodel(nn.Module):\n",
    "    def __init__(self, m):\n",
    "        super().__init__()\n",
    "        self.m = m\n",
    "        self.fc1 = nn.Linear(1, m)\n",
    "        self.activation = nn.Tanh()\n",
    "        self.fc2 = nn.Linear(m, 1, bias=False) \n",
    "\n",
    "        'loss function'\n",
    "        self.loss_function = nn.MSELoss(reduction ='mean')\n",
    "        \n",
    "\n",
    "    def init_exact(self):\n",
    "      \n",
    "        nn.init.zeros_(self.fc1.weight)\n",
    "        nn.init.zeros_(self.fc1.bias)\n",
    "        nn.init.zeros_(self.fc2.weight)\n",
    "        with torch.no_grad():\n",
    "            self.fc1.weight[0, 0] = 2.0\n",
    "            self.fc1.bias[0] = 1.0\n",
    "            self.fc2.weight[0, 0] = 1.0              \n",
    "            for k in range(1, self.m):\n",
    "                nn.init.normal_(self.fc1.weight[k,0], mean=0.0, std=1)\n",
    "                nn.init.normal_(self.fc1.bias[k], mean=0.0, std=1)\n",
    "                self.fc2.weight[0, k] = 0    \n",
    "        \n",
    "    def forward(self, x):\n",
    "        if not torch.is_tensor(x):\n",
    "            x = torch.from_numpy(x)\n",
    "        x = x.float()\n",
    "        hidden = self.activation(self.fc1(x))  # [batch, m]\n",
    "        out = self.fc2(hidden)                 # [batch, 1]\n",
    "        return out\n",
    "\n",
    "    def loss_BC(self,x_b):\n",
    "       \n",
    "        u_true_b = torch.tanh(2*x_b +1)  \n",
    "        loss_u = self.loss_function(self.forward(x_b), u_true_b)\n",
    "                \n",
    "        return loss_u\n",
    "    \n",
    "    def loss_PDE(self, x_f):\n",
    "                        \n",
    "        g = x_f.clone()\n",
    "                        \n",
    "        g.requires_grad = True\n",
    "        \n",
    "        u = self.forward(g)\n",
    "                \n",
    "        u_x = autograd.grad(u,g,torch.ones([x_f.shape[0], 1]).to(device), retain_graph=True, create_graph=True)[0]\n",
    "                                \n",
    "        u_xx = autograd.grad(u_x,g,torch.ones(x_f.shape).to(device), create_graph=True)[0]\n",
    "                                                                          \n",
    "        f = -8*(1 / torch.cosh(2*g + 1)**2) * torch.tanh(2*g + 1)\n",
    "        \n",
    "        loss_f = self.loss_function(f,u_xx)\n",
    "                \n",
    "        return loss_f\n",
    "    \n",
    "    def loss(self,x_b,x_f):\n",
    "\n",
    "        loss_u = self.loss_BC(x_b)\n",
    "        loss_f = self.loss_PDE(x_f)\n",
    "        \n",
    "        loss_val = loss_u + loss_f\n",
    "        \n",
    "        return loss_val\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1b2fb857",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.autograd as autograd\n",
    "import numpy as np\n",
    "\n",
    "def f_true(x):\n",
    "    return -8 * (1 / torch.cosh(2 * x + 1)**2) * torch.tanh(2 * x + 1)\n",
    "\n",
    "def u_true(x):\n",
    "    return torch.tanh(2 * x + 1)\n",
    "\n",
    "def l_k_fun(model, x):\n",
    "    x = x.clone().detach().requires_grad_(True)\n",
    "    u = model(x)\n",
    "    u_x = autograd.grad(u, x, torch.ones_like(u), create_graph=True, retain_graph=True)[0]\n",
    "    u_xx = autograd.grad(u_x, x, torch.ones_like(u_x), create_graph=True)[0]\n",
    "    f = f_true(x)\n",
    "    l_k = (u_xx - f) ** 2\n",
    "    return l_k  \n",
    "\n",
    "def covariance_fun(model, x_f, eta, batch_size):\n",
    "    params = [p for p in model.parameters() if p.requires_grad]\n",
    "    \n",
    "    Nf = x_f.shape[0]\n",
    "\n",
    "    V = []\n",
    "    for k in range(Nf):\n",
    "        x_k = x_f[k].unsqueeze(0).detach().requires_grad_(False)\n",
    "        l_k = l_k_fun(model,x_k)\n",
    "        grad_lk = autograd.grad(l_k, params, retain_graph=False)\n",
    "        grad_vector_lk = torch.cat([g.reshape(-1) for g in grad_lk])\n",
    "        V.append(grad_vector_lk.unsqueeze(0))\n",
    "    V = torch.cat(V, dim=0)  # [Nf, param_num]\n",
    "    \n",
    "  \n",
    "    with torch.no_grad():\n",
    "        avg_grad = V.mean(dim=0)  # [param_num]\n",
    "    \n",
    "    V_diff = (V - avg_grad).T  # [param_num, Nf]\n",
    "    \n",
    "    noise_scale = torch.sqrt(torch.tensor(eta / (Nf * batch_size), device=device))\n",
    "    V = V_diff * noise_scale  \n",
    "    VVt = V @ V.T\n",
    "    #VVt_2norm = torch.linalg.norm(VVt, ord=2).item()\n",
    "    VVt_Fnorm = torch.linalg.norm(VVt, ord='fro').item()\n",
    "\n",
    "    return V, VVt, VVt_Fnorm\n",
    "    \n",
    "\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3a96ac99",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "\n",
    "def covariance_perturbed_init(model, sqrt_cov_matrix, epsilon_scale=1.0):\n",
    "\n",
    "    params = [p for p in model.parameters() if p.requires_grad]\n",
    "    flat_params = torch.cat([p.detach().clone().reshape(-1) for p in params])  # [param_dim]\n",
    "\n",
    "    Nf=1000\n",
    "    \n",
    "    delta = epsilon_scale * (sqrt_cov_matrix @ torch.randn([Nf], device=flat_params.device))\n",
    "    perturbed_params = flat_params + delta\n",
    "\n",
    "    with torch.no_grad():\n",
    "        idx = 0\n",
    "        for p in params:\n",
    "            numel = p.numel()\n",
    "            p.copy_(perturbed_params[idx:idx+numel].reshape(p.shape))\n",
    "            idx += numel"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eeba2855",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sequentialmodel(\n",
      "  (fc1): Linear(in_features=1, out_features=10, bias=True)\n",
      "  (activation): Tanh()\n",
      "  (fc2): Linear(in_features=10, out_features=1, bias=False)\n",
      "  (loss_function): MSELoss()\n",
      ")\n",
      "\n",
      "\n",
      "Exact network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=1.1172099113, bias=-0.0206414796, out_weight=0.0000000000\n",
      "Neuron 2: weight=0.6916948557, bias=-0.0982946083, out_weight=0.0000000000\n",
      "Neuron 3: weight=0.9565225244, bias=-0.5749083161, out_weight=0.0000000000\n",
      "Neuron 4: weight=2.0265746117, bias=2.0448455811, out_weight=0.0000000000\n",
      "Neuron 5: weight=1.5994553566, bias=-0.6218314767, out_weight=0.0000000000\n",
      "Neuron 6: weight=-0.1538601220, bias=1.8114522696, out_weight=0.0000000000\n",
      "Neuron 7: weight=-0.8120930195, bias=-0.4859311283, out_weight=0.0000000000\n",
      "Neuron 8: weight=-0.8302080631, bias=0.0340307839, out_weight=0.0000000000\n",
      "Neuron 9: weight=-2.2118842602, bias=-0.4110427499, out_weight=0.0000000000\n",
      "\n",
      "\n",
      "Exact covariance matrix F-norm: 1.230839e-14\n",
      "\n",
      "\n",
      "GD Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=0.9999999404, out_weight=1.0000000000\n",
      "Neuron 1: weight=1.1172099113, bias=-0.0206414796, out_weight=0.0000000132\n",
      "Neuron 2: weight=0.6916948557, bias=-0.0982946083, out_weight=0.0000000043\n",
      "Neuron 3: weight=0.9565225244, bias=-0.5749083161, out_weight=0.0000000054\n",
      "Neuron 4: weight=2.0265746117, bias=2.0448455811, out_weight=-0.0000000031\n",
      "Neuron 5: weight=1.5994553566, bias=-0.6218314767, out_weight=0.0000000299\n",
      "Neuron 6: weight=-0.1538601220, bias=1.8114522696, out_weight=0.0000000001\n",
      "Neuron 7: weight=-0.8120930195, bias=-0.4859311283, out_weight=-0.0000000024\n",
      "Neuron 8: weight=-0.8302080631, bias=0.0340307839, out_weight=-0.0000000069\n",
      "Neuron 9: weight=-2.2118842602, bias=-0.4110427499, out_weight=-0.0000000294\n",
      "Trained by GD, Step 00000 | Loss: 1.465187e-13\n",
      "Trained by GD, Step 05000 | Loss: 4.547557e-03\n",
      "Trained by GD, Step 10000 | Loss: 3.199222e-03\n",
      "Trained by GD, Step 15000 | Loss: 2.442217e-03\n",
      "Trained by GD, Step 20000 | Loss: 1.974584e-03\n",
      "Trained by GD, Step 25000 | Loss: 1.662566e-03\n",
      "GD Trained network parameters by neuron:\n",
      "Neuron 0: weight=1.1449851990, bias=2.3001399040, out_weight=-0.3125248253\n",
      "Neuron 1: weight=0.6360166669, bias=0.5472770929, out_weight=0.4817183614\n",
      "Neuron 2: weight=0.5590345263, bias=0.3753327727, out_weight=0.4440808594\n",
      "Neuron 3: weight=1.0907970667, bias=-0.8323577642, out_weight=-0.2605572939\n",
      "Neuron 4: weight=1.7449638844, bias=2.0515406132, out_weight=-0.5246064067\n",
      "Neuron 5: weight=1.6881183386, bias=-0.2374710888, out_weight=-0.1797785312\n",
      "Neuron 6: weight=-0.1352867335, bias=1.8140088320, out_weight=-0.2048586756\n",
      "Neuron 7: weight=-2.2549290657, bias=-1.0989775658, out_weight=-0.5559422374\n",
      "Neuron 8: weight=-0.6783747077, bias=-0.6323737502, out_weight=-0.5072971582\n",
      "Neuron 9: weight=-0.9525334239, bias=-0.9715235233, out_weight=-0.5637392998\n",
      "\n",
      "\n",
      "SGD Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=0.9999999404, out_weight=1.0\n",
      "Neuron 1: weight=1.1172099113, bias=-0.0206414796, out_weight=1.31676021197790760197676718235015869140625e-08\n",
      "Neuron 2: weight=0.6916948557, bias=-0.0982946083, out_weight=4.27280877346447596210055053234100341796875e-09\n",
      "Neuron 3: weight=0.9565225244, bias=-0.5749083161, out_weight=5.42893641153341377503238618373870849609375e-09\n",
      "Neuron 4: weight=2.0265746117, bias=2.0448455811, out_weight=-3.0621354341064943582750856876373291015625e-09\n",
      "Neuron 5: weight=1.5994553566, bias=-0.6218314767, out_weight=2.9910818710732200997881591320037841796875e-08\n",
      "Neuron 6: weight=-0.1538601220, bias=1.8114522696, out_weight=5.39935561538751329635488218627870082855224609375e-11\n",
      "Neuron 7: weight=-0.8120930195, bias=-0.4859311283, out_weight=-2.3913937496899961843155324459075927734375e-09\n",
      "Neuron 8: weight=-0.8302080631, bias=0.0340307839, out_weight=-6.912017624927102588117122650146484375e-09\n",
      "Neuron 9: weight=-2.2118842602, bias=-0.4110427499, out_weight=-2.94273974077441380359232425689697265625e-08\n",
      "Trained by SGD, Step 00000 | Loss: 1.384119e-13\n",
      "Trained by SGD, Step 05000 | Loss: 3.639364e-04\n",
      "Trained by SGD, Step 10000 | Loss: 5.647702e-04\n",
      "Trained by SGD, Step 15000 | Loss: 1.095621e-04\n",
      "Trained by SGD, Step 20000 | Loss: 6.671750e-04\n",
      "Trained by SGD, Step 25000 | Loss: 2.994430e-03\n",
      "Trained by SGD, Step 30000 | Loss: 5.752518e-05\n",
      "SGD Trained network parameters by neuron:\n",
      " Neuron 0: weight=1.7235107422, bias=2.0306725502, out_weight=-0.5919128656\n",
      " Neuron 1: weight=0.7493187785, bias=0.5881339908, out_weight=0.5591326356\n",
      " Neuron 2: weight=1.0886430740, bias=0.8533742428, out_weight=0.4412381947\n",
      " Neuron 3: weight=1.1227918863, bias=-0.8858078718, out_weight=-0.1422196329\n",
      " Neuron 4: weight=0.8279094696, bias=2.2505593300, out_weight=0.0557473786\n",
      " Neuron 5: weight=1.6937888861, bias=-0.2318815887, out_weight=-0.1412827820\n",
      " Neuron 6: weight=-0.1017751247, bias=1.8244038820, out_weight=0.2583456337\n",
      " Neuron 7: weight=-0.9457935095, bias=-1.0962902308, out_weight=-0.5376229286\n",
      " Neuron 8: weight=-2.2466197014, bias=-1.0943845510, out_weight=-0.5463730693\n",
      " Neuron 9: weight=0.1375092417, bias=-1.0933758020, out_weight=0.7084034085\n",
      "\n",
      "\n",
      "Test Error trained by GD: 0.01310\n",
      "\n",
      "\n",
      "Test Error trained by SGD: 0.00123\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "X_f_train = torch.from_numpy(x_f).float().to(device)\n",
    "X_b_train = torch.from_numpy(x_b).float().to(device)\n",
    "dataset = torch.utils.data.TensorDataset(X_f_train)\n",
    "dataloader = torch.utils.data.DataLoader(dataset, batch_size=32, shuffle=True)\n",
    "\n",
    "eta=0.02\n",
    "m=10\n",
    "\n",
    "PINN_GD = Sequentialmodel(m)\n",
    "PINN_GD.to(device)\n",
    "\n",
    "PINN_SGD = Sequentialmodel(m)\n",
    "PINN_SGD.to(device)\n",
    "\n",
    "'Neural Network Summary'\n",
    "print(PINN_GD)\n",
    "print('\\n')\n",
    "\n",
    "PINN_GD.init_exact()\n",
    "print(\"Exact network parameters by neuron:\")       \n",
    "for idx in range(PINN_GD.m):\n",
    "    w = PINN_GD.fc1.weight[idx, 0].item()\n",
    "    b = PINN_GD.fc1.bias[idx].item()\n",
    "    a = PINN_GD.fc2.weight[0, idx].item()\n",
    "    print(f\"Neuron {idx}: weight={w:.10f}, bias={b:.10f}, out_weight={a:.10f}\")\n",
    "print('\\n')\n",
    "V_true, VVt_true, VVt_2norm_true = covariance_fun(PINN_GD, X_f_train, eta, batch_size=32)\n",
    "print(f\"Exact covariance matrix F-norm: {VVt_2norm_true:.6e}\")\n",
    "print('\\n')\n",
    "\n",
    "update_num = 30000\n",
    "max_iter = 100\n",
    "\n",
    "covariance_perturbed_init(PINN_GD, V_true, epsilon_scale=1)\n",
    "PINN_SGD.load_state_dict(PINN_GD.state_dict())\n",
    "\n",
    "'GD'\n",
    "\n",
    "print(\"GD Initial network parameters by neuron:\")       \n",
    "for idx in range(PINN_GD.m):\n",
    "    w = PINN_GD.fc1.weight[idx, 0].item()\n",
    "    b = PINN_GD.fc1.bias[idx].item()\n",
    "    a = PINN_GD.fc2.weight[0, idx].item()\n",
    "    print(f\"Neuron {idx}: weight={w:.10f}, bias={b:.10f}, out_weight={a:.10f}\")\n",
    "    \n",
    "optimizer_GD = optim.SGD(PINN_GD.parameters(), lr=eta)\n",
    "\n",
    "for i in range(update_num):\n",
    "\n",
    "    optimizer_GD.zero_grad()\n",
    "    loss = PINN_GD.loss(X_b_train, X_f_train)\n",
    "    loss.backward()\n",
    "    optimizer_GD.step()\n",
    "\n",
    "    if i % 5000 == 0:\n",
    "        print(f\"Trained by GD, Step {i:05d} | Loss: {loss.item():.6e}\")\n",
    "            \n",
    "print(\"GD Trained network parameters by neuron:\")       \n",
    "for idx in range(PINN_GD.m):\n",
    "    w = PINN_GD.fc1.weight[idx, 0].item()\n",
    "    b = PINN_GD.fc1.bias[idx].item()\n",
    "    a = PINN_GD.fc2.weight[0, idx].item()\n",
    "    print(f\"Neuron {idx}: weight={w:.10f}, bias={b:.10f}, out_weight={a:.10f}\")\n",
    "print('\\n')\n",
    "\n",
    "'SGD'\n",
    "\n",
    "print(\"SGD Initial network parameters by neuron:\")       \n",
    "for idx in range(PINN_SGD.m):\n",
    "    w = PINN_SGD.fc1.weight[idx, 0].item()\n",
    "    b = PINN_SGD.fc1.bias[idx].item()\n",
    "    a = PINN_SGD.fc2.weight[0, idx].item()\n",
    "    print(f\"Neuron {idx}: weight={w:.10f}, bias={b:.10f}, out_weight={a:.510}\")\n",
    "    \n",
    "optimizer_SGD = optim.SGD(PINN_SGD.parameters(), lr=eta)\n",
    "    \n",
    "step = 0\n",
    "\n",
    "for i in range(max_iter):\n",
    "\n",
    "    for batch in dataloader:\n",
    "\n",
    "        batch_x = batch[0].to(device)\n",
    "        optimizer_SGD.zero_grad()\n",
    "        loss = PINN_SGD.loss(X_b_train, batch_x)\n",
    "        loss.backward()\n",
    "        optimizer_SGD.step()\n",
    "\n",
    "        if step % 5000 == 0:\n",
    "            print(f\"Trained by SGD, Step {step:05d} | Loss: {loss.item():.6e}\")\n",
    "        step += 1\n",
    "    \n",
    "print(\"SGD Trained network parameters by neuron:\")       \n",
    "for idx in range(PINN_SGD.m):\n",
    "    w = PINN_SGD.fc1.weight[idx, 0].item()\n",
    "    b = PINN_SGD.fc1.bias[idx].item()\n",
    "    a = PINN_SGD.fc2.weight[0, idx].item()\n",
    "    print(f\" Neuron {idx}: weight={w:.10f}, bias={b:.10f}, out_weight={a:.10f}\")\n",
    "print('\\n')\n",
    "\n",
    "x_eval = np.linspace(-1, 1, 10000).reshape(-1,1)\n",
    "X_eval = torch.from_numpy(x_eval).float().to(device)\n",
    "with torch.no_grad():\n",
    "    u_pred_GD = np.reshape(PINN_GD(X_eval).cpu().detach().numpy(),10000,order='F')\n",
    "    u_pred_SGD = np.reshape(PINN_SGD(X_eval).cpu().detach().numpy(),10000,order='F')\n",
    "\n",
    "def u_true(x):\n",
    "    return np.tanh(2*x + 1)\n",
    "u_true_vals = np.reshape(u_true(x_eval),10000,order='F')\n",
    "\n",
    "error_GD=  torch.linalg.norm(torch.from_numpy(u_true_vals - u_pred_GD), 2) / torch.linalg.norm(torch.from_numpy(u_true_vals), 2)\n",
    "print('Test Error trained by GD: %.5f'  % (error_GD.item()))\n",
    "print('\\n')\n",
    "\n",
    "error_SGD=  torch.linalg.norm(torch.from_numpy(u_true_vals - u_pred_SGD), 2) / torch.linalg.norm(torch.from_numpy(u_true_vals), 2)\n",
    "print('Test Error trained by SGD: %.5f'  % (error_SGD.item()))\n",
    "\n",
    "plt.plot(x_eval, u_pred_GD, label='PINN with lr=0.1 (GD)')\n",
    "plt.plot(x_eval, u_pred_SGD, label='PINN with lr=0.1 (SGD)')\n",
    "plt.plot(x_eval, u_true_vals, '--', label='True')\n",
    "plt.legend()\n",
    "plt.xlabel('x')\n",
    "plt.ylabel('u(x)')\n",
    "plt.title('PINN with lr=0.1 vs True Solution')\n",
    "plt.show()\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "86327772",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "def compute_full_hessian_norm(model, x_b, x_f):\n",
    "\n",
    "    device = next(model.parameters()).device\n",
    "    x_b = x_b.to(device)\n",
    "    x_f = x_f.to(device)\n",
    " \n",
    "    model.zero_grad()\n",
    "    loss_val = model.loss(x_b, x_f)\n",
    "  \n",
    "    params = [p for p in model.parameters() if p.requires_grad]\n",
    "    flat_params = torch.cat([p.view(-1) for p in params])\n",
    "    num_params = flat_params.numel()\n",
    "    \n",
    "    grads = autograd.grad(loss_val, params, create_graph=True, retain_graph=True)\n",
    "    flat_grads = torch.cat([g.view(-1) for g in grads])\n",
    "    \n",
    "    hessian = torch.zeros(num_params, num_params, device=device)\n",
    "    \n",
    "    for i in range(num_params):\n",
    "        \n",
    "        grad_i = flat_grads[i]\n",
    "        grad2_i = autograd.grad(grad_i, params, retain_graph=True, allow_unused=True)\n",
    "        \n",
    "        grad2_i_flat = []\n",
    "        for g, p in zip(grad2_i, params):\n",
    "            if g is None:\n",
    "                grad2_i_flat.append(torch.zeros_like(p).view(-1))\n",
    "            else:\n",
    "                grad2_i_flat.append(g.contiguous().view(-1))\n",
    "        \n",
    "        hessian_row = torch.cat(grad2_i_flat)\n",
    "        hessian[i] = hessian_row\n",
    "    \n",
    "  \n",
    "    hessian = (hessian + hessian.T) / 2.0\n",
    "    \n",
    "   \n",
    "    eigenvalues = torch.linalg.eigvalsh(hessian) \n",
    "    \n",
    "    max_eigenvalue = eigenvalues.abs().max().item()\n",
    "    \n",
    "    return max_eigenvalue, hessian.detach().cpu().numpy()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7b1bcbcb",
   "metadata": {},
   "source": [
    "# Main"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "520f0df2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sequentialmodel(\n",
      "  (fc1): Linear(in_features=1, out_features=10, bias=True)\n",
      "  (activation): Tanh()\n",
      "  (fc2): Linear(in_features=10, out_features=1, bias=False)\n",
      "  (loss_function): MSELoss()\n",
      ")\n",
      "Exact network parameters by neuron (global min):\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-1.6164904833, bias=0.6330825686, out_weight=0.0000000000\n",
      "Neuron 2: weight=-0.1622948050, bias=0.6340952516, out_weight=0.0000000000\n",
      "Neuron 3: weight=-1.1054456234, bias=0.6538760662, out_weight=0.0000000000\n",
      "Neuron 4: weight=-0.1308069974, bias=0.3481885493, out_weight=0.0000000000\n",
      "Neuron 5: weight=1.0693068504, bias=1.0080726147, out_weight=0.0000000000\n",
      "Neuron 6: weight=-2.4896166325, bias=0.9365469813, out_weight=0.0000000000\n",
      "Neuron 7: weight=-2.0577309132, bias=-0.7605363131, out_weight=0.0000000000\n",
      "Neuron 8: weight=0.9791522622, bias=0.2230312228, out_weight=0.0000000000\n",
      "Neuron 9: weight=0.1105062515, bias=-0.9334203005, out_weight=0.0000000000\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "c:\\Users\\user\\anaconda3\\envs\\python_31015\\lib\\site-packages\\torch\\autograd\\graph.py:769: UserWarning: Attempting to run cuBLAS, but there was no current CUDA context! Attempting to set the primary context... (Triggered internally at C:\\actions-runner\\_work\\pytorch\\pytorch\\builder\\windows\\pytorch\\aten\\src\\ATen\\cuda\\CublasHandlePool.cpp:135.)\n",
      "  return Variable._execution_engine.run_backward(  # Calls into the C++ engine to run the backward pass\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Hessian matrix 2-norm: 3.980359e+01\n",
      "\n",
      "\n",
      "Initial step size eta=0.02\n",
      "Critical step size eta**=0.050246720590883524\n",
      "\n",
      "\n",
      "The step size eta=0.02 lies within the stable region for gradient descent.\n",
      "Covariance matrix F-norm at global min with eta=0.02: 3.484832e-15\n",
      "\n",
      "\n",
      "Main Iteration:0\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=0.9999999404, out_weight=1.0000000000\n",
      "Neuron 1: weight=1.0157213211, bias=-0.8315619826, out_weight=-0.0000000118\n",
      "Neuron 2: weight=-0.0621909387, bias=-0.3424026072, out_weight=0.0000000001\n",
      "Neuron 3: weight=-0.2561483979, bias=-1.4075105190, out_weight=-0.0000000043\n",
      "Neuron 4: weight=-0.6494032741, bias=-1.0068430901, out_weight=0.0000000000\n",
      "Neuron 5: weight=1.6913574934, bias=0.2085422277, out_weight=-0.0000000018\n",
      "Neuron 6: weight=-0.1687933505, bias=0.0193619207, out_weight=-0.0000000090\n",
      "Neuron 7: weight=-1.3391933441, bias=1.9213265181, out_weight=-0.0000000059\n",
      "Neuron 8: weight=-0.9603151083, bias=1.5592291355, out_weight=0.0000000048\n",
      "Neuron 9: weight=1.7129454613, bias=0.3680042028, out_weight=-0.0000000000\n",
      "Initial covariance matrix F-norm: 6.202084e-15\n",
      "Step 00000 | Loss: 9.478529e-14\n",
      "Step 01000 | Loss: 9.671430e-14\n",
      "Step 02000 | Loss: 1.163306e-13\n",
      "Step 03000 | Loss: 6.637052e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=1.0157213211, bias=-0.8315619826, out_weight=0.0000000465\n",
      "Neuron 2: weight=-0.0621909387, bias=-0.3424026072, out_weight=-0.0000000480\n",
      "Neuron 3: weight=-0.2561483979, bias=-1.4075105190, out_weight=-0.0000001190\n",
      "Neuron 4: weight=-0.6494032741, bias=-1.0068430901, out_weight=0.0000001395\n",
      "Neuron 5: weight=1.6913574934, bias=0.2085422277, out_weight=0.0000000602\n",
      "Neuron 6: weight=-0.1687933505, bias=0.0193619207, out_weight=0.0000000041\n",
      "Neuron 7: weight=-1.3391933441, bias=1.9213265181, out_weight=-0.0000000121\n",
      "Neuron 8: weight=-0.9603151083, bias=1.5592291355, out_weight=0.0000000317\n",
      "Neuron 9: weight=1.7129454613, bias=0.3680042028, out_weight=-0.0000000517\n",
      "Final covariance matrix F-norm: 2.314055e-15\n",
      "\n",
      "\n",
      "Main Iteration:1\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=0.0644711256, bias=-0.4688434303, out_weight=0.0000000130\n",
      "Neuron 2: weight=-0.3694997132, bias=-0.6338381171, out_weight=0.0000000004\n",
      "Neuron 3: weight=-1.7657381296, bias=0.5827450156, out_weight=0.0000000072\n",
      "Neuron 4: weight=0.2658398151, bias=-0.8018705249, out_weight=0.0000000002\n",
      "Neuron 5: weight=-0.3311361074, bias=-0.7463126779, out_weight=0.0000000127\n",
      "Neuron 6: weight=0.5414656401, bias=1.0347417593, out_weight=0.0000000300\n",
      "Neuron 7: weight=0.6948882341, bias=-0.5543017983, out_weight=-0.0000000221\n",
      "Neuron 8: weight=-0.6482290626, bias=0.1411211342, out_weight=0.0000000050\n",
      "Neuron 9: weight=-0.9730006456, bias=-0.1752773225, out_weight=-0.0000000002\n",
      "Initial covariance matrix F-norm: 1.859315e-15\n",
      "Step 00000 | Loss: 4.083713e-14\n",
      "Step 01000 | Loss: 5.211283e-14\n",
      "Step 02000 | Loss: 3.574918e-14\n",
      "Step 03000 | Loss: 5.604545e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=0.0644711256, bias=-0.4688434303, out_weight=-0.0000000780\n",
      "Neuron 2: weight=-0.3694997132, bias=-0.6338381171, out_weight=0.0000000280\n",
      "Neuron 3: weight=-1.7657381296, bias=0.5827450156, out_weight=-0.0000000202\n",
      "Neuron 4: weight=0.2658398151, bias=-0.8018705249, out_weight=-0.0000000711\n",
      "Neuron 5: weight=-0.3311361074, bias=-0.7463126779, out_weight=0.0000000034\n",
      "Neuron 6: weight=0.5414656401, bias=1.0347417593, out_weight=-0.0000000728\n",
      "Neuron 7: weight=0.6948882341, bias=-0.5543017983, out_weight=0.0000001134\n",
      "Neuron 8: weight=-0.6482290626, bias=0.1411211342, out_weight=-0.0000000208\n",
      "Neuron 9: weight=-0.9730006456, bias=-0.1752773225, out_weight=0.0000000315\n",
      "Final covariance matrix F-norm: 1.894664e-15\n",
      "\n",
      "\n",
      "Main Iteration:2\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.4689146578, bias=1.3513969183, out_weight=0.0000000132\n",
      "Neuron 2: weight=0.5718181729, bias=0.0834709927, out_weight=-0.0000000002\n",
      "Neuron 3: weight=0.5893953443, bias=0.0180278942, out_weight=0.0000000036\n",
      "Neuron 4: weight=-1.7301383018, bias=-0.5449380875, out_weight=-0.0000000001\n",
      "Neuron 5: weight=-0.1222872883, bias=-0.9760639071, out_weight=-0.0000000036\n",
      "Neuron 6: weight=0.6063237190, bias=0.6424314976, out_weight=0.0000000581\n",
      "Neuron 7: weight=-1.0342558622, bias=0.8899900913, out_weight=-0.0000000041\n",
      "Neuron 8: weight=0.5851250887, bias=0.4584318995, out_weight=0.0000000022\n",
      "Neuron 9: weight=1.9918416739, bias=0.1775036752, out_weight=0.0000000001\n",
      "Initial covariance matrix F-norm: 2.384496e-15\n",
      "Step 00000 | Loss: 8.155976e-14\n",
      "Step 01000 | Loss: 8.368480e-14\n",
      "Step 02000 | Loss: 8.857151e-14\n",
      "Step 03000 | Loss: 4.248858e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.4689146578, bias=1.3513969183, out_weight=0.0000000316\n",
      "Neuron 2: weight=0.5718181729, bias=0.0834709927, out_weight=0.0000000528\n",
      "Neuron 3: weight=0.5893953443, bias=0.0180278942, out_weight=0.0000000807\n",
      "Neuron 4: weight=-1.7301383018, bias=-0.5449380875, out_weight=-0.0000000158\n",
      "Neuron 5: weight=-0.1222872883, bias=-0.9760639071, out_weight=-0.0000000295\n",
      "Neuron 6: weight=0.6063237190, bias=0.6424314976, out_weight=-0.0000000811\n",
      "Neuron 7: weight=-1.0342558622, bias=0.8899900913, out_weight=-0.0000000191\n",
      "Neuron 8: weight=0.5851250887, bias=0.4584318995, out_weight=-0.0000000679\n",
      "Neuron 9: weight=1.9918416739, bias=0.1775036752, out_weight=-0.0000000053\n",
      "Final covariance matrix F-norm: 2.407157e-15\n",
      "\n",
      "\n",
      "Main Iteration:3\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.0798821896, bias=0.9542006254, out_weight=0.0000000034\n",
      "Neuron 2: weight=-0.0789611414, bias=-0.0411498882, out_weight=-0.0000000000\n",
      "Neuron 3: weight=0.7901890874, bias=-0.5223459601, out_weight=-0.0000000003\n",
      "Neuron 4: weight=1.8723473549, bias=-1.5032391548, out_weight=-0.0000000000\n",
      "Neuron 5: weight=0.2011351138, bias=0.4927207530, out_weight=-0.0000000002\n",
      "Neuron 6: weight=0.3116843700, bias=-0.2769274414, out_weight=0.0000000197\n",
      "Neuron 7: weight=-0.5481189489, bias=-1.8920499086, out_weight=-0.0000000156\n",
      "Neuron 8: weight=-1.1748374701, bias=-0.3524604142, out_weight=0.0000000025\n",
      "Neuron 9: weight=-0.4126217663, bias=0.3103223145, out_weight=-0.0000000000\n",
      "Initial covariance matrix F-norm: 1.883149e-15\n",
      "Step 00000 | Loss: 9.247637e-14\n",
      "Step 01000 | Loss: 1.018855e-13\n",
      "Step 02000 | Loss: 6.332088e-14\n",
      "Step 03000 | Loss: 5.132873e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.0798821896, bias=0.9542006254, out_weight=0.0000000756\n",
      "Neuron 2: weight=-0.0789611414, bias=-0.0411498882, out_weight=0.0000000184\n",
      "Neuron 3: weight=0.7901890874, bias=-0.5223459601, out_weight=0.0000001651\n",
      "Neuron 4: weight=1.8723473549, bias=-1.5032391548, out_weight=-0.0000000201\n",
      "Neuron 5: weight=0.2011351138, bias=0.4927207530, out_weight=-0.0000000298\n",
      "Neuron 6: weight=0.3116843700, bias=-0.2769274414, out_weight=-0.0000000209\n",
      "Neuron 7: weight=-0.5481189489, bias=-1.8920499086, out_weight=0.0000000039\n",
      "Neuron 8: weight=-1.1748374701, bias=-0.3524604142, out_weight=0.0000000486\n",
      "Neuron 9: weight=-0.4126217663, bias=0.3103223145, out_weight=0.0000000142\n",
      "Final covariance matrix F-norm: 1.977198e-15\n",
      "\n",
      "\n",
      "Main Iteration:4\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-2.2703115940, bias=-0.7812588215, out_weight=0.0000000213\n",
      "Neuron 2: weight=0.9026724696, bias=-1.5861744881, out_weight=0.0000000002\n",
      "Neuron 3: weight=0.2457197607, bias=0.5430786014, out_weight=0.0000000151\n",
      "Neuron 4: weight=0.0462368056, bias=-0.0056350464, out_weight=0.0000000001\n",
      "Neuron 5: weight=1.3735525608, bias=0.4771502912, out_weight=0.0000000121\n",
      "Neuron 6: weight=-0.4031038880, bias=-0.1336037070, out_weight=0.0000000026\n",
      "Neuron 7: weight=-1.7113126516, bias=1.0055249929, out_weight=-0.0000000280\n",
      "Neuron 8: weight=-1.6537710428, bias=0.2850004733, out_weight=0.0000000038\n",
      "Neuron 9: weight=1.8583124876, bias=0.8166379929, out_weight=-0.0000000001\n",
      "Initial covariance matrix F-norm: 3.652190e-15\n",
      "Step 00000 | Loss: 6.999609e-14\n",
      "Step 01000 | Loss: 4.808653e-14\n",
      "Step 02000 | Loss: 9.066359e-14\n",
      "Step 03000 | Loss: 8.077566e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-2.2703115940, bias=-0.7812588215, out_weight=0.0000000296\n",
      "Neuron 2: weight=0.9026724696, bias=-1.5861744881, out_weight=0.0000000497\n",
      "Neuron 3: weight=0.2457197607, bias=0.5430786014, out_weight=0.0000000790\n",
      "Neuron 4: weight=0.0462368056, bias=-0.0056350464, out_weight=-0.0000000247\n",
      "Neuron 5: weight=1.3735525608, bias=0.4771502912, out_weight=-0.0000001401\n",
      "Neuron 6: weight=-0.4031038880, bias=-0.1336037070, out_weight=0.0000001605\n",
      "Neuron 7: weight=-1.7113126516, bias=1.0055249929, out_weight=-0.0000000092\n",
      "Neuron 8: weight=-1.6537710428, bias=0.2850004733, out_weight=-0.0000000568\n",
      "Neuron 9: weight=1.8583124876, bias=0.8166379929, out_weight=0.0000000945\n",
      "Final covariance matrix F-norm: 3.650898e-15\n",
      "\n",
      "\n",
      "Main Iteration:5\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.4053395092, bias=1.8806301355, out_weight=-0.0000000365\n",
      "Neuron 2: weight=-1.1801158190, bias=-0.3917222917, out_weight=-0.0000000002\n",
      "Neuron 3: weight=0.1552209258, bias=0.0860372335, out_weight=-0.0000000173\n",
      "Neuron 4: weight=0.8109305501, bias=0.1679715961, out_weight=-0.0000000001\n",
      "Neuron 5: weight=0.3097223639, bias=0.0269418545, out_weight=-0.0000000085\n",
      "Neuron 6: weight=0.8837338686, bias=0.0239571631, out_weight=-0.0000000665\n",
      "Neuron 7: weight=0.4019806087, bias=-0.5575602055, out_weight=0.0000000019\n",
      "Neuron 8: weight=-1.7088197470, bias=2.0966291428, out_weight=0.0000000048\n",
      "Neuron 9: weight=-1.8416970968, bias=1.1421524286, out_weight=0.0000000001\n",
      "Initial covariance matrix F-norm: 2.005332e-15\n",
      "Step 00000 | Loss: 6.936118e-14\n",
      "Step 01000 | Loss: 5.464726e-14\n",
      "Step 02000 | Loss: 8.157537e-14\n",
      "Step 03000 | Loss: 9.951241e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.4053395092, bias=1.8806301355, out_weight=0.0000000309\n",
      "Neuron 2: weight=-1.1801158190, bias=-0.3917222917, out_weight=-0.0000000603\n",
      "Neuron 3: weight=0.1552209258, bias=0.0860372335, out_weight=-0.0000000901\n",
      "Neuron 4: weight=0.8109305501, bias=0.1679715961, out_weight=-0.0000000339\n",
      "Neuron 5: weight=0.3097223639, bias=0.0269418545, out_weight=-0.0000001325\n",
      "Neuron 6: weight=0.8837338686, bias=0.0239571631, out_weight=0.0000000492\n",
      "Neuron 7: weight=0.4019806087, bias=-0.5575602055, out_weight=-0.0000000381\n",
      "Neuron 8: weight=-1.7088197470, bias=2.0966291428, out_weight=-0.0000000307\n",
      "Neuron 9: weight=-1.8416970968, bias=1.1421524286, out_weight=-0.0000000259\n",
      "Final covariance matrix F-norm: 2.103451e-15\n",
      "\n",
      "\n",
      "Main Iteration:6\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=0.0636566505, bias=-1.2696530819, out_weight=0.0000000523\n",
      "Neuron 2: weight=-0.0657867417, bias=-1.5288972855, out_weight=0.0000000002\n",
      "Neuron 3: weight=0.7055556178, bias=-0.3780641854, out_weight=0.0000000232\n",
      "Neuron 4: weight=1.7068165541, bias=-1.0457283258, out_weight=0.0000000001\n",
      "Neuron 5: weight=-0.0020166119, bias=-0.1342581958, out_weight=0.0000000138\n",
      "Neuron 6: weight=0.0676440448, bias=2.4964983463, out_weight=0.0000000913\n",
      "Neuron 7: weight=-0.3256452680, bias=0.3032752275, out_weight=-0.0000000270\n",
      "Neuron 8: weight=-0.5798569322, bias=-0.5950963497, out_weight=-0.0000000044\n",
      "Neuron 9: weight=-1.4991163015, bias=1.4509570599, out_weight=-0.0000000001\n",
      "Initial covariance matrix F-norm: 1.873728e-15\n",
      "Step 00000 | Loss: 7.666784e-14\n",
      "Step 01000 | Loss: 6.960949e-14\n",
      "Step 02000 | Loss: 6.357935e-14\n",
      "Step 03000 | Loss: 5.309121e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=0.0636566505, bias=-1.2696530819, out_weight=0.0000000302\n",
      "Neuron 2: weight=-0.0657867417, bias=-1.5288972855, out_weight=-0.0000000192\n",
      "Neuron 3: weight=0.7055556178, bias=-0.3780641854, out_weight=0.0000001550\n",
      "Neuron 4: weight=1.7068165541, bias=-1.0457283258, out_weight=0.0000000149\n",
      "Neuron 5: weight=-0.0020166119, bias=-0.1342581958, out_weight=0.0000000108\n",
      "Neuron 6: weight=0.0676440448, bias=2.4964983463, out_weight=0.0000001154\n",
      "Neuron 7: weight=-0.3256452680, bias=0.3032752275, out_weight=-0.0000000384\n",
      "Neuron 8: weight=-0.5798569322, bias=-0.5950963497, out_weight=0.0000001861\n",
      "Neuron 9: weight=-1.4991163015, bias=1.4509570599, out_weight=0.0000000142\n",
      "Final covariance matrix F-norm: 1.952315e-15\n",
      "\n",
      "\n",
      "Main Iteration:7\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=0.9999999404\n",
      "Neuron 1: weight=-0.2363606840, bias=1.4925841093, out_weight=-0.0000000327\n",
      "Neuron 2: weight=-0.3568039536, bias=-1.0599335432, out_weight=-0.0000000004\n",
      "Neuron 3: weight=-0.3741112649, bias=-0.9955452085, out_weight=-0.0000000157\n",
      "Neuron 4: weight=-0.0893282592, bias=-0.5675718784, out_weight=-0.0000000002\n",
      "Neuron 5: weight=0.6761741042, bias=1.6028903723, out_weight=-0.0000000129\n",
      "Neuron 6: weight=-0.3069067895, bias=-0.7243453264, out_weight=-0.0000000716\n",
      "Neuron 7: weight=0.3184945583, bias=0.1797552109, out_weight=0.0000000449\n",
      "Neuron 8: weight=1.5170882940, bias=-1.2913388014, out_weight=-0.0000000055\n",
      "Neuron 9: weight=-1.0880161524, bias=0.5342912674, out_weight=0.0000000002\n",
      "Initial covariance matrix F-norm: 2.627458e-15\n",
      "Step 00000 | Loss: 7.225297e-14\n",
      "Step 01000 | Loss: 1.040348e-13\n",
      "Step 02000 | Loss: 6.198514e-14\n",
      "Step 03000 | Loss: 7.472148e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.2363606840, bias=1.4925841093, out_weight=0.0000001712\n",
      "Neuron 2: weight=-0.3568039536, bias=-1.0599335432, out_weight=-0.0000000332\n",
      "Neuron 3: weight=-0.3741112649, bias=-0.9955452085, out_weight=-0.0000000310\n",
      "Neuron 4: weight=-0.0893282592, bias=-0.5675718784, out_weight=-0.0000001153\n",
      "Neuron 5: weight=0.6761741042, bias=1.6028903723, out_weight=-0.0000003977\n",
      "Neuron 6: weight=-0.3069067895, bias=-0.7243453264, out_weight=-0.0000001425\n",
      "Neuron 7: weight=0.3184945583, bias=0.1797552109, out_weight=0.0000001931\n",
      "Neuron 8: weight=1.5170882940, bias=-1.2913388014, out_weight=-0.0000000020\n",
      "Neuron 9: weight=-1.0880161524, bias=0.5342912674, out_weight=0.0000000210\n",
      "Final covariance matrix F-norm: 1.838207e-15\n",
      "\n",
      "\n",
      "Main Iteration:8\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-1.1410635710, bias=0.9207007289, out_weight=0.0000000102\n",
      "Neuron 2: weight=-0.4125171602, bias=0.3389493823, out_weight=0.0000000001\n",
      "Neuron 3: weight=0.8801433444, bias=1.2111874819, out_weight=0.0000000035\n",
      "Neuron 4: weight=-2.3219459057, bias=-0.6840869188, out_weight=0.0000000001\n",
      "Neuron 5: weight=-1.5240038633, bias=-0.4603850842, out_weight=0.0000000056\n",
      "Neuron 6: weight=-2.4191398621, bias=-1.2212493420, out_weight=0.0000000185\n",
      "Neuron 7: weight=0.2703894079, bias=-0.0624746196, out_weight=-0.0000000125\n",
      "Neuron 8: weight=1.5007317066, bias=1.3604815006, out_weight=-0.0000000010\n",
      "Neuron 9: weight=-0.3407146335, bias=1.3656281233, out_weight=-0.0000000000\n",
      "Initial covariance matrix F-norm: 4.013269e-15\n",
      "Step 00000 | Loss: 6.398354e-14\n",
      "Step 01000 | Loss: 5.148833e-14\n",
      "Step 02000 | Loss: 9.623032e-14\n",
      "Step 03000 | Loss: 8.409072e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-1.1410635710, bias=0.9207007289, out_weight=-0.0000000297\n",
      "Neuron 2: weight=-0.4125171602, bias=0.3389493823, out_weight=-0.0000000226\n",
      "Neuron 3: weight=0.8801433444, bias=1.2111874819, out_weight=-0.0000001343\n",
      "Neuron 4: weight=-2.3219459057, bias=-0.6840869188, out_weight=0.0000000286\n",
      "Neuron 5: weight=-1.5240038633, bias=-0.4603850842, out_weight=-0.0000000680\n",
      "Neuron 6: weight=-2.4191398621, bias=-1.2212493420, out_weight=0.0000000088\n",
      "Neuron 7: weight=0.2703894079, bias=-0.0624746196, out_weight=-0.0000000041\n",
      "Neuron 8: weight=1.5007317066, bias=1.3604815006, out_weight=0.0000000226\n",
      "Neuron 9: weight=-0.3407146335, bias=1.3656281233, out_weight=0.0000001150\n",
      "Final covariance matrix F-norm: 4.896543e-15\n",
      "\n",
      "\n",
      "Main Iteration:9\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.3353685439, bias=-1.6928908825, out_weight=-0.0000000015\n",
      "Neuron 2: weight=0.5403024554, bias=-1.7660541534, out_weight=-0.0000000002\n",
      "Neuron 3: weight=-0.7028779984, bias=0.3054963052, out_weight=-0.0000000018\n",
      "Neuron 4: weight=-0.8143140674, bias=-0.3542229831, out_weight=-0.0000000001\n",
      "Neuron 5: weight=0.2747886479, bias=-0.4398599565, out_weight=-0.0000000046\n",
      "Neuron 6: weight=1.5088987350, bias=-0.7061455250, out_weight=0.0000000131\n",
      "Neuron 7: weight=0.9137540460, bias=0.8804106712, out_weight=-0.0000000143\n",
      "Neuron 8: weight=-0.5868622065, bias=0.4186665118, out_weight=0.0000000076\n",
      "Neuron 9: weight=-1.5044656992, bias=-0.8772856593, out_weight=0.0000000001\n",
      "Initial covariance matrix F-norm: 1.982441e-15\n",
      "Step 00000 | Loss: 6.614327e-14\n",
      "Step 01000 | Loss: 6.046422e-14\n",
      "Step 02000 | Loss: 7.817705e-14\n",
      "Step 03000 | Loss: 6.939588e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.3353685439, bias=-1.6928908825, out_weight=-0.0000000334\n",
      "Neuron 2: weight=0.5403024554, bias=-1.7660541534, out_weight=-0.0000000132\n",
      "Neuron 3: weight=-0.7028779984, bias=0.3054963052, out_weight=-0.0000000127\n",
      "Neuron 4: weight=-0.8143140674, bias=-0.3542229831, out_weight=0.0000000339\n",
      "Neuron 5: weight=0.2747886479, bias=-0.4398599565, out_weight=-0.0000000154\n",
      "Neuron 6: weight=1.5088987350, bias=-0.7061455250, out_weight=0.0000000134\n",
      "Neuron 7: weight=0.9137540460, bias=0.8804106712, out_weight=-0.0000001254\n",
      "Neuron 8: weight=-0.5868622065, bias=0.4186665118, out_weight=-0.0000000099\n",
      "Neuron 9: weight=-1.5044656992, bias=-0.8772856593, out_weight=-0.0000000779\n",
      "Final covariance matrix F-norm: 2.159581e-15\n",
      "\n",
      "\n",
      "Main Iteration:10\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=1.1271572113, bias=1.1909453869, out_weight=0.0000000295\n",
      "Neuron 2: weight=0.8389213681, bias=-0.2481373399, out_weight=0.0000000007\n",
      "Neuron 3: weight=0.1069320291, bias=0.6242386699, out_weight=0.0000000187\n",
      "Neuron 4: weight=0.9738952518, bias=0.0298695005, out_weight=0.0000000004\n",
      "Neuron 5: weight=-1.7178994417, bias=-0.3415849507, out_weight=0.0000000193\n",
      "Neuron 6: weight=-0.4046015739, bias=-0.4115113914, out_weight=0.0000000390\n",
      "Neuron 7: weight=1.6323773861, bias=-1.6057101488, out_weight=-0.0000000117\n",
      "Neuron 8: weight=-0.2038651854, bias=-0.7589679956, out_weight=-0.0000000028\n",
      "Neuron 9: weight=1.4892702103, bias=0.6036748886, out_weight=-0.0000000003\n",
      "Initial covariance matrix F-norm: 2.428070e-15\n",
      "Step 00000 | Loss: 6.309883e-14\n",
      "Step 01000 | Loss: 7.845113e-14\n",
      "Step 02000 | Loss: 7.917625e-14\n",
      "Step 03000 | Loss: 6.289066e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=1.1271572113, bias=1.1909453869, out_weight=-0.0000001211\n",
      "Neuron 2: weight=0.8389213681, bias=-0.2481373399, out_weight=0.0000000354\n",
      "Neuron 3: weight=0.1069320291, bias=0.6242386699, out_weight=0.0000000655\n",
      "Neuron 4: weight=0.9738952518, bias=0.0298695005, out_weight=0.0000000759\n",
      "Neuron 5: weight=-1.7178994417, bias=-0.3415849507, out_weight=0.0000000735\n",
      "Neuron 6: weight=-0.4046015739, bias=-0.4115113914, out_weight=0.0000000527\n",
      "Neuron 7: weight=1.6323773861, bias=-1.6057101488, out_weight=-0.0000000054\n",
      "Neuron 8: weight=-0.2038651854, bias=-0.7589679956, out_weight=-0.0000000393\n",
      "Neuron 9: weight=1.4892702103, bias=0.6036748886, out_weight=0.0000001025\n",
      "Final covariance matrix F-norm: 2.400416e-15\n",
      "\n",
      "\n",
      "Main Iteration:11\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.7408524156, bias=-1.4163776636, out_weight=0.0000000058\n",
      "Neuron 2: weight=-1.3578414917, bias=1.1320396662, out_weight=-0.0000000002\n",
      "Neuron 3: weight=-0.8376572728, bias=-1.6715322733, out_weight=-0.0000000024\n",
      "Neuron 4: weight=1.1852490902, bias=-0.5340163112, out_weight=-0.0000000001\n",
      "Neuron 5: weight=-1.4600281715, bias=-0.9245674610, out_weight=-0.0000000030\n",
      "Neuron 6: weight=-1.4365832806, bias=-0.3663595915, out_weight=0.0000000359\n",
      "Neuron 7: weight=1.5840369463, bias=-0.3911296427, out_weight=0.0000000013\n",
      "Neuron 8: weight=1.0157834291, bias=0.0854762867, out_weight=-0.0000000006\n",
      "Neuron 9: weight=-0.6013790965, bias=-1.1343820095, out_weight=0.0000000001\n",
      "Initial covariance matrix F-norm: 2.176780e-15\n",
      "Step 00000 | Loss: 5.436970e-14\n",
      "Step 01000 | Loss: 5.263845e-14\n",
      "Step 02000 | Loss: 5.880019e-14\n",
      "Step 03000 | Loss: 7.147061e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.7408524156, bias=-1.4163776636, out_weight=0.0000000289\n",
      "Neuron 2: weight=-1.3578414917, bias=1.1320396662, out_weight=-0.0000000389\n",
      "Neuron 3: weight=-0.8376572728, bias=-1.6715322733, out_weight=-0.0000000077\n",
      "Neuron 4: weight=1.1852490902, bias=-0.5340163112, out_weight=-0.0000000616\n",
      "Neuron 5: weight=-1.4600281715, bias=-0.9245674610, out_weight=0.0000000042\n",
      "Neuron 6: weight=-1.4365832806, bias=-0.3663595915, out_weight=-0.0000000011\n",
      "Neuron 7: weight=1.5840369463, bias=-0.3911296427, out_weight=0.0000000509\n",
      "Neuron 8: weight=1.0157834291, bias=0.0854762867, out_weight=-0.0000000534\n",
      "Neuron 9: weight=-0.6013790965, bias=-1.1343820095, out_weight=-0.0000000196\n",
      "Final covariance matrix F-norm: 2.202420e-15\n",
      "\n",
      "\n",
      "Main Iteration:12\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.4325640202, bias=-0.7861450315, out_weight=-0.0000000115\n",
      "Neuron 2: weight=-1.4087707996, bias=-1.3118515015, out_weight=-0.0000000004\n",
      "Neuron 3: weight=-1.0216101408, bias=1.1189684868, out_weight=-0.0000000082\n",
      "Neuron 4: weight=0.5653166771, bias=1.8292890787, out_weight=-0.0000000002\n",
      "Neuron 5: weight=0.3674516976, bias=-0.4722127020, out_weight=-0.0000000096\n",
      "Neuron 6: weight=0.3752543926, bias=1.9593399763, out_weight=-0.0000000253\n",
      "Neuron 7: weight=-0.7074102759, bias=-0.1843419522, out_weight=-0.0000000045\n",
      "Neuron 8: weight=0.6285465360, bias=-0.7443274260, out_weight=0.0000000001\n",
      "Neuron 9: weight=-0.3329925239, bias=-0.0442384407, out_weight=0.0000000002\n",
      "Initial covariance matrix F-norm: 1.714839e-15\n",
      "Step 00000 | Loss: 5.199313e-14\n",
      "Step 01000 | Loss: 8.383051e-14\n",
      "Step 02000 | Loss: 6.054185e-14\n",
      "Step 03000 | Loss: 1.079553e-13\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.4325640202, bias=-0.7861450315, out_weight=0.0000000491\n",
      "Neuron 2: weight=-1.4087707996, bias=-1.3118515015, out_weight=0.0000000405\n",
      "Neuron 3: weight=-1.0216101408, bias=1.1189684868, out_weight=-0.0000000433\n",
      "Neuron 4: weight=0.5653166771, bias=1.8292890787, out_weight=0.0000000063\n",
      "Neuron 5: weight=0.3674516976, bias=-0.4722127020, out_weight=-0.0000000171\n",
      "Neuron 6: weight=0.3752543926, bias=1.9593399763, out_weight=0.0000000530\n",
      "Neuron 7: weight=-0.7074102759, bias=-0.1843419522, out_weight=-0.0000000758\n",
      "Neuron 8: weight=0.6285465360, bias=-0.7443274260, out_weight=0.0000000493\n",
      "Neuron 9: weight=-0.3329925239, bias=-0.0442384407, out_weight=0.0000000119\n",
      "Final covariance matrix F-norm: 1.795562e-15\n",
      "\n",
      "\n",
      "Main Iteration:13\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=0.4415431917, bias=-0.3264282346, out_weight=-0.0000000244\n",
      "Neuron 2: weight=-0.7207796574, bias=1.4445667267, out_weight=-0.0000000003\n",
      "Neuron 3: weight=-0.0585907027, bias=0.8539324999, out_weight=-0.0000000112\n",
      "Neuron 4: weight=-0.5830104947, bias=-0.1663232595, out_weight=-0.0000000002\n",
      "Neuron 5: weight=-0.3732480407, bias=0.4447566569, out_weight=-0.0000000064\n",
      "Neuron 6: weight=1.0670239925, bias=-0.9203750491, out_weight=-0.0000000464\n",
      "Neuron 7: weight=0.1421764642, bias=1.0166269541, out_weight=-0.0000000141\n",
      "Neuron 8: weight=0.8137424588, bias=2.5589799881, out_weight=0.0000000098\n",
      "Neuron 9: weight=-1.9114128351, bias=-0.7664008737, out_weight=0.0000000001\n",
      "Initial covariance matrix F-norm: 2.292379e-15\n",
      "Step 00000 | Loss: 4.720703e-14\n",
      "Step 01000 | Loss: 1.087203e-13\n",
      "Step 02000 | Loss: 4.854201e-14\n",
      "Step 03000 | Loss: 6.281260e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=0.4415431917, bias=-0.3264282346, out_weight=-0.0000000197\n",
      "Neuron 2: weight=-0.7207796574, bias=1.4445667267, out_weight=0.0000000283\n",
      "Neuron 3: weight=-0.0585907027, bias=0.8539324999, out_weight=0.0000000459\n",
      "Neuron 4: weight=-0.5830104947, bias=-0.1663232595, out_weight=0.0000000358\n",
      "Neuron 5: weight=-0.3732480407, bias=0.4447566569, out_weight=0.0000000131\n",
      "Neuron 6: weight=1.0670239925, bias=-0.9203750491, out_weight=0.0000000405\n",
      "Neuron 7: weight=0.1421764642, bias=1.0166269541, out_weight=0.0000000026\n",
      "Neuron 8: weight=0.8137424588, bias=2.5589799881, out_weight=-0.0000000376\n",
      "Neuron 9: weight=-1.9114128351, bias=-0.7664008737, out_weight=-0.0000000255\n",
      "Final covariance matrix F-norm: 2.337155e-15\n",
      "\n",
      "\n",
      "Main Iteration:14\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=0.9999999404, out_weight=1.0000001192\n",
      "Neuron 1: weight=-2.3853390217, bias=0.2848291099, out_weight=0.0000000240\n",
      "Neuron 2: weight=-2.1278102398, bias=-1.4610561132, out_weight=0.0000000004\n",
      "Neuron 3: weight=-0.2747634947, bias=-0.3308350444, out_weight=0.0000000093\n",
      "Neuron 4: weight=-0.9668187499, bias=2.5014224052, out_weight=0.0000000002\n",
      "Neuron 5: weight=-0.3187283874, bias=-1.0681014061, out_weight=0.0000000128\n",
      "Neuron 6: weight=1.3684610128, bias=0.5661051273, out_weight=0.0000000649\n",
      "Neuron 7: weight=0.1574679315, bias=-0.5453080535, out_weight=-0.0000000680\n",
      "Neuron 8: weight=0.0431605428, bias=-0.2576096058, out_weight=0.0000000104\n",
      "Neuron 9: weight=-0.2985710502, bias=0.5447013378, out_weight=-0.0000000002\n",
      "Initial covariance matrix F-norm: 8.734425e-15\n",
      "Step 00000 | Loss: 2.308344e-13\n",
      "Step 01000 | Loss: 6.491509e-14\n",
      "Step 02000 | Loss: 5.715740e-14\n",
      "Step 03000 | Loss: 7.881890e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000001192\n",
      "Neuron 1: weight=-2.3853390217, bias=0.2848291099, out_weight=-0.0000000304\n",
      "Neuron 2: weight=-2.1278102398, bias=-1.4610561132, out_weight=0.0000000339\n",
      "Neuron 3: weight=-0.2747634947, bias=-0.3308350444, out_weight=-0.0000000926\n",
      "Neuron 4: weight=-0.9668187499, bias=2.5014224052, out_weight=0.0000000450\n",
      "Neuron 5: weight=-0.3187283874, bias=-1.0681014061, out_weight=-0.0000000237\n",
      "Neuron 6: weight=1.3684610128, bias=0.5661051273, out_weight=-0.0000002333\n",
      "Neuron 7: weight=0.1574679315, bias=-0.5453080535, out_weight=-0.0000000111\n",
      "Neuron 8: weight=0.0431605428, bias=-0.2576096058, out_weight=0.0000000340\n",
      "Neuron 9: weight=-0.2985710502, bias=0.5447013378, out_weight=-0.0000000903\n",
      "Final covariance matrix F-norm: 3.738886e-15\n",
      "\n",
      "\n",
      "Main Iteration:15\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-1.0049656630, bias=-0.4230903983, out_weight=0.0000000038\n",
      "Neuron 2: weight=0.5706607699, bias=-0.3267307580, out_weight=0.0000000003\n",
      "Neuron 3: weight=-0.9411361814, bias=-0.0999625996, out_weight=0.0000000063\n",
      "Neuron 4: weight=-0.6839153767, bias=0.3924555779, out_weight=0.0000000002\n",
      "Neuron 5: weight=-0.9821395278, bias=0.8983654380, out_weight=0.0000000069\n",
      "Neuron 6: weight=-0.3951538801, bias=1.4591628313, out_weight=-0.0000000034\n",
      "Neuron 7: weight=0.5662586093, bias=0.8881697655, out_weight=0.0000000315\n",
      "Neuron 8: weight=-0.7226403356, bias=-0.7965043187, out_weight=-0.0000000064\n",
      "Neuron 9: weight=-0.3839495480, bias=-0.0201015174, out_weight=-0.0000000001\n",
      "Initial covariance matrix F-norm: 1.750745e-15\n",
      "Step 00000 | Loss: 6.104535e-14\n",
      "Step 01000 | Loss: 5.325081e-14\n",
      "Step 02000 | Loss: 5.248926e-14\n",
      "Step 03000 | Loss: 6.610728e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-1.0049656630, bias=-0.4230903983, out_weight=-0.0000000269\n",
      "Neuron 2: weight=0.5706607699, bias=-0.3267307580, out_weight=0.0000000156\n",
      "Neuron 3: weight=-0.9411361814, bias=-0.0999625996, out_weight=-0.0000000566\n",
      "Neuron 4: weight=-0.6839153767, bias=0.3924555779, out_weight=-0.0000000417\n",
      "Neuron 5: weight=-0.9821395278, bias=0.8983654380, out_weight=-0.0000000164\n",
      "Neuron 6: weight=-0.3951538801, bias=1.4591628313, out_weight=0.0000001055\n",
      "Neuron 7: weight=0.5662586093, bias=0.8881697655, out_weight=-0.0000000637\n",
      "Neuron 8: weight=-0.7226403356, bias=-0.7965043187, out_weight=0.0000001210\n",
      "Neuron 9: weight=-0.3839495480, bias=-0.0201015174, out_weight=0.0000000259\n",
      "Final covariance matrix F-norm: 1.909422e-15\n",
      "\n",
      "\n",
      "Main Iteration:16\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.0328921899, bias=-0.6249333024, out_weight=0.0000000182\n",
      "Neuron 2: weight=-0.8400620818, bias=0.7436569929, out_weight=0.0000000001\n",
      "Neuron 3: weight=0.0869811997, bias=-1.2755441666, out_weight=0.0000000089\n",
      "Neuron 4: weight=-0.6437963843, bias=-1.2505837679, out_weight=0.0000000001\n",
      "Neuron 5: weight=0.0373731405, bias=0.0981042683, out_weight=0.0000000048\n",
      "Neuron 6: weight=-0.3157178760, bias=0.1287074685, out_weight=0.0000000474\n",
      "Neuron 7: weight=2.0318739414, bias=-0.8510330319, out_weight=-0.0000000190\n",
      "Neuron 8: weight=-0.2879932523, bias=0.3213791549, out_weight=0.0000000043\n",
      "Neuron 9: weight=-0.0750081614, bias=-1.7405517101, out_weight=-0.0000000001\n",
      "Initial covariance matrix F-norm: 2.052281e-15\n",
      "Step 00000 | Loss: 1.303055e-13\n",
      "Step 01000 | Loss: 4.024212e-14\n",
      "Step 02000 | Loss: 5.702383e-14\n",
      "Step 03000 | Loss: 6.518744e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.0328921899, bias=-0.6249333024, out_weight=-0.0000000349\n",
      "Neuron 2: weight=-0.8400620818, bias=0.7436569929, out_weight=-0.0000000712\n",
      "Neuron 3: weight=0.0869811997, bias=-1.2755441666, out_weight=-0.0000000726\n",
      "Neuron 4: weight=-0.6437963843, bias=-1.2505837679, out_weight=0.0000001853\n",
      "Neuron 5: weight=0.0373731405, bias=0.0981042683, out_weight=0.0000000129\n",
      "Neuron 6: weight=-0.3157178760, bias=0.1287074685, out_weight=0.0000000373\n",
      "Neuron 7: weight=2.0318739414, bias=-0.8510330319, out_weight=0.0000000130\n",
      "Neuron 8: weight=-0.2879932523, bias=0.3213791549, out_weight=-0.0000000058\n",
      "Neuron 9: weight=-0.0750081614, bias=-1.7405517101, out_weight=-0.0000000913\n",
      "Final covariance matrix F-norm: 2.064722e-15\n",
      "\n",
      "\n",
      "Main Iteration:17\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=1.0137771368, bias=2.5326294899, out_weight=0.0000000068\n",
      "Neuron 2: weight=-1.1204913855, bias=0.4655200839, out_weight=-0.0000000001\n",
      "Neuron 3: weight=-0.1945876479, bias=0.4577802718, out_weight=-0.0000000030\n",
      "Neuron 4: weight=-0.5957212448, bias=0.2081873566, out_weight=-0.0000000001\n",
      "Neuron 5: weight=-0.4703968167, bias=-0.4480045438, out_weight=-0.0000000024\n",
      "Neuron 6: weight=0.4822644591, bias=-0.5822269917, out_weight=0.0000000324\n",
      "Neuron 7: weight=-0.7510466576, bias=0.8432822227, out_weight=-0.0000000091\n",
      "Neuron 8: weight=1.1265586615, bias=-0.5774128437, out_weight=-0.0000000029\n",
      "Neuron 9: weight=1.4950702190, bias=-2.9098989964, out_weight=0.0000000001\n",
      "Initial covariance matrix F-norm: 1.714888e-15\n",
      "Step 00000 | Loss: 5.972306e-14\n",
      "Step 01000 | Loss: 4.832419e-14\n",
      "Step 02000 | Loss: 8.104108e-14\n",
      "Step 03000 | Loss: 5.971786e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=1.0137771368, bias=2.5326294899, out_weight=-0.0000000582\n",
      "Neuron 2: weight=-1.1204913855, bias=0.4655200839, out_weight=-0.0000000251\n",
      "Neuron 3: weight=-0.1945876479, bias=0.4577802718, out_weight=0.0000001112\n",
      "Neuron 4: weight=-0.5957212448, bias=0.2081873566, out_weight=-0.0000001434\n",
      "Neuron 5: weight=-0.4703968167, bias=-0.4480045438, out_weight=-0.0000000025\n",
      "Neuron 6: weight=0.4822644591, bias=-0.5822269917, out_weight=0.0000000297\n",
      "Neuron 7: weight=-0.7510466576, bias=0.8432822227, out_weight=-0.0000000189\n",
      "Neuron 8: weight=1.1265586615, bias=-0.5774128437, out_weight=-0.0000000743\n",
      "Neuron 9: weight=1.4950702190, bias=-2.9098989964, out_weight=-0.0000000639\n",
      "Final covariance matrix F-norm: 1.765746e-15\n",
      "\n",
      "\n",
      "Main Iteration:18\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=1.6608921289, bias=-0.8543131948, out_weight=0.0000000288\n",
      "Neuron 2: weight=1.4834408760, bias=0.4087717235, out_weight=0.0000000001\n",
      "Neuron 3: weight=-0.5153694749, bias=-0.5181792974, out_weight=0.0000000087\n",
      "Neuron 4: weight=-1.9806180000, bias=0.0600441732, out_weight=0.0000000001\n",
      "Neuron 5: weight=-0.3681578934, bias=0.5785977840, out_weight=0.0000000022\n",
      "Neuron 6: weight=1.1649804115, bias=1.1206753254, out_weight=0.0000000660\n",
      "Neuron 7: weight=0.2922074497, bias=-1.0777339935, out_weight=0.0000000058\n",
      "Neuron 8: weight=0.2534996569, bias=-0.0078668380, out_weight=-0.0000000091\n",
      "Neuron 9: weight=-0.3437344730, bias=-0.5087420940, out_weight=-0.0000000000\n",
      "Initial covariance matrix F-norm: 2.313902e-15\n",
      "Step 00000 | Loss: 1.220708e-13\n",
      "Step 01000 | Loss: 1.207662e-13\n",
      "Step 02000 | Loss: 5.802477e-14\n",
      "Step 03000 | Loss: 6.338680e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=1.6608921289, bias=-0.8543131948, out_weight=0.0000000194\n",
      "Neuron 2: weight=1.4834408760, bias=0.4087717235, out_weight=0.0000000194\n",
      "Neuron 3: weight=-0.5153694749, bias=-0.5181792974, out_weight=0.0000000247\n",
      "Neuron 4: weight=-1.9806180000, bias=0.0600441732, out_weight=0.0000000302\n",
      "Neuron 5: weight=-0.3681578934, bias=0.5785977840, out_weight=-0.0000000791\n",
      "Neuron 6: weight=1.1649804115, bias=1.1206753254, out_weight=-0.0000000548\n",
      "Neuron 7: weight=0.2922074497, bias=-1.0777339935, out_weight=-0.0000000446\n",
      "Neuron 8: weight=0.2534996569, bias=-0.0078668380, out_weight=0.0000000403\n",
      "Neuron 9: weight=-0.3437344730, bias=-0.5087420940, out_weight=-0.0000000338\n",
      "Final covariance matrix F-norm: 2.317607e-15\n",
      "\n",
      "\n",
      "Main Iteration:19\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=0.9999999404\n",
      "Neuron 1: weight=0.6375574470, bias=0.7077437043, out_weight=0.0000000084\n",
      "Neuron 2: weight=0.7733194828, bias=-0.6824126244, out_weight=-0.0000000004\n",
      "Neuron 3: weight=0.7168910503, bias=0.1459788680, out_weight=-0.0000000015\n",
      "Neuron 4: weight=-0.3454068899, bias=-1.3953939676, out_weight=-0.0000000002\n",
      "Neuron 5: weight=-1.4108695984, bias=1.3652865887, out_weight=-0.0000000092\n",
      "Neuron 6: weight=1.8478187323, bias=0.5123600960, out_weight=0.0000000037\n",
      "Neuron 7: weight=0.6495861411, bias=-0.0895664170, out_weight=0.0000000435\n",
      "Neuron 8: weight=0.4945821166, bias=-0.8075665236, out_weight=-0.0000000176\n",
      "Neuron 9: weight=-0.8126527071, bias=0.1896231771, out_weight=0.0000000002\n",
      "Initial covariance matrix F-norm: 3.200218e-15\n",
      "Step 00000 | Loss: 6.964264e-14\n",
      "Step 01000 | Loss: 6.062902e-14\n",
      "Step 02000 | Loss: 1.167434e-13\n",
      "Step 03000 | Loss: 6.704359e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=0.6375574470, bias=0.7077437043, out_weight=0.0000001901\n",
      "Neuron 2: weight=0.7733194828, bias=-0.6824126244, out_weight=-0.0000002257\n",
      "Neuron 3: weight=0.7168910503, bias=0.1459788680, out_weight=0.0000002181\n",
      "Neuron 4: weight=-0.3454068899, bias=-1.3953939676, out_weight=0.0000002293\n",
      "Neuron 5: weight=-1.4108695984, bias=1.3652865887, out_weight=-0.0000001262\n",
      "Neuron 6: weight=1.8478187323, bias=0.5123600960, out_weight=0.0000000366\n",
      "Neuron 7: weight=0.6495861411, bias=-0.0895664170, out_weight=0.0000000307\n",
      "Neuron 8: weight=0.4945821166, bias=-0.8075665236, out_weight=-0.0000000871\n",
      "Neuron 9: weight=-0.8126527071, bias=0.1896231771, out_weight=0.0000002733\n",
      "Final covariance matrix F-norm: 3.123446e-15\n",
      "\n",
      "\n",
      "Main Iteration:20\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.1954917759, bias=-2.0022783279, out_weight=0.0000000027\n",
      "Neuron 2: weight=-0.3469801545, bias=1.0875223875, out_weight=0.0000000000\n",
      "Neuron 3: weight=-1.0937564373, bias=1.4050017595, out_weight=-0.0000000012\n",
      "Neuron 4: weight=-1.6324051619, bias=-0.0746434405, out_weight=0.0000000000\n",
      "Neuron 5: weight=2.1660137177, bias=-0.3529733419, out_weight=-0.0000000014\n",
      "Neuron 6: weight=1.1172099113, bias=-0.0206414796, out_weight=0.0000000004\n",
      "Neuron 7: weight=0.6916948557, bias=-0.0982946083, out_weight=-0.0000000008\n",
      "Neuron 8: weight=0.9565225244, bias=-0.5749083161, out_weight=-0.0000000045\n",
      "Neuron 9: weight=2.0265746117, bias=2.0448455811, out_weight=0.0000000000\n",
      "Initial covariance matrix F-norm: 2.348342e-15\n",
      "Step 00000 | Loss: 8.779436e-14\n",
      "Step 01000 | Loss: 3.779095e-14\n",
      "Step 02000 | Loss: 7.916584e-14\n",
      "Step 03000 | Loss: 8.204559e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.1954917759, bias=-2.0022783279, out_weight=-0.0000000317\n",
      "Neuron 2: weight=-0.3469801545, bias=1.0875223875, out_weight=0.0000000159\n",
      "Neuron 3: weight=-1.0937564373, bias=1.4050017595, out_weight=-0.0000000172\n",
      "Neuron 4: weight=-1.6324051619, bias=-0.0746434405, out_weight=0.0000000606\n",
      "Neuron 5: weight=2.1660137177, bias=-0.3529733419, out_weight=0.0000000070\n",
      "Neuron 6: weight=1.1172099113, bias=-0.0206414796, out_weight=0.0000000764\n",
      "Neuron 7: weight=0.6916948557, bias=-0.0982946083, out_weight=0.0000000531\n",
      "Neuron 8: weight=0.9565225244, bias=-0.5749083161, out_weight=-0.0000000642\n",
      "Neuron 9: weight=2.0265746117, bias=2.0448455811, out_weight=-0.0000000404\n",
      "Final covariance matrix F-norm: 2.892036e-15\n",
      "\n",
      "\n",
      "Main Iteration:21\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.6218314767, bias=-0.1538601220, out_weight=-0.0000000146\n",
      "Neuron 2: weight=1.8114522696, bias=-0.8120930195, out_weight=-0.0000000000\n",
      "Neuron 3: weight=-0.4859311283, bias=-0.8302080631, out_weight=-0.0000000043\n",
      "Neuron 4: weight=0.0340307839, bias=-2.2118842602, out_weight=-0.0000000000\n",
      "Neuron 5: weight=-0.4110427499, bias=-0.3957836628, out_weight=-0.0000000020\n",
      "Neuron 6: weight=-1.1808662415, bias=-0.7949853539, out_weight=-0.0000000265\n",
      "Neuron 7: weight=-0.0998490900, bias=0.0547575951, out_weight=0.0000000086\n",
      "Neuron 8: weight=-0.0627254471, bias=0.8416796923, out_weight=0.0000000043\n",
      "Neuron 9: weight=2.4226486683, bias=-1.2424370050, out_weight=0.0000000000\n",
      "Initial covariance matrix F-norm: 2.814265e-15\n",
      "Step 00000 | Loss: 1.193941e-13\n",
      "Step 01000 | Loss: 5.808028e-14\n",
      "Step 02000 | Loss: 6.107267e-14\n",
      "Step 03000 | Loss: 7.782143e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=0.9999999404\n",
      "Neuron 1: weight=-0.6218314767, bias=-0.1538601220, out_weight=-0.0000002399\n",
      "Neuron 2: weight=1.8114522696, bias=-0.8120930195, out_weight=-0.0000000654\n",
      "Neuron 3: weight=-0.4859311283, bias=-0.8302080631, out_weight=0.0000006424\n",
      "Neuron 4: weight=0.0340307839, bias=-2.2118842602, out_weight=-0.0000002383\n",
      "Neuron 5: weight=-0.4110427499, bias=-0.3957836628, out_weight=0.0000002600\n",
      "Neuron 6: weight=-1.1808662415, bias=-0.7949853539, out_weight=-0.0000003141\n",
      "Neuron 7: weight=-0.0998490900, bias=0.0547575951, out_weight=0.0000000285\n",
      "Neuron 8: weight=-0.0627254471, bias=0.8416796923, out_weight=0.0000001629\n",
      "Neuron 9: weight=2.4226486683, bias=-1.2424370050, out_weight=0.0000000651\n",
      "Final covariance matrix F-norm: 3.129551e-15\n",
      "\n",
      "\n",
      "Main Iteration:22\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-1.2606735229, bias=0.3349300027, out_weight=-0.0000000264\n",
      "Neuron 2: weight=-0.2975469530, bias=-0.5615794063, out_weight=0.0000000002\n",
      "Neuron 3: weight=-1.3784655333, bias=-0.6586383581, out_weight=-0.0000000060\n",
      "Neuron 4: weight=0.0164197087, bias=1.6601953506, out_weight=0.0000000001\n",
      "Neuron 5: weight=1.2222713232, bias=-0.5100500584, out_weight=0.0000000027\n",
      "Neuron 6: weight=0.1415881217, bias=0.6361415386, out_weight=-0.0000000639\n",
      "Neuron 7: weight=-0.1575459242, bias=0.3511222899, out_weight=-0.0000000133\n",
      "Neuron 8: weight=-0.5900731683, bias=-0.3196507096, out_weight=0.0000000109\n",
      "Neuron 9: weight=1.0842578411, bias=-1.3842144012, out_weight=-0.0000000001\n",
      "Initial covariance matrix F-norm: 1.909911e-15\n",
      "Step 00000 | Loss: 9.493101e-14\n",
      "Step 01000 | Loss: 9.568908e-14\n",
      "Step 02000 | Loss: 4.149805e-14\n",
      "Step 03000 | Loss: 5.693536e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-1.2606735229, bias=0.3349300027, out_weight=-0.0000000475\n",
      "Neuron 2: weight=-0.2975469530, bias=-0.5615794063, out_weight=0.0000000555\n",
      "Neuron 3: weight=-1.3784655333, bias=-0.6586383581, out_weight=-0.0000000626\n",
      "Neuron 4: weight=0.0164197087, bias=1.6601953506, out_weight=0.0000001058\n",
      "Neuron 5: weight=1.2222713232, bias=-0.5100500584, out_weight=0.0000000157\n",
      "Neuron 6: weight=0.1415881217, bias=0.6361415386, out_weight=-0.0000000414\n",
      "Neuron 7: weight=-0.1575459242, bias=0.3511222899, out_weight=0.0000000517\n",
      "Neuron 8: weight=-0.5900731683, bias=-0.3196507096, out_weight=0.0000001422\n",
      "Neuron 9: weight=1.0842578411, bias=-1.3842144012, out_weight=0.0000000698\n",
      "Final covariance matrix F-norm: 2.160890e-15\n",
      "\n",
      "\n",
      "Main Iteration:23\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=0.9999999404\n",
      "Neuron 1: weight=-0.6575593948, bias=-1.2550536394, out_weight=-0.0000000052\n",
      "Neuron 2: weight=-0.6261727214, bias=0.2276002914, out_weight=-0.0000000001\n",
      "Neuron 3: weight=-1.2397109270, bias=-0.0019254745, out_weight=-0.0000000051\n",
      "Neuron 4: weight=0.3211532533, bias=-0.2541078031, out_weight=-0.0000000000\n",
      "Neuron 5: weight=-0.1235801727, bias=0.8970884681, out_weight=-0.0000000047\n",
      "Neuron 6: weight=-0.1024087444, bias=-0.3248371482, out_weight=0.0000000058\n",
      "Neuron 7: weight=-0.7171928287, bias=-1.5379472971, out_weight=0.0000000218\n",
      "Neuron 8: weight=-1.2024127245, bias=-0.5378046632, out_weight=-0.0000000057\n",
      "Neuron 9: weight=-1.8491976261, bias=-0.0699689612, out_weight=0.0000000000\n",
      "Initial covariance matrix F-norm: 2.944374e-15\n",
      "Step 00000 | Loss: 1.244894e-13\n",
      "Step 01000 | Loss: 4.673735e-14\n",
      "Step 02000 | Loss: 6.045511e-14\n",
      "Step 03000 | Loss: 3.658358e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=0.9999999404\n",
      "Neuron 1: weight=-0.6575593948, bias=-1.2550536394, out_weight=0.0000002839\n",
      "Neuron 2: weight=-0.6261727214, bias=0.2276002914, out_weight=-0.0000000684\n",
      "Neuron 3: weight=-1.2397109270, bias=-0.0019254745, out_weight=-0.0000000747\n",
      "Neuron 4: weight=0.3211532533, bias=-0.2541078031, out_weight=-0.0000000730\n",
      "Neuron 5: weight=-0.1235801727, bias=0.8970884681, out_weight=0.0000004447\n",
      "Neuron 6: weight=-0.1024087444, bias=-0.3248371482, out_weight=-0.0000001616\n",
      "Neuron 7: weight=-0.7171928287, bias=-1.5379472971, out_weight=0.0000001957\n",
      "Neuron 8: weight=-1.2024127245, bias=-0.5378046632, out_weight=-0.0000002282\n",
      "Neuron 9: weight=-1.8491976261, bias=-0.0699689612, out_weight=0.0000000911\n",
      "Final covariance matrix F-norm: 2.267731e-15\n",
      "\n",
      "\n",
      "Main Iteration:24\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000001192, out_weight=1.0000000000\n",
      "Neuron 1: weight=0.2131318301, bias=0.5807632208, out_weight=-0.0000000112\n",
      "Neuron 2: weight=-1.2737531662, bias=0.6627067327, out_weight=-0.0000000001\n",
      "Neuron 3: weight=1.1965847015, bias=2.0761854649, out_weight=-0.0000000071\n",
      "Neuron 4: weight=-1.2438917160, bias=-0.6114681959, out_weight=-0.0000000001\n",
      "Neuron 5: weight=0.5811503530, bias=-1.0153430700, out_weight=-0.0000000025\n",
      "Neuron 6: weight=0.6957083344, bias=0.2369759083, out_weight=-0.0000000309\n",
      "Neuron 7: weight=-0.0031021477, bias=0.6316713095, out_weight=0.0000000346\n",
      "Neuron 8: weight=-0.6041387916, bias=-0.0511639677, out_weight=-0.0000000077\n",
      "Neuron 9: weight=0.6517327428, bias=-1.1299874783, out_weight=0.0000000001\n",
      "Initial covariance matrix F-norm: 1.675688e-14\n",
      "Step 00000 | Loss: 2.915185e-13\n",
      "Step 01000 | Loss: 7.106815e-14\n",
      "Step 02000 | Loss: 6.895179e-14\n",
      "Step 03000 | Loss: 5.953571e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=0.2131318301, bias=0.5807632208, out_weight=0.0000000911\n",
      "Neuron 2: weight=-1.2737531662, bias=0.6627067327, out_weight=-0.0000000499\n",
      "Neuron 3: weight=1.1965847015, bias=2.0761854649, out_weight=-0.0000001255\n",
      "Neuron 4: weight=-1.2438917160, bias=-0.6114681959, out_weight=0.0000000150\n",
      "Neuron 5: weight=0.5811503530, bias=-1.0153430700, out_weight=-0.0000000022\n",
      "Neuron 6: weight=0.6957083344, bias=0.2369759083, out_weight=-0.0000000535\n",
      "Neuron 7: weight=-0.0031021477, bias=0.6316713095, out_weight=0.0000001658\n",
      "Neuron 8: weight=-0.6041387916, bias=-0.0511639677, out_weight=0.0000000045\n",
      "Neuron 9: weight=0.6517327428, bias=-1.1299874783, out_weight=0.0000000210\n",
      "Final covariance matrix F-norm: 1.996606e-15\n",
      "\n",
      "\n",
      "Main Iteration:25\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=1.1556875706, bias=0.5931224823, out_weight=-0.0000000239\n",
      "Neuron 2: weight=1.0894078016, bias=0.3406504691, out_weight=0.0000000001\n",
      "Neuron 3: weight=0.1283116490, bias=0.5988626480, out_weight=-0.0000000061\n",
      "Neuron 4: weight=0.2797000408, bias=-0.3282535076, out_weight=0.0000000000\n",
      "Neuron 5: weight=-1.2345777750, bias=-0.1451051086, out_weight=-0.0000000008\n",
      "Neuron 6: weight=2.6827821732, bias=0.2823220491, out_weight=-0.0000000390\n",
      "Neuron 7: weight=-0.5442869663, bias=-0.5674430132, out_weight=-0.0000000277\n",
      "Neuron 8: weight=0.1137777045, bias=0.1817689538, out_weight=0.0000000161\n",
      "Neuron 9: weight=-1.0406111479, bias=-0.1890678406, out_weight=-0.0000000001\n",
      "Initial covariance matrix F-norm: 3.937219e-15\n",
      "Step 00000 | Loss: 1.015923e-13\n",
      "Step 01000 | Loss: 4.379830e-14\n",
      "Step 02000 | Loss: 8.992679e-14\n",
      "Step 03000 | Loss: 9.265158e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=1.1556875706, bias=0.5931224823, out_weight=-0.0000000486\n",
      "Neuron 2: weight=1.0894078016, bias=0.3406504691, out_weight=0.0000000022\n",
      "Neuron 3: weight=0.1283116490, bias=0.5988626480, out_weight=0.0000000751\n",
      "Neuron 4: weight=0.2797000408, bias=-0.3282535076, out_weight=-0.0000000138\n",
      "Neuron 5: weight=-1.2345777750, bias=-0.1451051086, out_weight=-0.0000000506\n",
      "Neuron 6: weight=2.6827821732, bias=0.2823220491, out_weight=-0.0000000198\n",
      "Neuron 7: weight=-0.5442869663, bias=-0.5674430132, out_weight=0.0000000947\n",
      "Neuron 8: weight=0.1137777045, bias=0.1817689538, out_weight=0.0000000394\n",
      "Neuron 9: weight=-1.0406111479, bias=-0.1890678406, out_weight=-0.0000000212\n",
      "Final covariance matrix F-norm: 2.957776e-15\n",
      "\n",
      "\n",
      "Main Iteration:26\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=0.9999999404, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.8355987668, bias=-0.7504681945, out_weight=0.0000000022\n",
      "Neuron 2: weight=-0.0548723303, bias=-1.0178512335, out_weight=0.0000000005\n",
      "Neuron 3: weight=2.7953751087, bias=-0.5823549032, out_weight=0.0000000066\n",
      "Neuron 4: weight=0.2923755944, bias=1.5219477415, out_weight=0.0000000003\n",
      "Neuron 5: weight=-0.9761036634, bias=-0.5390229821, out_weight=0.0000000075\n",
      "Neuron 6: weight=0.1959639192, bias=-0.6206290126, out_weight=0.0000000054\n",
      "Neuron 7: weight=0.8559576869, bias=0.9397062063, out_weight=-0.0000000167\n",
      "Neuron 8: weight=-0.7286941409, bias=-0.7471458316, out_weight=0.0000000051\n",
      "Neuron 9: weight=0.2925755680, bias=0.7581775188, out_weight=-0.0000000002\n",
      "Initial covariance matrix F-norm: 6.330310e-15\n",
      "Step 00000 | Loss: 1.359716e-13\n",
      "Step 01000 | Loss: 8.096475e-14\n",
      "Step 02000 | Loss: 7.907043e-14\n",
      "Step 03000 | Loss: 8.746866e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.8355987668, bias=-0.7504681945, out_weight=0.0000000210\n",
      "Neuron 2: weight=-0.0548723303, bias=-1.0178512335, out_weight=-0.0000000388\n",
      "Neuron 3: weight=2.7953751087, bias=-0.5823549032, out_weight=0.0000000211\n",
      "Neuron 4: weight=0.2923755944, bias=1.5219477415, out_weight=0.0000000259\n",
      "Neuron 5: weight=-0.9761036634, bias=-0.5390229821, out_weight=-0.0000000337\n",
      "Neuron 6: weight=0.1959639192, bias=-0.6206290126, out_weight=0.0000000314\n",
      "Neuron 7: weight=0.8559576869, bias=0.9397062063, out_weight=-0.0000000902\n",
      "Neuron 8: weight=-0.7286941409, bias=-0.7471458316, out_weight=0.0000000567\n",
      "Neuron 9: weight=0.2925755680, bias=0.7581775188, out_weight=0.0000000087\n",
      "Final covariance matrix F-norm: 4.005280e-15\n",
      "\n",
      "\n",
      "Main Iteration:27\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-1.0337702036, bias=0.2663705945, out_weight=-0.0000000092\n",
      "Neuron 2: weight=-0.1439218819, bias=-0.1215024143, out_weight=-0.0000000001\n",
      "Neuron 3: weight=1.3638712168, bias=0.6301981211, out_weight=-0.0000000017\n",
      "Neuron 4: weight=0.8320708871, bias=0.1871151775, out_weight=-0.0000000001\n",
      "Neuron 5: weight=1.1524658203, bias=-0.7600461245, out_weight=-0.0000000009\n",
      "Neuron 6: weight=0.9148828387, bias=0.3765882850, out_weight=-0.0000000418\n",
      "Neuron 7: weight=2.9927518368, bias=0.6284400225, out_weight=0.0000000021\n",
      "Neuron 8: weight=0.4696037769, bias=0.9578309655, out_weight=0.0000000017\n",
      "Neuron 9: weight=-0.3085474670, bias=0.6425065994, out_weight=0.0000000000\n",
      "Initial covariance matrix F-norm: 3.544978e-15\n",
      "Step 00000 | Loss: 6.050889e-14\n",
      "Step 01000 | Loss: 4.712203e-14\n",
      "Step 02000 | Loss: 9.990099e-14\n",
      "Step 03000 | Loss: 1.069908e-13\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-1.0337702036, bias=0.2663705945, out_weight=-0.0000000318\n",
      "Neuron 2: weight=-0.1439218819, bias=-0.1215024143, out_weight=-0.0000000245\n",
      "Neuron 3: weight=1.3638712168, bias=0.6301981211, out_weight=0.0000000846\n",
      "Neuron 4: weight=0.8320708871, bias=0.1871151775, out_weight=-0.0000000376\n",
      "Neuron 5: weight=1.1524658203, bias=-0.7600461245, out_weight=0.0000000419\n",
      "Neuron 6: weight=0.9148828387, bias=0.3765882850, out_weight=-0.0000001117\n",
      "Neuron 7: weight=2.9927518368, bias=0.6284400225, out_weight=-0.0000000069\n",
      "Neuron 8: weight=0.4696037769, bias=0.9578309655, out_weight=-0.0000000057\n",
      "Neuron 9: weight=-0.3085474670, bias=0.6425065994, out_weight=0.0000000558\n",
      "Final covariance matrix F-norm: 3.799377e-15\n",
      "\n",
      "\n",
      "Main Iteration:28\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=1.5757938623, bias=1.6978576183, out_weight=0.0000000070\n",
      "Neuron 2: weight=-0.6794250011, bias=0.2216725498, out_weight=-0.0000000004\n",
      "Neuron 3: weight=-0.8955156803, bias=0.8447655439, out_weight=-0.0000000048\n",
      "Neuron 4: weight=-0.9100059271, bias=0.0370593295, out_weight=-0.0000000002\n",
      "Neuron 5: weight=-1.3484157324, bias=-1.0940498114, out_weight=-0.0000000073\n",
      "Neuron 6: weight=0.0550035201, bias=2.0008282661, out_weight=0.0000000445\n",
      "Neuron 7: weight=0.0135668041, bias=-0.9474929571, out_weight=-0.0000000321\n",
      "Neuron 8: weight=0.3536550999, bias=0.0466263443, out_weight=0.0000000040\n",
      "Neuron 9: weight=0.7292158604, bias=-0.3132576942, out_weight=0.0000000002\n",
      "Initial covariance matrix F-norm: 1.750100e-15\n",
      "Step 00000 | Loss: 6.895743e-14\n",
      "Step 01000 | Loss: 4.266205e-14\n",
      "Step 02000 | Loss: 7.528700e-14\n",
      "Step 03000 | Loss: 7.651171e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=1.5757938623, bias=1.6978576183, out_weight=-0.0000000652\n",
      "Neuron 2: weight=-0.6794250011, bias=0.2216725498, out_weight=0.0000000027\n",
      "Neuron 3: weight=-0.8955156803, bias=0.8447655439, out_weight=-0.0000000683\n",
      "Neuron 4: weight=-0.9100059271, bias=0.0370593295, out_weight=0.0000000352\n",
      "Neuron 5: weight=-1.3484157324, bias=-1.0940498114, out_weight=-0.0000000831\n",
      "Neuron 6: weight=0.0550035201, bias=2.0008282661, out_weight=0.0000000364\n",
      "Neuron 7: weight=0.0135668041, bias=-0.9474929571, out_weight=-0.0000000285\n",
      "Neuron 8: weight=0.3536550999, bias=0.0466263443, out_weight=-0.0000000713\n",
      "Neuron 9: weight=0.7292158604, bias=-0.3132576942, out_weight=0.0000000311\n",
      "Final covariance matrix F-norm: 1.928962e-15\n",
      "\n",
      "\n",
      "Main Iteration:29\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=0.9999999404\n",
      "Neuron 1: weight=-0.5413732529, bias=-0.5724231601, out_weight=-0.0000000106\n",
      "Neuron 2: weight=1.0658179522, bias=-1.1462633610, out_weight=-0.0000000003\n",
      "Neuron 3: weight=-0.4296619296, bias=-0.1982364208, out_weight=-0.0000000086\n",
      "Neuron 4: weight=1.8893623352, bias=0.5886537433, out_weight=-0.0000000001\n",
      "Neuron 5: weight=0.8103240728, bias=1.1139851809, out_weight=-0.0000000127\n",
      "Neuron 6: weight=-0.3852166831, bias=0.5602155924, out_weight=-0.0000000089\n",
      "Neuron 7: weight=0.9029935002, bias=0.6414819956, out_weight=0.0000000279\n",
      "Neuron 8: weight=0.2437277883, bias=-0.0289368797, out_weight=-0.0000000075\n",
      "Neuron 9: weight=-0.0045027332, bias=-0.6300022602, out_weight=0.0000000001\n",
      "Initial covariance matrix F-norm: 3.288615e-15\n",
      "Step 00000 | Loss: 9.787483e-14\n",
      "Step 01000 | Loss: 7.195460e-14\n",
      "Step 02000 | Loss: 6.810871e-14\n",
      "Step 03000 | Loss: 1.096085e-13\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=0.9999999404\n",
      "Neuron 1: weight=-0.5413732529, bias=-0.5724231601, out_weight=0.0000001148\n",
      "Neuron 2: weight=1.0658179522, bias=-1.1462633610, out_weight=0.0000001276\n",
      "Neuron 3: weight=-0.4296619296, bias=-0.1982364208, out_weight=0.0000001319\n",
      "Neuron 4: weight=1.8893623352, bias=0.5886537433, out_weight=0.0000000148\n",
      "Neuron 5: weight=0.8103240728, bias=1.1139851809, out_weight=-0.0000002623\n",
      "Neuron 6: weight=-0.3852166831, bias=0.5602155924, out_weight=0.0000001524\n",
      "Neuron 7: weight=0.9029935002, bias=0.6414819956, out_weight=0.0000004464\n",
      "Neuron 8: weight=0.2437277883, bias=-0.0289368797, out_weight=-0.0000001220\n",
      "Neuron 9: weight=-0.0045027332, bias=-0.6300022602, out_weight=-0.0000001479\n",
      "Final covariance matrix F-norm: 2.610449e-15\n",
      "\n",
      "\n",
      "Main Iteration:30\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=0.4009148777, bias=-0.5105206370, out_weight=-0.0000000182\n",
      "Neuron 2: weight=-0.3115839958, bias=-0.0693287626, out_weight=-0.0000000002\n",
      "Neuron 3: weight=-1.1425571442, bias=-2.3621642590, out_weight=-0.0000000104\n",
      "Neuron 4: weight=0.7029282451, bias=0.3921147883, out_weight=-0.0000000001\n",
      "Neuron 5: weight=-1.0320992470, bias=-0.4446171522, out_weight=-0.0000000080\n",
      "Neuron 6: weight=0.5119389892, bias=-0.5420712829, out_weight=-0.0000000531\n",
      "Neuron 7: weight=-0.8572292924, bias=-1.8534232378, out_weight=0.0000000283\n",
      "Neuron 8: weight=-1.3924459219, bias=-0.3818907440, out_weight=-0.0000000080\n",
      "Neuron 9: weight=-0.6636574864, bias=1.0315138102, out_weight=0.0000000001\n",
      "Initial covariance matrix F-norm: 1.885099e-15\n",
      "Step 00000 | Loss: 6.129992e-14\n",
      "Step 01000 | Loss: 9.254414e-14\n",
      "Step 02000 | Loss: 6.195912e-14\n",
      "Step 03000 | Loss: 8.302387e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=0.4009148777, bias=-0.5105206370, out_weight=-0.0000000417\n",
      "Neuron 2: weight=-0.3115839958, bias=-0.0693287626, out_weight=-0.0000000423\n",
      "Neuron 3: weight=-1.1425571442, bias=-2.3621642590, out_weight=-0.0000000100\n",
      "Neuron 4: weight=0.7029282451, bias=0.3921147883, out_weight=-0.0000000229\n",
      "Neuron 5: weight=-1.0320992470, bias=-0.4446171522, out_weight=0.0000000099\n",
      "Neuron 6: weight=0.5119389892, bias=-0.5420712829, out_weight=0.0000000339\n",
      "Neuron 7: weight=-0.8572292924, bias=-1.8534232378, out_weight=0.0000000054\n",
      "Neuron 8: weight=-1.3924459219, bias=-0.3818907440, out_weight=-0.0000000264\n",
      "Neuron 9: weight=-0.6636574864, bias=1.0315138102, out_weight=-0.0000000229\n",
      "Final covariance matrix F-norm: 1.897525e-15\n",
      "\n",
      "\n",
      "Main Iteration:31\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=0.9999999404\n",
      "Neuron 1: weight=0.3489324450, bias=0.3216123581, out_weight=-0.0000000260\n",
      "Neuron 2: weight=0.5473304391, bias=-1.7793911695, out_weight=-0.0000000006\n",
      "Neuron 3: weight=-0.9040086269, bias=-0.8429154754, out_weight=-0.0000000166\n",
      "Neuron 4: weight=0.7420345545, bias=-0.0717495680, out_weight=-0.0000000003\n",
      "Neuron 5: weight=0.2286186516, bias=0.5613806248, out_weight=-0.0000000210\n",
      "Neuron 6: weight=1.3805971146, bias=-0.0752578527, out_weight=-0.0000000509\n",
      "Neuron 7: weight=1.3311828375, bias=0.3065835536, out_weight=0.0000000494\n",
      "Neuron 8: weight=0.6711614728, bias=0.2125323266, out_weight=-0.0000000109\n",
      "Neuron 9: weight=0.2817564905, bias=-1.1733262539, out_weight=0.0000000003\n",
      "Initial covariance matrix F-norm: 2.956495e-15\n",
      "Step 00000 | Loss: 1.650104e-13\n",
      "Step 01000 | Loss: 5.545564e-14\n",
      "Step 02000 | Loss: 9.265852e-14\n",
      "Step 03000 | Loss: 9.703523e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=0.9999999404\n",
      "Neuron 1: weight=0.3489324450, bias=0.3216123581, out_weight=-0.0000001612\n",
      "Neuron 2: weight=0.5473304391, bias=-1.7793911695, out_weight=-0.0000000920\n",
      "Neuron 3: weight=-0.9040086269, bias=-0.8429154754, out_weight=0.0000000964\n",
      "Neuron 4: weight=0.7420345545, bias=-0.0717495680, out_weight=0.0000002857\n",
      "Neuron 5: weight=0.2286186516, bias=0.5613806248, out_weight=-0.0000001290\n",
      "Neuron 6: weight=1.3805971146, bias=-0.0752578527, out_weight=-0.0000002700\n",
      "Neuron 7: weight=1.3311828375, bias=0.3065835536, out_weight=0.0000002411\n",
      "Neuron 8: weight=0.6711614728, bias=0.2125323266, out_weight=0.0000001419\n",
      "Neuron 9: weight=0.2817564905, bias=-1.1733262539, out_weight=-0.0000000646\n",
      "Final covariance matrix F-norm: 2.293309e-15\n",
      "\n",
      "\n",
      "Main Iteration:32\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=0.5424034595, bias=-0.0300739482, out_weight=0.0000000067\n",
      "Neuron 2: weight=1.2911534309, bias=-2.0566046238, out_weight=-0.0000000000\n",
      "Neuron 3: weight=1.0633087158, bias=-1.2812505960, out_weight=0.0000000041\n",
      "Neuron 4: weight=0.0806511417, bias=0.2836257219, out_weight=-0.0000000000\n",
      "Neuron 5: weight=-0.7679620385, bias=-2.7287895679, out_weight=0.0000000002\n",
      "Neuron 6: weight=-0.8730942607, bias=0.7049176693, out_weight=0.0000000203\n",
      "Neuron 7: weight=1.4254354239, bias=0.6915167570, out_weight=-0.0000000068\n",
      "Neuron 8: weight=-0.3748766184, bias=-1.7346795797, out_weight=0.0000000015\n",
      "Neuron 9: weight=-1.4936321974, bias=-0.9203385711, out_weight=0.0000000000\n",
      "Initial covariance matrix F-norm: 2.075913e-15\n",
      "Step 00000 | Loss: 7.240736e-14\n",
      "Step 01000 | Loss: 1.134735e-13\n",
      "Step 02000 | Loss: 8.792619e-14\n",
      "Step 03000 | Loss: 7.614048e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=0.5424034595, bias=-0.0300739482, out_weight=-0.0000000390\n",
      "Neuron 2: weight=1.2911534309, bias=-2.0566046238, out_weight=0.0000000067\n",
      "Neuron 3: weight=1.0633087158, bias=-1.2812505960, out_weight=-0.0000000317\n",
      "Neuron 4: weight=0.0806511417, bias=0.2836257219, out_weight=-0.0000000127\n",
      "Neuron 5: weight=-0.7679620385, bias=-2.7287895679, out_weight=-0.0000000090\n",
      "Neuron 6: weight=-0.8730942607, bias=0.7049176693, out_weight=-0.0000000870\n",
      "Neuron 7: weight=1.4254354239, bias=0.6915167570, out_weight=0.0000000137\n",
      "Neuron 8: weight=-0.3748766184, bias=-1.7346795797, out_weight=-0.0000000010\n",
      "Neuron 9: weight=-1.4936321974, bias=-0.9203385711, out_weight=0.0000000053\n",
      "Final covariance matrix F-norm: 2.088366e-15\n",
      "\n",
      "\n",
      "Main Iteration:33\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=0.9999999404, out_weight=1.0000000000\n",
      "Neuron 1: weight=-1.0216537714, bias=-0.1205792129, out_weight=0.0000000202\n",
      "Neuron 2: weight=-0.0979488045, bias=1.0352895260, out_weight=0.0000000004\n",
      "Neuron 3: weight=-0.1062865704, bias=-1.7092479467, out_weight=0.0000000132\n",
      "Neuron 4: weight=-0.7212156057, bias=0.1532117575, out_weight=0.0000000002\n",
      "Neuron 5: weight=-1.0555577278, bias=0.5962054133, out_weight=0.0000000108\n",
      "Neuron 6: weight=-0.5260431767, bias=-0.1829437613, out_weight=0.0000000315\n",
      "Neuron 7: weight=-0.0769765377, bias=0.0795142949, out_weight=-0.0000000201\n",
      "Neuron 8: weight=-0.7366437912, bias=3.0360202789, out_weight=0.0000000012\n",
      "Neuron 9: weight=0.8683328629, bias=0.3209394217, out_weight=-0.0000000002\n",
      "Initial covariance matrix F-norm: 5.236055e-15\n",
      "Step 00000 | Loss: 1.252626e-13\n",
      "Step 01000 | Loss: 7.332329e-14\n",
      "Step 02000 | Loss: 4.814898e-14\n",
      "Step 03000 | Loss: 9.681665e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-1.0216537714, bias=-0.1205792129, out_weight=-0.0000000329\n",
      "Neuron 2: weight=-0.0979488045, bias=1.0352895260, out_weight=0.0000000242\n",
      "Neuron 3: weight=-0.1062865704, bias=-1.7092479467, out_weight=-0.0000000202\n",
      "Neuron 4: weight=-0.7212156057, bias=0.1532117575, out_weight=-0.0000000613\n",
      "Neuron 5: weight=-1.0555577278, bias=0.5962054133, out_weight=-0.0000000461\n",
      "Neuron 6: weight=-0.5260431767, bias=-0.1829437613, out_weight=0.0000000967\n",
      "Neuron 7: weight=-0.0769765377, bias=0.0795142949, out_weight=-0.0000000156\n",
      "Neuron 8: weight=-0.7366437912, bias=3.0360202789, out_weight=0.0000000152\n",
      "Neuron 9: weight=0.8683328629, bias=0.3209394217, out_weight=-0.0000000379\n",
      "Final covariance matrix F-norm: 1.762297e-15\n",
      "\n",
      "\n",
      "Main Iteration:34\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.0002919465, bias=-0.3983551562, out_weight=0.0000000151\n",
      "Neuron 2: weight=-0.1660952717, bias=2.6173315048, out_weight=-0.0000000000\n",
      "Neuron 3: weight=-0.3960103095, bias=-0.0308474004, out_weight=0.0000000013\n",
      "Neuron 4: weight=-0.2646400332, bias=0.0229911115, out_weight=-0.0000000000\n",
      "Neuron 5: weight=-0.8544789553, bias=-0.6674141288, out_weight=0.0000000021\n",
      "Neuron 6: weight=-0.1692174673, bias=0.0129845990, out_weight=0.0000000394\n",
      "Neuron 7: weight=-0.5648132563, bias=-0.1909907907, out_weight=-0.0000000141\n",
      "Neuron 8: weight=-0.3005906045, bias=0.9861701131, out_weight=-0.0000000034\n",
      "Neuron 9: weight=-0.7706210017, bias=-2.9136393070, out_weight=0.0000000000\n",
      "Initial covariance matrix F-norm: 1.689836e-15\n",
      "Step 00000 | Loss: 5.801609e-14\n",
      "Step 01000 | Loss: 4.640743e-14\n",
      "Step 02000 | Loss: 8.164650e-14\n",
      "Step 03000 | Loss: 6.343190e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.0002919465, bias=-0.3983551562, out_weight=0.0000000029\n",
      "Neuron 2: weight=-0.1660952717, bias=2.6173315048, out_weight=0.0000000312\n",
      "Neuron 3: weight=-0.3960103095, bias=-0.0308474004, out_weight=-0.0000000519\n",
      "Neuron 4: weight=-0.2646400332, bias=0.0229911115, out_weight=-0.0000000099\n",
      "Neuron 5: weight=-0.8544789553, bias=-0.6674141288, out_weight=0.0000001117\n",
      "Neuron 6: weight=-0.1692174673, bias=0.0129845990, out_weight=0.0000000447\n",
      "Neuron 7: weight=-0.5648132563, bias=-0.1909907907, out_weight=-0.0000001228\n",
      "Neuron 8: weight=-0.3005906045, bias=0.9861701131, out_weight=-0.0000000136\n",
      "Neuron 9: weight=-0.7706210017, bias=-2.9136393070, out_weight=0.0000000147\n",
      "Final covariance matrix F-norm: 1.712737e-15\n",
      "\n",
      "\n",
      "Main Iteration:35\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=0.5029633641, bias=0.3300251663, out_weight=0.0000000030\n",
      "Neuron 2: weight=-0.0095005771, bias=0.7446422577, out_weight=0.0000000004\n",
      "Neuron 3: weight=-1.7097346783, bias=0.0646999925, out_weight=0.0000000068\n",
      "Neuron 4: weight=-0.7149356008, bias=-1.2355872393, out_weight=0.0000000002\n",
      "Neuron 5: weight=0.8348634839, bias=-1.8063564301, out_weight=0.0000000074\n",
      "Neuron 6: weight=-2.0573456287, bias=-0.5680345893, out_weight=-0.0000000004\n",
      "Neuron 7: weight=0.2782153785, bias=-0.6398184299, out_weight=-0.0000000085\n",
      "Neuron 8: weight=-1.6437848806, bias=-0.7646645904, out_weight=0.0000000034\n",
      "Neuron 9: weight=-1.3182733059, bias=-0.9325097203, out_weight=-0.0000000002\n",
      "Initial covariance matrix F-norm: 2.815869e-15\n",
      "Step 00000 | Loss: 7.218705e-14\n",
      "Step 01000 | Loss: 9.674379e-14\n",
      "Step 02000 | Loss: 6.469868e-14\n",
      "Step 03000 | Loss: 4.672521e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=0.5029633641, bias=0.3300251663, out_weight=0.0000000321\n",
      "Neuron 2: weight=-0.0095005771, bias=0.7446422577, out_weight=0.0000001155\n",
      "Neuron 3: weight=-1.7097346783, bias=0.0646999925, out_weight=-0.0000000082\n",
      "Neuron 4: weight=-0.7149356008, bias=-1.2355872393, out_weight=0.0000000805\n",
      "Neuron 5: weight=0.8348634839, bias=-1.8063564301, out_weight=0.0000000275\n",
      "Neuron 6: weight=-2.0573456287, bias=-0.5680345893, out_weight=0.0000000480\n",
      "Neuron 7: weight=0.2782153785, bias=-0.6398184299, out_weight=-0.0000000251\n",
      "Neuron 8: weight=-1.6437848806, bias=-0.7646645904, out_weight=-0.0000000880\n",
      "Neuron 9: weight=-1.3182733059, bias=-0.9325097203, out_weight=0.0000000528\n",
      "Final covariance matrix F-norm: 3.184362e-15\n",
      "\n",
      "\n",
      "Main Iteration:36\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=0.0293614622, bias=0.4552844465, out_weight=0.0000000095\n",
      "Neuron 2: weight=1.3116044998, bias=0.5071085095, out_weight=-0.0000000004\n",
      "Neuron 3: weight=-1.1020072699, bias=0.0164663270, out_weight=-0.0000000006\n",
      "Neuron 4: weight=-0.5230802894, bias=-1.6071854830, out_weight=-0.0000000002\n",
      "Neuron 5: weight=0.4143725336, bias=1.3040177822, out_weight=-0.0000000061\n",
      "Neuron 6: weight=-0.9715055227, bias=0.6877169609, out_weight=0.0000000171\n",
      "Neuron 7: weight=-0.0222354792, bias=0.0386384688, out_weight=0.0000000310\n",
      "Neuron 8: weight=0.6798384190, bias=0.3081932962, out_weight=-0.0000000099\n",
      "Neuron 9: weight=1.6584602594, bias=0.5830604434, out_weight=0.0000000002\n",
      "Initial covariance matrix F-norm: 2.199310e-15\n",
      "Step 00000 | Loss: 7.700438e-14\n",
      "Step 01000 | Loss: 7.905482e-14\n",
      "Step 02000 | Loss: 9.920537e-14\n",
      "Step 03000 | Loss: 8.344367e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=0.0293614622, bias=0.4552844465, out_weight=0.0000000745\n",
      "Neuron 2: weight=1.3116044998, bias=0.5071085095, out_weight=0.0000000494\n",
      "Neuron 3: weight=-1.1020072699, bias=0.0164663270, out_weight=-0.0000000178\n",
      "Neuron 4: weight=-0.5230802894, bias=-1.6071854830, out_weight=0.0000000017\n",
      "Neuron 5: weight=0.4143725336, bias=1.3040177822, out_weight=-0.0000000072\n",
      "Neuron 6: weight=-0.9715055227, bias=0.6877169609, out_weight=-0.0000000172\n",
      "Neuron 7: weight=-0.0222354792, bias=0.0386384688, out_weight=0.0000000439\n",
      "Neuron 8: weight=0.6798384190, bias=0.3081932962, out_weight=-0.0000001576\n",
      "Neuron 9: weight=1.6584602594, bias=0.5830604434, out_weight=0.0000000207\n",
      "Final covariance matrix F-norm: 2.254276e-15\n",
      "\n",
      "\n",
      "Main Iteration:37\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-1.4607976675, bias=-0.5928504467, out_weight=0.0000000100\n",
      "Neuron 2: weight=-0.6215501428, bias=0.0901525617, out_weight=0.0000000004\n",
      "Neuron 3: weight=0.7370534539, bias=-0.8995583653, out_weight=0.0000000114\n",
      "Neuron 4: weight=-0.5200930238, bias=1.5285587311, out_weight=0.0000000002\n",
      "Neuron 5: weight=-0.3521685600, bias=-1.5645798445, out_weight=0.0000000111\n",
      "Neuron 6: weight=-0.7432483435, bias=1.0478993654, out_weight=0.0000000239\n",
      "Neuron 7: weight=-0.2511776090, bias=1.7393522263, out_weight=-0.0000000092\n",
      "Neuron 8: weight=-2.0469009876, bias=-1.4310107231, out_weight=0.0000000071\n",
      "Neuron 9: weight=0.4815791845, bias=1.0926151276, out_weight=-0.0000000002\n",
      "Initial covariance matrix F-norm: 2.213803e-15\n",
      "Step 00000 | Loss: 1.087550e-13\n",
      "Step 01000 | Loss: 8.819161e-14\n",
      "Step 02000 | Loss: 9.065708e-14\n",
      "Step 03000 | Loss: 1.074696e-13\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-1.4607976675, bias=-0.5928504467, out_weight=-0.0000000262\n",
      "Neuron 2: weight=-0.6215501428, bias=0.0901525617, out_weight=-0.0000000514\n",
      "Neuron 3: weight=0.7370534539, bias=-0.8995583653, out_weight=0.0000000568\n",
      "Neuron 4: weight=-0.5200930238, bias=1.5285587311, out_weight=0.0000000903\n",
      "Neuron 5: weight=-0.3521685600, bias=-1.5645798445, out_weight=-0.0000000025\n",
      "Neuron 6: weight=-0.7432483435, bias=1.0478993654, out_weight=0.0000000186\n",
      "Neuron 7: weight=-0.2511776090, bias=1.7393522263, out_weight=0.0000001093\n",
      "Neuron 8: weight=-2.0469009876, bias=-1.4310107231, out_weight=-0.0000000084\n",
      "Neuron 9: weight=0.4815791845, bias=1.0926151276, out_weight=-0.0000002284\n",
      "Final covariance matrix F-norm: 2.280968e-15\n",
      "\n",
      "\n",
      "Main Iteration:38\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.5642336011, bias=0.7507718801, out_weight=0.0000000039\n",
      "Neuron 2: weight=-0.0157783274, bias=-0.3396984935, out_weight=0.0000000000\n",
      "Neuron 3: weight=-1.3854110241, bias=-1.8355462551, out_weight=0.0000000021\n",
      "Neuron 4: weight=0.6378089786, bias=0.3942968547, out_weight=0.0000000000\n",
      "Neuron 5: weight=-0.4209174216, bias=0.3864370883, out_weight=0.0000000018\n",
      "Neuron 6: weight=-0.2307615429, bias=0.9778403640, out_weight=0.0000000020\n",
      "Neuron 7: weight=-0.5715444088, bias=1.1472171545, out_weight=-0.0000000281\n",
      "Neuron 8: weight=1.5358664989, bias=0.3379892707, out_weight=0.0000000040\n",
      "Neuron 9: weight=-0.9520809054, bias=-0.0765040070, out_weight=-0.0000000000\n",
      "Initial covariance matrix F-norm: 1.897491e-15\n",
      "Step 00000 | Loss: 4.822011e-14\n",
      "Step 01000 | Loss: 8.214263e-14\n",
      "Step 02000 | Loss: 7.190082e-14\n",
      "Step 03000 | Loss: 1.001092e-13\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.5642336011, bias=0.7507718801, out_weight=0.0000000349\n",
      "Neuron 2: weight=-0.0157783274, bias=-0.3396984935, out_weight=-0.0000000181\n",
      "Neuron 3: weight=-1.3854110241, bias=-1.8355462551, out_weight=0.0000000594\n",
      "Neuron 4: weight=0.6378089786, bias=0.3942968547, out_weight=0.0000000759\n",
      "Neuron 5: weight=-0.4209174216, bias=0.3864370883, out_weight=0.0000000158\n",
      "Neuron 6: weight=-0.2307615429, bias=0.9778403640, out_weight=0.0000000328\n",
      "Neuron 7: weight=-0.5715444088, bias=1.1472171545, out_weight=-0.0000000187\n",
      "Neuron 8: weight=1.5358664989, bias=0.3379892707, out_weight=-0.0000000279\n",
      "Neuron 9: weight=-0.9520809054, bias=-0.0765040070, out_weight=-0.0000000285\n",
      "Final covariance matrix F-norm: 1.989765e-15\n",
      "\n",
      "\n",
      "Main Iteration:39\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=0.2059798241, bias=1.3608362675, out_weight=-0.0000000057\n",
      "Neuron 2: weight=-1.0999101400, bias=0.6394029856, out_weight=0.0000000001\n",
      "Neuron 3: weight=-0.7222269177, bias=0.4347302914, out_weight=-0.0000000008\n",
      "Neuron 4: weight=-0.0828692839, bias=-1.4889129400, out_weight=0.0000000000\n",
      "Neuron 5: weight=0.7582545877, bias=0.1242757440, out_weight=0.0000000038\n",
      "Neuron 6: weight=-0.6716766953, bias=2.4079225063, out_weight=-0.0000000182\n",
      "Neuron 7: weight=-0.7449373603, bias=-0.3681399226, out_weight=-0.0000000373\n",
      "Neuron 8: weight=0.5303604007, bias=-0.2504943311, out_weight=0.0000000105\n",
      "Neuron 9: weight=-0.1611372977, bias=-1.1083384752, out_weight=-0.0000000000\n",
      "Initial covariance matrix F-norm: 1.709585e-15\n",
      "Step 00000 | Loss: 7.327298e-14\n",
      "Step 01000 | Loss: 7.317237e-14\n",
      "Step 02000 | Loss: 6.045511e-14\n",
      "Step 03000 | Loss: 6.297740e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=0.2059798241, bias=1.3608362675, out_weight=0.0000000086\n",
      "Neuron 2: weight=-1.0999101400, bias=0.6394029856, out_weight=-0.0000000579\n",
      "Neuron 3: weight=-0.7222269177, bias=0.4347302914, out_weight=-0.0000000631\n",
      "Neuron 4: weight=-0.0828692839, bias=-1.4889129400, out_weight=-0.0000000463\n",
      "Neuron 5: weight=0.7582545877, bias=0.1242757440, out_weight=0.0000000187\n",
      "Neuron 6: weight=-0.6716766953, bias=2.4079225063, out_weight=0.0000000116\n",
      "Neuron 7: weight=-0.7449373603, bias=-0.3681399226, out_weight=0.0000000701\n",
      "Neuron 8: weight=0.5303604007, bias=-0.2504943311, out_weight=0.0000000108\n",
      "Neuron 9: weight=-0.1611372977, bias=-1.1083384752, out_weight=-0.0000000115\n",
      "Final covariance matrix F-norm: 1.754609e-15\n",
      "\n",
      "\n",
      "Main Iteration:40\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=0.5200131536, bias=-0.0027621200, out_weight=-0.0000000059\n",
      "Neuron 2: weight=-0.5462489128, bias=0.9356046915, out_weight=-0.0000000003\n",
      "Neuron 3: weight=1.0251958370, bias=-0.3001102209, out_weight=-0.0000000060\n",
      "Neuron 4: weight=1.2108509541, bias=-0.4544638991, out_weight=-0.0000000001\n",
      "Neuron 5: weight=0.5630894899, bias=0.0344574638, out_weight=-0.0000000058\n",
      "Neuron 6: weight=0.0834314674, bias=0.4053222835, out_weight=-0.0000000128\n",
      "Neuron 7: weight=-0.9879937768, bias=-0.1144245490, out_weight=0.0000000168\n",
      "Neuron 8: weight=-0.0988940597, bias=-0.3796474636, out_weight=-0.0000000056\n",
      "Neuron 9: weight=1.0209341049, bias=0.8332019448, out_weight=0.0000000001\n",
      "Initial covariance matrix F-norm: 1.743946e-15\n",
      "Step 00000 | Loss: 7.039161e-14\n",
      "Step 01000 | Loss: 7.618949e-14\n",
      "Step 02000 | Loss: 6.214647e-14\n",
      "Step 03000 | Loss: 5.248579e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=0.5200131536, bias=-0.0027621200, out_weight=-0.0000000241\n",
      "Neuron 2: weight=-0.5462489128, bias=0.9356046915, out_weight=-0.0000000330\n",
      "Neuron 3: weight=1.0251958370, bias=-0.3001102209, out_weight=0.0000000056\n",
      "Neuron 4: weight=1.2108509541, bias=-0.4544638991, out_weight=0.0000000505\n",
      "Neuron 5: weight=0.5630894899, bias=0.0344574638, out_weight=-0.0000000263\n",
      "Neuron 6: weight=0.0834314674, bias=0.4053222835, out_weight=0.0000000305\n",
      "Neuron 7: weight=-0.9879937768, bias=-0.1144245490, out_weight=0.0000000426\n",
      "Neuron 8: weight=-0.0988940597, bias=-0.3796474636, out_weight=-0.0000000424\n",
      "Neuron 9: weight=1.0209341049, bias=0.8332019448, out_weight=-0.0000000194\n",
      "Final covariance matrix F-norm: 1.759228e-15\n",
      "\n",
      "\n",
      "Main Iteration:41\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.9366729259, bias=-1.1173754930, out_weight=-0.0000000015\n",
      "Neuron 2: weight=-1.1824021339, bias=1.5200920105, out_weight=-0.0000000003\n",
      "Neuron 3: weight=-1.0983538628, bias=-0.7354533076, out_weight=-0.0000000030\n",
      "Neuron 4: weight=0.7447363734, bias=-0.5851950049, out_weight=-0.0000000002\n",
      "Neuron 5: weight=-0.0132466601, bias=-0.9145535231, out_weight=-0.0000000015\n",
      "Neuron 6: weight=0.7805695534, bias=1.0076452494, out_weight=-0.0000000042\n",
      "Neuron 7: weight=-0.5516315699, bias=-2.4082193375, out_weight=-0.0000000370\n",
      "Neuron 8: weight=1.6035760641, bias=-1.9870032072, out_weight=0.0000000090\n",
      "Neuron 9: weight=-0.9788454175, bias=-0.1986232102, out_weight=0.0000000001\n",
      "Initial covariance matrix F-norm: 1.805395e-15\n",
      "Step 00000 | Loss: 5.288131e-14\n",
      "Step 01000 | Loss: 8.601800e-14\n",
      "Step 02000 | Loss: 6.470692e-14\n",
      "Step 03000 | Loss: 9.595276e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.9366729259, bias=-1.1173754930, out_weight=0.0000001005\n",
      "Neuron 2: weight=-1.1824021339, bias=1.5200920105, out_weight=-0.0000000291\n",
      "Neuron 3: weight=-1.0983538628, bias=-0.7354533076, out_weight=-0.0000001211\n",
      "Neuron 4: weight=0.7447363734, bias=-0.5851950049, out_weight=0.0000000919\n",
      "Neuron 5: weight=-0.0132466601, bias=-0.9145535231, out_weight=-0.0000000484\n",
      "Neuron 6: weight=0.7805695534, bias=1.0076452494, out_weight=-0.0000001101\n",
      "Neuron 7: weight=-0.5516315699, bias=-2.4082193375, out_weight=-0.0000000780\n",
      "Neuron 8: weight=1.6035760641, bias=-1.9870032072, out_weight=-0.0000000402\n",
      "Neuron 9: weight=-0.9788454175, bias=-0.1986232102, out_weight=0.0000000665\n",
      "Final covariance matrix F-norm: 1.864928e-15\n",
      "\n",
      "\n",
      "Main Iteration:42\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-1.3382805586, bias=1.3981149197, out_weight=-0.0000000008\n",
      "Neuron 2: weight=0.0714694411, bias=0.1855071336, out_weight=0.0000000000\n",
      "Neuron 3: weight=0.3754984140, bias=-1.8386460543, out_weight=0.0000000029\n",
      "Neuron 4: weight=0.4787482321, bias=-0.5495311022, out_weight=-0.0000000000\n",
      "Neuron 5: weight=0.0428047068, bias=-1.3696551323, out_weight=0.0000000071\n",
      "Neuron 6: weight=-0.0378699712, bias=0.8126194477, out_weight=-0.0000000122\n",
      "Neuron 7: weight=-0.2361120284, bias=-1.1889189482, out_weight=-0.0000000432\n",
      "Neuron 8: weight=-1.4999375343, bias=0.2110185176, out_weight=0.0000000144\n",
      "Neuron 9: weight=-0.4081827998, bias=-1.2111228704, out_weight=-0.0000000000\n",
      "Initial covariance matrix F-norm: 1.744126e-15\n",
      "Step 00000 | Loss: 8.220681e-14\n",
      "Step 01000 | Loss: 5.072505e-14\n",
      "Step 02000 | Loss: 8.271335e-14\n",
      "Step 03000 | Loss: 3.277760e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-1.3382805586, bias=1.3981149197, out_weight=-0.0000000518\n",
      "Neuron 2: weight=0.0714694411, bias=0.1855071336, out_weight=-0.0000000242\n",
      "Neuron 3: weight=0.3754984140, bias=-1.8386460543, out_weight=-0.0000000455\n",
      "Neuron 4: weight=0.4787482321, bias=-0.5495311022, out_weight=-0.0000000371\n",
      "Neuron 5: weight=0.0428047068, bias=-1.3696551323, out_weight=-0.0000000502\n",
      "Neuron 6: weight=-0.0378699712, bias=0.8126194477, out_weight=0.0000000374\n",
      "Neuron 7: weight=-0.2361120284, bias=-1.1889189482, out_weight=-0.0000000196\n",
      "Neuron 8: weight=-1.4999375343, bias=0.2110185176, out_weight=-0.0000000390\n",
      "Neuron 9: weight=-0.4081827998, bias=-1.2111228704, out_weight=0.0000001277\n",
      "Final covariance matrix F-norm: 1.805861e-15\n",
      "\n",
      "\n",
      "Main Iteration:43\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.2919073105, bias=-0.7415004969, out_weight=-0.0000000086\n",
      "Neuron 2: weight=-0.3710476756, bias=0.6970149875, out_weight=-0.0000000000\n",
      "Neuron 3: weight=0.1786303073, bias=0.0071970662, out_weight=-0.0000000030\n",
      "Neuron 4: weight=-1.6229432821, bias=-0.1977139413, out_weight=-0.0000000000\n",
      "Neuron 5: weight=-1.0123565197, bias=-0.2773270309, out_weight=-0.0000000014\n",
      "Neuron 6: weight=-1.2954564095, bias=-0.7789186835, out_weight=-0.0000000164\n",
      "Neuron 7: weight=1.4356100559, bias=0.1510855705, out_weight=0.0000000157\n",
      "Neuron 8: weight=0.5139718056, bias=1.3286746740, out_weight=0.0000000008\n",
      "Neuron 9: weight=-0.3016385734, bias=-0.2769269049, out_weight=0.0000000000\n",
      "Initial covariance matrix F-norm: 2.101047e-15\n",
      "Step 00000 | Loss: 6.265474e-14\n",
      "Step 01000 | Loss: 6.865515e-14\n",
      "Step 02000 | Loss: 7.325564e-14\n",
      "Step 03000 | Loss: 4.030283e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.2919073105, bias=-0.7415004969, out_weight=-0.0000000392\n",
      "Neuron 2: weight=-0.3710476756, bias=0.6970149875, out_weight=0.0000000241\n",
      "Neuron 3: weight=0.1786303073, bias=0.0071970662, out_weight=-0.0000000223\n",
      "Neuron 4: weight=-1.6229432821, bias=-0.1977139413, out_weight=0.0000000372\n",
      "Neuron 5: weight=-1.0123565197, bias=-0.2773270309, out_weight=-0.0000000149\n",
      "Neuron 6: weight=-1.2954564095, bias=-0.7789186835, out_weight=0.0000000041\n",
      "Neuron 7: weight=1.4356100559, bias=0.1510855705, out_weight=0.0000000716\n",
      "Neuron 8: weight=0.5139718056, bias=1.3286746740, out_weight=-0.0000000245\n",
      "Neuron 9: weight=-0.3016385734, bias=-0.2769269049, out_weight=0.0000000238\n",
      "Final covariance matrix F-norm: 2.124954e-15\n",
      "\n",
      "\n",
      "Main Iteration:44\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=0.9405736327, bias=1.2842071056, out_weight=0.0000000328\n",
      "Neuron 2: weight=-0.8186210394, bias=0.4582332969, out_weight=0.0000000002\n",
      "Neuron 3: weight=1.5737733841, bias=-0.6695608497, out_weight=0.0000000123\n",
      "Neuron 4: weight=-0.6348657608, bias=1.7755995989, out_weight=0.0000000001\n",
      "Neuron 5: weight=-1.2001936436, bias=0.2460332811, out_weight=0.0000000120\n",
      "Neuron 6: weight=-0.1772744060, bias=-1.3769466877, out_weight=0.0000000638\n",
      "Neuron 7: weight=-0.5787715912, bias=0.7248364687, out_weight=-0.0000000495\n",
      "Neuron 8: weight=-0.6570038199, bias=1.0697478056, out_weight=0.0000000023\n",
      "Neuron 9: weight=1.5205037594, bias=-0.4535931945, out_weight=-0.0000000001\n",
      "Initial covariance matrix F-norm: 1.919024e-15\n",
      "Step 00000 | Loss: 7.134224e-14\n",
      "Step 01000 | Loss: 8.500839e-14\n",
      "Step 02000 | Loss: 4.845300e-14\n",
      "Step 03000 | Loss: 4.208464e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=0.9405736327, bias=1.2842071056, out_weight=-0.0000000953\n",
      "Neuron 2: weight=-0.8186210394, bias=0.4582332969, out_weight=0.0000000257\n",
      "Neuron 3: weight=1.5737733841, bias=-0.6695608497, out_weight=0.0000000061\n",
      "Neuron 4: weight=-0.6348657608, bias=1.7755995989, out_weight=0.0000000649\n",
      "Neuron 5: weight=-1.2001936436, bias=0.2460332811, out_weight=0.0000001024\n",
      "Neuron 6: weight=-0.1772744060, bias=-1.3769466877, out_weight=-0.0000000646\n",
      "Neuron 7: weight=-0.5787715912, bias=0.7248364687, out_weight=-0.0000000634\n",
      "Neuron 8: weight=-0.6570038199, bias=1.0697478056, out_weight=-0.0000000288\n",
      "Neuron 9: weight=1.5205037594, bias=-0.4535931945, out_weight=0.0000000495\n",
      "Final covariance matrix F-norm: 1.943783e-15\n",
      "\n",
      "\n",
      "Main Iteration:45\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=1.5216251612, bias=-0.2709772885, out_weight=-0.0000000073\n",
      "Neuron 2: weight=-0.1477362514, bias=1.0268847942, out_weight=-0.0000000004\n",
      "Neuron 3: weight=0.2584802210, bias=0.7142741680, out_weight=-0.0000000068\n",
      "Neuron 4: weight=0.5362110734, bias=-0.8021433949, out_weight=-0.0000000002\n",
      "Neuron 5: weight=0.7996675968, bias=1.6077300310, out_weight=-0.0000000087\n",
      "Neuron 6: weight=-0.5853837729, bias=-0.2386338562, out_weight=-0.0000000059\n",
      "Neuron 7: weight=-0.6092095971, bias=1.6600542068, out_weight=-0.0000000107\n",
      "Neuron 8: weight=-0.7720248103, bias=0.6362332702, out_weight=0.0000000029\n",
      "Neuron 9: weight=0.1655287594, bias=0.3751365244, out_weight=0.0000000002\n",
      "Initial covariance matrix F-norm: 1.722759e-15\n",
      "Step 00000 | Loss: 5.268835e-14\n",
      "Step 01000 | Loss: 5.036423e-14\n",
      "Step 02000 | Loss: 5.060015e-14\n",
      "Step 03000 | Loss: 8.092312e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=1.5216251612, bias=-0.2709772885, out_weight=0.0000000261\n",
      "Neuron 2: weight=-0.1477362514, bias=1.0268847942, out_weight=0.0000001400\n",
      "Neuron 3: weight=0.2584802210, bias=0.7142741680, out_weight=0.0000000351\n",
      "Neuron 4: weight=0.5362110734, bias=-0.8021433949, out_weight=0.0000000370\n",
      "Neuron 5: weight=0.7996675968, bias=1.6077300310, out_weight=-0.0000001560\n",
      "Neuron 6: weight=-0.5853837729, bias=-0.2386338562, out_weight=0.0000000711\n",
      "Neuron 7: weight=-0.6092095971, bias=1.6600542068, out_weight=0.0000000498\n",
      "Neuron 8: weight=-0.7720248103, bias=0.6362332702, out_weight=-0.0000000943\n",
      "Neuron 9: weight=0.1655287594, bias=0.3751365244, out_weight=0.0000000340\n",
      "Final covariance matrix F-norm: 1.900696e-15\n",
      "\n",
      "\n",
      "Main Iteration:46\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.3175055385, bias=-1.3978927135, out_weight=0.0000000010\n",
      "Neuron 2: weight=-0.3032006919, bias=-0.4092377722, out_weight=0.0000000000\n",
      "Neuron 3: weight=0.1062980369, bias=-1.3500500917, out_weight=0.0000000024\n",
      "Neuron 4: weight=-0.7016844153, bias=-1.1489995718, out_weight=-0.0000000000\n",
      "Neuron 5: weight=0.4626043141, bias=-1.0669186115, out_weight=0.0000000044\n",
      "Neuron 6: weight=-0.9518280029, bias=-0.0972065181, out_weight=-0.0000000031\n",
      "Neuron 7: weight=0.4237121940, bias=-0.9852880239, out_weight=-0.0000000435\n",
      "Neuron 8: weight=1.4874463081, bias=-0.2077727914, out_weight=0.0000000124\n",
      "Neuron 9: weight=-0.7484461069, bias=-1.0296499729, out_weight=-0.0000000000\n",
      "Initial covariance matrix F-norm: 1.730580e-15\n",
      "Step 00000 | Loss: 4.376534e-14\n",
      "Step 01000 | Loss: 5.938999e-14\n",
      "Step 02000 | Loss: 9.129503e-14\n",
      "Step 03000 | Loss: 4.548618e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.3175055385, bias=-1.3978927135, out_weight=-0.0000000722\n",
      "Neuron 2: weight=-0.3032006919, bias=-0.4092377722, out_weight=-0.0000000478\n",
      "Neuron 3: weight=0.1062980369, bias=-1.3500500917, out_weight=-0.0000000854\n",
      "Neuron 4: weight=-0.7016844153, bias=-1.1489995718, out_weight=0.0000000722\n",
      "Neuron 5: weight=0.4626043141, bias=-1.0669186115, out_weight=0.0000000612\n",
      "Neuron 6: weight=-0.9518280029, bias=-0.0972065181, out_weight=-0.0000000390\n",
      "Neuron 7: weight=0.4237121940, bias=-0.9852880239, out_weight=0.0000000068\n",
      "Neuron 8: weight=1.4874463081, bias=-0.2077727914, out_weight=0.0000000000\n",
      "Neuron 9: weight=-0.7484461069, bias=-1.0296499729, out_weight=0.0000000664\n",
      "Final covariance matrix F-norm: 1.767734e-15\n",
      "\n",
      "\n",
      "Main Iteration:47\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=0.9999999404\n",
      "Neuron 1: weight=0.0552936271, bias=-1.3330322504, out_weight=-0.0000000174\n",
      "Neuron 2: weight=-0.7270749211, bias=-0.0415960029, out_weight=0.0000000003\n",
      "Neuron 3: weight=0.3207877576, bias=0.5330362916, out_weight=-0.0000000050\n",
      "Neuron 4: weight=-0.6015243530, bias=1.1686221361, out_weight=0.0000000001\n",
      "Neuron 5: weight=2.4665279388, bias=0.9793000817, out_weight=0.0000000002\n",
      "Neuron 6: weight=1.5081691742, bias=-0.7526158690, out_weight=-0.0000000502\n",
      "Neuron 7: weight=-0.2112736404, bias=0.7792533636, out_weight=0.0000000423\n",
      "Neuron 8: weight=-0.0883694515, bias=0.6359034181, out_weight=-0.0000000085\n",
      "Neuron 9: weight=-0.3800931275, bias=0.0954452381, out_weight=-0.0000000001\n",
      "Initial covariance matrix F-norm: 4.633472e-15\n",
      "Step 00000 | Loss: 2.061216e-13\n",
      "Step 01000 | Loss: 7.644059e-14\n",
      "Step 02000 | Loss: 5.380071e-14\n",
      "Step 03000 | Loss: 8.652280e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=0.0552936271, bias=-1.3330322504, out_weight=-0.0000000572\n",
      "Neuron 2: weight=-0.7270749211, bias=-0.0415960029, out_weight=0.0000000165\n",
      "Neuron 3: weight=0.3207877576, bias=0.5330362916, out_weight=-0.0000000985\n",
      "Neuron 4: weight=-0.6015243530, bias=1.1686221361, out_weight=-0.0000000864\n",
      "Neuron 5: weight=2.4665279388, bias=0.9793000817, out_weight=0.0000000061\n",
      "Neuron 6: weight=1.5081691742, bias=-0.7526158690, out_weight=0.0000000369\n",
      "Neuron 7: weight=-0.2112736404, bias=0.7792533636, out_weight=0.0000000619\n",
      "Neuron 8: weight=-0.0883694515, bias=0.6359034181, out_weight=0.0000000224\n",
      "Neuron 9: weight=-0.3800931275, bias=0.0954452381, out_weight=0.0000000308\n",
      "Final covariance matrix F-norm: 3.055916e-15\n",
      "\n",
      "\n",
      "Main Iteration:48\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-1.8360285759, bias=-1.8107715845, out_weight=0.0000000057\n",
      "Neuron 2: weight=-0.5087539554, bias=-1.4845101833, out_weight=0.0000000002\n",
      "Neuron 3: weight=1.3871186972, bias=-0.0894590765, out_weight=0.0000000039\n",
      "Neuron 4: weight=0.5701462626, bias=-1.6712179184, out_weight=0.0000000001\n",
      "Neuron 5: weight=0.9462459087, bias=-0.2312089801, out_weight=0.0000000054\n",
      "Neuron 6: weight=-0.4947102368, bias=1.6819410324, out_weight=0.0000000023\n",
      "Neuron 7: weight=1.8427968025, bias=1.6106805801, out_weight=0.0000000066\n",
      "Neuron 8: weight=-0.9730637074, bias=-0.6423439980, out_weight=-0.0000000031\n",
      "Neuron 9: weight=-0.4275229871, bias=-0.5597276688, out_weight=-0.0000000001\n",
      "Initial covariance matrix F-norm: 1.804952e-15\n",
      "Step 00000 | Loss: 6.149942e-14\n",
      "Step 01000 | Loss: 7.515169e-14\n",
      "Step 02000 | Loss: 7.189735e-14\n",
      "Step 03000 | Loss: 5.671852e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-1.8360285759, bias=-1.8107715845, out_weight=0.0000001091\n",
      "Neuron 2: weight=-0.5087539554, bias=-1.4845101833, out_weight=-0.0000000401\n",
      "Neuron 3: weight=1.3871186972, bias=-0.0894590765, out_weight=0.0000000587\n",
      "Neuron 4: weight=0.5701462626, bias=-1.6712179184, out_weight=0.0000000169\n",
      "Neuron 5: weight=0.9462459087, bias=-0.2312089801, out_weight=0.0000000378\n",
      "Neuron 6: weight=-0.4947102368, bias=1.6819410324, out_weight=0.0000000285\n",
      "Neuron 7: weight=1.8427968025, bias=1.6106805801, out_weight=0.0000001483\n",
      "Neuron 8: weight=-0.9730637074, bias=-0.6423439980, out_weight=0.0000001883\n",
      "Neuron 9: weight=-0.4275229871, bias=-0.5597276688, out_weight=0.0000000223\n",
      "Final covariance matrix F-norm: 2.330511e-15\n",
      "\n",
      "\n",
      "Main Iteration:49\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.2875713408, bias=-0.5069505572, out_weight=0.0000000037\n",
      "Neuron 2: weight=0.0627807155, bias=-0.1577868015, out_weight=0.0000000003\n",
      "Neuron 3: weight=0.4041003287, bias=0.8984649777, out_weight=0.0000000055\n",
      "Neuron 4: weight=0.3627027273, bias=0.2168322802, out_weight=0.0000000002\n",
      "Neuron 5: weight=-0.5325087905, bias=-1.1262111664, out_weight=0.0000000063\n",
      "Neuron 6: weight=-0.8229341507, bias=-0.5619962811, out_weight=0.0000000035\n",
      "Neuron 7: weight=0.4416505694, bias=1.3876866102, out_weight=0.0000000027\n",
      "Neuron 8: weight=-0.3808001578, bias=-0.1641462743, out_weight=0.0000000013\n",
      "Neuron 9: weight=-1.9380471706, bias=0.9211302996, out_weight=-0.0000000001\n",
      "Initial covariance matrix F-norm: 1.962227e-15\n",
      "Step 00000 | Loss: 7.630702e-14\n",
      "Step 01000 | Loss: 2.868712e-14\n",
      "Step 02000 | Loss: 1.150070e-13\n",
      "Step 03000 | Loss: 6.706441e-14\n",
      "Trained network parameters by neuron with lr=0.1:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.2875713408, bias=-0.5069505572, out_weight=-0.0000000463\n",
      "Neuron 2: weight=0.0627807155, bias=-0.1577868015, out_weight=-0.0000000215\n",
      "Neuron 3: weight=0.4041003287, bias=0.8984649777, out_weight=0.0000000012\n",
      "Neuron 4: weight=0.3627027273, bias=0.2168322802, out_weight=0.0000000515\n",
      "Neuron 5: weight=-0.5325087905, bias=-1.1262111664, out_weight=0.0000000956\n",
      "Neuron 6: weight=-0.8229341507, bias=-0.5619962811, out_weight=0.0000000669\n",
      "Neuron 7: weight=0.4416505694, bias=1.3876866102, out_weight=0.0000000586\n",
      "Neuron 8: weight=-0.3808001578, bias=-0.1641462743, out_weight=-0.0000000603\n",
      "Neuron 9: weight=-1.9380471706, bias=0.9211302996, out_weight=-0.0000000110\n",
      "Final covariance matrix F-norm: 1.967349e-15\n"
     ]
    }
   ],
   "source": [
    "\n",
    "X_f_train = torch.from_numpy(x_f).float().to(device)\n",
    "X_b_train = torch.from_numpy(x_b).float().to(device)\n",
    "dataset = torch.utils.data.TensorDataset(X_f_train)\n",
    "dataloader = torch.utils.data.DataLoader(dataset, batch_size=32, shuffle=True)\n",
    "\n",
    "eta=0.02\n",
    "m=10\n",
    "PINN = Sequentialmodel(m)\n",
    "PINN.to(device)\n",
    "\n",
    "'Neural Network Summary'\n",
    "print(PINN)\n",
    "\n",
    "PINN.init_exact()\n",
    "print(\"Exact network parameters by neuron (global min):\")       \n",
    "for idx in range(PINN.m):\n",
    "    w = PINN.fc1.weight[idx, 0].item()\n",
    "    b = PINN.fc1.bias[idx].item()\n",
    "    a = PINN.fc2.weight[0, idx].item()\n",
    "    print(f\"Neuron {idx}: weight={w:.10f}, bias={b:.10f}, out_weight={a:.10f}\")\n",
    "hessian_norm, full_hessian = compute_full_hessian_norm(PINN, X_b_train, X_f_train)   \n",
    "print(f\"Hessian matrix 2-norm: {hessian_norm:.6e}\")\n",
    "\n",
    "print('\\n')\n",
    "eta_tran_GD=2/hessian_norm\n",
    "print(f'Initial step size eta={eta}')\n",
    "print(f'Critical step size eta**={eta_tran_GD}')\n",
    "\n",
    "print('\\n')\n",
    "if eta < eta_tran_GD:\n",
    "    print(f'The step size eta={eta} lies within the stable region for gradient descent.')\n",
    "else:\n",
    "    eta=eta_tran_GD-0.001\n",
    "    print(f'Reset eta={eta} to ensure the step size is within the stability region of gradient descent .')\n",
    "\n",
    "V_true, VVt_true, VVt_2norm_true = covariance_fun(PINN, X_f_train, eta, batch_size=32)\n",
    "print(f\"Covariance matrix F-norm at global min with eta={eta}: {VVt_2norm_true:.6e}\")\n",
    "\n",
    "main_itr_num = 50\n",
    "max_iter = 100\n",
    "\n",
    "test_x = torch.linspace(-1, 1, 10000).unsqueeze(1).to(device) \n",
    "all_outputs = []\n",
    "final_weights = []\n",
    "\n",
    "for main_itr in range(main_itr_num):\n",
    "    print('\\n')\n",
    "    print(f\"Main Iteration:{main_itr}\")  \n",
    "    \n",
    "\n",
    "    PINN.init_exact()\n",
    "    covariance_perturbed_init(PINN, V_true, epsilon_scale=1)\n",
    "    \n",
    "    print(\"Initial network parameters by neuron:\")       \n",
    "    for idx in range(PINN.m):\n",
    "        w = PINN.fc1.weight[idx, 0].item()\n",
    "        b = PINN.fc1.bias[idx].item()\n",
    "        a = PINN.fc2.weight[0, idx].item()\n",
    "        print(f\"Neuron {idx}: weight={w:.10f}, bias={b:.10f}, out_weight={a:.10f}\")\n",
    "    V, VVt, VVt_Fnorm = covariance_fun(PINN, X_f_train, eta, batch_size=32)\n",
    "    print(f\"Initial covariance matrix F-norm: {VVt_Fnorm:.6e}\")\n",
    "    \n",
    "    optimizer = optim.SGD(PINN.parameters(), lr=eta)\n",
    "    \n",
    "    step = 0\n",
    "\n",
    "    for i in range(max_iter):\n",
    "\n",
    "        for batch in dataloader:\n",
    "            #VVt_2norm = covariance_fun(PINN, X_f_train, eta, batch_size=32)\n",
    "\n",
    "            batch_x = batch[0].to(device)\n",
    "            optimizer.zero_grad()\n",
    "            loss = PINN.loss(X_b_train, batch_x)\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "\n",
    "            if step % 1000 == 0:\n",
    "                print(f\"Step {step:05d} | Loss: {loss.item():.6e}\")\n",
    "            step += 1\n",
    "    \n",
    "    print(f\"Trained network parameters by neuron with lr={eta}:\")       \n",
    "    for idx in range(PINN.m):\n",
    "        w = PINN.fc1.weight[idx, 0].item()\n",
    "        b = PINN.fc1.bias[idx].item()\n",
    "        a = PINN.fc2.weight[0, idx].item()\n",
    "        print(f\"Neuron {idx}: weight={w:.10f}, bias={b:.10f}, out_weight={a:.10f}\")\n",
    "    V, VVt, VVt_Fnorm = covariance_fun(PINN, X_f_train, eta, batch_size=32)\n",
    "    print(f\"Final covariance matrix F-norm: {VVt_Fnorm:.6e}\")\n",
    "    \n",
    "   \n",
    "    with torch.no_grad():\n",
    "        output = PINN(test_x).cpu().numpy()\n",
    "        all_outputs.append(output)  # shape: [main_itr_num, 100, 1]\n",
    "\n",
    "   \n",
    "    final_weights.append(copy.deepcopy(PINN.state_dict()))\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5163b158",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Relative L2 error: 3.569e-07\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\user\\AppData\\Local\\Temp\\ipykernel_48420\\4157665835.py:66: UserWarning: This figure includes Axes that are not compatible with tight_layout, so results might be incorrect.\n",
      "  plt.tight_layout()\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAHqCAYAAAAZLi26AAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQAAy9dJREFUeJzs3XV4FNfbxvHvbtwTQiBCcNdAcAkSXIpVqOF1eVvaUqggLS20vwIVKNSBKm1DgRYKheDu7l4kCZaEuOy8fwBbAgECJNkE7s917UXmzJlzntksm332nDljMgzDQERERERERERyndnWAYiIiIiIiIjcrZR0i4iIiIiIiOQRJd0iIiIiIiIieURJt4iIiIiIiEgeUdItIiIiIiIikkeUdIuIiIiIiIjkESXdIiIiIiIiInlESbeIiIiIiIhIHlHSLSIiIiIiIpJHlHSLiMg978iRI5hMJj766KOb1h0xYgQmkykfopLrmTJlCiaTiSNHjtg6lEKhdOnS9O3b19ZhFHhLlizBZDKxZMkSW4ciIncZJd0iIvnscsJw+eHs7EzFihV5/vnniY6Otta7/AHw999/v+ZYZ2dnTpw4cU3bLVq0oHr16lnKSpcujclk4oUXXrimfnZ9ZOdyUnq9x5gxY271aZBLrnw9rFix4pr9hmEQHByMyWSic+fONoiw8Orbty/u7u7X3e/u7l7gk9G5c+cyYsQIm/X/+eefM2XKlFxtM7v3E09PT0JCQpgwYQKZmZm52p+IiK3Z2zoAEZF71TvvvEOZMmVISUlhxYoVTJo0iblz57Jjxw5cXV1veGxqaipjxozhs88+y3F/X331FUOHDiUwMPC2Y3744Yfp2LHjNeW1a9e+7TblImdnZ3766SeaNm2apXzp0qUcP34cJycnG0UmtjR37lwmTpx4R4n33r17MZtvb5zl888/p2jRonny5cSV7ydxcXHMnTuXF154gaNHj/K///0v1/sTEbEVJd0iIjbSoUMH6tatC8DAgQPx9fVl3LhxzJo1i4cffviGx4aEhNxSEl2tWjX27t3LmDFj+PTTT2875jp16vDYY4/d9vFyfR07duS3337j008/xd7+vz/PP/30E6GhoZw5c8aG0Ul+S0xMxM3NLVfaKqhf2Fz9fvLss8/SoEEDfvrpJyXdInJX0fRyEZEColWrVgAcPnz4pnXfeOMNMjMzczytu3Tp0vTu3ZuvvvqKkydP3lGcOemrc+fOrFixgvr16+Ps7EzZsmWZNm1alnrp6emMHDmSChUq4OzsjK+vL02bNmXBggVZ6u3Zs4f777+fIkWK4OzsTN26dZk9e3aWOpenaK9YsYIXX3wRPz8/vL29eeqpp0hLSyM2NpbevXvj4+ODj48PgwcPxjCMbOMfP348pUqVwsXFhebNm7Njx44cnfcPP/xAaGgoLi4uFClShF69evHvv//m+Hl7+OGHOXv2bJbzT0tL4/fff+eRRx7J9hiLxcLHH39MtWrVcHZ2pnjx4jz11FOcP38+S71Zs2bRqVMnAgMDcXJyoly5crz77rvXTOO9fHnCrl27aNmyJa6urgQFBfHhhx/m6By+++47WrVqRbFixXBycqJq1apMmjTpmno5fY0A7Ny5k1atWuHi4kKJEiUYNWoUFoslR/Hcqsuvo5UrVzJo0CD8/Pxwc3Oje/funD59+pr6f//9N82bN8fDwwNPT0/q1avHTz/9lKXO2rVrad++PV5eXri6utK8eXNWrlyZpc7ldQJ27drFI488go+PD02bNqVv375MnDgRIMtU7Ms++ugjGjdujK+vLy4uLoSGhmZ7qcjV13Tn9DxLly7Nzp07Wbp0qbXvFi1acOjQIUwmE+PHj7+mr1WrVmEymfj5559z9qRfwWQyUbx48SxfOkHevH6PHz9Ot27dcHNzo1ixYrz88sukpqbecswiIjmhpFtEpIA4ePAgAL6+vjetW6ZMmVtOot98800yMjLu6PrrpKQkzpw5c80jIyMjS70DBw5w//3306ZNG8aOHYuPjw99+/Zl586d1jojRoxg5MiRtGzZkgkTJvDmm29SsmRJNm3aZK2zc+dOGjZsyO7duxkyZAhjx47Fzc2Nbt268ccff1wT3wsvvMD+/fsZOXIk9913H19++SVvv/02Xbp0ITMzk/fff5+mTZvyv//9j++///6a46dNm8ann37Kc889x9ChQ9mxYwetWrXKcq19dt577z169+5NhQoVGDduHC+99BKRkZGEhYURGxubo+e2dOnSNGrUKEuy8vfffxMXF0evXr2yPeapp57itddeo0mTJnzyySf069ePH3/8kXbt2pGenm6tN2XKFNzd3Rk0aBCffPIJoaGhDBs2jCFDhlzT5vnz52nfvj21atVi7NixVK5cmddff52/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TcpyzObNmzGbzRw9evS652Zvb4+/vz/+/v5UrVqVd955h4SEBPbt22etM27cOGrUqIGbmxvBwcE8++yzJCQkWPdPmTIFb29v5s+fT5UqVXB3d6d9+/acOnXqls6xsFDSLSIiIjaRmprBu++uo1mzD/D39+fpp59mzZo1wD5gA5BJ0SKrearvHE78m8axk+GMHtseL2/bXFMpIpJT7u7uuLu7M3PmTFJTU7Ots379egC+++47Tp06Zd3+9ddfGTFiBO+//z4bNmwgICCAzz//PMuxY8eOZcqUKXz77besWLGCc+fO8ccff2SpM3r0aKZNm8bkyZPZuXMnL7/8Mo899hhLly7FbDbz8MMP89NPP2U55scff6RJkyaUKlUqR+eZmprKd999h7e3N5UqVbKWm81mPv30U3bu3MnUqVNZtGgRgwcPznJsUlISH330Ed9//z3Lli3j2LFjvPrqq7d0joWFySisXxcUIPHx8Xh5eREXF4enp6etwxERESnQIiOP8vbbB1m7thIWSxCwB6hi3V+9UinatHiGvk89Qs3awTaLU0QKhpSUFA4fPkyZMmVwdr404pwWB0d/unidtb1b3geRkXhxenmpR8AxZ1OoIyIieOKJJ0hOTqZOnTo0b96cXr16UbNmTWud7K7pbty4MbVr12bixInWsoYNG5KSkmJdSC0wMJCXX36Z11577WJ4GRmUKVOG0NBQa6JfpEgRFi5cSKNGjaztDBw4kKSkJH766Se2bNlCnTp1OHLkCCVLlsRisVCyZEneeustnn766WzPacSIEbz77ru4uFz88jMpKQkPDw+mT59O+/btr/tc/P777zz99NOcOXMGuDjS3a9fPw4cOEC5cuUA+Pzzz3nnnXeIiorK0Tnml2xff5fkNA/USLeIiIjkuQsX0njxxTX4+GyldetSrF7d6lLCDVAZL49wXuzfhY2rF7Ft92HGTX5dCbeIFGo9e/bk5MmTzJ49m/bt27NkyRLq1KnDlClTbnjc7t27adCgQZayKxPnuLg4Tp06laWOvb09devWtW4fOHCApKQk2rRpYx11d3d3Z9q0aRw8eBCAkJAQqlSpYh3tXrp0KTExMTzwwAM3jK9SpUps2bKFLVu2sHHjRp555hkeeOABNmzYYK2zcOFCwsPDCQoKwsPDg8cff5yzZ8+SlJRkrePq6mpNuAECAgKIiYnJ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woQJ9O7dG7g40h0bG8vMmTNvO674+Hi8vLyIi4vTdCkRKXD27dtH69at+ffff4HSODn+yLw/3WnRtqatQxORPHZ5FfG6devafKr5ZYZhsG/fPlauXIm7uzutW7emSJEitg5LROSW5TQPLDQj3WlpaWzcuJHWrVtby8xmM61bt2b16tU5aiMpKYn09PRr3tiXLFlCsWLFqFSpEs888wxnz57N1dhFRGxl+/bthIWFXUq4oWLZdPbt9FLCLXKPKIgj3iaTiUqVKtG9e3fMZjN//PEHu3btohCNA4mI3JJCs5DamTNnyMzMpHjx4lnKixcvzp49e3LUxuuvv05gYGCWxL19+/b06NGDMmXKcPDgQd544w06dOjA6tWrsbOzy7ad1NRUUlNTrdvx8fG3cUYiInnrxx930r//HtLSzgNQo3IpFiyIpHiJcjaOTETy0+UR7l27duHt7Y2vry8mk8nGUYGdnR2tWrVi/fr1LFiwgH379tGkSROcnJxsHZqIFFKGYXDhwgUCAwMxmwvO+HKhSbrv1JgxY/jll19YsmQJzs7O1vJevXpZf65RowY1a9akXLlyLFmyhPDw8GzbGj16NCNHjszzmEVEbtcXX2zh6adLAdUAB0JrvsE/C/6hSLEStg5NRGygTp06eHt7U66cvnQTkbvfv//+S4kSBeczT6FJuosWLYqdnR3R0dFZyqOjo/H397/hsR999BFjxoxh4cKF1Kx54ymVZcuWpWjRohw4cOC6SffQoUMZNGiQdTs+Pp7g4OAcnomISN76+ONNvPxyBcADAE/3UsycvZQixfxsG5iI2JSvry9w8cNoQVyD5sKFCyxbtozTp09Tp04datSoUSBG5EUkbxiGwffff89rr71NSso8oApgoVnT9fweURdn5+xnHd/I5bzMw8Mj1+O9E4Um6XZ0dCQ0NJTIyEi6desGXFxILTIykueff/66x3344Ye89957zJ8/n7p16960n+PHj3P27FkCAgKuW8fJyUlTn0SkQBo9egNvvFEVcAWgiPc6du+qSLEAb5vGJSK2dzmB9fT0LJBJt6enJw899BAbNmxgy5YtxMXF0bJlS1xdXW0dmojksnPnzvHkk08QETHjUsmTODjMZMKENJ58ss0dt1/QvrArOBPdc2DQoEF89dVXTJ06ld27d/PMM8+QmJhIv379AOjduzdDhw611v/g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R/ZZsGAB3n33XdVtuVzeZNe9PHXqFKZNewenTu0GYPzAPXdgbxuJL7/shOEBnmLFIyIiIiIi0mqiFt3m5uYwNzd/Yj83NzcUFhbixIkTcHJyAgBERkZCqVTCxcXliduvW7cOY8aMearHSk5ORuvWrR9bcAOAgYFBrfc3JRYWFkhNjQOwHsDbkEpzMMIzDt/96IbutqPFjkdERERERKTVNOKLu71794afnx+mT5+OH3/8ERUVFZg9ezYmTpyomrk8KysLPj4++O233+Ds7Kza9tKlS4iJiUF4ePhD+929ezfy8vLg6uoKQ0NDHDhwAJ999hnef//9Rntu6tahQwdMmDABp05GwGtwDyz/ygetjDkTORERERERUWPQiKIbADZv3ozZs2fDx8cHUqkUISEh+Pbbb1X3V1RU4Pz58ygtLa2x3fr169GxY0eMGDHioX3q6elhzZo1eOeddyAIAnr06IFVq1Zh+vTpan8+jemnn36CkZERJBKJ2FGIiIiIiIiaFYnQHNbHUrOnXRSdiIiIiIiItMPT1oEasU43ERERERERkSZi0U1ERERERESkJiy6iYiIiIiIiNSERTcRERERERGRmrDoJiIiIiIiIlITFt1EREREREREasKim4iIiIiIiEhNWHQTERERERERqQmLbiIiIiIiIiI1YdFNREREREREpCYsuomIiIiIiIjUhEU3ERERERERkZqw6CYiIiIiIiJSExbdRERERERERGqiK3YAbSAIAgBALpeLnISIiIiIiIgaQ3X9V10PPg6L7gZQXFwMAOjUqZPISYiIiIiIiKgxFRcXw9TU9LH3S4QnleX0REqlEtnZ2TA2NoZEIhE7zkPkcjk6deqE69evw8TEROw4VIXj0nRxbJomjkvTxHFpmjguTRPHpWniuDRNmjAugiCguLgY1tbWkEof/81tnuluAFKpFB07dhQ7xhOZmJg02V/Y5ozj0nRxbJomjkvTxHFpmjguTRPHpWniuDRNTX1cajvDXY0TqRERERERERGpCYtuIiIiIiIiIjVh0d0MGBgYYNGiRTAwMBA7Cj2A49J0cWyaJo5L08RxaZo4Lk0Tx6Vp4rg0Tdo0LpxIjYiIiIiIiEhNeKabiIiIiIiISE1YdBMRERERERGpCYtuIiIiIiIiIjVh0a0lPv30UwwePBhGRkYwMzN7qm0EQcDChQthZWWFFi1awNfXFxcvXqzRp6CgAJMmTYKJiQnMzMwwbdo0lJSUqOEZaKe6vn7Xrl2DRCJ55M+2bdtU/R51/5YtWxrjKWmF+vxee3t7P/Sav/HGGzX6ZGZmIiAgAEZGRrCwsMDcuXOhUCjU+VS0Sl3HpaCgAG+99RZsbW3RokULdO7cGXPmzEFRUVGNfjxe6mbNmjXo2rUrDA0N4eLigqSkpFr7b9u2DXZ2djA0NIS9vT3Cw8Nr3P807zX0ZHUZl59//hkeHh5o3bo1WrduDV9f34f6v/rqqw8dF35+fup+GlqpLmOzcePGh153Q0PDGn14zDSMuozLo97jJRIJAgICVH14zDybmJgYjB49GtbW1pBIJNi5c+cTt4mOjsbAgQNhYGCAHj16YOPGjQ/1qet7lmgE0goLFy4UVq1aJbz77ruCqanpU22zbNkywdTUVNi5c6eQkpIijBkzRujWrZtw9+5dVR8/Pz9hwIABQmJiohAbGyv06NFDePHFF9X0LLRPXV8/hUIh5OTk1PhZvHix0KpVK6G4uFjVD4CwYcOGGv0eHDeqXX1+r728vITp06fXeM2LiopU9ysUCqFfv36Cr6+vcOrUKSE8PFxo166dsGDBAnU/Ha1R13FJTU0VgoODhbCwMOHSpUvCoUOHhJ49ewohISE1+vF4eXpbtmwR9PX1hfXr1wtpaWnC9OnTBTMzMyEvL++R/ePi4gQdHR1h+fLlwtmzZ4WPPvpI0NPTE1JTU1V9nua9hmpX13F56aWXhDVr1ginTp0S0tPThVdffVUwNTUVbty4oeozZcoUwc/Pr8ZxUVBQ0FhPSWvUdWw2bNggmJiY1Hjdc3Nza/ThMfPs6jout2/frjEmZ86cEXR0dIQNGzao+vCYeTbh4eHChx9+KISGhgoAhB07dtTa/8qVK4KRkZHw7rvvCmfPnhVWr14t6OjoCBEREao+dR1nMbHo1jIbNmx4qqJbqVQKlpaWwooVK1RthYWFgoGBgfDHH38IgiAIZ8+eFQAIx44dU/X566+/BIlEImRlZTV4dm3TUK+fg4OD8Nprr9Voe5r/rOjR6jsuXl5ewttvv/3Y+8PDwwWpVFrjj6cffvhBMDExEcrLyxskuzZrqONl69atgr6+vlBRUaFq4/Hy9JydnYVZs2apbldWVgrW1tbC559//sj+L7zwghAQEFCjzcXFRXj99dcFQXi69xp6srqOy/9SKBSCsbGx8Ouvv6rapkyZIowdO7ahozY7dR2bJ/2dxmOmYTzrMfPVV18JxsbGQklJiaqNx0zDeZr35Q8++EDo27dvjbYJEyYII0eOVN1+1nFuTLy8vJm6evUqcnNz4evrq2ozNTWFi4sLEhISAAAJCQkwMzPDoEGDVH18fX0hlUpx9OjRRs+saRri9Ttx4gSSk5Mxbdq0h+6bNWsW2rVrB2dnZ6xfvx4CV/97Ks8yLps3b0a7du3Qr18/LFiwAKWlpTX2a29vj/bt26vaRo4cCblcjrS0tIZ/Ilqmof6/KSoqgomJCXR1dWu083h5snv37uHEiRM13hekUil8fX1V7wv/KyEhoUZ/4P7vfXX/p3mvodrVZ1z+V2lpKSoqKtCmTZsa7dHR0bCwsICtrS1mzpyJ27dvN2h2bVffsSkpKUGXLl3QqVMnjB07tsZ7BI+ZZ9cQx8y6deswceJEtGzZskY7j5nG86T3l4YY58ak++QupI1yc3MBoEaBUH27+r7c3FxYWFjUuF9XVxdt2rRR9aHHa4jXb926dejduzcGDx5co33JkiUYNmwYjIyMsH//frz55psoKSnBnDlzGiy/tqrvuLz00kvo0qULrK2tcfr0acybNw/nz59HaGioar+POp6q76PaNcTxcuvWLSxduhQzZsyo0c7j5encunULlZWVj/w9Pnfu3CO3edzv/YPvI9Vtj+tDtavPuPyvefPmwdrausYfp35+fggODka3bt1w+fJl/Oc//4G/vz8SEhKgo6PToM9BW9VnbGxtbbF+/Xr0798fRUVFWLlyJQYPHoy0tDR07NiRx0wDeNZjJikpCWfOnMG6detqtPOYaVyPe3+Ry+W4e/cu/v7772f+v7ExsehuwubPn48vvvii1j7p6emws7NrpEQEPP24PKu7d+/i999/x8cff/zQfQ+2OTo64s6dO1ixYkWzLiLUPS4PFnL29vawsrKCj48PLl++jO7du9d7v9qusY4XuVyOgIAA9OnTB5988kmN+3i8UHO2bNkybNmyBdHR0TUm7Jo4caLq3/b29ujfvz+6d++O6Oho+Pj4iBG1WXBzc4Obm5vq9uDBg9G7d2/89NNPWLp0qYjJqNq6detgb28PZ2fnGu08ZuhZsOhuwt577z28+uqrtfaxsbGp174tLS0BAHl5ebCyslK15+XlwcHBQdXn5s2bNbZTKBQoKChQbd8cPe24POvrt337dpSWlmLy5MlP7Ovi4oKlS5eivLwcBgYGT+yvjRprXKq5uLgAAC5duoTu3bvD0tLyoRkz8/LyAIDHi5rHpbi4GH5+fjA2NsaOHTugp6dXa38eL4/Wrl076OjoqH5vq+Xl5T12DCwtLWvt/zTvNVS7+oxLtZUrV2LZsmU4ePAg+vfvX2tfGxsbtGvXDpcuXWIB8ZSeZWyq6enpwdHREZcuXQLAY6YhPMu43LlzB1u2bMGSJUue+Dg8ZtTrce8vJiYmaNGiBXR0dJ75+GtM/E53E2Zubg47O7taf/T19eu1727dusHS0hKHDh1Stcnlchw9elT1CaybmxsKCwtx4sQJVZ/IyEgolUpVwdEcPe24POvrt27dOowZMwbm5uZP7JucnIzWrVs36wKiscalWnJyMgCo/ihyc3NDampqjcLxwIEDMDExQZ8+fRrmSWogdY+LXC7HiBEjoK+vj7CwsIeW3nkUHi+Ppq+vDycnpxrvC0qlEocOHapxZu5Bbm5uNfoD93/vq/s/zXsN1a4+4wIAy5cvx9KlSxEREVFjroTHuXHjBm7fvl2j0KPa1XdsHlRZWYnU1FTV685j5tk9y7hs27YN5eXlePnll5/4ODxm1OtJ7y8Ncfw1KrFncqOGkZGRIZw6dUq1vNSpU6eEU6dO1VhmytbWVggNDVXdXrZsmWBmZibs2rVLOH36tDB27NhHLhnm6OgoHD16VDhy5IjQs2dPLhlWB096/W7cuCHY2toKR48erbHdxYsXBYlEIvz1118P7TMsLEz4+eefhdTUVOHixYvC999/LxgZGQkLFy5U+/PRFnUdl0uXLglLliwRjh8/Lly9elXYtWuXYGNjI3h6eqq2qV4ybMSIEUJycrIQEREhmJubc8mwOqjruBQVFQkuLi6Cvb29cOnSpRrLuCgUCkEQeLzU1ZYtWwQDAwNh48aNwtmzZ4UZM2YIZmZmqln5X3nlFWH+/Pmq/nFxcYKurq6wcuVKIT09XVi0aNEjlwx70nsN1a6u47Js2TJBX19f2L59e43jovpvguLiYuH9998XEhIShKtXrwoHDx4UBg4cKPTs2VMoKysT5TlqqrqOzeLFi4V9+/YJly9fFk6cOCFMnDhRMDQ0FNLS0lR9eMw8u7qOS7UhQ4YIEyZMeKidx8yzKy4uVtUnAIRVq1YJp06dEjIyMgRBEIT58+cLr7zyiqp/9ZJhc+fOFdLT04U1a9Y8csmw2sa5KWHRrSWmTJkiAHjoJyoqStUHVWvVVlMqlcLHH38stG/fXjAwMBB8fHyE8+fP19jv7du3hRdffFFo1aqVYGJiIkydOrVGIU+1e9Lrd/Xq1YfGSRAEYcGCBUKnTp2EysrKh/b5119/CQ4ODkKrVq2Eli1bCgMGDBB+/PHHR/alR6vruGRmZgqenp5CmzZtBAMDA6FHjx7C3Llza6zTLQiCcO3aNcHf319o0aKF0K5dO+G9996rsXQV1a6u4xIVFfXI//cACFevXhUEgcdLfaxevVro3LmzoK+vLzg7OwuJiYmq+7y8vIQpU6bU6L9161ahV69egr6+vtC3b19h7969Ne5/mvcaerK6jEuXLl0eeVwsWrRIEARBKC0tFUaMGCGYm5sLenp6QpcuXYTp06c3yT9UNUFdxubf//63qm/79u2FUaNGCSdPnqyxPx4zDaOu/5edO3dOACDs37//oX3xmHl2j3vPrh6HKVOmCF5eXg9t4+DgIOjr6ws2NjY16phqtY1zUyIRBK6bQkRERERERKQO/E43ERERERERkZqw6CYiIiIiIiJSExbdRERERERERGrCopuIiIiIiIhITVh0ExEREREREakJi24iIiIiIiIiNWHRTURERERERKQmLLqJiIiIiIiI1IRFNxEREREREZGasOgmIiIiIiIiUhMW3URERERERERqwqKbiIiI6iQ/Px+Wlpb47LPPVG3x8fHQ19fHoUOHRExGRETU9EgEQRDEDkFERESaJTw8HEFBQYiPj4etrS0cHBwwduxYrFq1SuxoRERETQqLbiIiIqqXWbNm4eDBgxg0aBBSU1Nx7NgxGBgYiB2LiIioSWHRTURERPVy9+5d9OvXD9evX8eJEydgb28vdiQiIqImh9/pJiIionq5fPkysrOzoVQqce3aNbHjEBERNUk8001ERER1du/ePTg7O8PBwQG2trb4+uuvkZqaCgsLC7GjERERNSksuomIiKjO5s6di+3btyMlJQWtWrWCl5cXTE1NsWfPHrGjERERNSm8vJyIiIjqJDo6Gl9//TU2bdoEExMTSKVSbNq0CbGxsfjhhx/EjkdERNSk8Ew3ERERERERkZrwTDcRERERERGRmrDoJiIiIiIiIlITFt1EREREREREasKim4iIiIiIiEhNWHQTERERERERqQmLbiIiIiIiIiI1YdFNREREREREpCYsuomIiIiIiIjUhEU3ERERERERkZqw6CYiIiIiIiJSExbdRERERERERGrCopuIiIiIiIhITf4fAygh0eJHdH0AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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RERERERU3P4BwL1DwNHRckciCybdNqp37964e/euxt/KlSvlDkt2L7/8MrKysrBu3TqtcWvXrkVeXh5eeuklo+ebl5cHAAgODoafn5/JcRIRERERUQl5KXJHIAsm3TbK09MTVapU0fgLCgpSj1coFPj1118xaNAgVKhQAeHh4di4caN6fGpqKkaMGIHQ0FB4e3sjPDwcy5YtU4+/desWhgwZgsDAQAQHB+PZZ59FXFycevzo0aMxcOBAzJ49G5UrV0ZgYCA+++wzFBQUYPLkyQgODkaNGjU05lnoypUr6NSpE7y8vNC0aVPs27ev1M968OBBdOnSBd7e3ggLC8PEiRORlZWls2ylSpXQv39/LF26VGvc0qVLMXDgQAQHB+PDDz9EgwYNUKFCBdStWxfTpk1T92gPADNnzkTLli3x66+/ok6dOvDy8gKg3bz8999/R9u2beHn54cqVapg+PDhSEpKUo8vbC6/a9cutG3bFhUqVECnTp1w9epVjdj++ecftGvXDl5eXggJCcGgQYPU43Jzc/HBBx+gevXq8PHxQYcOHbB3795S1xkRERERkdWolEBeGrCpEXB2atHwgixgR1fg0tfyxWYHnCvpFkL6Ylj7TwiLfJxZs2ZhyJAhOH/+PJ555hmMGDECKSnS1aNp06bh0qVL2Lp1Ky5fvoyffvoJISEhAKTHqfXq1Qt+fn44cOAADh06BF9fX/Tu3Vtd4wsAu3fvRnx8PPbv34/58+djxowZ6NevH4KCgnDs2DG8/vrreO2113D79m2NuCZPnoz3338fZ86cQceOHdG/f3/cv39f52eIiYlB79698fzzz+P8+fNYtWoVDh48iLfeekvv5x43bhx2796NGzduqIddv34d+/fvx7hx4wAAfn5+WL58OS5duoTvv/8eixcvxoIFCzTmEx0djb/++gvr1q3Tex96fn4+Pv/8c5w7dw5///034uLiMHr0aK1yn3zyCb799lucPHkSbm5uGDt2rHrc5s2bMWjQIDzzzDM4c+YMdu3ahfbt26vHv/XWWzhy5AgiIiJw/vx5DB48GL1790ZUVJTedUBEREREZBW3NwJrfIHdPYD0q8CluUXjon8B7h0Azk6RLz57IOxYWlqaACDS0tK0xj18+FBcunRJPHz4sGhgfqYQf8L6f/mZRn2uUaNGCVdXV+Hj46Px9+WXX6rLABCf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T09PsXz5cnHp0iXx6quvisDAQHWv/S+//LL46KOP1OUPHTok3NzcxDfffCMuX74sZsyYofORYWUdq8g4xm6nuXPnCg8PD7F27VqN/abwHCMjI0N88MEH4siRIyI2Nlbs3LlTtG7dWoSHh4ucnBxZPqO9M3YbzZo1S/z7778iJiZGnDp1SgwdOlR4eXmJixcvqstwXzI/Y7dToc6dO4sXX3xRazj3JcvIyMhQ50YAxPz588WZM2fEjRs3hBBCfPTRR+Lll19Wly98ZNjkyZPF5cuXxcKFC3U+Mqy0bW9rmHSbyahRowQArb89e/aoy+DRs2cLqVQqMW3aNFG5cmXh6ekpevToIa5evaox3/v374thw4YJX19f4e/vL8aMGaORyJNxylqfsbGxWttNCCGmTp0qwsLChFKp1Jrn1q1bRcuWLYWvr6/w8fERLVq0EIsWLdJZlgxj7Ha6efOm6Nq1qwgODhaenp6ifv36YvLkyRrP6RZCiLi4ONGnTx/h7e0tQkJCxPvvv6/xqCoyjrHbac+ePTp/JwGI2NhYIQT3J3P48ccfRc2aNYWHh4do3769OHr0qHpct27dxKhRozTKr169WjRo0EB4eHiIJk2aiM2bN2uMN+RYRcYzZjvVqlVL534zY8YMIYQQ2dnZ4umnnxahoaHC3d1d1KpVS7zyyis2e/JpL4zZRu+++666bOXKlcUzzzwjTp8+rTE/7kuWYexv3pUrVwQAsX37dq15cV+yDH3H/8JtM2rUKNGtWzetaVq2bCk8PDxE3bp1NXKoQqVte1ujEILPYSEiIiIiIiKyBN7TTURERERERGQhTLqJiIiIiIiILIRJNxEREREREZGFMOkmIiIiIiIishAm3UREREREREQWwqSbiIiIiIiIyEKYdBMRERERERFZCJNuIiIiIiIiIgth0k1ERERERERkIUy6iYiIiIiIiCyESTcRERERERGRhTDpJiIiciL37t1DlSpVMHv2bPWww4cPw8PDA7t27ZIxMiIiIsekEEIIuYMgIiIi69myZQsGDhyIw4cPo2HDhmjZsiWeffZZzJ8/X+7QiIiIHA6TbiIiIic0YcIE7Ny5E23btkVkZCROnDgBT09PucMiIiJyOEy6iYiInNDDhw/RtGlT3Lp1C6dOnUKzZs3kDomIiMgh8Z5uIiIiJxQTE4P4+HioVCrExcXJHQ4REZHDYk03ERGRk8nLy0P79u3RsmVLNGzYEN999x0iIyNRqVIluUMjIiJyOEy6iYiInMzkyZOxdu1anDt3Dr6+vujWrRsCAgKwadMmuUMjIiJyOGxeTkRE5ET27t2L7777Dr///jv8/f3h4uKC33//HQcOHMBPP/0kd3hEREQOhzXdRERERERERBbCmm4iIiIiIiIiC2HSTURERERERGQhTLqJiIiIiIiILIRJNxEREREREZGFMOkmIiIiIiIishAm3UREREREREQWwqSbiIiIiIiIyEKYdBMRERERERFZCJNuIiIiIiIiIgth0k1ERERERERkIUy6iYiIiIiIiCyESTcRERERERGRhfw/azswVLugQOoAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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aGbXdAcFBWmu486VKxeu6GSEjx49sl1k5HSePtV/f/asMnEQETkzaxNiU+7TrQSl7xNORETkqsyu6a5cuTL27duH4sWLo3Hjxhg8eDCioqKwevVqVK5c2R4xejyevScich+e+JueVpKeXgLPa7qJiMjVmZ10T5s2DXFxcQCAMWPGIC4uDsuXL0fhwoXZc3karDkYcJYDCWeJg4jI07laTbM9OlJztW1ARESey+yku0CBAprXQUFBmD17tk0DclfucHCQch2YhBMR2Z4r/La6w38aERGRo5h9TTc5nrMegPGgi4jI9lyhZteZYlFzxpiIiIgAE2u6s2TJgosXLyJbtmzInDkzVGlkgU94Hym35azJPxGRM3FE8meP32NnTVpTW1f+JxERkaswKemePn06MmbMqHmdVtJNhoQAuna1fHqexyAicg5KJqau3Ht4WvGmd0jhCjX/REREaTEp6Y6MjNS87ty5s10CmThxIoYNG4YBAwZgxowZdlmGUo4ds276zz7Tf79oEdCpE1CvHrBhA+DnZ938LcVzL0TkyVL7DfSEZNCW6+gJ24uIiDyb2dd0161bFwsWLEBsbKzNgjhy5AjmzJmD0qVL22yezuT/b2tuM506yedt22QCbqr794F27YB//rFtPEREnsIRJxudtWZXd/mvXpk3bWJi6uOSktKedt8+7Wvd7Z/y/2/xYvNiIiIichSzk+63334bw4YNQ1hYGNq0aYO1a9fizZs3FgcQFxeHDh064JdffkHmzJktno+nMufcx2efAStWAHXq2GbZSh8AEhEpydLk2BaJuxK/v9Zc6jR8eOrjLl+2fL66Dh+2zXyIiIhszeyk+4cffsDt27fx119/ISgoCJ06dULOnDnRo0cP7N692+wA+vbtiyZNmqBu3brplo2Pj0dsbKzew9OZc+B1/br94iAi8gSu2kmatR49AqpWVToKIiIi12TRLcO8vLxQv359LFiwAPfv38ecOXPw77//4v333zdrPsuWLcOxY8cwYcIEk8pPmDABoaGhmkd4eLgl4ZONOOOBIRGRoyjdq7Yja7t37nTcsoiIiNyNVffpvnfvHmbPno1Jkybh1KlTqFChgsnT3rx5EwMGDMAff/yBDBkymDTNsGHDEBMTo3ncvHnT0tDdBpt4ExE5F2t/l01ptt6vH1CsmHXLISIiIscwO+mOjY3F/Pnz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LVviAtsUEhE5BdYWEBEREVnP7Gu6o6OjkS1bNpssfPfu3ejbty8OHTqEbdu24c2bN6hfvz5e2OseNArhgSulxJpucgX87SIiIiI1HhdYzuSk++DBg9iwYYPesN9//x0RERHIkSMHevTogfj4eLMWvnnzZnTu3Blvv/02ypQpgwULFuDGjRs4evSoWfMhIvJE6Z28SUgArlwBNm8GPvzQ/PnHxVkWFxERERFpmZx0jx07FmfOnNG8j4qKQrdu3VC3bl189dVXWL9+PSZMmGBVMDExMQCALFmyWDUfIiICatUCChUCGjUC/vxT6WiIiIiIPJPJHamdOHEC48aN07xftmwZKlWqhF9++QUAEB4ejlGjRmH06NEWBZKcnIyBAweiWrVqKFmypNEy8fHxerXpsbGxFi3L0dgUg1J680b7WgggKQnwMfnbSGQad76lGBEREZGrMLmm++nTp8iZM6fm/e7du9GoUSPN+woVKuDmzZsWB9K3b1+cPn0ay5YtS7XMhAkTEBoaqnmEh4dbvDwiJb31FhASIk/IeHkB2bMD/9/QQ486ISciIiIiUhIrEi1nctKdM2dOREdHAwASEhJw7NgxVK5cWTP++fPn8PX1tSiIfv36YcOGDdi5cyfy5MmTarlhw4YhJiZG87AmySdS2vPn2tfPngGrVxuWadZMNg82s7sE8hDskI+IiEgfE0P74XGH5Uxu0Nq4cWN89dVXmDRpEv766y8EBgaievXqmvGnTp1CwYIFzVq4EAKfffYZ1qxZg127diEiIiLN8v7+/vD39zdrGc6AH1AyhbHPyd9/y+c9e4B69RwbD7me+HggMRGIjgaePFE6GiIiIiICzEi6x40bh9atW6NmzZoIDg7GwoUL4efnpxn/22+/oX79+mYtvG/fvliyZAnWrl2LjBkz4t69ewCA0NBQBAQEmDUvIleX1skZnrUlU7z1FvD4sWllnz61byxERETkXng8ajmTk+5s2bJhz549iImJQXBwMLy9vfXGr1y5EsHBwWYtfNasWQCAWrVq6Q2fP38+OnfubNa8nBk/oETkCKYm3ACQNav94iAiIiL348jWu2XLOm5ZjmB2f8mhoaFGh1tymy/hIe2umXQTkT1Y8xPqIT+/RERERIozuSM1shwPbskU/JwQERERkbNiRaLlmHQTERERERER2QmTbgfgWSEisje2lCAi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opfIk3nS257R0dEG+00IIYYNGybCw8NFUlKSwTw3bdokypYtK4KDg0VQUJAoU6aMmD17ttGyZBpz99ONGzdEjRo1RJYsWYS/v78oVKiQGDp0qN59uoUQ4tq1a6JRo0YiICBAZMuWTQwePFjvVlVkHnP3086dO43+TgIQ0dHRQgh+n2zhp59+Ennz5hV+fn6iYsWK4tChQ5pxNWvWFJGRkXrlV6xYIYoUKSL8/PzE22+/Lf7++2+98ab8V5H5zNlP+fLlM/q9GTVqlBBCiJcvX4r69euL7NmzC19fX5EvXz7RvXt3pz34dBXm7KOBAwdqyubMmVM0btxYHDt2TG9+/C7Zh7m/eefPnxcAxNatWw3mxe+SfaT2/6/eN5GRkaJmzZoG05QtW1b4+fmJAgUK6OVQamnte2ejEoL3YSEiIiIiIiKyB17TTURERERERGQnTLqJiIiIiIiI7IRJNxEREREREZGdMOkmIiIiIiIishMm3URERERERER2wqSbiIiIiIiIyE6YdBMRERERERHZCZNuIiIiIiIiIjth0k1ERERERERkJ0y6iYiIiIiIiOyESTcRERERERGRnTDpJiIi8iAPHz5EWFgYxo8frxl24MAB+Pn5YceOHQpGRkRE5J5UQgihdBBERETkOBs3bkTLli1x4MABFC1aFGXLlkWLFi0wbdo0pUMjIiJyO0y6iYiIPFDfvn2xfft2lC9fHlFRUThy5Aj8/f2VDouIiMjtMOkmIiLyQK9evULJkiVx8+ZNHD16FKVKlVI6JCIiIrfEa7qJiIg80JUrV3Dnzh0kJyfj2rVrSodDRETktljTTURE5GESEhJQsWJFlC1bFkWLFsWMGTMQFRWFHDlyKB0aERGR22HSTURE5GGGDh2KVatW4eTJkwgODkbNmjURGhqKDRs2KB0aERGR22HzciIiIg+ya9cuzJgxA4sWLUJISAi8vLywaNEi7N27F7NmzVI6PCIiIrfDmm4iIiIiIiIiO2FNNxEREREREZGdMOkmIiIiIiIishMm3URERERERER2wqSbiIiIiIiIyE6YdBMRERERERHZCZNuIiIiIiIiIjth0k1ERERERERkJ0y6iYiIiIiIiOyESTcRERERERGRnTDpJiIiIiIiIrITJt1EREREREREdsKkm4iIiIiIiMhO/g8d6AETA802nwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1000x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "from mpl_toolkits.axes_grid1.inset_locator import inset_axes, mark_inset\n",
    "\n",
    "all_outputs = np.stack(all_outputs, axis=0)    # [20, 10000, 1]\n",
    "\n",
    "mean_output = np.mean(all_outputs, axis=0).flatten()   # [10000,]\n",
    "\n",
    "var_output = np.mean((all_outputs - mean_output.reshape(1, -1, 1)) ** 2, axis=0).flatten()   # [10000,]\n",
    "\n",
    "std_output = np.sqrt(var_output)\n",
    "\n",
    "x_eval = np.linspace(-1, 1, 10000)\n",
    "def u_true(x):\n",
    "    return np.tanh(2 * x + 1)\n",
    "u_true_vals = u_true(x_eval)\n",
    "\n",
    "rel_l2_error = np.linalg.norm(u_true_vals - mean_output, 2) / np.linalg.norm(u_true_vals, 2)\n",
    "print(f\"Relative L2 error: {rel_l2_error:.3e}\")\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(10,5))\n",
    "ax.plot(x_eval, u_true_vals, 'k-', label='True Solution', linewidth=2)\n",
    "ax.plot(x_eval, mean_output, 'b--', label='Ensemble Mean', linewidth=2)\n",
    "ax.fill_between(\n",
    "    x_eval,\n",
    "    mean_output - np.sqrt(var_output),\n",
    "    mean_output + np.sqrt(var_output),\n",
    "    color='orange', alpha=0.3, label='Stddev Band'\n",
    ")\n",
    "ax.set_xlabel('x')\n",
    "ax.set_ylabel('u(x)')\n",
    "ax.set_title('PINN Ensemble Mean and Uncertainty Band')\n",
    "ax.legend(loc='upper right')\n",
    "\n",
    "x1, x2 = -0.001, 0.001  \n",
    "axins = inset_axes(ax, width=\"35%\", height=\"50%\", loc='lower right', borderpad=2)\n",
    "\n",
    "axins.plot(x_eval, u_true_vals, 'k-', linewidth=2)\n",
    "axins.plot(x_eval, mean_output, 'b--', linewidth=2)\n",
    "axins.fill_between(\n",
    "    x_eval,\n",
    "    mean_output - np.sqrt(var_output),\n",
    "    mean_output + np.sqrt(var_output),\n",
    "    color='orange', alpha=0.3\n",
    ")\n",
    "axins.set_xlim(x1, x2)\n",
    "\n",
    "\n",
    "region = (x_eval >= x1) & (x_eval <= x2)\n",
    "y_vals = np.hstack([\n",
    "    u_true_vals[region], \n",
    "    mean_output[region] + np.sqrt(var_output[region]), \n",
    "    mean_output[region] - np.sqrt(var_output[region])\n",
    "])\n",
    "axins.set_ylim(y_vals.min(), y_vals.max())\n",
    "\n",
    "axins.set_xticks([])\n",
    "axins.set_yticks([])\n",
    "\n",
    "\n",
    "mark_inset(ax, axins, loc1=2, loc2=4, fc=\"none\", ec=\"0.6\", lw=1)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "\n",
    "plt.figure(figsize=(10, 4))\n",
    "plt.plot(x_eval, var_output, color='orange', label='Ensemble Variance')\n",
    "plt.xlabel('x')\n",
    "plt.ylabel('Variance')\n",
    "plt.title('Output Variance of PINN Ensemble')\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "plt.figure(figsize=(10, 4))\n",
    "plt.plot(x_eval, std_output, color='blue', label='Ensemble Std')\n",
    "plt.xlabel('x')\n",
    "plt.ylabel('Standard Deviation')\n",
    "plt.title('Output Standard Deviation of PINN Ensemble')\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bf26016a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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YMuWLdizZw88PDxU6/38/GBmZobo6Gil7eTJk0hJSVG+jIGIiIiIHk8Gn1pw8OBBLF26FKam/7epqakpJk6cWOL9ZcsyevRorFu3Dt9++y2sra2V815tbW1hbm4OW1tbDB8+HKGhobC3t4eNjQ3Gjh2LgIAA3rGAiIiI6DFncJC1sbFBSkoKvLy8VO3nzp2DtbW1QWMtWrQIANC5c2dV+4oVKzBkyBAAd2/3ZWJiguDgYOTm5iIoKAgLFy40tGwiIiIiesQYHGRfeuklDB8+HJ999hnat28PAPj111/x7rvvqr62tjxE5IF99Ho9IiMjERkZaWipRERERPQIMzjIfvbZZ9BoNBg8eDDu3LkDADAzM8Obb76JmTNnVnqBREREREQlMTjIarVazJs3D+Hh4UhOTgYANGrUCBYWFpVeHBERERFRaSp0H1kAsLCwQIsWLSqzFiIiIiKicit3kB02bFi5+i1fvrzCxRARERERlVe5g+zKlSvh5uaG1q1bl+siLSIiIiKiqlTuIPvmm29i/fr1OHPmDIYOHYpXX30V9vb2VVkbEREREVGpyv3NXpGRkbh06RImTpyIbdu2wcXFBQMGDMDOnTs5Q0tERERED51BX1Gr0+kwcOBA7Nq1CydOnICPjw/eeustuLu7Izs7u6pqJCIiIiIqxqAgq9rQxAQajQYigoKCgsqsiYiIiIjogQwKsrm5uVi/fj26d++OJk2a4OjRo1iwYAFSUlJgZWVVVTUSERERERVT7ou93nrrLWzYsAEuLi4YNmwY1q9fj7p161ZlbUREREREpSp3kF28eDFcXV3h6emJffv2Yd++fSX227x5c6UVR0RERERUmnIH2cGDB0Oj0VRlLURERERE5WbQFyIQEREREdUUFb5rARERERFRdWKQJSIiIiKjxCBLREREREaJQZaIiIiIjBKDLBEREREZJQZZIiIiIjJKDLJEREREZJQYZImIiIjIKDHIEhEREZFRYpAlIiIiIqPEIEtERERERolBloiIiIiMEoMsERERERklBlkiIiIiMkrVGmR/+ukn9O7dG87OztBoNNi6datqvYhg8uTJqF+/PszNzdGtWzckJSVVT7FEREREVKNUa5C9efMmfH19ERkZWeL6WbNmYf78+Vi8eDH2798PS0tLBAUFIScn5yFXSkREREQ1jWl17rxnz57o2bNnietEBHPnzsUHH3yAvn37AgD+97//wdHREVu3bsXLL7/8MEslIiIiohqmxp4je+bMGaSmpqJbt25Km62tLfz9/REbG1uNlRERERFRTVCtM7JlSU1NBQA4Ojqq2h0dHZV1JcnNzUVubq6ynJWVVTUFEhEREVG1qrEzshUVHh4OW1tb5eHi4lLdJRERERFRFaixQdbJyQkAkJaWpmpPS0tT1pUkLCwMmZmZyuPcuXNVWicRERERVY8aG2Q9PDzg5OSE6OhopS0rKwv79+9HQEBAqdvpdDrY2NioHkRERET06KnWc2Szs7Nx6tQpZfnMmTNISEiAvb09XF1dMW7cOHz88cd44okn4OHhgQ8//BDOzs7o169f9RVNRERERDVCtQbZgwcPokuXLspyaGgoACAkJAQrV67ExIkTcfPmTYwcORIZGRl4+umnERUVBb1eX10lExEREVENUa1BtnPnzhCRUtdrNBpMnz4d06dPf4hVEREREZExqLHnyBIRERERlYVBloiIiIiMEoMsERERERklBlkiIiIiMkoMskRERERklBhkiYiIiMgoMcgSERERkVFikCUiIiIio8QgS0RERERGiUGWiIiIiIwSgywRERERGSUGWSIiIiIySgyyRERERGSUGGSJiIiIyCgxyBIRERGRUWKQJSIiIiKjxCBLREREREaJQZaIiIiIjBKDLBEREREZJQZZIiIiIjJKDLJEREREZJQYZImIiIjIKDHIEhEREZFRYpAlIiIiIqPEIEtERERERolBloiIiIiMEoMsERERERklBlkiIiIiMkoMskRERERklEyru4DyiIyMxKefforU1FT4+vri888/x1NPPVXdZREREdFDkJKSgvT09Oou47FWt25duLq6VncZxdT4IPvVV18hNDQUixcvhr+/P+bOnYugoCCcPHkS9erVq+7yiIiIqAqlpKTA26spbt3Oqe5SHmsW5nok/nmyxoXZGh9k58yZg9dffx1Dhw4FACxevBg//PADli9fjkmTJlVzdURERFSV0tPTcet2Dta8BXg7V3c1j6fEi8CrC3OQnp7OIGuIvLw8xMfHIywsTGkzMTFBt27dEBsbW42VERER0cPk7Qy08ajuKqimqdFBNj09HQUFBXB0dFS1Ozo64s8//yxxm9zcXOTm5irLmZmZAICsrKyqK/Qe2dnZAID4s0A2PwWpFidT7/6ZnZ390F53IiKqGnxfrX4P+321aB8i8sC+NTrIVkR4eDimTZtWrN3FxeWh1jHyy4e6OypBYGBgdZdARESVhO+r1e9hv6/euHEDtra2Zfap0UG2bt26qFWrFtLS0lTtaWlpcHJyKnGbsLAwhIaGKsuFhYW4du0a6tSpA41GU6X1PiqysrLg4uKCc+fOwcbGprrLISIiMlp8TzWciODGjRtwdn7wSdE1OshqtVr4+fkhOjoa/fr1A3A3mEZHR2PMmDElbqPT6aDT6VRtdnZ2VVzpo8nGxoa/dERERJWA76mGedBMbJEaHWQBIDQ0FCEhIWjbti2eeuopzJ07Fzdv3lTuYkBEREREj6caH2RfeuklXLlyBZMnT0ZqaipatWqFqKioYheAEREREdHjpcYHWQAYM2ZMqacSUOXT6XSYMmVKsVM0iIiIyDB8T61aGinPvQ2IiIiIiGoYk+ougIiIiIioIhhkiYiIiMgoMcgSERERkVFikK0ikZGRcHd3h16vh7+/P37//fcy+2/cuBFeXl7Q6/Vo0aIFtm/frlovIpg8eTLq168Pc3NzdOvWDUlJSao+165dw6BBg2BjYwM7OzsMHz5c+Wq/In/88Qc6duwIvV4PFxcXzJo1S7U+Pz8f06dPR6NGjaDX6+Hr64uoqChVnxs3bmDcuHFwc3ODubk52rdvjwMHDqj6pKWlYciQIXB2doaFhQWeffbZYvUmJyfjhRdegIODA2xsbDBgwIBiX37h7u4OjUajesycObPYsfnss8/QpEkT6HQ6NGjQADNmzCjzeBMRkXGpie+rOTk5GDJkCFq0aAFTU1Plnvf327t3L9q0aQOdTofGjRtj5cqVBj+/nJwcjB49GnXq1IGVlRWCg4OLvWdGR0ejffv2sLa2hpOTE9577z3cuXNHVUffvn1Rv359WFpaolWrVli7dq1qjJUrVxZ739Xr9aUe52onVOk2bNggWq1Wli9fLsePH5fXX39d7OzsJC0trcT+v/76q9SqVUtmzZolJ06ckA8++EDMzMzk6NGjSp+ZM2eKra2tbN26VY4cOSJ9+vQRDw8PuX37ttLn2WefFV9fX4mLi5Off/5ZGjduLAMHDlTWZ2ZmiqOjowwaNEiOHTsm69evF3Nzc/niiy+UPhMnThRnZ2f54YcfJDk5WRYuXCh6vV4OHTqk9BkwYIA0a9ZM9u3bJ0lJSTJlyhSxsbGR8+fPi4hIYWGhtGvXTjp27Ci///67/PnnnzJy5EhxdXWV7OxsERHJzs4WT09PeeGFF+SPP/6QP/74Q/r27StPPvmkFBQUKPtyc3OT6dOny6VLl5RH0RhFxo4dK02bNpVvv/1WTp8+LQcPHpQff/yxIi8dERHVQDX1fTU7O1tGjRolS5YskaCgIOnbt2+xWk6fPi0WFhYSGhoqJ06ckM8//1xq1aolUVFRBj2/UaNGiYuLi0RHR8vBgwelXbt20r59e2V9QkKCaLVamTZtmiQlJcnevXvFy8tL3nnnHaXPjBkz5IMPPpBff/1VTp06JXPnzhUTExPZtm2b0mfFihViY2Ojet9NTU0t5yv18DHIVoGnnnpKRo8erSwXFBSIs7OzhIeHl9h/wIAB0qtXL1Wbv7+/vPHGGyJyNxg6OTnJp59+qqzPyMgQnU4n69evFxGREydOCAA5cOCA0mfHjh2i0WjkwoULIiKycOFCqV27tuTm5ip93nvvPWnatKmyXL9+fVmwYIGqlv79+8ugQYNEROTWrVtSq1Yt+f7771V92rRpI++//76IiJw8eVIAyLFjx1THwMHBQZYuXSoiIjt37hQTExPJzMxUPSeNRiO7du1S2tzc3CQiIqLE41b0vE1NTeXPP/8stQ8RERm3mvq+eq+QkJASg+zEiRPFx8dH1fbSSy9JUFBQuZ9fRkaGmJmZycaNG5U+iYmJAkBiY2NFRCQsLEzatm2r2s93330ner1esrKySjhKdz333HMydOhQZXnFihVia2tbav+ahqcWVLK8vDzEx8ejW7duSpuJiQm6deuG2NjYEreJjY1V9QeAoKAgpf+ZM2eQmpqq6mNrawt/f3+lT2xsLOzs7NC2bVulT7du3WBiYoL9+/crfTp16gStVqvaz8mTJ3H9+nUAQG5ubrGPEMzNzfHLL78AAO7cuYOCgoIy++Tm5gKAqo+JiQl0Op2qj0ajUd1XT6/Xw8TEROlTZObMmahTpw5at26NTz/9VPUxybZt2+Dp6Ynvv/8eHh4ecHd3x4gRI3Dt2rWSDjURERmZmvy+Wh4PqqU8zy8+Ph75+fmqPl5eXnB1dVX6lPb+nZOTg/j4+FLry8zMhL29vaotOzsbbm5ucHFxQd++fXH8+PFyP9+HjUG2kqWnp6OgoKDYN485OjoiNTW1xG1SU1PL7F/054P61KtXT7Xe1NQU9vb2qj4ljXHvPoKCgjBnzhwkJSWhsLAQu3btwubNm3Hp0iUAgLW1NQICAvDRRx/h4sWLKCgowJo1axAbG6v0KfrlCgsLw/Xr15GXl4f//ve/OH/+vNKnXbt2sLS0xHvvvYdbt27h5s2bmDBhAgoKCpQ+APD2229jw4YNiImJwRtvvIFPPvkEEydOVNafPn0af//9NzZu3Ij//e9/WLlyJeLj4/Hiiy+WeKyJiMi41OT31fIorZasrCzcvn27XM8vNTUVWq0WdnZ2pfYJCgrCb7/9hvXr16OgoAAXLlzA9OnTAUD1vnqvr7/+GgcOHMDQoUOVtqZNm2L58uX49ttvsWbNGhQWFqJ9+/Y4f/58uZ/zw8QgSyrz5s3DE088AS8vL2i1WowZMwZDhw6Ficn//aisXr0aIoIGDRpAp9Nh/vz5GDhwoNLHzMwMmzdvxl9//QV7e3tYWFggJiYGPXv2VPo4ODhg48aN2LZtG6ysrGBra4uMjAy0adNGta/Q0FB07twZLVu2xKhRozB79mx8/vnnyqxvYWEhcnNz8b///Q8dO3ZE586dsWzZMsTExODkyZMP8cgRERFVnx49euDTTz/FqFGjoNPp0KRJEzz33HMAoHpfLRITE4OhQ4di6dKl8PHxUdoDAgIwePBgtGrVCoGBgdi8eTMcHBzwxRdfPLTnYggG2UpWt25d1KpVq9iVhGlpaXBycipxGycnpzL7F/35oD6XL19Wrb9z5w6uXbum6lPSGPfuw8HBAVu3bsXNmzfx999/488//4SVlRU8PT2VbRo1aoR9+/YhOzsb586dw++//478/HxVHz8/PyQkJCAjIwOXLl1CVFQUrl69qurTo0cPJCcn4/Lly0hPT8fq1atx4cIFVZ/7+fv7486dOzh79iwAoH79+jA1NUWTJk2UPt7e3gCAlJSUUschIiLjUJPfV8ujtFpsbGxgbm5erufn5OSEvLw8ZGRklNoHuDv5k5GRgZSUFKSnp6Nv374AUOx9dd++fejduzciIiIwePDgMus3MzND69atcerUqXI/54eJQbaSabVa+Pn5ITo6WmkrLCxEdHQ0AgICStwmICBA1R8Adu3apfT38PCAk5OTqk9WVhb279+v9AkICEBGRobqPJg9e/agsLAQ/v7+Sp+ffvoJ+fn5qv00bdoUtWvXVu1fr9ejQYMGuHPnDjZt2qT8MtzL0tIS9evXx/Xr17Fz584S+9ja2sLBwQFJSUk4ePBgiX3q1q0LOzs77NmzB5cvX0afPn1KPE4AkJCQABMTE+Xjng4dOuDOnTtITk5W+vz1118AADc3t1LHISIi41CT31fL40G1lOf5+fn5wczMTNXn5MmTSElJKXYMNBoNnJ2dYW5ujvXr18PFxQVt2rRR1u/duxe9evXCf//7X4wcOfKB9RcUFODo0aOoX79+uZ/zQ1XdV5s9ijZs2CA6nU5WrlwpJ06ckJEjR4qdnZ1y+4rXXntNJk2apPT/9ddfxdTUVD777DNJTEyUKVOmlHibEDs7O/n222+VW1WVdJuQ1q1by/79++WXX36RJ554QnWbkIyMDHF0dJTXXntNjh07Jhs2bBALCwvV7bfi4uJk06ZNkpycLD/99JN07dpVPDw85Pr160qfqKgo2bFjh5w+fVp+/PFH8fX1FX9/f8nLy1P6fP311xITEyPJycmydetWcXNzk/79+6uO0/LlyyU2NlZOnTolq1evFnt7ewkNDVXW//bbbxIRESEJCQmSnJwsa9asEQcHBxk8eLDSp6CgQNq0aSOdOnWSQ4cOycGDB8Xf31+6d+9ekZeOiIhqoJr6vioicvz4cTl8+LD07t1bOnfuLIcPH5bDhw8r64tuv/Xuu+9KYmKiREZGlnj7rbKen8jd22+5urrKnj175ODBgxIQECABAQGqWmbNmiV//PGHHDt2TKZPny5mZmayZcsWZf2ePXvEwsJCwsLCVLfXunr1qtJn2rRpsnPnTklOTpb4+Hh5+eWXRa/Xy/Hjxw181R4OBtkq8vnnn4urq6totVp56qmnJC4uTlkXGBgoISEhqv5ff/21NGnSRLRarfj4+MgPP/ygWl9YWCgffvihODo6ik6nk2eeeUZOnjyp6nP16lUZOHCgWFlZiY2NjQwdOlRu3Lih6nPkyBF5+umnRafTSYMGDWTmzJmq9Xv37hVvb2/R6XRSp04dee2114rdZuSrr74ST09P0Wq14uTkJKNHj5aMjAxVn3nz5knDhg3FzMxMXF1d5YMPPlDd9kvk7q2/HB0dxczMTJ544gmZPXu2FBYWKuvj4+PF399fbG1tRa/Xi7e3t3zyySeSk5OjGufChQvSv39/sbKyEkdHRxkyZIjql5KIiIxfTX1fdXNzEwDFHveKiYmRVq1aiVarFU9PT1mxYoVBz09E5Pbt2/LWW29J7dq1xcLCQl544QW5dOmSqk+XLl2U90x/f3/Zvn27an1ISEiJtQYGBip9xo0bp9Th6Ogozz33nOpe8jWNRkSkumaDiYiIiIgqiufIEhEREZFRYpAlIiIiIqPEIEtERERERolBloiIiIiMEoMsERERERklBlkiIiIiMkoMskRERERklBhkiYiIiMgoMcgSEVGp9u7dC41Gg4yMjOouhYioGAZZIqJ7nDt3DsOGDYOzszO0Wi3c3Nzw73//G1evXjVonLNnz0Kj0SAhIaFK6tRoNNi6dWuVjE1EZCwYZImI/r/Tp0+jbdu2SEpKwvr163Hq1CksXrwY0dHRCAgIwLVr16q7RCIiugeDLBHR/zd69GhotVr8+OOPCAwMhKurK3r27Indu3fjwoULeP/995W+Jc2I2tnZYeXKlQAADw8PAEDr1q2h0WjQuXNnAMCQIUPQr18/TJs2DQ4ODrCxscGoUaOQl5enjOPu7o65c+eqxm7VqhWmTp2qrAeAF154ARqNRlm+X/v27fHee++p2q5cuQIzMzP89NNPAIDVq1ejbdu2sLa2hpOTE1555RVcvny51GM0depUtGrVStU2d+7cYjV8+eWX8Pb2hl6vh5eXFxYuXFjqmEREFcUgS0QE4Nq1a9i5cyfeeustmJubq9Y5OTlh0KBB+OqrryAi5Rrv999/BwDs3r0bly5dwubNm5V10dHRSExMxN69e7F+/Xps3rwZ06ZNK3etBw4cAACsWLECly5dUpbvN2jQIGzYsEFV81dffQVnZ2d07NgRAJCfn4+PPvoIR44cwdatW3H27FkMGTKk3LWUZO3atZg8eTJmzJiBxMREfPLJJ/jwww+xatWqfzQuEdH9GGSJiAAkJSVBRODt7V3iem9vb1y/fh1Xrlwp13gODg4AgDp16sDJyQn29vbKOq1Wi+XLl8PHxwe9evXC9OnTMX/+fBQWFho0tp2dHZycnJTl+w0YMAAXL17EL7/8orStW7cOAwcOhEajAQAMGzYMPXv2hKenJ9q1a4f58+djx44dyM7OLlctJZkyZQpmz56N/v37w8PDA/3798f48ePxxRdfVHhMIqKSMMgSEd2jvDOu/4Svry8sLCyU5YCAAGRnZ+PcuXOVuh8HBwf06NEDa9euBQCcOXMGsbGxGDRokNInPj4evXv3hqurK6ytrREYGAgASElJqdA+b968ieTkZAwfPhxWVlbK4+OPP0ZycvI/f1JERPdgkCUiAtC4cWNoNBokJiaWuD4xMRG1a9dWZj81Gk2x0Jufn18ptZiYmFTa2IMGDcI333yD/Px8rFu3Di1atECLFi0A3A2dQUFBsLGxwdq1a3HgwAFs2bIFAFTn7BpSW9FM7tKlS5GQkKA8jh07hri4uAo9ByKi0jDIEhHh7ikA3bt3x8KFC3H79m3VutTUVKxduxYvvfSS8pG8g4MDLl26pPRJSkrCrVu3lGWtVgsAKCgoKLavI0eOqPYRFxcHKysruLi4lDh2VlYWzpw5oxrDzMysxLHv17dvX+Tk5CAqKgrr1q1Tzcb++eefuHr1KmbOnImOHTvCy8urzAu9impLTU1Vhdl7bzHm6OgIZ2dnnD59Go0bN1Y9ii6AIyKqLAyyRET/34IFC5Cbm4ugoCD89NNPOHfuHKKiotC9e3c0aNAAM2bMUPp27doVCxYswOHDh3Hw4EGMGjUKZmZmyvp69erB3NwcUVFRSEtLQ2ZmprIuLy8Pw4cPx4kTJ7B9+3ZMmTIFY8aMgYmJiTL26tWr8fPPP+Po0aMICQlBrVq1VLW6u7sjOjoaqampuH79eqnPydLSEv369cOHH36IxMREDBw4UFnn6uoKrVaLzz//HKdPn8Z3332Hjz76qMxj1LlzZ1y5cgWzZs1CcnIyIiMjsWPHDlWfadOmITw8HPPnz8dff/2Fo0ePYsWKFZgzZ06ZYxMRGUyIiEhx9uxZCQkJEUdHRzEzMxMXFxcZO3aspKenq/pduHBBevToIZaWlvLEE0/I9u3bxdbWVlasWKH0Wbp0qbi4uIiJiYkEBgaKiEhISIj07dtXJk+eLHXq1BErKyt5/fXXJScnR9kuMzNTXnrpJbGxsREXFxdZuXKl+Pr6ypQpU5Q+3333nTRu3FhMTU3Fzc2tzOe0fft2ASCdOnUqtm7dunXi7u4uOp1OAgIC5LvvvhMAcvjwYRERiYmJEQBy/fp1ZZtFixaJi4uLWFpayuDBg2XGjBnFali7dq20atVKtFqt1K5dWzp16iSbN28us04iIkNpRB7ClQ1ERATg7n1kMzIy+K1cRESVgKcWEBEREZFRYpAlIiIiIqPEUwuIiIiIyChxRpaIiIiIjBKDLBEREREZJQZZIiIiIjJKDLJEREREZJQYZImIiIjIKDHIEhEREZFRYpAlIiIiIqPEIEtERERERolBloiIiIiM0v8DleKvjxPSa/oAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 700x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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vYqTJ0+id+/ecHJyUvqFhISgdu3aRsWXvcKTkpKCmzdvolmzZnjw4AHOnj1r1BiGeHt7K8/tZs2a4dixY1i6dClKly5d4LaffvpprtcEQ5eZM2eaFZuuGq7VanPdpnvOFFQxHz58OPz9/fVeH3JSq9UYNGgQdu/ejZEjR+L8+fM4cuQIunbtirS0NL399OjRAy4uLnjrrbewc+dOJCQkYNGiRZg/f75eP1PGZJwlN06yLrbFHQA9nQYNGhj8iC+nChUq6F3X/YPXJa1arRZTp07FRx99BC8vL7z44oto164devfuDW9vbwDA+fPnAUBJCHPK+U/W3t4enp6eem0uLi4oX748VCpVrnZDCXSVKlX0rjs5OcHHxyffU6acP38eMTExufatc/369Ty3vXTpEoCs5DqnwMBA/P7773luay61Wg1/f3+9tqpVqwJAoZ8aRne8lStX1mt3d3fXSwKze+655wyOkfM+02g08Pf3V243R875V6lUqFy5slH3S0GP+byOXdf2999/F7iP06dPY/To0fj1119x7949vdvM/ehep1u3blixYgWioqIwcOBAtGzZ0qjtatSogRo1ajzVvoGsJQqpqanKdRsbG3h6eirJu+7j2uwePXoEwPBHuDoHDx7E8uXLsXv3br03PoZ88cUXuHnzJqZNm4YpU6YAANq0aYN+/fph4cKFyhsQb29vbN68Gb169UKbNm0AZL0ezZkzBxEREXpvVIwdk3GWzDjJ+jCRLSGyV9Cyk2xrTT/44AO0b98eP/30E3bs2IHPP/8ckydPxq+//or69esjMzMTQNbaS11ym52trf7DKa99GhPL08jMzETt2rXx1VdfGbzdz8/vmexHpVIZjDkjI+OZjJ9zX4YUxr4Kkl+SUpD8jiOvx4W5CvtxdufOHYSEhKB06dL44osvEBAQAHt7e/z9998YPny48nwxV3JysnJ+zTNnziAzM7PABADISqCNqS5pNBq4u7vnefuMGTMwfvx45XrFihWRkJAAHx8fAEBiYmKubRITE+Hu7m6wWqvz6aefolmzZnjuueeUNyQ3b95Utr98+bLyJkSj0eC7777DxIkTce7cOXh5eaFq1aro0aMH1Gq13puQl156CRcvXsTJkydx//591K1bF1evXgXwvzeGpozJOEtmnGR9mMiSnoCAAHz00Uf46KOPcP78edSrVw8z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RERkKotIZFmRJSIiIiJTWUQiy4osEREREZnKIhJZVmSJiIiIyFQWkciyIktEREREprKIRJYVWSIiIiIylUUksqzIEhEREZGpLCKRZUWWiIiIiExlEYksK7JEREREZCqLSGRZkSUiIiIiU1lEIsuKLBERERGZyiISWVZkiYiIiMhUFpHIsiJLRERERKayiESWFVkiIiIiMpVFJLKsyBIRERGRqSwikWVFloiIiIhMZRGJLCuyRERERGQqi0hkWZElIiIiIlNZRCLLiiwRERERmcoiEllWZImIiIjIVBaRyLIiS0RERESmsohElhVZIiIiIjKVRSSyrMgSERERkaksIpFlRZaIiIiITGURiSwrskRERERkKotIZFmRJSIiIiJTWUQiy4osEREREZnKIhJZVmSJiIiIyFQWkciyIktEREREprKIRJYVWSIiIiIylUUksqzIEhEREZGpLCKRZUWWiIiIiExlEYksK7JEREREZCqLSGRZkSUiIiIiU1lEIsuKLBERERGZyiISWVZkiYiIiMhUFpHIsiJLRERERKayiESWFVkiIiIiMpVFJLKsyBIRERGRqSwikU2696hItyMiIiIi62cRiezj9Azztnti3nZEREREZP0sIpFVicrcLZ9pHERERERkPSwikdXYmheG1sztiIiIiMj6WUQm6O1iX6TbEREREZH1s4hElqffIiIiIiJTWUQiy9NvEREREZGpLCKRZUWWiIiIiExlEYksK7JEREREZCqLSGRZkSUiIiIiU1lEIsuKLBERERGZyiISWVZkiYiIiMhUFpHIsiJLRERERKayiESWFVkiIiIiMpVFJLKsyBIRERGRqSwikWVFloiIiIhMZRGJLCuyRERERGQqi0hkWZElIiIiIlNZRCLLiiwRERERmcoiEllWZImIiIjIVBaRyLIiS0RERESmsohElhVZIiIiIjKVRSSyrMgSERERkaksIpFlRZaIiIiITGURiSwrskRERERkKotIZFmRJSIiIiJTWUQiy4osEREREZnKIhJZVmSJiIiIyFQWkciyIktEREREprKIRJYVWSIiIiIylUUksqzIEhEREZGpLCKRZUWWiIiIiExlEYksK7JEREREZCqLSGRZkSUiIiIiU1lEIsuKLBERERGZyiISWVZkiYiIiMhUFpHIsiJLRERERKayiESWFVkiIiIiMpVFJLKs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",
      "text/plain": [
       "<Figure size 700x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "Text(0.5, 0, 'Offset from 0.0001000100')"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAh8AAAGwCAYAAAAJ/wd3AAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQAAKP9JREFUeJzt3X9YlHW+//EXP5wBFQZBAU3wR5aghqklYVlpKHq5phuWdXnKNY+11yFTqVbdXXV3SzHrqGVq1mXYns0sTydb++GeDiZaqSliaSpp+YNVQVMBxUSFz/eP1vk6geYgfoax5+O65rriM/fc95tbg6fD3EOAMcYIAADAkkBfDwAAAH5ZiA8AAGAV8QEAAKwiPgAAgFXEBwAAsIr4AAAAVhEfAADAqmBfD/BTVVVVOnDggMLCwhQQEODrcQAAwCUwxuj48eNq0aKFAgMv/txGvYuPAwcOKC4uztdjAACAWigsLFTLli0vuk29i4+wsDBJPw4fHh7u42kAAMClKCsrU1xcnPv7+MXUu/g496OW8PBw4gMAAD9zKS+Z4AWnAADAKuIDAABYRXwAAACriA8AAGCVV/Hxpz/9SQEBAR63hIQE9/2nTp1SRkaGoqKi1LhxY6Wnp6u4uLjOhwYAAP7L62c+OnbsqIMHD7pvn376qfu+cePGafny5Vq6dKlyc3N14MAB3XPPPXU6MAAA8G9eX2obHBys2NjYauulpaVauHChFi9erN69e0uSsrOzlZiYqHXr1umWW265/GkBAIDf8/qZj507d6pFixZq27athg0bpn379kmS8vLydObMGaWmprq3TUhIUHx8vNauXXvB/VVUVKisrMzjBgAArl5exUdycrIWLVqkFStWaP78+dq9e7d69uyp48ePq6ioSA6HQxERER6PiYmJUVFR0QX3mZWVJZfL5b7x1uoAAFzdvPqxS//+/d3/nZSUpOTkZLVq1Upvv/22QkNDazXAxIkTlZmZ6f743NuzAgCAq9NlXWobERGh66+/Xrt27VJsbKxOnz6tkpISj22Ki4trfI3IOU6n0/1W6rylOgAAV7/Lio8TJ07o22+/VfPmzdWtWzc1aNBAOTk57vsLCgq0b98+paSkXPagAADg6uDVj12efPJJDRw4UK1atdKBAwc0ZcoUBQUF6YEHHpDL5dLIkSOVmZmpyMhIhYeHa/To0UpJSeFKFwAA4OZVfPzzn//UAw88oCNHjqhZs2a67bbbtG7dOjVr1kySNGvWLAUGBio9PV0VFRVKS0vTvHnzrsjgAADAPwUYY4yvhzhfWVmZXC6XSktLef0HAAB+wpvv316/yZi/az3hA1+P4Hf2TB/g6xEAAFcRfrEcAACwivgAAABWER8AAMAq4gMAAFhFfAAAAKuIDwAAYBXxAQAArCI+AACAVcQHAACwivgAAABWER8AAMAq4gMAAFhFfAAAAKuIDwAAYBXxAQAArCI+AACAVcQHAACwivgAAABWER8AAMAq4gMAAFhFfAAAAKuIDwAAYBXxAQAArCI+AACAVcQHAACwivgAAABWER8AAMAq4gMAAFhFfAAAAKuIDwAAYBXxAQAArCI+AACAVcQHAACwivgAAABWER8AAMAq4gMAAFhFfAAAAKuIDwAAYBXxAQAArCI+AACAVcQHAACwivgAAABWER8AAMAq4gMAAFhFfAAAAKuIDwAAYBXxAQAArCI+AACAVcQHAACwivgAAABWER8AAMAq4gMAAFhFfAAAAKuIDwAAYBXxAQAArCI+AACAVcQHAACwivgAAABWER8AAMAq4gMAAFh1WfExffp0BQQEaOzYse61U6dOKSMjQ1FRUWrcuLHS09NVXFx8uXMCAICrRK3jY8OGDVqwYIGSkpI81seNG6fly5dr6dKlys3N1YEDB3TPPfdc9qAAAODqUKv4OHHihIYNG6ZXX31VTZo0ca+XlpZq4cKFmjlzpnr37q1u3bopOztbn3/+udatW1fjvioqKlRWVuZxAwAAV69axUdGRoYGDBig1NRUj/W8vDydOXPGYz0hIUHx8fFau3ZtjfvKysqSy+Vy3+Li4mozEgAA8BNex8eSJUu0adMmZWVlVbuvqKhIDodDERERHusxMTEqKiqqcX8TJ05UaWmp+1ZYWOjtSAAAwI8Ee7NxYWGhxowZo48//lghISF1MoDT6ZTT6ayTfQEAgPrPq2c+8vLydOjQIXXt2lXBwcEKDg5Wbm6uXnzxRQUHBysmJkanT59WSUmJx+OKi4sVGxtbl3MDAAA/5dUzH3fddZe2bNnisTZixAglJCRo/PjxiouLU4MGDZSTk6P09HRJUkFBgfbt26eUlJS6mxoAAPgtr+IjLCxMnTp18lhr1KiRoqKi3OsjR45UZmamIiMjFR4ertGjRyslJUW33HJL3U0NAAD8llfxcSlmzZqlwMBApaenq6KiQmlpaZo3b15dHwYAAPipAGOM8fUQ5ysrK5PL5VJpaanCw8PrfP+tJ3xQ5/u82u2ZPsDXIwAA6jlvvn/zu10AAIBVxAcAALCK+AAAAFYRHwAAwCriAwAAWEV8AAAAq4gPAABgFfEBAACsIj4AAIBVxAcAALCK+AAAAFYRHwAAwCriAwAAWEV8AAAAq4gPAABgFfEBAACsIj4AAIBVxAcAALCK+AAAAFYRHwAAwCriAwAAWEV8AAAAq4gPAABgFfEBAACsIj4AAIBVxAcAALCK+AAAAFYRHwAAwCriAwAAWEV8AAAAq4gPAABgFfEBAACsIj4AAIBVxAcAALCK+AAAAFYRHwAAwCriAwAAWEV8AAAAq4gPAABgFfEBAACsIj4AAIBVxAcAALCK+AAAAFYRHwAAwCriAwAAWEV8AAAAq4gPAABgFfEBAACsIj4AAIBVxAcAALCK+AAAAFYRHwAAwCriAwAAWEV8AAAAq4gPAABgFfEBAACsIj4AAIBVxAcAALCK+AAAAFYRHwAAwCriAwAAWOVVfMyfP19JSUkKDw9XeHi4UlJS9NFHH7nvP3XqlDIyMhQVFaXGjRsrPT1dxcXFdT40AADwX17FR8uWLTV9+nTl5eVp48aN6t27twYNGqSvv/5akjRu3DgtX75cS5cuVW5urg4cOKB77rnnigwOAAD8U4AxxlzODiIjI/Xcc89pyJAhatasmRYvXqwhQ4ZIknbs2KHExEStXbtWt9xyS42Pr6ioUEVFhfvjsrIyxcXFqbS0VOHh4ZczWo1aT/igzvd5tdszfYCvRwAA1HNlZWVyuVyX9P271q/5qKys1JIlS1ReXq6UlBTl5eXpzJkzSk1NdW+TkJCg+Ph4rV279oL7ycrKksvlct/i4uJqOxIAAPADXsfHli1b1LhxYzmdTv32t7/Vu+++qw4dOqioqEgOh0MREREe28fExKioqOiC+5s4caJKS0vdt8LCQq8/CQAA4D+CvX1A+/bttXnzZpWWluq///u/NXz4cOXm5tZ6AKfTKafTWevHAwAA/+J1fDgcDrVr106S1K1bN23YsEEvvPCChg4dqtOnT6ukpMTj2Y/i4mLFxsbW2cAAAMC/Xfb7fFRVVamiokLdunVTgwYNlJOT476voKBA+/btU0pKyuUeBgAAXCW8euZj4sSJ6t+/v+Lj43X8+HEtXrxYq1at0j/+8Q+5XC6NHDlSmZmZioyMVHh4uEaPHq2UlJQLXukCAAB+ebyKj0OHDumhhx7SwYMH5XK5lJSUpH/84x/q06ePJGnWrFkKDAxUenq6KioqlJaWpnnz5l2RwQEAgH+67Pf5qGveXCdcG7zPh/d4nw8AwM+x8j4fAAAAtUF8AAAAq4gPAABgFfEBAACsIj4AAIBVxAcAALCK+AAAAFYRHwAAwCriAwAAWEV8AAAAq4gPAABgFfEBAACsIj4AAIBVxAcAALCK+AAAAFYRHwAAwCriAwAAWEV8AAAAq4gPAABgFfEBAACsIj4AAIBVxAcAALCK+AAAAFYRHwAAwCriAwAAWEV8AAAAq4gPAABgFfEBAACsIj4AAIBVxAcAALCK+AAAAFYRHwAAwCriAwAAWEV8AAAAq4gPAABgFfEBAACsIj4AAIBVxAcAALCK+AAAAFYRHwAAwCriAwAAWEV8AAAAq4gPAABgFfEBAACsIj4AAIBVxAcAALCK+AAAAFYRHwAAwCriAwAAWEV8AAAAq4gPAABgFfEBAACsIj4AAIBVxAcAALCK+AAAAFYRHwAAwCriAwAAWEV8AAAAq4gPAABgFfEBAACs8io+srKydPPNNyssLEzR0dEaPHiwCgoKPLY5deqUMjIyFBUVpcaNGys9PV3FxcV1OjQAAPBfXsVHbm6uMjIytG7dOn388cc6c+aM+vbtq/Lycvc248aN0/Lly7V06VLl5ubqwIEDuueee+p8cAAA4J+Cvdl4xYoVHh8vWrRI0dHRysvL0+23367S0lItXLhQixcvVu/evSVJ2dnZSkxM1Lp163TLLbfU3eQAAMAvXdZrPkpLSyVJkZGRkqS8vDydOXNGqamp7m0SEhIUHx+vtWvX1riPiooKlZWVedwAAMDVq9bxUVVVpbFjx+rWW29Vp06dJElFRUVyOByKiIjw2DYmJkZFRUU17icrK0sul8t9i4uLq+1IAADAD9Q6PjIyMrR161YtWbLksgaYOHGiSktL3bfCwsLL2h8AAKjfvHrNxzmPPfaY3n//fa1evVotW7Z0r8fGxur06dMqKSnxePajuLhYsbGxNe7L6XTK6XTWZgwAAOCHvHrmwxijxx57TO+++65WrlypNm3aeNzfrVs3NWjQQDk5Oe61goIC7du3TykpKXUzMQAA8GtePfORkZGhxYsX67333lNYWJj7dRwul0uhoaFyuVwaOXKkMjMzFRkZqfDwcI0ePVopKSlc6QIAACR5GR/z58+XJN15550e69nZ2frNb34jSZo1a5YCAwOVnp6uiooKpaWlad68eXUyLAAA8H9exYcx5me3CQkJ0dy5czV37txaDwUAAK5e/G4XAABgFfEBAACsIj4AAIBVxAcAALCK+AAAAFYRHwAAwCriAwAAWEV8AAAAq4gPAABgFfEBAACsIj4AAIBVxAcAALCK+AAAAFYRHwAAwCriAwAAWEV8AAAAq4gPAABgFfEBAACsIj4AAIBVxAcAALCK+AAAAFYRHwAAwCriAwAAWEV8AAAAq4gPAABgFfEBAACsIj4AAIBVxAcAALCK+AAAAFYRHwAAwCriAwAAWEV8AAAAq4gPAABgFfEBAACsIj4AAIBVxAcAALCK+AAAAFYRHwAAwCriAwAAWEV8AAAAq4gPAABgFfEBAACsIj4AAIBVxAcAALCK+AAAAFYRHwAAwCriAwAAWEV8AAAAq4gPAABgFfEBAACsIj4AAIBVxAcAALCK+AAAAFYRHwAAwCriAwAAWEV8AAAAq4gPAABgFfEBAACsIj4AAIBVxAcAALCK+AAAAFZ5HR+rV6/WwIED1aJFCwUEBGjZsmUe9xtjNHnyZDVv3lyhoaFKTU3Vzp0762peAADg57yOj/LycnXu3Flz586t8f4ZM2boxRdf1Msvv6z169erUaNGSktL06lTpy57WAAA4P+CvX1A//791b9//xrvM8Zo9uzZ+uMf/6hBgwZJkv76178qJiZGy5Yt0/3333950wIAAL9Xp6/52L17t4qKipSamupec7lcSk5O1tq1a2t8TEVFhcrKyjxuAADg6lWn8VFUVCRJiomJ8ViPiYlx3/dTWVlZcrlc7ltcXFxdjgQAAOoZn1/tMnHiRJWWlrpvhYWFvh4JAABcQXUaH7GxsZKk4uJij/Xi4mL3fT/ldDoVHh7ucQMAAFevOo2PNm3aKDY2Vjk5Oe61srIyrV+/XikpKXV5KAAA4Ke8vtrlxIkT2rVrl/vj3bt3a/PmzYqMjFR8fLzGjh2rZ555Rtddd53atGmjSZMmqUWLFho8eHBdzg0AAPyU1/GxceNG9erVy/1xZmamJGn48OFatGiRfve736m8vFyPPPKISkpKdNttt2nFihUKCQmpu6kBAIDfCjDGGF8Pcb6ysjK5XC6VlpZekdd/tJ7wQZ3v82q3Z/oAX48AAKjnvPn+7fOrXQAAwC8L8QEAAKwiPgAAgFXEBwAAsIr4AAAAVhEfAADAKuIDAABYRXwAAACriA8AAGAV8QEAAKwiPgAAgFXEBwAAsIr4AAAAVhEfAADAKuIDAABYRXwAAACriA8AAGAV8QEAAKwiPgAAgFXEBwAAsIr4AAAAVhEfAADAKuIDAABYRXwAAACriA8AAGAV8QEAAKwiPgAAgFXEBwAAsIr4AAAAVhEfAADAKuIDAABYRXwAAACriA8AAGAV8QEAAKwiPgAAgFXEBwAAsIr4AAAAVhEfAADAKuIDAABYRXwAAACriA8AAGAV8QEAAKwiPgAAgFXEBwAAsIr4AAAAVhEfAADAKuIDAABYRXwAAACriA8AAGAV8QEAAKwiPgAAgFXEBwAAsIr4AAAAVhEfAADAKuIDAABYRXwAAACriA8AAGAV8QEAAKwK9vUAAABcjtYTPvD1CH5nz/QBPj0+z3wAAACriA8AAGDVFYuPuXPnqnXr1goJCVFycrK++OKLK3UoAADgR65IfLz11lvKzMzUlClTtGnTJnXu3FlpaWk6dOjQlTgcAADwI1ckPmbOnKlRo0ZpxIgR6tChg15++WU1bNhQr7322pU4HAAA8CN1frXL6dOnlZeXp4kTJ7rXAgMDlZqaqrVr11bbvqKiQhUVFe6PS0tLJUllZWV1PZokqari5BXZ79XsSv1ZAEBd4Ou6967E1/Vz+zTG/Oy2dR4f33//vSorKxUTE+OxHhMTox07dlTbPisrS3/+85+rrcfFxdX1aKgl12xfTwAAqEtX8uv68ePH5XK5LrqNz9/nY+LEicrMzHR/XFVVpaNHjyoqKkoBAQE+nKxmZWVliouLU2FhocLDw309jl/gnHmPc+Y9zlntcN68xzmrmTFGx48fV4sWLX522zqPj6ZNmyooKEjFxcUe68XFxYqNja22vdPplNPp9FiLiIio67HqXHh4OH/pvMQ58x7nzHucs9rhvHmPc1bdzz3jcU6dv+DU4XCoW7duysnJca9VVVUpJydHKSkpdX04AADgZ67Ij10yMzM1fPhw3XTTTerevbtmz56t8vJyjRgx4kocDgAA+JErEh9Dhw7V4cOHNXnyZBUVFenGG2/UihUrqr0I1R85nU5NmTKl2o+KcGGcM+9xzrzHOasdzpv3OGeXL8BcyjUxAAAAdYTf7QIAAKwiPgAAgFXEBwAAsIr4AAAAVhEftbRnzx6NHDlSbdq0UWhoqK699lpNmTJFp0+f9vVo9c7cuXPVunVrhYSEKDk5WV988YWvR6q3srKydPPNNyssLEzR0dEaPHiwCgoKfD2WX5k+fboCAgI0duxYX49Sr+3fv1//9m//pqioKIWGhuqGG27Qxo0bfT1WvVVZWalJkyZ5fM1/+umnL+n3mKA6n7+9ur/asWOHqqqqtGDBArVr105bt27VqFGjVF5erueff97X49Ubb731ljIzM/Xyyy8rOTlZs2fPVlpamgoKChQdHe3r8eqd3NxcZWRk6Oabb9bZs2f1+9//Xn379tW2bdvUqFEjX49X723YsEELFixQUlKSr0ep144dO6Zbb71VvXr10kcffaRmzZpp586datKkia9Hq7eeffZZzZ8/X6+//ro6duyojRs3asSIEXK5XHr88cd9PZ7f4VLbOvTcc89p/vz5+u6773w9Sr2RnJysm2++WS+99JKkH9/tNi4uTqNHj9aECRN8PF39d/jwYUVHRys3N1e33367r8ep106cOKGuXbtq3rx5euaZZ3TjjTdq9uzZvh6rXpowYYI+++wzrVmzxtej+I1f/epXiomJ0cKFC91r6enpCg0N1d/+9jcfTuaf+LFLHSotLVVkZKSvx6g3Tp8+rby8PKWmprrXAgMDlZqaqrVr1/pwMv9RWloqSfy9ugQZGRkaMGCAx9831Ozvf/+7brrpJt17772Kjo5Wly5d9Oqrr/p6rHqtR48eysnJ0TfffCNJ+vLLL/Xpp5+qf//+Pp7MP/Fjlzqya9cuzZkzhx+5nOf7779XZWVltXe2jYmJ0Y4dO3w0lf+oqqrS2LFjdeutt6pTp06+HqdeW7JkiTZt2qQNGzb4ehS/8N1332n+/PnKzMzU73//e23YsEGPP/64HA6Hhg8f7uvx6qUJEyaorKxMCQkJCgoKUmVlpaZOnaphw4b5ejS/xDMfPzFhwgQFBARc9PbTb5z79+9Xv379dO+992rUqFE+mhxXm4yMDG3dulVLlizx9Sj1WmFhocaMGaM33nhDISEhvh7HL1RVValr166aNm2aunTpokceeUSjRo3Syy+/7OvR6q23335bb7zxhhYvXqxNmzbp9ddf1/PPP6/XX3/d16P5JZ75+IknnnhCv/nNby66Tdu2bd3/feDAAfXq1Us9evTQK6+8coWn8y9NmzZVUFCQiouLPdaLi4sVGxvro6n8w2OPPab3339fq1evVsuWLX09Tr2Wl5enQ4cOqWvXru61yspKrV69Wi+99JIqKioUFBTkwwnrn+bNm6tDhw4ea4mJiXrnnXd8NFH999RTT2nChAm6//77JUk33HCD9u7dq6ysLJ4tqgXi4yeaNWumZs2aXdK2+/fvV69evdStWzdlZ2crMJAnks7ncDjUrVs35eTkaPDgwZJ+/BdXTk6OHnvsMd8OV08ZYzR69Gi9++67WrVqldq0aePrkeq9u+66S1u2bPFYGzFihBISEjR+/HjCowa33nprtUu4v/nmG7Vq1cpHE9V/J0+erPY1PigoSFVVVT6ayL8RH7W0f/9+3XnnnWrVqpWef/55HT582H0f/6r//zIzMzV8+HDddNNN6t69u2bPnq3y8nKNGDHC16PVSxkZGVq8eLHee+89hYWFqaioSJLkcrkUGhrq4+nqp7CwsGqviWnUqJGioqJ4rcwFjBs3Tj169NC0adN033336YsvvtArr7zCs7cXMXDgQE2dOlXx8fHq2LGj8vPzNXPmTD388MO+Hs0/GdRKdna2kVTjDZ7mzJlj4uPjjcPhMN27dzfr1q3z9Uj11oX+TmVnZ/t6NL9yxx13mDFjxvh6jHpt+fLlplOnTsbpdJqEhATzyiuv+Hqkeq2srMyMGTPGxMfHm5CQENO2bVvzhz/8wVRUVPh6NL/E+3wAAACreJECAACwivgAAABWER8AAMAq4gMAAFhFfAAAAKuIDwAAYBXxAQAArCI+AADwU6tXr9bAgQPVokULBQQEaNmyZVf0eJWVlZo0aZLatGmj0NBQXXvttXr66afl7VuGER+Al06ePKn09HSFh4crICBAJSUlNa7ZsmzZMrVr105BQUEaO3asteMC8L3y8nJ17txZc+fOtXK8Z599VvPnz9dLL72k7du369lnn9WMGTM0Z84cr/ZDfAD/UlhYqIcfflgtWrSQw+FQq1atNGbMGB05csRju9dff11r1qzR559/roMHD8rlctW4djlWrVp1yRHz6KOPasiQISosLNTTTz99WcetK6tWrVLXrl3ldDrVrl07LVq06Gcf89VXX6lnz54KCQlRXFycZsyYUW2bpUuXKiEhQSEhIbrhhhv04YcfetxvjNHkyZPVvHlzhYaGKjU1VTt37vTYZurUqerRo4caNmyoiIiIGmfZt2+fBgwYoIYNGyo6OlpPPfWUzp496/XnOHfuXLVu3VohISFKTk7WF1984XH/K6+8ojvvvPOi0Xr06FENGzZM4eHhioiI0MiRI3XixAmvzx2uTv3799czzzyjX//61zXeX1FRoSeffFLXXHONGjVqpOTkZK1atarWx/v88881aNAgDRgwQK1bt9aQIUPUt2/fan+3f5Zv390dqB++/fZbEx0dbW677TazatUqs3fvXvPhhx+ajh07muuuu84cOXLEve0TTzxhbr/9do/H17R2OT755BMjyRw7duyi2x0/ftxIMitXrrzgNmfPnjWVlZV1NtvP+e6770zDhg1NZmam2bZtm5kzZ44JCgoyK1asuOBjSktLTUxMjBk2bJjZunWrefPNN01oaKhZsGCBe5vPPvvMBAUFmRkzZpht27aZP/7xj6ZBgwZmy5Yt7m2mT59uXC6XWbZsmfnyyy/N3Xffbdq0aWN++OEH9zaTJ082M2fONJmZmcblclWb5ezZs6ZTp04mNTXV5Ofnmw8//NA0bdrUTJw40avPccmSJcbhcJjXXnvNfP3112bUqFEmIiLCFBcXu7eZNWuWycrKMllZWRf88+7Xr5/p3LmzWbdunVmzZo1p166deeCBB7w6d/hlkGTeffddj7V///d/Nz169DCrV682u3btMs8995xxOp3mm2++qdUxpk6dalq1amUKCgqMMcZs3rzZREdHm7/97W/ezVqrowNXmX79+pmWLVuakydPeqwfPHjQNGzY0Pz2t781xvz4C8t03i98u+OOO2pcM8aYuXPnmnbt2hmn02mio6NNenq6e7+VlZVm2rRppnXr1iYkJMQkJSWZpUuXGmOM2b17d7VfLDd8+PBqM58LlPNvn3zyicnOzjYul8u89957JjEx0QQFBZndu3ebo0ePmgcffNBERESY0NBQ069fP48vQOcet3z5cnP99deb0NBQk56ebsrLy82iRYtMq1atTEREhBk9erQ5e/bsBc/l7373O9OxY0ePtaFDh5q0tLQLPmbevHmmSZMmHr+ka/z48aZ9+/buj++77z4zYMAAj8clJyebRx991BhjTFVVlYmNjTXPPfec+/6SkhLjdDrNm2++We2Y5z7fn/rwww9NYGCgKSoqcq/Nnz/fhIeHu+e7lM+xe/fuJiMjw/1xZWWladGihcnKyqp2zAvF5rZt24wks2HDBvfaRx99ZAICAsz+/fuNMZd27vDL8NP42Lt3rwkKCnL/XTnnrrvu8ohpb1RWVprx48ebgIAAExwcbAICAsy0adO8n7VWRweuIkeOHLno/0CjRo0yTZo0MVVVVebIkSNm1KhRJiUlxRw8eNAcOXKkxrUNGzaYoKAgs3jxYrNnzx6zadMm88ILL7j3+cwzz5iEhASzYsUK8+2335rs7GzjdDrNqlWrzNmzZ80777xjJJmCggJz8OBBU1JSUm2uiooKU1BQYCSZd955xxw8eNBUVFSY7Oxs06BBA9OjRw/z2WefmR07dpjy8nJz9913m8TERLN69WqzefNmk5aWZtq1a2dOnz5tjDHux/Xp08ds2rTJ5ObmmqioKNO3b19z3333ma+//tosX77cOBwOs2TJkguez549e1b7jbKvvfaaCQ8Pv+BjHnzwQTNo0CCPtZUrVxpJ5ujRo8YYY+Li4sysWbM8tpk8ebJJSkoyxvz47JUkk5+f77HN7bffbh5//PFqx7xQfEyaNMl07tzZY+27774zksymTZsu6XOsqKgwQUFB1f4V+tBDD5m777672jEvFB8LFy40ERERHmtnzpwxQUFB5n/+53+MMZd27vDL8NP4eP/9940k06hRI49bcHCwue+++4wxxmzfvv2Cv0373G38+PHufb755pumZcuW5s033zRfffWV+etf/2oiIyPNokWLvJo12Nuf9wBXm507d8oYo8TExBrvT0xM1LFjx3T48GFFR0erYcOGcjgcio2NdW/z07VVq1apUaNG+tWvfqWwsDC1atVKXbp0kfTjz2CnTZum//u//1NKSookqW3btvr000+1YMEC3XHHHYqMjJQkRUdHX/B1CQ6HQ9HR0ZKkyMhIj3nOnDmjefPmqXPnzu7P8e9//7s+++wz9ejRQ5L0xhtvKC4uTsuWLdO9997rftz8+fN17bXXSpKGDBmi//qv/1JxcbEaN26sDh06qFevXvrkk080dOjQGucqKipSTEyMx1pMTIzKysr0ww8/KDQ0tMbHtGnTptpjzt3XpEmTC+63qKjIvd35j6tpm0txoeOcf4yf+xyPHTumysrK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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "x_eval = np.linspace(-1, 1, 10000)\n",
    "\n",
    "x_point = -0.5\n",
    "\n",
    "\n",
    "idx = np.argmin(np.abs(x_eval - x_point))\n",
    "\n",
    "x0 = x_eval[idx]\n",
    "\n",
    "\n",
    "all_outputs_at_x0 = all_outputs[:, idx, 0]  # shape: (20,)\n",
    "\n",
    "\n",
    "true_value = np.tanh(2 * x0 + 1)  \n",
    "\n",
    "tolerance = 1e-8\n",
    "\n",
    "outputs = np.sort(all_outputs_at_x0)\n",
    "\n",
    "unique_vals = []\n",
    "\n",
    "counts = []\n",
    "\n",
    "group = [outputs[0]]\n",
    "for val in outputs[1:]:\n",
    "    if abs(val - group[-1]) <= tolerance:\n",
    "        group.append(val)\n",
    "    else:\n",
    "        unique_vals.append(np.mean(group))\n",
    "        counts.append(len(group))\n",
    "        group = [val]\n",
    "unique_vals.append(np.mean(group))\n",
    "counts.append(len(group))\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(7,3))\n",
    "ax.bar(unique_vals, counts, width=tolerance*2, color='orange', edgecolor='black', align='center')\n",
    "\n",
    "\n",
    "ax.set_xticks(unique_vals)\n",
    "ax.set_xticklabels([f\"{x:.10f}\" for x in unique_vals])\n",
    "\n",
    "plt.xlabel('Output value')\n",
    "plt.ylabel('Model count')\n",
    "plt.title(f'Unique ensemble outputs at x = {x0}')\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "plt.figure(figsize=(7,2))\n",
    "for idx, (val, cnt) in enumerate(zip(unique_vals, counts)):\n",
    "    plt.scatter([val]*cnt, np.linspace(0, 1, cnt), s=80, label=f'{val:.6f}' if cnt==1 else None)\n",
    "plt.xlabel('Output value (grouped by 1e-8)')\n",
    "plt.yticks([])\n",
    "plt.title(f'Ensemble output grouping at x = {x0}')\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "\n",
    "plt.bar(unique_vals - true_value, counts, width=tolerance*2)\n",
    "plt.xlabel(f'Offset from {true_value:.10f}')\n",
    "\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "python_31015",
   "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.10.15"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
