{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Import Libraries"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "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",
    "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",
    "    #print(f\"Sqrt diffusion matrix computed. Shape: {V_diff.shape}\")\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",
    "\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": "fcb2f8e0",
   "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",
    "    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",
      "\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.01\n",
      "Critical step size eta**=0.050246720590883524\n",
      "\n",
      "\n",
      "The step size eta=0.01 lies within the stable region for gradient descent.\n",
      "Covariance matrix F-norm at global min with eta=0.01: 1.742416e-15\n",
      "\n",
      "\n",
      "Main Iteration:0\n",
      "Initial network parameters by neuron:\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.0000000083\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.0000000030\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.0000000013\n",
      "Neuron 6: weight=-0.1687933505, bias=0.0193619207, out_weight=-0.0000000064\n",
      "Neuron 7: weight=-1.3391933441, bias=1.9213265181, out_weight=-0.0000000042\n",
      "Neuron 8: weight=-0.9603151083, bias=1.5592291355, out_weight=0.0000000034\n",
      "Neuron 9: weight=1.7129454613, bias=0.3680042028, out_weight=-0.0000000000\n",
      "Initial covariance matrix F-norm: 1.108029e-15\n",
      "Step 00000 | Loss: 4.914819e-14\n",
      "Step 01000 | Loss: 9.661369e-14\n",
      "Step 02000 | Loss: 1.145542e-13\n",
      "Step 03000 | Loss: 6.522734e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000461\n",
      "Neuron 2: weight=-0.0621909387, bias=-0.3424026072, out_weight=-0.0000000368\n",
      "Neuron 3: weight=-0.2561483979, bias=-1.4075105190, out_weight=-0.0000000991\n",
      "Neuron 4: weight=-0.6494032741, bias=-1.0068430901, out_weight=0.0000001132\n",
      "Neuron 5: weight=1.6913574934, bias=0.2085422277, out_weight=0.0000000397\n",
      "Neuron 6: weight=-0.1687933505, bias=0.0193619207, out_weight=0.0000000164\n",
      "Neuron 7: weight=-1.3391933441, bias=1.9213265181, out_weight=-0.0000000084\n",
      "Neuron 8: weight=-0.9603151083, bias=1.5592291355, out_weight=0.0000000291\n",
      "Neuron 9: weight=1.7129454613, bias=0.3680042028, out_weight=-0.0000000321\n",
      "Final covariance matrix F-norm: 1.147346e-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.0000000092\n",
      "Neuron 2: weight=-0.3694997132, bias=-0.6338381171, out_weight=0.0000000003\n",
      "Neuron 3: weight=-1.7657381296, bias=0.5827450156, out_weight=0.0000000051\n",
      "Neuron 4: weight=0.2658398151, bias=-0.8018705249, out_weight=0.0000000001\n",
      "Neuron 5: weight=-0.3311361074, bias=-0.7463126779, out_weight=0.0000000090\n",
      "Neuron 6: weight=0.5414656401, bias=1.0347417593, out_weight=0.0000000212\n",
      "Neuron 7: weight=0.6948882341, bias=-0.5543017983, out_weight=-0.0000000157\n",
      "Neuron 8: weight=-0.6482290626, bias=0.1411211342, out_weight=0.0000000035\n",
      "Neuron 9: weight=-0.9730006456, bias=-0.1752773225, out_weight=-0.0000000001\n",
      "Initial covariance matrix F-norm: 9.294217e-16\n",
      "Step 00000 | Loss: 4.058559e-14\n",
      "Step 01000 | Loss: 5.036249e-14\n",
      "Step 02000 | Loss: 3.524438e-14\n",
      "Step 03000 | Loss: 5.237998e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000636\n",
      "Neuron 2: weight=-0.3694997132, bias=-0.6338381171, out_weight=0.0000000231\n",
      "Neuron 3: weight=-1.7657381296, bias=0.5827450156, out_weight=-0.0000000223\n",
      "Neuron 4: weight=0.2658398151, bias=-0.8018705249, out_weight=-0.0000000672\n",
      "Neuron 5: weight=-0.3311361074, bias=-0.7463126779, out_weight=0.0000000014\n",
      "Neuron 6: weight=0.5414656401, bias=1.0347417593, out_weight=-0.0000000519\n",
      "Neuron 7: weight=0.6948882341, bias=-0.5543017983, out_weight=0.0000000883\n",
      "Neuron 8: weight=-0.6482290626, bias=0.1411211342, out_weight=-0.0000000129\n",
      "Neuron 9: weight=-0.9730006456, bias=-0.1752773225, out_weight=0.0000000446\n",
      "Final covariance matrix F-norm: 9.386667e-16\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.0000000093\n",
      "Neuron 2: weight=0.5718181729, bias=0.0834709927, out_weight=-0.0000000001\n",
      "Neuron 3: weight=0.5893953443, bias=0.0180278942, out_weight=0.0000000026\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.0000000025\n",
      "Neuron 6: weight=0.6063237190, bias=0.6424314976, out_weight=0.0000000411\n",
      "Neuron 7: weight=-1.0342558622, bias=0.8899900913, out_weight=-0.0000000029\n",
      "Neuron 8: weight=0.5851250887, bias=0.4584318995, out_weight=0.0000000015\n",
      "Neuron 9: weight=1.9918416739, bias=0.1775036752, out_weight=0.0000000000\n",
      "Initial covariance matrix F-norm: 1.192203e-15\n",
      "Step 00000 | Loss: 8.167425e-14\n",
      "Step 01000 | Loss: 8.401613e-14\n",
      "Step 02000 | Loss: 8.888897e-14\n",
      "Step 03000 | Loss: 4.489464e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000319\n",
      "Neuron 2: weight=0.5718181729, bias=0.0834709927, out_weight=0.0000000303\n",
      "Neuron 3: weight=0.5893953443, bias=0.0180278942, out_weight=0.0000000462\n",
      "Neuron 4: weight=-1.7301383018, bias=-0.5449380875, out_weight=-0.0000000242\n",
      "Neuron 5: weight=-0.1222872883, bias=-0.9760639071, out_weight=-0.0000000321\n",
      "Neuron 6: weight=0.6063237190, bias=0.6424314976, out_weight=-0.0000000303\n",
      "Neuron 7: weight=-1.0342558622, bias=0.8899900913, out_weight=-0.0000000511\n",
      "Neuron 8: weight=0.5851250887, bias=0.4584318995, out_weight=-0.0000000342\n",
      "Neuron 9: weight=1.9918416739, bias=0.1775036752, out_weight=-0.0000000049\n",
      "Final covariance matrix F-norm: 1.204041e-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.0000000024\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.0000000002\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.0000000001\n",
      "Neuron 6: weight=0.3116843700, bias=-0.2769274414, out_weight=0.0000000139\n",
      "Neuron 7: weight=-0.5481189489, bias=-1.8920499086, out_weight=-0.0000000110\n",
      "Neuron 8: weight=-1.1748374701, bias=-0.3524604142, out_weight=0.0000000018\n",
      "Neuron 9: weight=-0.4126217663, bias=0.3103223145, out_weight=-0.0000000000\n",
      "Initial covariance matrix F-norm: 9.415743e-16\n",
      "Step 00000 | Loss: 9.247637e-14\n",
      "Step 01000 | Loss: 1.033479e-13\n",
      "Step 02000 | Loss: 6.067369e-14\n",
      "Step 03000 | Loss: 5.155945e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000507\n",
      "Neuron 2: weight=-0.0789611414, bias=-0.0411498882, out_weight=0.0000000105\n",
      "Neuron 3: weight=0.7901890874, bias=-0.5223459601, out_weight=0.0000001226\n",
      "Neuron 4: weight=1.8723473549, bias=-1.5032391548, out_weight=-0.0000000213\n",
      "Neuron 5: weight=0.2011351138, bias=0.4927207530, out_weight=-0.0000000180\n",
      "Neuron 6: weight=0.3116843700, bias=-0.2769274414, out_weight=-0.0000000068\n",
      "Neuron 7: weight=-0.5481189489, bias=-1.8920499086, out_weight=-0.0000000017\n",
      "Neuron 8: weight=-1.1748374701, bias=-0.3524604142, out_weight=0.0000000348\n",
      "Neuron 9: weight=-0.4126217663, bias=0.3103223145, out_weight=0.0000000017\n",
      "Final covariance matrix F-norm: 9.497267e-16\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.0000000151\n",
      "Neuron 2: weight=0.9026724696, bias=-1.5861744881, out_weight=0.0000000001\n",
      "Neuron 3: weight=0.2457197607, bias=0.5430786014, out_weight=0.0000000107\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.0000000086\n",
      "Neuron 6: weight=-0.4031038880, bias=-0.1336037070, out_weight=0.0000000019\n",
      "Neuron 7: weight=-1.7113126516, bias=1.0055249929, out_weight=-0.0000000198\n",
      "Neuron 8: weight=-1.6537710428, bias=0.2850004733, out_weight=0.0000000027\n",
      "Neuron 9: weight=1.8583124876, bias=0.8166379929, out_weight=-0.0000000001\n",
      "Initial covariance matrix F-norm: 1.803990e-15\n",
      "Step 00000 | Loss: 5.640974e-14\n",
      "Step 01000 | Loss: 4.952982e-14\n",
      "Step 02000 | Loss: 9.419548e-14\n",
      "Step 03000 | Loss: 7.011752e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000111\n",
      "Neuron 2: weight=0.9026724696, bias=-1.5861744881, out_weight=0.0000000295\n",
      "Neuron 3: weight=0.2457197607, bias=0.5430786014, out_weight=0.0000000367\n",
      "Neuron 4: weight=0.0462368056, bias=-0.0056350464, out_weight=-0.0000000135\n",
      "Neuron 5: weight=1.3735525608, bias=0.4771502912, out_weight=-0.0000000968\n",
      "Neuron 6: weight=-0.4031038880, bias=-0.1336037070, out_weight=0.0000000914\n",
      "Neuron 7: weight=-1.7113126516, bias=1.0055249929, out_weight=-0.0000000065\n",
      "Neuron 8: weight=-1.6537710428, bias=0.2850004733, out_weight=-0.0000000313\n",
      "Neuron 9: weight=1.8583124876, bias=0.8166379929, out_weight=0.0000000734\n",
      "Final covariance matrix F-norm: 1.798412e-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.0000000258\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.0000000123\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.0000000060\n",
      "Neuron 6: weight=0.8837338686, bias=0.0239571631, out_weight=-0.0000000470\n",
      "Neuron 7: weight=0.4019806087, bias=-0.5575602055, out_weight=0.0000000013\n",
      "Neuron 8: weight=-1.7088197470, bias=2.0966291428, out_weight=0.0000000034\n",
      "Neuron 9: weight=-1.8416970968, bias=1.1421524286, out_weight=0.0000000001\n",
      "Initial covariance matrix F-norm: 9.959264e-16\n",
      "Step 00000 | Loss: 6.710951e-14\n",
      "Step 01000 | Loss: 5.584595e-14\n",
      "Step 02000 | Loss: 8.061087e-14\n",
      "Step 03000 | Loss: 1.005255e-13\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000310\n",
      "Neuron 2: weight=-1.1801158190, bias=-0.3917222917, out_weight=-0.0000000336\n",
      "Neuron 3: weight=0.1552209258, bias=0.0860372335, out_weight=-0.0000000461\n",
      "Neuron 4: weight=0.8109305501, bias=0.1679715961, out_weight=-0.0000000083\n",
      "Neuron 5: weight=0.3097223639, bias=0.0269418545, out_weight=-0.0000000661\n",
      "Neuron 6: weight=0.8837338686, bias=0.0239571631, out_weight=0.0000000306\n",
      "Neuron 7: weight=0.4019806087, bias=-0.5575602055, out_weight=-0.0000000216\n",
      "Neuron 8: weight=-1.7088197470, bias=2.0966291428, out_weight=-0.0000000259\n",
      "Neuron 9: weight=-1.8416970968, bias=1.1421524286, out_weight=-0.0000000193\n",
      "Final covariance matrix F-norm: 1.000881e-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.0000000370\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.0000000164\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.0000000098\n",
      "Neuron 6: weight=0.0676440448, bias=2.4964983463, out_weight=0.0000000646\n",
      "Neuron 7: weight=-0.3256452680, bias=0.3032752275, out_weight=-0.0000000191\n",
      "Neuron 8: weight=-0.5798569322, bias=-0.5950963497, out_weight=-0.0000000031\n",
      "Neuron 9: weight=-1.4991163015, bias=1.4509570599, out_weight=-0.0000000001\n",
      "Initial covariance matrix F-norm: 9.368288e-16\n",
      "Step 00000 | Loss: 7.489148e-14\n",
      "Step 01000 | Loss: 6.822887e-14\n",
      "Step 02000 | Loss: 6.590388e-14\n",
      "Step 03000 | Loss: 5.288825e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000267\n",
      "Neuron 2: weight=-0.0657867417, bias=-1.5288972855, out_weight=-0.0000000080\n",
      "Neuron 3: weight=0.7055556178, bias=-0.3780641854, out_weight=0.0000001076\n",
      "Neuron 4: weight=1.7068165541, bias=-1.0457283258, out_weight=0.0000000079\n",
      "Neuron 5: weight=-0.0020166119, bias=-0.1342581958, out_weight=0.0000000085\n",
      "Neuron 6: weight=0.0676440448, bias=2.4964983463, out_weight=0.0000000754\n",
      "Neuron 7: weight=-0.3256452680, bias=0.3032752275, out_weight=-0.0000000260\n",
      "Neuron 8: weight=-0.5798569322, bias=-0.5950963497, out_weight=0.0000001291\n",
      "Neuron 9: weight=-1.4991163015, bias=1.4509570599, out_weight=0.0000000182\n",
      "Final covariance matrix F-norm: 9.503783e-16\n",
      "\n",
      "\n",
      "Main Iteration:7\n",
      "Initial network parameters by neuron:\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.0000000232\n",
      "Neuron 2: weight=-0.3568039536, bias=-1.0599335432, out_weight=-0.0000000003\n",
      "Neuron 3: weight=-0.3741112649, bias=-0.9955452085, out_weight=-0.0000000111\n",
      "Neuron 4: weight=-0.0893282592, bias=-0.5675718784, out_weight=-0.0000000001\n",
      "Neuron 5: weight=0.6761741042, bias=1.6028903723, out_weight=-0.0000000091\n",
      "Neuron 6: weight=-0.3069067895, bias=-0.7243453264, out_weight=-0.0000000506\n",
      "Neuron 7: weight=0.3184945583, bias=0.1797552109, out_weight=0.0000000317\n",
      "Neuron 8: weight=1.5170882940, bias=-1.2913388014, out_weight=-0.0000000039\n",
      "Neuron 9: weight=-1.0880161524, bias=0.5342912674, out_weight=0.0000000001\n",
      "Initial covariance matrix F-norm: 8.762159e-16\n",
      "Step 00000 | Loss: 5.262284e-14\n",
      "Step 01000 | Loss: 1.104897e-13\n",
      "Step 02000 | Loss: 6.362272e-14\n",
      "Step 03000 | Loss: 7.325043e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000781\n",
      "Neuron 2: weight=-0.3568039536, bias=-1.0599335432, out_weight=0.0000000068\n",
      "Neuron 3: weight=-0.3741112649, bias=-0.9955452085, out_weight=0.0000000143\n",
      "Neuron 4: weight=-0.0893282592, bias=-0.5675718784, out_weight=-0.0000000431\n",
      "Neuron 5: weight=0.6761741042, bias=1.6028903723, out_weight=-0.0000000818\n",
      "Neuron 6: weight=-0.3069067895, bias=-0.7243453264, out_weight=-0.0000000239\n",
      "Neuron 7: weight=0.3184945583, bias=0.1797552109, out_weight=-0.0000000302\n",
      "Neuron 8: weight=1.5170882940, bias=-1.2913388014, out_weight=0.0000000081\n",
      "Neuron 9: weight=-1.0880161524, bias=0.5342912674, out_weight=-0.0000000407\n",
      "Final covariance matrix F-norm: 8.871736e-16\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.0000000072\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.0000000025\n",
      "Neuron 4: weight=-2.3219459057, bias=-0.6840869188, out_weight=0.0000000000\n",
      "Neuron 5: weight=-1.5240038633, bias=-0.4603850842, out_weight=0.0000000039\n",
      "Neuron 6: weight=-2.4191398621, bias=-1.2212493420, out_weight=0.0000000131\n",
      "Neuron 7: weight=0.2703894079, bias=-0.0624746196, out_weight=-0.0000000088\n",
      "Neuron 8: weight=1.5007317066, bias=1.3604815006, out_weight=-0.0000000007\n",
      "Neuron 9: weight=-0.3407146335, bias=1.3656281233, out_weight=-0.0000000000\n",
      "Initial covariance matrix F-norm: 2.008825e-15\n",
      "Step 00000 | Loss: 6.409456e-14\n",
      "Step 01000 | Loss: 5.181619e-14\n",
      "Step 02000 | Loss: 9.468121e-14\n",
      "Step 03000 | Loss: 8.338295e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000287\n",
      "Neuron 2: weight=-0.4125171602, bias=0.3389493823, out_weight=-0.0000000042\n",
      "Neuron 3: weight=0.8801433444, bias=1.2111874819, out_weight=-0.0000000972\n",
      "Neuron 4: weight=-2.3219459057, bias=-0.6840869188, out_weight=0.0000000311\n",
      "Neuron 5: weight=-1.5240038633, bias=-0.4603850842, out_weight=-0.0000000589\n",
      "Neuron 6: weight=-2.4191398621, bias=-1.2212493420, out_weight=-0.0000000203\n",
      "Neuron 7: weight=0.2703894079, bias=-0.0624746196, out_weight=-0.0000000112\n",
      "Neuron 8: weight=1.5007317066, bias=1.3604815006, out_weight=-0.0000000067\n",
      "Neuron 9: weight=-0.3407146335, bias=1.3656281233, out_weight=0.0000000732\n",
      "Final covariance matrix F-norm: 2.607980e-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.0000000010\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.0000000013\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.0000000033\n",
      "Neuron 6: weight=1.5088987350, bias=-0.7061455250, out_weight=0.0000000093\n",
      "Neuron 7: weight=0.9137540460, bias=0.8804106712, out_weight=-0.0000000101\n",
      "Neuron 8: weight=-0.5868622065, bias=0.4186665118, out_weight=0.0000000054\n",
      "Neuron 9: weight=-1.5044656992, bias=-0.8772856593, out_weight=0.0000000001\n",
      "Initial covariance matrix F-norm: 9.910345e-16\n",
      "Step 00000 | Loss: 6.597674e-14\n",
      "Step 01000 | Loss: 5.073416e-14\n",
      "Step 02000 | Loss: 7.841991e-14\n",
      "Step 03000 | Loss: 6.629419e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000338\n",
      "Neuron 2: weight=0.5403024554, bias=-1.7660541534, out_weight=-0.0000000207\n",
      "Neuron 3: weight=-0.7028779984, bias=0.3054963052, out_weight=-0.0000000155\n",
      "Neuron 4: weight=-0.8143140674, bias=-0.3542229831, out_weight=0.0000000380\n",
      "Neuron 5: weight=0.2747886479, bias=-0.4398599565, out_weight=-0.0000000158\n",
      "Neuron 6: weight=1.5088987350, bias=-0.7061455250, out_weight=0.0000000163\n",
      "Neuron 7: weight=0.9137540460, bias=0.8804106712, out_weight=-0.0000001216\n",
      "Neuron 8: weight=-0.5868622065, bias=0.4186665118, out_weight=-0.0000000125\n",
      "Neuron 9: weight=-1.5044656992, bias=-0.8772856593, out_weight=-0.0000000780\n",
      "Final covariance matrix F-norm: 1.079159e-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.0000000208\n",
      "Neuron 2: weight=0.8389213681, bias=-0.2481373399, out_weight=0.0000000005\n",
      "Neuron 3: weight=0.1069320291, bias=0.6242386699, out_weight=0.0000000132\n",
      "Neuron 4: weight=0.9738952518, bias=0.0298695005, out_weight=0.0000000003\n",
      "Neuron 5: weight=-1.7178994417, bias=-0.3415849507, out_weight=0.0000000136\n",
      "Neuron 6: weight=-0.4046015739, bias=-0.4115113914, out_weight=0.0000000276\n",
      "Neuron 7: weight=1.6323773861, bias=-1.6057101488, out_weight=-0.0000000083\n",
      "Neuron 8: weight=-0.2038651854, bias=-0.7589679956, out_weight=-0.0000000020\n",
      "Neuron 9: weight=1.4892702103, bias=0.6036748886, out_weight=-0.0000000002\n",
      "Initial covariance matrix F-norm: 1.153512e-15\n",
      "Step 00000 | Loss: 6.281781e-14\n",
      "Step 01000 | Loss: 7.983544e-14\n",
      "Step 02000 | Loss: 7.685172e-14\n",
      "Step 03000 | Loss: 6.230259e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000001150\n",
      "Neuron 2: weight=0.8389213681, bias=-0.2481373399, out_weight=0.0000000455\n",
      "Neuron 3: weight=0.1069320291, bias=0.6242386699, out_weight=0.0000000790\n",
      "Neuron 4: weight=0.9738952518, bias=0.0298695005, out_weight=0.0000000606\n",
      "Neuron 5: weight=-1.7178994417, bias=-0.3415849507, out_weight=0.0000000784\n",
      "Neuron 6: weight=-0.4046015739, bias=-0.4115113914, out_weight=0.0000000269\n",
      "Neuron 7: weight=1.6323773861, bias=-1.6057101488, out_weight=-0.0000000081\n",
      "Neuron 8: weight=-0.2038651854, bias=-0.7589679956, out_weight=-0.0000000640\n",
      "Neuron 9: weight=1.4892702103, bias=0.6036748886, out_weight=0.0000000846\n",
      "Final covariance matrix F-norm: 1.167560e-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.0000000041\n",
      "Neuron 2: weight=-1.3578414917, bias=1.1320396662, out_weight=-0.0000000001\n",
      "Neuron 3: weight=-0.8376572728, bias=-1.6715322733, out_weight=-0.0000000017\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.0000000022\n",
      "Neuron 6: weight=-1.4365832806, bias=-0.3663595915, out_weight=0.0000000254\n",
      "Neuron 7: weight=1.5840369463, bias=-0.3911296427, out_weight=0.0000000009\n",
      "Neuron 8: weight=1.0157834291, bias=0.0854762867, out_weight=-0.0000000005\n",
      "Neuron 9: weight=-0.6013790965, bias=-1.1343820095, out_weight=0.0000000001\n",
      "Initial covariance matrix F-norm: 1.086116e-15\n",
      "Step 00000 | Loss: 5.363288e-14\n",
      "Step 01000 | Loss: 5.208681e-14\n",
      "Step 02000 | Loss: 5.823120e-14\n",
      "Step 03000 | Loss: 7.267104e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000287\n",
      "Neuron 3: weight=-0.8376572728, bias=-1.6715322733, out_weight=0.0000000115\n",
      "Neuron 4: weight=1.1852490902, bias=-0.5340163112, out_weight=-0.0000000377\n",
      "Neuron 5: weight=-1.4600281715, bias=-0.9245674610, out_weight=-0.0000000072\n",
      "Neuron 6: weight=-1.4365832806, bias=-0.3663595915, out_weight=0.0000000097\n",
      "Neuron 7: weight=1.5840369463, bias=-0.3911296427, out_weight=0.0000000413\n",
      "Neuron 8: weight=1.0157834291, bias=0.0854762867, out_weight=-0.0000000206\n",
      "Neuron 9: weight=-0.6013790965, bias=-1.1343820095, out_weight=0.0000000016\n",
      "Final covariance matrix F-norm: 1.088455e-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.0000000082\n",
      "Neuron 2: weight=-1.4087707996, bias=-1.3118515015, out_weight=-0.0000000003\n",
      "Neuron 3: weight=-1.0216101408, bias=1.1189684868, out_weight=-0.0000000058\n",
      "Neuron 4: weight=0.5653166771, bias=1.8292890787, out_weight=-0.0000000001\n",
      "Neuron 5: weight=0.3674516976, bias=-0.4722127020, out_weight=-0.0000000068\n",
      "Neuron 6: weight=0.3752543926, bias=1.9593399763, out_weight=-0.0000000179\n",
      "Neuron 7: weight=-0.7074102759, bias=-0.1843419522, out_weight=-0.0000000032\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.0000000001\n",
      "Initial covariance matrix F-norm: 8.574196e-16\n",
      "Step 00000 | Loss: 5.199313e-14\n",
      "Step 01000 | Loss: 8.383051e-14\n",
      "Step 02000 | Loss: 5.783742e-14\n",
      "Step 03000 | Loss: 1.081652e-13\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000061\n",
      "Neuron 2: weight=-1.4087707996, bias=-1.3118515015, out_weight=0.0000000388\n",
      "Neuron 3: weight=-1.0216101408, bias=1.1189684868, out_weight=-0.0000000414\n",
      "Neuron 4: weight=0.5653166771, bias=1.8292890787, out_weight=0.0000000200\n",
      "Neuron 5: weight=0.3674516976, bias=-0.4722127020, out_weight=-0.0000000037\n",
      "Neuron 6: weight=0.3752543926, bias=1.9593399763, out_weight=0.0000000396\n",
      "Neuron 7: weight=-0.7074102759, bias=-0.1843419522, out_weight=-0.0000000683\n",
      "Neuron 8: weight=0.6285465360, bias=-0.7443274260, out_weight=0.0000000383\n",
      "Neuron 9: weight=-0.3329925239, bias=-0.0442384407, out_weight=-0.0000000079\n",
      "Final covariance matrix F-norm: 8.790169e-16\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.0000000172\n",
      "Neuron 2: weight=-0.7207796574, bias=1.4445667267, out_weight=-0.0000000002\n",
      "Neuron 3: weight=-0.0585907027, bias=0.8539324999, out_weight=-0.0000000079\n",
      "Neuron 4: weight=-0.5830104947, bias=-0.1663232595, out_weight=-0.0000000001\n",
      "Neuron 5: weight=-0.3732480407, bias=0.4447566569, out_weight=-0.0000000045\n",
      "Neuron 6: weight=1.0670239925, bias=-0.9203750491, out_weight=-0.0000000328\n",
      "Neuron 7: weight=0.1421764642, bias=1.0166269541, out_weight=-0.0000000100\n",
      "Neuron 8: weight=0.8137424588, bias=2.5589799881, out_weight=0.0000000069\n",
      "Neuron 9: weight=-1.9114128351, bias=-0.7664008737, out_weight=0.0000000001\n",
      "Initial covariance matrix F-norm: 1.143979e-15\n",
      "Step 00000 | Loss: 5.099393e-14\n",
      "Step 01000 | Loss: 1.086579e-13\n",
      "Step 02000 | Loss: 4.733583e-14\n",
      "Step 03000 | Loss: 6.410497e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000201\n",
      "Neuron 2: weight=-0.7207796574, bias=1.4445667267, out_weight=0.0000000216\n",
      "Neuron 3: weight=-0.0585907027, bias=0.8539324999, out_weight=0.0000000337\n",
      "Neuron 4: weight=-0.5830104947, bias=-0.1663232595, out_weight=0.0000000267\n",
      "Neuron 5: weight=-0.3732480407, bias=0.4447566569, out_weight=0.0000000117\n",
      "Neuron 6: weight=1.0670239925, bias=-0.9203750491, out_weight=0.0000000352\n",
      "Neuron 7: weight=0.1421764642, bias=1.0166269541, out_weight=0.0000000112\n",
      "Neuron 8: weight=0.8137424588, bias=2.5589799881, out_weight=-0.0000000008\n",
      "Neuron 9: weight=-1.9114128351, bias=-0.7664008737, out_weight=-0.0000000177\n",
      "Final covariance matrix F-norm: 1.144722e-15\n",
      "\n",
      "\n",
      "Main Iteration:14\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-2.3853390217, bias=0.2848291099, out_weight=0.0000000169\n",
      "Neuron 2: weight=-2.1278102398, bias=-1.4610561132, out_weight=0.0000000003\n",
      "Neuron 3: weight=-0.2747634947, bias=-0.3308350444, out_weight=0.0000000065\n",
      "Neuron 4: weight=-0.9668187499, bias=2.5014224052, out_weight=0.0000000001\n",
      "Neuron 5: weight=-0.3187283874, bias=-1.0681014061, out_weight=0.0000000091\n",
      "Neuron 6: weight=1.3684610128, bias=0.5661051273, out_weight=0.0000000459\n",
      "Neuron 7: weight=0.1574679315, bias=-0.5453080535, out_weight=-0.0000000481\n",
      "Neuron 8: weight=0.0431605428, bias=-0.2576096058, out_weight=0.0000000073\n",
      "Neuron 9: weight=-0.2985710502, bias=0.5447013378, out_weight=-0.0000000001\n",
      "Initial covariance matrix F-norm: 1.403870e-15\n",
      "Step 00000 | Loss: 8.524084e-14\n",
      "Step 01000 | Loss: 6.975844e-14\n",
      "Step 02000 | Loss: 4.156571e-14\n",
      "Step 03000 | Loss: 7.501985e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-2.3853390217, bias=0.2848291099, out_weight=-0.0000000113\n",
      "Neuron 2: weight=-2.1278102398, bias=-1.4610561132, out_weight=-0.0000000055\n",
      "Neuron 3: weight=-0.2747634947, bias=-0.3308350444, out_weight=0.0000000080\n",
      "Neuron 4: weight=-0.9668187499, bias=2.5014224052, out_weight=-0.0000000004\n",
      "Neuron 5: weight=-0.3187283874, bias=-1.0681014061, out_weight=0.0000000138\n",
      "Neuron 6: weight=1.3684610128, bias=0.5661051273, out_weight=-0.0000000330\n",
      "Neuron 7: weight=0.1574679315, bias=-0.5453080535, out_weight=-0.0000000586\n",
      "Neuron 8: weight=0.0431605428, bias=-0.2576096058, out_weight=-0.0000000099\n",
      "Neuron 9: weight=-0.2985710502, bias=0.5447013378, out_weight=-0.0000000527\n",
      "Final covariance matrix F-norm: 1.387670e-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.0000000027\n",
      "Neuron 2: weight=0.5706607699, bias=-0.3267307580, out_weight=0.0000000002\n",
      "Neuron 3: weight=-0.9411361814, bias=-0.0999625996, out_weight=0.0000000044\n",
      "Neuron 4: weight=-0.6839153767, bias=0.3924555779, out_weight=0.0000000001\n",
      "Neuron 5: weight=-0.9821395278, bias=0.8983654380, out_weight=0.0000000049\n",
      "Neuron 6: weight=-0.3951538801, bias=1.4591628313, out_weight=-0.0000000024\n",
      "Neuron 7: weight=0.5662586093, bias=0.8881697655, out_weight=0.0000000223\n",
      "Neuron 8: weight=-0.7226403356, bias=-0.7965043187, out_weight=-0.0000000045\n",
      "Neuron 9: weight=-0.3839495480, bias=-0.0201015174, out_weight=-0.0000000001\n",
      "Initial covariance matrix F-norm: 8.753087e-16\n",
      "Step 00000 | Loss: 5.926206e-14\n",
      "Step 01000 | Loss: 5.415807e-14\n",
      "Step 02000 | Loss: 5.151532e-14\n",
      "Step 03000 | Loss: 6.565278e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000232\n",
      "Neuron 2: weight=0.5706607699, bias=-0.3267307580, out_weight=0.0000000062\n",
      "Neuron 3: weight=-0.9411361814, bias=-0.0999625996, out_weight=-0.0000000485\n",
      "Neuron 4: weight=-0.6839153767, bias=0.3924555779, out_weight=-0.0000000369\n",
      "Neuron 5: weight=-0.9821395278, bias=0.8983654380, out_weight=-0.0000000362\n",
      "Neuron 6: weight=-0.3951538801, bias=1.4591628313, out_weight=0.0000001071\n",
      "Neuron 7: weight=0.5662586093, bias=0.8881697655, out_weight=-0.0000000346\n",
      "Neuron 8: weight=-0.7226403356, bias=-0.7965043187, out_weight=0.0000000975\n",
      "Neuron 9: weight=-0.3839495480, bias=-0.0201015174, out_weight=0.0000000244\n",
      "Final covariance matrix F-norm: 9.118854e-16\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.0000000129\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.0000000063\n",
      "Neuron 4: weight=-0.6437963843, bias=-1.2505837679, out_weight=0.0000000000\n",
      "Neuron 5: weight=0.0373731405, bias=0.0981042683, out_weight=0.0000000034\n",
      "Neuron 6: weight=-0.3157178760, bias=0.1287074685, out_weight=0.0000000335\n",
      "Neuron 7: weight=2.0318739414, bias=-0.8510330319, out_weight=-0.0000000134\n",
      "Neuron 8: weight=-0.2879932523, bias=0.3213791549, out_weight=0.0000000030\n",
      "Neuron 9: weight=-0.0750081614, bias=-1.7405517101, out_weight=-0.0000000000\n",
      "Initial covariance matrix F-norm: 1.015477e-15\n",
      "Step 00000 | Loss: 1.229572e-13\n",
      "Step 01000 | Loss: 4.203755e-14\n",
      "Step 02000 | Loss: 5.673240e-14\n",
      "Step 03000 | Loss: 6.589000e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000213\n",
      "Neuron 2: weight=-0.8400620818, bias=0.7436569929, out_weight=-0.0000000911\n",
      "Neuron 3: weight=0.0869811997, bias=-1.2755441666, out_weight=-0.0000000485\n",
      "Neuron 4: weight=-0.6437963843, bias=-1.2505837679, out_weight=0.0000001255\n",
      "Neuron 5: weight=0.0373731405, bias=0.0981042683, out_weight=0.0000000072\n",
      "Neuron 6: weight=-0.3157178760, bias=0.1287074685, out_weight=0.0000000430\n",
      "Neuron 7: weight=2.0318739414, bias=-0.8510330319, out_weight=0.0000000143\n",
      "Neuron 8: weight=-0.2879932523, bias=0.3213791549, out_weight=0.0000000071\n",
      "Neuron 9: weight=-0.0750081614, bias=-1.7405517101, out_weight=-0.0000000601\n",
      "Final covariance matrix F-norm: 1.042632e-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.0000000048\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.0000000021\n",
      "Neuron 4: weight=-0.5957212448, bias=0.2081873566, out_weight=-0.0000000000\n",
      "Neuron 5: weight=-0.4703968167, bias=-0.4480045438, out_weight=-0.0000000017\n",
      "Neuron 6: weight=0.4822644591, bias=-0.5822269917, out_weight=0.0000000229\n",
      "Neuron 7: weight=-0.7510466576, bias=0.8432822227, out_weight=-0.0000000064\n",
      "Neuron 8: weight=1.1265586615, bias=-0.5774128437, out_weight=-0.0000000020\n",
      "Neuron 9: weight=1.4950702190, bias=-2.9098989964, out_weight=0.0000000000\n",
      "Initial covariance matrix F-norm: 8.574410e-16\n",
      "Step 00000 | Loss: 5.763445e-14\n",
      "Step 01000 | Loss: 4.831422e-14\n",
      "Step 02000 | Loss: 7.748836e-14\n",
      "Step 03000 | Loss: 5.785823e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000349\n",
      "Neuron 2: weight=-1.1204913855, bias=0.4655200839, out_weight=-0.0000000392\n",
      "Neuron 3: weight=-0.1945876479, bias=0.4577802718, out_weight=0.0000000646\n",
      "Neuron 4: weight=-0.5957212448, bias=0.2081873566, out_weight=0.0000000201\n",
      "Neuron 5: weight=-0.4703968167, bias=-0.4480045438, out_weight=0.0000000739\n",
      "Neuron 6: weight=0.4822644591, bias=-0.5822269917, out_weight=0.0000000070\n",
      "Neuron 7: weight=-0.7510466576, bias=0.8432822227, out_weight=-0.0000000527\n",
      "Neuron 8: weight=1.1265586615, bias=-0.5774128437, out_weight=0.0000000320\n",
      "Neuron 9: weight=1.4950702190, bias=-2.9098989964, out_weight=0.0000000209\n",
      "Final covariance matrix F-norm: 8.726545e-16\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.0000000204\n",
      "Neuron 2: weight=1.4834408760, bias=0.4087717235, out_weight=0.0000000000\n",
      "Neuron 3: weight=-0.5153694749, bias=-0.5181792974, out_weight=0.0000000062\n",
      "Neuron 4: weight=-1.9806180000, bias=0.0600441732, out_weight=0.0000000000\n",
      "Neuron 5: weight=-0.3681578934, bias=0.5785977840, out_weight=0.0000000016\n",
      "Neuron 6: weight=1.1649804115, bias=1.1206753254, out_weight=0.0000000467\n",
      "Neuron 7: weight=0.2922074497, bias=-1.0777339935, out_weight=0.0000000041\n",
      "Neuron 8: weight=0.2534996569, bias=-0.0078668380, out_weight=-0.0000000064\n",
      "Neuron 9: weight=-0.3437344730, bias=-0.5087420940, out_weight=-0.0000000000\n",
      "Initial covariance matrix F-norm: 1.111912e-15\n",
      "Step 00000 | Loss: 1.220708e-13\n",
      "Step 01000 | Loss: 1.169221e-13\n",
      "Step 02000 | Loss: 5.526135e-14\n",
      "Step 03000 | Loss: 6.340067e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000163\n",
      "Neuron 2: weight=1.4834408760, bias=0.4087717235, out_weight=0.0000000174\n",
      "Neuron 3: weight=-0.5153694749, bias=-0.5181792974, out_weight=0.0000000125\n",
      "Neuron 4: weight=-1.9806180000, bias=0.0600441732, out_weight=0.0000000199\n",
      "Neuron 5: weight=-0.3681578934, bias=0.5785977840, out_weight=-0.0000000427\n",
      "Neuron 6: weight=1.1649804115, bias=1.1206753254, out_weight=-0.0000000576\n",
      "Neuron 7: weight=0.2922074497, bias=-1.0777339935, out_weight=-0.0000000362\n",
      "Neuron 8: weight=0.2534996569, bias=-0.0078668380, out_weight=0.0000000244\n",
      "Neuron 9: weight=-0.3437344730, bias=-0.5087420940, out_weight=-0.0000000276\n",
      "Final covariance matrix F-norm: 1.149468e-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.0000000060\n",
      "Neuron 2: weight=0.7733194828, bias=-0.6824126244, out_weight=-0.0000000003\n",
      "Neuron 3: weight=0.7168910503, bias=0.1459788680, out_weight=-0.0000000011\n",
      "Neuron 4: weight=-0.3454068899, bias=-1.3953939676, out_weight=-0.0000000001\n",
      "Neuron 5: weight=-1.4108695984, bias=1.3652865887, out_weight=-0.0000000065\n",
      "Neuron 6: weight=1.8478187323, bias=0.5123600960, out_weight=0.0000000026\n",
      "Neuron 7: weight=0.6495861411, bias=-0.0895664170, out_weight=0.0000000308\n",
      "Neuron 8: weight=0.4945821166, bias=-0.8075665236, out_weight=-0.0000000124\n",
      "Neuron 9: weight=-0.8126527071, bias=0.1896231771, out_weight=0.0000000001\n",
      "Initial covariance matrix F-norm: 1.598543e-15\n",
      "Step 00000 | Loss: 6.935435e-14\n",
      "Step 01000 | Loss: 7.445303e-14\n",
      "Step 02000 | Loss: 9.761983e-14\n",
      "Step 03000 | Loss: 7.252879e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000002389\n",
      "Neuron 2: weight=0.7733194828, bias=-0.6824126244, out_weight=-0.0000001615\n",
      "Neuron 3: weight=0.7168910503, bias=0.1459788680, out_weight=0.0000001561\n",
      "Neuron 4: weight=-0.3454068899, bias=-1.3953939676, out_weight=0.0000001852\n",
      "Neuron 5: weight=-1.4108695984, bias=1.3652865887, out_weight=-0.0000001023\n",
      "Neuron 6: weight=1.8478187323, bias=0.5123600960, out_weight=0.0000000693\n",
      "Neuron 7: weight=0.6495861411, bias=-0.0895664170, out_weight=0.0000000197\n",
      "Neuron 8: weight=0.4945821166, bias=-0.8075665236, out_weight=0.0000000166\n",
      "Neuron 9: weight=-0.8126527071, bias=0.1896231771, out_weight=0.0000002411\n",
      "Final covariance matrix F-norm: 1.449243e-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.0000000019\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.0000000009\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.0000000010\n",
      "Neuron 6: weight=1.1172099113, bias=-0.0206414796, out_weight=0.0000000003\n",
      "Neuron 7: weight=0.6916948557, bias=-0.0982946083, out_weight=-0.0000000005\n",
      "Neuron 8: weight=0.9565225244, bias=-0.5749083161, out_weight=-0.0000000032\n",
      "Neuron 9: weight=2.0265746117, bias=2.0448455811, out_weight=0.0000000000\n",
      "Initial covariance matrix F-norm: 1.174166e-15\n",
      "Step 00000 | Loss: 8.779436e-14\n",
      "Step 01000 | Loss: 3.484019e-14\n",
      "Step 02000 | Loss: 8.058831e-14\n",
      "Step 03000 | Loss: 7.825262e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000302\n",
      "Neuron 2: weight=-0.3469801545, bias=1.0875223875, out_weight=0.0000000149\n",
      "Neuron 3: weight=-1.0937564373, bias=1.4050017595, out_weight=-0.0000000263\n",
      "Neuron 4: weight=-1.6324051619, bias=-0.0746434405, out_weight=0.0000000200\n",
      "Neuron 5: weight=2.1660137177, bias=-0.3529733419, out_weight=0.0000000098\n",
      "Neuron 6: weight=1.1172099113, bias=-0.0206414796, out_weight=0.0000000392\n",
      "Neuron 7: weight=0.6916948557, bias=-0.0982946083, out_weight=0.0000000299\n",
      "Neuron 8: weight=0.9565225244, bias=-0.5749083161, out_weight=-0.0000000287\n",
      "Neuron 9: weight=2.0265746117, bias=2.0448455811, out_weight=-0.0000000264\n",
      "Final covariance matrix F-norm: 1.250050e-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.0000000104\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.0000000031\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.0000000014\n",
      "Neuron 6: weight=-1.1808662415, bias=-0.7949853539, out_weight=-0.0000000188\n",
      "Neuron 7: weight=-0.0998490900, bias=0.0547575951, out_weight=0.0000000061\n",
      "Neuron 8: weight=-0.0627254471, bias=0.8416796923, out_weight=0.0000000030\n",
      "Neuron 9: weight=2.4226486683, bias=-1.2424370050, out_weight=0.0000000000\n",
      "Initial covariance matrix F-norm: 1.406325e-15\n",
      "Step 00000 | Loss: 1.195450e-13\n",
      "Step 01000 | Loss: 5.647219e-14\n",
      "Step 02000 | Loss: 5.003810e-14\n",
      "Step 03000 | Loss: 7.158163e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000451\n",
      "Neuron 2: weight=1.8114522696, bias=-0.8120930195, out_weight=0.0000000445\n",
      "Neuron 3: weight=-0.4859311283, bias=-0.8302080631, out_weight=0.0000000741\n",
      "Neuron 4: weight=0.0340307839, bias=-2.2118842602, out_weight=-0.0000000591\n",
      "Neuron 5: weight=-0.4110427499, bias=-0.3957836628, out_weight=0.0000000182\n",
      "Neuron 6: weight=-1.1808662415, bias=-0.7949853539, out_weight=0.0000000029\n",
      "Neuron 7: weight=-0.0998490900, bias=0.0547575951, out_weight=-0.0000000009\n",
      "Neuron 8: weight=-0.0627254471, bias=0.8416796923, out_weight=0.0000000390\n",
      "Neuron 9: weight=2.4226486683, bias=-1.2424370050, out_weight=-0.0000000074\n",
      "Final covariance matrix F-norm: 1.446419e-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.0000000186\n",
      "Neuron 2: weight=-0.2975469530, bias=-0.5615794063, out_weight=0.0000000001\n",
      "Neuron 3: weight=-1.3784655333, bias=-0.6586383581, out_weight=-0.0000000043\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.0000000019\n",
      "Neuron 6: weight=0.1415881217, bias=0.6361415386, out_weight=-0.0000000452\n",
      "Neuron 7: weight=-0.1575459242, bias=0.3511222899, out_weight=-0.0000000094\n",
      "Neuron 8: weight=-0.5900731683, bias=-0.3196507096, out_weight=0.0000000077\n",
      "Neuron 9: weight=1.0842578411, bias=-1.3842144012, out_weight=-0.0000000001\n",
      "Initial covariance matrix F-norm: 9.488317e-16\n",
      "Step 00000 | Loss: 9.315465e-14\n",
      "Step 01000 | Loss: 9.585659e-14\n",
      "Step 02000 | Loss: 4.363350e-14\n",
      "Step 03000 | Loss: 5.624320e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000519\n",
      "Neuron 2: weight=-0.2975469530, bias=-0.5615794063, out_weight=0.0000000412\n",
      "Neuron 3: weight=-1.3784655333, bias=-0.6586383581, out_weight=-0.0000000116\n",
      "Neuron 4: weight=0.0164197087, bias=1.6601953506, out_weight=0.0000000689\n",
      "Neuron 5: weight=1.2222713232, bias=-0.5100500584, out_weight=0.0000000102\n",
      "Neuron 6: weight=0.1415881217, bias=0.6361415386, out_weight=-0.0000000323\n",
      "Neuron 7: weight=-0.1575459242, bias=0.3511222899, out_weight=0.0000000350\n",
      "Neuron 8: weight=-0.5900731683, bias=-0.3196507096, out_weight=0.0000001071\n",
      "Neuron 9: weight=1.0842578411, bias=-1.3842144012, out_weight=0.0000000468\n",
      "Final covariance matrix F-norm: 9.952809e-16\n",
      "\n",
      "\n",
      "Main Iteration:23\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.6575593948, bias=-1.2550536394, out_weight=-0.0000000037\n",
      "Neuron 2: weight=-0.6261727214, bias=0.2276002914, out_weight=-0.0000000000\n",
      "Neuron 3: weight=-1.2397109270, bias=-0.0019254745, out_weight=-0.0000000036\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.0000000033\n",
      "Neuron 6: weight=-0.1024087444, bias=-0.3248371482, out_weight=0.0000000041\n",
      "Neuron 7: weight=-0.7171928287, bias=-1.5379472971, out_weight=0.0000000154\n",
      "Neuron 8: weight=-1.2024127245, bias=-0.5378046632, out_weight=-0.0000000040\n",
      "Neuron 9: weight=-1.8491976261, bias=-0.0699689612, out_weight=0.0000000000\n",
      "Initial covariance matrix F-norm: 9.966651e-16\n",
      "Step 00000 | Loss: 7.265542e-14\n",
      "Step 01000 | Loss: 4.753142e-14\n",
      "Step 02000 | Loss: 5.155251e-14\n",
      "Step 03000 | Loss: 3.556183e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.6575593948, bias=-1.2550536394, out_weight=0.0000000574\n",
      "Neuron 2: weight=-0.6261727214, bias=0.2276002914, out_weight=-0.0000000512\n",
      "Neuron 3: weight=-1.2397109270, bias=-0.0019254745, out_weight=-0.0000000582\n",
      "Neuron 4: weight=0.3211532533, bias=-0.2541078031, out_weight=-0.0000000159\n",
      "Neuron 5: weight=-0.1235801727, bias=0.8970884681, out_weight=0.0000001533\n",
      "Neuron 6: weight=-0.1024087444, bias=-0.3248371482, out_weight=-0.0000000600\n",
      "Neuron 7: weight=-0.7171928287, bias=-1.5379472971, out_weight=0.0000000397\n",
      "Neuron 8: weight=-1.2024127245, bias=-0.5378046632, out_weight=0.0000000474\n",
      "Neuron 9: weight=-1.8491976261, bias=-0.0699689612, out_weight=0.0000000211\n",
      "Final covariance matrix F-norm: 1.010739e-15\n",
      "\n",
      "\n",
      "Main Iteration:24\n",
      "Initial network parameters by neuron:\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.0000000079\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.0000000051\n",
      "Neuron 4: weight=-1.2438917160, bias=-0.6114681959, out_weight=-0.0000000000\n",
      "Neuron 5: weight=0.5811503530, bias=-1.0153430700, out_weight=-0.0000000017\n",
      "Neuron 6: weight=0.6957083344, bias=0.2369759083, out_weight=-0.0000000219\n",
      "Neuron 7: weight=-0.0031021477, bias=0.6316713095, out_weight=0.0000000245\n",
      "Neuron 8: weight=-0.6041387916, bias=-0.0511639677, out_weight=-0.0000000055\n",
      "Neuron 9: weight=0.6517327428, bias=-1.1299874783, out_weight=0.0000000000\n",
      "Initial covariance matrix F-norm: 9.155084e-16\n",
      "Step 00000 | Loss: 7.994473e-14\n",
      "Step 01000 | Loss: 6.464967e-14\n",
      "Step 02000 | Loss: 6.731594e-14\n",
      "Step 03000 | Loss: 5.924601e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000626\n",
      "Neuron 2: weight=-1.2737531662, bias=0.6627067327, out_weight=-0.0000000471\n",
      "Neuron 3: weight=1.1965847015, bias=2.0761854649, out_weight=-0.0000001258\n",
      "Neuron 4: weight=-1.2438917160, bias=-0.6114681959, out_weight=0.0000000178\n",
      "Neuron 5: weight=0.5811503530, bias=-1.0153430700, out_weight=-0.0000000042\n",
      "Neuron 6: weight=0.6957083344, bias=0.2369759083, out_weight=-0.0000000501\n",
      "Neuron 7: weight=-0.0031021477, bias=0.6316713095, out_weight=0.0000001281\n",
      "Neuron 8: weight=-0.6041387916, bias=-0.0511639677, out_weight=0.0000000058\n",
      "Neuron 9: weight=0.6517327428, bias=-1.1299874783, out_weight=0.0000000124\n",
      "Final covariance matrix F-norm: 9.965374e-16\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.0000000169\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.0000000043\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.0000000005\n",
      "Neuron 6: weight=2.6827821732, bias=0.2823220491, out_weight=-0.0000000276\n",
      "Neuron 7: weight=-0.5442869663, bias=-0.5674430132, out_weight=-0.0000000196\n",
      "Neuron 8: weight=0.1137777045, bias=0.1817689538, out_weight=0.0000000114\n",
      "Neuron 9: weight=-1.0406111479, bias=-0.1890678406, out_weight=-0.0000000000\n",
      "Initial covariance matrix F-norm: 1.710478e-15\n",
      "Step 00000 | Loss: 8.677781e-14\n",
      "Step 01000 | Loss: 4.250073e-14\n",
      "Step 02000 | Loss: 8.953439e-14\n",
      "Step 03000 | Loss: 9.374793e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000605\n",
      "Neuron 2: weight=1.0894078016, bias=0.3406504691, out_weight=-0.0000000021\n",
      "Neuron 3: weight=0.1283116490, bias=0.5988626480, out_weight=0.0000000489\n",
      "Neuron 4: weight=0.2797000408, bias=-0.3282535076, out_weight=-0.0000000175\n",
      "Neuron 5: weight=-1.2345777750, bias=-0.1451051086, out_weight=-0.0000000533\n",
      "Neuron 6: weight=2.6827821732, bias=0.2823220491, out_weight=-0.0000000142\n",
      "Neuron 7: weight=-0.5442869663, bias=-0.5674430132, out_weight=0.0000000546\n",
      "Neuron 8: weight=0.1137777045, bias=0.1817689538, out_weight=0.0000000253\n",
      "Neuron 9: weight=-1.0406111479, bias=-0.1890678406, out_weight=-0.0000000197\n",
      "Final covariance matrix F-norm: 1.500434e-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.0000000016\n",
      "Neuron 2: weight=-0.0548723303, bias=-1.0178512335, out_weight=0.0000000004\n",
      "Neuron 3: weight=2.7953751087, bias=-0.5823549032, out_weight=0.0000000046\n",
      "Neuron 4: weight=0.2923755944, bias=1.5219477415, out_weight=0.0000000002\n",
      "Neuron 5: weight=-0.9761036634, bias=-0.5390229821, out_weight=0.0000000053\n",
      "Neuron 6: weight=0.1959639192, bias=-0.6206290126, out_weight=0.0000000038\n",
      "Neuron 7: weight=0.8559576869, bias=0.9397062063, out_weight=-0.0000000118\n",
      "Neuron 8: weight=-0.7286941409, bias=-0.7471458316, out_weight=0.0000000036\n",
      "Neuron 9: weight=0.2925755680, bias=0.7581775188, out_weight=-0.0000000001\n",
      "Initial covariance matrix F-norm: 3.137381e-15\n",
      "Step 00000 | Loss: 1.324114e-13\n",
      "Step 01000 | Loss: 1.419576e-13\n",
      "Step 02000 | Loss: 1.261508e-13\n",
      "Step 03000 | Loss: 1.491155e-13\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000001707\n",
      "Neuron 2: weight=-0.0548723303, bias=-1.0178512335, out_weight=0.0000000397\n",
      "Neuron 3: weight=2.7953751087, bias=-0.5823549032, out_weight=-0.0000000012\n",
      "Neuron 4: weight=0.2923755944, bias=1.5219477415, out_weight=-0.0000000655\n",
      "Neuron 5: weight=-0.9761036634, bias=-0.5390229821, out_weight=0.0000002821\n",
      "Neuron 6: weight=0.1959639192, bias=-0.6206290126, out_weight=0.0000000102\n",
      "Neuron 7: weight=0.8559576869, bias=0.9397062063, out_weight=0.0000002778\n",
      "Neuron 8: weight=-0.7286941409, bias=-0.7471458316, out_weight=-0.0000000223\n",
      "Neuron 9: weight=0.2925755680, bias=0.7581775188, out_weight=-0.0000000948\n",
      "Final covariance matrix F-norm: 2.241536e-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.0000000065\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.0000000012\n",
      "Neuron 4: weight=0.8320708871, bias=0.1871151775, out_weight=-0.0000000000\n",
      "Neuron 5: weight=1.1524658203, bias=-0.7600461245, out_weight=-0.0000000006\n",
      "Neuron 6: weight=0.9148828387, bias=0.3765882850, out_weight=-0.0000000296\n",
      "Neuron 7: weight=2.9927518368, bias=0.6284400225, out_weight=0.0000000015\n",
      "Neuron 8: weight=0.4696037769, bias=0.9578309655, out_weight=0.0000000012\n",
      "Neuron 9: weight=-0.3085474670, bias=0.6425065994, out_weight=0.0000000000\n",
      "Initial covariance matrix F-norm: 1.770489e-15\n",
      "Step 00000 | Loss: 5.890774e-14\n",
      "Step 01000 | Loss: 4.778990e-14\n",
      "Step 02000 | Loss: 9.991487e-14\n",
      "Step 03000 | Loss: 1.003780e-13\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000588\n",
      "Neuron 2: weight=-0.1439218819, bias=-0.1215024143, out_weight=0.0000000037\n",
      "Neuron 3: weight=1.3638712168, bias=0.6301981211, out_weight=0.0000000582\n",
      "Neuron 4: weight=0.8320708871, bias=0.1871151775, out_weight=-0.0000000297\n",
      "Neuron 5: weight=1.1524658203, bias=-0.7600461245, out_weight=0.0000000051\n",
      "Neuron 6: weight=0.9148828387, bias=0.3765882850, out_weight=-0.0000000887\n",
      "Neuron 7: weight=2.9927518368, bias=0.6284400225, out_weight=-0.0000000045\n",
      "Neuron 8: weight=0.4696037769, bias=0.9578309655, out_weight=-0.0000000346\n",
      "Neuron 9: weight=-0.3085474670, bias=0.6425065994, out_weight=0.0000000743\n",
      "Final covariance matrix F-norm: 1.808357e-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.0000000049\n",
      "Neuron 2: weight=-0.6794250011, bias=0.2216725498, out_weight=-0.0000000003\n",
      "Neuron 3: weight=-0.8955156803, bias=0.8447655439, out_weight=-0.0000000034\n",
      "Neuron 4: weight=-0.9100059271, bias=0.0370593295, out_weight=-0.0000000001\n",
      "Neuron 5: weight=-1.3484157324, bias=-1.0940498114, out_weight=-0.0000000051\n",
      "Neuron 6: weight=0.0550035201, bias=2.0008282661, out_weight=0.0000000315\n",
      "Neuron 7: weight=0.0135668041, bias=-0.9474929571, out_weight=-0.0000000227\n",
      "Neuron 8: weight=0.3536550999, bias=0.0466263443, out_weight=0.0000000028\n",
      "Neuron 9: weight=0.7292158604, bias=-0.3132576942, out_weight=0.0000000001\n",
      "Initial covariance matrix F-norm: 8.745475e-16\n",
      "Step 00000 | Loss: 6.895049e-14\n",
      "Step 01000 | Loss: 4.276440e-14\n",
      "Step 02000 | Loss: 7.598783e-14\n",
      "Step 03000 | Loss: 7.797409e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000641\n",
      "Neuron 2: weight=-0.6794250011, bias=0.2216725498, out_weight=-0.0000000063\n",
      "Neuron 3: weight=-0.8955156803, bias=0.8447655439, out_weight=-0.0000000744\n",
      "Neuron 4: weight=-0.9100059271, bias=0.0370593295, out_weight=0.0000000312\n",
      "Neuron 5: weight=-1.3484157324, bias=-1.0940498114, out_weight=-0.0000000846\n",
      "Neuron 6: weight=0.0550035201, bias=2.0008282661, out_weight=0.0000000258\n",
      "Neuron 7: weight=0.0135668041, bias=-0.9474929571, out_weight=-0.0000000193\n",
      "Neuron 8: weight=0.3536550999, bias=0.0466263443, out_weight=-0.0000000269\n",
      "Neuron 9: weight=0.7292158604, bias=-0.3132576942, out_weight=0.0000000235\n",
      "Final covariance matrix F-norm: 9.596891e-16\n",
      "\n",
      "\n",
      "Main Iteration:29\n",
      "Initial network parameters by neuron:\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.5413732529, bias=-0.5724231601, out_weight=-0.0000000075\n",
      "Neuron 2: weight=1.0658179522, bias=-1.1462633610, out_weight=-0.0000000002\n",
      "Neuron 3: weight=-0.4296619296, bias=-0.1982364208, out_weight=-0.0000000061\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.0000000090\n",
      "Neuron 6: weight=-0.3852166831, bias=0.5602155924, out_weight=-0.0000000063\n",
      "Neuron 7: weight=0.9029935002, bias=0.6414819956, out_weight=0.0000000197\n",
      "Neuron 8: weight=0.2437277883, bias=-0.0289368797, out_weight=-0.0000000053\n",
      "Neuron 9: weight=-0.0045027332, bias=-0.6300022602, out_weight=0.0000000001\n",
      "Initial covariance matrix F-norm: 1.115990e-15\n",
      "Step 00000 | Loss: 7.781970e-14\n",
      "Step 01000 | Loss: 6.012899e-14\n",
      "Step 02000 | Loss: 6.101716e-14\n",
      "Step 03000 | Loss: 1.119729e-13\n",
      "Trained network parameters by neuron with lr=0.01 :\n",
      "Neuron 0: weight=2.0000000000, bias=1.0000000000, out_weight=1.0000000000\n",
      "Neuron 1: weight=-0.5413732529, bias=-0.5724231601, out_weight=-0.0000000208\n",
      "Neuron 2: weight=1.0658179522, bias=-1.1462633610, out_weight=0.0000000103\n",
      "Neuron 3: weight=-0.4296619296, bias=-0.1982364208, out_weight=-0.0000000560\n",
      "Neuron 4: weight=1.8893623352, bias=0.5886537433, out_weight=-0.0000000092\n",
      "Neuron 5: weight=0.8103240728, bias=1.1139851809, out_weight=-0.0000001354\n",
      "Neuron 6: weight=-0.3852166831, bias=0.5602155924, out_weight=-0.0000000065\n",
      "Neuron 7: weight=0.9029935002, bias=0.6414819956, out_weight=0.0000000564\n",
      "Neuron 8: weight=0.2437277883, bias=-0.0289368797, out_weight=0.0000000074\n",
      "Neuron 9: weight=-0.0045027332, bias=-0.6300022602, out_weight=-0.0000000678\n",
      "Final covariance matrix F-norm: 1.134320e-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.0000000128\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.0000000074\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.0000000056\n",
      "Neuron 6: weight=0.5119389892, bias=-0.5420712829, out_weight=-0.0000000375\n",
      "Neuron 7: weight=-0.8572292924, bias=-1.8534232378, out_weight=0.0000000200\n",
      "Neuron 8: weight=-1.3924459219, bias=-0.3818907440, out_weight=-0.0000000057\n",
      "Neuron 9: weight=-0.6636574864, bias=1.0315138102, out_weight=0.0000000001\n",
      "Initial covariance matrix F-norm: 9.425134e-16\n",
      "Step 00000 | Loss: 6.120278e-14\n",
      "Step 01000 | Loss: 9.098982e-14\n",
      "Step 02000 | Loss: 6.199208e-14\n",
      "Step 03000 | Loss: 8.269080e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000282\n",
      "Neuron 2: weight=-0.3115839958, bias=-0.0693287626, out_weight=-0.0000000163\n",
      "Neuron 3: weight=-1.1425571442, bias=-2.3621642590, out_weight=-0.0000000050\n",
      "Neuron 4: weight=0.7029282451, bias=0.3921147883, out_weight=-0.0000000222\n",
      "Neuron 5: weight=-1.0320992470, bias=-0.4446171522, out_weight=0.0000000113\n",
      "Neuron 6: weight=0.5119389892, bias=-0.5420712829, out_weight=0.0000000014\n",
      "Neuron 7: weight=-0.8572292924, bias=-1.8534232378, out_weight=0.0000000114\n",
      "Neuron 8: weight=-1.3924459219, bias=-0.3818907440, out_weight=-0.0000000221\n",
      "Neuron 9: weight=-0.6636574864, bias=1.0315138102, out_weight=-0.0000000124\n",
      "Final covariance matrix F-norm: 9.452360e-16\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.0000000184\n",
      "Neuron 2: weight=0.5473304391, bias=-1.7793911695, out_weight=-0.0000000004\n",
      "Neuron 3: weight=-0.9040086269, bias=-0.8429154754, out_weight=-0.0000000118\n",
      "Neuron 4: weight=0.7420345545, bias=-0.0717495680, out_weight=-0.0000000002\n",
      "Neuron 5: weight=0.2286186516, bias=0.5613806248, out_weight=-0.0000000148\n",
      "Neuron 6: weight=1.3805971146, bias=-0.0752578527, out_weight=-0.0000000360\n",
      "Neuron 7: weight=1.3311828375, bias=0.3065835536, out_weight=0.0000000349\n",
      "Neuron 8: weight=0.6711614728, bias=0.2125323266, out_weight=-0.0000000077\n",
      "Neuron 9: weight=0.2817564905, bias=-1.1733262539, out_weight=0.0000000002\n",
      "Initial covariance matrix F-norm: 1.371235e-15\n",
      "Step 00000 | Loss: 1.652498e-13\n",
      "Step 01000 | Loss: 5.581993e-14\n",
      "Step 02000 | Loss: 1.021769e-13\n",
      "Step 03000 | Loss: 1.009349e-13\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000510\n",
      "Neuron 2: weight=0.5473304391, bias=-1.7793911695, out_weight=-0.0000000319\n",
      "Neuron 3: weight=-0.9040086269, bias=-0.8429154754, out_weight=0.0000001103\n",
      "Neuron 4: weight=0.7420345545, bias=-0.0717495680, out_weight=0.0000002176\n",
      "Neuron 5: weight=0.2286186516, bias=0.5613806248, out_weight=-0.0000000363\n",
      "Neuron 6: weight=1.3805971146, bias=-0.0752578527, out_weight=-0.0000002558\n",
      "Neuron 7: weight=1.3311828375, bias=0.3065835536, out_weight=0.0000002615\n",
      "Neuron 8: weight=0.6711614728, bias=0.2125323266, out_weight=0.0000001016\n",
      "Neuron 9: weight=0.2817564905, bias=-1.1733262539, out_weight=-0.0000000267\n",
      "Final covariance matrix F-norm: 1.094206e-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.0000000047\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.0000000029\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.0000000143\n",
      "Neuron 7: weight=1.4254354239, bias=0.6915167570, out_weight=-0.0000000048\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.0000000000\n",
      "Initial covariance matrix F-norm: 1.037746e-15\n",
      "Step 00000 | Loss: 7.222174e-14\n",
      "Step 01000 | Loss: 1.128073e-13\n",
      "Step 02000 | Loss: 8.839630e-14\n",
      "Step 03000 | Loss: 8.022055e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000012\n",
      "Neuron 2: weight=1.2911534309, bias=-2.0566046238, out_weight=-0.0000000069\n",
      "Neuron 3: weight=1.0633087158, bias=-1.2812505960, out_weight=-0.0000000034\n",
      "Neuron 4: weight=0.0806511417, bias=0.2836257219, out_weight=-0.0000000015\n",
      "Neuron 5: weight=-0.7679620385, bias=-2.7287895679, out_weight=-0.0000000154\n",
      "Neuron 6: weight=-0.8730942607, bias=0.7049176693, out_weight=-0.0000000722\n",
      "Neuron 7: weight=1.4254354239, bias=0.6915167570, out_weight=0.0000000069\n",
      "Neuron 8: weight=-0.3748766184, bias=-1.7346795797, out_weight=-0.0000000109\n",
      "Neuron 9: weight=-1.4936321974, bias=-0.9203385711, out_weight=0.0000000263\n",
      "Final covariance matrix F-norm: 1.044571e-15\n",
      "\n",
      "\n",
      "Main Iteration:33\n",
      "Initial network parameters by neuron:\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.0000000143\n",
      "Neuron 2: weight=-0.0979488045, bias=1.0352895260, out_weight=0.0000000003\n",
      "Neuron 3: weight=-0.1062865704, bias=-1.7092479467, out_weight=0.0000000093\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.0000000077\n",
      "Neuron 6: weight=-0.5260431767, bias=-0.1829437613, out_weight=0.0000000223\n",
      "Neuron 7: weight=-0.0769765377, bias=0.0795142949, out_weight=-0.0000000142\n",
      "Neuron 8: weight=-0.7366437912, bias=3.0360202789, out_weight=0.0000000009\n",
      "Neuron 9: weight=0.8683328629, bias=0.3209394217, out_weight=-0.0000000001\n",
      "Initial covariance matrix F-norm: 8.658959e-16\n",
      "Step 00000 | Loss: 7.720907e-14\n",
      "Step 01000 | Loss: 7.351932e-14\n",
      "Step 02000 | Loss: 4.697631e-14\n",
      "Step 03000 | Loss: 9.670043e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000214\n",
      "Neuron 2: weight=-0.0979488045, bias=1.0352895260, out_weight=0.0000000151\n",
      "Neuron 3: weight=-0.1062865704, bias=-1.7092479467, out_weight=-0.0000000091\n",
      "Neuron 4: weight=-0.7212156057, bias=0.1532117575, out_weight=-0.0000000363\n",
      "Neuron 5: weight=-1.0555577278, bias=0.5962054133, out_weight=-0.0000000531\n",
      "Neuron 6: weight=-0.5260431767, bias=-0.1829437613, out_weight=0.0000000653\n",
      "Neuron 7: weight=-0.0769765377, bias=0.0795142949, out_weight=-0.0000000094\n",
      "Neuron 8: weight=-0.7366437912, bias=3.0360202789, out_weight=0.0000000110\n",
      "Neuron 9: weight=0.8683328629, bias=0.3209394217, out_weight=-0.0000000321\n",
      "Final covariance matrix F-norm: 8.757374e-16\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.0000000107\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.0000000009\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.0000000015\n",
      "Neuron 6: weight=-0.1692174673, bias=0.0129845990, out_weight=0.0000000278\n",
      "Neuron 7: weight=-0.5648132563, bias=-0.1909907907, out_weight=-0.0000000100\n",
      "Neuron 8: weight=-0.3005906045, bias=0.9861701131, out_weight=-0.0000000024\n",
      "Neuron 9: weight=-0.7706210017, bias=-2.9136393070, out_weight=0.0000000000\n",
      "Initial covariance matrix F-norm: 8.449179e-16\n",
      "Step 00000 | Loss: 5.801609e-14\n",
      "Step 01000 | Loss: 4.623949e-14\n",
      "Step 02000 | Loss: 7.722642e-14\n",
      "Step 03000 | Loss: 6.349999e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000011\n",
      "Neuron 2: weight=-0.1660952717, bias=2.6173315048, out_weight=0.0000000300\n",
      "Neuron 3: weight=-0.3960103095, bias=-0.0308474004, out_weight=-0.0000000393\n",
      "Neuron 4: weight=-0.2646400332, bias=0.0229911115, out_weight=-0.0000000148\n",
      "Neuron 5: weight=-0.8544789553, bias=-0.6674141288, out_weight=0.0000000954\n",
      "Neuron 6: weight=-0.1692174673, bias=0.0129845990, out_weight=0.0000000244\n",
      "Neuron 7: weight=-0.5648132563, bias=-0.1909907907, out_weight=-0.0000000714\n",
      "Neuron 8: weight=-0.3005906045, bias=0.9861701131, out_weight=-0.0000000101\n",
      "Neuron 9: weight=-0.7706210017, bias=-2.9136393070, out_weight=-0.0000000051\n",
      "Final covariance matrix F-norm: 8.534653e-16\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.0000000022\n",
      "Neuron 2: weight=-0.0095005771, bias=0.7446422577, out_weight=0.0000000003\n",
      "Neuron 3: weight=-1.7097346783, bias=0.0646999925, out_weight=0.0000000048\n",
      "Neuron 4: weight=-0.7149356008, bias=-1.2355872393, out_weight=0.0000000001\n",
      "Neuron 5: weight=0.8348634839, bias=-1.8063564301, out_weight=0.0000000052\n",
      "Neuron 6: weight=-2.0573456287, bias=-0.5680345893, out_weight=-0.0000000003\n",
      "Neuron 7: weight=0.2782153785, bias=-0.6398184299, out_weight=-0.0000000060\n",
      "Neuron 8: weight=-1.6437848806, bias=-0.7646645904, out_weight=0.0000000024\n",
      "Neuron 9: weight=-1.3182733059, bias=-0.9325097203, out_weight=-0.0000000001\n",
      "Initial covariance matrix F-norm: 1.408120e-15\n",
      "Step 00000 | Loss: 7.179153e-14\n",
      "Step 01000 | Loss: 9.358486e-14\n",
      "Step 02000 | Loss: 6.805364e-14\n",
      "Step 03000 | Loss: 4.857963e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000110\n",
      "Neuron 2: weight=-0.0095005771, bias=0.7446422577, out_weight=0.0000000657\n",
      "Neuron 3: weight=-1.7097346783, bias=0.0646999925, out_weight=-0.0000000097\n",
      "Neuron 4: weight=-0.7149356008, bias=-1.2355872393, out_weight=0.0000000810\n",
      "Neuron 5: weight=0.8348634839, bias=-1.8063564301, out_weight=0.0000000274\n",
      "Neuron 6: weight=-2.0573456287, bias=-0.5680345893, out_weight=0.0000000484\n",
      "Neuron 7: weight=0.2782153785, bias=-0.6398184299, out_weight=-0.0000000094\n",
      "Neuron 8: weight=-1.6437848806, bias=-0.7646645904, out_weight=-0.0000000947\n",
      "Neuron 9: weight=-1.3182733059, bias=-0.9325097203, out_weight=0.0000000545\n",
      "Final covariance matrix F-norm: 1.604542e-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.0000000067\n",
      "Neuron 2: weight=1.3116044998, bias=0.5071085095, out_weight=-0.0000000003\n",
      "Neuron 3: weight=-1.1020072699, bias=0.0164663270, out_weight=-0.0000000004\n",
      "Neuron 4: weight=-0.5230802894, bias=-1.6071854830, out_weight=-0.0000000001\n",
      "Neuron 5: weight=0.4143725336, bias=1.3040177822, out_weight=-0.0000000043\n",
      "Neuron 6: weight=-0.9715055227, bias=0.6877169609, out_weight=0.0000000121\n",
      "Neuron 7: weight=-0.0222354792, bias=0.0386384688, out_weight=0.0000000219\n",
      "Neuron 8: weight=0.6798384190, bias=0.3081932962, out_weight=-0.0000000070\n",
      "Neuron 9: weight=1.6584602594, bias=0.5830604434, out_weight=0.0000000001\n",
      "Initial covariance matrix F-norm: 1.099418e-15\n",
      "Step 00000 | Loss: 7.653253e-14\n",
      "Step 01000 | Loss: 7.911033e-14\n",
      "Step 02000 | Loss: 9.612103e-14\n",
      "Step 03000 | Loss: 8.254161e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000515\n",
      "Neuron 2: weight=1.3116044998, bias=0.5071085095, out_weight=-0.0000000007\n",
      "Neuron 3: weight=-1.1020072699, bias=0.0164663270, out_weight=-0.0000000487\n",
      "Neuron 4: weight=-0.5230802894, bias=-1.6071854830, out_weight=-0.0000000122\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.0000000437\n",
      "Neuron 7: weight=-0.0222354792, bias=0.0386384688, out_weight=0.0000000295\n",
      "Neuron 8: weight=0.6798384190, bias=0.3081932962, out_weight=-0.0000000941\n",
      "Neuron 9: weight=1.6584602594, bias=0.5830604434, out_weight=0.0000000020\n",
      "Final covariance matrix F-norm: 1.115249e-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.0000000071\n",
      "Neuron 2: weight=-0.6215501428, bias=0.0901525617, out_weight=0.0000000003\n",
      "Neuron 3: weight=0.7370534539, bias=-0.8995583653, out_weight=0.0000000080\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.0000000078\n",
      "Neuron 6: weight=-0.7432483435, bias=1.0478993654, out_weight=0.0000000169\n",
      "Neuron 7: weight=-0.2511776090, bias=1.7393522263, out_weight=-0.0000000065\n",
      "Neuron 8: weight=-2.0469009876, bias=-1.4310107231, out_weight=0.0000000051\n",
      "Neuron 9: weight=0.4815791845, bias=1.0926151276, out_weight=-0.0000000001\n",
      "Initial covariance matrix F-norm: 1.106331e-15\n",
      "Step 00000 | Loss: 1.094420e-13\n",
      "Step 01000 | Loss: 8.627821e-14\n",
      "Step 02000 | Loss: 8.151639e-14\n",
      "Step 03000 | Loss: 1.066161e-13\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000117\n",
      "Neuron 2: weight=-0.6215501428, bias=0.0901525617, out_weight=-0.0000000526\n",
      "Neuron 3: weight=0.7370534539, bias=-0.8995583653, out_weight=0.0000000566\n",
      "Neuron 4: weight=-0.5200930238, bias=1.5285587311, out_weight=0.0000000604\n",
      "Neuron 5: weight=-0.3521685600, bias=-1.5645798445, out_weight=-0.0000000210\n",
      "Neuron 6: weight=-0.7432483435, bias=1.0478993654, out_weight=-0.0000000016\n",
      "Neuron 7: weight=-0.2511776090, bias=1.7393522263, out_weight=0.0000000734\n",
      "Neuron 8: weight=-2.0469009876, bias=-1.4310107231, out_weight=-0.0000000047\n",
      "Neuron 9: weight=0.4815791845, bias=1.0926151276, out_weight=-0.0000000958\n",
      "Final covariance matrix F-norm: 1.107435e-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.0000000027\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.0000000015\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.0000000013\n",
      "Neuron 6: weight=-0.2307615429, bias=0.9778403640, out_weight=0.0000000014\n",
      "Neuron 7: weight=-0.5715444088, bias=1.1472171545, out_weight=-0.0000000199\n",
      "Neuron 8: weight=1.5358664989, bias=0.3379892707, out_weight=0.0000000028\n",
      "Neuron 9: weight=-0.9520809054, bias=-0.0765040070, out_weight=-0.0000000000\n",
      "Initial covariance matrix F-norm: 9.486727e-16\n",
      "Step 00000 | Loss: 4.842654e-14\n",
      "Step 01000 | Loss: 8.187374e-14\n",
      "Step 02000 | Loss: 8.170721e-14\n",
      "Step 03000 | Loss: 9.977436e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000302\n",
      "Neuron 2: weight=-0.0157783274, bias=-0.3396984935, out_weight=-0.0000000141\n",
      "Neuron 3: weight=-1.3854110241, bias=-1.8355462551, out_weight=0.0000000619\n",
      "Neuron 4: weight=0.6378089786, bias=0.3942968547, out_weight=0.0000000481\n",
      "Neuron 5: weight=-0.4209174216, bias=0.3864370883, out_weight=0.0000000136\n",
      "Neuron 6: weight=-0.2307615429, bias=0.9778403640, out_weight=0.0000000302\n",
      "Neuron 7: weight=-0.5715444088, bias=1.1472171545, out_weight=0.0000000039\n",
      "Neuron 8: weight=1.5358664989, bias=0.3379892707, out_weight=-0.0000000306\n",
      "Neuron 9: weight=-0.9520809054, bias=-0.0765040070, out_weight=-0.0000000348\n",
      "Final covariance matrix F-norm: 9.941581e-16\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.0000000040\n",
      "Neuron 2: weight=-1.0999101400, bias=0.6394029856, out_weight=0.0000000000\n",
      "Neuron 3: weight=-0.7222269177, bias=0.4347302914, out_weight=-0.0000000006\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.0000000027\n",
      "Neuron 6: weight=-0.6716766953, bias=2.4079225063, out_weight=-0.0000000129\n",
      "Neuron 7: weight=-0.7449373603, bias=-0.3681399226, out_weight=-0.0000000263\n",
      "Neuron 8: weight=0.5303604007, bias=-0.2504943311, out_weight=0.0000000074\n",
      "Neuron 9: weight=-0.1611372977, bias=-1.1083384752, out_weight=-0.0000000000\n",
      "Initial covariance matrix F-norm: 8.547561e-16\n",
      "Step 00000 | Loss: 7.149142e-14\n",
      "Step 01000 | Loss: 7.358003e-14\n",
      "Step 02000 | Loss: 6.096165e-14\n",
      "Step 03000 | Loss: 6.124962e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000114\n",
      "Neuron 2: weight=-1.0999101400, bias=0.6394029856, out_weight=-0.0000000681\n",
      "Neuron 3: weight=-0.7222269177, bias=0.4347302914, out_weight=-0.0000000444\n",
      "Neuron 4: weight=-0.0828692839, bias=-1.4889129400, out_weight=-0.0000000339\n",
      "Neuron 5: weight=0.7582545877, bias=0.1242757440, out_weight=-0.0000000236\n",
      "Neuron 6: weight=-0.6716766953, bias=2.4079225063, out_weight=0.0000000099\n",
      "Neuron 7: weight=-0.7449373603, bias=-0.3681399226, out_weight=0.0000000692\n",
      "Neuron 8: weight=0.5303604007, bias=-0.2504943311, out_weight=0.0000000068\n",
      "Neuron 9: weight=-0.1611372977, bias=-1.1083384752, out_weight=-0.0000000132\n",
      "Final covariance matrix F-norm: 8.648706e-16\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.0000000041\n",
      "Neuron 2: weight=-0.5462489128, bias=0.9356046915, out_weight=-0.0000000002\n",
      "Neuron 3: weight=1.0251958370, bias=-0.3001102209, out_weight=-0.0000000042\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.0000000041\n",
      "Neuron 6: weight=0.0834314674, bias=0.4053222835, out_weight=-0.0000000091\n",
      "Neuron 7: weight=-0.9879937768, bias=-0.1144245490, out_weight=0.0000000119\n",
      "Neuron 8: weight=-0.0988940597, bias=-0.3796474636, out_weight=-0.0000000039\n",
      "Neuron 9: weight=1.0209341049, bias=0.8332019448, out_weight=0.0000000001\n",
      "Initial covariance matrix F-norm: 8.715034e-16\n",
      "Step 00000 | Loss: 7.039161e-14\n",
      "Step 01000 | Loss: 7.712754e-14\n",
      "Step 02000 | Loss: 6.001796e-14\n",
      "Step 03000 | Loss: 5.249794e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000103\n",
      "Neuron 2: weight=-0.5462489128, bias=0.9356046915, out_weight=-0.0000000323\n",
      "Neuron 3: weight=1.0251958370, bias=-0.3001102209, out_weight=0.0000000080\n",
      "Neuron 4: weight=1.2108509541, bias=-0.4544638991, out_weight=0.0000000437\n",
      "Neuron 5: weight=0.5630894899, bias=0.0344574638, out_weight=-0.0000000127\n",
      "Neuron 6: weight=0.0834314674, bias=0.4053222835, out_weight=0.0000000086\n",
      "Neuron 7: weight=-0.9879937768, bias=-0.1144245490, out_weight=0.0000000427\n",
      "Neuron 8: weight=-0.0988940597, bias=-0.3796474636, out_weight=-0.0000000188\n",
      "Neuron 9: weight=1.0209341049, bias=0.8332019448, out_weight=-0.0000000184\n",
      "Final covariance matrix F-norm: 8.798355e-16\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.0000000011\n",
      "Neuron 2: weight=-1.1824021339, bias=1.5200920105, out_weight=-0.0000000002\n",
      "Neuron 3: weight=-1.0983538628, bias=-0.7354533076, out_weight=-0.0000000021\n",
      "Neuron 4: weight=0.7447363734, bias=-0.5851950049, out_weight=-0.0000000001\n",
      "Neuron 5: weight=-0.0132466601, bias=-0.9145535231, out_weight=-0.0000000011\n",
      "Neuron 6: weight=0.7805695534, bias=1.0076452494, out_weight=-0.0000000030\n",
      "Neuron 7: weight=-0.5516315699, bias=-2.4082193375, out_weight=-0.0000000261\n",
      "Neuron 8: weight=1.6035760641, bias=-1.9870032072, out_weight=0.0000000064\n",
      "Neuron 9: weight=-0.9788454175, bias=-0.1986232102, out_weight=0.0000000001\n",
      "Initial covariance matrix F-norm: 9.025611e-16\n",
      "Step 00000 | Loss: 5.198793e-14\n",
      "Step 01000 | Loss: 8.593300e-14\n",
      "Step 02000 | Loss: 6.547193e-14\n",
      "Step 03000 | Loss: 9.815065e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000879\n",
      "Neuron 2: weight=-1.1824021339, bias=1.5200920105, out_weight=-0.0000000246\n",
      "Neuron 3: weight=-1.0983538628, bias=-0.7354533076, out_weight=-0.0000000414\n",
      "Neuron 4: weight=0.7447363734, bias=-0.5851950049, out_weight=0.0000000813\n",
      "Neuron 5: weight=-0.0132466601, bias=-0.9145535231, out_weight=-0.0000000384\n",
      "Neuron 6: weight=0.7805695534, bias=1.0076452494, out_weight=-0.0000000784\n",
      "Neuron 7: weight=-0.5516315699, bias=-2.4082193375, out_weight=-0.0000000628\n",
      "Neuron 8: weight=1.6035760641, bias=-1.9870032072, out_weight=-0.0000000233\n",
      "Neuron 9: weight=-0.9788454175, bias=-0.1986232102, out_weight=-0.0000000069\n",
      "Final covariance matrix F-norm: 9.633814e-16\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.0000000006\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.0000000020\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.0000000050\n",
      "Neuron 6: weight=-0.0378699712, bias=0.8126194477, out_weight=-0.0000000087\n",
      "Neuron 7: weight=-0.2361120284, bias=-1.1889189482, out_weight=-0.0000000306\n",
      "Neuron 8: weight=-1.4999375343, bias=0.2110185176, out_weight=0.0000000102\n",
      "Neuron 9: weight=-0.4081827998, bias=-1.2111228704, out_weight=-0.0000000000\n",
      "Initial covariance matrix F-norm: 8.717906e-16\n",
      "Step 00000 | Loss: 8.043045e-14\n",
      "Step 01000 | Loss: 5.086903e-14\n",
      "Step 02000 | Loss: 8.267345e-14\n",
      "Step 03000 | Loss: 3.337088e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000370\n",
      "Neuron 2: weight=0.0714694411, bias=0.1855071336, out_weight=-0.0000000219\n",
      "Neuron 3: weight=0.3754984140, bias=-1.8386460543, out_weight=-0.0000000307\n",
      "Neuron 4: weight=0.4787482321, bias=-0.5495311022, out_weight=-0.0000000478\n",
      "Neuron 5: weight=0.0428047068, bias=-1.3696551323, out_weight=-0.0000000308\n",
      "Neuron 6: weight=-0.0378699712, bias=0.8126194477, out_weight=0.0000000236\n",
      "Neuron 7: weight=-0.2361120284, bias=-1.1889189482, out_weight=-0.0000000073\n",
      "Neuron 8: weight=-1.4999375343, bias=0.2110185176, out_weight=-0.0000000300\n",
      "Neuron 9: weight=-0.4081827998, bias=-1.2111228704, out_weight=0.0000000948\n",
      "Final covariance matrix F-norm: 8.850758e-16\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.0000000061\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.0000000021\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.0000000010\n",
      "Neuron 6: weight=-1.2954564095, bias=-0.7789186835, out_weight=-0.0000000116\n",
      "Neuron 7: weight=1.4356100559, bias=0.1510855705, out_weight=0.0000000111\n",
      "Neuron 8: weight=0.5139718056, bias=1.3286746740, out_weight=0.0000000006\n",
      "Neuron 9: weight=-0.3016385734, bias=-0.2769269049, out_weight=0.0000000000\n",
      "Initial covariance matrix F-norm: 1.050231e-15\n",
      "Step 00000 | Loss: 6.022439e-14\n",
      "Step 01000 | Loss: 6.757962e-14\n",
      "Step 02000 | Loss: 7.320013e-14\n",
      "Step 03000 | Loss: 4.061508e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000269\n",
      "Neuron 2: weight=-0.3710476756, bias=0.6970149875, out_weight=0.0000000380\n",
      "Neuron 3: weight=0.1786303073, bias=0.0071970662, out_weight=-0.0000000190\n",
      "Neuron 4: weight=-1.6229432821, bias=-0.1977139413, out_weight=0.0000000312\n",
      "Neuron 5: weight=-1.0123565197, bias=-0.2773270309, out_weight=-0.0000000129\n",
      "Neuron 6: weight=-1.2954564095, bias=-0.7789186835, out_weight=0.0000000015\n",
      "Neuron 7: weight=1.4356100559, bias=0.1510855705, out_weight=0.0000000457\n",
      "Neuron 8: weight=0.5139718056, bias=1.3286746740, out_weight=-0.0000000007\n",
      "Neuron 9: weight=-0.3016385734, bias=-0.2769269049, out_weight=0.0000000157\n",
      "Final covariance matrix F-norm: 1.075542e-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.0000000232\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.0000000087\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.0000000085\n",
      "Neuron 6: weight=-0.1772744060, bias=-1.3769466877, out_weight=0.0000000451\n",
      "Neuron 7: weight=-0.5787715912, bias=0.7248364687, out_weight=-0.0000000350\n",
      "Neuron 8: weight=-0.6570038199, bias=1.0697478056, out_weight=0.0000000016\n",
      "Neuron 9: weight=1.5205037594, bias=-0.4535931945, out_weight=-0.0000000001\n",
      "Initial covariance matrix F-norm: 9.594754e-16\n",
      "Step 00000 | Loss: 6.768544e-14\n",
      "Step 01000 | Loss: 8.325111e-14\n",
      "Step 02000 | Loss: 4.915035e-14\n",
      "Step 03000 | Loss: 4.177214e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000931\n",
      "Neuron 2: weight=-0.8186210394, bias=0.4582332969, out_weight=-0.0000000036\n",
      "Neuron 3: weight=1.5737733841, bias=-0.6695608497, out_weight=0.0000000270\n",
      "Neuron 4: weight=-0.6348657608, bias=1.7755995989, out_weight=0.0000000521\n",
      "Neuron 5: weight=-1.2001936436, bias=0.2460332811, out_weight=0.0000000670\n",
      "Neuron 6: weight=-0.1772744060, bias=-1.3769466877, out_weight=-0.0000000544\n",
      "Neuron 7: weight=-0.5787715912, bias=0.7248364687, out_weight=-0.0000000533\n",
      "Neuron 8: weight=-0.6570038199, bias=1.0697478056, out_weight=-0.0000000291\n",
      "Neuron 9: weight=1.5205037594, bias=-0.4535931945, out_weight=0.0000000214\n",
      "Final covariance matrix F-norm: 9.761180e-16\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.0000000052\n",
      "Neuron 2: weight=-0.1477362514, bias=1.0268847942, out_weight=-0.0000000003\n",
      "Neuron 3: weight=0.2584802210, bias=0.7142741680, out_weight=-0.0000000048\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.0000000062\n",
      "Neuron 6: weight=-0.5853837729, bias=-0.2386338562, out_weight=-0.0000000042\n",
      "Neuron 7: weight=-0.6092095971, bias=1.6600542068, out_weight=-0.0000000076\n",
      "Neuron 8: weight=-0.7720248103, bias=0.6362332702, out_weight=0.0000000021\n",
      "Neuron 9: weight=0.1655287594, bias=0.3751365244, out_weight=0.0000000001\n",
      "Initial covariance matrix F-norm: 8.613022e-16\n",
      "Step 00000 | Loss: 5.268770e-14\n",
      "Step 01000 | Loss: 4.966513e-14\n",
      "Step 02000 | Loss: 5.060015e-14\n",
      "Step 03000 | Loss: 8.040096e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000229\n",
      "Neuron 2: weight=-0.1477362514, bias=1.0268847942, out_weight=0.0000000929\n",
      "Neuron 3: weight=0.2584802210, bias=0.7142741680, out_weight=0.0000000192\n",
      "Neuron 4: weight=0.5362110734, bias=-0.8021433949, out_weight=0.0000000325\n",
      "Neuron 5: weight=0.7996675968, bias=1.6077300310, out_weight=-0.0000001074\n",
      "Neuron 6: weight=-0.5853837729, bias=-0.2386338562, out_weight=0.0000000612\n",
      "Neuron 7: weight=-0.6092095971, bias=1.6600542068, out_weight=0.0000000330\n",
      "Neuron 8: weight=-0.7720248103, bias=0.6362332702, out_weight=-0.0000000915\n",
      "Neuron 9: weight=0.1655287594, bias=0.3751365244, out_weight=0.0000000204\n",
      "Final covariance matrix F-norm: 9.403396e-16\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.0000000007\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.0000000017\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.0000000031\n",
      "Neuron 6: weight=-0.9518280029, bias=-0.0972065181, out_weight=-0.0000000022\n",
      "Neuron 7: weight=0.4237121940, bias=-0.9852880239, out_weight=-0.0000000308\n",
      "Neuron 8: weight=1.4874463081, bias=-0.2077727914, out_weight=0.0000000087\n",
      "Neuron 9: weight=-0.7484461069, bias=-1.0296499729, out_weight=-0.0000000000\n",
      "Initial covariance matrix F-norm: 8.640392e-16\n",
      "Step 00000 | Loss: 4.194214e-14\n",
      "Step 01000 | Loss: 6.041001e-14\n",
      "Step 02000 | Loss: 8.949785e-14\n",
      "Step 03000 | Loss: 4.400647e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000695\n",
      "Neuron 2: weight=-0.3032006919, bias=-0.4092377722, out_weight=-0.0000000392\n",
      "Neuron 3: weight=0.1062980369, bias=-1.3500500917, out_weight=-0.0000000803\n",
      "Neuron 4: weight=-0.7016844153, bias=-1.1489995718, out_weight=0.0000000630\n",
      "Neuron 5: weight=0.4626043141, bias=-1.0669186115, out_weight=0.0000000472\n",
      "Neuron 6: weight=-0.9518280029, bias=-0.0972065181, out_weight=-0.0000000385\n",
      "Neuron 7: weight=0.4237121940, bias=-0.9852880239, out_weight=0.0000000076\n",
      "Neuron 8: weight=1.4874463081, bias=-0.2077727914, out_weight=0.0000000037\n",
      "Neuron 9: weight=-0.7484461069, bias=-1.0296499729, out_weight=0.0000000757\n",
      "Final covariance matrix F-norm: 8.842408e-16\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.0000000123\n",
      "Neuron 2: weight=-0.7270749211, bias=-0.0415960029, out_weight=0.0000000002\n",
      "Neuron 3: weight=0.3207877576, bias=0.5330362916, out_weight=-0.0000000036\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.0000000001\n",
      "Neuron 6: weight=1.5081691742, bias=-0.7526158690, out_weight=-0.0000000355\n",
      "Neuron 7: weight=-0.2112736404, bias=0.7792533636, out_weight=0.0000000299\n",
      "Neuron 8: weight=-0.0883694515, bias=0.6359034181, out_weight=-0.0000000060\n",
      "Neuron 9: weight=-0.3800931275, bias=0.0954452381, out_weight=-0.0000000001\n",
      "Initial covariance matrix F-norm: 2.278206e-15\n",
      "Step 00000 | Loss: 2.078476e-13\n",
      "Step 01000 | Loss: 8.025872e-14\n",
      "Step 02000 | Loss: 5.762751e-14\n",
      "Step 03000 | Loss: 8.005575e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000017\n",
      "Neuron 2: weight=-0.7270749211, bias=-0.0415960029, out_weight=0.0000000212\n",
      "Neuron 3: weight=0.3207877576, bias=0.5330362916, out_weight=0.0000000079\n",
      "Neuron 4: weight=-0.6015243530, bias=1.1686221361, out_weight=0.0000000038\n",
      "Neuron 5: weight=2.4665279388, bias=0.9793000817, out_weight=0.0000000547\n",
      "Neuron 6: weight=1.5081691742, bias=-0.7526158690, out_weight=-0.0000000018\n",
      "Neuron 7: weight=-0.2112736404, bias=0.7792533636, out_weight=0.0000000220\n",
      "Neuron 8: weight=-0.0883694515, bias=0.6359034181, out_weight=-0.0000000135\n",
      "Neuron 9: weight=-0.3800931275, bias=0.0954452381, out_weight=-0.0000000127\n",
      "Final covariance matrix F-norm: 1.737968e-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.0000000040\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.0000000028\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.0000000038\n",
      "Neuron 6: weight=-0.4947102368, bias=1.6819410324, out_weight=0.0000000016\n",
      "Neuron 7: weight=1.8427968025, bias=1.6106805801, out_weight=0.0000000046\n",
      "Neuron 8: weight=-0.9730637074, bias=-0.6423439980, out_weight=-0.0000000022\n",
      "Neuron 9: weight=-0.4275229871, bias=-0.5597276688, out_weight=-0.0000000001\n",
      "Initial covariance matrix F-norm: 9.024752e-16\n",
      "Step 00000 | Loss: 6.129125e-14\n",
      "Step 01000 | Loss: 8.321815e-14\n",
      "Step 02000 | Loss: 6.492550e-14\n",
      "Step 03000 | Loss: 6.085410e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000730\n",
      "Neuron 2: weight=-0.5087539554, bias=-1.4845101833, out_weight=-0.0000000116\n",
      "Neuron 3: weight=1.3871186972, bias=-0.0894590765, out_weight=0.0000000167\n",
      "Neuron 4: weight=0.5701462626, bias=-1.6712179184, out_weight=0.0000000042\n",
      "Neuron 5: weight=0.9462459087, bias=-0.2312089801, out_weight=0.0000000815\n",
      "Neuron 6: weight=-0.4947102368, bias=1.6819410324, out_weight=0.0000000189\n",
      "Neuron 7: weight=1.8427968025, bias=1.6106805801, out_weight=0.0000000973\n",
      "Neuron 8: weight=-0.9730637074, bias=-0.6423439980, out_weight=0.0000001487\n",
      "Neuron 9: weight=-0.4275229871, bias=-0.5597276688, out_weight=0.0000000237\n",
      "Final covariance matrix F-norm: 9.600125e-16\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.0000000026\n",
      "Neuron 2: weight=0.0627807155, bias=-0.1577868015, out_weight=0.0000000002\n",
      "Neuron 3: weight=0.4041003287, bias=0.8984649777, out_weight=0.0000000039\n",
      "Neuron 4: weight=0.3627027273, bias=0.2168322802, out_weight=0.0000000001\n",
      "Neuron 5: weight=-0.5325087905, bias=-1.1262111664, out_weight=0.0000000044\n",
      "Neuron 6: weight=-0.8229341507, bias=-0.5619962811, out_weight=0.0000000025\n",
      "Neuron 7: weight=0.4416505694, bias=1.3876866102, out_weight=0.0000000019\n",
      "Neuron 8: weight=-0.3808001578, bias=-0.1641462743, out_weight=0.0000000009\n",
      "Neuron 9: weight=-1.9380471706, bias=0.9211302996, out_weight=-0.0000000001\n",
      "Initial covariance matrix F-norm: 9.811135e-16\n",
      "Step 00000 | Loss: 7.630702e-14\n",
      "Step 01000 | Loss: 2.865937e-14\n",
      "Step 02000 | Loss: 1.147225e-13\n",
      "Step 03000 | Loss: 6.760738e-14\n",
      "Trained network parameters by neuron with lr=0.01 :\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.0000000210\n",
      "Neuron 2: weight=0.0627807155, bias=-0.1577868015, out_weight=-0.0000000131\n",
      "Neuron 3: weight=0.4041003287, bias=0.8984649777, out_weight=0.0000000005\n",
      "Neuron 4: weight=0.3627027273, bias=0.2168322802, out_weight=0.0000000194\n",
      "Neuron 5: weight=-0.5325087905, bias=-1.1262111664, out_weight=0.0000000512\n",
      "Neuron 6: weight=-0.8229341507, bias=-0.5619962811, out_weight=0.0000000659\n",
      "Neuron 7: weight=0.4416505694, bias=1.3876866102, out_weight=0.0000000345\n",
      "Neuron 8: weight=-0.3808001578, bias=-0.1641462743, out_weight=-0.0000000228\n",
      "Neuron 9: weight=-1.9380471706, bias=0.9211302996, out_weight=-0.0000000141\n",
      "Final covariance matrix F-norm: 9.823523e-16\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.01\n",
    "m=10\n",
    "PINN = Sequentialmodel(m)\n",
    "PINN.to(device)\n",
    "\n",
    "'Neural Network Summary'\n",
    "print(PINN)\n",
    "print('\\n')\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",
    "    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",
    "    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.597e-07\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\user\\AppData\\Local\\Temp\\ipykernel_63888\\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+naQAAy8pJREFUeJzs3Xd4FNXbxvHvbnpPCCGd3luA0EsooRepKlgoCip2UVEsFEVBX0FUELtYf6IGBQVBDL0Teu9FSggtCell5/0DWAkECJBkE7g/17UXmTNnznlms2z22XPmjMkwDAMRERERERERyXdmWwcgIiIiIiIicrtS0i0iIiIiIiJSQJR0i4iIiIiIiBQQJd0iIiIiIiIiBURJt4iIiIiIiEgBUdItIiIiIiIiUkCUdIuIiIiIiIgUECXdIiIiIiIiIgVESbeIiIiIiIhIAVHSLSIid7yDBw9iMpl47733rlt39OjRmEymQohKrmbatGmYTCYOHjxo61CKhbJlyzJw4EBbh1HkLVq0CJPJxKJFi2wdiojcZpR0i4gUsosJw8WHs7MzlStX5sknn+TEiRPWehc/AP76669XHOvs7MzRo0evaLtVq1bUrFkzR1nZsmUxmUw89dRTV9TPrY/cXExKr/YYP378jT4NcsGlr4dly5Zdsd8wDEJDQzGZTHTt2tUGERZfAwcOxN3d/ar73d3di3wyOmfOHEaPHm2z/j/++GOmTZuWr23m9n7i6elJnTp1mDx5MtnZ2fnan4iIrdnbOgARkTvVG2+8Qbly5UhLS2PZsmVMnTqVOXPmsHXrVlxdXa95bHp6OuPHj+ejjz7Kc3+ff/45I0aMICgo6KZj7tevH507d76ivG7dujfdppzn7OzMjz/+SPPmzXOUL168mCNHjuDk5GSjyMSW5syZw5QpU24p8d61axdm882Ns3z88ceULFmyQL6cuPT9JCEhgTlz5vDUU09x6NAh/u///i/f+xMRsRUl3SIiNtKpUyfq168PwODBg/H19WXixInMnDmTfv36XfPYOnXq3FASXaNGDXbt2sX48eP58MMPbzrmevXq8cADD9z08XJ1nTt35pdffuHDDz/E3v6/P88//vgj4eHhnDp1yobRSWFLTk7Gzc0tX9oqql/YXP5+8vjjj9OoUSN+/PFHJd0iclvR9HIRkSKiTZs2ABw4cOC6dV955RWys7PzPK27bNmy9O/fn88//5xjx47dUpx56atr164sW7aMhg0b4uzsTPny5fn2229z1MvMzGTMmDFUqlQJZ2dnfH19ad68OfPnz89Rb+fOnfTp04cSJUrg7OxM/fr1mTVrVo46F6doL1u2jKeffho/Pz+8vb159NFHycjIID4+nv79++Pj44OPjw/Dhw/HMIxc43///fcpU6YMLi4utGzZkq1bt+bpvL///nvCw8NxcXGhRIkS9O3bl3///TfPz1u/fv04ffp0jvPPyMjg119/5b777sv1GIvFwqRJk6hRowbOzs74+/vz6KOPcvbs2Rz1Zs6cSZcuXQgKCsLJyYkKFSrw5ptvXjGN9+LlCdu3b6d169a4uroSHBzMu+++m6dz+Prrr2nTpg2lSpXCycmJ6tWrM3Xq1Cvq5fU1ArBt2zbatGmDi4sLISEhjB07FovFkqd4btTF19Hy5csZNmwYfn5+uLm50bNnT06ePHlF/b/++ouWLVvi4eGBp6cnDRo04Mcff8xRZ/Xq1XTs2BEvLy9cXV1p2bIly5cvz1Hn4joB27dv57777sPHx4fmzZszcOBApkyZApBjKvZF7733Hk2bNsXX1xcXFxfCw8NzvVTk8mu683qeZcuWZdu2bSxevNjad6tWrdi/fz8mk4n333//ir5WrFiByWTif//7X96e9EuYTCb8/f1zfOkEBfP6PXLkCD169MDNzY1SpUrx3HPPkZ6efsMxi4jkhZJuEZEiYt++fQD4+vpet265cuVuOIl+9dVXycrKuqXrr1NSUjh16tQVj6ysrBz19u7dS58+fWjXrh0TJkzAx8eHgQMHsm3bNmud0aNHM2bMGFq3bs3kyZN59dVXKV26NOvXr7fW2bZtG40bN2bHjh28/PLLTJgwATc3N3r06MFvv/12RXxPPfUUe/bsYcyYMdx111189tlnvP7663Tr1o3s7Gzefvttmjdvzv/93//x3XffXXH8t99+y4cffsgTTzzBiBEj2Lp1K23atMlxrX1u3nrrLfr370+lSpWYOHEizz77LNHR0URERBAfH5+n57Zs2bI0adIkR7Ly119/kZCQQN++fXM95tFHH+XFF1+kWbNmfPDBBwwaNIgffviBDh06kJmZaa03bdo03N3dGTZsGB988AHh4eGMHDmSl19++Yo2z549S8eOHQkLC2PChAlUrVqVl156ib/++uu65zB16lTKlCnDK6+8woQJEwgNDeXxxx+3Jo6XystrJDY2ltatW7Nx40Zefvllnn32Wb799ls++OCD68ZyK5566ik2bdrEqFGjGDp0KH/88QdPPvlkjjrTpk2jS5cunDlzhhEjRjB+/Hjq1KnD3LlzrXUWLFhAREQEiYmJjBo1irfffpv4+HjatGnDmjVrruj37rvvJiUlhbfffpshQ4bw6KOP0q5dOwC+++476+OiDz74gLp16/LGG2/w9ttvY29vz913383s2bPz5TwnTZpESEgIVatWtfb96quvUr58eZo1a8YPP/xwRZs//PADHh4edO/e/br9X/p+sn//fqZMmcLcuXMZMGBAjnr5/fpNTU0lMjKSefPm8eSTT/Lqq6+ydOlShg8fnqfnTUTkhhkiIlKovv76awMw/vnnH+PkyZPGv//+a/z000+Gr6+v4eLiYhw5csQwDMNYuHChARi//PLLFceuXbvW2Ldvn2Fvb288/fTT1v0tW7Y0atSokaO/MmXKGF26dDEMwzAGDRpkODs7G8eOHbtqH7k5cOCAAVz1sXLlyhz9AcaSJUusZXFxcYaTk5Px/PPPW8vCwsKscV1NZGSkUatWLSMtLc1aZrFYjKZNmxqVKlW64nnp0KGDYbFYrOVNmjQxTCaT8dhjj1nLsrKyjJCQEKNly5ZXnN+lz79hGMbq1asNwHjuueesZaNGjTIu/fN58OBBw87OznjrrbdyxL5lyxbD3t7+ivLLXfo7nTx5suHh4WGkpKQYhmEYd999t9G6dWvDMHL+Hg3DMJYuXWoAxg8//JCjvblz515RfrG9Sz366KOGq6trjue2ZcuWBmB8++231rL09HQjICDA6N279zXP42r9dOjQwShfvnyOsry+Rp599lkDMFavXp2jnpeXlwEYBw4cuGY8AwYMMNzc3K66383NzRgwYIB1++Lvom3btjleR88995xhZ2dnxMfHG4ZhGPHx8YaHh4fRqFEjIzU1NUebF4+zWCxGpUqVrnhNpqSkGOXKlTPatWtnLbv4murXr98VMT7xxBPG1T6uXf58Z2RkGDVr1jTatGmTo7xMmTI3dZ6GYRg1atTI8X/lok8//dQAjB07duTov2TJkjn6ys213k+GDh2aI6bcztMwbu31O2nSJAMwfv75Z2tZcnKyUbFiRQMwFi5ceM34RURulEa6RURspG3btvj5+REaGkrfvn1xd3fnt99+Izg4OE/Hly9fngcffJDPPvuM48eP5+mY11577ZZGux955BHmz59/xaN69eo56lWvXp0WLVpYt/38/KhSpQr79++3lnl7e7Nt2zb27NmTa19nzpxhwYIF3HPPPZw7d846Inb69Gk6dOjAnj17rljB/eGHH84x/bZRo0YYhsHDDz9sLbOzs6N+/fo5YrmoR48eOZ7/hg0b0qhRI+bMmXPV52TGjBlYLBbuueeeHKP/AQEBVKpUiYULF1712Mvdc889pKam8ueff3Lu3Dn+/PPPq04t/+WXX/Dy8qJdu3Y5+g0PD8fd3T1Hvy4uLtafLz6XLVq0ICUlhZ07d+Zo193dPcd1to6OjjRs2DDX5+tyl/aTkJDAqVOnaNmyJfv37ychISFH3by8RubMmUPjxo1p2LBhjnr333//dWO5FY888kiO11GLFi3Izs7m0KFDAMyfP59z587x8ssv4+zsnOPYi8dt3LiRPXv2cN9993H69Gnr7yc5OZnIyEiWLFlyxTT5xx577IbivPT5Pnv2LAkJCbRo0SLHbJFbOc9rueeee3B2ds4x2j1v3jxOnTqV53UfLn0/iYqK4oknnuDTTz9l2LBhOerl9+t3zpw5BAYG0qdPH2uZq6srjzzySJ7iFhG5UVpITUTERqZMmULlypWxt7fH39+fKlWq3PAKw6+99hrfffcd48ePz9OU20sT9dymZl5PpUqVaNu27XXrlS5d+ooyHx+fHNcav/HGG3Tv3p3KlStTs2ZNOnbsyIMPPkjt2rWB89OPDcPg9ddf5/XXX8+1n7i4uBxJ8uX9enl5ARAaGnpF+eXXPV88v8tVrlyZn3/++Wqnyp49ezAMI9djARwcHK567OX8/Pxo27YtP/74IykpKWRnZ+dIDC7vNyEhgVKlSuW6Py4uzvrztm3beO2111iwYAGJiYk56l2eDIeEhFxxH3IfHx82b9583fiXL1/OqFGjWLlyJSkpKVf0c/H3AXl7jRw6dIhGjRpdUa9KlSrXjSWvcrvn+uWx+fj4AFhju3gpyOW357vUxS+TLp8qfamEhARr23D+spEb8eeffzJ27Fg2btyY43rkvN5H/nrneS3e3t5069aNH3/8kTfffBM4P7U8ODjYuj7F9Vz+ftKrVy9MJhOTJk3ioYceolatWkD+v34PHTpExYoVr6iXn68rEZFLKekWEbGRhg0bWlcvv1nly5fngQceuKEk+tVXX+W7777jnXfeoUePHrfU/9XY2dnlWm5csnhZREQE+/btY+bMmfz999988cUXvP/++3zyyScMHjzYOgr4wgsv0KFDh1zbq1ixYp76za3cuMpCajfKYrFgMpn466+/cu3nWveJzs19993HkCFDiI2NpVOnTnh7e1+131KlSuV6XS2cT+AB4uPjadmyJZ6enrzxxhtUqFABZ2dn1q9fz0svvXTFaGtefne52bdvH5GRkVStWpWJEycSGhqKo6Mjc+bM4f3338+3fm6Es7Mz6enpGIZxRYJlGAZpaWlXjFTnV2wXz/f//u//qFOnTq51Ln9tXDqiez1Lly7lrrvuIiIigo8//pjAwEAcHBz4+uuvr1jM7Wpu9Tz79+/PL7/8wooVK6hVqxazZs3i8ccfv+nbkwFERkYyefJklixZQq1atQrt9SsiUpCUdIuIFHOvvfYa33//Pe+8806e6leoUIEHHniATz/9NNdRxMJUokQJBg0axKBBg0hKSiIiIoLRo0czePBgypcvD5wfKc7L6Hp+yG2q++7duylbtuxVj6lQoQKGYVCuXDkqV658yzH07NmTRx99lFWrVjF9+vRr9vvPP//QrFmzayZrixYt4vTp08yYMYOIiAhreV5Wyb8Rf/zxB+np6cyaNSvHCOqNTK+/XJkyZXL9nezatSvPx2dlZbFv374rvqDZu3cv2dnZlClT5objqlChAgBbt269ot3L63h6et7S6/dqo9ZRUVE4Ozszb968HLcE+/rrr2+6rxvpH6Bjx474+fnxww8/0KhRI1JSUnjwwQdvqb+LizImJSUBBfP6LVOmDFu3br3iy5i8vq5ERG6UrukWESnmLk2iY2Nj83TMa6+9RmZmZp5vBVUQTp8+nWPb3d2dihUrWqfJlipVilatWvHpp5/mes16brdwulW///57juvE16xZw+rVq+nUqdNVj+nVqxd2dnaMGTPmitE0wzCuOM/rcXd3Z+rUqYwePZpu3bpdtd4999xDdna2dWrvpbKysqyrpl8c+bs0toyMDD7++OMbiut6cusnISHhlpLAzp07s2rVqhwrfZ88efKqo/uXu/h7mzx58hX7Lq6ofq3f7dW0b98eDw8Pxo0bR1paWo59F88/PDycChUq8N5771kTyEvl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0YvTp09cUqMkcG+OY+ztDhMcsJu6Ycl06ORPn761KVmyC9ClMEMXKTaGDTv/uBmXrFVW5Pn5+TFgwAAGDBhAixYtePHFF3nvvfeoV68e06dPp1SpUnje6rcDuVi1ahURERHA+VsQrlu3jieffDLXuvXq1WP79u3X/YLhakqUKMFdd93Fzz//zCeffHLVPnbt2nXVPtatW4fFYmHChAnWkf2ff/75puLJb0q6RURERG5RRkY2P/+8m+nTT7BmjStxcZWB6hceAMHAf0m3nd0KnJ02UqXCv7Rp7ch9/WtRN7w0cPvcIkdEID09ndjY2Bxl9vb2lCxZMk/Hjxw5kvDwcGrUqEF6ejp//vmndar2/fffz//93//RvXt33njjDUJCQjh06BAzZsxg+PDhORZFuxlTpkyhUqVKVKtWjffff5+zZ8/y0EMP5Vr3pZdeonHjxjz55JMMHjwYNzc3tm/fzvz586+YJn4106ZN4+OPP851oTY4/1x07dqV0qVL06dPH8xmM5s2bWLr1q2MHTuWihUrkpmZyUcffUS3bt1Yvnz5VRP4wqakW0REROQGZWdnExOzibfeOsfq1S7ExVUBql14XMnFOYI2zcw0a9yAZq06Ub9p5IWpjnUKMWoRKWxz584lMDAwR1mVKlXYuXNnno53dHRkxIgRHDx4EBcXF1q0aMFPP/0EnL82ecmSJbz00kv06tWLc+fOERwcTGRkZL6MfI8fP57x48ezceNGKlasyKxZs676ZUHt2rVZvHgxr776Ki1atMAwDCpUqMC9996ba/3cuLi44OLictX9HTp04M8//+SNN97gnXfewcHBgapVqzJ48GAAwsLCmDhxIu+88w4jRowgIiKCcePG0b9//xs78QJgMgp6AvsdIDExES8vLxISEgpkaoeIiIjY3vbth1i2bB5///030dHRxMfHA0eBoCvqmkynCA7YQrPG57jvgfJ06V4dO7vL75stInmRlpbGgQMHKFeuHM7OzrYOR+4w13r95TUP1Ei3iIiISC6OHElk6tQd/PFHGjt3liYz81/g0ctqLQLusybZTRud4/4HK9K1RzXM5taFH7SIiBQ5SrpFREREgKwsC999t4MffjjJ2rU+JCZW5/wtuy4KAdyBJHy83GnTrDZVq8TSoNkWuvWsqSRbRERypaRbRERE7liJiYl8//1yJk70YP/+KhhG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6tQpITU1VRAEQZg9e7bw6quvqvtXXDJs1qxZQkpKirBixYrHXjKsqnHWJiy664iJEycKAB65RUZGqvug/Fq1FVQqlTB37lyhefPmgpGRkeDr6ytcuHCh0nbv3r0rvPTSS0KjRo0EmUwmvPbaa5UKeara016/a9euPTJOgiAIc+bMEVq1aiWUlZU9ss1//vlHcHJyEho1aiQ0bNhQ6N69u/DLL788ti89XnXHJS0tTfD09BSaNGkiGBkZCe3btxdmzZpV6TrdgiAI169fFwICAoQGDRoIzZo1Ez788MNKl66iqlV3XCIjIx/7/x4A4dq1a4IgcH95Hj/++KPQunVrwdDQUHB1dRWOHj2qXubl5SVMnDixUv8tW7YIHTt2FAwNDYUuXboIYWFhlZY/y3sNPV11xqVNmzaP3S8+//xzQRAEobCwUBg4cKBgYWEhGBgYCG3atBGmTJmilR9UdUF1xua9995T923evLkwePBg4eTJk5W2x32mZlT3/7Lz588LAIR9+/Y9si3uMy/uSe/ZFeMwceJEwcvL65F1nJycBENDQ8HW1rZSHVOhqnHWJhJB4HVTiIiIiIiIiDSBv+kmIiIiIiIi0hAW3UREREREREQawqKbiIiIiIiISENYdBMRERERERFpCItuIiIiIiIiIg1h0U1ERERERESkISy6iYiIiIiIiDSERTcRERERERGRhrDoJiIiIiIiItIQFt1EREREREREGsKim4iIiIiIiEhDWHQTERFRtWRnZ8PKygpffvmluu3IkSMwNDTEwYMHRUxGRESkfSSCIAhihyAiIiLdEh4ejhEjRuDIkSOwt7eHk5MThg8fjuXLl4sdjYiISKuw6CYiIqLnMn36dBw4cAA9e/ZEUlISjh8/DiMjI7FjERERaRUW3URERPRc7t+/j65du+LGjRs4ceIEHB0dxY5ERESkdfibbiIiInouV65cQUZGBlQqFa5fvy52HCIiIq3EI91ERERUbSUlJXB1dYWTkxPs7e3x3XffISkpCZaWlmJHIyIi0iosuomIiKjaZs2ahW3btiExMRGNGjWCl5cXzMzMsHv3brGjERERaRWeXk5ERETVEhUVhe+++w7r16+HTCaDVCrF+vXrERMTg5UrV4odj4iISKvwSDcRERERERGRhvBINxEREREREZGGsOgmIiIiIiIi0hAW3UREREREREQawqKbiIiIiIiISENYdBMRERERERFpCItuIiIiIiIiIg1h0U1ERERERESkISy6iYiIiIiIiDSERTcRERERERGRhrDoJiIiIiIiItIQFt1EREREREREGsKim4iIiIiIiEhD/j9/sDbYGTRuDQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1000x500 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAGGCAYAAABmGOKbAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQAAfcdJREFUeJzt3Xd8E/X/B/BXuktpS0vLLnvJ3gjKUJAhgoCCDGW64etGRWXpVwEHOH58Ufky/KpsQVE2Ze+9ympLoUBpy+jebT6/P44mTTOapEkuubyej0ceSe4+97l37nLJve/zuTuVEEKAiIiIiIiIiGzOQ+4AiIiIiIiIiJSKSTcRERERERGRnTDpJiIiIiIiIrITJt1EREREREREdsKkm4iIiIiIiMhOmHQTERERERER2QmTbiIiIiIiIiI7YdJNREREREREZCdMuomIiIiIiIjshEk3ERGRmWbOnAmVSiV3GA61ZcsWtGnTBn5+flCpVEhNTZU7JDLTtWvXoFKp8PXXX5dZ1h2/20REjsKkm4hIQaKiovD888+jZs2a8PX1RY0aNTB69GhERUWVq94vvvgCf/75p22CLMPBgwcxc+bMMpO7goIChIWF4dFHHzVaRgiBiIgItGvXzsZRuod79+5h+PDh8Pf3x4IFC/Drr78iICDAYNlly5ZBpVJpHn5+fmjcuDEmT56MpKQkTbndu3dDpVJh7dq1etP6+fnh1q1benX37NkTLVq00BlWt25dqFQq/Otf/9Irb2gehhQnpcYec+bMMTk9ERGRObzkDoCIiGxj3bp1GDlyJEJDQzFx4kTUq1cP165dw+LFi7F27VqsXLkSQ4YMsaruL774As8++ywGDx5s26ANOHjwIGbNmoVx48ahUqVKRst5e3tj2LBh+Omnn3D9+nXUqVNHr8zevXtx8+ZNvP322zaJ7ZNPPsGHH35ok7pcwbFjx5CRkYHPPvsMvXv3NmuaTz/9FPXq1UNubi7279+PhQsXYtOmTTh//jwqVKhgctq8vDzMmTMHP/zwg9kxLlq0CFOnTkWNGjXMnqa0kSNH4sknn9Qb3rZtW6vrJCIiKsakm4hIAWJjY/HCCy+gfv362Lt3L8LDwzXj3nzzTXTr1g0vvPACzp49i/r168sYqW2NHj0aP/74I1asWGEwGV6+fDk8PDwwYsSIcs0nKysLAQEB8PLygpeX+/x1JicnA4DJgx+l9e/fHx06dAAAvPjii6hcuTLmzZuHv/76CyNHjjQ5bZs2bSxKops3b47Lly9jzpw5+P77782OsbR27drh+eeft3p6IiIiU9i9nIhIAb766itkZ2fj559/1km4ASAsLAw//fQTsrKy8OWXX2qGjxs3DnXr1tWrq/S5nSqVCllZWfjll1803W7HjRunU/bSpUsYPnw4goKCULlyZbz55pvIzc3V1FHcjXfZsmV681OpVJg5c6amvilTpgAA6tWrp5nftWvXDH7uRx55BHXr1sXy5cv1xhUUFGDt2rV47LHHUKNGDZw9exbjxo1D/fr14efnh2rVqmHChAm4d++ewc9/4cIFjBo1CiEhIZou7IbOe126dCkef/xxVKlSBb6+vmjWrBkWLlyoF0/dunXx1FNPYf/+/ejUqRP8/PxQv359/O9//9Mrm5qairfffht169aFr68vatWqhTFjxuDu3buaMnl5eZgxYwYaNmwIX19fRERE4P3330deXp7BZVXamjVr0L59e/j7+yMsLAzPP/+8Ttfunj17YuzYsQCAjh076qx3Szz++OMAgLi4uDLLfvTRRygqKjK7W3fdunUxZswYLFq0CAkJCRbHZglz119BQQFmzZqFRo0awc/PD5UrV8ajjz6K7du365S7dOkSnn32WYSGhsLPzw8dOnTAhg0bdMoUd7vfv38/3njjDYSHh6NSpUp45ZVXkJ+fj9TUVIwZMwYhISEICQnB+++/DyGEwfjnz5+POnXqwN/fHz169MD58+fN+ty//fab5nsSGhqKESNG4MaNGxYsOSIicp/D9URECvb333+jbt266Natm8Hx3bt3R926dbFx40aL6/7111/x4osvolOnTnj55ZcBAA0aNNApM3z4cNStWxezZ8/G4cOH8f333yMlJcVgQmnK0KFDceXKFaxYsQLz589HWFgYAOgdSCimUqkwatQofPHFF4iKikLz5s0147Zs2YL79+9j9OjRAIDt27fj6tWrGD9+PKpVq4aoqCj8/PPPiIqKwuHDh/WS6WHDhqFRo0b44osvjCYyALBw4UI0b94cgwYNgpeXF/7++2+8/vrrUKvVmDRpkk7ZmJgYPPvss5g4cSLGjh2LJUuWYNy4cWjfvr0m9szMTHTr1g0XL17EhAkT0K5dO9y9excbNmzAzZs3ERYWBrVajUGD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sXbt2jKXi7Hv6NixY0VAQIDe5/vqq6/EN998IyIiIoSvr6/o1q2b5nZ+pess7Y8//hCPPvqoZt+padOmYtKkSeLy5cvGFywREelQCWGjK244EZVKhfXr12supLJq1SqMHj0aUVFRehcDqVixIqpVq4b8/HyDt9koqXLlygYvgFZ6fqY0atQIEyZMwNSpU83+PEREzmrmzJmYNWsW7ty5w148RERERAa4Rffytm3boqioCMnJyTr31yzJx8cHTZs2tXssarVa5xw6IiIiIiIiUi7FJN2ZmZmIiYnRvI+Li8Pp06cRGhqKxo0bY/To0RgzZgy++eYbtG3bFnfu3EFkZCRatWpl1UVjTM2vdu3ayMrKwueff45BgwahevXquHv3LhYsWIBbt25h2LBhNvnMRERERERE5NwUk3QfP34cjz32mOb9O++8AwAYO3Ysli1bhqVLl+Lf//433n33Xdy6dQthYWF4+OGH8dRTT9llfp6enrh06RJ++eUX3L17F5UrV0bHjh2xb98+sy4GQ0RERERERK5Pked0ExERERERETkDt7lPNxEREREREZGjMekmIiIiIiIishOXPqdbrVYjISEBgYGBUKlUcodDREREREREbkIIgYyMDNSoUQMeHsbbs1066U5ISEBERITcYRAREREREZGbunHjBmrVqmV0vEsn3YGBgQCkDxkUFCRzNEREREREROQu0tPTERERoclLjXHppLu4S3lQUBCTbiIiIiIiInK4sk515oXUiIiIiIiIiOyESTcRERERERGRnTDpJiIiIiIiIrITlz6n21xFRUUoKCiQOwyicvPx8TF5OwIiIiIiInIuik66hRBITExEamqq3KEQ2YSHhwfq1asHHx8fuUMhIiIiIiIzKDrpLk64q1SpggoVKpR5VTkiZ6ZWq5GQkIDbt2+jdu3a/D4TEREREbkAxSbdRUVFmoS7cuXKcodDZBPh4eFISEhAYWEhvL295Q6HiIiIiIjKoNiTQ4vP4a5QoYLMkRDZTnG38qKiIpkjISIiIiIicyg26S7GLrikJPw+ExERERG5FsUn3URERERERERyYdJNNnPt2jWoVCqcPn3aaJndu3dDpVI57RXle/bsibfeekvuMIiIiIicX/wfwPZuQFa83JEQOTUm3U5o3LhxUKlUeo9+/frJHZrsvvnmG4SEhCA3N1dvXHZ2NoKC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",
      "text/plain": [
       "<Figure size 1000x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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aNEig3kAEGPGjNG8//777wUAERMTk+HnURs9erQAIIKCgkSLFi3EhAkTxPHjxw3KHTt2zGQML168MBg2adIkoVKpxPXr1zXDIiMjBQAxfvx4vbKVK1cWVapU0bxfv369ACCmTp2qGZaSkiLq1KljEIOxZS9fvlwAEPv27dMMU6/rbt266ZV98OCB8PPzE61atRJpaWma4V9++aUAYHS7pQdADBgwwOT4wYMH623PpUuXCi8vL7F//369cvPmzRMAxMGDB4UQQly8eFEAELNmzdIr98knn4jg4GC9z55+PzC2Xg4fPiwAiN9++00zbPXq1QKA2L17t0H5evXqiXr16mnez5w5UwAQy5Yt0wxLTk4WNWvWFMHBwZrvhnp/zZkzp3jy5Imm7F9//SUAiI0bN5paVUIIIYYMGSIA6K2fhIQEERERIQoXLixSU1P1PndG614XANGnTx/x8OFD8eDBA3H06FHRqFEjAUBMmzZNU65QoUKiVatWBtOql9OgQQMRHh6uWceLFi0SAMSxY8c05dX728OHD8XevXsFADF9+vQMl2FMvXr1BACjj48++shgeb1799abvkOHDiJnzpya9zNmzNDEZYq5+6d6vfj7++v93vz8888CgAgPD9fsE0IIMWrUKIPfJvXn013/SUlJolKlSiJ37twiOTlZCGH8N7BRo0aifPny4tWrV5phaWlpolatWqJ48eImPx8Rkb2xejkRUToJCQkAgKxZs2ZYTj0+Pj7e5jGorxCpffrppwCAzZs323xZ6Y0bNw5//PEHKleujG3btuGrr75ClSpV8Oabb+L8+fNmzUP36t3z58/x6NEj1KpVC0IInDx50qB8//799d7XqVMH165d07zfvHkzfHx8NFe+AcDb21uzXkwt+9WrV3j06BFq1KgBADhx4kSmy965cyeSk5Px6aef6l0VHzJkiKmPK1twcDAA7b62evVqlC5dGqVKlcKjR480j4YNGwIAdu/eDUC6/7hSpUpYuXKlZl6pqalYs2YN2rRpk+FVU91xr1+/xuPHj1GsWDFky5bN6Hoxx+bNmxEeHo5u3bpphvn6+mLQoEFITEzE3r179cp36dIF2bNn17xX15DQ3damllOtWjVN9X9AWof9+vVDbGysVS3CL1y4ELly5ULu3LlRvXp1HDx4EEOHDpW1vdW1D8ytAl23bl00aNBAVrV0XYULF8aOHTsMHsZiNvbdevz4seZ3S33/+19//YW0tDSjyzN3/1Rr1KiR3q021atXBwC88847er+r6uHpt7+Pjw8++ugjzXs/Pz989NFHePDgAY4fP240xidPnuCff/5B586dkZCQoInx8ePHaNasGS5fvozbt28bnZaIyN7cJunet28f2rRpg3z58kGlUtm9K57ChQsb7a4j/YEyEbke9UGhOiEyxdzk3BLFixfXe1+0aFF4eXk5rBunbt26Yf/+/Xj69Cm2b9+O9957DydPnkSbNm307i035caNG+jVqxdy5MihuU+7Xr16AIC4uDi9slmyZDGo7p49e3Y8ffpU8/769evImzevJllVK1mypMGynzx5gsGDByNPnjwICAhArly5EBERYXTZADTjdJcFGG6DXLly6SWM1khMTASg3XcuX76Ms2fPIleuXHqPEiVKANBvwK5Lly44ePCgJoHYs2cPHjx4gC5dumS4zJcvX2L06NEoUKAA/P39ERYWhly5cuHZs2dG14s5rl+/juLFi8PLS/9wQl0dXb0u1QoWLKj3Xr0+dbe1qeUY29amliNHu3btsGPHDuzcuRNHjx7Fo0ePMG3aNIPPlBFLkmi5ibquoKAgNG7c2OBhrMuwzNZ5ly5dULt2bXz44YfIkycPunbtilWrVukl4HL2T2PLVLeqXqBAAaPD02//fPnyGVSTVy/L1G/glStXIITAN998YxDnmDFjjMZJROQobnNP9/Pnz1GxYkX07t0bHTt2tPvyjh07ptfIz5kzZ9CkSRNNAzRE5LpCQ0ORN29eREVFZVguKioKb7zxBkJCQgDAZKNN6RsEs0T6edtzWbpCQkLQpEkTNGnSBL6+vliyZAmOHj2qSaBNxdCkSRM8efIEX3zxBUqVKoWgoCDcvn0bvXr1Mria5u3tbdOYO3fujEOHDmHEiBGoVKkSgoODkZaWhubNmxu9kmdpC9LWOHPmDLy9vTUJf1paGsqXL4/p06cbLa+brHTp0gWjRo3C6tWrMWTIEKxatQqhoaEZ9kcNSLUlFi1ahCFDhqBmzZoIDQ2FSqVC165dTV7htDVT21r8/730SsifPz8aN25s9XzGjBmD+vXr4+effzar9fS6deuifv36mDp1qsHVaFvKbJ0HBARg37592L17N/7++29s3boVK1euRMOGDbF9+3Z4e3vL2j8zWqY9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MswKcrdTXFycqF69uihfvry4cuWKXncsKSkpQgh+n6y1YsUK4e/vLxYvXizOnTsn+vXrJ7Jly6Zptb9Hjx5i5MiRmvIHDx4UPj4+4ocffhDnz58XY8aMMdplWGb/VSSP3O00efJk4efnJ9asWaP3vVEfYyQkJIjhw4eLw4cPi5iYGLFz507x5ptviuLFi4tXr14p8hldndxtNG7cOLFt2zZx9epVcfz4cdG1a1eRJUsWcfbsWU0ZfpdsT+52Unv77bdFly5dDIbzu2QfCQkJmtwIgJg+fbo4efKkuH79uhBCiJEjR4oePXpoyqu7DBsxYoQ4f/68mD17ttEuwzLa9s6GSbeNREZGCgAGj927d2vK4P/7nlVLS0sT33zzjciTJ4/w9/cXjRo1EhcvXtSb7+PHj0W3bt1EcHCwCAkJER988IFeIk/yZLY+Y2JiDLabEEKMGjVKFChQQKSmphrMc8uWLaJSpUoiODhYBAUFiYoVK4p58+YZLUvmkbudbty4IerWrSty5Mgh/P39RbFixcSIESP0+ukWQojY2FjRokULERAQIMLCwsSwYcP0uqoieeRup927dxv9nQQgYmJihBD8PtnCrFmzRMGCBYWfn5+oVq2aOHLkiGZcvXr1RGRkpF75VatWiRIlSgg/Pz9RtmxZ8ffff+uNN+e/iuSTs50KFSpk9HszZswYIYQQL168EE2bNhW5cuUSvr6+olChQqJv375Oe/DpKuRsoyFDhmjK5smTR7Rs2VKcOHFCb378LtmH3N+8CxcuCABi+/btBvPid8k+TP3/q7dNZGSkqFevnsE0lSpVEn5+fqJIkSJ6OZRaRtve2aiEYD8sRERERERERPbAe7qJiIiIiIiI7IRJNxEREREREZGdMOkmIiIiIiIishMm3URERERERER2wqSbiIiIiIiIyE6YdBMRERERERHZCZNuIiIiIiIiIjth0k1ERERERERkJ0y6iYiIiIiIiOyESTcRERERERGRnTDpJiIiIiIiIrITJt1EREQe5OHDhwgPD8fEiRM1ww4dOgQ/Pz/s2rVLwciIiIjck0oIIZQOgoiIiBxn8+bNaN++PQ4dOoSSJUuiUqVKaNeuHaZPn650aERERG6HSTcREZEHGjBgAHbu3ImqVasiOjoax44dg7+/v9JhERERuR0m3URERB7o5cuXKFeuHG7evInjx4+jfPnySodERETklnhPNxERkQe6evUq7ty5g7S0NMTGxiodDhERkdvilW4iIiIPk5ycjGrVqqFSpUooWbIkZs6ciejoaOTOnVvp0IiIiNwOk24iIiIPM2LECKxZswanT59GcHAw6tWrh9DQUGzatEnp0IiIiNwOq5cTERF5kD179mDmzJlYunQpQkJC4OXlhaVLl2L//v2YO3eu0uERERG5HV7pJiIiIiIiIrITXukmIiIiIiIishMm3URERERERER2wqSbiIiIiIiIyE6YdBMRERERERHZCZNuIiIiIiIiIjth0k1ERERERERkJ0y6iYiIiIiIiOyESTcRERERERGRnTDpJiIiIiIiIrITJt1EREREREREdsKkm4iIiIiIiMhOmHQTERERERER2cn/AYN5BUdKtcMgAAAAAElFTkSuQmCC",
      "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",
    "\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",
    "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",
    "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",
    "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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L774Al27doVGo1Havb29kZqaWqvFERERERHpY/BM7Llz59C8efNK7ZcvX1aFWiIiIiKiumJwiO3SpQu+++475X1FcP3888/h7+9fe5UREREREVXB4NMJ5syZg379+uHYsWO4du0aFi5ciGPHjuHXX39FXFxcXdRIRERERKRi8EzsY489hqSkJFy7dg0dO3bEDz/8gObNmyM+Ph6+vr51USMRERERkYrBM7EA0Lp1ayxfvry2ayEiIiIiqpEahdiCgoIaD2hjY3PbxRARERER1USNQqydnV2N7zxQVlZ2RwUREREREd1KjUJsbGys8v/p6emYOnUqRo4cqdyNID4+HmvWrEF4eHjdVElEREREdIMahdiAgADl/2fNmoX58+dj2LBhStvAgQPRsWNHLFu2DMHBwbVfJRERERHRDQy+O0F8fDy6dOlSqb1Lly747bffDBorPDwcjzzyCKytrdG8eXMMHjwYJ06cUPUpKirC+PHj0bRpU1hZWSEoKAg5OTmGlk1ERERE9xCDQ6yLi4veOxN8/vnncHFxMWisuLg4jB8/HgkJCdi9ezdKS0vRt29fXL58WekzefJk7NixA5s3b0ZcXByysrIwZMgQQ8smIiIionuIwbfYioiIQFBQEHbu3Ak/Pz8AwG+//YaUlBRs2bLFoLGio6NV71evXo3mzZsjMTERPXv2RH5+PlasWIENGzagd+/eAIBVq1bBy8sLCQkJ6Nq1q6HlExEREdE9wOCZ2KeffhopKSkYMGAALly4gAsXLmDAgAH466+/8PTTT99RMfn5+QAAe3t7AEBiYiJKS0vRp08fpU+7du3g6uqK+Ph4vWMUFxejoKBA9SIiIiKie8ttPeygVatWmDNnTq0WUl5ejkmTJqF79+7o0KEDACA7OxtarRZ2dnaqvo6OjsjOztY7Tnh4OGbOnFmrtRERERFRw3JbITYvLw8rVqxAcnIyAMDb2xujR4+Gra3tbRcyfvx4HD16FD///PNtjwEAYWFhCA0NVd4XFBQYfK4uERERETVsBp9OcPDgQbRu3RoRERHK6QTz589H69atcejQodsqYsKECfj2228RGxuLVq1aKe1OTk4oKSlBXl6eqn9OTg6cnJz0jqXT6WBjY6N6EREREdG9xeAQO3nyZAwcOBDp6enYunUrtm7dirS0NDzzzDOYNGmSQWOJCCZMmIBt27Zh79698PDwUC339fWFmZkZYmJilLYTJ04gIyNDedACEREREd1/DD6d4ODBg1i+fDlMTf9vVVNTU7z99tt67x9bnfHjx2PDhg34+uuvYW1trZznamtrCwsLC9ja2iIkJAShoaGwt7eHjY0NJk6cCH9/f96ZgIiIiOg+ZnCItbGxQUZGBtq1a6dqz8zMhLW1tUFjLVmyBADQq1cvVfuqVaswcuRIANdv6WViYoKgoCAUFxcjMDAQUVFRhpZNRERERPcQg0Ps888/j5CQEHzyySfo1q0bAOCXX37BW2+9pXoUbU2IyC37mJubIzIyEpGRkYaWSkRERET3KIND7CeffAKNRoMRI0bg2rVrAAAzMzOMGzcOc+fOrfUCiYiIiIhuZnCI1Wq1WLhwIcLDw5GamgoAaN26NRo3blzrxRERERER6XNb94kFgMaNG6Njx461WQsRERERUY3UOMSOHj26Rv1Wrlx528UQEREREdVEjUPs6tWr4ebmhoceeqhGF2QREREREdWVGofYcePGYePGjUhLS8OoUaPw0ksvwd7evi5rIyIiIiLSq8ZP7IqMjMSZM2fw9ttvY8eOHXBxccHQoUOxa9cuzswSERER0V1l0GNndTodhg0bht27d+PYsWPw9vbG66+/Dnd3dxQWFtZVjUREREREKgaFWNWKJibQaDQQEZSVldVmTURERERE1TIoxBYXF2Pjxo148skn8eCDD+LIkSNYvHgxMjIyYGVlVVc1EhERERGp1PjCrtdffx2bNm2Ci4sLRo8ejY0bN6JZs2Z1WRsRERERkV41DrFLly6Fq6srPD09ERcXh7i4OL39tm7dWmvFERERERHpU+MQO2LECGg0mrqshYiIiIioRgx62AERERERUUNw23cnICIiIiKqLwyxRERERGR0GGKJiIiIyOgwxBIRERGR0WGIJSIiIiKjwxBLREREREaHIZaIiIiIjA5DLBEREREZHYZYIiIiIjI6DLFEREREZHQYYomIiIjI6DDEEhEREZHRYYglIiIiIqPDEEtERERERqdeQ+yPP/6IAQMGwNnZGRqNBtu3b1ctFxFMmzYNLVq0gIWFBfr06YOUlJT6KZaIiIiIGox6DbGXL1+Gj48PIiMj9S7/6KOPsGjRIixduhT79++HpaUlAgMDUVRUdJcrJSIiIqKGxLQ+N96vXz/069dP7zIRwYIFC/De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",
      "text/plain": [
       "<Figure size 700x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAArIAAAC+CAYAAADJJOzSAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQAANOlJREFUeJzt3XlcVNX/P/DXsMww7IjIpmLgArigSZm54FJu5JKWpuS+pWba4vax3MrMVi1TMxfK3crKxCUz0bRMrcQNFRGEFEURE0RF4P37w9/crwMDDAiOF17Px2MeD+fOuee+z5yZ8T1vzr2jEREBEREREZHKWFk6ACIiIiKi0mAiS0RERESqxESWiIiIiFSJiSwRERERqRITWSIiIiJSJSayRERERKRKTGSJiIiISJWYyBIRERGRKjGRJSIiIiJVYiJLD6XIyEhoNBocOnSo2LZt2rRBmzZtyj8oeigNGjQItWrVsnQYRERkAUxkVcqQ6BV2279/v6VDpP8vKysLM2bMQHR09AM53pYtWzBjxowHciwyz5o1azBv3jxLh1GmYmNj0alTJzg6OqJKlSro378/Ll++XOJ+4uPjYWdnV+gX1x07dqBly5awt7eHm5sbnnvuOSQmJhZol5mZifHjx6N69erQ6XQICgrCokWLTB7T3D4ZJ+MkFRBSpRUrVggAmTVrlqxcubLA7fLly5YO8b4Yxnfw4MFi24aFhUlYWFj5B1VKly9fFgAyffr0B3K8MWPGSGV6a2dnZ8utW7csHUaRwsPDxc/Pz9JhlJnk5GSpWrWqBAQEyPz582X27Nni5uYmISEhcvv27RL11bVrV3FwcDD5fv/pp5/EyspKQkNDZf78+fL2229L1apVxdfXV1JTU5V2OTk58uSTT4pWq5VXX31VFi5cKN27dxcAMnv27FL1yTgZJ6lD5fnfroIpSaKnRkxkS+9BJrKZmZkP5DhqV9ES2VGjRoler5dz584p23bs2CEA5IsvvjC7n23btolWq5U333zT5Ps9ODhYateubZQcHz58WKysrOS1115Ttm3YsEEAyLJly4z279Wrl9jZ2cmlS5dK3CfjZJykDkxkVcrcRC8hIUEAyAcffCBffPGF+Pv7i1arldDQUDlw4IBR25SUFBk0aJD4+vqKVqsVLy8v6datmyQkJBi127Jli7Rs2VLs7e3F0dFRunTpIseOHTNqM3DgQHFwcJBz585JeHi4ODg4iI+PjyxYsEBERI4cOSJt27YVe3t7qVmzpqxevdrk+Hbv3i0jRoyQKlWqiJOTk/Tv31+uXr1q1NZUInvr1i2ZNm2aBAQEiFarlerVq8uECRPMrtxt2LBBHn30UbGzsxN3d3eJiIiQf//9t9jjGsZuSFoMz3/+myGpNTxP8fHx0qFDB7G3txdvb2+ZOXOm5OXlKX3u2rVLAMiuXbuMjmXof8WKFUp/po5XlNzcXJk+fbp4e3uLXq+XNm3ayPHjx8XPz08GDhyotDPMSXR0tIwaNUo8PDzE1dVVefzzzz+X4OBg0Wq14u3tLaNHj5b09HSjY+Xvs7Dn0jDedevWyZQpU8TT01Ps7e2la9eukpSUVOjzfe9zYs5rXuTuXAcFBYlOp5P69evLxo0bC/RZmB9++EG6dOki3t7eotVqxd/fX2bNmiU5OTlGY8s/H0X1vXz5cpP/Oc+ePVsASFRUVLFxlbdq1arJ888/X2B73bp1pX379mb1kZ2dLfXq1ZMJEyaY/DxLS0sTADJhwoQC+9avX198fHyU+2PHjhUAcuPGDaN233zzjQCQJUuWlLhPxlm54yT14BpZlfvvv/9w5coVo1taWlqBdmvWrMEHH3yAkSNH4p133kFiYiJ69uyJO3fuKG169eqF77//HoMHD8bChQvxyiuvICMjA0lJSUqblStXIjw8HI6Ojpg7dy7eeustnDhxAi1btiyw1ig3NxedO3dGjRo18P7776NWrVp4+eWXERkZiU6dOiE0NBRz586Fk5MTBgwYgISEhAJxv/zyy4iNjcWMGTMwYMAArF69Gj169ICIFPqc5OXloVu3bvjwww/RtWtXfPbZZ+jRowc++eQT9OnTp9jnNDIyEr1794a1tTXmzJmD4cOHY+PGjWjZsiWuXbtW7P738vDwUNZrPfvss1i5ciVWrlyJnj17Gj1PnTp1gqenJ95//300bdoU06dPx/Tp00t0LAAYOXIknn76aQBQjrVy5coi95kyZQpmzpyJ0NBQfPDBB6hTpw46duyIGzdumGw/evRonDhxAtOmTcPkyZMBADNmzMCYMWPg4+ODjz76CL169cIXX3yBDh06GL3GSmr27NmIiorCpEmT8Morr2DHjh146qmncPPmzWL3Nec1HxUVhT59+sDW1hZz5sxBz549MXToUPz1119mxRcZGQlHR0e89tprmD9/Ppo2bWr0vADA1KlT0bhxY1StWlWZj6LWyw4ePBjPPPMMXnvtNSQnJwMAjh49ipkzZ2Lo0KHo0qVLkTFlZmYW+Ewwdfvvv//MGmN+58+fR2pqKkJDQws89vjjj+Off/4xq5958+YhPT0db775psnHb9++DQDQ6/UFHrO3t8eFCxdw8eJFpa21tTW0Wm2BdgCU+SxJn4yzcsdJKmLpTJpKx/BN1tRNp9Mp7QzVKXd3d6NK5o8//igA5KeffhIRkfT0dKWKVZiMjAxxdXWV4cOHG22/ePGiuLi4GG03VAbfffddZVt6erro9XrRaDSybt06ZfvJkycL/OndML6mTZtKdna2sv39998XAPLjjz8q2/JX81auXClWVlby22+/GcW5ePFiASD79u0rdIzZ2dlSrVo1adCggdy8eVPZvnnzZgEg06ZNK/S494793opbUUsLDM/T2LFjlW15eXkSHh4uWq1WWetsbkVWpGRLCy5evCg2NjbSo0cPo+0zZswQACYrsi1btjSqOKampopWq5UOHTpIbm6usn3BggUCQJYvX65sK2lF1tfXV65fv65sN/wpcf78+cq2wiqyxb3mRUQaNmwo1atXl4yMDGVbdHR0sVVTg6ysrALbRo4cKfb29kbV/5IuLUhJSZEqVarI008/Lbdv35YmTZpIzZo15b///it238Kq8vlvpV2Oc/DgQQEgX3/9dYHHJkyYIACK/ctHSkqKODk5KcsQTFXmcnNzxdXVtUCF98qVK8raykOHDomIyEcffSQACrznJ0+eLADkmWeeKXGfjLPyxknqwoqsyn3++efYsWOH0W3r1q0F2vXp0wdubm7K/VatWgEAzp49C+DuN1WtVovo6Gikp6ebPNaOHTtw7do19O3b16iyY21tjWbNmmHXrl0F9hk2bJjyb1dXV9SrVw8ODg7o3bu3sr1evXpwdXVVYrnXiBEjYGtrq9wfNWoUbGxssGXLlkKfk2+++QZBQUEIDAw0irNdu3YAYDJOg0OHDiE1NRWjR4+GnZ2dsj08PByBgYGIiooqdN/78fLLLyv/1mg0ePnll5GdnY1ffvmlXI5nsHPnTuTk5GD06NFG28eOHVvoPsOHD4e1tbVy/5dffkF2djbGjx8PKysro3bOzs739ZwNGDAATk5Oyv3nnnsO3t7eRc6/QXGv+QsXLuDo0aMYMGAAHB0dlXZhYWFo2LChWfHdW+HJyMjAlStX0KpVK2RlZeHkyZNm9WGKl5eX8t5u1aoVDh8+jOXLl8PZ2bnYfSdOnFjgM8HU7aOPPipVbIZquE6nK/CY4T1TXMV80qRJ8Pf3N/p8yM/KygojR47Ezp07MWXKFMTFxeGvv/5C7969kZ2dbXScfv36wcXFBUOGDMGOHTuQmJiIJUuWYOHChUbtStIn46y8cZK62Fg6ALo/jz/+uMk/8eVXs2ZNo/uG/+ANSatOp8PcuXPx+uuvw9PTE0888QSeeeYZDBgwAF5eXgCAuLg4AFASwvzy/ydrZ2cHDw8Po20uLi6oXr06NBpNge2mEug6deoY3Xd0dIS3t3eRl0yJi4tDbGxsgWMbpKamFrrvuXPnANxNrvMLDAzE3r17C923tKysrODv72+0rW7dugBQ7peGMYy3du3aRturVKlilATe65FHHjHZR/7nTKvVwt/fX3m8NPLPv0ajQe3atc16Xop7zRc2dsO2v//+u9hjHD9+HG+++SZ+/fVXXL9+3eix0v7p3uCFF17AqlWrEBUVhREjRqB9+/Zm7RccHIzg4OD7OjZwd4lCZmamct/a2hoeHh5K8m74c+29bt26BcD0n3AN9u/fj5UrV2Lnzp1GX3xMmTVrFq5cuYL3338f7733HgCgQ4cOGDp0KBYvXqx8AfHy8sKmTZvQv39/dOjQAcDdz6PPPvsMAwcONPqiYm6fjLNyxknqw0S2kri3gnYvuWet6fjx49G1a1f88MMP2L59O9566y3MmTMHv/76K5o0aYK8vDwAd9deGpLbe9nYGL+cCjumObHcj7y8PDRs2BAff/yxycdr1KhRJsfRaDQmY87NzS2T/vMfy5TyOFZxikpSilPUOAp7XZRWeb/Orl27hrCwMDg7O2PWrFkICAiAnZ0d/v77b0yaNEl5v5RWWlqacn3NEydOIC8vr9gEALibQJtTXdJqtahSpUqhj3/44YeYOXOmct/Pzw+JiYnw9vYGAKSkpBTYJyUlBVWqVDFZrTWYOHEiWrVqhUceeUT5QnLlyhVl/6SkJOVLiFarxdKlSzF79mycPn0anp6eqFu3Lvr16wcrKyujLyGtW7fG2bNncfToUdy4cQMhISG4cOECgP/7YliSPhln5YyT1IeJLBkJCAjA66+/jtdffx1xcXFo3LgxPvroI6xatQoBAQEAgGrVquGpp556IPHExcWhbdu2yv3MzEykpKQUecJLQEAAYmJi0L59+0ITp8L4+fkBAE6dOlWg8nzq1CnlceBuhc/Ucoj8FcjiYsjLy8PZs2eNPnRPnz4NAMovVhmqiflPNjNV7SzJmA3jOXPmjFGlNS0trdAlJoX1cerUKaPKcnZ2NhISEoxeK25ubiZPmDt37lyBqjTwf38FMBARnDlzBo0aNTIrNnPiPnPmTIHHTG3LLzo6Gmlpadi4cSNat26tbDd10mJJX4cAMGbMGGRkZGDOnDmYMmUK5s2bh9dee63Y/caNG4evvvqq2HZhYWFF/kjHgAED0LJlS+W+4QuMr68vPDw8TF7E/sCBA2jcuHGRx01KSsK5c+cKVPYBoFu3bnBxcSnwGvH09ISnpyeAu196oqOj0axZswJVNGtra6PjG5bmmPq8Kq5Pxlk54yT1YSJLAO7++pSVlZXRutCAgAA4OTkpf0Ls2LEjnJ2d8e6776Jt27ZGa1cB4PLly4X+Ob+0lixZgsGDByvHWrRoEXJyctC5c+dC9+nduze2bNmCL7/8EiNGjDB67ObNm8jLy4ODg4PJfUNDQ1GtWjUsXrwYQ4YMUSpLW7duRWxsLKZNm6a0DQgIwJYtW4zGHRMTg3379hlVfQ1n0BZ1xYMFCxbg008/BXA3WVuwYAFsbW2VPyf7+fnB2toae/bsQY8ePZT9DGvB7mUY27Vr1+Dq6lroMQGgffv2sLGxwaJFi5SrHRjiMddTTz0FrVaLTz/9FJ06dVKStmXLluG///5DeHi40jYgIAC//fYbsrOzlTONN2/ejOTkZJOJ7Ndff40pU6Yo62S//fZbpKSkYNKkSWbHVxgfHx80aNBAOYbhP7Ldu3fj6NGjRl9aTDFUfO+t8GZnZxc6JyVZavDtt99i/fr1+PTTTzF27FjExMTgzTffxDPPPGP0hceUiRMn4sUXXyz2GIUtHTHw9/c3OSfA3SucfPXVV0hOTlZe6zt37sTp06fx6quvKu3u3LmD+Ph4uLi4KJXcJUuWICsry6i/X3/9FZ999hk+/PBDBAYGFhnXhx9+iJSUFHz22WdFtrt8+TLmzp2LRo0aFfvF21SfjLNyxknqw0RW5bZu3WrypJInn3yy0P+ETDl9+jTat2+P3r17Izg4GDY2Nvj+++9x6dIlvPDCCwDurj1atGgR+vfvj0cffRQvvPACPDw8kJSUhKioKLRo0aJECZA5srOzlbhOnTqFhQsXomXLlujWrVuh+/Tv3x8bNmzASy+9hF27dqFFixbIzc3FyZMnsWHDBmzfvr3QdcW2traYO3cuBg8ejLCwMPTt2xeXLl3C/PnzUatWLaP/pIcMGYKPP/4YHTt2xNChQ5GamorFixejfv36Rusl9Xo9goODsX79etStWxdVqlRBgwYN0KBBAwB31xJv27YNAwcORLNmzbB161ZERUXhf//7n5Igu7i44Pnnn8dnn30GjUaDgIAAbN682eR636ZNmwIAXnnlFXTs2BHW1tbKHObn6emJcePG4aOPPkK3bt3QqVMnxMTEYOvWrahatapZlUQPDw/lEl6dOnVCt27dlLl67LHHjJKqYcOG4dtvv0WnTp3Qu3dvxMfHG1X786tSpQpatmyJwYMH49KlS5g3bx5q166N4cOHFxuXOd599110794dLVq0wODBg5Geno4FCxagQYMGRutDTXnyySfh5uaGgQMH4pVXXoFGo8HKlStNLl1o2rQp1q9fj9deew2PPfYYHB0d0bVrV5P9pqamYtSoUWjbtq1yEuCCBQuwa9cuDBo0CHv37i1yiUFZrZEtyv/+9z988803aNu2LcaNG4fMzEx88MEHaNiwIQYPHqy0O3/+PIKCgjBw4EBERkYCgLKW8V6GL3lhYWFG781Vq1bhu+++Q+vWreHo6IhffvkFGzZswLBhw9CrVy+jPsLCwtC8eXPUrl0bFy9exJIlS5CZmYnNmzcbPV/m9sk4K2ecpEKWu2AC3Y+iLr+Fey7HdO/F4fPDPZeEunLliowZM0YCAwPFwcFBXFxcpFmzZrJhw4YC++3atUs6duwoLi4uYmdnJwEBATJo0CCjy5cYLvSfX1hYmNSvX7/Adj8/PwkPDy8wPsMPIri5uYmjo6NERERIWlpagT7zX0ooOztb5s6dK/Xr1xedTidubm7StGlTmTlzplmXMFq/fr00adJEdDqdVKlSxeQPIoiIrFq1SrngfuPGjWX79u0mL6b/+++/S9OmTUWr1Ro976Z+EMHT01OmT59udCkrkbuX8erVq5fY29uLm5ubjBw5Uo4dO1bg8ls5OTkyduxY8fDwEI1GU+yluHJycuStt94SLy8v0ev10q5dO4mNjRV3d3d56aWXlHbF/QjHggULJDAwUGxtbcXT01NGjRpV4AcRRO5eMsfX11d0Op20aNFCDh06VOjlt9auXStTpkyRatWqiV6vl/DwcKNfkzI8h4X9IEJ+9z73BuvWrZPAwEDR6XTSoEED2bRpk/Tq1UsCAwOLfN5ERPbt2ydPPPGE6PV68fHxkYkTJ8r27dsLXCotMzNT+vXrJ66ursVe2qtnz57i5OQkiYmJRtsNlw+bO3dusXE9CMeOHVNes66urhIRESEXL140amOYC1OXXLtXYa+tP//8U1q3bi1ubm5iZ2cnISEhsnjxYqMfCzF49dVXxd/fX3Q6nXh4eEi/fv0kPj6+QLuS9Mk4GSc9/DQiZXTmAxGV2KBBg/Dtt98WW/170K5duwY3Nze88847mDp16gM/fnR0NNq2bYtvvvkGzz333AM/fuPGjeHh4YEdO3Y88GMTEZH5eB1ZokrO1Bnuhl+eatOmzYMN5gG7c+cOcnJyjLZFR0cjJiamwo+diKgi4BpZokpu/fr1iIyMRJcuXeDo6Ii9e/di7dq16NChA1q0aGHp8MrV+fPn8dRTT+HFF1+Ej48PTp48icWLF8PLywsvvfSSpcMjIqJiMJElquQaNWoEGxsbvP/++7h+/bpyAtg777xj6dDKnZubG5o2bYqlS5fi8uXLcHBwQHh4ON577z24u7tbOjwiIioG18gSERERkSpxjSwRERERqRITWSIiIiJSJbPWyObl5eHChQtwcnIq1U8tEhERERGZQ0SQkZEBHx+fIn8ABjAzkb1w4YLRT24SEREREZWn5ORkVK9evcg2ZiWyht85T05OhrOz8/1HRkREREQPj9RYIDIcyL2Duz8SWhgNYG0LDIoCqgWVSyjXr19HjRo1lPyzKGYlsoblBM7OzkxkiYiIiCqan78AbHP/f2ZYzDJSTS5weAnw3LJyDcmc5aw82YuIiIioMstMBY7/AEieee0lDzj+PZB5uVzDMgcTWSIiIqLKLPE3QHJLto/k3t3PwpjIEhEREVVm11NKud+Fso2jFJjIEhEREVVm/yWXcr9/yzaOUmAiS0RERFSZ2bmVcj/XMg2jNJjIEhEREVVmt9JLud+1Mg2jNJjIEhEREVVmrMgSERERkSqxIktEREREqsSKLBERERGpEiuyRERERKRKrMgSERERkSqxIktEREREqsSKLBERERGpEiuyRERERKRKrMgSERERkSqxIktEREREqsSKLBERERGpEiuyRERERKRKrMgSERERkSqxIktEREREqsSKLBERERGpEiuyRERERKRKrMgSERERkSqxIktEREREqsSKLBERERGpEiuyRERERKRKrMgSERERkSqxIktEREREqsSKLBERERGpEiuyRERERKRKrMgSERERkSqxIktEREREqsSKLBERERGpEiuyRERERKRKrMgSERERkSqxIktEREREqsSKLBERERGpEiuyRERERKRKrMgSERERkSqxIktEREREqsSKLBERERGpEiuyRERERKRKrMgSERERkSqxIktEREREqsSKLBERERGpEiuyRERERKRKrMgSERERkSqxIktEREREqsSKLBERERGpEiuyRERERKRKrMgSERERkSplnC/lfillG0cpMJElIiIiqsxybpdyv5tlG0cpMJElIiIiolLQWDoAJrJERERElZqN7sHuV4aYyBIRERFVZk6+pdzPp2zjKAUmskRERESVGS+/RURERESqxMtvEREREZEqsSJLRERERKrEiiwRERERqRIrskRERESkSqzIEhEREZEqsSJLRERERKrEiiwRERERqRIrskRERESkSqzIEhEREZEqsSJLRERERKrEiiwRERERqRIrskRERESkSqzIEhEREZEqsSJLRERERKrEiiwRERERqRIrskRERESkSqzIEhEREZEqsSJLRERERKrEiiwRERERqRIrskRERESkSqzIEhEREZEqsSJLRERERKrEiiwRERERqRIrskRERESkSqzIEhEREZEqsSJLRERERKrEiiwRERERqRIrskRERESkSqzIEhEREZEqsSJLRERERKrEiiwRERERqRIrskRERESkSiquyNpYOoDCXM64jf1n03Djdg4cdDZ4wt8dHk46S4dFREREVLGouCL70CWyJy9ex+e/nsGWYxeRmyfKdmsrDbo08MKYdrUR6OVswQiJiIiIKhAVV2QfqqUFu09fRvcF+woksQCQmyfYcuwiui/Yh92nL1soQiIiIqIKRsUV2YcmkT158TpGfH0I2Tl5BZJYg9w8QXZOHkZ8fQgnL15/wBESERERVUCsyN6/z389g5w8gekU9v8IgJw8wcJd8Q8iLCIiIqKKjRXZ+3M547bJ5QSFyc0TRB1NwZXM2+UcGREREVEFx4rs/dl/Ns3sJNYgN0+w/2xaOUVEREREVEmwInt/btzOKdV+mbdKtx8RERER/X8u1R/sfmXooUhkHXSluwqYo91Dd/UwIiIiInVx9nmw+5WhhyKRfcLfHdZWmhLtY22lwRP+7uUUEREREVElUasVoClhSqixurufhT0UiayHkw5dGniZncxaW2kQ3tAbVR35S19ERERE98WxGlD/WZidFmqsgPo9AUePcg3LHGb9bV7k7olY16+X37VbBz5WDVv/SYDk5BV5CS4NAI2NFQaEepRrPERERESVRuORwOFNQG5u8W2trYHGI4ByysMM+Z0h/yyKRsxo9e+//6JGjRr3HxkRERERkRmSk5NRvXrRJ5SZlcjm5eXhwoULcHJygkZTsrWsD4vr16+jRo0aSE5OhrOzs6XDoWJwvtSDc6UenCt14XypB+eqbIkIMjIy4OPjAyuropc7mLW0wMrKqtiMWC2cnZ35IlMRzpd6cK7Ug3OlLpwv9eBclR0XFxez2j0UJ3sREREREZUUE1kiIiIiUqVKk8jqdDpMnz4dOh0v2aUGnC/14FypB+dKXThf6sG5shyzTvYiIiIiInrYVJqKLBERERFVLExkiYiIiEiVmMgSERERkSqpIpHNyMjA+PHj4efnB71ejyeffBIHDx4scp/PP/8cQUFB0Ov1qFevHr7++mujx+/cuYNZs2YhICAAdnZ2CAkJwbZt2wrt77333oNGo8H48ePLYkgVmqXma8aMGdBoNEa3wMDAMh9fRWLJ99b58+fx4osvwt3dHXq9Hg0bNsShQ4fKdHwViaXmqlatWgXeVxqNBmPGjCnzMVYklpqv3NxcvPXWW3jkkUeg1+sREBCAt99+26yf+qysLDVXpTkumSAq0Lt3bwkODpbdu3dLXFycTJ8+XZydneXff/812X7hwoXi5OQk69atk/j4eFm7dq04OjrKpk2blDYTJ04UHx8fiYqKkvj4eFm4cKHY2dnJ33//XaC/AwcOSK1ataRRo0Yybty48hpmhWGp+Zo+fbrUr19fUlJSlNvly5fLfbxqZqm5unr1qvj5+cmgQYPkzz//lLNnz8r27dvlzJkz5T5mtbLUXKWmphq9p3bs2CEAZNeuXeU9ZFWz1HzNnj1b3N3dZfPmzZKQkCDffPONODo6yvz588t9zGplqbkq6XHJtIc+kc3KyhJra2vZvHmz0fZHH31Upk6danKf5s2byxtvvGG07bXXXpMWLVoo9729vWXBggVGbXr27CkRERFG2zIyMqROnTqyY8cOCQsLYyJbDEvO1/Tp0yUkJOQ+R1B5WHKuJk2aJC1btrzfIVQalv4cvNe4ceMkICBA8vLySjqMSsOS8xUeHi5Dhgwpsg39H0vNVWmOS6Y99EsLcnJykJubCzs7O6Pter0ee/fuNbnP7du3TbY/cOAA7ty5U2Sb/H2OGTMG4eHheOqpp+53KJWCpecrLi4OPj4+8Pf3R0REBJKSku53SBWWJedq06ZNCA0NxfPPP49q1aqhSZMm+PLLL8tiWBWSpd9XBtnZ2Vi1ahWGDBkCjUZT2uFUeJacryeffBI7d+7E6dOnAQAxMTHYu3cvOnfufN/jqogsNVelOS4VwtKZtDmaN28uYWFhcv78ecnJyZGVK1eKlZWV1K1b12T7KVOmiJeXlxw6dEjy8vLk4MGD4unpKQDkwoULIiLSt29fCQ4OltOnT0tubq78/PPPotfrRavVKv2sXbtWGjRoIDdv3hQRYUXWTJaary1btsiGDRskJiZGtm3bJs2bN5eaNWvK9evXH8i41chSc6XT6USn08mUKVPk77//li+++ELs7OwkMjLygYxbjSw1V/dav369WFtby/nz58ttnBWFpeYrNzdXJk2aJBqNRmxsbESj0ci77777QMasVpaaq5Iel0xTRSJ75swZad26tQAQa2treeyxxyQiIkICAwNNts/KypLBgweLjY2NWFtbi4+Pj0ycOFEAyMWLF0Xk7rqv7t27i5WVlVhbW0vdunVl9OjRYmdnJyIiSUlJUq1aNYmJiVH6ZSJrHkvMlynp6eni7OwsS5cuLZdxVgSWmitbW1tp3ry5Ud9jx46VJ554ovwGq3IPw/uqQ4cO8swzz5TbGCsSS83X2rVrpXr16rJ27Vo5cuSIfP3111KlShV+SSyCpeaqpMcl01SRyBpkZmYq33Z69+4tXbp0KbJ9dna2JCcnS05OjrI4Ozc316jNzZs35d9//5W8vDyZOHGiBAcHi4jI999/r7y4DDcAotFoxNraWnJycspnkBXIg5yvwoSGhsrkyZPvbyCVwIOeq5o1a8rQoUON2i9cuFB8fHzKaEQVl6XeV4mJiWJlZSU//PBD2Q2mEnjQ81W9evUCazPffvttqVevXhmNqOKy1HurpMclYw/9Gtl7OTg4wNvbG+np6di+fTu6d+9eZHtbW1tUr14d1tbWWLduHZ555hlYWRkP2c7ODr6+vsjJycF3332n9Nm+fXscPXoUhw8fVm6hoaGIiIjA4cOHYW1tXW7jrCge5HyZkpmZifj4eHh7e5fJeCqyBz1XLVq0wKlTp4zanz59Gn5+fmU3qArKUu+rFStWoFq1aggPDy/T8VR0D3q+srKyCrS3trZGXl5e2Q2qgrLUe6ukx6V8LJ1Jm2Pbtm2ydetWOXv2rPz8888SEhIizZo1k+zsbBERmTx5svTv319pf+rUKVm5cqWcPn1a/vzzT+nTp49UqVJFEhISlDb79++X7777TuLj42XPnj3Srl07eeSRRyQ9Pb3QOLi0wDyWmq/XX39doqOjJSEhQfbt2ydPPfWUVK1aVVJTUx/U0FXHUnN14MABsbGxkdmzZ0tcXJysXr1a7O3tZdWqVQ9q6Kpjyc/B3NxcqVmzpkyaNOlBDLVCsNR8DRw4UHx9fZXLb23cuFGqVq0qEydOfFBDVx1LzVVxxyXzqCKRXb9+vfj7+4tWqxUvLy8ZM2aMXLt2TXl84MCBEhYWptw/ceKENG7cWPR6vTg7O0v37t3l5MmTRn1GR0dLUFCQ6HQ6cXd3l/79+xd7AgMTWfNYar769Okj3t7eotVqxdfXV/r06cPrkhbDku+tn376SRo0aCA6nU4CAwNlyZIl5TbOisCSc7V9+3YBIKdOnSq38VU0lpqv69evy7hx46RmzZpiZ2cn/v7+MnXqVLl9+3a5jlfNLDVXxR2XzKMR4c99EBEREZH6qGqNLBERERGRARNZIiIiIlIlJrJEREREpEpMZImIiIhIlZjIEhEREZEqMZElIiIiIlViIktEREREqsREloiIiIhUiYksEaladHQ0NBoNrl27Vu7HSktLQ7Vq1ZCYmFjux7Ikc55TjUaDH3744YHFVN62bduGxo0bIy8vz9KhEFnEnj170LVrV/j4+DyQ9/eMGTOg0WiMboGBgSXuh4kskcokJydjyJAh8PHxgVarhZ+fH8aNG4e0tLQS9ZOYmAiNRoPDhw+XS5wVLdEBgNmzZ6N79+6oVauWpUOpkFJSUtCvXz/UrVsXVlZWGD9+fJn1ffDgQbRv3x6urq5wc3NDx44dERMTozzeqVMn2NraYvXq1WV2TCI1uXHjBkJCQvD5558/sGPWr18fKSkpym3v3r0l7oOJLJGKnD17FqGhoYiLi8PatWtx5swZLF68GDt37kTz5s1x9epVS4dYYWVlZWHZsmUYOnToffWTm5vLql8hbt++DQ8PD7z55psICQkps34zMzPRqVMn1KxZE3/++Sf27t0LJycndOzYEXfu3FHaDRo0CJ9++mmZHZdITTp37ox33nkHzz77rMnHb9++jTfeeAO+vr5wcHBAs2bNEB0dfV/HtLGxgZeXl3KrWrVqiftgIkukImPGjIFWq8XPP/+MsLAw1KxZE507d8Yvv/yC8+fPY+rUqUpbUxVRV1dXREZGAgAeeeQRAECTJk2g0WjQpk0bAHf/M+/RowdmzpwJDw8PODs746WXXkJ2drbST61atTBv3jyjvhs3bowZM2YojwPAs88+C41GU2gF88knn8SkSZOMtl2+fBm2trbYs2cPAGDlypUIDQ2Fk5MTvLy80K9fP6Smphb6HM2YMQONGzc22jZv3rwCMSxduhRBQUGws7NDYGAgFi5cWGifALBlyxbodDo88cQTRts3bdqEOnXqwM7ODm3btsVXX31l9Gf5yMhIuLq6YtOmTQgODoZOp0NSUhLS09MxYMAAuLm5wd7eHp07d0ZcXFyJxmHOXOXl5WHOnDl45JFHoNfrERISgm+//bbA2OrWrQu9Xo+2bduavXQiJSUFnTt3hl6vh7+/v1G/7dq1w8svv2zU/vLly9Bqtdi5c6fJ/mrVqoX58+djwIABcHFxKfS4JZ27kydP4urVq5g1axbq1auH+vXrY/r06bh06RLOnTuntOvatSsOHTqE+Ph4c4ZPVKm8/PLL+OOPP7Bu3TocOXIEzz//PDp16mT0uVVScXFx8PHxgb+/PyIiIpCUlFTiPpjIEqnE1atXsX37dowePRp6vd7oMS8vL0RERGD9+vUQEbP6O3DgAADgl19+QUpKCjZu3Kg8tnPnTsTGxiI6Ohpr167Fxo0bMXPmTLNjPXjwIABgxYoVSElJUe7nFxERgXXr1hnFvH79evj4+KBVq1YAgDt37uDtt99GTEwMfvjhByQmJmLQoEFmx2LK6tWrMW3aNMyePRuxsbF499138dZbb+Grr74qdJ/ffvsNTZs2NdqWkJCA5557Dj169EBMTAxGjhxp9GXCICsrC3PnzsXSpUtx/PhxVKtWDYMGDcKhQ4ewadMm/PHHHxARdOnSxahCaI7i5mrOnDn4+uuvsXjxYhw/fhyvvvoqXnzxRezevRvA3aUqPXv2RNeuXXH48GEMGzYMkydPNuvYb731Fnr16oWYmBhERETghRdeQGxsLABg2LBhWLNmDW7fvq20X7VqFXx9fdGuXbsSjfFepZm7evXqwd3dHcuWLUN2djZu3ryJZcuWISgoyOiLQc2aNeHp6Ynffvut1PERVURJSUlYsWIFvvnmG7Rq1QoBAQF444030LJlS6xYsaJUfTZr1gyRkZHYtm0bFi1ahISEBLRq1QoZGRkl60iISBX2798vAOT77783+fjHH38sAOTSpUsiIibburi4yIoVK0REJCEhQQDIP//8Y9Rm4MCBUqVKFblx44aybdGiReLo6Ci5ubkiIuLn5yeffPKJ0X4hISEyffp05X5RsRqkpqaKjY2N7NmzR9nWvHlzmTRpUqH7HDx4UABIRkaGiIjs2rVLAEh6erqIiEyfPl1CQkKM9vnkk0/Ez89PuR8QECBr1qwxavP2229L8+bNCz1u9+7dZciQIUbbJk2aJA0aNDDaNnXqVKN4VqxYIQDk8OHDSpvTp08LANm3b5+y7cqVK6LX62XDhg1mj6O4ubp165bY29vL77//btTP0KFDpW/fviIiMmXKFAkODi4wrnvHYAoAeemll4y2NWvWTEaNGiUiIjdv3hQ3NzdZv3698nijRo1kxowZhfZ5r7CwMBk3blyB7aWZOxGRo0ePSkBAgFhZWYmVlZXUq1dPEhMTC7Rr0qSJ2TESVVT5P783b94sAMTBwcHoZmNjI7179xYRkdjYWAFQ5K2oz/b09HRxdnaWpUuXlihWm1Kl0URkMWJmxfV+hISEwN7eXrnfvHlzZGZmIjk5GX5+fmV2HA8PD3To0AGrV69Gq1atkJCQgD/++ANffPGF0uavv/7CjBkzEBMTg/T0dGV9aVJSEoKDg0t8zBs3biA+Ph5Dhw7F8OHDle05OTlF/jn75s2bsLOzM9p26tQpPPbYY0bbHn/88QL7arVaNGrUSLkfGxsLGxsbNGvWTNnm7u6OevXqKRVNcxU1V5mZmcjKysLTTz9ttE92djaaNGmixHJvHIY+zJG/XfPmzZWTB+3s7NC/f38sX74cvXv3xt9//41jx45h06ZNJRrfvcyZu86dOysVVT8/Pxw/fhw3b97E0KFD0aJFC6xduxa5ubn48MMPER4ejoMHDxr9hUOv1yMrK6vUMRJVRJmZmbC2tsZff/0Fa2tro8ccHR0BAP7+/sV+frm7uxf6mKurK+rWrYszZ86UKDYmskQqUbt2bWg0GsTGxppcjB8bGws3Nzd4eHgAuLtGNn/SW9I/WxfGysqqzPqOiIjAK6+8gs8++wxr1qxBw4YN0bBhQwB3E5eOHTuiY8eOWL16NTw8PJCUlISOHTsarQMtSWyZmZkAgC+//LJAApf/A/peVatWRXp6eqnGqNfrodFoSrRPWTzHhrFGRUXB19fX6DGdTleivkpj2LBhaNy4Mf7991+sWLEC7dq1u68vQubM3dKlS3Hz5k0AgK2tLQBgzZo1SExMxB9//AErKytlm5ubG3788Ue88MILSj9Xr15V3kNEdFeTJk2Qm5uL1NRUZdlXflqttlSXzzLIzMxEfHw8+vfvX6L9uEaWSCXc3d3x9NNPY+HChcp/1AYXL17E6tWr0adPHyVh8vDwQEpKitImLi7OqNKk1WoB3D2LPr+YmBijY+zfvx+Ojo6oUaOGyb6vX7+OhIQEoz5sbW1N9p1f9+7dcevWLWzbtg1r1qxBRESE8tjJkyeRlpaG9957D61atUJgYGCRJ3oZYrt48aJREnjvJcY8PT3h4+ODs2fPonbt2kY3wwlwpjRp0gQnTpww2lavXj0cOnTIaFth64HvFRQUhJycHPz555/KtrS0NJw6dUqpMhc3DoOi5urek8vyj9Uwl0FBQcp66Xv7MEf+dvv370dQUJByv2HDhggNDcWXX36JNWvWYMiQIWb1Wxhz5s7X11fZZkias7KyYGVlZfRlwnD/3itI3Lp1C/Hx8Uq1mqgyyczMxOHDh5XPmYSEBBw+fBhJSUmoW7cuIiIiMGDAAGzcuBEJCQk4cOAA5syZg6ioqFId74033sDu3buRmJiI33//Hc8++yysra3Rt2/fknVUslUTRGRJp0+flqpVq0qrVq1k9+7dkpSUJFu3bpUGDRpInTp1JC0tTWn7wgsvSFBQkPz9999y8OBBadeundja2iprZO/cuSN6vV7eeecduXjxoly7dk1E7q67dHR0lL59+8rx48clKipKPD09ZfLkyUrfkydPFi8vL9mzZ48cOXJEevToIY6OjkZrZOvUqSOjRo2SlJQUuXr1apHjioiIkJCQENFoNHLu3Dlle2pqqmi1WpkwYYLEx8fLjz/+KHXr1jVa25t/jeyJEydEo9HIe++9J2fOnJEFCxaIm5ub0drSL7/8UvR6vcyfP19OnTolR44ckeXLl8tHH31UaIxHjhwRGxsbo7GcPXtWbG1tZeLEiXLq1ClZv369VK9eXQAoz+eKFSvExcWlQH/du3eX4OBg+e233+Tw4cPSqVMnqV27tmRnZ5s9DnPmaurUqeLu7i6RkZFy5swZ+euvv+TTTz+VyMhIERE5d+6caLVaeeONN+TkyZOyevVq8fLyMmuNbNWqVWXZsmVy6tQpmTZtmlhZWcnx48eN2i1ZskS0Wq24ubnJzZs3C+3P4J9//pF//vlHmjZtKv369ZN//vnHqM/SzF1sbKzodDoZNWqUnDhxQo4dOyYvvviiuLi4yIULF5R2u3btEkdHR6M1x0SVheGzNP9t4MCBIiKSnZ0t06ZNk1q1aomtra14e3vLs88+K0eOHCnV8fr06SPe3t6i1WrF19dX+vTpI2fOnClxP0xkiVQmMTFRBg4cKJ6enmJrays1atSQsWPHypUrV4zanT9/Xjp06CAODg5Sp04d2bJli9HJXiJ3k4IaNWqIlZWVhIWFicjd5Kh79+4ybdo0cXd3F0dHRxk+fLjcunVL2e+///6TPn36iLOzs9SoUUMiIyMLnOy1adMmqV27ttjY2BglX6Zs2bJFAEjr1q0LPLZmzRqpVauW6HQ6ad68uWzatKnIRFbk7glPNWrUEAcHBxkwYIDMnj27QAyrV6+Wxo0bK0lW69atZePGjUXG+fjjj8vixYuNtv34449Su3Zt0el00qZNG1m0aJEAUJK2whLZq1evSv/+/cXFxUX0er107NhRTp8+bdSmuHGYM1d5eXkyb948qVevntja2oqHh4d07NhRdu/erbT56aeflDG0atVKli9fblYi+/nnn8vTTz8tOp1OatWqZXRil0FGRobY29vL6NGji3pqjfrNfyuLufv555+lRYsW4uLiIm5ubtKuXTv5448/jNqMGDFCRo4caVacRPRw0Ig8gDNHiEg1Bg0ahGvXrlW4X+UqC1FRUZgwYQKOHTumrLXMb/bs2Vi8eDGSk5PLPR41zFViYiICAgJw8OBBPProo5YOp1BXrlxRlooUtcSEiB4uPNmLiMhM4eHhiIuLw/nz55U1pgsXLsRjjz0Gd3d37Nu3Dx988EGBHwKojO7cuYO0tDS8+eabeOKJJx7qJBa4m3AvXLiQSSyRyjCRJSIqgfHjxxvdj4uLwzvvvIOrV6+iZs2aeP311zFlyhTLBPcQ2bdvH9q2bYu6desW+CWxh1FoaChCQ0MtHQYRlRCXFhARERGRKvHyW0RERESkSkxkiYiIiEiVmMgSERERkSoxkSUiIiIiVWIiS0RERESqxESWiIiIiFSJiSwRERERqRITWSIiIiJSJSayRERERKRK/w95qGvh0UWahwAAAABJRU5ErkJggg==",
      "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": 11,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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gwaZuLg443Q6TYcOHcyECRPM119/HezRAi43N/esx0k0R2PHjq1zX999991gjxZwF+UxHwAAIHia1ptnAACgySM+AACAVcQHAACwivgAAABWER8AAMAq4gMAAFhFfAAAAKuIDwAAmqh169bpxhtvVLt27eRwOLR06dJGfbzq6mpNnTpVHTt2VGRkpDp16qTHH39c/n5kGPEB+OnkyZPKysqSy+WSw+FQaWlpnctsWbp0qTp37qzQ0FDde++91h4XQPCdOHFCvXr10ty5c6083m9/+1vNnz9f//3f/62dO3fqt7/9rWbNmqU5c+b4tR3iA/inffv26ec//7natWun8PBwpaam6p577qn1Fyn/8Ic/aP369frggw904MABud3uOpc1xJo1a+odMePHj9fIkSO1b98+Pf744w163EBZs2aNfvjDH8rpdKpz587Ky8s7730+/vhjDRgwQBEREUpOTtasWbNqrbNkyRJ17dpVERER+sEPfqDly5f73G6M0bRp09S2bVtFRkYqIyNDn3/+uc86M2bMUL9+/RQVFaWYmJg6ZyksLNTw4cMVFRWlhIQEPfjgg6qqqvJ7H+fOnasOHTooIiJCaWlp+vvf/+5z++9//3sNHDjwnNF65MgRjRo1Si6XSzExMRo3bpyOHz/u93OH5mnYsGF64okn9JOf/KTO2z0ejx544AFdcsklatmypdLS0rRmzZoLfrwPPvhAI0aM0PDhw9WhQweNHDlSQ4YMqfW9fV7B/XR34Pvhiy++MAkJCaZ///5mzZo15quvvjLLly83V1xxhbnsssvM4cOHvevef//95pprrvG5f13LGuLdd981kszRo0fPud6xY8eMJLN69eqzrlNVVWWqq6sDNtv5fPnllyYqKspkZ2ebTz/91MyZM8eEhoaaFStWnPU+ZWVlJjEx0YwaNcps377dvPLKKyYyMtIsWLDAu877779vQkNDzaxZs8ynn35qHnnkEdOiRQvzySefeNeZOXOmcbvdZunSpeajjz4yN910k+nYsaP55ptvvOtMmzbNPP300yY7O9u43e5as1RVVZkePXqYjIwMs3XrVrN8+XLTunVrM2XKFL/2cfHixSY8PNy8+OKLZseOHebuu+82MTExpqSkxLvO7NmzTU5OjsnJyTnr13vo0KGmV69eZuPGjWb9+vWmc+fO5o477vDrucPFQZJ5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Wfr444+1d+9erV69Wt27d5fT6VRhYaE6d+7sc0lOTpb07b9GpG8/0CcQunXrpqqqKm3atMm77PDhwyooKFD37t0D8hinpaena9WqVT7LVq5c6X2L6Wz3WbdunSorK33u06VLF+/bBufbbseOHZWUlOSzTnl5uTZt2nTOx65rlk8++cTnl/7KlSvlcrm8z9X5ZgkPD1efPn181qmpqdGqVav8nqW0tFT5+fneZatXr1ZNTY33Vaz6PHdovj788EP17t3b+6ppdna2evfurWnTpkmScnNzNWbMGN1///3q0qWLbr75Zm3evFkpKSkX9Hhz5szRyJEj9e///u/q1q2bHnjgAY0fP97/0/wDcIwL0OR99tlnpnXr1mbAgAFm7dq1prCw0LzzzjumR48etU61veeee7xntJxt2bJly8yzzz5rtm7davbu3WvmzZtnQkJCzPbt240xxvznf/6niY+PN3l5eWb37t0mPz/fPPfcc96Dtr7++mvjcDhMXl6eOXjwoDl27Fidcx89etR7lstpZzuQcsSIEaZ79+5m/fr1Ztu2bWbo0KG1Djj97v2mT59e6+DLsWPH1jrA8UynT0N98MEHzc6dO83cuXNrnYY6Z84cM3jwYO/10tJSk5iYaEaPHm22b99uFi9ebKKiomqdahsWFmZ+97vfmZ07d5rp06fXeaptTEyMefPNN83HH39sRowYUetU26+++sps3brV/OY3vzGtWrUyW7duNVu3bvU+x6dPtR0yZIjZtm2bWbFihWnTpk2dp9qeax8XL15snE6nycvLM59++qn5xS9+YWJiYnzOojlw4IDZunWreeGFF4wks27dOrN161af77ehQ4ea3r17m02bNpn33nvPXHbZZT6n2tbnuQO+b4gP4J/27t1rxo4daxITE02LFi1McnKymTRpkvnHP/7hs1594mP9+vXm2muvNbGxsSYyMtL07NnTvPrqq97ba2pqzDPPPGO6dOliWrRoYdq0aWMyMzPN2rVrves89thjJikpyTgcjjpPtTXGv/g4faqt2+02kZGRJjMzs85Tbc90IfFhzLdnb1x55ZUmPDzcXHrppSY3N7fWdlNTU32WffTRR6Z///7G6XSaSy65xMycObPWdl977TVz+eWXm/DwcHPFFVeYt99+2+f2mpoaM3XqVJOYmGicTqe57rrrvJ9HcOb8quOI/jOfw71795phw4aZyMhI07p1a3P//febyspKv/bRmG8jKyUlxYSHh5urrrrKbNy4sdbzUNcsZ27r8OHD5o477jCtWrUyLpfL3HnnnbVitD7PHfB94jAmgEfZAQAAnAfHfAAAAKuIDwAAYBXxAQAArCI+AACAVcQHAACwivgAAABWER8AAMAq4gMAAFhFfAAAAKuIDwAAYBXxAQAArPp/E0fYf1EzDGoAAAAASUVORK5CYII=",
      "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",
    "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
}
