{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Converged at 45752/100000\n",
      "tensor(0.0975, grad_fn=<AddBackward0>)\n",
      "Converged at 49242/100000\n",
      "tensor(1.0000, grad_fn=<AddBackward0>)\n",
      "Converged at 48434/100000\n",
      "tensor(0.5488, grad_fn=<AddBackward0>)\n",
      "Converged at 44746/100000\n",
      "tensor(0.0975, grad_fn=<AddBackward0>)\n",
      "Converged at 43531/100000\n",
      "tensor(0.0975, grad_fn=<AddBackward0>)\n",
      "Converged at 50112/100000\n",
      "tensor(0.0975, grad_fn=<AddBackward0>)\n",
      "Converged at 69515/100000\n",
      "tensor(0.0976, grad_fn=<AddBackward0>)\n",
      "Converged at 44754/100000\n",
      "tensor(0.0975, grad_fn=<AddBackward0>)\n",
      "Converged at 50069/100000\n",
      "tensor(0.5488, grad_fn=<AddBackward0>)\n",
      "Converged at 50575/100000\n",
      "tensor(0.0975, grad_fn=<AddBackward0>)\n",
      "Converged at 44771/100000\n",
      "tensor(0.0975, grad_fn=<AddBackward0>)\n",
      "Converged at 44232/100000\n",
      "tensor(0.0975, grad_fn=<AddBackward0>)\n",
      "Converged at 46341/100000\n",
      "tensor(0.5488, grad_fn=<AddBackward0>)\n",
      "Converged at 27169/100000\n",
      "tensor(0.0975, grad_fn=<AddBackward0>)\n",
      "Converged at 49223/100000\n",
      "tensor(0.0975, grad_fn=<AddBackward0>)\n",
      "Converged at 47829/100000\n",
      "tensor(0.0975, grad_fn=<AddBackward0>)\n",
      "Converged at 47317/100000\n",
      "tensor(0.5488, grad_fn=<AddBackward0>)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import numpy as np\n",
    "\n",
    "\n",
    "torch.manual_seed(0)\n",
    "\n",
    "num_experiments = 20\n",
    "\n",
    "x = torch.tensor([[-np.sqrt(3)],[np.sqrt(3)]], dtype = torch.float32)\n",
    "y = torch.tensor([[1],[1]], dtype = torch.float32)\n",
    "\n",
    "for i in range(num_experiments):\n",
    "    \n",
    "    m = 3\n",
    "\n",
    "    model = nn.Sequential(\n",
    "                nn.Linear(1, m, bias = True, dtype = torch.float32),\n",
    "                nn.ReLU(),\n",
    "                nn.Linear(m, 1, bias = False, dtype = torch.float32)\n",
    "            )\n",
    "\n",
    "    optimizer = torch.optim.SGD(model.parameters(), lr=1e-3)\n",
    "    epochs = 100000\n",
    "    tol = 1e-6\n",
    "    lam = 1e-1\n",
    "\n",
    "    for i in range(epochs):\n",
    "\n",
    "        model.zero_grad()\n",
    "        l2_penalty = sum([torch.sum(param ** 2) for param in model.parameters()])\n",
    "        obj = torch.sum((model(x) - y) ** 2) / 2 + lam * l2_penalty/2\n",
    "        obj.backward()\n",
    "            \n",
    "        optimizer.step()\n",
    "\n",
    "        # check for convergence\n",
    "        \n",
    "        model.zero_grad()\n",
    "        l2_penalty = sum([torch.sum(param ** 2) for param in model.parameters()])\n",
    "        obj = torch.sum((model(x) - y) ** 2) / 2 + lam * l2_penalty/2\n",
    "        obj.backward()    \n",
    "        grad_norm = sum([torch.sum(param.grad ** 2) for param in model.parameters()])\n",
    "\n",
    "        if grad_norm <= tol:\n",
    "            print(f\"Converged at {i}/{epochs}\")\n",
    "            print(obj)\n",
    "            break\n",
    "\n",
    "        #if i % 25 == 0:\n",
    "        #    print(f\"{i}/{epochs}: Obj - {obj}, Grad - {grad_norm}\")\n",
    "\n",
    "\n",
    "    xs = np.linspace(-2, 2, 100).T\n",
    "    xs = np.expand_dims(xs, axis = 1)\n",
    "    plt.plot(xs, model(torch.tensor(xs, dtype = torch.float32)).detach().numpy(), color = 'blue')\n",
    "    plt.scatter(np.sqrt(3), 1, color = 'red', s = 80)\n",
    "    plt.scatter(-np.sqrt(3), 1, color = 'red', s = 80)\n",
    "    plt.ylim(0,1.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0/100000: Obj - 5514.25146484375, Grad - 64729.25\n",
      "2500/100000: Obj - 21.856000900268555, Grad - 0.008170859888195992\n",
      "5000/100000: Obj - 21.839962005615234, Grad - 0.004937290214002132\n",
      "7500/100000: Obj - 21.830259323120117, Grad - 0.0029876981861889362\n",
      "10000/100000: Obj - 21.824377059936523, Grad - 0.0018096306594088674\n",
      "12500/100000: Obj - 21.820823669433594, Grad - 0.0010966783156618476\n",
      "15000/100000: Obj - 21.818668365478516, Grad - 0.0006648821872659028\n",
      "17500/100000: Obj - 21.817371368408203, Grad - 0.0004031542921438813\n",
      "20000/100000: Obj - 21.81656837463379, Grad - 0.00024453052901662886\n",
      "22500/100000: Obj - 21.81609344482422, Grad - 0.0001483352534705773\n",
      "25000/100000: Obj - 21.815799713134766, Grad - 9.000915451906621e-05\n",
      "27500/100000: Obj - 21.815629959106445, Grad - 5.4639469453832135e-05\n",
      "Converged at 27948/100000\n",
      "tensor(21.8156, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5401.3896484375, Grad - 136977.703125\n",
      "2500/100000: Obj - 6.0174689292907715, Grad - 0.010110870003700256\n",
      "5000/100000: Obj - 5.999843120574951, Grad - 0.0047949072904884815\n",
      "7500/100000: Obj - 5.9909491539001465, Grad - 0.0026251629460603\n",
      "10000/100000: Obj - 5.985744953155518, Grad - 0.0016572318272665143\n",
      "12500/100000: Obj - 5.982273101806641, Grad - 0.0011727992678061128\n",
      "15000/100000: Obj - 5.979709625244141, Grad - 0.0009012508089654148\n",
      "17500/100000: Obj - 5.97767972946167, Grad - 0.0007344376062974334\n",
      "20000/100000: Obj - 5.975992202758789, Grad - 0.0006245660479180515\n",
      "22500/100000: Obj - 5.974532127380371, Grad - 0.0005474748904816806\n",
      "25000/100000: Obj - 5.973238945007324, Grad - 0.0004907471593469381\n",
      "27500/100000: Obj - 5.97206974029541, Grad - 0.00044709164649248123\n",
      "30000/100000: Obj - 5.970998764038086, Grad - 0.0004121609381400049\n",
      "32500/100000: Obj - 5.970005989074707, Grad - 0.00038324869819916785\n",
      "35000/100000: Obj - 5.969081878662109, Grad - 0.00035882199881598353\n",
      "37500/100000: Obj - 5.9682111740112305, Grad - 0.00033746339613571763\n",
      "40000/100000: Obj - 5.9673919677734375, Grad - 0.0003186612157151103\n",
      "42500/100000: Obj - 5.966619968414307, Grad - 0.0003018961288034916\n",
      "45000/100000: Obj - 5.965882301330566, Grad - 0.0002866001450456679\n",
      "47500/100000: Obj - 5.965184211730957, Grad - 0.0002726591192185879\n",
      "50000/100000: Obj - 5.964521408081055, Grad - 0.00025996798649430275\n",
      "52500/100000: Obj - 5.963885307312012, Grad - 0.00024800622486509383\n",
      "55000/100000: Obj - 5.963278770446777, Grad - 0.00023694185074418783\n",
      "57500/100000: Obj - 5.962701320648193, Grad - 0.00022668825113214552\n",
      "60000/100000: Obj - 5.9621477127075195, Grad - 0.00021690015273634344\n",
      "62500/100000: Obj - 5.961616039276123, Grad - 0.0002076589735224843\n",
      "65000/100000: Obj - 5.961109161376953, Grad - 0.0001989611773751676\n",
      "67500/100000: Obj - 5.960625171661377, Grad - 0.00019073790463153273\n",
      "70000/100000: Obj - 5.9601569175720215, Grad - 0.00018272735178470612\n",
      "72500/100000: Obj - 5.959708213806152, Grad - 0.00017505032883491367\n",
      "75000/100000: Obj - 5.959280967712402, Grad - 0.00016777048585936427\n",
      "77500/100000: Obj - 5.958872318267822, Grad - 0.00016076758038252592\n",
      "80000/100000: Obj - 5.9584784507751465, Grad - 0.00015396825619973242\n",
      "82500/100000: Obj - 5.95810079574585, Grad - 0.00014730851398780942\n",
      "85000/100000: Obj - 5.957740783691406, Grad - 0.00014089405885897577\n",
      "87500/100000: Obj - 5.957396984100342, Grad - 0.00013476905587594956\n",
      "90000/100000: Obj - 5.9570698738098145, Grad - 0.00012877260451205075\n",
      "92500/100000: Obj - 5.956754207611084, Grad - 0.0001228511828230694\n",
      "95000/100000: Obj - 5.956453323364258, Grad - 0.00011712162813637406\n",
      "97500/100000: Obj - 5.956167221069336, Grad - 0.0001116142375394702\n",
      "0/100000: Obj - 5278.16064453125, Grad - 149767.8125\n",
      "2500/100000: Obj - 20.813854217529297, Grad - 0.015665939077734947\n",
      "5000/100000: Obj - 20.783138275146484, Grad - 0.009441372007131577\n",
      "7500/100000: Obj - 20.76459503173828, Grad - 0.005704524926841259\n",
      "10000/100000: Obj - 20.753379821777344, Grad - 0.00345161953009665\n",
      "12500/100000: Obj - 20.7465877532959, Grad - 0.0020905982237309217\n",
      "15000/100000: Obj - 20.74248695373535, Grad - 0.0012668219860643148\n",
      "17500/100000: Obj - 20.739990234375, Grad - 0.0007683809963054955\n",
      "20000/100000: Obj - 20.738494873046875, Grad - 0.0004657697572838515\n",
      "22500/100000: Obj - 20.737571716308594, Grad - 0.0002824508410412818\n",
      "25000/100000: Obj - 20.737010955810547, Grad - 0.0001713488163659349\n",
      "27500/100000: Obj - 20.736671447753906, Grad - 0.00010395886056357995\n",
      "30000/100000: Obj - 20.736480712890625, Grad - 6.309596938081086e-05\n",
      "Converged at 31162/100000\n",
      "tensor(20.7364, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5465.91015625, Grad - 119765.15625\n",
      "2500/100000: Obj - 20.784027099609375, Grad - 0.00962613895535469\n",
      "5000/100000: Obj - 20.765125274658203, Grad - 0.005813385359942913\n",
      "7500/100000: Obj - 20.753707885742188, Grad - 0.0035165881272405386\n",
      "10000/100000: Obj - 20.746784210205078, Grad - 0.0021299710497260094\n",
      "12500/100000: Obj - 20.742597579956055, Grad - 0.001290258951485157\n",
      "15000/100000: Obj - 20.740068435668945, Grad - 0.0007821935578249395\n",
      "17500/100000: Obj - 20.7385196685791, Grad - 0.00047449927660636604\n",
      "20000/100000: Obj - 20.737600326538086, Grad - 0.0002875754435081035\n",
      "22500/100000: Obj - 20.73703956604004, Grad - 0.00017446053971070796\n",
      "25000/100000: Obj - 20.73668670654297, Grad - 0.0001057994450093247\n",
      "27500/100000: Obj - 20.736467361450195, Grad - 6.420735007850453e-05\n",
      "Converged at 28753/100000\n",
      "tensor(20.7364, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5249.6240234375, Grad - 149474.671875\n",
      "2500/100000: Obj - 6.221031665802002, Grad - 0.059247951954603195\n",
      "5000/100000: Obj - 6.115198612213135, Grad - 0.032441653311252594\n",
      "7500/100000: Obj - 6.051186561584473, Grad - 0.020330147817730904\n",
      "10000/100000: Obj - 6.010700702667236, Grad - 0.012646546587347984\n",
      "12500/100000: Obj - 5.985678672790527, Grad - 0.007739564403891563\n",
      "15000/100000: Obj - 5.970495223999023, Grad - 0.0046518100425601006\n",
      "17500/100000: Obj - 5.961430072784424, Grad - 0.002758893184363842\n",
      "20000/100000: Obj - 5.956071376800537, Grad - 0.0016256413655355573\n",
      "22500/100000: Obj - 5.95291805267334, Grad - 0.0009568824898451567\n",
      "25000/100000: Obj - 5.951059818267822, Grad - 0.0005646507488563657\n",
      "27500/100000: Obj - 5.94996976852417, Grad - 0.00033072009682655334\n",
      "30000/100000: Obj - 5.949319839477539, Grad - 0.00020060339011251926\n",
      "32500/100000: Obj - 5.948925495147705, Grad - 0.00012170583795523271\n",
      "35000/100000: Obj - 5.948685646057129, Grad - 7.387408550130203e-05\n",
      "Converged at 36949/100000\n",
      "tensor(5.9486, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5378.90478515625, Grad - 131326.796875\n",
      "2500/100000: Obj - 5.999104976654053, Grad - 0.01111968606710434\n",
      "5000/100000: Obj - 5.978771209716797, Grad - 0.005765330512076616\n",
      "7500/100000: Obj - 5.968079090118408, Grad - 0.0030915115494281054\n",
      "10000/100000: Obj - 5.962245464324951, Grad - 0.0017229109071195126\n",
      "12500/100000: Obj - 5.958942413330078, Grad - 0.0009932771790772676\n",
      "15000/100000: Obj - 5.957014083862305, Grad - 0.0005876686773262918\n",
      "17500/100000: Obj - 5.9558634757995605, Grad - 0.00035417446633800864\n",
      "20000/100000: Obj - 5.955165863037109, Grad - 0.00021613635180983692\n",
      "22500/100000: Obj - 5.954738140106201, Grad - 0.00013298892008606344\n",
      "25000/100000: Obj - 5.954474925994873, Grad - 8.242554031312466e-05\n",
      "27500/100000: Obj - 5.954310894012451, Grad - 5.1196162530686706e-05\n",
      "Converged at 27624/100000\n",
      "tensor(5.9543, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5510.42578125, Grad - 53515.15625\n",
      "2500/100000: Obj - 21.86867332458496, Grad - 0.011274595744907856\n",
      "5000/100000: Obj - 21.84744644165039, Grad - 0.006504211574792862\n",
      "7500/100000: Obj - 21.83470916748047, Grad - 0.0039168456569314\n",
      "10000/100000: Obj - 21.827009201049805, Grad - 0.0023591872304677963\n",
      "12500/100000: Obj - 21.822410583496094, Grad - 0.001421741908416152\n",
      "15000/100000: Obj - 21.81960678100586, Grad - 0.0008574060630053282\n",
      "17500/100000: Obj - 21.817930221557617, Grad - 0.0005175185506232083\n",
      "20000/100000: Obj - 21.81691551208496, Grad - 0.0003126485098619014\n",
      "22500/100000: Obj - 21.816268920898438, Grad - 0.00018860191630665213\n",
      "25000/100000: Obj - 21.815898895263672, Grad - 0.00011444155097706243\n",
      "27500/100000: Obj - 21.815673828125, Grad - 6.946207577129826e-05\n",
      "Converged at 29148/100000\n",
      "tensor(21.8156, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5483.37890625, Grad - 63385.34375\n",
      "2500/100000: Obj - 5.992273807525635, Grad - 0.004643564578145742\n",
      "5000/100000: Obj - 5.983110427856445, Grad - 0.0028426884673535824\n",
      "7500/100000: Obj - 5.977463722229004, Grad - 0.0017657693242654204\n",
      "10000/100000: Obj - 5.973930835723877, Grad - 0.0011138826375827193\n",
      "12500/100000: Obj - 5.97168493270874, Grad - 0.0007162866531871259\n",
      "15000/100000: Obj - 5.970224380493164, Grad - 0.0004721695731859654\n",
      "17500/100000: Obj - 5.969247817993164, Grad - 0.0003216761106159538\n",
      "20000/100000: Obj - 5.968570232391357, Grad - 0.00022834209084976465\n",
      "22500/100000: Obj - 5.968077659606934, Grad - 0.00017019009101204574\n",
      "25000/100000: Obj - 5.967702388763428, Grad - 0.00013366203347686678\n",
      "27500/100000: Obj - 5.967399597167969, Grad - 0.00011037976219085976\n",
      "30000/100000: Obj - 5.967145919799805, Grad - 9.537634468870237e-05\n",
      "32500/100000: Obj - 5.966922760009766, Grad - 8.549055201001465e-05\n",
      "35000/100000: Obj - 5.966718673706055, Grad - 7.873938011471182e-05\n",
      "37500/100000: Obj - 5.966527938842773, Grad - 7.395273132715374e-05\n",
      "40000/100000: Obj - 5.96634578704834, Grad - 7.036528404569253e-05\n",
      "42500/100000: Obj - 5.966172695159912, Grad - 6.760795076843351e-05\n",
      "45000/100000: Obj - 5.966009140014648, Grad - 6.546646181959659e-05\n",
      "47500/100000: Obj - 5.965848922729492, Grad - 6.349303293973207e-05\n",
      "50000/100000: Obj - 5.965693950653076, Grad - 6.185082020238042e-05\n",
      "52500/100000: Obj - 5.965541839599609, Grad - 6.0373888118192554e-05\n",
      "55000/100000: Obj - 5.965392589569092, Grad - 5.900844553252682e-05\n",
      "57500/100000: Obj - 5.965246677398682, Grad - 5.772998702013865e-05\n",
      "60000/100000: Obj - 5.965103626251221, Grad - 5.652123945765197e-05\n",
      "62500/100000: Obj - 5.964962959289551, Grad - 5.544519081013277e-05\n",
      "65000/100000: Obj - 5.964826583862305, Grad - 5.435498314909637e-05\n",
      "67500/100000: Obj - 5.964692115783691, Grad - 5.3385490900836885e-05\n",
      "70000/100000: Obj - 5.964560031890869, Grad - 5.240827158559114e-05\n",
      "72500/100000: Obj - 5.964430332183838, Grad - 5.147060437593609e-05\n",
      "75000/100000: Obj - 5.9643025398254395, Grad - 5.05726202391088e-05\n",
      "Converged at 76626/100000\n",
      "tensor(5.9642, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5294.78369140625, Grad - 119582.6015625\n",
      "2500/100000: Obj - 6.0746378898620605, Grad - 0.03374987840652466\n",
      "5000/100000: Obj - 6.028066158294678, Grad - 0.013034927658736706\n",
      "7500/100000: Obj - 6.002188682556152, Grad - 0.00808412954211235\n",
      "10000/100000: Obj - 5.9860520362854, Grad - 0.005071495659649372\n",
      "12500/100000: Obj - 5.975868225097656, Grad - 0.003225396852940321\n",
      "15000/100000: Obj - 5.969339370727539, Grad - 0.0020894210319966078\n",
      "17500/100000: Obj - 5.965065002441406, Grad - 0.0013861112529411912\n",
      "20000/100000: Obj - 5.962190628051758, Grad - 0.0009475841070525348\n",
      "22500/100000: Obj - 5.960193634033203, Grad - 0.0006708730361424387\n",
      "25000/100000: Obj - 5.958755016326904, Grad - 0.0004940557410009205\n",
      "27500/100000: Obj - 5.9576735496521, Grad - 0.00037869904190301895\n",
      "30000/100000: Obj - 5.956830978393555, Grad - 0.00030184531351551414\n",
      "32500/100000: Obj - 5.956145763397217, Grad - 0.0002488666505087167\n",
      "35000/100000: Obj - 5.9555745124816895, Grad - 0.00021135341376066208\n",
      "37500/100000: Obj - 5.955082893371582, Grad - 0.0001835543371271342\n",
      "40000/100000: Obj - 5.954651832580566, Grad - 0.00016228447202593088\n",
      "42500/100000: Obj - 5.954268455505371, Grad - 0.00014543677389156073\n",
      "45000/100000: Obj - 5.953922748565674, Grad - 0.00013167821452952921\n",
      "47500/100000: Obj - 5.953609943389893, Grad - 0.00012005316966678947\n",
      "50000/100000: Obj - 5.953322410583496, Grad - 0.00011010782327502966\n",
      "52500/100000: Obj - 5.953058242797852, Grad - 0.00010136891796719283\n",
      "55000/100000: Obj - 5.952815055847168, Grad - 9.372654312755913e-05\n",
      "57500/100000: Obj - 5.952589988708496, Grad - 8.680780592840165e-05\n",
      "60000/100000: Obj - 5.952381610870361, Grad - 8.063299173954874e-05\n",
      "62500/100000: Obj - 5.952186584472656, Grad - 7.505607209168375e-05\n",
      "65000/100000: Obj - 5.952005386352539, Grad - 6.998361641308293e-05\n",
      "67500/100000: Obj - 5.951837062835693, Grad - 6.537172885145992e-05\n",
      "70000/100000: Obj - 5.951679229736328, Grad - 6.113300332799554e-05\n",
      "72500/100000: Obj - 5.951531410217285, Grad - 5.727145617129281e-05\n",
      "75000/100000: Obj - 5.951392650604248, Grad - 5.372943633119576e-05\n",
      "77500/100000: Obj - 5.951262950897217, Grad - 5.044458157499321e-05\n",
      "Converged at 77839/100000\n",
      "tensor(5.9512, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5369.81787109375, Grad - 114850.7890625\n",
      "2500/100000: Obj - 7.358968734741211, Grad - 0.007499894592911005\n",
      "5000/100000: Obj - 7.344257831573486, Grad - 0.004525933414697647\n",
      "7500/100000: Obj - 7.335351943969727, Grad - 0.002747064223513007\n",
      "10000/100000: Obj - 7.329936981201172, Grad - 0.0016736226389184594\n",
      "12500/100000: Obj - 7.326641082763672, Grad - 0.0010221907868981361\n",
      "15000/100000: Obj - 7.324618339538574, Grad - 0.0006253393949009478\n",
      "17500/100000: Obj - 7.323384761810303, Grad - 0.00038304569898173213\n",
      "20000/100000: Obj - 7.322628498077393, Grad - 0.0002348636626265943\n",
      "22500/100000: Obj - 7.322165012359619, Grad - 0.00014422598178498447\n",
      "25000/100000: Obj - 7.321877479553223, Grad - 8.857762441039085e-05\n",
      "27500/100000: Obj - 7.321698188781738, Grad - 5.457675797515549e-05\n",
      "Converged at 27952/100000\n",
      "tensor(7.3217, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5429.88427734375, Grad - 174699.671875\n",
      "2500/100000: Obj - 20.93062400817871, Grad - 0.061146002262830734\n",
      "5000/100000: Obj - 20.838855743408203, Grad - 0.17530383169651031\n",
      "7500/100000: Obj - 20.790597915649414, Grad - 0.014853758737444878\n",
      "10000/100000: Obj - 20.76546287536621, Grad - 0.015125594101846218\n",
      "12500/100000: Obj - 20.752212524414062, Grad - 0.004149491433054209\n",
      "15000/100000: Obj - 20.745168685913086, Grad - 0.002143898280337453\n",
      "17500/100000: Obj - 20.741365432739258, Grad - 0.0011486075818538666\n",
      "20000/100000: Obj - 20.739288330078125, Grad - 0.04394465312361717\n",
      "22500/100000: Obj - 20.73814582824707, Grad - 0.0003451720695011318\n",
      "25000/100000: Obj - 20.737499237060547, Grad - 0.00019402816542424262\n",
      "27500/100000: Obj - 20.737131118774414, Grad - 0.00011134131636936218\n",
      "30000/100000: Obj - 20.736909866333008, Grad - 6.542338087456301e-05\n",
      "Converged at 31325/100000\n",
      "tensor(20.7368, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5400.7255859375, Grad - 174000.15625\n",
      "2500/100000: Obj - 7.341374397277832, Grad - 0.0025362956803292036\n",
      "5000/100000: Obj - 7.3365397453308105, Grad - 0.0014469731831923127\n",
      "7500/100000: Obj - 7.333732604980469, Grad - 0.0008570615900680423\n",
      "10000/100000: Obj - 7.332042694091797, Grad - 0.0005249262321740389\n",
      "12500/100000: Obj - 7.33099365234375, Grad - 0.00033220689510926604\n",
      "15000/100000: Obj - 7.330318927764893, Grad - 0.00021814352658111602\n",
      "17500/100000: Obj - 7.329865455627441, Grad - 0.00014951937191653997\n",
      "20000/100000: Obj - 7.3295488357543945, Grad - 0.0001075625914381817\n",
      "22500/100000: Obj - 7.3293137550354, Grad - 8.16372994449921e-05\n",
      "25000/100000: Obj - 7.329134941101074, Grad - 6.522684270748869e-05\n",
      "27500/100000: Obj - 7.328984260559082, Grad - 5.4651791288051754e-05\n",
      "Converged at 29052/100000\n",
      "tensor(7.3289, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5318.646484375, Grad - 151920.671875\n",
      "2500/100000: Obj - 6.009037494659424, Grad - 0.01113833487033844\n",
      "5000/100000: Obj - 5.987161636352539, Grad - 0.006735720206052065\n",
      "7500/100000: Obj - 5.973910808563232, Grad - 0.004086263012140989\n",
      "10000/100000: Obj - 5.965864658355713, Grad - 0.0024839621037244797\n",
      "12500/100000: Obj - 5.960970401763916, Grad - 0.0015120846219360828\n",
      "15000/100000: Obj - 5.95798921585083, Grad - 0.000921412487514317\n",
      "17500/100000: Obj - 5.956171989440918, Grad - 0.0005619496805593371\n",
      "20000/100000: Obj - 5.955063343048096, Grad - 0.0003430548822507262\n",
      "22500/100000: Obj - 5.954386234283447, Grad - 0.00020958753884769976\n",
      "25000/100000: Obj - 5.953972339630127, Grad - 0.00012822632561437786\n",
      "27500/100000: Obj - 5.953718662261963, Grad - 7.860366167733446e-05\n",
      "Converged at 29819/100000\n",
      "tensor(5.9536, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5490.9580078125, Grad - 68457.1484375\n",
      "2500/100000: Obj - 6.213507175445557, Grad - 0.9213002920150757\n",
      "5000/100000: Obj - 6.031239986419678, Grad - 0.18015019595623016\n",
      "7500/100000: Obj - 5.989656925201416, Grad - 0.027043301612138748\n",
      "10000/100000: Obj - 5.9762797355651855, Grad - 0.0043512615375220776\n",
      "12500/100000: Obj - 5.9694085121154785, Grad - 0.0021104118786752224\n",
      "15000/100000: Obj - 5.965217113494873, Grad - 0.00130810949485749\n",
      "17500/100000: Obj - 5.962612152099609, Grad - 0.0008165570325218141\n",
      "20000/100000: Obj - 5.9609785079956055, Grad - 0.0005147329065948725\n",
      "22500/100000: Obj - 5.95994234085083, Grad - 0.0003291921457275748\n",
      "25000/100000: Obj - 5.959273338317871, Grad - 0.00021467916667461395\n",
      "27500/100000: Obj - 5.95883321762085, Grad - 0.0001438614126527682\n",
      "30000/100000: Obj - 5.958533763885498, Grad - 9.985574433812872e-05\n",
      "32500/100000: Obj - 5.958319664001465, Grad - 7.21833057468757e-05\n",
      "35000/100000: Obj - 5.958162784576416, Grad - 5.467000664793886e-05\n",
      "Converged at 35911/100000\n",
      "tensor(5.9581, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5579.65478515625, Grad - 94861.8515625\n",
      "2500/100000: Obj - 20.96114730834961, Grad - 0.2270345687866211\n",
      "5000/100000: Obj - 20.85857391357422, Grad - 0.07259547710418701\n",
      "7500/100000: Obj - 20.80215072631836, Grad - 0.01868502050638199\n",
      "10000/100000: Obj - 20.77174949645996, Grad - 0.009345641359686852\n",
      "12500/100000: Obj - 20.75547981262207, Grad - 0.005599914118647575\n",
      "15000/100000: Obj - 20.74675750732422, Grad - 0.0026100287213921547\n",
      "17500/100000: Obj - 20.742046356201172, Grad - 0.0013970864238217473\n",
      "20000/100000: Obj - 20.739490509033203, Grad - 0.000760910683311522\n",
      "22500/100000: Obj - 20.738075256347656, Grad - 0.00042131319059990346\n",
      "25000/100000: Obj - 20.737268447875977, Grad - 0.00023759857867844403\n",
      "27500/100000: Obj - 20.73680877685547, Grad - 0.00013648689491674304\n",
      "30000/100000: Obj - 20.736560821533203, Grad - 7.997699867701158e-05\n",
      "Converged at 32248/100000\n",
      "tensor(20.7364, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5481.44482421875, Grad - 73286.890625\n",
      "2500/100000: Obj - 7.431573867797852, Grad - 0.016318654641509056\n",
      "5000/100000: Obj - 7.399478435516357, Grad - 0.009937232360243797\n",
      "7500/100000: Obj - 7.379720211029053, Grad - 0.0061933728866279125\n",
      "10000/100000: Obj - 7.367271900177002, Grad - 0.003953694831579924\n",
      "12500/100000: Obj - 7.359221935272217, Grad - 0.002594333840534091\n",
      "15000/100000: Obj - 7.353863716125488, Grad - 0.0017588392365723848\n",
      "17500/100000: Obj - 7.350165367126465, Grad - 0.001238842960447073\n",
      "20000/100000: Obj - 7.3475117683410645, Grad - 0.0009104035561904311\n",
      "22500/100000: Obj - 7.345520973205566, Grad - 0.0006990809924900532\n",
      "25000/100000: Obj - 7.343960285186768, Grad - 0.0005598637508228421\n",
      "27500/100000: Obj - 7.342685222625732, Grad - 0.0004656288947444409\n",
      "30000/100000: Obj - 7.341611385345459, Grad - 0.00039938592817634344\n",
      "32500/100000: Obj - 7.34067440032959, Grad - 0.0003510969108901918\n",
      "35000/100000: Obj - 7.339846611022949, Grad - 0.0003144345246255398\n",
      "37500/100000: Obj - 7.339097023010254, Grad - 0.0002854584308806807\n",
      "40000/100000: Obj - 7.33841609954834, Grad - 0.00026178182451985776\n",
      "42500/100000: Obj - 7.337787628173828, Grad - 0.00024178592138923705\n",
      "45000/100000: Obj - 7.337206840515137, Grad - 0.00022459030151367188\n",
      "47500/100000: Obj - 7.336665153503418, Grad - 0.0002094055962515995\n",
      "50000/100000: Obj - 7.3361616134643555, Grad - 0.00019590204465202987\n",
      "52500/100000: Obj - 7.335688591003418, Grad - 0.00018361274851486087\n",
      "55000/100000: Obj - 7.335244178771973, Grad - 0.00017258415755350143\n",
      "57500/100000: Obj - 7.334827423095703, Grad - 0.00016232355847023427\n",
      "60000/100000: Obj - 7.334432125091553, Grad - 0.00015301781240850687\n",
      "62500/100000: Obj - 7.334064960479736, Grad - 0.0001443842484150082\n",
      "65000/100000: Obj - 7.333707332611084, Grad - 0.00013631967885885388\n",
      "67500/100000: Obj - 7.333380222320557, Grad - 0.00012888909259345382\n",
      "70000/100000: Obj - 7.333066463470459, Grad - 0.00012208183761686087\n",
      "72500/100000: Obj - 7.3327741622924805, Grad - 0.00011566220200620592\n",
      "75000/100000: Obj - 7.332491874694824, Grad - 0.00010963395470753312\n",
      "77500/100000: Obj - 7.3322224617004395, Grad - 0.00010402637417428195\n",
      "80000/100000: Obj - 7.331969261169434, Grad - 9.874488750938326e-05\n",
      "82500/100000: Obj - 7.331730842590332, Grad - 9.381267591379583e-05\n",
      "85000/100000: Obj - 7.331502437591553, Grad - 8.922578126657754e-05\n",
      "87500/100000: Obj - 7.331289291381836, Grad - 8.494628855260089e-05\n",
      "90000/100000: Obj - 7.331080913543701, Grad - 8.091513154795393e-05\n",
      "92500/100000: Obj - 7.330887794494629, Grad - 7.707651820965111e-05\n",
      "95000/100000: Obj - 7.330695629119873, Grad - 7.344559708144516e-05\n",
      "97500/100000: Obj - 7.330515384674072, Grad - 7.000339974183589e-05\n",
      "0/100000: Obj - 5405.23193359375, Grad - 114730.7890625\n",
      "2500/100000: Obj - 7.445976257324219, Grad - 0.018161457031965256\n",
      "5000/100000: Obj - 7.409972190856934, Grad - 0.011236099526286125\n",
      "7500/100000: Obj - 7.387521266937256, Grad - 0.00707137119024992\n",
      "10000/100000: Obj - 7.373260498046875, Grad - 0.004544098861515522\n",
      "12500/100000: Obj - 7.363992214202881, Grad - 0.00299704447388649\n",
      "15000/100000: Obj - 7.357789039611816, Grad - 0.0020409156568348408\n",
      "17500/100000: Obj - 7.353494644165039, Grad - 0.0014429284492507577\n",
      "20000/100000: Obj - 7.350398063659668, Grad - 0.0010635030921548605\n",
      "22500/100000: Obj - 7.348067283630371, Grad - 0.0008179046562872827\n",
      "25000/100000: Obj - 7.34623908996582, Grad - 0.0006555325817316771\n",
      "27500/100000: Obj - 7.3447442054748535, Grad - 0.0005446100840345025\n",
      "30000/100000: Obj - 7.343487739562988, Grad - 0.0004662359715439379\n",
      "32500/100000: Obj - 7.342403888702393, Grad - 0.0004087646957486868\n",
      "35000/100000: Obj - 7.341437339782715, Grad - 0.00036488374462351203\n",
      "37500/100000: Obj - 7.340569972991943, Grad - 0.000330195645801723\n",
      "40000/100000: Obj - 7.339783191680908, Grad - 0.00030171475373208523\n",
      "42500/100000: Obj - 7.339056491851807, Grad - 0.000277742394246161\n",
      "45000/100000: Obj - 7.338391304016113, Grad - 0.00025714177172631025\n",
      "47500/100000: Obj - 7.337776184082031, Grad - 0.0002389979490544647\n",
      "50000/100000: Obj - 7.337196350097656, Grad - 0.0002228510711574927\n",
      "52500/100000: Obj - 7.3366594314575195, Grad - 0.0002083585422951728\n",
      "55000/100000: Obj - 7.336158752441406, Grad - 0.0001952678430825472\n",
      "57500/100000: Obj - 7.335684776306152, Grad - 0.00018323466065339744\n",
      "60000/100000: Obj - 7.335239410400391, Grad - 0.00017225914052687585\n",
      "62500/100000: Obj - 7.334822177886963, Grad - 0.00016218877863138914\n",
      "65000/100000: Obj - 7.3344292640686035, Grad - 0.00015294560580514371\n",
      "67500/100000: Obj - 7.3340654373168945, Grad - 0.0001443399814888835\n",
      "70000/100000: Obj - 7.333714485168457, Grad - 0.00013629632303491235\n",
      "72500/100000: Obj - 7.333378791809082, Grad - 0.00012887807679362595\n",
      "75000/100000: Obj - 7.333064556121826, Grad - 0.000122003213618882\n",
      "77500/100000: Obj - 7.3327717781066895, Grad - 0.00011560595885384828\n",
      "80000/100000: Obj - 7.332492828369141, Grad - 0.0001096584674087353\n",
      "82500/100000: Obj - 7.332223892211914, Grad - 0.00010406570800114423\n",
      "85000/100000: Obj - 7.33197021484375, Grad - 9.875412797555327e-05\n",
      "87500/100000: Obj - 7.331727981567383, Grad - 9.3813483545091e-05\n",
      "90000/100000: Obj - 7.33150053024292, Grad - 8.923123823478818e-05\n",
      "92500/100000: Obj - 7.331284046173096, Grad - 8.494421490468085e-05\n",
      "95000/100000: Obj - 7.331081390380859, Grad - 8.093841461231932e-05\n",
      "97500/100000: Obj - 7.33088493347168, Grad - 7.706072938162833e-05\n",
      "0/100000: Obj - 5425.89599609375, Grad - 79101.7109375\n",
      "2500/100000: Obj - 6.068187713623047, Grad - 0.0628180205821991\n",
      "5000/100000: Obj - 6.010964393615723, Grad - 0.012806132435798645\n",
      "7500/100000: Obj - 5.985963344573975, Grad - 0.007660838309675455\n",
      "10000/100000: Obj - 5.970959663391113, Grad - 0.004600766114890575\n",
      "12500/100000: Obj - 5.961947917938232, Grad - 0.0027646913658827543\n",
      "15000/100000: Obj - 5.956530570983887, Grad - 0.001662843395024538\n",
      "17500/100000: Obj - 5.953271389007568, Grad - 0.0010011426638811827\n",
      "20000/100000: Obj - 5.951307773590088, Grad - 0.0006033512181602418\n",
      "22500/100000: Obj - 5.950124740600586, Grad - 0.000363984057912603\n",
      "25000/100000: Obj - 5.9494099617004395, Grad - 0.00021976613788865507\n",
      "27500/100000: Obj - 5.948977947235107, Grad - 0.00013280374696478248\n",
      "30000/100000: Obj - 5.948718547821045, Grad - 8.031554898479953e-05\n",
      "Converged at 32355/100000\n",
      "tensor(5.9486, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5461.21484375, Grad - 74664.25\n",
      "2500/100000: Obj - 7.354119300842285, Grad - 0.005591767840087414\n",
      "5000/100000: Obj - 7.3431549072265625, Grad - 0.0033692496363073587\n",
      "7500/100000: Obj - 7.336540222167969, Grad - 0.0020357805769890547\n",
      "10000/100000: Obj - 7.3325347900390625, Grad - 0.0012323603732511401\n",
      "12500/100000: Obj - 7.330111026763916, Grad - 0.0007470325799658895\n",
      "15000/100000: Obj - 7.328642845153809, Grad - 0.00045336250332184136\n",
      "17500/100000: Obj - 7.3277482986450195, Grad - 0.0002754748275037855\n",
      "20000/100000: Obj - 7.32720947265625, Grad - 0.00016767684428486973\n",
      "22500/100000: Obj - 7.326876640319824, Grad - 0.00010235102672595531\n",
      "25000/100000: Obj - 7.3266754150390625, Grad - 6.267448043217883e-05\n",
      "Converged at 26162/100000\n",
      "tensor(7.3266, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5491.5, Grad - 124169.03125\n",
      "2500/100000: Obj - 7.259922981262207, Grad - 0.6771080493927002\n",
      "5000/100000: Obj - 7.037440299987793, Grad - 1.831152319908142\n",
      "7500/100000: Obj - 6.851369857788086, Grad - 1.9041520357131958\n",
      "10000/100000: Obj - 6.74498987197876, Grad - 2.660123348236084\n",
      "12500/100000: Obj - 6.692965507507324, Grad - 1.9142343997955322\n",
      "15000/100000: Obj - 6.670496940612793, Grad - 1.6982485055923462\n",
      "17500/100000: Obj - 6.658685207366943, Grad - 1.6496050357818604\n",
      "20000/100000: Obj - 6.652094841003418, Grad - 1.5862191915512085\n",
      "22500/100000: Obj - 6.647773742675781, Grad - 1.7024600505828857\n",
      "25000/100000: Obj - 6.64565372467041, Grad - 1.6836739778518677\n",
      "27500/100000: Obj - 6.645507335662842, Grad - 1.5533946752548218\n",
      "30000/100000: Obj - 6.644242286682129, Grad - 1.736555814743042\n",
      "32500/100000: Obj - 6.643731117248535, Grad - 1.6957710981369019\n",
      "35000/100000: Obj - 6.644400596618652, Grad - 1.579554796218872\n",
      "37500/100000: Obj - 6.642983913421631, Grad - 1.6644164323806763\n",
      "40000/100000: Obj - 6.644110679626465, Grad - 1.5782887935638428\n",
      "42500/100000: Obj - 6.643319606781006, Grad - 1.8477494716644287\n",
      "45000/100000: Obj - 6.642930030822754, Grad - 1.6758108139038086\n",
      "47500/100000: Obj - 6.642764091491699, Grad - 1.6648025512695312\n",
      "50000/100000: Obj - 6.6432647705078125, Grad - 1.3023015260696411\n",
      "52500/100000: Obj - 6.643755912780762, Grad - 1.5729330778121948\n",
      "55000/100000: Obj - 6.6439290046691895, Grad - 1.5772126913070679\n",
      "57500/100000: Obj - 6.643071174621582, Grad - 1.7279075384140015\n",
      "60000/100000: Obj - 6.642815113067627, Grad - 1.6667383909225464\n",
      "62500/100000: Obj - 6.64264440536499, Grad - 0.7850008010864258\n",
      "65000/100000: Obj - 6.643705368041992, Grad - 1.5649923086166382\n",
      "67500/100000: Obj - 6.643884658813477, Grad - 1.5772491693496704\n",
      "70000/100000: Obj - 6.643259525299072, Grad - 1.8479875326156616\n",
      "72500/100000: Obj - 6.642858028411865, Grad - 1.6700186729431152\n",
      "75000/100000: Obj - 6.642679691314697, Grad - 1.6626427173614502\n",
      "77500/100000: Obj - 6.643551349639893, Grad - 1.4837549924850464\n",
      "80000/100000: Obj - 6.643829345703125, Grad - 1.5756794214248657\n",
      "82500/100000: Obj - 6.643991947174072, Grad - 1.5765061378479004\n",
      "85000/100000: Obj - 6.642953872680664, Grad - 1.6895939111709595\n",
      "87500/100000: Obj - 6.642749786376953, Grad - 1.664577841758728\n",
      "90000/100000: Obj - 6.64326810836792, Grad - 1.302141547203064\n",
      "92500/100000: Obj - 6.643758296966553, Grad - 1.5728719234466553\n",
      "95000/100000: Obj - 6.64392614364624, Grad - 1.577304482460022\n",
      "97500/100000: Obj - 6.643224716186523, Grad - 1.8470733165740967\n"
     ]
    },
    {
     "data": {
      "image/png": "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+nRmzZrFqlWriIqKok+fPmRnZ3u7HBERKWb3brjrLnPctCns2GFaUjwZOBCio/1Tm4iDxW73tE7g6Zk4cSLffvstX3/9tdvrdrudxMRE7rrrLu6++24A0tPTiY+PZ/bs2QwdOvSU3yMjI4PY2FjS09OJiYnxZvkiIpVe48YmpISGwqOPwr33er7XYoGCAs3cEe8oz+e311tQ/vOf/9ChQweuuuoq6tWrR7t27XjllVcKr+/cuZO0tDRSUlIKz8XGxtKpUydWrlzp9j1zcnLIyMhweYiISPmNGWPCCcDUqfDww6Xf/+STCicSGF4PKL/99hsvvvgiTZs25auvvuLWW2/l9ttv58033wQgLS0NgPj4eJfXxcfHF14rLjU1ldjY2MJHUlKSt8sWEan0vv3WOdake3ezWuzx457vr14dJkzwS2kiJXg9oNhsNs4//3weffRR2rVrx+jRo7npppuYNWvWab/npEmTSE9PL3zs3bvXixWLiFR+ublw2WXmuEYNGD4cvvyy9NcsWuT7ukQ88XpAqV+/Pq1atXI517JlS/bs2QNAQkICAAcOHHC558CBA4XXiouIiCAmJsblISIiZTdoEKSnm+M33oB77in9/saN4cILfV6WiEdeDyhdu3Zl69atLue2bdtGo0aNAEhOTiYhIYHFixcXXs/IyGDVqlV06dLF2+WIiFR5774LCxea4xtuMHvpHD1a+mu0W7EEWqi33/DOO+/kwgsv5NFHH+Xqq6/mhx9+4OWXX+bll18GwGKxMH78eB555BGaNm1KcnIykydPJjExkcGDB3u7HBGRKu3wYfjHP8xxYiL062d2Iy7NpZdCkZUhRALC6wGlY8eOzJ07l0mTJvHQQw+RnJzMs88+y7Bhwwrvuffee8nKymL06NEcO3aMbt26sXDhQqpVq+btckREqrRevcz4E6sVPvnEdPWUxmKB+fP9U5tIaby+Doo/aB0UEZFT+/e/4V//MsePPgqbNpnuntI88gg88IDPS5MqKqDroIiISOBt2gQPPWSO27aFc889dTiJjFQ4keDh9S4eEREJLJvNbARos0FEhOnaueiiU7/uiy98X5tIWakFRUSkkrn+enCse/nWW5CaCvv3l/6aBg2gRw+flyZSZgooIiKVyFdfObty+veHuDh49dVTv07TiiXYqItHRKSSOHEChgwxx7VqwdtvQ7t2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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "x = torch.tensor([[np.tan(np.pi/3)],[-np.tan(5*np.pi/24)],[-np.tan(7*np.pi/24)],[-np.tan(9*np.pi/24)],[-np.tan(11*np.pi/24)]], dtype = torch.float32)\n",
    "y = torch.tensor([[94],[29],[24],[20],[20]], dtype = torch.float32)\n",
    "\n",
    "for i in range(num_experiments):\n",
    "    \n",
    "    m = 6\n",
    "\n",
    "    model = nn.Sequential(\n",
    "                nn.Linear(1, m, bias = True, dtype = torch.float32),\n",
    "                nn.ReLU(),\n",
    "                nn.Linear(m, 1, bias = False, dtype = torch.float32)\n",
    "            )\n",
    "\n",
    "    optimizer = torch.optim.SGD(model.parameters(), lr=1e-3)\n",
    "    epochs = 100000\n",
    "    tol = 5e-5\n",
    "    lam = 1e-1\n",
    "\n",
    "    for i in range(epochs):\n",
    "\n",
    "        model.zero_grad()\n",
    "        l2_penalty = sum([torch.sum(param ** 2) for param in model.parameters()])\n",
    "        obj = torch.sum((model(x) - y) ** 2) / 2 + lam * l2_penalty/2\n",
    "        obj.backward()\n",
    "            \n",
    "        optimizer.step()\n",
    "\n",
    "        # check for convergence\n",
    "        \n",
    "        model.zero_grad()\n",
    "        l2_penalty = sum([torch.sum(param ** 2) for param in model.parameters()])\n",
    "        obj = torch.sum((model(x) - y) ** 2) / 2 + lam * l2_penalty/2\n",
    "        obj.backward()    \n",
    "        grad_norm = sum([torch.sum(param.grad ** 2) for param in model.parameters()])\n",
    "\n",
    "        if grad_norm <= tol:\n",
    "            print(f\"Converged at {i}/{epochs}\")\n",
    "            print(obj)\n",
    "            break\n",
    "\n",
    "        if i % 2500 == 0:\n",
    "            print(f\"{i}/{epochs}: Obj - {obj}, Grad - {grad_norm}\")\n",
    "\n",
    "\n",
    "    xs = np.linspace(-8, 4, 300).T\n",
    "    xs = np.expand_dims(xs, axis = 1)\n",
    "    plt.plot(xs, model(torch.tensor(xs, dtype = torch.float32)).detach().numpy(), color = 'blue')\n",
    "    for p in range(5):\n",
    "        plt.scatter(x[p], y[p], color = 'red', s = 80)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Converged at 49979/100000\n",
      "tensor(0.5488, grad_fn=<AddBackward0>)\n",
      "Converged at 49372/100000\n",
      "tensor(0.0975, grad_fn=<AddBackward0>)\n",
      "Converged at 50480/100000\n",
      "tensor(0.0975, grad_fn=<AddBackward0>)\n",
      "Converged at 49990/100000\n",
      "tensor(0.0975, grad_fn=<AddBackward0>)\n",
      "Converged at 50728/100000\n",
      "tensor(0.0975, grad_fn=<AddBackward0>)\n",
      "Converged at 49786/100000\n",
      "tensor(0.5488, grad_fn=<AddBackward0>)\n",
      "Converged at 50223/100000\n",
      "tensor(0.0975, grad_fn=<AddBackward0>)\n",
      "Converged at 45900/100000\n",
      "tensor(0.0975, grad_fn=<AddBackward0>)\n",
      "Converged at 45961/100000\n",
      "tensor(0.0975, grad_fn=<AddBackward0>)\n",
      "Converged at 50334/100000\n",
      "tensor(0.0975, grad_fn=<AddBackward0>)\n",
      "Converged at 51734/100000\n",
      "tensor(0.5488, grad_fn=<AddBackward0>)\n",
      "Converged at 48257/100000\n",
      "tensor(0.0975, grad_fn=<AddBackward0>)\n",
      "Converged at 48093/100000\n",
      "tensor(0.0975, grad_fn=<AddBackward0>)\n",
      "Converged at 48116/100000\n",
      "tensor(0.0975, grad_fn=<AddBackward0>)\n",
      "Converged at 46527/100000\n",
      "tensor(0.0975, grad_fn=<AddBackward0>)\n",
      "Converged at 49838/100000\n",
      "tensor(0.0975, grad_fn=<AddBackward0>)\n",
      "Converged at 46792/100000\n",
      "tensor(0.5488, grad_fn=<AddBackward0>)\n",
      "Converged at 46579/100000\n",
      "tensor(0.0975, grad_fn=<AddBackward0>)\n"
     ]
    },
    {
     "data": {
      "image/png": "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ubpJ/QrSvn17BAcHIzExEQ888AAA6UV9/PhxxMXFlbjsjnDm+tzh5MmTuHDhgu7B7WmevMb69esjOjoaiYmJecFHWloaNm7c6PSoI1c5en1xcXG4fPkytmzZgvbt2wMAVq5cCYvFkhdgOGL79u0A4NX3sCAhISFo3749EhMT0bdvXwBSVZyYmIhnn322wH3i4uKQmJiIUaNG5a37/fffvfZ5c4Yr15dfbm4udu7ciXvuuceDJfWeuLg4u2Ggvvr+ucv27dsN/6wVRimF5557DkuWLMGqVatQv379Yvcx5DPosa6xPujkyZOqUaNGqmvXrurkyZPqzJkzeS/bbZo0aaI2btyYt+6ZZ55RderUUStXrlSbN29WcXFxKi4uzohLKNY///yjtm3bpl599VVVoUIFtW3bNrVt2zaVnp6et02TJk3U4sWLlVJKpaenqxdeeEElJSWpo0ePqj/++EO1a9dO3XDDDer69etGXUaRnL1GpZR66623VKVKldQPP/ygduzYofr06aPq16+vrl27ZsQlFKl79+6qbdu2auPGjWrt2rXqhhtuUAMGDMj7ff6/0UOHDqkpU6aozZs3q6NHj6offvhBNWjQQN1+++1GXYLOggULlNlsVvPmzVN79uxRTz31lKpUqZJKTk5WSin12GOPqXHjxuVtv27dOhUUFKSmTZum9u7dqyZPnqyCg4PVzp07jbqEIjl7fa+++qpasWKFOnz4sNqyZYt6+OGHVWhoqNq9e7dRl1Ck9PT0vM8YAPXee++pbdu2qX/++UcppdS4cePUY489lrf9kSNHVLly5dTYsWPV3r171cyZM1VgYKBavny5UZdQJGev7/3331dLly5VBw8eVDt37lQjR45UAQEB6o8//jDqEoo0bNgwFRERoVatWqV75l29ejVvG1/4DJapYGTu3LkKQIEvq6NHjyoA6s8//8xbd+3aNTV8+HBVuXJlVa5cOXXffffpAhhfMmjQoAKvz/Z6AKi5c+cqpZS6evWquvvuu1W1atVUcHCwqlu3rho6dGjejdQXOXuNSsnw3okTJ6qoqChlNptV165d1f79+71feAdcuHBBDRgwQFWoUEGFh4erwYMH6wKt/H+jx48fV7fffruqUqWKMpvNqlGjRmrs2LEqNTXVoCuwN336dFWnTh0VEhKiOnbsqDZs2JD3u86dO6tBgwbptv/uu+9U48aNVUhIiGrevLn65ZdfvFxi5zhzfaNGjcrbNioqSt1zzz1q69atBpTaMdahrPlf1msaNGiQ6ty5s90+bdq0USEhIapBgwa6z6Kvcfb63n77bdWwYUMVGhqqqlSpou644w61cuVKYwrvgMKeebbviS98Bk3/V1giIiIiQ5SK0TRERETkvxiMEBERkaEYjBAREZGhGIwQERGRoRiMEBERkaEYjBAREZGhGIwQERGRoRiMEBERkaEYjBAREZGhGIwQERGRoRiMEBERkaEYjBAREZGh/j8+CUQ3R2+wHwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = torch.tensor([[-np.sqrt(3)],[np.sqrt(3)]], dtype = torch.float32)\n",
    "y = torch.tensor([[1],[1]], dtype = torch.float32)\n",
    "\n",
    "for i in range(num_experiments):\n",
    "    \n",
    "    m = 5\n",
    "\n",
    "    model = nn.Sequential(\n",
    "                nn.Linear(1, m, bias = True, dtype = torch.float32),\n",
    "                nn.ReLU(),\n",
    "                nn.Linear(m, 1, bias = False, dtype = torch.float32)\n",
    "            )\n",
    "\n",
    "    optimizer = torch.optim.SGD(model.parameters(), lr=1e-3)\n",
    "    epochs = 100000\n",
    "    tol = 1e-6\n",
    "    lam = 1e-1\n",
    "\n",
    "    for i in range(epochs):\n",
    "\n",
    "        model.zero_grad()\n",
    "        l2_penalty = sum([torch.sum(param ** 2) for param in model.parameters()])\n",
    "        obj = torch.sum((model(x) - y) ** 2) / 2 + lam * l2_penalty/2\n",
    "        obj.backward()\n",
    "            \n",
    "        optimizer.step()\n",
    "\n",
    "        # check for convergence\n",
    "        \n",
    "        model.zero_grad()\n",
    "        l2_penalty = sum([torch.sum(param ** 2) for param in model.parameters()])\n",
    "        obj = torch.sum((model(x) - y) ** 2) / 2 + lam * l2_penalty/2\n",
    "        obj.backward()    \n",
    "        grad_norm = sum([torch.sum(param.grad ** 2) for param in model.parameters()])\n",
    "\n",
    "        if grad_norm <= tol:\n",
    "            print(f\"Converged at {i}/{epochs}\")\n",
    "            print(obj)\n",
    "            break\n",
    "\n",
    "        #if i % 25 == 0:\n",
    "        #    print(f\"{i}/{epochs}: Obj - {obj}, Grad - {grad_norm}\")\n",
    "\n",
    "\n",
    "    xs = np.linspace(-2, 2, 100).T\n",
    "    xs = np.expand_dims(xs, axis = 1)\n",
    "    plt.plot(xs, model(torch.tensor(xs, dtype = torch.float32)).detach().numpy(), color = 'blue')\n",
    "    plt.scatter(np.sqrt(3), 1, color = 'red', s = 80)\n",
    "    plt.scatter(-np.sqrt(3), 1, color = 'red', s = 80)\n",
    "    plt.ylim(0,1.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0/100000: Obj - 5362.2021484375, Grad - 95953.328125\n",
      "2500/100000: Obj - 6.107298374176025, Grad - 0.06921267509460449\n",
      "5000/100000: Obj - 6.0537190437316895, Grad - 0.01655721664428711\n",
      "7500/100000: Obj - 6.020477294921875, Grad - 0.010513932444155216\n",
      "10000/100000: Obj - 5.99928617477417, Grad - 0.006734294351190329\n",
      "12500/100000: Obj - 5.985641956329346, Grad - 0.004364940337836742\n",
      "15000/100000: Obj - 5.976734638214111, Grad - 0.002875795355066657\n",
      "17500/100000: Obj - 5.9708099365234375, Grad - 0.001935460022650659\n",
      "20000/100000: Obj - 5.966774940490723, Grad - 0.0013376242714002728\n",
      "22500/100000: Obj - 5.9639458656311035, Grad - 0.0009539025486446917\n",
      "25000/100000: Obj - 5.961895942687988, Grad - 0.0007042227080091834\n",
      "27500/100000: Obj - 5.960357189178467, Grad - 0.0005389453726820648\n",
      "30000/100000: Obj - 5.959158897399902, Grad - 0.00042707836837507784\n",
      "32500/100000: Obj - 5.958194255828857, Grad - 0.0003492282994557172\n",
      "35000/100000: Obj - 5.957396507263184, Grad - 0.0002936210948973894\n",
      "37500/100000: Obj - 5.9567155838012695, Grad - 0.0002523181028664112\n",
      "40000/100000: Obj - 5.956126689910889, Grad - 0.00022081713541410863\n",
      "42500/100000: Obj - 5.955605506896973, Grad - 0.0001959039509529248\n",
      "45000/100000: Obj - 5.955143928527832, Grad - 0.00017572022625245154\n",
      "47500/100000: Obj - 5.954726219177246, Grad - 0.00015885444008745253\n",
      "50000/100000: Obj - 5.954347133636475, Grad - 0.00014437442587222904\n",
      "52500/100000: Obj - 5.954002857208252, Grad - 0.00013207862502895296\n",
      "55000/100000: Obj - 5.9536871910095215, Grad - 0.00012119683378841728\n",
      "57500/100000: Obj - 5.953396797180176, Grad - 0.00011165202886331826\n",
      "60000/100000: Obj - 5.953128814697266, Grad - 0.0001031047577271238\n",
      "62500/100000: Obj - 5.952880382537842, Grad - 9.549122478347272e-05\n",
      "65000/100000: Obj - 5.9526519775390625, Grad - 8.845413685776293e-05\n",
      "67500/100000: Obj - 5.952439785003662, Grad - 8.220412564696744e-05\n",
      "70000/100000: Obj - 5.952240943908691, Grad - 7.65217118896544e-05\n",
      "72500/100000: Obj - 5.952056884765625, Grad - 7.136793283279985e-05\n",
      "75000/100000: Obj - 5.951884746551514, Grad - 6.667136767646298e-05\n",
      "77500/100000: Obj - 5.951724052429199, Grad - 6.234904140001163e-05\n",
      "80000/100000: Obj - 5.951573371887207, Grad - 5.845346822752617e-05\n",
      "82500/100000: Obj - 5.951433181762695, Grad - 5.482070992002264e-05\n",
      "85000/100000: Obj - 5.951300144195557, Grad - 5.1382208766881377e-05\n",
      "Converged at 86099/100000\n",
      "tensor(5.9512, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5308.50244140625, Grad - 180520.625\n",
      "2500/100000: Obj - 6.070836067199707, Grad - 0.022813830524683\n",
      "5000/100000: Obj - 6.0260701179504395, Grad - 0.01378720998764038\n",
      "7500/100000: Obj - 5.998902797698975, Grad - 0.008401729166507721\n",
      "10000/100000: Obj - 5.982298851013184, Grad - 0.005150056444108486\n",
      "12500/100000: Obj - 5.972097873687744, Grad - 0.0031726143788546324\n",
      "15000/100000: Obj - 5.965799331665039, Grad - 0.0019641618710011244\n",
      "17500/100000: Obj - 5.961890697479248, Grad - 0.001223138184286654\n",
      "20000/100000: Obj - 5.95944881439209, Grad - 0.000767452351283282\n",
      "22500/100000: Obj - 5.957908630371094, Grad - 0.0004865934606641531\n",
      "25000/100000: Obj - 5.9569268226623535, Grad - 0.0003131165576633066\n",
      "27500/100000: Obj - 5.956290245056152, Grad - 0.00020567256433423609\n",
      "30000/100000: Obj - 5.955865383148193, Grad - 0.00013887291424907744\n",
      "32500/100000: Obj - 5.9555745124816895, Grad - 9.778642561286688e-05\n",
      "35000/100000: Obj - 5.955366134643555, Grad - 7.117475615814328e-05\n",
      "37500/100000: Obj - 5.955210208892822, Grad - 5.457395673147403e-05\n",
      "Converged at 38454/100000\n",
      "tensor(5.9552, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5292.9990234375, Grad - 229550.578125\n",
      "2500/100000: Obj - 7.4051666259765625, Grad - 0.017602402716875076\n",
      "5000/100000: Obj - 7.37116813659668, Grad - 0.010275682434439659\n",
      "7500/100000: Obj - 7.351223945617676, Grad - 0.006062375381588936\n",
      "10000/100000: Obj - 7.339400291442871, Grad - 0.0036132927052676678\n",
      "12500/100000: Obj - 7.332327842712402, Grad - 0.0021720409858971834\n",
      "15000/100000: Obj - 7.328060626983643, Grad - 0.0013143960386514664\n",
      "17500/100000: Obj - 7.325468063354492, Grad - 0.0007994920015335083\n",
      "20000/100000: Obj - 7.323895454406738, Grad - 0.0004882601788267493\n",
      "22500/100000: Obj - 7.322930335998535, Grad - 0.00029904060647822917\n",
      "25000/100000: Obj - 7.322344779968262, Grad - 0.0001836281007854268\n",
      "27500/100000: Obj - 7.3219780921936035, Grad - 0.00011307684326311573\n",
      "30000/100000: Obj - 7.321752071380615, Grad - 6.975195719860494e-05\n",
      "Converged at 31728/100000\n",
      "tensor(7.3217, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5390.0654296875, Grad - 206735.421875\n",
      "2500/100000: Obj - 21.30680274963379, Grad - 0.25074583292007446\n",
      "5000/100000: Obj - 21.063438415527344, Grad - 0.09064634144306183\n",
      "7500/100000: Obj - 20.92059326171875, Grad - 0.0706222653388977\n",
      "10000/100000: Obj - 20.83950424194336, Grad - 0.027553770691156387\n",
      "12500/100000: Obj - 20.794591903686523, Grad - 0.014596424996852875\n",
      "15000/100000: Obj - 20.770034790039062, Grad - 0.008077451027929783\n",
      "17500/100000: Obj - 20.756616592407227, Grad - 0.006712744012475014\n",
      "20000/100000: Obj - 20.749225616455078, Grad - 0.0023219778668135405\n",
      "22500/100000: Obj - 20.74514389038086, Grad - 0.0012994681019335985\n",
      "25000/100000: Obj - 20.74283218383789, Grad - 0.0007174796191975474\n",
      "27500/100000: Obj - 20.741506576538086, Grad - 0.0004155500791966915\n",
      "30000/100000: Obj - 20.74071502685547, Grad - 0.00025106300017796457\n",
      "32500/100000: Obj - 20.740201950073242, Grad - 0.00016016651352401823\n",
      "35000/100000: Obj - 20.739891052246094, Grad - 0.00010916459723375738\n",
      "37500/100000: Obj - 20.739654541015625, Grad - 7.993574399733916e-05\n",
      "40000/100000: Obj - 20.73946762084961, Grad - 6.281674723140895e-05\n",
      "42500/100000: Obj - 20.739336013793945, Grad - 5.228746886132285e-05\n",
      "Converged at 43194/100000\n",
      "tensor(20.7393, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5249.6015625, Grad - 297169.78125\n",
      "2500/100000: Obj - 6.0365447998046875, Grad - 0.023587478324770927\n",
      "5000/100000: Obj - 5.996053218841553, Grad - 0.011248920112848282\n",
      "7500/100000: Obj - 5.975221157073975, Grad - 0.006017177831381559\n",
      "10000/100000: Obj - 5.963876724243164, Grad - 0.003343581221997738\n",
      "12500/100000: Obj - 5.957485198974609, Grad - 0.0019129045540466905\n",
      "15000/100000: Obj - 5.953795433044434, Grad - 0.001116133644245565\n",
      "17500/100000: Obj - 5.951623916625977, Grad - 0.0006622718647122383\n",
      "20000/100000: Obj - 5.950328826904297, Grad - 0.0003963206254411489\n",
      "22500/100000: Obj - 5.9495530128479, Grad - 0.00023851219157222658\n",
      "25000/100000: Obj - 5.949085235595703, Grad - 0.00014407631533686072\n",
      "27500/100000: Obj - 5.9488019943237305, Grad - 8.721575431991369e-05\n",
      "30000/100000: Obj - 5.948630332946777, Grad - 5.289587352308445e-05\n",
      "Converged at 30283/100000\n",
      "tensor(5.9486, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5477.302734375, Grad - 34447.38671875\n",
      "2500/100000: Obj - 7.4272308349609375, Grad - 0.021019870415329933\n",
      "5000/100000: Obj - 7.385830879211426, Grad - 0.012783598154783249\n",
      "7500/100000: Obj - 7.36064338684082, Grad - 0.00777844525873661\n",
      "10000/100000: Obj - 7.345312595367432, Grad - 0.004734905902296305\n",
      "12500/100000: Obj - 7.33597993850708, Grad - 0.002883321838453412\n",
      "15000/100000: Obj - 7.330295085906982, Grad - 0.001756498939357698\n",
      "17500/100000: Obj - 7.326837062835693, Grad - 0.001070479629561305\n",
      "20000/100000: Obj - 7.3247199058532715, Grad - 0.0006526284851133823\n",
      "22500/100000: Obj - 7.323432922363281, Grad - 0.0003980832116212696\n",
      "25000/100000: Obj - 7.322652816772461, Grad - 0.00024287719861604273\n",
      "27500/100000: Obj - 7.322170257568359, Grad - 0.0001483226369600743\n",
      "30000/100000: Obj - 7.32188081741333, Grad - 9.061547461897135e-05\n",
      "32500/100000: Obj - 7.321700096130371, Grad - 5.533266084967181e-05\n",
      "Converged at 33016/100000\n",
      "tensor(7.3217, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5286.94482421875, Grad - 176043.6875\n",
      "2500/100000: Obj - 6.117746829986572, Grad - 0.035425156354904175\n",
      "5000/100000: Obj - 6.048758506774902, Grad - 0.020949311554431915\n",
      "7500/100000: Obj - 6.008260726928711, Grad - 0.012198577634990215\n",
      "10000/100000: Obj - 5.984778881072998, Grad - 0.007050700485706329\n",
      "12500/100000: Obj - 5.971202850341797, Grad - 0.004083465319126844\n",
      "15000/100000: Obj - 5.9633684158325195, Grad - 0.0023579488042742014\n",
      "17500/100000: Obj - 5.958762168884277, Grad - 0.0014102546265348792\n",
      "20000/100000: Obj - 5.95599889755249, Grad - 0.0008484464487992227\n",
      "22500/100000: Obj - 5.95433235168457, Grad - 0.0005132522783242166\n",
      "25000/100000: Obj - 5.953315734863281, Grad - 0.00031521901837550104\n",
      "27500/100000: Obj - 5.952693462371826, Grad - 0.0001927681005327031\n",
      "30000/100000: Obj - 5.952313423156738, Grad - 0.00011827128764707595\n",
      "32500/100000: Obj - 5.952078819274902, Grad - 7.281344733200967e-05\n",
      "Converged at 34502/100000\n",
      "tensor(5.9520, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5267.31787109375, Grad - 218086.34375\n",
      "2500/100000: Obj - 7.398747444152832, Grad - 0.015902219340205193\n",
      "5000/100000: Obj - 7.367806911468506, Grad - 0.00943197775632143\n",
      "7500/100000: Obj - 7.34937858581543, Grad - 0.005643761716783047\n",
      "10000/100000: Obj - 7.332659721374512, Grad - 0.017228994518518448\n",
      "12500/100000: Obj - 7.315268516540527, Grad - 0.06948933005332947\n",
      "15000/100000: Obj - 7.284822940826416, Grad - 0.25720715522766113\n",
      "17500/100000: Obj - 7.217416763305664, Grad - 0.6392874121665955\n",
      "20000/100000: Obj - 7.089563846588135, Grad - 1.1886471509933472\n",
      "22500/100000: Obj - 6.9264020919799805, Grad - 1.7618129253387451\n",
      "25000/100000: Obj - 6.797275066375732, Grad - 1.8806912899017334\n",
      "27500/100000: Obj - 6.725239276885986, Grad - 1.7636337280273438\n",
      "30000/100000: Obj - 6.688674449920654, Grad - 0.9657489061355591\n",
      "32500/100000: Obj - 6.670431613922119, Grad - 0.8936394453048706\n",
      "35000/100000: Obj - 6.6545000076293945, Grad - 1.773657202720642\n",
      "37500/100000: Obj - 6.646947383880615, Grad - 1.6006277799606323\n",
      "40000/100000: Obj - 6.643343925476074, Grad - 1.8473807573318481\n",
      "42500/100000: Obj - 6.642895221710205, Grad - 1.6694549322128296\n",
      "45000/100000: Obj - 6.642679214477539, Grad - 1.6616536378860474\n",
      "47500/100000: Obj - 6.6437225341796875, Grad - 1.5648419857025146\n",
      "50000/100000: Obj - 6.643904209136963, Grad - 1.5774401426315308\n",
      "52500/100000: Obj - 6.643253326416016, Grad - 1.847419023513794\n",
      "55000/100000: Obj - 6.642842769622803, Grad - 1.6694426536560059\n",
      "57500/100000: Obj - 6.642650604248047, Grad - 1.6617546081542969\n",
      "60000/100000: Obj - 6.64366340637207, Grad - 1.5432937145233154\n",
      "62500/100000: Obj - 6.643883228302002, Grad - 1.5773286819458008\n",
      "65000/100000: Obj - 6.643256187438965, Grad - 1.8476881980895996\n",
      "67500/100000: Obj - 6.642849445343018, Grad - 1.6695501804351807\n",
      "70000/100000: Obj - 6.642657279968262, Grad - 1.6620409488677979\n",
      "72500/100000: Obj - 6.643653392791748, Grad - 1.5433663129806519\n",
      "75000/100000: Obj - 6.643870830535889, Grad - 1.5766711235046387\n",
      "77500/100000: Obj - 6.643263816833496, Grad - 1.8478996753692627\n",
      "80000/100000: Obj - 6.642858028411865, Grad - 1.6700078248977661\n",
      "82500/100000: Obj - 6.642665386199951, Grad - 1.6620614528656006\n",
      "85000/100000: Obj - 6.643648147583008, Grad - 1.543517827987671\n",
      "87500/100000: Obj - 6.643866062164307, Grad - 1.5768734216690063\n",
      "90000/100000: Obj - 6.643784046173096, Grad - 2.321119546890259\n",
      "92500/100000: Obj - 6.642874240875244, Grad - 1.675221562385559\n",
      "95000/100000: Obj - 6.642673492431641, Grad - 1.6623305082321167\n",
      "97500/100000: Obj - 6.643641948699951, Grad - 1.543539047241211\n",
      "0/100000: Obj - 5395.32666015625, Grad - 116954.0078125\n",
      "2500/100000: Obj - 7.415884971618652, Grad - 0.015931149944663048\n",
      "5000/100000: Obj - 7.384117126464844, Grad - 0.009991376660764217\n",
      "7500/100000: Obj - 7.363988876342773, Grad - 0.0064059654250741005\n",
      "10000/100000: Obj - 7.350951671600342, Grad - 0.0041955565102398396\n",
      "12500/100000: Obj - 7.3423261642456055, Grad - 0.002808013465255499\n",
      "15000/100000: Obj - 7.336497783660889, Grad - 0.0019217055523768067\n",
      "17500/100000: Obj - 7.332467079162598, Grad - 0.0013449261896312237\n",
      "20000/100000: Obj - 7.329612731933594, Grad - 0.0009619762422516942\n",
      "22500/100000: Obj - 7.3275532722473145, Grad - 0.0007023022044450045\n",
      "25000/100000: Obj - 7.326037406921387, Grad - 0.0005221057217568159\n",
      "27500/100000: Obj - 7.324903964996338, Grad - 0.00039451185148209333\n",
      "30000/100000: Obj - 7.324038982391357, Grad - 0.0003017348935827613\n",
      "32500/100000: Obj - 7.323371887207031, Grad - 0.00023329572286456823\n",
      "35000/100000: Obj - 7.322856903076172, Grad - 0.00018194640870206058\n",
      "37500/100000: Obj - 7.3224592208862305, Grad - 0.00014268737868405879\n",
      "40000/100000: Obj - 7.322134017944336, Grad - 0.0001124688278650865\n",
      "42500/100000: Obj - 7.321887493133545, Grad - 8.894577331375331e-05\n",
      "45000/100000: Obj - 7.321685314178467, Grad - 7.054974412312731e-05\n",
      "47500/100000: Obj - 7.321529388427734, Grad - 5.5952888942556456e-05\n",
      "Converged at 48718/100000\n",
      "tensor(7.3215, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5302.7978515625, Grad - 140046.75\n",
      "2500/100000: Obj - 21.28738784790039, Grad - 0.1837603747844696\n",
      "5000/100000: Obj - 21.042179107666016, Grad - 0.09887973964214325\n",
      "7500/100000: Obj - 20.901599884033203, Grad - 0.05168836563825607\n",
      "10000/100000: Obj - 20.824235916137695, Grad - 0.02445811778306961\n",
      "12500/100000: Obj - 20.782840728759766, Grad - 0.012997495010495186\n",
      "15000/100000: Obj - 20.760986328125, Grad - 0.007079434115439653\n",
      "17500/100000: Obj - 20.74946403503418, Grad - 0.0034466227516531944\n",
      "20000/100000: Obj - 20.743385314941406, Grad - 0.0018014071974903345\n",
      "22500/100000: Obj - 20.74013328552246, Grad - 0.0009524868219159544\n",
      "25000/100000: Obj - 20.738399505615234, Grad - 0.0005119674024172127\n",
      "27500/100000: Obj - 20.737438201904297, Grad - 0.00028129795100539923\n",
      "30000/100000: Obj - 20.736900329589844, Grad - 0.0001592952903592959\n",
      "32500/100000: Obj - 20.736587524414062, Grad - 9.116766159422696e-05\n",
      "35000/100000: Obj - 20.73642349243164, Grad - 5.3460484195966274e-05\n",
      "Converged at 35323/100000\n",
      "tensor(20.7364, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5352.28759765625, Grad - 204349.078125\n",
      "2500/100000: Obj - 6.450738430023193, Grad - 0.18153685331344604\n",
      "5000/100000: Obj - 6.244035720825195, Grad - 0.05647724121809006\n",
      "7500/100000: Obj - 6.131144046783447, Grad - 0.03534012287855148\n",
      "10000/100000: Obj - 6.061318874359131, Grad - 0.021550772711634636\n",
      "12500/100000: Obj - 6.020071506500244, Grad - 0.012613706290721893\n",
      "15000/100000: Obj - 5.9949774742126465, Grad - 0.007844292558729649\n",
      "17500/100000: Obj - 5.979389667510986, Grad - 0.00485927052795887\n",
      "20000/100000: Obj - 5.9697442054748535, Grad - 0.003005701582878828\n",
      "22500/100000: Obj - 5.963768005371094, Grad - 0.0018683975795283914\n",
      "25000/100000: Obj - 5.960034370422363, Grad - 0.0011765360832214355\n",
      "27500/100000: Obj - 5.9576616287231445, Grad - 0.0007568973815068603\n",
      "30000/100000: Obj - 5.956114292144775, Grad - 0.000501861097291112\n",
      "32500/100000: Obj - 5.955070495605469, Grad - 0.00034598822821862996\n",
      "35000/100000: Obj - 5.954335689544678, Grad - 0.00024946738267317414\n",
      "37500/100000: Obj - 5.953794002532959, Grad - 0.00018866994651034474\n",
      "40000/100000: Obj - 5.953375339508057, Grad - 0.00014938674576114863\n",
      "42500/100000: Obj - 5.953037738800049, Grad - 0.00012347307347226888\n",
      "45000/100000: Obj - 5.952752113342285, Grad - 0.0001056198962032795\n",
      "47500/100000: Obj - 5.952505111694336, Grad - 9.281112579628825e-05\n",
      "50000/100000: Obj - 5.9522857666015625, Grad - 8.307611278723925e-05\n",
      "52500/100000: Obj - 5.952089309692383, Grad - 7.544009713456035e-05\n",
      "55000/100000: Obj - 5.951908588409424, Grad - 6.92518224241212e-05\n",
      "57500/100000: Obj - 5.951742649078369, Grad - 6.402365397661924e-05\n",
      "60000/100000: Obj - 5.9515886306762695, Grad - 5.9494115703273565e-05\n",
      "62500/100000: Obj - 5.95144510269165, Grad - 5.5503565818071365e-05\n",
      "65000/100000: Obj - 5.9513115882873535, Grad - 5.1935996452812105e-05\n",
      "Converged at 66473/100000\n",
      "tensor(5.9512, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5292.873046875, Grad - 143168.921875\n",
      "2500/100000: Obj - 6.122836589813232, Grad - 0.032941486686468124\n",
      "5000/100000: Obj - 6.0580925941467285, Grad - 0.020004048943519592\n",
      "7500/100000: Obj - 6.018634796142578, Grad - 0.012203735299408436\n",
      "10000/100000: Obj - 5.9945502281188965, Grad - 0.007454686798155308\n",
      "12500/100000: Obj - 5.979825973510742, Grad - 0.004561273381114006\n",
      "15000/100000: Obj - 5.970810890197754, Grad - 0.0027957595884799957\n",
      "17500/100000: Obj - 5.965280532836914, Grad - 0.0017167542828246951\n",
      "20000/100000: Obj - 5.961881637573242, Grad - 0.0010561549570411444\n",
      "22500/100000: Obj - 5.959786891937256, Grad - 0.0006518897134810686\n",
      "25000/100000: Obj - 5.958494663238525, Grad - 0.0004023853107355535\n",
      "27500/100000: Obj - 5.957695484161377, Grad - 0.00024901324650272727\n",
      "30000/100000: Obj - 5.957200527191162, Grad - 0.00015441604773513973\n",
      "32500/100000: Obj - 5.9568939208984375, Grad - 9.847038745647296e-05\n",
      "35000/100000: Obj - 5.956697940826416, Grad - 6.117831071605906e-05\n",
      "Converged at 36070/100000\n",
      "tensor(5.9566, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5359.3671875, Grad - 186612.078125\n",
      "2500/100000: Obj - 21.076276779174805, Grad - 18.177989959716797\n",
      "5000/100000: Obj - 20.9210147857666, Grad - 9.413520812988281\n",
      "7500/100000: Obj - 20.835765838623047, Grad - 0.02774876542389393\n",
      "10000/100000: Obj - 20.789962768554688, Grad - 0.015493413433432579\n",
      "12500/100000: Obj - 20.765546798706055, Grad - 0.0075307064689695835\n",
      "15000/100000: Obj - 20.752538681030273, Grad - 0.003974626772105694\n",
      "17500/100000: Obj - 20.745569229125977, Grad - 0.002098310040310025\n",
      "20000/100000: Obj - 20.741790771484375, Grad - 0.0011262723710387945\n",
      "22500/100000: Obj - 20.73973846435547, Grad - 0.0006139444303698838\n",
      "25000/100000: Obj - 20.738590240478516, Grad - 0.0003416311228647828\n",
      "27500/100000: Obj - 20.737937927246094, Grad - 0.0001951396989170462\n",
      "30000/100000: Obj - 20.73756980895996, Grad - 0.00011468531010905281\n",
      "32500/100000: Obj - 20.737348556518555, Grad - 6.995463627390563e-05\n",
      "Converged at 34296/100000\n",
      "tensor(20.7372, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5180.18994140625, Grad - 175840.78125\n",
      "2500/100000: Obj - 7.5047078132629395, Grad - 0.03918849676847458\n",
      "5000/100000: Obj - 7.429410457611084, Grad - 0.022622937336564064\n",
      "7500/100000: Obj - 7.3856658935546875, Grad - 0.013247909024357796\n",
      "10000/100000: Obj - 7.359891891479492, Grad - 0.007854892872273922\n",
      "12500/100000: Obj - 7.34454345703125, Grad - 0.0047005657106637955\n",
      "15000/100000: Obj - 7.335329055786133, Grad - 0.002831599209457636\n",
      "17500/100000: Obj - 7.329763412475586, Grad - 0.0017137749819085002\n",
      "20000/100000: Obj - 7.326391696929932, Grad - 0.0010408909292891622\n",
      "22500/100000: Obj - 7.324338912963867, Grad - 0.0006340784020721912\n",
      "25000/100000: Obj - 7.323090553283691, Grad - 0.0003873337700497359\n",
      "27500/100000: Obj - 7.322322845458984, Grad - 0.0002370958391111344\n",
      "30000/100000: Obj - 7.321859359741211, Grad - 0.00014552209177054465\n",
      "32500/100000: Obj - 7.321565628051758, Grad - 8.964623702922836e-05\n",
      "35000/100000: Obj - 7.321392059326172, Grad - 5.536747630685568e-05\n",
      "Converged at 35534/100000\n",
      "tensor(7.3214, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5339.7294921875, Grad - 242165.625\n",
      "2500/100000: Obj - 6.025315761566162, Grad - 0.01392086036503315\n",
      "5000/100000: Obj - 5.998589992523193, Grad - 0.00803909171372652\n",
      "7500/100000: Obj - 5.982998371124268, Grad - 0.00474158301949501\n",
      "10000/100000: Obj - 5.973732948303223, Grad - 0.0028401007875800133\n",
      "12500/100000: Obj - 5.968152046203613, Grad - 0.0017220110166817904\n",
      "15000/100000: Obj - 5.964749813079834, Grad - 0.001055872067809105\n",
      "17500/100000: Obj - 5.962653160095215, Grad - 0.0006556364824064076\n",
      "20000/100000: Obj - 5.9613423347473145, Grad - 0.0004137410141993314\n",
      "22500/100000: Obj - 5.960505962371826, Grad - 0.00026675104163587093\n",
      "25000/100000: Obj - 5.9599609375, Grad - 0.00017715759167913347\n",
      "27500/100000: Obj - 5.959592342376709, Grad - 0.00012226070975884795\n",
      "30000/100000: Obj - 5.9593329429626465, Grad - 8.846057608025149e-05\n",
      "32500/100000: Obj - 5.959141254425049, Grad - 6.745185237377882e-05\n",
      "35000/100000: Obj - 5.958991527557373, Grad - 5.422827962320298e-05\n",
      "Converged at 36112/100000\n",
      "tensor(5.9589, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5235.26611328125, Grad - 196232.625\n",
      "2500/100000: Obj - 7.514656066894531, Grad - 0.05071089789271355\n",
      "5000/100000: Obj - 7.429220676422119, Grad - 0.027140967547893524\n",
      "7500/100000: Obj - 7.383458137512207, Grad - 0.01428267639130354\n",
      "10000/100000: Obj - 7.359068870544434, Grad - 0.007510901894420385\n",
      "12500/100000: Obj - 7.345970630645752, Grad - 0.003994929138571024\n",
      "15000/100000: Obj - 7.33883810043335, Grad - 0.0021643848158419132\n",
      "17500/100000: Obj - 7.334867000579834, Grad - 0.001202080282382667\n",
      "20000/100000: Obj - 7.3326029777526855, Grad - 0.0006887191557325423\n",
      "22500/100000: Obj - 7.331274032592773, Grad - 0.0004100269579794258\n",
      "25000/100000: Obj - 7.330456733703613, Grad - 0.00025579254725016654\n",
      "27500/100000: Obj - 7.329936981201172, Grad - 0.00016868226521182805\n",
      "30000/100000: Obj - 7.329586029052734, Grad - 0.00011795588943641633\n",
      "32500/100000: Obj - 7.3293328285217285, Grad - 8.749137487029657e-05\n",
      "35000/100000: Obj - 7.329140663146973, Grad - 6.865887553431094e-05\n",
      "37500/100000: Obj - 7.328986167907715, Grad - 5.66463713767007e-05\n",
      "Converged at 39559/100000\n",
      "tensor(7.3289, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5281.583984375, Grad - 139550.890625\n",
      "2500/100000: Obj - 6.205149173736572, Grad - 0.0802023783326149\n",
      "5000/100000: Obj - 6.09779167175293, Grad - 0.030124470591545105\n",
      "7500/100000: Obj - 6.038751125335693, Grad - 0.018351685255765915\n",
      "10000/100000: Obj - 6.002539157867432, Grad - 0.011183209717273712\n",
      "12500/100000: Obj - 5.980588912963867, Grad - 0.006732341833412647\n",
      "15000/100000: Obj - 5.9674506187438965, Grad - 0.004005027934908867\n",
      "17500/100000: Obj - 5.959661960601807, Grad - 0.002366140019148588\n",
      "20000/100000: Obj - 5.955065727233887, Grad - 0.0013956421753391623\n",
      "22500/100000: Obj - 5.952353477478027, Grad - 0.0008248756639659405\n",
      "25000/100000: Obj - 5.950761795043945, Grad - 0.0004844327340833843\n",
      "27500/100000: Obj - 5.949808120727539, Grad - 0.00029378803446888924\n",
      "30000/100000: Obj - 5.949230194091797, Grad - 0.00017821921210270375\n",
      "32500/100000: Obj - 5.948880195617676, Grad - 0.00010813866538228467\n",
      "35000/100000: Obj - 5.948667526245117, Grad - 6.578156899195164e-05\n",
      "Converged at 36365/100000\n",
      "tensor(5.9486, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5275.4755859375, Grad - 234979.0\n",
      "2500/100000: Obj - 6.036135196685791, Grad - 0.018734700977802277\n",
      "5000/100000: Obj - 6.000914573669434, Grad - 0.010660048574209213\n",
      "7500/100000: Obj - 5.980066776275635, Grad - 0.006388877052813768\n",
      "10000/100000: Obj - 5.9675421714782715, Grad - 0.003847269108518958\n",
      "12500/100000: Obj - 5.95999002456665, Grad - 0.002323405584320426\n",
      "15000/100000: Obj - 5.955423831939697, Grad - 0.0014056562213227153\n",
      "17500/100000: Obj - 5.952661514282227, Grad - 0.0008513665525242686\n",
      "20000/100000: Obj - 5.950987339019775, Grad - 0.000515978317707777\n",
      "22500/100000: Obj - 5.949973106384277, Grad - 0.0003129213291686028\n",
      "25000/100000: Obj - 5.9493560791015625, Grad - 0.00018989147793035954\n",
      "27500/100000: Obj - 5.9489827156066895, Grad - 0.0001152920740423724\n",
      "30000/100000: Obj - 5.948756694793701, Grad - 7.008303509792313e-05\n",
      "Converged at 31698/100000\n",
      "tensor(5.9487, grad_fn=<AddBackward0>)\n",
      "0/100000: Obj - 5298.26953125, Grad - 237485.734375\n",
      "2500/100000: Obj - 6.044193744659424, Grad - 0.015209709294140339\n",
      "5000/100000: Obj - 6.015203475952148, Grad - 0.008676080033183098\n",
      "7500/100000: Obj - 5.998334884643555, Grad - 0.005167838651686907\n",
      "10000/100000: Obj - 5.988090515136719, Grad - 0.003210362745448947\n",
      "12500/100000: Obj - 5.981612682342529, Grad - 0.002078481949865818\n",
      "15000/100000: Obj - 5.977319717407227, Grad - 0.001410574885085225\n",
      "17500/100000: Obj - 5.974345684051514, Grad - 0.0010015360312536359\n",
      "20000/100000: Obj - 5.9721856117248535, Grad - 0.0007459434564225376\n",
      "22500/100000: Obj - 5.9705400466918945, Grad - 0.0005827091517858207\n",
      "25000/100000: Obj - 5.969228267669678, Grad - 0.00047556799836456776\n",
      "27500/100000: Obj - 5.968137741088867, Grad - 0.00040291176992468536\n",
      "30000/100000: Obj - 5.967198371887207, Grad - 0.0003516831202432513\n",
      "32500/100000: Obj - 5.966367721557617, Grad - 0.00031399616273120046\n",
      "35000/100000: Obj - 5.9656219482421875, Grad - 0.00028516780002973974\n",
      "37500/100000: Obj - 5.964939117431641, Grad - 0.00026211992371827364\n",
      "40000/100000: Obj - 5.964308738708496, Grad - 0.0002430629392620176\n",
      "42500/100000: Obj - 5.963722229003906, Grad - 0.00022677797824144363\n",
      "45000/100000: Obj - 5.963175296783447, Grad - 0.00021256302716210485\n",
      "47500/100000: Obj - 5.962658405303955, Grad - 0.00019991799490526319\n",
      "50000/100000: Obj - 5.962174892425537, Grad - 0.00018853640358429402\n",
      "52500/100000: Obj - 5.9617180824279785, Grad - 0.0001781397295417264\n",
      "55000/100000: Obj - 5.961284637451172, Grad - 0.0001686238538241014\n",
      "57500/100000: Obj - 5.960875034332275, Grad - 0.0001598678936716169\n",
      "60000/100000: Obj - 5.960485458374023, Grad - 0.00015172774146776646\n",
      "62500/100000: Obj - 5.960116863250732, Grad - 0.00014416835620068014\n",
      "65000/100000: Obj - 5.959765911102295, Grad - 0.0001371307298541069\n",
      "67500/100000: Obj - 5.959432601928711, Grad - 0.00013053996372036636\n",
      "70000/100000: Obj - 5.959114074707031, Grad - 0.0001244198647327721\n",
      "72500/100000: Obj - 5.958811283111572, Grad - 0.00011863336840178818\n",
      "75000/100000: Obj - 5.958522796630859, Grad - 0.00011325256491545588\n",
      "77500/100000: Obj - 5.95824670791626, Grad - 0.00010816567373694852\n",
      "80000/100000: Obj - 5.957983016967773, Grad - 0.00010337241110391915\n",
      "82500/100000: Obj - 5.957729816436768, Grad - 9.88425308605656e-05\n",
      "85000/100000: Obj - 5.957488059997559, Grad - 9.460990258958191e-05\n",
      "87500/100000: Obj - 5.957258701324463, Grad - 9.06374552869238e-05\n",
      "90000/100000: Obj - 5.957037448883057, Grad - 8.678974700160325e-05\n",
      "92500/100000: Obj - 5.95682430267334, Grad - 8.316192543134093e-05\n",
      "95000/100000: Obj - 5.95662260055542, Grad - 7.979110523592681e-05\n",
      "97500/100000: Obj - 5.956427097320557, Grad - 7.654586079297587e-05\n",
      "0/100000: Obj - 5503.1015625, Grad - 133929.71875\n",
      "2500/100000: Obj - 6.232834815979004, Grad - 0.06034865975379944\n",
      "5000/100000: Obj - 6.1193342208862305, Grad - 0.03488733991980553\n",
      "7500/100000: Obj - 6.052031517028809, Grad - 0.02088756486773491\n",
      "10000/100000: Obj - 6.010768413543701, Grad - 0.012756221927702427\n",
      "12500/100000: Obj - 5.985703468322754, Grad - 0.007700873073190451\n",
      "15000/100000: Obj - 5.970637798309326, Grad - 0.004608700051903725\n",
      "17500/100000: Obj - 5.961642742156982, Grad - 0.0027460965793579817\n",
      "20000/100000: Obj - 5.95628547668457, Grad - 0.0016349473735317588\n",
      "22500/100000: Obj - 5.95309591293335, Grad - 0.000974781287368387\n",
      "25000/100000: Obj - 5.9511942863464355, Grad - 0.0005795375909656286\n",
      "27500/100000: Obj - 5.950061321258545, Grad - 0.0003487960493657738\n",
      "30000/100000: Obj - 5.949374675750732, Grad - 0.0002115717506967485\n",
      "32500/100000: Obj - 5.948958873748779, Grad - 0.00012836743553634733\n",
      "35000/100000: Obj - 5.948706150054932, Grad - 7.78690300649032e-05\n",
      "Converged at 37217/100000\n",
      "tensor(5.9486, grad_fn=<AddBackward0>)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(10.0, 40.0)"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiMAAAGiCAYAAAA1LsZRAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAACF2ElEQVR4nO3dd3xT1fsH8E+6W2hLW6BltGXvvUFFlrJko+IEVBRFviJOXLjRHypO3AIqCC5ABEHZqyB77713W6B05vz+eLzce5u0TdqkSdvP+/XKKze5N7cnLeQ+Oec5z7EopRSIiIiIPMTH0w0gIiKiko3BCBEREXkUgxEiIiLyKAYjRERE5FEMRoiIiMijGIwQERGRRzEYISIiIo9iMEJEREQexWCEiIiIPIrBCBEREXlUgYKRd955BxaLBaNGjbr+XGpqKkaMGIGoqCiULl0aAwYMwJkzZwraTiIiIiqm8h2MrFu3Dl9++SUaNWpkev7JJ5/EnDlz8Msvv2DZsmU4efIk+vfvX+CGEhERUfGUr2DkypUruOeee/D1118jIiLi+vNJSUn49ttv8cEHH6BTp05o3rw5Jk2ahNWrV2PNmjUuazQREREVH375edGIESPQs2dPdOnSBW+++eb15zds2ICMjAx06dLl+nN16tRBXFwcEhIS0KZNG5tzpaWlIS0t7fpjq9WKixcvIioqChaLJT/NIyIiokKmlMLly5dRsWJF+Pg419fhdDAyffp0bNy4EevWrbPZd/r0aQQEBKBMmTKm56Ojo3H69Gm75xs3bhxee+01Z5tBREREXujYsWOoXLmyU69xKhg5duwYnnjiCfzzzz8ICgpy6gflZMyYMRg9evT1x0lJSYiLi8OxY8cQFhbmkp9BREREZjNmAA8/DFSuDBw/DvTqBcyZo+8vUwZITJRtHx/g0iXZfu454IsvZPvQISAyUraTk5MRGxuL0NBQp9viVDCyYcMGnD17Fs2aNbv+XFZWFpYvX45PP/0UCxYsQHp6OhITE029I2fOnEFMTIzdcwYGBiIwMNDm+bCwMAYjREREbrJzp9wHB8t9hQrm/aVL68FIdDSgXZL//VfufXyAKlVsz5ufFAungpHOnTtj27ZtpueGDh2KOnXq4LnnnkNsbCz8/f2xaNEiDBgwAACwZ88eHD16FG3btnW6cUREROQeGzbI/ZUrcn/hgnn/tWv6dqtW+vbBg3KfLSOjQJwKRkJDQ9GgQQPTc6VKlUJUVNT15x988EGMHj0akZGRCAsLw8iRI9G2bVu7yatERERU+KxWYNMm2dZSOrXgRGMMTvr2lXulgKQk2a5e3XXtyddsmtxMmDABPj4+GDBgANLS0tC1a1dMnDjR1T+GiIiI8mnvXukRCQwE0tKAmBjJG9FYLBJ4aFq3lvtjx/Tnb7rJde0pcDCydOlS0+OgoCB89tln+Oyzzwp6aiIiInIDrRekUiUZdmncGFiwQN9fujRw+bL+uFYtud+4UX/OUMWjwLg2DRERUQmjBSMhIXKffSZueLi+HRYG+PrK9rx5+vOu7BlhMEJERFTCaMGIMUnVyFizrF49fVsrpu7nJ70nrsJghIiIqAQxJq+eOCH327ebjzl7Vt/u0UPfPnxY7g0rwbgEgxEiIqISZN8+yQcJDARSU2WoJlvVDqSm6ttabojVqk8Drl3btW1iMEJERFSCaEM0sbFy36gRkJKi789eYL1hQ7k/fFifSXPzza5tE4MRIiKiEkQLRrSKqtpMGY1xCCYgQM8N0SqvAkDXrq5tE4MRIiKiEkQLRtLT5T77yivGxNS4OH37r7/0bWNFVldgMEJERFRCWK16rZBTp+T+6FHzMVqFVQDo0EHf1npG/P0l38SVGIwQERGVEPv368mrFy7IFN6EBPMx587p271769vHjsl92bKubxeDESIiohJCG6LRVtutVQs4f17f7+NjLgPfrJncZ2YCV6/KtrHuiKswGCEiIiohtGBES1Jt1MgcfBiTV318gIoVZfvAAf35jh1d3y4GI0RERCWEFoxkZcl9dLR5v3EIJipKFswDgNWr9ee7d3d9uxiMEBERlQDG5FUtL8RYXwSQ4RhNixb6tnFNmsaNXd82BiNEREQlwIEDQHKy1A45ckSe09aa0WgzbACgb199WysfHxioL5rnSgxGiIiISgBtiKZGDckTqVAB2LvXfIyxp+SGG/Ttkyflvnx597SNwQgREVEJoAUjWl5IkyZARoa+P/sqvNr6M+np+uq+jRq5p20MRoiIiEoALRjRklKrVjXvNyazlioF+PnJtrH3RFs0z9UYjBARERVzSunJqxcvyr2/v/mYkBB927gq7/Ll+na3bu5pH4MRIiKiYu7AASnzHhAgVVgBYPt28zFnz+rbxum7xjVpjEGKKzEYISIiKua0IZpatST/o1Qp8yq8gLkMvLEHZOtWuQ8O1od4XI3BCBERUTGnBSNaXkijRrJGjcbfX+qQaIyJqmfOyH2FCu5rH4MRIiKiYk4LRrSk1Ozryxin7Pr7A2Fhsn3tGpCWJttNm7qvfQxGiIiIijFj8mpSktwb16ABgHLl9O1KlfTtXbv07VtucU/7AAYjRERExdrBg0BiovR4aAvenT5tPubKFX27fXt9e8kSfdtdM2kABiNERETFmjZEU7euJKn6+JiDDMBcBr5PH33777/l3mIB4uLc10YGI0RERMWYFoxowy+1a5uDDwC4elXfbtlS39am/4aEuG8mDcBghIiIqFjTgpGgILlv3Ng8cyYyUt+2WIDKlfXH2nRf43PuwGCEiIiomDImr2p5IdkDC2PCakSE3gNy5Yq+do2xt8QdGIwQEREVU4cOAZcuSeXVw4flucxM8zE+hkigWTN9e8cOffvWW93WRGmDe09PREREnqIN0dSrp5eBX7HCfIxxZo295FWAwQgRERHlkxaMxMfLkE3FiuYeDwA4f17fNk7rXbhQ7i0W84q+7sBghIiIqJjSgpFSpeS+SRMgNVXfHxgIZGXpj+vU0bd375b70FC3NhEAgxEiIqJiSSk9GLl2Te5r1TIfY6wdEhwsuSWaixflPj7efW3UMBghIiIqhg4fluRVf3/g+HF5LiTEfEx4uL5do4a+nZioJ7q2aePOVgoGI0RERMWQ1ivSoAGwbZtsb9liPkZbqwYAunbVt7XjAfeWgdcwGCEiIiqGtGCkenXJEylVCli1ynzMyZP6ds+e+va8efp2ly7ua6OGwQgREVExpAUjYWFy37ixDL8YGcvAN2miby9dKvc+Pvrr3YnBCBERUTFjrLyqVVFt2NB8TIUK+ravL1CmjP543z65N+aUuBODESIiomLmyBHgwgVJXtWGYsqXNx9TsaK+bQxMAL0HpVo1tzXRhMEIERFRMWNMXt26VbaN+SGAub7IDTfo2+fP6/uMz7sTgxEiIqJiZv16ua9bV1be9fEBFi82H2MMTvr107c3bdK3u3d3XxuNGIwQEREVM1rPSGSk3NepAxw9aj5GK2oGAK1b69t//qlv33yze9qXHYMRIiKiYkQpvWfEapX7Jk3MwzLBwebVe41VVleulHtfXzmuMDAYISIiKkaMlVfPnJHnqlY1H2NMTC1TRhbD0xw8KPcREe5spRmDESIiomJEG6Jp1EhPXtWm92qMZeGNU36VApKTZbtmTfe1MTsGI0RERMWINkTTsCGwf79sL1tmPsaYL9Knj7595ow+tFNY+SIAgxEiIqJiResZiY6Wno5KlfQeEs3p0/p2p062rwUKbyYNwGCEiIio2FDKHFAAkrx67Zr5OWMZ+Hr19O3Zs/Xttm1d3rwcMRghIiIqJg4dkuTVgACpLwKYgw0AiI3VtwMD5aZJSJB7f3+5FRYGI0RERMWEveTV7NNzjaXfs8+y0WqRREW5p305YTBCRERUTGjJq02bAtu2yXb2fJHUVH27Sxd9Wyng8mXZrlPHfW20x6lg5PPPP0ejRo0QFhaGsLAwtG3bFn/99df1/R06dIDFYjHdhg8f7vJGExERkS2tZ6RSJSAtDShdGlixwnzMqVP6tnEmzfHjEpAAQOfO7m1ndn7OHFy5cmW88847qFmzJpRSmDJlCvr06YNNmzahfv36AIBhw4bh9ddfv/6aEONkZiIiInILY/Kq339X98aNgdWrzcdduqRvN22qb69dq28X5kwawMlgpFevXqbHb731Fj7//HOsWbPmejASEhKCmJgYh8+ZlpaGtLS064+TtWorRERE5LCDB4HERElIvXBBnmvcGFi1Sj+mVCl9Jo2Pjzk3xDiTxhikFIZ854xkZWVh+vTpuHr1Ktoa5v9MnToVZcuWRYMGDTBmzBikpKTkep5x48YhPDz8+i3WmOZLREREDjEmr2r5IuXLm4+pXl3fzr5v3Tq5DwyUQKUwOdUzAgDbtm1D27ZtkZqaitKlS2PmzJmo99+8obvvvhvx8fGoWLEitm7diueeew579uzB77//nuP5xowZg9GjR19/nJyczICEiIjISVryarNmwG+/yfaJE+ZjjNN427Qx7zt+XO7LlXNP+3LjdDBSu3ZtbN68GUlJSfj1118xePBgLFu2DPXq1cPDDz98/biGDRuiQoUK6Ny5Mw4cOIDqxnDMIDAwEIHG3w4RERE5TesZqVEDOH9eVt1dutR8jFZ7BAAGDNC3rVZ9+Oa/rItC5XRHTEBAAGrUqIHmzZtj3LhxaNy4MT766CO7x7Zu3RoAsF8rjk9EREQuZ0xe1b7f16kjRdCMzp7Vt40VVo8c0bdvvdU9bcxNgUeFrFarKQHVaPPmzQCACsYKK0RERORSBw4ASUkSiGizZZo0ATIzzccZ0ziNBc+M03979HBbM3Pk1DDNmDFj0L17d8TFxeHy5cuYNm0ali5digULFuDAgQOYNm0aevTogaioKGzduhVPPvkk2rdvj0aNGrmr/URERCWe1ivSuLGevFqjhvmYKlWAw4dlu3Rpc5LqnDn6du3a7mplzpwKRs6ePYv7778fp06dQnh4OBo1aoQFCxbglltuwbFjx7Bw4UJ8+OGHuHr1KmJjYzFgwAC89NJL7mo7ERERQU9ebdEC+Ptv2b5yxXxMdLQejGTPC9m4Ue6DggCLxW3NzJFTwci3336b477Y2FgsW7aswA0iIiIi52g9I/XqARMnyraxiBlgXqm3d2/zPq0qqxNlwlyKa9MQEREVYVar3rNRqpTcV64M/Je2eZ2xDLwxSTUrC7h2TbYbN3ZbM3PFYISIiKgI05JXg4LkHpDk1ezDNImJ+rZxmObAAX27sMvAaxiMEBERFWH2klcbNjQfExoqPSAA4O8PBAfr+xYv1rcZjBAREZHTjMmr2tCMr6/5mGrV9O24OPO+uXPl3mKx3VdYGIwQEREVYcaeke3bZXvHDvMxAQH6dufO5n1bt8q9sbeksDEYISIiKqKMyauRkUBamgzJrFxpPu70aX27b1/zvjNn5L5SJbc1M08MRoiIiIqo/fuB5GRJXtUSVhs3Nq9BA8haNZrmzfXt9HQJYLI/X9gYjBARERVR2hBNkyZ68qq96bna1F2LBShfXn9+71592xNl4DUMRoiIiIooLRgxJq+WLWs+xrgGTVSUed+CBfp2t24ub57DGIwQEREVUdpMmmbN9GDk2DHzMeXK6dstW5r3acGIxWI+rrAxGCEiIiqCjMmrlSsDFy7IlN5Vq8zHJSfr2wMGmPdps25Kl3ZfOx3BYISIiKgI2rcPuHxZpuSmpMhzdesCBw+ajzPOpLnpJvM+LbE1NtZ97XQEgxEiIqIiSBuiMSavNmkCZGSYj7t8Wd+uXl3fTk2V2TQA0Lq1u1rpGAYjRERERdCaNXLfurWeL2KstAoAYWF6GfjgYHNl1l279O2ePd3WTIcwGCEiIiqCEhLkvm1bYNMm2TYuhgeYg5Patc37/vxT3zau4usJDEaIiIiKmJQUYMsW2a5XT88T0RJaNRaLvt2rl3nfwoVy7+MjVVs9icEIERFREbNhA5CZCVSsCFy8KM/Fxuo9JBqt1DtgW9Rszx65DwtzXzsdxWCEiIioiDEO0Wg9JE2aAFevmo+7cEHfbtTI/r4qVdzRQucwGCEiIipitGCkTRs9ebVePfMxFou+7oyvLxASou+7elV6VgDghhvc2lSHMBghIiIqQpTSZ9K0basHI1ar+ThjGfgKFcz7tm7Vtz09kwZgMEJERFSkHDkihcz8/WXoZft2ed646B1gXoemc2fzvtmz9e2OHd3TTmcwGCEiIipCtCGapk2Bw4elcFlYGLB6tfm4S5f07f79zfuWLpV7X18gKMhdLXUcgxEiIqIixF6+SOPGwLlz5uPOntW3W7Uy7ztwQO7LlHFHC53HYISIiKgIsZcvkn2mDABcuaJvx8SY92m9Jsby8J7EYISIiKiIuHZNryViDEayr7obFqYntGavI5KcrJeIb9/ebU11CoMRIiKiIkIrdhYTI0XOtGDk5EnzccYej+bNbc+h6d3bLc10GoMRIiKiIsI4RHPihFRf9fPTn9cYV+69/Xbzvpkz9e127dzTTmcxGCEiIioijJVXtXVo6tbVE1I1xuTVDh3M+1atknt/f/Mqvp7EYISIiKgIUMo8k+avv2S7XTvbgmfG1Xtr1TLv0xbVi4hwSzPzhcEIERFREXD0KHDqlAzLNGsG/PGHPN+4sfk4i0VqjwBAQIBt70dystxnD1I8icEIERFREaDlhTRpIlVXT50CQkNt64sYy8BnXwTvwgW9F6VTJ3e11HkMRoiIiIoA4xCNVs69e3dg3jzzccZCZn37mvetXatve8tMGoDBCBERUZFgTF7VgpE+ffREVs3Fi/p2r17mfcaZNE2bur6N+cVghIiIyMulpurFzmJigJ07JXfkllvM03gB87BN9nwSbagnIADw8aIIwIuaQkRERPZs3ChBR3S0XrSsQwepNZJdSorc+/hITonR0aNyX7as25qaLwxGiIiIvJy9fJG+fYHFi83HhYbKFGAAiIoy71MKuHxZtuvVc1tT84XBCBERkZfThlcaNgRWr5bt3r2B+fPNx1Wrpm9nX3fm7Fk9ULnlFve0M78YjBAREXk5rWckPV0CimbNZG0arZqqJjVV377rLvO+lSv17eyJrZ7GYISIiMiLHTsmuSG+vlJfBJAhmtRUPT9Ec/68vt2mjXmfcSZN3bpuaWq+MRghIiLyYlqvSIMGeo5Inz7Atm22xyYl6dsVK5r3rV8v90FBrm9jQTEYISIi8mJavkjFitIbUqWK5I789pv5OIsFyMyU7ZAQeWx0/Ljcly/v1ubmC4MRIiIiL6b1jGgzYfr2BdLSgM8/Nx9nLAOffbaMUvqQTqNGbmlmgTAYISIi8lJpaXqF1R075L5PH+Cnn/QF7zSlSunbd99t3nfypD6TpmtX97S1IBiMEBERealNm2QGTXg4cOkSEBkJ3HAD8NFHtsdeuKBvZ5+6u3Chvu1Na9JoGIwQERF5KW2IRitgdtttkkOyZYvtscY1aWrXNu+bM0ffjotzbRtdgcEIERGRl9KCkcREue/Tx36vCCBDOoCsWePvb96nrWsTEuLyJroEgxEiIiIvpQUjFy/KlNwaNWxn0QDmMvAVKtjuP3Uq533egMEIERGRFzp+XG7aFN0uXWxn0DRpIvexsfpzt91mPsZqBa5dMx/vbRiMEBEReSGtvohWpKxTJ+C778zHaImqxjLwd95pPubIEX27Z0/XttFVGIwQERF5IW2I5to16R05elRm1mjuuENPZD13Tn++aVPzef76S9/O3mviLZwKRj7//HM0atQIYWFhCAsLQ9u2bfGX4V2mpqZixIgRiIqKQunSpTFgwACcOXPG5Y0mIiIq7rSeEQBo1Qr46ivz/hkzgK1bZfvqVbm3WICwMPNx8+bp+8qVc09bC8qpYKRy5cp45513sGHDBqxfvx6dOnVCnz59sOO/SixPPvkk5syZg19++QXLli3DyZMn0b9/f7c0nIiIqLhKTwc2bNAfR0ebF8V74w3g7Fng9GkJMqxWeT57IALoa9gYi6J5G4tSWv5t/kRGRmL8+PEYOHAgypUrh2nTpmHgwIEAgN27d6Nu3bpISEhAm+zLB+YgOTkZ4eHhSEpKQpi93yoREVExt3atedXdyEi9jogWfCxYAHTrJmvVHD4s+7p0Af75x3yuoCCZ9lunDrBrl/vaXJDrd75zRrKysjB9+nRcvXoVbdu2xYYNG5CRkYEuXbpcP6ZOnTqIi4tDgjbwZUdaWhqSk5NNNyIiopLMeNmsWNFc0GzmTJnG+/bb8rh0aX3fAw+Yz5OVpdcfadHCPW11BaeDkW3btqF06dIIDAzE8OHDMXPmTNSrVw+nT59GQEAAypQpYzo+Ojoap0+fzvF848aNQ3h4+PVbrHF+EhERUQlkzBdJStK3fX2l8NmMGcDy5UBwsJ4vAgDt25vPs3+/vu2NZeA1TgcjtWvXxubNm7F27Vo8+uijGDx4MHbu3JnvBowZMwZJSUnXb8eOHcv3uYiIiIqD1av1bWOwsXMncOUK8PTT8viFF4ATJ/T9lSqZz/PHH/p2t26ub6er+Dn7goCAANSoUQMA0Lx5c6xbtw4fffQR7rzzTqSnpyMxMdHUO3LmzBnExMTkeL7AwEAEBgY633IiIqJi6ORJQPtebrHolVVDQoBatYAxYyQAqVpVgpKXX5b99hJU//5b7n18pEqrtypwnRGr1Yq0tDQ0b94c/v7+WLRo0fV9e/bswdGjR9G2bduC/hgiIqISwThEY5xicuECsHEj8N578njCBPPrmje3PZc2cOHNgQjgZM/ImDFj0L17d8TFxeHy5cuYNm0ali5digULFiA8PBwPPvggRo8ejcjISISFhWHkyJFo27atwzNpiIiISjrjEI2mYkXpJRk8GMjMBG6/XXJHPvxQP0YbujE6f17uvXGlXiOngpGzZ8/i/vvvx6lTpxAeHo5GjRphwYIFuOW/erQTJkyAj48PBgwYgLS0NHTt2hUTJ050S8OJiIiKlerVgYMH8Q82AWgCQAGQhWmOHwdeegnYvl0Kl332mbzEWB5eKw2vycjQK7Z6+wBFgeuMuBrrjBARUYni5ydzcAGkwx8hSEGWoa+gFRLw6b9t0aaN1Bf59VdgwADZFxws69IYC59ptm4FGjeW7XnzgO7d3fs2CnL9djqBlYiIiFxEW5L3P1vQ2BSIAArL0BHNWm2EFfVw1116IALoC+TZS179/Xd9u2NH1zXZHbhQHhERkSf42fYHzEEvwyOF+/AdXsHr2IV6iMEpfPKJYa9hXKNRI9vTL14s976++sq/3oo9I0RERJ7w39CM0c/oZ3o8HN/iRqwEAHyJRxAVpRcOmT5dP06b3mu0Z4/cF4WMB/aMEBERFbbq1e0+vQcN/ttSeAvPYAgmQ8EH92MKemMOULv29WPHjNFf17Wr7bm0EvLVqrmozW7EYISIiKiwHTxo89TXuBfa7BlA4TwqYh9qoSJO4EOMkqf37gUgeSNHjshTvr42qSdIS5MpwABw440ub73LMRghIiLyAg9jyn9bCu/iyesByDd4CBFIvH7ciBHm5NR162zPtXWrvt2vn+1+b8NghIiIyMM+wnAYe0W+xP+g4IMH8Q26Y/7148bgdRjLdy1cCDRtanu+X37Rt2+4wS1NdikGI0RERIUtWyLHKEyEFozUw2YcRHXE4ijex1PXj3kLz+EdvHT98dSpQOfO9k+/fLnc+/nZnbTjdRiMEBERFbYDB65vDsWXpl070QwA8C0eRDiSAQATMBIvYRy0gGXiRODuu3M+/f79ch8R4bomuxODESIiIk/w9QUATMYw6EM0UkZ1OD7HLVgIAPgKD2A0Prp+zPjxwKOP5n7qxES5r1HDtU12FwYjREREnpCZiXZYBj0QAQAfVMEh/B+eBQD8iDvxCL65fsyrr9pfEM8oJUUvYdKhg4vb7CYMRoiIiDxAKSAB7W2e/w4PIBRXMBO9cB9+ghaIPPssMHZs3uf9919921g63psxGCEiIvKAuDjb5/pgFjpiKRagM/pjNrRA5PHHgXffdey8v/6qb9ubaeONikCOLRERUfFy9Spw/Ljt8xNP9MWyfQrdOujPPfAATGvS5GXVKrn39wd8ikiXQxFpJhERUfERHW37XFwccOKEOc/jrruAb7917tyHD8t9VFR+W1f4GIwQEREVoiNHpGcku+bNgVat9Me9ewPTpjl//mSZDYw6dfLXPk9gMEJERFSIclgjDzNn6tu33grMnu38uZOTAavMDkaXLs6/3lMYjBARERWSefP0abc5uekmYMGC/J1/xQp9u3///J3DExiMEBERFZLbbst9f6tWein3/DAuoMdhGiIiIjJ5+22pLaLx9zfvb9QIWLu2YD9jzRq5DwwELJbcj/UmDEaIiIgKwYsvmh9nZOjbUVHAli0F/xnHjsl9uXIFP1dhYjBCRETkZoMG5b5/6lTX/JwrV+S+fn3XnK+wMBghIiJysxkzct9vnNKbXxcv6sNA3bsX/HyFicEIERGRG+VVkr1uXSAiouA/559/9O2+fQt+vsLEYISIiMhNlAI2b7a/r1QpuW/b1jU/a9YsfTs+3jXnLCwMRoiIiNykQgXb57RZNGFhcu+qYGTDBrkPDnbN+QoTgxEiIiI3uHoVOHPG/FxgoL4uzcWLct+mjWt+3smTch8T45rzFSYGI0RERG5Qtqz5scUCrFwpq/UGBwNpadI7Uq+ea35eSorcN2nimvMVJgYjRERELrZ7N5Caan7u55+BP/6Q7dq15b51a8DHBVfi06f1mTS9exf8fIWNwQgREZGL1a1rflytmqwVoyWZasmrrhqimTNH386r5Lw3YjBCRETkQuHhts+NGQMcPgxs2wb4+ur5Ha5KXv3zT7m3WGyHh4oCBiNEREQuUrUqkJxsfi4mBrj3XmD2bHncpg1w6JBst27tmp+rlZLXelyKGgYjRERELlC7tvR+ZDdqFBAUpAcjWsJq7dpAZKRrfrY2a6dSJdecr7AxGCEiIiqghg2BvXttnw8NBR55BLhwAVixQp7T6oy4aohGKT1ZtkUL15yzsDEYISIiKoCWLYHt283P+frK/SOPAGXKSE6H1Qo0aiQzbQDXBSPG3ph+/VxzzsLGYISIiCifbrwRWL/e9vmsLOkBeeIJeawN0fTuDfz7r2y7aibNL7/o2127uuachY3BCBERUT506QKsWmX7fGio3N9zD1C5MnDtGrBggTxXvz5w5YocU7++a9oxf77c+/gApUu75pyFjcEIERGRk3r3BhYtsr/vyhW5f+YZuV+4UKqjxsYCly7Jc61a6UM5BbVrl9xra90URQxGiIiInHDnneYiY0bx8ZJQ2quXPmtGG6Lp0wdYu1a2XZUvAkhyLABUr+66cxY2BiNEREQOeuABKeuek1On5P7ZZ+U+K0svAd+nD5CQINuuyhdRCsjIkO327V1zTk9gMEJEROSAESOASZP0x9kXuGvXDkhPl16PG26Q59asAc6dk6qsDRro039dFYxs3Khv33uva87pCQxGiIiI8vDMM8DEifrjIUOAnTv1xxYLsGOHbD/7rDwG9LVoevYE1q2T7Vq1gKgo17Rr6lR9u2lT15zTExiMEBER5eLVV4H33tMfjx8P/PST+Zj77weSkqSqqrZqrlJ6vkjfvsA//8h2x46ua9vy5XLv768HQEURgxEiIqIc/N//Aa+9pj/+4gup65GWpj/n6yszZgDpQfH578q6ezewbx8QEAB066YHI7fc4rr2HTwo90VxcTwjBiNERER2TJwIPPec/vijj2Rqrla0TPPmm8CJE/qCeBptiKZTJ+k12b1bApVOnVzXRm1Rvrp1XXdOT/DzdAOIiIi8zeTJkrCqefttCSKaNzcfFxIC/PCDbI8aBQQG6vuMQzRaz0mLFkBEhGvamJEhs3UAoHt315zTU9gzQkREZPDzz8DQofrjl18Gnn4aGDxYZssYff+9JLJqC+JpTp3Sa4r06qUP0XTp4rp2zpunbw8e7LrzegKDESIiov/8+acUNdOMHg28/jrwzjsyjdbPMJ5QsaIM3QDA8OGyIJ5GWy+mdWugQgW9Z6Sg+SJWq5yrUydg4EB5zmIBypUr2Hk9jcM0REREABYvll4MzfDhwPvvA5s3S0ACAJmZ+v5ff5XaIsYF8TTabJu77wa2bQPOnpUhHWcqryYlAd98A8ydK70vFy6Yf76mYkXHz+mtGIwQEVGJt2YN0Lmz/vj++4HPP5dhmcGDJQgICZE1ZgDJ/Rg/XrbvvReoVEl/7cGDcj4fH+COO/RaIDffbM4pyf7zv/sOWL0aOHIEuHpVpgbnxGKRRfhGjACeeir/79tbMBghIqISbcsWc4/FgAHAlCmy/eabwNatkhNy+bJ+zI8/6jNYtAXxNNOny32nTsD+/cCHH8rjW26RRfR++EGSW7dtA86ft81Dyc7XV4aAataUczz0EBAXl993652cyhkZN24cWrZsidDQUJQvXx59+/bFnj17TMd06NABFovFdBs+fLhLG01EROQKO3cCTZroj3v0kOEXANiwQWbRAPqsFUCGXt57T3ouevc2T6tVSu8JycgAbroJOH5cejKeekqCmsceAxYsAE6etA1EgoKAKlWA/v2BGTOkRyYzU4KWhAQZLipugQgAWJTKrSPIrFu3bhg0aBBatmyJzMxMvPDCC9i+fTt27tyJUqVKAZBgpFatWnhdG2ADEBISgjAH1zZOTk5GeHg4kpKSHH4NERGRsw4fBqpW1R936gQsWiTbaWkyjXfHDskjMa7Se/KkBAzp6cDKlUDLlsC0acBvv0nJ9zNn8v7ZPj5AWJistNuxo/R21K7tyndX+Apy/XZqmGb+/Pmmx5MnT0b58uWxYcMGtDcsFxgSEoKYmBiHzpmWloY0Qym7ZK2CCxERkZucPGkORNq10wMRQErA79gBlC8PGC99Tz0ldUPS02X4pH17meGSm4AAOU+TJtLjcffdOeeOlFQFmtqblJQEAIiMjDQ9P3XqVJQtWxYNGjTAmDFjkKJl/Ngxbtw4hIeHX7/FxsYWpElERES5On/enHDarBmwapX+eO1amcoLAJGRMtyief99vQJrVlbOgUiZMlIHRCnpZTl2THpXhg5lIGKPU8M0RlarFb1790ZiYiJWrlx5/fmvvvoK8fHxqFixIrZu3YrnnnsOrVq1wu+//273PPZ6RmJjYzlMQ0RELpecLIGCduWrX1/yN776SgqT7dkDXLzo2LkqVAAaNpQ8jz//1AOTXr2AmTOl56QkKbRhGqMRI0Zg+/btpkAEAB5++OHr2w0bNkSFChXQuXNnHDhwANWrV7c5T2BgIAIZJhIRkZtduWIORCwWGYqpXNmx1z/wgMyCuXAB+PZbKTrWqZMkugIyHDNlCjBokFuaX6zla5jm8ccfx59//oklS5agch5/xdatWwMA9u/fn58fRURE5LRz54Bx46S2R/ny0ksRGmqu3ZF9XMDYkzFkiHnfsWMyM+bCBekRKVNGFsbTApF69WTWDAOR/HGqZ0QphZEjR2LmzJlYunQpqhqzf3KwefNmAECFChXy1UAiIqLcLF0qa8QkJEjQkJKSe8EwQAqYVa4s5drvvRdo1EiCjf37pchZQIB+bOnSUuVUK3JWvrzUIgGkd+X55/UpwJQ/TgUjI0aMwLRp0zB79myEhobi9OnTAIDw8HAEBwfjwIEDmDZtGnr06IGoqChs3boVTz75JNq3b49GjRq55Q0QEVHJkJQETJok+Rk7dkgvhTG51B5fX3ONkMhIeZ3R8eMyvXb/fglQPvzQvLLu+fN6SXaLRYqkaef65x9JgKWCcSqB1WKx2H1+0qRJGDJkCI4dO4Z7770X27dvx9WrVxEbG4t+/frhpZdeYp0RIiJy2IYNkpexYoWUR79yJe/ejuBgGUJp2RK46y6gZ0/p1dDmSERE2Can7t8vK+keOQLE4ij+wS14CF9gJToCkAJjf/8t5d+vXNFfd9ttkqTqxzrm1xXk+p3v2TTuwmCEiKjkuHZNSqvPnCll18+dc6w8eliYlEfv0gV48EGgWjXzMUoBpUrJ+QHJF8lexmrlSqDvTedxAWVRE3uxEF0Qh2OwwArAAkDhX7RGO79/ry9Q5+8vSap33eWKd1+8eGQ2DRERkTN27JBVaJctk8XkLl/Ou2BYYCAQHS1DIQMHArffbs7nsEcpCVa0QCQ42DYQmTYNGHpPGtJRFi2wDn/iNkTjLOJxAFogEotDaIU1wH+BSK1aUo+kbNn8vHvKDYMRIiJyqfR04OefZY2XTZukPLqhnJRdPj7Se1GtGtChg5RHr1cvfz8/MlIfUgkM1FfaBSRQef11qbAKBKI/fsMPuA8huIZUAEehT8w4hqrQApMn8BE+3DMqfw2iPDEYISKifDt0SAqGLVok+RdJSY6XR2/USEqr33uv9F64QtmyQGKibPv7m/M80tJkSEdbyO5ZvItxGAMfSLZCeSRCCz7kHghEKhajA9phLYBRrmkk2WAwQkREecrKAv74A5g+HVi/XtZ2SU3N/TUWiySQVqki02aHDpVEUHepUEGfKePnJz0iWoLp+fNAv36SJ+KLTHyORzEM31x/7TGUxWVoeQ4SkLTAOiSgLfzwX3RVu7aUaCWXYzBCREQmp04BX38ts0j27AEuXTJPj7XH3196JerXl3LoQ4ZI3kZhiYsD/qs2AV9fyRfRApE9e2RmzYEDQHg48GtSN3SBvireEVRGFRyB1hsCWPEpHscIfG7+IXv3uv19lFQMRoiISqisLBle+eEHWfzt+HG5iOc2x9JikYJhsbFA27ZSIOzmmwuvzfbUqCHFzgDJPbl8WQ9Eli6VlXIvXZIemrlzgXr19UDkHTyDMXgHekFyhdOIRjTOF+I7IAYjREQlwMWLMpNl3jxg1y55rE1XzYmfnySD1qkD9Ogha7OUK1c47XVUvXrS4wFIoJSYqOefTJkCDBsmhdHatJF1ZcqXl31p8ENzbMQONIDeI6KwEi0ZiHgAgxEiomJm1Spg8mS5P3YMuHrVsfLolSpJwbB77gG6dvX+VWebNpXACpBA5MIFmZFjtQKvvAK89Zbsu/NOqdyqBSkLY+5Bj9PfIQPaHGFJWPVHGm7Ahpx/YK1a7norJR6DESKiIurKFQk65swBtm2TJE1HyqOXKSPX1VtvlSm0jq5a603atgX+W/oMgOSLRETIMNPQocCMGfL8iy/KVF4fHwnIBg0Cfj7943+v0iI0SVg9gfK5/1Amr7oNgxEioiJg82YZZlmxAjh8WAKRvKbQBgXJDJPmzaV3oF8/7+/tcESHDsCaNfrjw4dl+OXsWaBPH9nn7y9JuIMHyzHHjwONG+vl4C2woin+xUbIyvJlcBHlcDnnH1ocfnFejMEIEZEXSUuTOhgzZ0oAcvZs3uXRfXxklkj16kCnTpInUaNGoTS30PXoIRVcNbt3A/Hxsohdz54SmEREAL//LkELALz3HvDss/pQVblywNatPqhQoTW0XpEzyKOsal4JNlQgDEaIiDxk714pGLZkiZRHT052rDx6+fKSLzFggAw75FUevbgYMAD46y/98datUvpj4UIpFZ+UJAHZ3LnyfHq61DXZtk1/zX33Ad9/L7kxWuJqDexBjr9CX18GIoWAwQgRkZtlZUlp9J9/BjZulDoejpRHL10aqFpVvuE/+CDQsGGhNNcr3XOP9HZo1qyR38fXXwOPPiq/4xtvlB6lsmUlwOvaVc+hCQiQuik33yw9JOvX6+fap+oAtWuZ64jUqsUckULEYISIyIWOHpXejoULgX375Nt6XgXDAgLkAtqwoeQ83H+/rDhL4uGHZWE7zdKl0rPx7LPA+PHy3L33Sk5NYKAELsbjmzaVOipa7ZFKlfR9t9763wYDD49iMEJElA9ZWVKzY9o0YN06KY+urRKbE608elycfIsfMkTqX1DOnnxSej808+ZJIDJwoPSCALLo3SuvSI9To0Z6SXiLBZgwAXjiCf31V6/KcZoFC9z+FsgBDEaIiPJw9qxcEOfPl4TJxETHCoZFRUl59J49pWBYmTKF0dri46WXgA8/1B//9hvQpIkMtaxfLz1K330nPSEffgiMHq0nqZYtC2zZAlSsaD5necPs3VGj3Nt+chyDESIig8WLpTx6QoJMB01Jybs8enCwlEdv00aGWDp1Krz2Fldvv60XLQPkb1KzJtC6tRRyi4oCZs2Sx02bmmuO3HMP8OOP2c8ow2YpKfrjCRPc1XpyFoMRIiqRkpKAb7+VmRc7dkjXviO9HRERMlOjWzdJKo2JKZz2liQTJkixMs3EiRJ83HCDrDtTu7b83Y4fl2Evbeqzv78Mu3TsaP+8devq25Mnu635lA8MRoio2Fu7VsqBr1wpCaZXruRdHj04WLr4W7YE7r5b6luw7pX7ffWVDLdo3n9f/la33SbTnjt0kFk1TzwhvSWaxo0lSTWnac6zZ+uJxD4+ejE08g4MRoio2Lh2TRZHmz1bakucO5d3wTBfXykYVrMm0KWLFAyLjy+c9pLZ1KnAI4/oj197TYZktLyRIUPkuVq1pPQ9IMNk48cDTz2V+7n79dO3jdN6yTswGCGiImnbNpnKuXy5FAxzpDx6YKCUR2/WDLj9dpmR4cdPQa8wa5ZMz9U89ZQEDXPmyOO335YhmSpV9F6tqChJUjVO1bVn7Fj9NYGBkmNC3oX/DYnIq6WnA9Ony0yKTZtkZosjBcPCwoBq1SR/4MEHzfkC5F3mzzf3XAwdKonEmzbJ+jqTJknvx8aN+jGDBgE//eTY+V9/Xd8+c8Y1bSbXYjBCRF7jwAHJGVi8WLaTkvLu7QgIkOmajRsD/ftLfkdQUOG0lwpu6VKge3f9cd++koR68qT8XV9/XfI7jEmq8+c7NmPJapVFAjVRUTIkR96HwQgRFbqsLClYNWMGsGGDFKFKTc39NRYLEBoq3fQ33SR1O5o1K5TmkpusW2ee+dK+PfDPP1KYrF496c0aPlzf37ChXl8kL5cvy78R45Tfkydd1nRyMQYjRORWJ05IwbC//5alPxIT8y6P7u8vRasaNAB695bExdKlC6O1VFi2bQNatdIfN2gArFghuR033wxs3y4r8QISiL77LvDMM3mfNzUV+PxzYNw4SWDWNGtWchYULIoYjBCRS2RlScAxdapMsTxxwlxgyh6LRdZgiY2VGhKDB0uZdCre9u2Tsu2a2FgJPgD5d7B8uZ5wGhkpuSNxcbmfMyNDcktef13+7WW3YYNr2k7uwWCEiJx24YLMZPnrL2DXLuDiRccKhkVGStd7jx7AQw/JYypZjh2TqbmaiAh5DgAqVwZWrdL33XGHDOXlJitLEllffVXyjAAJbq5elX+X2nnIuzEYIaJcLVsmtTsSEuSi4Wh59EqVpFT3vfdK/Q4WDKNz58w9HMHBwKVLMt02K0sqqgISuM6da1hR1w6lJO/olVekgi4gCa8vvigl+SMi9GPzCmjI8xiMEBEASfibNEnqOuzYIUWlMjJyf42vryz+Vru2XDiGDbNdmIwIkJlR0dH6Y19fKVIXHGxe7bh+fZnCm1N+h1IyHPjSS3rxsjJlgGefBf73Pxn2M86YeeMNl78VcgMGI0Ql0MaNsi7LihXA4cOOlUcPCpJAo3lz4M47ZQomezvIEVeuSE+F8d9YVpb0gBgDkXHjgOefz/k8K1ZIz8eKFfK4VCngySelQJq2IvL+/UBysmxbLBK0kPdjMEJUjF27JgmlM2dKpUpHyqP7+Mg3yxo1gM6dpbejWrXCaS8VP2lp8u/JXrCr5RlFRMgU3JySVDdskCBkwQJ5HBgIjBghgUu5cuZj69XTt2fOLHDzqZAwGCEqJnbvloJhS5dKefTLlx0rjx4dLeWxBw6URD9OfyRXSU+X3ovc/h0OGAD8+qv9fTt2SE7I77/LYz8/qab70kuS7Jrdn3/qQ4v+/kCfPgVrPxUeBiNERUxGBvDzz/IBvnGjlLd2pDx6aChQtaqsevrgg1LXgchdMjIkEMmppoyfnwQPXbva7jtwQGbHTJ0qPSoWiyRCjx0LVK+e8880Bh9bthSo+VTIGIwQebHDh6Vg2MKFUpshOTnvgmEBAdJ13bChrPdx332SJEhUWJSSInU5TfeuW1eGZbL3wh0/Lgmn332nv7Z/f6kdUr9+7j9z3Di9ByY0lGsRFTUMRoi8QFaWfEv86ScpkX3qlDmxzx6LRT7w4+OlUNjQoeaKlkSeoBQQEpJzbtJbbwEvvGB+7uxZ4J13gIkT9V6+bt2AN980ry2TG+M57RU9I+/GYISokJ0+LQXD5s8H9uyROguOlEePipJvh7fdJoEHF/wibxQaan+doTJlpDckPl5/LjEReO894MMPpUgZIOvTvPWWc5V4775b346LkzZQ0cJghMhNrFZg0SLgxx+BNWukC/ratbwLhoWESAXJtm2leFOHDoXWZKICCQvTgwqjfv30JFRApvp+/DEwfrwEJADQooUEIbfcIv8PnPHTT/r2kSNON5u8gNcGI+PGSQJTYKCnW0KUt0uXpG7H3LlSHv3CBcfKo0dEyNh2t25SHj37NEWioiIyUmZwGfn6An/8IeX/Aekx+fJL4O23ZWgGkN6+N96QujXOBiGAeWiybdt8NZ28gEWpvEodFa7k5GSEh4cDSEKdOmH48kvptiPyFgkJUql01Srg6FH5JpjX/yKtPHqrVtKl3K0bC4ZR8VG2rATgRrVry4yWwECZWTN5siSiaiXfq1cHXnsNGDSoYP8XjAGMd13NSh7t+p2UlISwsDCnXuu1PSPlykndhJtvlqJL775rXmuAyN2uXpU1WWbPlhVFz51zvDx6zZrS3fzQQ3mvNkpUlJUrZxuIvP468PLLMlQ5bZpMyd2/X/ZVriy1Q4YMkVyogqhUSd8eOrRg5yLP8tqekcOHk/D222H46it5Pjoa+OgjKcqUn648otxs3SpJpcuXA4cOyZh2XgXDgoKAmBi9PHr//uztoJKlTBlZc0ZTqpT8X6paVYL4l1+WQB6QoOWFF4Dhw+X/TkFdumRe9dm7rmQlU7HsGalSRXpEli8HHn5YekkGDQK+/16mfxkzsokclZ4u39R++026kM+ccaw8eliYdCt36iS9HcYl0IlKmqwsCSiMeVGdOkk9nH/+kc/qdevk+TJlgGeekUXsSpd2XRsqVNC333vPdeclz/DanhEgCYBEVgMGSAGnt9+WC0dIiMw/HzlSkgCJ7Nm3TwqGLV4sFR2Tkx0rj16+PNC4sfy7u/tulkcnMtq40bb2x+TJEqy/+KJ8gQSkl+SJJ4Cnn3b9EPv48bJKLyBfFvKaGk+FoyA9I0UiGNHcdJPcays2Nm8uF5umTQu1ieRlsrKkp2PGDPmgPH3afp0DIx8f+ZZWtaokSD/4oAQgRJSzxx4DPv/c/NycOdJb/ddf8jgwEHj0UWDMGAnsXeXSJeltWbtWck40y5ZxkoO3KDHBiKZGDUkmTEqSMfpRoyQru1SpwmwpecLx47IY3D//SM9HYqJjBcPKlZO1WPr0kdodruwuJiruEhNlCvrp0+bne/QA5s2TbT8/4IEHJE/E3iJ2zkhNlQJp//6r3/btsz0uJMR+XRPyjGIZjFSpkoTDh3N/M2XK6AVz4uMlYu/e3e1NpEKQlSXftKZNk29DJ044Vh69VCn5t9CunWTXs+4AUcFMmSL/l3K6UlgswD33SF2o3Baxy4nVKjmBxsBjyxb7dXpq1NBn5QDy5cQ4o4Y8q1gGI6dOJeHAgTB8/rl0v+dWQMrPT99/113AhAky+4aKhnPnZCbLX3/Jh9KlS44VDIuKAurVA3r2lA9LY2Y9ERWM1SrVf7VhcXv69ZNpvM6sAH38uDnwWL/etlgaIL2ZrVtLbZ5WraRC63ff6bki0dG2PTXkWcUyGAGSEB8fhptvlq71Y8eATz6RRMS8RERIgtMDD9iZBly9OnDwoP64WjXHTkousXSpzIhKSJC/aUpK3uXRg4Ol27dNG1mBtlMnyfkgonzK43NwyxbpVcypN7JrV5lE0KJF7j8mKUmCDWPwcfKk7XEhIXIuLfBo1Urq82T//DY+Tktjcrm3KbbBiDFnxMdH1uto0EAuYMuX550rcPPNUnq4dm3IV+ncXuDrm/fXcXJYUpJUKZ0zB9i5U4oiOVIwLCICqFNHPuweekjqeBCRizjwOTjq8Ux89JH93Q0bAp9+aj9hNC1NaowYA4/du+3+CDRsaA486tbNe2bkAw/IZwoANGokARN5l2IZjDz/fBIWLQrD9u32o3MfH8kZSU2V4CQnfn7AK5kv4zm8iwDkcTUEWDknH9atk3VZVq2SRaquXHGsPHqFCkDLljK0dtttLBhG5FZ5VIu8jBDUwy4cRywA22PHjQOee05OY7VKQqkx8Ni82X7NnqpVzYFHs2bSE1KQ5vNj2jsVWjAybtw4/P7779i9ezeCg4PRrl07vPvuu6hdu/b1Y1JTU/HUU09h+vTpSEtLQ9euXTFx4kREO5jEkf3NKCW9hzNmAH/+CWzblr/s6WrYh+8xBDdgde4HsockR9euAT/8AMyaJd+Azp3Lu2CYr68sdV+jBtCli/R2VK1aKM0lIk0ePSJTcRfuxw+wwv43gkmTpNdSCzzWrTNXXtVERZkDj5YtXbP4Y7VqUhkZAHr3luqu5H0KLRjp1q0bBg0ahJYtWyIzMxMvvPACtm/fjp07d6LUf/NqH330UcydOxeTJ09GeHg4Hn/8cfj4+GDVqlUuezNHj8qS0XPmSFfdlSuOvgOgF2biewxFGdj5n6Rh2I3t2yWpdNky+RC4fNmxgmExMVL35fbbgYEDOaZL5BVy6BWxAuiIxViODjD3hqjrjyMjgYsXbV8bFCS1nozBR9Wqrl+uY/ZsWdEX0HtlyDt5bJjm3LlzKF++PJYtW4b27dsjKSkJ5cqVw7Rp0zBw4EAAwO7du1G3bl0kJCSgTZs2eZ4zP2/m1Clg6lRZqnrLFqm0mTsrHsYn+AKj7HRGQmp979nj0M8u6tLTgZ9/Bn79Fdi0Scqjp6Xl/hqtPHrVqkDHjlIwrF69wmkvETkpe7Lqf7aiPlpiPdKRfaEYPRDR+PgA9eubA4/69Qu+0J0jjMHNihXAjTe6/2dS/ngsGNm/fz9q1qyJbdu2oUGDBli8eDE6d+6MS5cuoUyZMtePi4+Px6hRo/Dkk0/anCMtLQ1phqtfcnIyYmNjkVvRM8cZ35q9sCO3t87V+IioOMjP55zKY3/ha9BAhunJexUkGMn3BEmr1YpRo0bhhhtuQIP/JpmfPn0aAQEBpkAEAKKjo3E6hwnh48aNQ3h4+PWbBCKuYjHc8tqf/UZEVBzk53PO+z4HGYgUb/leZm7EiBHYvn07Vq5cWaAGjBkzBqNHj77+WOsZGTTIsXwDY7+OUtnSPaZOsT0ewBUE4Q/0h7z9nP/DBQVJQlZcnEwrzqm2hfFnOjOemb1PKq8+Knv7r12TnI6zZyWvI6/ps5qAABlqiYmR9+fv73iqjLPtzuuYgowB5/e1WnscaXtOP6OgqUXa6519D860Pa9zOPq8K19f0J+d0+ucfX1+jnfV7zw/58ntNVlZ8lmQkiK3q1cdycM3Dsdo2wrlcBoxOCNPN2yS58/O779fR4WEAPPnO/caKnryFYw8/vjj+PPPP7F8+XJUNixCEBMTg/T0dCQmJpp6R86cOYOYHApGBAYGIjAw0Ob5L7+Ui2WBJLxud6xUkwYLKuAsLiEK9oKS1FQpQ37ihBTpio6WioB33imF2ApzLZysLFme+8cfZaGoEydyn9IM6OXRK1eW8uiDB3NBKaKiLjNTEsyN02p37rQNCiwWyetKPXwKJ60VDHsUSiMZVxAOX6QhCwHQApGn8C7ewxg5rFYtYGvJyJ0jz3MqZ0QphZEjR2LmzJlYunQpatasadqvJbD+9NNPGDBgAABgz549qFOnjlsTWHPlQGr3ccSgIbYjEVFOnbpcOUnkuuMOmW6WbXQq3y5elJks8+YBu3bJY0fKo0dGSvGgHj2kQFDZsq5pDxF5hlLA4cPmwGPDBvu1lypX1pNLo6NlCn72KbAWZCESF3EB5RCGS0hGGWiByGP4FJ/hf+YfTuSEQktgfeyxxzBt2jTMnj3bVFskPDwcwcHBAGRq77x58zB58mSEhYVh5MiRAIDVq/Oo7/EflwcjeVUcNJiD23A7fkYagu3u9/WV4Y2cSiRHRcm8+ttvlyJejiyfvWoVMHmy3B87Jt2ref1FQkJkcajWrWWBqltuYcEwouLg/Hmp4WEMPs6ftz0uLEw+a7S1W1q2BCpWlCHb116TekDmnhKFaJzGFZTGVYQiFodwDFWgBSKD8S0mY5h+OOstUT4UWjBiyaGXYdKkSRgyZAgAvejZTz/9ZCp6ltMwTXYuD0ak4Q4fejlZ4eWXkWM5ZE3NmvKBcPiwlDq3p0wZ+ZAYMEAWnPrnH5l+vH27fMA4Uh69TBnpLb31VikYVtCluYnIO6SkyHR6Y+Bhb1TZ3x9o0sQ8rbZWLXMO28mTslbMN9/Y/1zp0gVYvDALVviiOdZiA1pBC0Rux3T8jLvNL2CvCOVDsSwH79JgBHB6bZp164Bhw/Je/6BMGamzUaECsGiRfKDkFJzkJihIztG8ueSk9OvH3g6i4iIrS/I6jIHHtm32P5Jq1zYHHo0bS0FBe86fB955B/jsM8lxy65UKfks+fFHedwfv+B3DIQWiNyG2ZiDfvoL2CNCBcBgxBm1awN79+qPcylwlpEBfPghMHZszkMzRhaLc18otG88gwbJwnB163I1WqKiTikZcl271pznYW8Zi5gYfailVStZudaR3LOkJOCDD+SmVaAODzeXaO/QAShdWpbRAIBnnpHVzP9rJbrgH/yDrvKwBBV6JPdhMOJmBw/K0vUOpr1cFxAgHzZ16sj02ePH5YPJXmllQHpHmjaVZNhbb5VvROwdIfJuFy8C69ebez3OnLE9rnRpGbY19npUquRc+fSrV2XV3HffBS5dkufq1ZPPKK1nxMcH+OQT4OuvZfG6oCD5UjV8uH6eG24ACliVgcgGgxEXyswEfvtNSqRv3Cil5vMqj56bm24CHn1UukqD/qu6fPIksGCBlGBfsybn4CQgQAKSXr2Azp3lWxPXeiHynNRUucAbA499+2yP8/OT/7vGwKN27fx/uUhLA776CnjrLT3QqVtXOjSMM2bi44Hvv5eVsE+elCT6778HunfXe21btJBhaCJXYzCST0eOyLeHhQvlAyUpKe+JN/7+8kGjDduEhkoiWl6vCw8HhgyRPJT69c37jh6VNvz+u/S+aN94svPzAxo2BHr2BDp1ku7d/CzFTUR5s1qB3bvNgceWLfZTKmrUMAceTZoAwfYn5TklM1OCiddek88JQGqHPPec5IocPqwf+9RTUkforrvkM6lePWD6dAmKtE95llQnd2IwkoesLGDuXGDaNOlOPXky7xwQi0W6VePiZGGmoUPl4q9ZvBh45BFg/3553LIlsHWrY70obdpIUHLnnfYLpx06JMmwM2fKlF97S3UD0h1br57UFenYUQqbecnIFlGRow2jarf166WqcXblytnmeUQ5V6IoT1ar9M6OHaunuFWsCLz8snyxue8+/QtQSIgUZVy0SAISpWS6/w8/SFK89glfs6Y5XY7I1RiMGJw5I70dCxbIt5rERMcKhkVFSY9Fz55SMMyRJLJr16Tb9N135WeEhkqV0+++y7s6KiDBzj33yJTd5s3tjx0rJQHP4sXSHbtqVc6rElss0m3brZskr910k+s/JImKg6Qk2zyPkydtjwsJkWDD2OsRF+dcnoczlJKE05deki83gBQvHDNGvvz07w/8/bd+fMeO8ln3xBPA55/Lc488Arz/vnwx0WqNVKkiX3KI3KlEBiNKAUuWSBfmmjWSvX7tWu6zWSwW+XCJjZXeicGD5aJdUNu3Aw8/LN9OAPnW9MQTkjCWU+CQXZMm0lty9925B0JKSZC1eLH09qxYoWfT21O9unxL6tBBunArVMj5WKLiKC1NLuzGwGP3btvjfH1lGNQYeNStK19WCsOiRcCLL8osHECCiaefBkaNkl6bVq30/+s+PvLZ16uX9LDOny+fb+PHAyNHyuec1nNSsaIsH0HkbsU+GElMlN6GuXOBHTukjocjvR0RETKTpVs36X1wpCJqflmtsp7O889LAOLnJx8kd9whBYdySlLNLjhYKrgOGyYZ73l9A7Na5XeyZImUj1+50v4UQk1cnLTn5pslOImPd9+3PKLCZrVK/pcx8Ni8GUhPtz22alW5wGtDLk2beiYHKyFBgpAlS+RxSAjwv//JVNzISOkVeecd/fjYWMn7SEyUSs/bt8trpk6VmXhBQXrhs3LlZBFNosJQLIOROnWScOJEGK5cybt2R3CwRP8tW0rPQo8enpsSe+KEfJD8/rs8rl4d+OILGT5p1cr+lL+c1KkjQdT998uHiiOsVvkWuGSJfFtauTL3IaPoaJmpc/PNcqtVi8EJFR2nTpkDj3Xr7OdYRUWZezxatnT8/5S7bN4swzFz58rjgAAZYnnhBSkJcPUq0KiRuSrrqFHAhAnyPnv1ks+TChWAOXOAZs3ks1DLW4uIcPxLEJErFMtgBEgCYH4zvr6SvFWzpny7HzZMvtl7o9mzgREj9O7R+++XcdysLPkgPHbM8XP5+wN9+8r77dzZucJoWVlScnrJEhlrXrUq9+TdyEgZh9Z6Tho2ZCE28g7JyVI8zBh8HD9ue1xQkORgGYOPqlW9J8jevVsSU3/+WR77+spMu1dekZ5LQL7M3HGHPtQSHCw9KI0bS+mB++6T/8eNGkmOSWys9I4YZ/k5OkRM5CrFMhgJCEhChQphaNZM/lMOHFh4Y7eukpws33w+/VR6d6KipGLifffJvpYt7dcoyE2VKlJ+fuhQKZjkrIwM+UBfskSmE69alfsMoNBQvdekfXvpyvb3d/7nEjkjI0OGIv79V69kumuXbS+pj48knhsDj/r1vfPf6OHDMkX3+++lB9NikerLr70mX7AAeX89ekivpqZ9e/n/quWEPPecPN+jh0zdDQ2Vm5ZPEhKS+1AtkbsUy2DEmyqwFtTatZLgqmXHd+4sQzc1asiHRrt2+j5H+fjIzJ+HHpIPpfwGaunp8kG/ZIkk0CUk2B9f1wQHy1RnLThp2VIv5kaUH0oBBw6Yezw2brQfJMfHmwOPZs1kVpo3O3VKFrH7+ms9l6NPH+CNN6TnUbN3r8zc0aYT+/hIrtzgwfK6xx6ThfAA4PHHZbjGz08S3rWhqaAgx5auIHIHBiNFQEaG9Iq8+qpUcQwKkm7Zp5+Wb3Hp6XKBX7PG+XNXrCg9JQ8+KN3RBZGaKm1YskRm7KxZk3uycECAzExq315u7drZr51CpDlzRnIejMGHvUJ/ERG2eR7R0YXf3vy6cEGm/X/6qR4gdOkigYmxZhEgPahvvaU/rlRJElPLlJFE1YED5cuCj4+Udh85Uo4rW1ZfmDMgQPLDuIQEeQqDkSLkwAGZ8rtwoTxu2FDKPLdpI4+zsmRdmsWLHTtf9sX5tFyaPn1yXunTGSkp0luyZInc/v039+DE11e+3WnByY03OlazhYqnK1ekl8MYeBw5YntcYKAMARqDjxo1vCfPwxnJyfoidlovR7t2EmxkLyVw9arkgRw4oD/3+OOytgwgtUF69pQhqlKlgBkz5DEgiaunT8u2VhW6qA1lU/HCYKSIUUqW9B49WpYAt1gk2fWtt/QKqlarrGfzxx+2r/fzsw0IsgclZctK0uywYTIrx1WuXJE8Ey04Wb9eL6yUk8aN9WGdm25y7xRr8pzMTPk2bww8duyw/fdhsUj9DmPg0bBh0V93KSUF+OwzmYarzWJp0kT+X3fvbhtYzZolPR7GJNVVqyQoA+RLQJ8+wLlz0lPy559yPkASXbUkeF9fCUS8MU+GShYGI0XU+fMyTDNlijyuVEm6dPv21Y+xWmXMeOpU2+S9wED74+r+/vrYNCC9E8OGyQefq+soJCdL4TUtONm0Ke+p2HXq6D0n7dvLTAAqWpSShEwt6Fi7VnpA7OUrVK5sDjyaNy9eyxakp0s+yJtv6j0VdeoAr78ODBhgOxtNKakPMm+e/tyNNwLLlunHzpgh/+/T0iQvZs4cGY4FpMdI60nx8ZHeFeZtkTco0PVbeZmkpCQFQCUlJXm6KYVm4UKlqldXSj6mlOrXT6njx22Pe/RRpSwW/TjtVqqU7XOAUgEB5uPDw5V67DGlNm1y33u5eFGpWbOUeuIJpRo1st+u7LeqVZUaPFipb79Vat8+paxW97WP8ufcOaXmzVPq1VeV6tFDqbJl7f8tw8KU6tJFqRdekH8HJ054uuXuk5Gh1HffKRUfr7//KlWUmjxZ9tmzd69SoaH68T4+Sk2apO+3WpV64w19f+/eSl25ou+vV0/fZ7EodfmyO98hkXMKcv1mMOIlUlKUGjNGKT8/+aAJDVXqs8+UysqyPfb55+VDLPuFoHRpCUCyP2+x2AYszZsr9cUXSrn713z+vFK//abU448rVb++Y8FJxYpKDRqk1MSJSm3fbv93QO5z9apSK1cq9cEH8neoVi3nYLdVK/nbfv+9Urt3l4y/VVaWUtOnK1W7tv67qFBB/r+mpeX8updftv13fuGCvj8tTYJybf/o0UplZur7mzQx/5++eNFtb5EoXxiMFCNbtyrVurX+odO2rVLbttk/dtw4pXx9bS8SoaFKlStn/wISHm5+TUiIUkOHKrV6deH0SJw5o9SMGUoNH27+MM/tFhWlVN++cnHcsMH8AU0Fk5kp/+a++Uaphx+WC569f1OA/L3uu0+pTz5Rau1apVJTPd36wmW1KjVnjlKNG5v/bY4fLwFcTq5cUapmTfPv8tFHzcdcuKDUzTfLPl9fCcSN2rQxv/7MGVe/O6KCYzBSzGRmKvXpp3p3rp+fdHunpNg//tNP9R6V7D0ldevav7AEBioVGWl+rn59pSZMkN6MwnLihFJTpyr10EPmoarcbmFhSnXvLsHYqlW5fxslndWq1OHDSv38s1JPP61U+/Y5D/HFxCjVp49Sb72l1D//KHXpkqdb71mLFpkDgrAwpV57Le+exT/+MP/fDApSat068zF79+rBSmioUvPnm/d36GD+2xw96tr3RuQqDEaKqWPHpEdA+xCqUUM+FHPyww8SZGS/sISEKHXTTfaHdgClKlc2vy4gQKm77pKfVdjd7kePKjVlilJDhpjH4nO7BQcr1amT5DMsXpz7t9SS5MIFpRYskByEXr2Uio62//srXVqpjh2Veu45GVI7dox5O5qEBPm3Zfy39txzeQfsVqv8zo2/57ZtbXv1li/XvxTExdn2gnbvbj7Hvn2ufX9ErsRgpJj7/XcZX9Y+kIYMyf3DcNYs+dDMftEJCpKEuLAw+xelcuWUqlTJ/Fz16tIDcfJk4b1fo4MHJbH13ntt25bTzd9fqXbtJAfnr7/cnxfjDa5dkwvnRx8pdc89tsMC2s3PT/KFHn1UEid37OCwlz2bN5uDCX9/yY1x5P/B/v3m/2MWi1JffWV73A8/6DleLVsqdeqUeX///ua/3fbtrnlvRO7CYKQESExUasQIfXZM2bLyYZbbN9h//jFn7ht7Pu65J+fExKAgydo3duH7+kovzdy5nrt4Wa3Spf3VV9JzExNj23Z7s418fOQC/OSTSs2cWbjDUO6QlSVBxKRJElQ0b25/mE7rTbv7bglSEhIkaKGc7d6t1J13mv/tPPCADG854tVXbYe7zp0zH2O1KvXKK/oxAwbY9ubdfbf5PP/+65r3R+RODEZKkNWrlWrQQP+QuuUWpQ4cyP01CQlKRUTY/5b8wAN64py9W+3atommlSvLh6mjH9DuYrUqtWuXJPvdfrv9pF17wQkgv8PHHpNZEZ7q9XGE1SrDJr/9JsMDHTvaDzABpcqXV+q225R6/XXJOzDO1KDcHT4sidzGocxBg5Tas8ex16ek2P4/GTbM9rhr1ySQ1o55/nnbodBhw8znWbas4O+PqDAwGClh0tIksVDL8wgOVurdd5VKT8/9dVu22L9g+/rK7Jb77pPu6JwudG3bmoMai0Wprl2V+vVX70gitVplzP3jj6VWS/YEXe2bbk49CA88IPkqhw55Lmfi0iXp0XrrLUkgrVDBfntDQiQB9emnJSH18GHmeeTHqVMy/GL8d9+rlwzTOOrPP22TVNessT3u7FmlbrhB/yLwzTe2x4waZf47Z09mJfJmDEZKqL17zcl1jRs71p27Z4/9/AuLRalHHpGZO8aiVsbeBT8/+UBt3tw2WHnmGce/SRaGrCwp8PbBB3KBCQ+3H4jZu9jHxspQ1pdfSte9Oy70qany9/r0U6Xuvz/nqc6+vjLl9uGH5QK2dWvORbXIMefPK/Xss+bcqs6dpRfRUVarBIzGv1Xr1vb/Nrt26cOi4eFS6DC7F14wn+v33/P77og8g8FICWa1SsVHrRfAYlHqf/9TKjk579cePiwVI+0FJUOGyPBHboXKGjRQqmdP21kaN98s+Sw5TUX2lMxMmVb5f/8nsxRKl7Y/dGVvaKd8eaUGDpRel82bnZ9llJUlQc3338s38Vat7BeoA+SiNWiQBFErV3J2kCslJUlehzHBtE2b3Gep2XPggDm4tViU+vxz+8cuWqRUmTJyXNWqSu3caXvMm2+a/w38+KPTb43I4xiMkDp7VmacaB9mlStLjQNHnD6tVJ069i+MAwfK7JwePWwDFm07MlIy/zt1Mg+DlCmj1MiRMjzkjdLT5ZvwuHFK3XqrDH1kf/8BAfaHdsqUkd6W8eOlAFj2IbKTJ+X39sILUh7dXq8MIEWzevSQC+S8ebbJjuQaKSnyt4qKMvckzpnjfK+XsVw7IMF4TkXIvvtOH8Jp107+n2b3wQfm833xhdNvj8grMBih6/7+2zxLZuBAxxM0L140l5w23rp1kwv3o4+au7aNF2ofH7moDx5sWyOkVSulvv7asR4bT0lLk56IN96QwCooyPb3EBhof+ZKUJBMp61XL+fqt0FBMsT15JNK/fSTfLtmnod7paVJmXZj7k3t2lIF2NnerZQU26D9gQfs/w2zsmRquXbcoEH2ZzJ98YX5fB98kL/3SeQNGIyQydWrMvNCy4cID5cuZEc/fJOT5VucvQvqTTdJvYN33jHnnWTvPahdW2ar9O1rvniXLi3VVteu9f4L8bVrSi1dqtTYsZIsmtO6PzkNY5UqJcHdE0/ILKi8EozJdTIyZOqzcRgyPl6ey0++TfYk1cBACVztSUmR2V3asS+/bP//3vffm/+9vPmm8+0i8iYMRsiuzZulmJL2YdeunXOFk65dkyEGexfapk0lWXXaNPPPAMxJoaGh8u3x6aeVqlXLfFzDhpKD4a0LflmtUvFy6lQJKFq1ynm2kXFYx14VXD8/SW585hkZGijp5dXdJStLZhcZezBiYiRJOD9r6VitMjPL+Lds0SLn2WOnT+trS/n7y+wse2bONJ9zzBjn20bkbRiMUI4yM6XglZas6e8v39ScKX6Vnm47a0C71akjBbhWrZJvg8Yekuw9CZ07y5TVe+4xD4EEBUm+y9Klnu0tOX1aAoWXX5Ypy/ZqswDyfNeu0vv02mt6Qqq9mTlhYfYTZS0WyVn43/9kajQXPisYq1V6L4zDjJGRkqyc3wTggwf1xFPtb/bJJzkfv327PjwZGZlzfZD5883/Fv73v/y1j8jbMBihPB09ai5vXauWUkuWOHeOzEwJJOwNTcTHy0yVw4eVeuop82yF7L0JcXFSNG3cOKUaNTLvq1VLLiDuvjhfviwXi/HjJYjKaR2cwECZbfHEE9JDsm9fzgFTUpJcEJ96SqY+2/s9lSmTczJrnToyfffHH7kYmjOWLDEPK4aGSkJwQT5Css9uKVcu99yrv//W/83XqCHT7u1ZutR83gcfzH8bibwNgxFyiNUq38KNyXwPPOB8pc6sLLlo2rvYxsTIxSE5WYZgjCvxWizm3pLAQEl2nTJFqk4aexD8/KRM9vz5BS8/n5Eh9Ua+/FI+/Bs2tD9DxmKRBFRtWvP69QUr5nbpklKzZ0shK+Oy88ZbVJR5hofxVrWq/H6+/Tb3IKikWrvWPIwYHCzDYAUp95+SYrvS9eDBuf/uv/xS7xW76aacf/66debz3n13/ttJ5I0YjJBTLl2Siqvah2L58pL74ezFzmpVavRo+xf2yEjpJcjIkAtyx47m/dmXrm/TRgp6ff65PuZu7HV57TUpi+5Imw4elDLvo0fL7BV7iwYCMv25f39Jxl282P0L6p0/L2XdH3/cfv0Wi0X+FtHR9n+nFSvKrIyJE2VIoLBXVPYWW7bIgo/GnrcRIwpe1n/ePHOSakBA7qXYMzOlF0w7/r77cs5L2bbN/Lfs169gbSXyRgxGKF9WrpSeAO0Dsls3uZDnxyuv2M+ZCA3VA51Nm6TXwdg7EhJivvCWL6/USy9Jt/fIkeYxex8fqckxc6Y+M+XcObmIvPqq7DNWjjXewsPlW/QLL0j9jxMnXPRLLIAzZ2SK6fDh9quv+vhIL1alSvanE0dFyWylDz5QasOG4r/67p49EoxpPXI+PvLv6dChgp3XarVdIbdp09wTXq9ckd+9dvwbb+QczO/bZz53164Fay+Rt2IwQvmWliYfpFqAEBIieRT5LTf+3nv2Z5wEB8tqu5mZsh7IK6+Y63EEBNiuEjxwoFILFkg11+yL+QUFmQMV4y0gQBJKH39cpk/u3l00ehFOnJC8lGHDJO8g+/vy9ZUy9VWq2J9mHBYmlWXHjZOEYm9YL8gVjhyR4TVjsHvHHVJivaAOHrRdb2nChNxfc+KEvhxCYKAE2zk5etT8N+rQoeBtJvJWDEaowHbvNl/wmzaVMe78+vJL+1NcAwIkYElLkxk9334rORzGi0H2HIqICLkI57SOTEiIjNVPmCBrveRnCqc3OnpUgqmhQ+2X7ff3l7ySmjXtV48NDpbiba++KsNQRa2s/KlT0jtmDLxuu0162Fzh7bfNv6+yZZU6fjz312zeLMN72vE51RpRSnq+jOdv3do17SbyVgxGyCWsVgkOtG+KPj5SLfTy5fyf88cf7eds+PlJ70hKivRaTJ2qVLNm9oON7IFHp06S/NeihXlfZKQkizpTS6UoOXRIyovfd59+Qcwe6NWsKQmY9mbs+PvLrJPnn1fqr7/cnyOTXxcuyLRpY4DVqZMUjnOFlBTz8CQgs8TyypmaO1dPsq5TR6n9+3M+9tIlc4J3kyauaTuRN2MwQi515oxc7LUP0rg4SUYtiNmzJX/EXoCRVyExf3/bWh3dukmbDh6UCqnZL85t28qF+8oVl/xKvI5WkO2rr5S66y6ZxWSvZ6RuXZk+bS+XxsdHhhuefFLycAoyC8UVkpOVev1187Tw1q3tr3CbXwsWmP+9BQQ4tkjeJ5/ouU2dOuVeqO/yZXMgUreu69pP5M0YjJBb/PWXeXjgjjuk67wgFi7MOdejXDkZkpg0SXIexo0zBxn+/rZBR7VqMuxz7px8c+3Xz7YC7COPyDTd4sxqlRyKiROlboq99XFKlZIhsRYtZGaOvb9BgwZSxn/69ILPTnFUSor8DY0BU6NGstCjq6YzW62Sg2R8r40b572ydGamFCXTXvPAA7nn4qSmmhOyq1d3TfuJigIGI+Q2V65IKXftAl+mjHwbL2hC6OrVkgeS/WJoscgwhBb0pKfLhTH7dN+4OHPCa3CwJH5u3iyvHTfOXOMEkDyYzz5TKjGx4L8Xb2e1ynTSjz+WAC0y0vZ3HRoqv5O2bSX3xF5wUqOGXICnTJFhIlfWOklLk6ncxsCoVi35e7sy4fjQIdsk1ffey/t1yclK9eypv+6dd3J//+np5kA4NtZlb4GoSGAwQm63caM+gwCQhNGdOwt+3m3bbItMabf+/aWiqyYhQXpnjB/45cvbfsu/8Ua5oKWmSuLmXXeZkyCDg6WQ1YoVJaeQWFaWBGoTJkiNDns5JWXKyCykm2+2XZ3WeIG95x5JUN69O3+/v8xMCW6MAVBcnOQr5XcWV07eecc8ZBIZKbNz8nLsmF6oLihIqV9+yf349HTz9OuYGJc0n6hIYTBChSIzU6kPP9R7JAICJF/DFbNX9u41rytivN16q9SY0Bw5IpU2jRfU0qXlAmoMVCpUkGJpp05JPsSHH9oWG6tbV6n331fq7NmCv4eiJDNThq7Gj5f6LPbyeaKipGhcly4ybGJvNlP58jL88fHHEuzk1qORlSUXdWPwGR0t+RiungGVkmKepQUodeedjgVPGzboVYrLl1dqzZrcj8/KMge7UVGueQ9ERQ2DESpUR46Yu6/r1Mm9UqUzDh+Waqz2gpIbbjBP67x8WVZjrVlTP8bXVwIO47CEv7/0jqxaJReOhAQZejDO1vD3l16Xf/4pGjVJXC0jQy6648ZJ8GdvqnD58lIno2dP6UGxN3W7TBlZA2n8eCnXnp4uAcDcuTIkpB0XESG9Fu5IMP77b3OSqr+/JK46YtYs/b3Xr+9YQTXjoo/h4QVpOVHRxmCECp3VKku1R0frH8TDhuU+y8AZJ07YlpA35n4Yp3lmZclqu506mY+rWVNyELK/9ttv5ZtzUpIMN2SfIly1qiyU5g1VWj0lLU1qaLzxhvxejRdc7VapklK33CI5KTfdZFviXxviMCYslyolU7rdkbdjtUpAafz5DRo4Vl/FapVKttqQzq23OtZGY9BWunTB3wNRUcZghDzm4kVZNM/Y7T59uutyMc6fl/LZ9oKS2rWlJ8P4szZvlhk5xm7zmBilWrY0f5OPjJShHq38/aZNsr6JcejHx0e+5f/xh+tzGYqa1FRZcXbsWKXat7dfATYuTnpNBg2SnhN7JewDA+X1Wsn/gtSwMTp0yNwbZrFIL48jMjLMazUNH+7Y39s4BTk4uEDNJyoWGIyQx61YYc4F6NHDnHxaUImJ8g3c3krB8fHSvW4MSk6flsqj5cubv5W3ayff6I0XrV69pBs/K0u+RU+ZIt/0jT+jYkWlXnwx/2v3FDcpKVKf46WXZPjMXuCh/X5r15YeFGMvmnbz85OZUs88I71b+elZ+7//M/+7iIhw/O+UlKQHuxaL5A85EkgbZ+cEBpacRGii3DAYIa+QmioJo8Z1bt5/37W9CleuSP6HvaAkJkYqvhoXjLt2TYqfNWpkvkC2bGmeHQTIkM5HH+nd87t2yaqsxvoXFotcWH/+ufis/eIKW7bkPKxm/P3eeaf0pA0cKEGkveClcWMpA//rr1KALyfXrtkmqQ4c6HjOz+HDMoyj/VudOdOx1xkDXH//4r9AIZGjGIyQV9m1S7ritQ/sZs1khoIrXbtmu3ia8ZvxF1/oK/sqJd9cFy2SXhBjIFO7tswWMc4mKVVKqUcf1cvKp6VJ8HHLLeafU7asBCuuWLCtqDp6VKmHHjL/HW6/XdYImjtXatQ0b24uBKbd6taVmjKPP67Uvffa5vdotzp1JID58Uf5eUrZJqn6+UmRPketXav31FSo4HhRPGOvmq+v+d8YUUnHYIS8TlaWUt98oycv+vjIhdvVsyfS0+VbtL1hgtBQKW6Vvcrm3r2SH2JMPixXToaWsl8QO3ZU6rff9N6dgwdlaMJebZMpU4reYnT5dfq0VCY15o707Cn1aOy5dEmWBBg1Sq/fkf3WsKEEmE8/LQGOsTfLeMueKFuvnnO5J7/8oifkNm4sNUUcYaxG7OPDnjGi7Ao1GFm2bJm67bbbVIUKFRQANTNb3+bgwYMVANOta9euDp+fwUjxcuqUJDQa8zvmzXP9z8nMlAXg7K1zExQkw0fJyebXXLwo+QbGSrABAZJD0KmT+dt85cpKvfWWPmyQkSGJrb17m3sFwsOlnLqrVpb1NhcvKjVmjDmQ69BBpk074/x5CfIef9y29os2XNO0qfwuX3pJkkpzqhJbsaL8G5s4UXqzchqmsVplOrExeMr+byInxiDVx0d65ojIrFCDkXnz5qkXX3xR/f777zkGI926dVOnTp26frvoRFYag5Hiae5cc47AoEHy7drVsrIk8LA3FTUgQBIlL1wwvyYjQ6kZM6QsuvH4tm1lyCEqynyO++6Tbn7NiRMyFTj7xbJFCxkuKg7/lJOTZZqvcbZRq1a2s5ny68wZGQp79NGcq78ab4GBMvxjb1ZPVJRSffvKVN0NGyRQTU+XXhftmJEjHc9l0vJKtCDJ0QCGqKTx2DBNTsFInz598n1OBiPF1+XLSo0erfc4lCkjQznumIlgtUryrL3iXb6+ctGzFwytWSOBkrG3o3p1CUCyJ7y2bClDM9q35KwsuTjfcYe5hyYkRIqsrV5d9GZdpKTI79GYxNuwoQy5uPO9nDyp1LRp8nvLvmLzoEF60mhKikw5fv11pTp3lim29obrtIDSYpEgxVHGGjQWi20gS0Q6rwtGwsPDVbly5VStWrXU8OHD1flc1iZPTU1VSUlJ12/Hjh1jMFLMrV8vSa3ah/zNN8s6J+4ycaL9cuc+Pkrdf7/9tUqOHlXq2WfNBbvCw2Vdlv79zd/Iy5VT6oUX9ORKpaS8/Pvv237Lr19fytLn8l/CK6SnS6+OMWGzZk0JEAqrQu3WrTJDyhhULF+e+2vS0qTC7rvvyjBM9kAGkIClY0eZ+r14cc55PtkrARfWKsZERZVXBSM//fSTmj17ttq6dauaOXOmqlu3rmrZsqXKzGH+29ixY21yTBiMFH8ZGeaei4AAGV5x9RolRpMnm+tDGG/9+5vXv9FcuSIr/RpzBnx9JVdk+HBzvomPj5xn8WK918BqlRosgwebv7UHBsoU5cWLvav8fGamUt9/r1S1anpbY2OlB6uwCr9ZrTIkZMzZ6dTJ+QJpq1bpPTrh4dJzYuzh0W7+/lJ/5vnnZUbO+fO2QaQjZeGJSjqvCkayO3DggAKgFi5caHc/e0ZKtkOHlOreXf/Qr1tXLt7u9PPP0pthLyjp2lVqZmSXlaXUn3/KBc14fKtWMvTUoYP5+Xr1pEfGeAG9dEkCm+wLAlavLtVCT51y7/vOjdUqdT3q1dPbFR0tC+C5M0DM7tw583CYn59Sn3/u/Hl++kmvuNusmV7a32qV1aY//1yCweyzouzdSvLUbSJneHUwopRSZcuWVV988YVD52TOSMljtUoJeWMxqUcekYu3O/35p746a/bbTTflvFrr1q2Sy2AsL1+5slJPPinPG6eehoXJFNjsw1Dr18t7NA4f+fpK4uXcuYVXSMtqld4AYwAQESHBkTsWscvNrFnm3qMqVZyveKv1qmjn6NMn9/dhtSp14IBSkybJMgLGBF0GIkTO8epg5NixY8pisajZs2c7dE4GIyXXhQtSX0K7EMTESC+Gu5M+Fy2SdVXsBSXNmpmHXYzOnJGhJWOZ85AQeQ8vvmhbs+TWW2U6sDHQuHJFKsRmn8lTubIsKOfKkvrZLVsm9VG0n1m6tFIvv+z+IDC71FSl7r7b/P4ffdT5gCw1VXKAtHM89ZRz53juOXMbiuv0bCJ3KdRg5PLly2rTpk1q06ZNCoD64IMP1KZNm9SRI0fU5cuX1dNPP60SEhLUoUOH1MKFC1WzZs1UzZo1VaqDfb0MRmjpUqmMql0UbrvNfpKpq61erVSNGvaDkrp1Ze0Ue0FJaqrko2Qv5tWjh9S1yF71tUoVqW+SPYl1+3YpCpZ9wbdu3WQIxVXVPtetk8DImL/y1FOSdFvYtm83906Fhkrw56zz5/Wqv76+zg/tvPqq+W+XkOB8G4hKukINRpYsWaLsJZwOHjxYpaSkqFtvvVWVK1dO+fv7q/j4eDVs2DB12omCEgxGSCmZLvvKK/oU2VKlZBZKYQxfbNhgvxAXILVEZsyw3w6rVaklSyS51Rh8NGggwx6jR5sDjaAgGdbJXrX02jXJeejUyfyzy5eXGT72Em0dsX27LDZozMcYPlyp48fzd76CsFqliJwxSfXmm/NXk2XvXpnpow2LLVjg3Ov/7//Mv+clS5xvAxGxHDwVYzt2mIcSWrQovO7z7dulCqi9oCQmRoZXcuqt2LdPCmsZ80fKlZMZGx98YJvE2q6dTJvNXmJ83z6peGqc4qpduH/80bbUfU5tuecePUDSpjQfOFDgX1G+nDtnrt/h66vUJ5/k71zLlukBXny8Utu2Off6Tz81/17dUR2YqKRgMELFWlaWUl9+qScX+vpKJdXCWgdm/37bmhPaLSpKLqQ5lQe/dEnWxzHmpAQEyFTfSZNkRodxXZ3oaOkR0mZ/aNLTZVXZnj3NvQkRERL0bN1q+7OPHlVq2DBzAbcBAyTA85TZs81JqvHxEizlx/ff6z1nrVo5X9H322/Nf8vffstfO4hIMBihEuHkSSnPbhwymT+/8H7+kSPSI2EvKAkNlaGYnGphZGTIAm3t2plf16GD9LCMHWvOnfDzk0quy5fb5qkcPSqJs9mTblu1Uurrr2UGyqhR5tk+3bu7fuVkZ9hLUh02LH+1S6xWSbTVzjNwoPOB6bRp5rb88IPz7SAiMwYjVKLMmWMuNnbPPfoCdoXh1CmpR2LMC9FuwcGysFtuyzGtXWvbI1K9ulITJkgi7E03mc/ZqJFSX31lO0U1M1OCsQED7K9arA3nrFzpzt9G3rZvN9fzKF1aqb//zt+5rl2T3512ruefd75o3KxZ5t/Rl1/mry1EZMZghEqcy5fl2782ZBEZKT0Mhbn2y4ULUsfCXlASECDty23o4NgxuZgaq8KGh8vMlrlzpefAOKRRpowkwe7fbz7P5ctyHnvrsjRsKMNITqxV6TJWq/QWGYeVbrgh/1OHz57Ve5b8/GSYxVkLFph/Px9+mL+2EJEtBiNUYv37r3lKbceO+Z9tkl9JSbJ4m/Gia0zOfPhh87o12V25IlNRjdOZfXxk+OGvvyTnxFie3WKRacOzZkkyrLGabIMGsoLwPfeYVy4OClLq3nsl4bMwArZz52QhQeP7mTAh/z971y79d1CmjNSGcdby5ea/zdtv568tRGQfgxEq0dLTZXqm1jMQGCgX5OwzU9zt6lWp4mlMGDUGEHffnXuyZlaW9Ijccov5tS1bysyZ2bPNpfONt2rVlJo61Tzl+OJF6RVp1Mh8bK1a8vty19DWnDnm1ZIrVy7YQoiLFukLFlarlr+qqP/+a/4dvPRS/ttDRPYxGCFSkrjZtat+walfXxZLK2ypqUo99ljOeRx9+uQ9BXXbNqnkakxCrVRJklqNK+kac1UeecT+rBqrVfJUhg0zr2Lr5yf5JvPnu2axvtRU6X0xtmvo0IIFhd9+q/8e27XLX2G2rVvNbXrqqfy3h4hyxmCE6D9Wq/QQaEMXFouUFk9MLPy2ZGTIhS8gwH5Qcsst8o09N2fPKvX663rPgDH4eOopqZPRsKFt0uovv9ivgZKcLDNuWrc2vyY+Xn7OsWP5e687dpiTVEuVKljNjqwsyYPRznfXXTlPn87Nnj3mnJ7HHst/m4godwxGiLI5f16+lWsXoQoVpI5EYSa4ajIzZSqqsZfDeGvXTqp+Zm+b1SpDM8acmOxDQN27S1Lm0qUy7dm4v1IlWTQupyTaLVukRokx0PHxkVoms2Y5Vn7ealXq3XfN+TJt2tiWundGSorky2jne+WV/P3dDh0yByJDhuS/TUSUNwYjRDlYvFgvFa4NkeT3239BabNLjPkUxlvjxpIzkpUliavGBNDQUKlFcumSBB59+5ovtPXrS4/H3r0S+BhXQPb3l4TWhAT7F/WUFMlJyV5DJSZGqr9mn72jOXfO3MPi4yO5KAUJ+E6flnopWru//z5/5zl1yvz7ufPO/LeJiBzDYIQoF9euScKilntQurRSH39cOOvc2GO1ypTSsDD7QYmxhHxIiAxX2Otp2L9fqf/9z5wHUrasvNdDh2S4Knvl2ObNpfJrTmXk9+yR9W+MwQwg6+T89JPkhShlm6RasWLBK7tu2ybDRYBM1V62LH/nOX/e3FPTu3fB2kVEjmEwQuSAbduUattWv0i1aiVDFZ709dfmOiPGW0SEzIbJa7gkMVGp99/XL+Rar8J998kifOvWyRCFcZgoKkqp555T6vBh++dMS5OVgrt1M/cwREbKCsbGdt53nx6k5NeCBXpwVrOm9PDkR3KyeajqllsK1i4ichyDESIHZWUpNXGifuHz85OeB0cWnHOnH36QXg17QUmVKlKHJK8EzowMCSBuuMH8+vbtZV2b06clv8MYtPj4yNDVP//kPLxy+LDkbWRfrM/HR3JOsleGddYXX+gBRPv2+c83SUkxz2Bq375g7SIi5zAYIXLSiRMyrVW7cFWvLhdkT/vtN9s1Z4xJuO+/79jF/99/pa6J8eJcrZoMD126JAmqXbqYz1+njvTEZP+vpyWp2qs0C0hgN3y4UuvXO/deMzOloqx2nvvvz38PS2qqvmie1utFRIWLwQhRPs2eLUW5jEMO+all4Wrz5pmrrhpvUVEyS8aRsurHj0sSamSkOXh48kmpy7Jzp1KPP27OOyldWqkRI6Q+x/Tp5mEZHx+l3npLFi0cN06COGPbmjaVnqe8plJfuSI9Mtrr3nwz/4mvGRnmIajGjfN3HiIqGAYjRAWQnCyJoNo3/6gopaZM8cw04OyWLDGXiTfeSpeWISZHKqlevSrDIXXqmAOL/v2VWrFCgodPPzXvz36LibHNscnKkgqpd91lrqcSHKzU4MGySF/23+OJE0o1aybHBQZKYmx+ZWSY1+SpWzf/5yKigmEwQuQCa9eaS6d37px7+fbClJBgW9xMuwUFSTDlyJRlbdrwrbeaz9GihUzvTU1VauFCmT1j3P/AA3nnrJw/L+vP1Ktnfm3dujK8dO6cUps36z1RZcsWrEJuZqa5R6datfyfi4gKriDXb4tSSsGLJCcnIzw8HElJSQgLC/N0c6iEycgAJkwAxo4FUlOBoCDglVeAp58G/P093Tpg0ybgoYeAjRtt9/n5AUOGAM89B9Sokfe5duwAPvoI+OEHea8AULEi0KIFsGABkJYGlC0LTJkC9OjheBuVAtasAb7+GpgxA0hJ0dsHAJmZQO3awLx5QLVqjp83u4gIIDFRtmNjgaNH838uIiq4gly/GYwQ2XHgAPDoo8A//8jjhg2Br74C2rTxbLs0u3YBDz4IJCTY7rNYgLvuAsaMARo0yPtc588DX34JfPIJcOaM/nzlysDUqUD79vlvZ3Iy8NNPwFtvAceO6c/HxwPDhgFDh0oA5KyyZYELF2Q7JgY4dSr/bSQi1yjI9dvHTW0iKtKqV5fegR9+kAvftm1Au3bAyJFygfW0unWB1aslaLr5ZglANEoB06ZJANWvH7B+fe7nKlsWaN1aP4d2f/y4nLt7d/ld5OdrS6lS0gOjBSJ16wLh4cCRI8BLLwFxcUCfPsCcOdJj4oiYGD0QiYpiIEJUHDAYIcqBxQLce6/0QgweLBfjTz8F6tUDZs3ydOtEtWrA0qVycb/1VnNQAkg7W7YEunYFli+3fX16OvDMM8AttwCnT0uwsHGjHNuvn5xv/nygWzfpZfnqK+DaNcfadvmyBBqffCKP331XApOTJ2Xo58Ybgaws4I8/gN69gSpVgJdfBg4fzvmccXF67014uPTqEFEx4OL8lQJjAit5q4ULlapRQ0+Y7NdPps56k9OnlerVy1wO3Xi78UaZNmy1yrRebVYLIKsbX71qPt+BA0qNGiVr4xinFr/4osyKycnRo/oCf0FBUozNnp07ZfVhY8E3i0Uqp/78s1SC1RinOpcu7bly/kRkH2fTEBWSlBSlXnhBLyYWGqrUZ5/JLBVvcvGi7Sq+xlt0tL4vKkqKoOUmKUlmylStqp/D31+pe++1LXa2fr0UaNN+ztq1ebc3NVWpGTMkCDG2s2xZCVaMQWBwsEzpJSLvwtk0RIVs2zbg4Ydl1gggia1ffSV5Gt7k8mVgxAhJIrWXk1G6tCSXPvaYPtslN9qwyoQJwIoV+vM33QSMGiXb990nM2jq1wfmzpVkVWccOgR8+y0waZIM6RgFBgJXrjjWViIqXJxNQ+QBWVkyC+X55+Wi7+cHPPusJGYGB3u6dWYpKTLl97vv9Km2RlWryv4hQ+SC74gNG4APPwSmT7cNdDp3Bn77TfI68iszU4IcLeALCJDkYUfbR0SFi7NpiDzA11d6FHbtkmTPzEzg7beBRo2ARYs83TqzkBBJJE1MlB6cWrX0fRaL9EYMHy4JsRMmAFev5n3O5s1lttH+/UDTpuZ9//4LvPoqcPBg/tt8//16IFK6NAMRouKMwQhRAVWqBPz+u9wqVpSLc5cu0svgbbM9/P2lvsfOnTL9t359fcquxSLDIqNHy8yWt97Si4rlJClJhqs2bZLHt98us40uX5Zek5o1gf79ZXaOM32wDzwgQ0uABFKnTzMQISrOGIwQuUi/ftJLMmKEXNinTJGpsj/+mL8aHe7k6yuF0bZuleGUpk3NQcn58zLcFB8PvPACcO6c7TkOHwZuuAH4+28JGGbNAn7+Gdi+XZ8ObLUCM2dKvZIWLeR3kZ6ee9tGjJB8EUAq4J48KfVKiKj4Ys4IkRusWSM9ENu3y+NbbgE+/1yKqXkjpaQ8+xtvAGvXynMWix6gBAdLD8jTT0tl1rVrpTbI2bPSGzRnDtCsme15d+4EPv4Y+P57vT5JhQoScDzyiBRcM3rqKeCDD2Q7IEACkago97xnInItJrASeaGMDOC994DXXpN1XoKCJI9i9GjvWOfGHqWAhQslKDHOltH4+0t5+JUr5T01bgz8+acEKLm5cEGSfT/9VK+YGhQkM29GjZKhnZdekqEh7eccOwZER7v07RGRGzEYIfJi+/ZJcujixfK4USNZRK5VK8+2Ky/Ll0tQsnCh/f0VK+oVXh2Vng788oskyW7YoD/fsKFMlwZkVtLBg7L4HREVHZxNQ+TFataUC/qUKTLksHWr1CV54glJ9PRW7dvLQoGrV8v6NNmdPCkBVf/+5sAiNwEBwD33AOvWSc9L//6Aj48eiPj6Anv2MBAhKmkYjBAVAotFpqru2iVDE0pJLkW9elJEzJvVqSNDMjmZOVOSU7t1sz+0Y4/FImvTDB0qSa6A9Ihs3y7Ti4moZGEwQlSIypWTZM6//5aL7vHjspjcwIG21Ua9wYEDQNu2MsRUurRUVN26FRg0yHZRvgULpDelfXvHVvmdNEneOyAJsvv2SeBDRCUPc0aIPCQlRXIyxo+Xaq5hYbKy7cMPy9CFp61aBfTtK9N8K1eWRNXGjfX9e/ZIkbepU6X9gHkGTqVKUm+lZUsZnvHxkZs27XnpUjkuKAjYssVciI2Iih4msBIVYVu2SADy77/yuF07qZJav77n2vTTTzKEkpYmlVbnzJEpufYcPAi88w4webLMIAIk6NCGX3ITESHThGvWdFnTichDmMBKVIQ1bixJoh9/LEMhq1dLEbKXXwZSUwu3LUpJb83dd0sg0rcvsGxZzoEIIMNNX30llWdHjJBKqVogEhMDtG4tNUl69ZK1ZrR1e+LjJUeEgQgRMRgh8gK+vsDIkVIkrHdv6WF4802ZBqwNZ7hbWhoweDDwyivy+OmnpTqro9VP4+KkjsihQ1JLRSvjvnatPNe6tZSNv3YNqFFDkl0rVnTf+yGiooPDNEReRimZofL443qBsAcekNySyEj3/MwLF/Q1ZHx9gc8+kwqpBXHunFRT/fRT4MoV/fmOHYFff3XfeyEiz+AwDVExYrFIYLBrF/Doo/Lcd9/JTJNp01y/zs3evVL3ZPlySaKdN6/ggQggM4fGjQOOHAHGjpXaISNHykwbBiJEZMSeESIvt2qVJLju3CmPu3aVdW6qVi34uZctk8Dn4kXJ4Zg717OJs0RUdLFnhKgYu+EGybV4801JDl2wQAKG994DMjPzf97vv5cF/C5elHyOtWsZiBCRZzAYISoCAgKAF1+UgmMdOkgS6DPPSA2P9eudO5dSkqQ6eLAkyt5+O7BkCRelIyLPYTBCVITUqiXVUL/7Tmp0bN4svRpPPmlOEs1JaqpM233jDXk8Zgwwfbo+3ZaIyBMYjBAVMRaLFCTbvVsCC6sV+PBDGWKZOzfn1507B3TqJMGHn58ENG+/7R3VXomoZOPHEFERVb68lGKfPx+oUgU4ehS47TbgzjulvofRrl3Sg5KQAJQpI2vjDB3qiVYTEdliMEJUxHXtKpVMn3lGaoT8/LNMA/7qK+k1WbRIFrs7dEiqpSYkSK0PIiJvwam9RMXIpk3AsGHAhg3yuGlTYNs2mXVzww3ArFlA2bIebSIRFVOc2ktEACT4WLtWckhKlZLgJDNTcksWLmQgQkTeicEIUTHj6ws88YQUSXvoIeD994EffwSCgjzdMiIi+/w83QAico+4OODrrz3dCiKivDndM7J8+XL06tULFStWhMViwaxZs0z7lVJ45ZVXUKFCBQQHB6NLly7Yt2+fq9pLRERExYzTwcjVq1fRuHFjfPbZZ3b3/9///R8+/vhjfPHFF1i7di1KlSqFrl27IjU1tcCNJSIiouLH6WGa7t27o3v37nb3KaXw4Ycf4qWXXkKfPn0AAN9//z2io6Mxa9YsDBo0yOY1aWlpSEtLu/44KSkJgGTlEhERUdGgXbfzM0nXpTkjhw4dwunTp9GlS5frz4WHh6N169ZISEiwG4yMGzcOr732ms3zsbGxrmwaERERFYILFy4gPDzcqde4NBg5/V/Zx+hsK25FR0df35fdmDFjMHr06OuPExMTER8fj6NHjzr9Zoqy5ORkxMbG4tixYyWqvgrfN993ScD3zfddEiQlJSEuLg6RkZFOv9bjs2kCAwMRGBho83x4eHiJ+iNqwsLC+L5LEL7vkoXvu2Qpqe/bJx8LXrm0zkhMTAwA4MyZM6bnz5w5c30fERERkZFLg5GqVasiJiYGixYtuv5ccnIy1q5di7Zt27ryRxEREVEx4fQwzZUrV7B///7rjw8dOoTNmzcjMjIScXFxGDVqFN58803UrFkTVatWxcsvv4yKFSuib9++Dp0/MDAQY8eOtTt0U5zxffN9lwR833zfJQHft/Pv2+mF8pYuXYqOdpb8HDx4MCZPngylFMaOHYuvvvoKiYmJuPHGGzFx4kTUqlXL6cYRERFR8ed1q/YSERFRycKF8oiIiMijGIwQERGRRzEYISIiIo9iMEJEREQe5fXByN69e9GnTx+ULVsWYWFhuPHGG7FkyRJPN8utli5dCovFYve2bt06TzfP7ebOnYvWrVsjODgYERERDk8LL8qqVKli87d+5513PN2sQpOWloYmTZrAYrFg8+bNnm6O2/Xu3RtxcXEICgpChQoVcN999+HkyZOebpZbHT58GA8++CCqVq2K4OBgVK9eHWPHjkV6erqnm+Z2b731Ftq1a4eQkBCUKVPG081xm88++wxVqlRBUFAQWrdujX///dfh13p9MHLbbbchMzMTixcvxoYNG9C4cWPcdtttOa51Uxy0a9cOp06dMt0eeughVK1aFS1atPB089zqt99+w3333YehQ4diy5YtWLVqFe6++25PN6tQvP7666a/+ciRIz3dpELz7LPPomLFip5uRqHp2LEjfv75Z+zZswe//fYbDhw4gIEDB3q6WW61e/duWK1WfPnll9ixYwcmTJiAL774Ai+88IKnm+Z26enpuP322/Hoo496uiluM2PGDIwePRpjx47Fxo0b0bhxY3Tt2hVnz5517ATKi507d04BUMuXL7/+XHJysgKg/vnnHw+2rHClp6ercuXKqddff93TTXGrjIwMValSJfXNN994uimFLj4+Xk2YMMHTzfCIefPmqTp16qgdO3YoAGrTpk2eblKhmz17trJYLCo9Pd3TTSlU//d//6eqVq3q6WYUmkmTJqnw8HBPN8MtWrVqpUaMGHH9cVZWlqpYsaIaN26cQ6/36p6RqKgo1K5dG99//z2uXr2KzMxMfPnllyhfvjyaN2/u6eYVmj/++AMXLlzA0KFDPd0Ut9q4cSNOnDgBHx8fNG3aFBUqVED37t2xfft2TzetULzzzjuIiopC06ZNMX78eGRmZnq6SW535swZDBs2DD/88ANCQkI83RyPuHjxIqZOnYp27drB39/f080pVElJSfla4ZW8S3p6OjZs2IAuXbpcf87HxwddunRBQkKCQ+fw6mDEYrFg4cKF2LRpE0JDQxEUFIQPPvgA8+fPR0REhKebV2i+/fZbdO3aFZUrV/Z0U9zq4MGDAIBXX30VL730Ev78809ERESgQ4cOuHjxoodb517/+9//MH36dCxZsgSPPPII3n77bTz77LOebpZbKaUwZMgQDB8+vNgPP9rz3HPPoVSpUoiKisLRo0cxe/ZsTzepUO3fvx+ffPIJHnnkEU83hQro/PnzyMrKQnR0tOn56Ohoh1MqPBKMPP/88zkmaGq33bt3QymFESNGoHz58lixYgX+/fdf9O3bF7169cKpU6c80fQCcfR9Gx0/fhwLFizAgw8+6KFWF5yj79tqtQIAXnzxRQwYMADNmzfHpEmTYLFY8Msvv3j4XTjPmb/36NGj0aFDBzRq1AjDhw/H+++/j08++QRpaWkefhfOc/R9f/LJJ7h8+TLGjBnj6Sa7hLP/v5955hls2rQJf//9N3x9fXH//fdDFcGC2Pn5XDtx4gS6deuG22+/HcOGDfNQywsmP++bcuaRcvDnzp3DhQsXcj2mWrVqWLFiBW699VZcunQJYWFh1/fVrFkTDz74IJ5//nl3N9WlHH3fAQEB1x+/8cYb+OSTT3DixIki24Xr6PtetWoVOnXqhBUrVuDGG2+8vq9169bo0qUL3nrrLXc31aXy8/fW7NixAw0aNMDu3btRu3ZtdzXRLRx933fccQfmzJkDi8Vy/fmsrCz4+vrinnvuwZQpU9zdVJcqyN/7+PHjiI2NxerVq4vcCufOvu+TJ0+iQ4cOaNOmDSZPngwfH6/uoM9Rfv7ekydPxqhRo5CYmOjm1hWu9PR0hISE4NdffzXNfhw8eDASExMd6vVzetVeVyhXrhzKlSuX53EpKSkAYPOP1cfH5/q36KLE0fetUUph0qRJuP/++4tsIAI4/r6bN2+OwMBA7Nmz53owkpGRgcOHDyM+Pt7dzXQ5Z//eRps3b4aPjw/Kly/v4la5n6Pv++OPP8abb755/fHJkyfRtWtXzJgxA61bt3ZnE92iIH9v7fOsKPaEOfO+T5w4gY4dO17v9SyqgQhQsL93cRMQEIDmzZtj0aJF14MRq9WKRYsW4fHHH3foHB4JRhzVtm1bREREYPDgwXjllVcQHByMr7/+GocOHULPnj093Ty3W7x4MQ4dOoSHHnrI000pFGFhYRg+fDjGjh2L2NhYxMfHY/z48QCA22+/3cOtc5+EhASsXbsWHTt2RGhoKBISEvDkk0/i3nvvLda5UXFxcabHpUuXBgBUr169WOdHrV27FuvWrcONN96IiIgIHDhwAC+//DKqV69e5HpFnHHixAl06NAB8fHxeO+993Du3Lnr+2JiYjzYMvc7evQoLl68iKNHjyIrK+t6LZ0aNWpc/3df1I0ePRqDBw9GixYt0KpVK3z44Ye4evWq4xMvXD/Bx7XWrVunbr31VhUZGalCQ0NVmzZt1Lx58zzdrEJx1113qXbt2nm6GYUqPT1dPfXUU6p8+fIqNDRUdenSRW3fvt3TzXKrDRs2qNatW6vw8HAVFBSk6tatq95++22Vmprq6aYVqkOHDpWIqb1bt25VHTt2VJGRkSowMFBVqVJFDR8+XB0/ftzTTXOrSZMmKQB2b8Xd4MGD7b7vJUuWeLppLvXJJ5+ouLg4FRAQoFq1aqXWrFnj8Gs9kjNCREREpCm6A3ZERERULDAYISIiIo9iMEJEREQexWCEiIiIPIrBCBEREXkUgxEiIiLyKAYjRERE5FEMRoiIiMijGIwQERGRRzEYISIiIo9iMEJEREQe9f9PBMRv+fR2iAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "x = torch.tensor([[np.tan(np.pi/3)],[-np.tan(5*np.pi/24)],[-np.tan(7*np.pi/24)],[-np.tan(9*np.pi/24)],[-np.tan(11*np.pi/24)]], dtype = torch.float32)\n",
    "y = torch.tensor([[94],[29],[24],[20],[20]], dtype = torch.float32)\n",
    "\n",
    "for i in range(num_experiments):\n",
    "    \n",
    "    m = 10\n",
    "\n",
    "    model = nn.Sequential(\n",
    "                nn.Linear(1, m, bias = True, dtype = torch.float32),\n",
    "                nn.ReLU(),\n",
    "                nn.Linear(m, 1, bias = False, dtype = torch.float32)\n",
    "            )\n",
    "\n",
    "    optimizer = torch.optim.SGD(model.parameters(), lr=1e-3)\n",
    "    epochs = 100000\n",
    "    tol = 5e-5\n",
    "    lam = 1e-1\n",
    "\n",
    "    for i in range(epochs):\n",
    "\n",
    "        model.zero_grad()\n",
    "        l2_penalty = sum([torch.sum(param ** 2) for param in model.parameters()])\n",
    "        obj = torch.sum((model(x) - y) ** 2) / 2 + lam * l2_penalty/2\n",
    "        obj.backward()\n",
    "            \n",
    "        optimizer.step()\n",
    "\n",
    "        # check for convergence\n",
    "        \n",
    "        model.zero_grad()\n",
    "        l2_penalty = sum([torch.sum(param ** 2) for param in model.parameters()])\n",
    "        obj = torch.sum((model(x) - y) ** 2) / 2 + lam * l2_penalty/2\n",
    "        obj.backward()    \n",
    "        grad_norm = sum([torch.sum(param.grad ** 2) for param in model.parameters()])\n",
    "\n",
    "        if grad_norm <= tol:\n",
    "            print(f\"Converged at {i}/{epochs}\")\n",
    "            print(obj)\n",
    "            break\n",
    "\n",
    "        if i % 2500 == 0:\n",
    "            print(f\"{i}/{epochs}: Obj - {obj}, Grad - {grad_norm}\")\n",
    "\n",
    "\n",
    "    xs = np.linspace(-8, 4, 300).T\n",
    "    xs = np.expand_dims(xs, axis = 1)\n",
    "    plt.plot(xs, model(torch.tensor(xs, dtype = torch.float32)).detach().numpy(), color = 'blue')\n",
    "    for p in range(5):\n",
    "        plt.scatter(x[p], y[p], color = 'red', s = 80)\n",
    "\n",
    "plt.xlim(-8, 0)\n",
    "plt.ylim(10, 40)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "FT",
   "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.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
