{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 252,
   "id": "1a196dec-e9d8-40de-a770-467fbef72abd",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np \n",
    "import torch\n",
    "from torch import nn \n",
    "import torchvision\n",
    "from matplotlib import pyplot as plt\n",
    "import math\n",
    "import torch.nn.functional as F\n",
    "from torch.nn import init\n",
    "from torch.nn.parameter import Parameter"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 250,
   "id": "4efe1af7-83d2-4c57-a926-5e5d2d5cc5a8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Initial parameters: a = -1.710301569497004, w = 0.570612997219531\n",
      "Trained parameters: a = -0.036929797558695306 w = -0.07176141360974343 aw = 0.002650134477133627\n",
      "Initial parameters: a = -3.8081471507110947, w = 0.8254105299789551\n",
      "Trained parameters: a = -0.002964369319376872 w = -0.14234596890611614 aw = 0.00042196602296226487\n",
      "Initial parameters: a = -0.9558809301254038, w = 0.4818660617184915\n",
      "Trained parameters: a = -0.0454149859631878 w = -0.06118372377102094 aw = 0.0027786579562364753\n",
      "Initial parameters: a = -2.412027678506774, w = 0.3278795241593574\n",
      "Trained parameters: a = -0.03740063072430415 w = -0.07105026953282807 aw = 0.0026573248936595808\n",
      "Initial parameters: a = -3.1663120505659714, w = 0.17521141890851205\n",
      "Trained parameters: a = -0.02245281209991203 w = -0.0937358460811585 aw = 0.002104633339086527\n",
      "Initial parameters: a = -2.5071925947259004, w = 0.4826878872092127\n",
      "Trained parameters: a = -0.028214909600067735 w = -0.08514964597927036 aw = 0.0024024895637828844\n",
      "Initial parameters: a = -1.5521867174738104, w = 0.47363207681145447\n",
      "Trained parameters: a = -0.03886297734935582 w = -0.06970772297095351 aw = 0.002709049658895337\n",
      "Initial parameters: a = -1.8540993585476968, w = 0.2950899142379063\n",
      "Trained parameters: a = -0.03665347041527452 w = -0.07265688926503273 aw = 0.002663127141141754\n",
      "Initial parameters: a = -2.8493067782373522, w = 0.7095798547491726\n",
      "Trained parameters: a = -0.0256219991086059 w = -0.08604922729309424 aw = 0.002204753224999887\n",
      "Initial parameters: a = -2.794471491406351, w = 0.43295982536069616\n",
      "Trained parameters: a = -0.031551589426599996 w = -0.07826334114328758 aw = 0.002469332806906941\n",
      "0.0\n"
     ]
    }
   ],
   "source": [
    "# Standard Multi Dim Case\n",
    "\n",
    "import numpy as np\n",
    "\n",
    "# Define ReLU function\n",
    "def relu(x):\n",
    "    return np.maximum(0, x)\n",
    "\n",
    "# Define derivative of ReLU\n",
    "def relu_derivative(x):\n",
    "    return np.where(x > 0, 1, 0)\n",
    "\n",
    "# Generate some synthetic data\n",
    "\n",
    "success = 0\n",
    "for runs in range(10):\n",
    "    # Initialize parameters\n",
    "    w = np.random.randn(d)\n",
    "    w[0] = abs(w[0])\n",
    "    a = -np.sqrt(np.sum(w**2))\n",
    "    \n",
    "    learning_rate = 0.01\n",
    "    epochs = 20000\n",
    "    print(f\"Initial parameters: a = {a}, w = {w[0]}\")\n",
    "    # Gradient descent loop\n",
    "    for epoch in range(epochs):\n",
    "        # Forward pass\n",
    "        wx = np.dot(x, w)  # Dot product for weighted sum\n",
    "        relu_out = relu(wx)\n",
    "        y_pred = a * relu_out\n",
    "\n",
    "        # Compute loss (MSE)\n",
    "        loss = np.mean((y_pred - y_target) ** 2)\n",
    "\n",
    "        # Backward pass (compute gradients)\n",
    "        dL_dy = 2 * (y_pred - y_target) / num_samples  # Gradient of loss wrt y_pred\n",
    "        dL_da = np.sum(dL_dy * relu_out)  # Gradient wrt 'a'\n",
    "        dL_drelu = dL_dy * a  # Gradient wrt ReLU output\n",
    "        dL_dwx = dL_drelu * relu_derivative(wx)  # Gradient wrt wx\n",
    "        dL_dw = np.dot(x.T, dL_dwx)  # Gradient wrt weight vector w\n",
    "        # print(dL_dw.shape)\n",
    "        # Update parameters\n",
    "        a -= learning_rate * dL_da\n",
    "        w -= learning_rate * dL_dw\n",
    "\n",
    "    # Print final parameters\n",
    "    print(f\"Trained parameters: a = {a} w = {w[0]} aw = {a * w[0]}\")\n",
    "    success += np.allclose(a*w[0], 1, 0.1) and a>0 and w[0]>0\n",
    "print(success/100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 251,
   "id": "1ea91b5c-4a8a-44c2-8672-0018f5596cb7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial parameters: a = -1.5859833122379565, w1 = 1.585983312237958\n",
      "after training parameters: a = 0.9838393681962944, w1 = 1.0164260877599656, aw = 0.9999999999999958\n",
      "initial parameters: a = -1.8799243851390417, w1 = 1.879924385139045\n",
      "after training parameters: a = 0.9791138941916632, w1 = 1.0213316407133368, aw = 0.9999999999999958\n",
      "initial parameters: a = -1.8709651753717802, w1 = 1.870965175371782\n",
      "after training parameters: a = 0.9792285544652577, w1 = 1.0212120504860902, aw = 0.9999999999999958\n",
      "initial parameters: a = -0.3896141773709039, w1 = 0.3896141773709038\n",
      "after training parameters: a = 1.0659034388080268, w1 = 0.9381712860578353, aw = 0.9999999999999958\n",
      "initial parameters: a = -0.8682927318763664, w1 = 0.8682927318763661\n",
      "after training parameters: a = 1.0104196270337402, w1 = 0.9896878220147672, aw = 0.9999999999999957\n",
      "initial parameters: a = -0.5346290861224352, w1 = 0.5346290861224353\n",
      "after training parameters: a = 1.0421469399316092, w1 = 0.9595575841403139, aw = 0.9999999999999958\n",
      "initial parameters: a = -2.6357477390168826, w1 = 2.6357477390168773\n",
      "after training parameters: a = 0.9748157092628656, w1 = 1.0258349249994894, aw = 0.9999999999999958\n",
      "initial parameters: a = -0.0033755065971610458, w1 = 0.003375506597161018\n",
      "after training parameters: a = 1.1628058733547013, w1 = 0.8599887762133416, aw = 0.9999999999999954\n",
      "initial parameters: a = -0.327821172843085, w1 = 0.3278211728430852\n",
      "after training parameters: a = 1.0789794348412192, w1 = 0.9268017236557932, aw = 0.9999999999999956\n",
      "initial parameters: a = -0.9242701395378299, w1 = 0.9242701395378295\n",
      "after training parameters: a = 1.0069619101713603, w1 = 0.9930862229235864, aw = 0.9999999999999958\n",
      "initial parameters: a = -1.0138959522925384, w1 = 1.0138959522925375\n",
      "after training parameters: a = 1.0021351041523434, w1 = 0.9978694448048963, aw = 0.9999999999999958\n",
      "initial parameters: a = -0.08568716140335904, w1 = 0.08568716140335905\n",
      "after training parameters: a = 1.1483551880501122, w1 = 0.870810712927573, aw = 0.9999999999999952\n",
      "initial parameters: a = -0.9254246260595874, w1 = 0.9254246260595871\n",
      "after training parameters: a = 1.0068944505927968, w1 = 0.993152757383118, aw = 0.9999999999999959\n",
      "initial parameters: a = -0.2553837556743171, w1 = 0.255383755674317\n",
      "after training parameters: a = 1.0970457137164564, w1 = 0.911539042992384, aw = 0.9999999999999954\n",
      "initial parameters: a = -0.8953463223630231, w1 = 0.8953463223630241\n",
      "after training parameters: a = 1.0087016388967638, w1 = 0.9913734264313429, aw = 0.999999999999996\n",
      "initial parameters: a = -0.4081008391602206, w1 = 0.40810083916022066\n",
      "after training parameters: a = 1.0623714788783407, w1 = 0.9412903300602561, aw = 0.9999999999999958\n",
      "initial parameters: a = -0.9958153947902298, w1 = 0.9958153947902287\n",
      "after training parameters: a = 1.0030456774241738, w1 = 0.9969635705604163, aw = 0.999999999999996\n",
      "initial parameters: a = -0.6511362418236568, w1 = 0.6511362418236569\n",
      "after training parameters: a = 1.0283076623664802, w1 = 0.9724716022232694, aw = 0.9999999999999958\n",
      "initial parameters: a = -0.8584511166566654, w1 = 0.8584511166566653\n",
      "after training parameters: a = 1.0110676273222472, w1 = 0.9890535241924782, aw = 0.9999999999999957\n",
      "initial parameters: a = -0.2346205699574139, w1 = 0.23462056995741373\n",
      "after training parameters: a = 1.102794481188718, w1 = 0.9067872727492081, aw = 0.9999999999999954\n",
      "initial parameters: a = -0.038237994960028325, w1 = 0.03823799496002833\n",
      "after training parameters: a = 1.1595060929778092, w1 = 0.862436175244086, aw = 0.9999999999999952\n",
      "initial parameters: a = -1.4485914146335441, w1 = 1.4485914146335437\n",
      "after training parameters: a = 0.9868700144904855, w1 = 1.0133046757087754, aw = 0.9999999999999958\n",
      "initial parameters: a = -0.29967664800678706, w1 = 0.29967664800678695\n",
      "after training parameters: a = 1.085633205677012, w1 = 0.9211214199886096, aw = 0.9999999999999956\n",
      "initial parameters: a = -0.05020461704174471, w1 = 0.05020461704174479\n",
      "after training parameters: a = 1.157259783874936, w1 = 0.8641102144339826, aw = 0.9999999999999953\n",
      "initial parameters: a = -2.620793091029972, w1 = 2.6207930910299746\n",
      "after training parameters: a = 0.9747934694536327, w1 = 1.025858329314097, aw = 0.9999999999999959\n",
      "initial parameters: a = -1.111967025774164, w1 = 1.1119670257741634\n",
      "after training parameters: a = 0.9976752935411523, w1 = 1.0023301233115558, aw = 0.9999999999999958\n",
      "initial parameters: a = -1.4641772387524377, w1 = 1.464177238752437\n",
      "after training parameters: a = 0.9864941163332446, w1 = 1.0136907898822063, aw = 0.9999999999999958\n",
      "initial parameters: a = -0.9968587734658089, w1 = 0.9968587734658078\n",
      "after training parameters: a = 1.0029923134225365, w1 = 0.9970166138040182, aw = 0.9999999999999958\n",
      "initial parameters: a = -0.28063640449013627, w1 = 0.28063640449013627\n",
      "after training parameters: a = 1.0903965423855708, w1 = 0.9170975522466298, aw = 0.9999999999999956\n",
      "initial parameters: a = -1.7586204841951338, w1 = 1.7586204841951332\n",
      "after training parameters: a = 0.9808126183733197, w1 = 1.0195627393726832, aw = 0.9999999999999958\n",
      "initial parameters: a = -0.37210547260686283, w1 = 0.37210547260686283\n",
      "after training parameters: a = 1.0694044821695259, w1 = 0.9350998772431478, aw = 0.9999999999999957\n",
      "initial parameters: a = -0.3891591956679286, w1 = 0.38915919566792867\n",
      "after training parameters: a = 1.0659924678570063, w1 = 0.9380929323171701, aw = 0.9999999999999957\n",
      "initial parameters: a = -0.053120653017545295, w1 = 0.05312065301754536\n",
      "after training parameters: a = 1.1566427471148761, w1 = 0.8645711932179494, aw = 0.9999999999999953\n",
      "initial parameters: a = -1.2235688824186286, w1 = 1.2235688824186275\n",
      "after training parameters: a = 0.9934311464238056, w1 = 1.0066122887326787, aw = 0.9999999999999958\n",
      "initial parameters: a = -1.0964692338108843, w1 = 1.096469233810883\n",
      "after training parameters: a = 0.9983302774933888, w1 = 1.0016725151427837, aw = 0.999999999999996\n",
      "initial parameters: a = -0.6256772874962121, w1 = 0.6256772874962124\n",
      "after training parameters: a = 1.0310175699009012, w1 = 0.9699155758287544, aw = 0.9999999999999956\n",
      "initial parameters: a = -1.319247194598766, w1 = 1.3192471945987674\n",
      "after training parameters: a = 0.9903584761052755, w1 = 1.0097353878694884, aw = 0.9999999999999958\n",
      "initial parameters: a = -0.20298063739565717, w1 = 0.20298063739565705\n",
      "after training parameters: a = 1.1120202517336197, w1 = 0.8992641981483821, aw = 0.9999999999999956\n",
      "initial parameters: a = -0.800038564397646, w1 = 0.8000385643976463\n",
      "after training parameters: a = 1.0151887936574029, w1 = 0.9850384541749256, aw = 0.9999999999999958\n",
      "initial parameters: a = -0.06352457461535514, w1 = 0.06352457461535507\n",
      "after training parameters: a = 1.1542488447028472, w1 = 0.8663643066131359, aw = 0.9999999999999954\n",
      "initial parameters: a = -1.2374381346841394, w1 = 1.237438134684139\n",
      "after training parameters: a = 0.9929561196685116, w1 = 1.0070938485517726, aw = 0.9999999999999959\n",
      "initial parameters: a = -0.45730165508679, w1 = 0.45730165508678994\n",
      "after training parameters: a = 1.0537383083609808, w1 = 0.9490022257570084, aw = 0.9999999999999958\n",
      "initial parameters: a = -0.042823381311574885, w1 = 0.04282338131157487\n",
      "after training parameters: a = 1.1587026511655183, w1 = 0.8630341865483031, aw = 0.9999999999999952\n",
      "initial parameters: a = -0.058022734808395336, w1 = 0.058022734808395225\n",
      "after training parameters: a = 1.155550455525348, w1 = 0.8653884347658063, aw = 0.9999999999999952\n",
      "initial parameters: a = -0.8484308822052845, w1 = 0.8484308822052845\n",
      "after training parameters: a = 1.0117405354354507, w1 = 0.9883957051988613, aw = 0.9999999999999959\n",
      "initial parameters: a = -2.246889333984613, w1 = 2.2468893339846043\n",
      "after training parameters: a = 0.9757235889190345, w1 = 1.0248804183445603, aw = 0.9999999999999959\n",
      "initial parameters: a = -0.6067002947652965, w1 = 0.6067002947652966\n",
      "after training parameters: a = 1.0331437835909547, w1 = 0.9679194860218203, aw = 0.9999999999999956\n",
      "initial parameters: a = -0.2112836922794728, w1 = 0.21128369227947275\n",
      "after training parameters: a = 1.1095476360460998, w1 = 0.9012681993208692, aw = 0.9999999999999956\n",
      "initial parameters: a = -1.2000789564268606, w1 = 1.2000789564268615\n",
      "after training parameters: a = 0.9942604922366505, w1 = 1.0057726398747213, aw = 0.9999999999999958\n",
      "initial parameters: a = -0.4919024475062051, w1 = 0.4919024475062051\n",
      "after training parameters: a = 1.0482760781844638, w1 = 0.9539471717526181, aw = 0.9999999999999956\n",
      "initial parameters: a = -1.8765527060418712, w1 = 1.8765527060418736\n",
      "after training parameters: a = 0.9791568507522961, w1 = 1.021286833903767, aw = 0.9999999999999958\n",
      "initial parameters: a = -0.6197114459661358, w1 = 0.6197114459661363\n",
      "after training parameters: a = 1.03167590914904, w1 = 0.9692966474566888, aw = 0.9999999999999959\n",
      "initial parameters: a = -0.635362388825629, w1 = 0.6353623888256291\n",
      "after training parameters: a = 1.0299679511151023, w1 = 0.9709039964955594, aw = 0.9999999999999957\n",
      "initial parameters: a = -1.189666659090361, w1 = 1.1896666590903608\n",
      "after training parameters: a = 0.9946384267962229, w1 = 1.0053904746280946, aw = 0.9999999999999958\n",
      "initial parameters: a = -0.624345389713224, w1 = 0.6243453897132241\n",
      "after training parameters: a = 1.0311637587624862, w1 = 0.9697780701681268, aw = 0.9999999999999958\n",
      "initial parameters: a = -0.18452535765584954, w1 = 0.18452535765584954\n",
      "after training parameters: a = 1.1176339269096676, w1 = 0.8947473550351699, aw = 0.9999999999999956\n",
      "initial parameters: a = -0.6047446645382125, w1 = 0.6047446645382129\n",
      "after training parameters: a = 1.033368292179359, w1 = 0.9677091967772787, aw = 0.9999999999999959\n",
      "initial parameters: a = -2.2055660570990714, w1 = 2.2055660570990683\n",
      "after training parameters: a = 0.9759846276038107, w1 = 1.0246063018995972, aw = 0.9999999999999959\n",
      "initial parameters: a = -0.8970661968871321, w1 = 0.8970661968871323\n",
      "after training parameters: a = 1.0085954561696522, w1 = 0.991477796060772, aw = 0.9999999999999958\n",
      "initial parameters: a = -1.2748750412787229, w1 = 1.2748750412787222\n",
      "after training parameters: a = 0.9917255040452079, w1 = 1.008343534497234, aw = 0.9999999999999959\n",
      "initial parameters: a = -0.6515219913395056, w1 = 0.6515219913395057\n",
      "after training parameters: a = 1.028267804625564, w1 = 0.972509297190471, aw = 0.9999999999999957\n",
      "initial parameters: a = -1.137685670424816, w1 = 1.1376856704248164\n",
      "after training parameters: a = 0.9966258661050051, w1 = 1.0033855572183545, aw = 0.9999999999999958\n",
      "initial parameters: a = -0.20149153394751806, w1 = 0.20149153394751793\n",
      "after training parameters: a = 1.1124673447099123, w1 = 0.8989027900506653, aw = 0.9999999999999954\n",
      "initial parameters: a = -0.006521315229457963, w1 = 0.006521315229458077\n",
      "after training parameters: a = 1.1627324538418327, w1 = 0.8600430792964056, aw = 0.9999999999999954\n",
      "initial parameters: a = -0.5987943895619102, w1 = 0.5987943895619101\n",
      "after training parameters: a = 1.0340577571257887, w1 = 0.9670639701785535, aw = 0.9999999999999958\n",
      "initial parameters: a = -0.668340488718081, w1 = 0.6683404887180808\n",
      "after training parameters: a = 1.026563500479336, w1 = 0.9741238603681731, aw = 0.9999999999999957\n",
      "initial parameters: a = -0.7341737987784956, w1 = 0.7341737987784956\n",
      "after training parameters: a = 1.0204741175715049, w1 = 0.9799366615782155, aw = 0.9999999999999959\n",
      "initial parameters: a = -0.08199555641356042, w1 = 0.08199555641356042\n",
      "after training parameters: a = 1.1493969534593846, w1 = 0.8700214464552534, aw = 0.9999999999999954\n",
      "initial parameters: a = -0.45728040461524083, w1 = 0.45728040461524105\n",
      "after training parameters: a = 1.0537418105972334, w1 = 0.9489990716352251, aw = 0.9999999999999958\n",
      "initial parameters: a = -1.4558223221467657, w1 = 1.4558223221467663\n",
      "after training parameters: a = 0.9866945238336498, w1 = 1.0134848991708698, aw = 0.9999999999999959\n",
      "initial parameters: a = -0.7045065398247229, w1 = 0.704506539824723\n",
      "after training parameters: a = 1.023109257235807, w1 = 0.977412718072509, aw = 0.9999999999999957\n",
      "initial parameters: a = -0.7890566873755187, w1 = 0.7890566873755187\n",
      "after training parameters: a = 1.016020043234899, w1 = 0.9842325519643323, aw = 0.9999999999999958\n",
      "initial parameters: a = -0.08382662792936085, w1 = 0.08382662792936091\n",
      "after training parameters: a = 1.1488827453328125, w1 = 0.8704108439806987, aw = 0.9999999999999956\n",
      "initial parameters: a = -1.4104591452035014, w1 = 1.4104591452035036\n",
      "after training parameters: a = 0.9878278318208518, w1 = 1.0123221555285675, aw = 0.9999999999999959\n",
      "initial parameters: a = -0.4097627959594973, w1 = 0.40976279595949733\n",
      "after training parameters: a = 1.062061985702589, w1 = 0.9415646294302329, aw = 0.9999999999999956\n",
      "initial parameters: a = -0.8610879101735701, w1 = 0.8610879101735703\n",
      "after training parameters: a = 1.010892772208126, w1 = 0.989224601750454, aw = 0.9999999999999959\n",
      "initial parameters: a = -1.4033699701251912, w1 = 1.4033699701251905\n",
      "after training parameters: a = 0.9880120834738162, w1 = 1.012133370357203, aw = 0.9999999999999958\n",
      "initial parameters: a = -0.6979032725390273, w1 = 0.6979032725390276\n",
      "after training parameters: a = 1.0237194216851075, w1 = 0.9768301536703601, aw = 0.9999999999999958\n",
      "initial parameters: a = -0.44304402112848223, w1 = 0.4430440211284821\n",
      "after training parameters: a = 1.0561306736756069, w1 = 0.9468525296398579, aw = 0.9999999999999957\n",
      "initial parameters: a = -0.4794929673992433, w1 = 0.4794929673992433\n",
      "after training parameters: a = 1.0501810168170786, w1 = 0.9522167930923251, aw = 0.9999999999999957\n",
      "initial parameters: a = -0.2965755451407618, w1 = 0.2965755451407617\n",
      "after training parameters: a = 1.0863944471319367, w1 = 0.9204759860840406, aw = 0.9999999999999957\n",
      "initial parameters: a = -0.46318479526758455, w1 = 0.46318479526758455\n",
      "after training parameters: a = 1.0527758780581316, w1 = 0.9498697879025475, aw = 0.9999999999999957\n",
      "initial parameters: a = -0.1972922656312063, w1 = 0.1972922656312064\n",
      "after training parameters: a = 1.1137339082916002, w1 = 0.8978805373124845, aw = 0.9999999999999953\n",
      "initial parameters: a = -0.31130867344288476, w1 = 0.3113086734428848\n",
      "after training parameters: a = 1.0828278734639594, w1 = 0.9235078118196219, aw = 0.9999999999999956\n",
      "initial parameters: a = -1.6999573745763803, w1 = 1.6999573745763805\n",
      "after training parameters: a = 0.9817548183538427, w1 = 1.018584254749822, aw = 0.9999999999999958\n",
      "initial parameters: a = -1.0715431522348844, w1 = 1.0715431522348855\n",
      "after training parameters: a = 0.9994212008769311, w1 = 1.0005791343255044, aw = 0.9999999999999957\n",
      "initial parameters: a = -0.19063559126502427, w1 = 0.19063559126502433\n",
      "after training parameters: a = 1.1157584669782517, w1 = 0.8962513210482206, aw = 0.9999999999999953\n",
      "initial parameters: a = -0.9413105807674832, w1 = 0.9413105807674832\n",
      "after training parameters: a = 1.0059810491556747, w1 = 0.9940545111056528, aw = 0.9999999999999959\n",
      "initial parameters: a = -1.03252390352754, w1 = 1.0325239035275395\n",
      "after training parameters: a = 1.001227526481256, w1 = 0.9987739784926067, aw = 0.9999999999999958\n",
      "initial parameters: a = -0.39792704994680883, w1 = 0.39792704994680894\n",
      "after training parameters: a = 1.0642947413051487, w1 = 0.9395893460618736, aw = 0.9999999999999957\n",
      "initial parameters: a = -1.8093063497331077, w1 = 1.8093063497331099\n",
      "after training parameters: a = 0.9800635737866225, w1 = 1.0203419724460792, aw = 0.9999999999999959\n",
      "initial parameters: a = -0.21804589539237398, w1 = 0.21804589539237382\n",
      "after training parameters: a = 1.1075602540052887, w1 = 0.9028854153836586, aw = 0.9999999999999957\n",
      "initial parameters: a = -0.8476339286190844, w1 = 0.8476339286190848\n",
      "after training parameters: a = 1.0117946346985938, w1 = 0.9883428570441951, aw = 0.9999999999999957\n",
      "initial parameters: a = -0.6520888885930609, w1 = 0.6520888885930605\n",
      "after training parameters: a = 1.0282092931801539, w1 = 0.9725646389628425, aw = 0.9999999999999958\n",
      "initial parameters: a = -1.089633037342387, w1 = 1.089633037342388\n",
      "after training parameters: a = 0.9986247963726391, w1 = 1.0013770974167193, aw = 0.9999999999999957\n",
      "initial parameters: a = -0.7847619081277033, w1 = 0.7847619081277034\n",
      "after training parameters: a = 1.0163503178924205, w1 = 0.9839127143421079, aw = 0.9999999999999956\n",
      "initial parameters: a = -0.3705080985900288, w1 = 0.37050809859002887\n",
      "after training parameters: a = 1.0697316730177286, w1 = 0.9348138652181636, aw = 0.9999999999999957\n",
      "initial parameters: a = -1.4055670191786427, w1 = 1.405567019178642\n",
      "after training parameters: a = 0.9879547683388561, w1 = 1.0121920881877948, aw = 0.9999999999999957\n",
      "initial parameters: a = -0.015618333949602986, w1 = 0.015618333949603049\n",
      "after training parameters: a = 1.1622592199811805, w1 = 0.8603932606498811, aw = 0.9999999999999952\n",
      "initial parameters: a = -0.9022771737866473, w1 = 0.9022771737866471\n",
      "after training parameters: a = 1.0082758881242504, w1 = 0.9917920400341511, aw = 0.9999999999999958\n",
      "Total success rate: 1.00\n"
     ]
    }
   ],
   "source": [
    "# MW single dim case\n",
    "# Define ReLU function\n",
    "def relu(x):\n",
    "    return np.maximum(0, x)\n",
    "\n",
    "# Define derivative of ReLU\n",
    "def relu_derivative(x):\n",
    "    return np.where(x > 0, 1, 0)\n",
    "\n",
    "alpha1 = 0.5\n",
    "alpha2 = 0.1\n",
    "# Initialize parameters\n",
    "def initialize_params(w, alpha=0.5):\n",
    "    u = np.sqrt(w + np.sqrt(w*w + alpha*alpha))\n",
    "    w1 =  (u + alpha/u)/np.sqrt(2) \n",
    "    w2 = (u - alpha/u)/np.sqrt(2)\n",
    "    return w1, w2\n",
    "\n",
    "def rescale_mw(w1, w2, alpha=0.5):\n",
    "    x = w1 * w2\n",
    "    u = np.sqrt(alpha + np.sqrt(x*x + alpha*alpha))\n",
    "    w1 = u\n",
    "    w2 = x/u\n",
    "    return w1, w2\n",
    "\n",
    "success = 0\n",
    "for runs in range(100):\n",
    "    a = -abs(np.random.randn())  # Scale factor vector 1\n",
    "    w = abs(np.sqrt(a**2))\n",
    "    a1, a2 = initialize_params(a, alpha1)\n",
    "    w1, w2 = initialize_params(w, alpha2)\n",
    "    learning_rate = 0.01\n",
    "    epochs = 20000\n",
    "    a = a1 * a2\n",
    "    # Gradient descent loop\n",
    "    print(f\"initial parameters: a = {a1*a2}, w1 = {w1 * w2}\")\n",
    "    \n",
    "    for epoch in range(epochs):\n",
    "        # Compute effective weights and scale factor\n",
    "        a = a1 * a2  # Elementwise product for effective scale factor\n",
    "        w = w1 * w2  # Elementwise product for effective weights\n",
    "        # Forward pass\n",
    "        wx = x[:, 0] * w  # Weighted sum\n",
    "        relu_out = relu(wx)\n",
    "        y_pred = a * relu_out  # Prediction: a scales the ReLU output\n",
    "\n",
    "        # Compute loss (MSE)\n",
    "        loss = np.mean((y_pred - y_target) ** 2)\n",
    "\n",
    "        # Backward pass (compute gradients)\n",
    "        dL_dy = 2 * (y_pred - y_target) / num_samples  # Gradient of loss wrt y_pred\n",
    "        \n",
    "\n",
    "        # Gradients wrt a1 and a2\n",
    "        dL_da = np.sum(dL_dy * relu_out)  # Gradient wrt effective scale factor a\n",
    "        dL_da1 = dL_da * a2  # Chain rule: gradient wrt a1\n",
    "        dL_da2 = dL_da * a1  # Chain rule: gradient wrt a2\n",
    "        # print(dL_dy.shape)\n",
    "        # Gradients wrt w1 and w2\n",
    "        # dL_drelu = np.outer(dL_dy, a)  # Gradient wrt ReLU output\n",
    "        dL_drelu = dL_dy * a  # Gradient wrt ReLU output\n",
    "        dL_dwx = dL_drelu * relu_derivative(wx)  # Gradient wrt wx\n",
    "        dL_dw = np.sum(x[:, 0] * dL_dwx)  # Gradient wrt effective weights w\n",
    "        dL_dw1 = dL_dw * w2  # Chain rule: gradient wrt w1\n",
    "        dL_dw2 = dL_dw * w1  # Chain rule: gradient wrt w2\n",
    "\n",
    "        # Update parameters\n",
    "        a1 -= learning_rate * dL_da1\n",
    "        a2 -= learning_rate * dL_da2\n",
    "        w1 -= learning_rate * dL_dw1\n",
    "        w2 -= learning_rate * dL_dw2\n",
    "\n",
    "        if epoch % 5 == 4:\n",
    "            a1, a2 = rescale_mw(a1, a2, alpha1)\n",
    "            w1, w2 = rescale_mw(w1, w2, alpha2)\n",
    "    print(f\"after training parameters: a = {a1*a2}, w1 = {w1 * w2}, aw = {a1*a2*w1*w2}\")\n",
    "    \n",
    "    success += np.allclose(a1*a2*w1*w2, 1, 0.1) and a1*a2 > 0 and w1*w2 > 0\n",
    "\n",
    "print(f'Total success rate: {success/100:.2f}')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 230,
   "id": "6834e188-a0ae-4e7c-b752-dde7945b1499",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Initial parameters: a = -2.7884629944264945, w = 0.42375968202270325\n",
      "Trained parameters: a = -0.14668308541967012 w = -0.14640960599417846 aw = 0.021475812742304326\n",
      "Initial parameters: a = -3.492874832619915, w = 1.598321807641033\n",
      "Trained parameters: a = -0.137660961192503 w = -0.13696839313836348 aw = 0.018855200652419753\n",
      "Initial parameters: a = -3.572625993870256, w = 0.05790774987690872\n",
      "Trained parameters: a = -0.1505421836972511 w = -0.1509703945750458 aw = 0.022727412872963024\n",
      "Initial parameters: a = -4.266257488490742, w = 1.2361357960304624\n",
      "Trained parameters: a = -0.1401763755534438 w = -0.14247034232907474 aw = 0.019970976211548083\n",
      "Initial parameters: a = -3.351549934781145, w = 0.4990958161377494\n",
      "Trained parameters: a = -0.150262029450315 w = -0.1503850706684809 aw = 0.022597165917674977\n",
      "Initial parameters: a = -2.070150058201771, w = 0.7290636450023644\n",
      "Trained parameters: a = -0.1444579623458297 w = -0.1428449583786161 aw = 0.020635091618749737\n",
      "Initial parameters: a = -2.5227651004583573, w = 0.30518884548075176\n",
      "Trained parameters: a = -0.14652205450562134 w = -0.14483130118875273 aw = 0.021220979806898486\n",
      "Initial parameters: a = -2.7664546267877967, w = 1.1789234912983253\n",
      "Trained parameters: a = -0.13623486533961318 w = -0.13533901088604652 aw = 0.01843789192325699\n",
      "Initial parameters: a = -3.0407932343240915, w = 0.9935895155940362\n",
      "Trained parameters: a = -0.14416479027478024 w = -0.14277071339274205 aw = 0.02058250995364542\n",
      "Initial parameters: a = -3.380730837669785, w = 1.8207602778020162\n",
      "Trained parameters: a = -0.14491259334859938 w = -0.1425204053320219 aw = 0.020653001541756845\n",
      "0.0\n"
     ]
    }
   ],
   "source": [
    "# Standard Multi Dim Case for same scaling, a<0 should not work\n",
    "\n",
    "import numpy as np\n",
    "\n",
    "# Define ReLU function\n",
    "def relu(x):\n",
    "    return np.maximum(0, x)\n",
    "\n",
    "# Define derivative of ReLU\n",
    "def relu_derivative(x):\n",
    "    return np.where(x > 0, 1, 0)\n",
    "\n",
    "# Generate some synthetic data\n",
    "d=10\n",
    "np.random.seed(42)\n",
    "num_samples=500\n",
    "x = np.random.randn(num_samples, d)  # Input data (100 samples, 1 feature)\n",
    "y_target = relu(x[:, 0])\n",
    "\n",
    "success = 0\n",
    "for runs in range(10):\n",
    "    # Initialize parameters\n",
    "    w = np.random.randn(d)\n",
    "    w[0] = abs(w[0])\n",
    "    a = -np.sqrt(np.sum(w**2))\n",
    "    \n",
    "    learning_rate = 0.001\n",
    "    epochs = 20000\n",
    "    print(f\"Initial parameters: a = {a}, w = {w[0]}\")\n",
    "    # Gradient descent loop\n",
    "    for epoch in range(epochs):\n",
    "        # Forward pass\n",
    "        wx = np.dot(x, w)  # Dot product for weighted sum\n",
    "        relu_out = relu(wx)\n",
    "        y_pred = a * relu_out\n",
    "\n",
    "        # Compute loss (MSE)\n",
    "        loss = np.mean((y_pred - y_target) ** 2)\n",
    "\n",
    "        # Backward pass (compute gradients)\n",
    "        dL_dy = 2 * (y_pred - y_target) / num_samples  # Gradient of loss wrt y_pred\n",
    "        dL_da = np.sum(dL_dy * relu_out)  # Gradient wrt 'a'\n",
    "        dL_drelu = dL_dy * a  # Gradient wrt ReLU output\n",
    "        dL_dwx = dL_drelu * relu_derivative(wx)  # Gradient wrt wx\n",
    "        dL_dw = np.dot(x.T, dL_dwx)  # Gradient wrt weight vector w\n",
    "        # print(dL_dw.shape)\n",
    "        # Update parameters\n",
    "        a -= learning_rate * dL_da\n",
    "        w -= learning_rate * dL_dw\n",
    "\n",
    "    # Print final parameters\n",
    "    print(f\"Trained parameters: a = {a} w = {w[0]} aw = {a * w[0]}\")\n",
    "    success += np.allclose(a*w[0], 1, 0.1) and a>0 and w[0]>0\n",
    "print(success/100)\n",
    "# a>0, w0 1 lr=1e-3\n",
    "# w<0, a>0 0.6 lr=1e-2\n",
    "# w>0 a<0 0 lr=1e-3\n",
    "# w<0 a<0 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 438,
   "id": "af205bef-78e0-4b19-ae32-e60c9cb14aa3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Initial parameters: a = 0.5, w = 0.5\n",
      "Trained parameters: a = 0.9999999999999946 w = 0.9999999999999946\n",
      "Initial parameters: a = -0.9261775475316414, w = 0.9261775475316414\n",
      "Trained parameters: a = -9.943844286531267e-10 w = -3.4087648393229535e-13\n",
      "Initial parameters: a = -1.9094166404701305, w = -1.9094166404701305\n",
      "Trained parameters: a = -0.07397627003724279 w = -0.07397627003724284\n",
      "Initial parameters: a = 1.3985675738191412, w = -1.3985675738191412\n",
      "Trained parameters: a = 0.07392921838544066 w = -0.07392921838544066\n",
      "1\n"
     ]
    }
   ],
   "source": [
    "# PLOTTING\n",
    "d=1\n",
    "np.random.seed(42)\n",
    "num_samples=500\n",
    "x = np.random.randn(num_samples, d)  # Input data (100 samples, 1 feature)\n",
    "y_target = relu(x[:, 0])\n",
    "# Standard Single Dim Case\n",
    "\n",
    "import numpy as np\n",
    "\n",
    "# Define ReLU function\n",
    "def relu(x):\n",
    "    return np.maximum(0, x)\n",
    "\n",
    "# Define derivative of ReLU\n",
    "def relu_derivative(x):\n",
    "    return np.where(x > 0, 1, 0)\n",
    "\n",
    "def initialize_aw(case):\n",
    "    if case == 0:\n",
    "        w = 0.5\n",
    "        a = abs(np.sqrt(np.sum(w**2)))\n",
    "    if case == 1:\n",
    "        w = abs(np.random.randn())\n",
    "        a = -abs(np.sqrt(np.sum(w**2)))\n",
    "    if case == 2:\n",
    "        w = -abs(np.random.randn())\n",
    "        a = -abs(np.sqrt(np.sum(w**2)))\n",
    "    if case == 3:\n",
    "        w = -abs(np.random.randn())\n",
    "        a = abs(np.sqrt(np.sum(w**2)))\n",
    "    return a, w\n",
    "success = 0\n",
    "\n",
    "result_dict_standard = {}\n",
    "for case in range(4):\n",
    "    # Initialize parameters\n",
    "    a, w = initialize_aw(case)\n",
    "    learning_rate = 0.005\n",
    "    epochs = 20000\n",
    "    print(f\"Initial parameters: a = {a}, w = {w}\")\n",
    "    # Gradient descent loop\n",
    "    a_vals = []\n",
    "    w_vals = []\n",
    "    \n",
    "    for epoch in range(epochs):\n",
    "        # Forward pass\n",
    "        wx = w * x[:, 0]  # Dot product for weighted sum\n",
    "        relu_out = relu(wx)\n",
    "        y_pred = a * relu_out\n",
    "\n",
    "        # Compute loss (MSE)\n",
    "        loss = np.mean((y_pred - y_target) ** 2)\n",
    "\n",
    "        # Backward pass (compute gradients)\n",
    "        dL_dy = 2 * (y_pred - y_target) / num_samples  # Gradient of loss wrt y_pred\n",
    "        dL_da = np.sum(dL_dy * relu_out)  # Gradient wrt 'a'\n",
    "        dL_drelu = dL_dy * a  # Gradient wrt ReLU output\n",
    "        dL_dwx = dL_drelu * relu_derivative(wx)  # Gradient wrt wx\n",
    "        dL_dw = np.sum(x[:, 0] * dL_dwx)  # Gradient wrt weight vector w\n",
    "        # print(dL_dw.shape)\n",
    "        # Update parameters\n",
    "        a -= learning_rate * dL_da\n",
    "        w -= learning_rate * dL_dw\n",
    "        a_vals.append(a)\n",
    "        w_vals.append(w)\n",
    "    result_dict_standard[case] = [a_vals, w_vals]\n",
    "    # Print final parameters\n",
    "    print(f\"Trained parameters: a = {a} w = {w}\")\n",
    "    success += np.allclose(a*w, 1) and a>0 and w>0\n",
    "print(success)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 439,
   "id": "cd86062e-2da6-445f-a62d-28f65a1bc11a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial parameters: a = 0.29999999999999993, w1 = 0.3\n",
      "after training parameters: a = 1.0847288100020296, w1 = 0.9218894075452093, aw = 0.999999999999991\n",
      "initial parameters: a = -0.9261775475316402, w1 = 0.9261775475316413\n",
      "after training parameters: a = 1.0055078681782892, w1 = 0.9945223022587815, aw = 0.9999999999999916\n",
      "initial parameters: a = -1.9094166404701312, w1 = -1.9094166404702284\n",
      "after training parameters: a = -2.3616108019103544e-08, w1 = -0.4250282772902541, aw = 1.0037513707660135e-08\n",
      "initial parameters: a = 1.398567573819141, w1 = -1.3985675738191319\n",
      "after training parameters: a = 1.1366248445574106e-07, w1 = -0.4039175241797289, aw = -4.591026931347985e-08\n",
      "Total success rate: 0.02\n"
     ]
    }
   ],
   "source": [
    "# MW single dim case\n",
    "# Define ReLU function\n",
    "def relu(x):\n",
    "    return np.maximum(0, x)\n",
    "\n",
    "# Define derivative of ReLU\n",
    "def relu_derivative(x):\n",
    "    return np.where(x > 0, 1, 0)\n",
    "\n",
    "d=1\n",
    "np.random.seed(42)\n",
    "num_samples=500\n",
    "x = np.random.randn(num_samples, d)  # Input data (100 samples, 1 feature)\n",
    "y_target = relu(x[:, 0])\n",
    "\n",
    "alpha1 = 0.5\n",
    "alpha2 = 0.1\n",
    "\n",
    "def initialize_aw(case):\n",
    "    if case == 0:\n",
    "        w = 0.3\n",
    "        a = abs(np.sqrt(np.sum(w**2)))\n",
    "    if case == 1:\n",
    "        w = abs(np.random.randn())\n",
    "        a = -abs(np.sqrt(np.sum(w**2)))\n",
    "    if case == 2:\n",
    "        w = -abs(np.random.randn())\n",
    "        a = -abs(np.sqrt(np.sum(w**2)))\n",
    "    if case == 3:\n",
    "        w = -abs(np.random.randn())\n",
    "        a = abs(np.sqrt(np.sum(w**2)))\n",
    "    return a, w\n",
    "\n",
    "# Initialize parameters\n",
    "def initialize_params(w, alpha=0.5):\n",
    "    u = np.sqrt(w + np.sqrt(w*w + alpha*alpha))\n",
    "    w1 =  (u + alpha/u)/np.sqrt(2) \n",
    "    w2 = (u - alpha/u)/np.sqrt(2)\n",
    "    return w1, w2\n",
    "\n",
    "def rescale_mw(w1, w2, alpha=0.5):\n",
    "    x = w1 * w2\n",
    "    u = np.sqrt(alpha + np.sqrt(x*x + alpha*alpha))\n",
    "    w1 = u\n",
    "    w2 = x/u\n",
    "    return w1, w2\n",
    "\n",
    "result_dict_mw = {}\n",
    "success = 0\n",
    "for case in range(4):\n",
    "    a, w = initialize_aw(case)\n",
    "    a1, a2 = initialize_params(a, alpha1)\n",
    "    w1, w2 = initialize_params(w, alpha2)\n",
    "    learning_rate = 0.005\n",
    "    epochs = 20000\n",
    "    a = a1 * a2\n",
    "    # Gradient descent loop\n",
    "    print(f\"initial parameters: a = {a1*a2}, w1 = {w1 * w2}\")\n",
    "    a_vals = []\n",
    "    w_vals = []\n",
    "    for epoch in range(epochs):\n",
    "        # Compute effective weights and scale factor\n",
    "        a = a1 * a2  # Elementwise product for effective scale factor\n",
    "        w = w1 * w2  # Elementwise product for effective weights\n",
    "        # Forward pass\n",
    "        wx = x[:, 0] * w  # Weighted sum\n",
    "        relu_out = relu(wx)\n",
    "        y_pred = a * relu_out  # Prediction: a scales the ReLU output\n",
    "\n",
    "        # Compute loss (MSE)\n",
    "        loss = np.mean((y_pred - y_target) ** 2)\n",
    "\n",
    "        # Backward pass (compute gradients)\n",
    "        dL_dy = 2 * (y_pred - y_target) / num_samples  # Gradient of loss wrt y_pred\n",
    "        \n",
    "\n",
    "        # Gradients wrt a1 and a2\n",
    "        dL_da = np.sum(dL_dy * relu_out)  # Gradient wrt effective scale factor a\n",
    "        dL_da1 = dL_da * a2  # Chain rule: gradient wrt a1\n",
    "        dL_da2 = dL_da * a1  # Chain rule: gradient wrt a2\n",
    "        # print(dL_dy.shape)\n",
    "        # Gradients wrt w1 and w2\n",
    "        # dL_drelu = np.outer(dL_dy, a)  # Gradient wrt ReLU output\n",
    "        dL_drelu = dL_dy * a  # Gradient wrt ReLU output\n",
    "        dL_dwx = dL_drelu * relu_derivative(wx)  # Gradient wrt wx\n",
    "        dL_dw = np.sum(x[:, 0] * dL_dwx)  # Gradient wrt effective weights w\n",
    "        dL_dw1 = dL_dw * w2  # Chain rule: gradient wrt w1\n",
    "        dL_dw2 = dL_dw * w1  # Chain rule: gradient wrt w2\n",
    "\n",
    "        # Update parameters\n",
    "        a1 -= learning_rate * dL_da1\n",
    "        a2 -= learning_rate * dL_da2\n",
    "        w1 -= learning_rate * dL_dw1\n",
    "        w2 -= learning_rate * dL_dw2\n",
    "\n",
    "        if epoch % 5 == 4:\n",
    "            a1, a2 = rescale_mw(a1, a2, alpha1)\n",
    "            w1, w2 = rescale_mw(w1, w2, alpha2)\n",
    "        \n",
    "        a_vals.append(a1*a2)\n",
    "        w_vals.append(w1*w2)\n",
    "    result_dict_mw[case] = [a_vals, w_vals]\n",
    "    \n",
    "    print(f\"after training parameters: a = {a1*a2}, w1 = {w1 * w2}, aw = {a1*a2*w1*w2}\")\n",
    "    \n",
    "    success += np.allclose(a1*a2*w1*w2, 1, 0.1) and a1*a2 > 0 and w1*w2 > 0\n",
    "\n",
    "print(f'Total success rate: {success/100:.2f}')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 440,
   "id": "252ed7d2-9eae-498b-9fd8-25ea7379dc4b",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.rcParams[\"font.family\"] = \"serif\"\n",
    "plt.rcParams[\"font.serif\"] = [\"Times New Roman\"]\n",
    "plt.rcParams.update({'font.size': 12})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 474,
   "id": "ab611420-1de5-448c-8f31-b5fb8f25855b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAGICAYAAAC9XMGTAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8o6BhiAAAACXBIWXMAAA9hAAAPYQGoP6dpAACO0klEQVR4nOzdd3xN9xvA8c+9N3vLFCQ2iYaQEEERmxbV6jBbpVNRtNWqLl2q0+r8oVVKh7Zo7b0JktibECOSyN65957fH4eQikhIcpOb5/163Zecc7/n3Ockce+T53yHRlEUBSGEEEIIM6E1dQBCCCGEEKVJkhshhBBCmBVJboQQQghhViS5EUIIIYRZkeRGCCGEEGZFkhshhBBCmBVJboQQQghhViS5EUIIIYRZkeRGCCGEEGbFLJOb2NhY+vfvj7OzMw0aNODbb78tsv25c+d44oknGDduHEOGDCE2NracIhVCCCFEaTPL5Gb48OE0bdqUb775hjp16jBy5Ejmz59faNvMzEy6dOnCiBEj+Oqrr3jkkUfo06cPBoOhnKMWQgghRGnQmNvaUocPH+bo0aM8+uijAOj1egICAvD09GTLli23tP/ss8+YPn06Fy5cAMBgMODs7My3337L0KFDyzV2IYQQQtw7s6vcuLq60r9///xtCwsLevXqRWJiYqHtFy9eTFBQUP62TqcjMDCQ3377rcxjFUIIIUTpM7vkxtvbG41GU2CfXq8nNDT0lrYGg4F9+/bh5uZWYL+npyeRkZFlGqcQQgghyoaFqQMoDxs3buT333+/ZX9iYiIGgwFXV9cC+x0dHUlISLjt+XJycsjJycnfNhqNJCYm4ubmdktiJYQQQojbUxSFtLQ0atSogVZbOjUXs09u/v77b7p27UqTJk1uee56ImJra1tgv8FgwNLS8rbnnDJlCpMnTy7dQIUQQogqLCYmhlq1apXKucw6uUlKSmLBggUsWrSo0Ofd3NywsrIiJSWlwP709HQ8PDxue96JEycyfvz4/O2UlBR8fX2JiYnBycmpdIIXQpSqJ554wrz70ilGmNcM0mLU7acOg1PpfFAIUZZSU1Px8fHB0dGx1M5ptsmNwWBgwoQJzJgxAysrq0LbaDQamjZtSlxcXIH9sbGxhISE3Pbc1tbWWFtb37LfyclJkhshKihLS0vz///Z6hnY8a76dcyf0OZt08YjRAmUZrcOs+tQfN3EiRMZOXIkNWvWzN/33yQGYMiQIezatSt/W6/XFxhKLoQQlcZ9w4BrHxCH5qrVHCGqILNMbiZNmoTRaOTKlSusWrWKf//9lwkTJrB3715+/vlnOnTokN8heMSIESiKQkREBAB//fUXTZo0KTCcXAghKgUnX6jTXf06NRrOrTdpOEKYitndlvr888/5+OOPAfjiiy/y91erVo2PPvqImTNnEh0djV6vx9raGkdHR1avXs0777xDnTp1uHr1KsuXLy+1HttCCFGumj4D0avVr/d/C3W6mTYeIUzA7GYoNoXU1FScnZ1JSUkx/3v6QlRSffv2ZdmyZaYOo+wZ8uB/tSHjMmi08MwZcKpt6qiEuK2y+AyV8oQQQpgTnSUEvqB+rRhh/3emjUcIEzC721KVSV5enizQKSoFnU5X5NxPooJp9hzs+hCMeXDgfxD6Dlja3vk4IcyEJDcmkJqaSkJCQoFZjoWo6KytrXF3d5dbr5WBfXVo9BgcWwjZV+H4rxDwtKmjEqLcSHJTzlJTU7l48SIODg64u7tjaWkpSzaICk1RFPLy8khJSeHixYsAkuBUBi1Gq8kNQORMdZi4vNeIKkKSm3KWkJCAg4MDtWrVkqRGVBq2trY4Ojpy4cIFEhISJLmpDLxbg1cwXNkHcZFwYQv4dDR1VEKUC+lQXI7y8vLIycnB2dlZEhtR6Wg0GpydncnJySEvL8/U4Yg70WggeNyN7T2fmi4WIcqZJDfl6HrnYemYKSqr67+70hG+kmj0ODj6ql+fXQHxB00bjxDlRJIbE5Cqjais5He3ktFZQssbi/yy93PTxSJEOZLkRgghzFnACLCppn59bCGkxpg2HiHKgSQ3QghhzqwcoPlL6tdGPUR8Zdp4hCgHktwIIYS5azEaLGzUr/d/BxlXTBuPEGVMkhsh7lFiYiKffPIJtWrVIjo62tTh3FZGRgazZs2iYcOGbNq0ydThiPJk5wnNnle/1mfJyClh9iS5EeXOaDTyyy+/0K1bN0JCQggLCyMsLIynn36alStX8vLLL5s6xBJZsmQJCxYsyJ/grjA//fQTGo2Gpk2b0rFjR8LCwvKHVoeFhdGxY0fq1q2LRqNhyZIlZRLn8uXL+f333zl16lSZnF9UcK1ev6l68y1kxJo2HiHKkEziJ8pVfHw8AwcOJDo6mtmzZxMWFpb/XExMDBMnTmTRokV8+eWX6HQ60wVaAsOHD+f48eMcPny4yHbTpk0rkLhdT3ZurqJMnDixVGN75513eP/99wF4/PHHSUxMZOvWraX6GqKScPCGwBdh31dq9SZ8KnSS/jfCPEnlRpQbvV5P7969iYqKYsOGDQUSGwAfHx/mz59P3759iY+PN02Qd8nGxqbI552cnBg5cuQdzzNhwgSsra1LJaY1a9bcksjcKU5h5lq9DhbXFtA88B2kXzZtPEKUEUluRLn56KOPCA8P54033sDX17fQNhqNhunTp1e6iQ7vNP/LI488UqxrqlatGr169brneE6cOMGgQYNQFOWezyXMiL0XBF5LsvXZEP6JaeMRoozIbamKZEHLin8f3L46DNlb4sNyc3OZNWsWAIMGDSqy7c2Jz5EjR/jll19YuHAh//vf//jll19YvHgxM2fOZNiwYeTk5PDhhx+yY8eO/GrP2LFjGT58OADjx4/n+++/JzMzkx9//JFhw4bx008/MX78eJKSknj33Xd577332L59O/Pnz+fvv/9m/vz5HDlyhI0bN7J161Zef/11Xn/99QIxLlq0iGnTpmFlZYWlpSVeXl4l/p7cTlxcHL/++iu//PILDzzwAG5ubrz11lu0atWK8+fPc+LECWrXrp3feTkoKIjIyEhAXeTy4sWLvPbaa6SnpxMVFUVYWBhNmjThm2++yX8NvV7PjBkzWLFiBeHh4bz11luMHz++sHCEuQmZoPa50Weq1ZvgseBc19RRCVGqJLmpSDJiIf32nVIrs3379pGQkICrqys1atS45fmdO3fy3HPPkZaWBqiVkP79+/P0009z6dKl/D46Tz/9NMnJydjZ2aEoCr1798bf35/169cDMGPGDEaMGMGlS5d46623+PLLLwkJCWHgwIH5rzVs2DD8/Pxo06ZN/r527dqxffv2/MTiiy++YOzYsbzzzjtMnDiRfv360bhxYwC+//57Jk6cyI4dO/Dz8+PYsWOEhISU2vcqIyMDCwsLwsPDsbW15YUXXmDo0KHY29uzevVqAgICyMzMzG8fERFBz549Wb16NQA1a9Zk6dKl1KlThzp16hQ6MmrRokV88cUXjBkzhjfeeIPXXnuNhx9+mLp15UPO7Nl5qgnN7o/BkAtb34Tei0wdlRClSpKbisS+uqkjuLO7jPH8+fMAWFlZFfp8mzZt2LNnD61ateLQoUN8+umnvPbaawDcf//9/PTTT/Tt25cePXrQo0cPABYsWMCGDRv49ddf888zZswY5s2bx3vvvceQIUOoU6cO1avfGnNh+9zd3QF48sknqVZNndE1NDQURVHYv38/jRs35sqVK4wbN4633noLPz8/APz8/HjooYdYsGDBXX1v/qtu3br519ioUSMGDBjAgAED8p/39PS8Zch5YddTlKFDh+Li4gJAhw4dmDp1KpGRkZLcVBWtXocD/4OseDj+q7rApnfpJehCmJokNxXJXdzuqSxsbdVOjPHx8RgMhkJHQtnY2NC8eXMOHTpEUFBQ/v7rbf9b8Vm4cCGurq64ubkV2D9o0CAiIiJYvnw5L730UrFj1Gpv7YJmZ2cHQFZWFgC//vorWVlZtGvXrkC7+vXrF/t1iuN211wWrv9sMjIyyvy1RAVh7QRt3oUNo9Ttza/CE5vVlcSFMAPSoViUi1atWqHRaDAYDOzYseO27a5/qBdnGHh0dHShH8h16tQBIDk5+a5iLcz1jrlHjx4FuCWhqsyud4aWlb6rmGbPQbVG6tcXt8LpZaaNR4hSJMmNKBfe3t706dMHgNmzZ5fKOWvVqkVWVtYtk+c5OTkB0KBBA6B0V7K+Pkz7woULpXbOkpKVuUWp0FlC+6k3trdMUPvgCGEGJLkR5WbmzJm4u7szf/581qxZU+Lj/zus+eGHHwbgl19+KbD/9OnTODk58eCDDwI3bi1lZ2cXec7iDJu+fjtq6dKlhT5vNBrveI6b292pfWEx2dnZFXot/20vSZC4owYPQc326tdJJ9QJ/oQwA5LciHLj6+vLli1bqFevHn379mXWrFkFPqRjYmI4efIkOp0OBweH/P1XrqiL/B07dqzA+Z599lmCg4P59NNP828XXb16lW+//ZZp06bln6NRo0ZYW1vn3w7Lyclh7ty5+e1vfn2A2Ngbw/ETExMBuHxZnezskUceoVWrVsydOzc/wcnJyWHvXrW/1JkzZ8jJybnj9+L6Egjnzp1Dr9ff8vztrhmgWbNmxMfH558jPDycffv23XI9bm5u+XFv374duFFxiouLu+01iipEo4HOM0Bz7aNg5/uQGmPamIQoDYq4ZykpKQqgpKSkFNkuKytLOXLkiJKVlVVOkVVMOTk5ynfffaf06NFDady4sdK2bVulRYsWSvPmzZVx48Ypx44dy2/74osvKtbW1gqgWFpaKqNGjSpwrsTEROX5559XatasqXTs2FHp2bOnsnTp0ltec+7cuYq7u7vStWtXZeLEiUpUVJTi5OSkPPzww8qKFSuUV199VbGyslIAxcnJSXn//feVTz75RHF2dlYAxdraWnn11VfzX/PJJ59UnJyclLCwMGXMmDHKiBEjFD8/P2XChAnKoUOHirz+J598UnFxcVEABVB8fHyUKVOm5D8/Z84cxdXVNf/5oKCgAsdfvXpV6dy5s+Lt7a0MGzZMWblypfL0008r/v7+ymeffaZER0criqIo//77r+Ll5aX07dtX2bRpkzJ+/HjF0tJSARQHBwdl8uTJytSpU/NjsbGxUd58880iY6/Mv8N9+vQxdQgV17pRivI56mPZY6aORlQxxf0MLQmNosgUpvcqNTUVZ2dnUlJS8vt7FCY7O5uzZ89St25dmQZfVEqV+Xe4b9++LFsmnWYLlZ0McxupQ8MB+q+BOt1MGpKoOor7GVoSZn1bKjs7m+nTpxMaGlqs9g8//DAajSb/sWvXrjKOUAghKgAbF+j42Y3tDaPU5RmEqKTMdp4bvV7PokWL+OGHH4o1f8fx48extLTkq6/UDnX29vbFToqEEKLSazJUndjv0na1c/GuD+D+j0wdlRB3xWyTGwsLC55++mmOHz9eYAbb25k1axazZs3C09OzHKITQogKRqOFbt/D/BZgzIPwqdDwUfBqYerIhCgxs74tBRSrX8Dly5eZM2cOvXr14ssvvyzWaBchhDA77vdB6Fvq14oBVg8HQ55pYxLiLph9clMcBw8epFevXsTFxfHKK68QGhqav8J0YXJyckhNTS3wEEIIsxDyBrg3Vb+Oj4I9n5o0HCHuhiQ3QPfu3fnzzz85f/48P/zwA0eOHGHEiBG3bT9lyhScnZ3zHz4+PuUYrRBClCGdFfSYe2Pum13vQ9x+08YkRAlJcnMTjUbDs88+y8yZM/nnn39umdb/uokTJ5KSkpL/uD75mxBCmIXqLaHla+rXhlxYMRjyskwbkxAlIMlNIUaMGIGnpyfnzp0r9Hlra2ucnJwKPIQQwqy0nQwegerXVw/D1tdNG48QJSDJTSF0Oh21a9emVq1apg5FCCFMw8IaHlwIFtcGZUTOhDMrTBuTEMUkyU0h0tLS8PHxwdfX19ShCCGE6bg1gY5f3Nhe/TRkxt2+vRAVhNknN3l5ebcsTPjzzz/ToUOH/CHfI0eO5Ouvv8ZgMJCWlsaECROYOnWqKcIVQoiKJfBFqPeg+nVmHKwYCkaDaWMS4g7MOrn5888/WbZsGZcvX2batGn5KyEnJCQQHR2dn/Q4Ojryxhtv0LBhQ8aMGcNbb71FgwYNTBm6EEJUDBqNOnrKzkvdPrdGXT1ciApMFs4sBbJwZumLiYkhKCiId999l1GjRpk6HHFNZf4dloUz79H5jbC4KyhGdfvh5VDvAdPGJMyCLJwpKr2jR4/Sr18/wsLCCA4OxsrKCo1Gg4VFwZVALCwscHFxwd7evtxiGzRoEA4ODvkLp9aqVYtPPvmk1M6fnJzMZ599RkhICO3ataNTp0507tyZV199le3btzNp0qT8tj///DOdO3fOj6N379707t2bBx98kNatW6PT6ejXr1+pxSbEHfl2gvun3NheOQRSzpouHiGKYLZrS4mK59ChQ7Rt25Z58+bx8MMPAxAXF8eLL77I0qVLC7T19vbm5MmT5RrfwoULOXHiBI0bN6Z69eqcPn0aa2vrUjl3REQEjz76KA0aNGDRokXUr18//7ndu3czevRo7Ozs8vc9+eSTBAcHExAQQFhYGAsWLChwvnXr1vHdd9+VSmxCFFur1+DyTji1BLKTYNmjMGAbWNqaOjIhCpDKjSg3n3/+OfXr189PbAA8PT357bff8PPzM2FkN1zva1W3bt1SS2zOnz9Ply5dqFGjBv/++2+BxAagdevWrF279pbbPEVVrbp27crjjz9eKvEJUWwaDfT8CVyu9UmMi4BVw27cqhKigpDkRpSbuLg4Tp06RXR0dIH9FhYWDBw40DRB/YdWqy3wb2l46qmnSE5OZtq0aVhZWRXaxtnZmSlTphT63O1IciNMwtoZ+v4Flg7q9onfYcdk08YkxH9IclNBKIpCbkZuhX/cS//zbt26kZ6eTps2bfj7778LPHdzf5P09HTmzJlDmzZtmDy54Jvm2bNnefTRR+natSs+Pj5Uq1aNBg0aEBYWxjfffMP27dt54YUX8PLyYs2aNUybNo2HHnoIV1fXux7eHxERwRtvvEHt2rX58ccfmT17NgMHDsTNzY2XX365yGMjIyPZtGkTDRs2pGXLlkW2bdGiRbHi+fPPP7lw4UKx4xei1Hk0hQcXARp1e9f7cPQXk4YkxM2kz00FkZeZxxSHkv3lbgoT0ydiZV949eFORo8ezY4dO1i8eDGPPPIIYWFhfPzxx7Rp06ZAu9jYWJKSkti1axc9evTI35+UlETHjh156aWXeP3118nKyqJjx47s27ePVatW5d9S2r59O3Fxcfz666988cUXjB07lnfeeYeJEyfSr18/GjduXKK4g4KCOHXqFFOnTuWvv/7i22+/5ZlnnmHu3LmMGDGC3r17061bt0KPXbVqFQBNmzYt9Pmvv/6a6dOnk5ubC4ClpSUffPABAwYMKLS9wWDgl19+oXXr1iW6BiFKXf3eEPYFbBqvbq8eDk51oWZb08YlBFK5EeXIwsKCP/74gzlz5uDp6cmmTZto27Ytjz32GJcuXcpv16BBAx566KFbjl+yZAkxMTH07dsXAFtbW0aNGoXRaCQyMjK/nbu7O6B2yq1WrRoAoaGhKIrC/v13t7rx9XP2798/f1mO0NBQgAKv/V/nz58HuO3tqJdeeonVq1dz6dIlzp07x8KFC29JbNauXUtYWBhhYWE0adLklqqXECYTNBaaPad+bciFJX3g6lGThiQESOWmwrC0s2Ri+kRTh3FHlnaW93yO4cOH8+ijj/LJJ58wbdo0Fi9ezPbt29m+fTt169ZVX8fy1tdJSUkB4PLly/j7+wPg5uYGUGAdsML6y1wfiZSVdXcrG9/tOW1tbfNjvp26devi5eXFhQsXCAoKuuX5bt26FRgtNWPGjGLHLUSZ0mig8yxIPg3n10N2IvzZAwZsBycfU0cnqjCp3FQQGo0GK3urCv/QaDSlcr1OTk58/PHHHDlyhFatWnH58mXefPPNIo95+OGHsbe356OPPiIjI4O8vDx+/vlnOnXqlF9FuZOymLOyqHOGhIQAsG/fviKTIJ1OV+DfoowZM0YWdRUVh85S7WDseS0xT4tRE5ysq6aNS1RpktyIcvPRRx/dsq9OnTosW7YMS0vLIm/vANSuXZsVK1ag0Wjo2rUrDz74IA0bNuTff/8ttaSrtD300EN4eXmRnp7Or7/+aupwhCgb1k7wyIobQ8QTj8LfvSE33bRxiSpLkhtRbk6dOsWOHTtu2e/l5YWdnR2NGjUq8vjc3FymTp3Kv//+y86dO1mzZg0ffvhhgcnv4N6qM0ajsdBz3O05bW1t+d///odOp+P1118v0LfoTgwGwz29thDlyt4LHl0D9tXV7cu74O8HIS/DtHGJKkmSG1FuFEXhiSeeYMOGDfn7jEYjH374IXq9ng8++CB///Uk4MqVK/n71qxZw4oVK/Dx8aFx48Y0adKEwMBAunXrxvz58/PbxcTEAOqoq+sSExOBovu+AJw4cSL/HNnZ2aVyzj59+vDrr7+Sk5NDaGho/giq6/bu3Zu/tsrNjh8/DqjD3yXBEZWCc13ovxqsXdTtC1vUCo4kOKK8KeKepaSkKICSkpJSZLusrCzlyJEjSlZWVjlFVrE89dRTCqAASq1atZQ2bdoo/v7+ykMPPaQcPHgwv92SJUsUT09PBVB0Op0yfPhwRVEUJSMjQwkJCVF8fHwUOzs7RafT5Z8PUNasWaO8+uqripWVlQIoTk5Oyvvvv6988sknirOzswIo1tbWyquvvlpofIMHD1ZcXFzyz+fl5aVMmTJF+fLLLxUHBwcFUGxsbJQXXnhBmTdvXn6MWq1WGThw4B2vPy4uTnnvvfeU1q1bK02bNlXatWunBAQEKG3btlU++eQT5erVq/ltw8LCFFtb2/xYfHx8lG+++eYefwL3rjL/Dvfp08fUIVQdsXsVZaaLonyO+vitk6LkZpg6KlFBFfcztCRkVfBSIKuCl49169axZMkSZs2alb/PYDCQmJjIlClT8PHxYdy4cSaM0PxV5t9hWRW8nMXugcXdIEcd5YhvZ+i3DCzLbzFcUTnIquCiysrMzGTw4MEMHTq0wH6dToeHhwctWrSgc+fOJopOCHGL6q2g/xqwuvZhdX4DLO6uLrgpRBmT5EZUCllZWeTk5PDNN98QFxdX4LkdO3ag1WoJDAw0UXRCiEJ5h6h9cK4nOJd2wG8dISO26OOEuEeS3IhKwc3NjYiICOzs7AgLC6N58+b07t2bUaNGkZ2dzeDBg00dohCiMDVC4fFNYOepbicchF/vh5SzJg1LmDeZoVhUGvXq1ePbb781dRhCiJLyagFPbFX74KSdV2c0XtQOHl6uPidEKZPKjRBCiLLn2ggGbgdXP3U74zL81h5O/2vauIRZkuRGCCFE+XCspVZwvK8tl5KXAUsfgshZRR8nRAlJciOEEKL82LnDYxug0WPqtmKEDaNhw8tg1Js2NmE2JLkRQghRvixtofevEDLxxr7IGeqCm5nxpotLmA1JboQQQpQ/jRbafwzd54D22tiW8xtgQUu4ss+0sYlKT5IbIYQQptN0uDpU/PqCm2nn1ZFUh34yZVSikpPkRgghhGnVbAdD9kGNtuq2IQdWPw1rnoW8TNPGJiols05usrOzmT59OqGhoXdse+7cOZ544gnGjRvHkCFDCqz+LIQQoow51IDHN0Lgizf2HZyt3qaKP2i6uESlZLbJjV6vZ9GiRfzwww93TFQyMzPp0qULI0aM4KuvvuKRRx6hT58+GAyGcopWCCEEOivo+g30/Aks7NR9iUfhl1YQ9Q3IOs+imMw2ubGwsODpp5+mT58+d2z79ddfk52dTffu3QF46KGHOHr0KAsXLizrMIUQQvzXfU/B0AjwaK5uG3Jg/Uuw9GHIuGLS0ETlYPbLL9jY2NyxzeLFiwkKCsrf1ul0BAYG8ttvv92yCrUoHUajkUWLFvHTTz+RkpKCnZ36V1rdunV5/PHHWbVqFdOnT2fjxo0sXLiQ2bNnY2NjQ5cuXfLPkZ6ezr59+9DpdCQnJ5dL3IoCGk25vJQQVZtrYxi0E7a8rg4TBzi9FC5uU6s7jR83bXyiQjP75OZODAYD+/btuyWJ8fT0JDw83ERRmbf4+HgGDhxIdHQ0s2fPJiwsLP+5mJgYJk6cyKJFi/jyyy/p1KkTnTp1YsmSJVhbW/PvvwWnaj937hx9+/Ytl7jTcuBCKthZQm2XcnlJIao2CxvoPB1qd4XVIyArHmN2IjuW/4B+x1FCej+HnYe3qaMUFVCVT24SExMxGAy4uroW2O/o6EhCQkKhx+Tk5JCTk5O/nZqaWqYxmhO9Xk/v3r05ffo0ERER+Pr6Fnjex8eH+fPnk5GRQXx8PNWrq8ND7e3t0etvnb20du3aTJo0qUxjNhjhUjokZQEopORoiD2fhmcNe7QWZntnV4iKo34fGHaY3HVj+OWEG5v3dqHWv8fIXfwi3b8cDI0elZKqKKDKvzNrrv2HsLW1LbDfYDBgaWlZ6DFTpkzB2dk5/+Hj41PmcZqLjz76iPDwcN54441bEpvrNBoN06dPv+33/78ef7zsytNXMuBw/PXEBkADikISVqRdTCuz1xVCFHQiy4NXz3zOkW8DqPvrASzTczm7vzrGZU/A370h5aypQxQVSJWv3Li5uWFlZUVKSkqB/enp6Xh4eBR6zMSJExk/fnz+dmpq6j0nOIoCOZVgcJa17u7/QMrNzWXWLHWBvEGDBhXZ9naJz82uXr3KqlWrGDx48N0FVAS9ES6nQVJ2IU9qNORZW5Mcl4ZtRi5W9lal/vpCCFWuAX7ekknUR+tx3xCBRgGdvSWdH4umtd9ctFoFzq6An+6D0Leh5SvqqCtRpVX55Eaj0dC0aVPi4uIK7I+NjSUkJKTQY6ytrbG2ti7VOHIM8OgfpXrKMrH4MbC5y9+affv2kZCQgKurKzVq1Ljl+Z07d/Lcc8+RlqZWRDQaDf379+fzzz8v9Hw///zzbRPQe5F6rW+NwVhEI0Uhw9mJ5HMpePi751cAhRCl50iskdmT92I/fyMeGepfGn4Dm/HA511x9HaAkz1g4xhIvwT6LNj2JhxdAF2+Bp8w0wYvTKrK35YCGDJkCLt27crf1uv1HD16lEcffdSEUZmf8+fPA2BlVfhfVW3atGHPnj04Ojpy7tw5Ro4cWSCxiY+PJywsjLCwMFq2bMlrr71W6jHGZ0B0slq5KXJGDY0GvbUVWQYNmfEyg6oQpSlHD9/8cJZ5Id/j/N1KLDKycfD3YtiWYTyx8GEcaziqJeRG/WHYUQh6WV2rCuDqEfi9Eyx9BJJPm/ZChMmYfeUmLy/vlo6oP//8M7Nnz2bt2rVYW1szYsQIvvzySyIiIggKCuKvv/6iSZMm9O/fv9zitNapVZGKzlp398de79cUHx+PwWBAp7v1ZDY2NjRv3pxDhw4VGJ4P4OHhwaZNm/K3Dxw4wIEDB+4+oEJY6cBCqyY3wB3Hfme4OGF14So21WzQWd7DN0cIAcDefcksHrMG2x1HsQNwsqXLh51o+2Jw4R34rZ2g0zRo8iSsewFi96j7T/3N2TWHyPPtT6OxE9V2osow6+Tmzz//ZNmyZVy+fJlp06YxaNAgPD09SUhIIDo6Gr1ej7W1NY6OjqxevZp33nmHOnXqcPXqVZYvX45WW36FLY3m7m/3VBatWrVCo9FgMBjYsWMH7du3L7Td9aSnsOTnZs2aNaNZs2alGqOzjfqIP5tMeqYRvbUVeVZW6K0sryU5CnAj2THqdGRbW5Mak0q1etVKNRYhqpK01Dx+eHUbqT/twDZPj6LVUGdoS574shO2rrZ3PoFXEAzcCYfnkfrvR6z9vQWHopri4JTGKAt/rLu+DQEjQFe8gQqicjPrj9P+/fsXWn0ZP358gQ7BAP7+/vzxRyXo9FKJeXt706dPH5YtW8bs2bNvm9xUBC7V7bFJzkaflUdeaiZ5OXoMlpZqomNtSa6NNYpWi8ZoJMvJAUNWNhZXMnD0sjd16EJUKoqisOp/h9kxaS0WCaloAYugOgz6oSd1g71KdC6DAcLX+rPp4xHkpueh0RjxDzgK2Vdh3Yuw93No+z74DbhxG0uYJbNObkTFM3PmTHbs2MH8+fMZPHhw/pIXd2IwGFDKcV0ZS1tLLG1v/IWnGBX0OXryMvPQZ+nJS88iO8dIpo0tedZW5NracDHLiMvZVNxr2GFhLf+1hLiTc3tj+eX5VeRFnMMCyPNwpvWH3en9rH+JO+mf3XiWlaNXEn84HoCarWvy4NQWeKcegxPX5iVLPg0rBkP4FGj3IdTvK/PjmCl5BxblytfXly1bttCnTx/69u3L559/zjPPPJO/TEZMTAwnT55Ep9Ph4OAAQFJSEvHx8Wg0GpKTk3FxcSn3uDVazS0JD4DRYCQtNY8rGaDXaUnEhvTzWbjbgVN1e7Q6+etQiP/KTMhk8SsbOLMgAo1RwWBlgf1T9/PyZ21xcS7ZbaPUC6mseXUNh387DICtmy1dP+lKi+Et0Gg1wG9waRxsfwvOr1cPSjgES/tB9RBoOxnq9JAkx8xIciPKnb+/P0eOHOHHH3/k77//ZtasWbi5uZGVlYWiKHTq1Im5c+fSuHFjXnvtNebNm5c/I3TdunXp378/s2fPNvFVqLQ6Lc7VrHF0gbgUA0mZRnJtrInVG0k7noSbpy22brYyVFwIwKg3smPWHja8swklLRsNkNHuPvp+1Y37WzmX6FyGXAM7v9rJlg+2kJeRh0arIfiFYDp/0PnWPjo1QuGxdXBuPWyfBJd3q/tjw+GvXuAVDK3fhAb95HaVmdAo5VnrN1Opqak4OzuTkpKCk9Pte+RnZ2dz9uxZ6tatW6wFPUXlk5WncDnZSE6OEUVRsMrKwcmQg4uPE1YOlX9iscr8O9y3b1+WLVtm6jCqrNNrTrN0zGrSjqu3jTJre+E9sSfPDa+DXQn7+J5ec5qVo1dy9cRVAHza+tBrVi+8WxRjnSlFgTP/wrZJkHCw4HNuTSBkotonRyt/+5eX4n6GloT89IQoRbaWGuq467iaqSUx3UiuxpqrBkuyzqbiZK/DsZYjFlby305UHfFH4ln5yhrOrjoFgN7BltQhnXn6rSCa1yxZlSQ5OpnV41dz7O9jANh72dPt0240G9qs+NVRjUZdq6reg3Dyb9j9EcRFqs9dPQIrh8KOdyBoHAQ8DVYOJYpRVAzyLitEKdNqwMNeg4OVjivpWrKzDWS4OJGXnUPm4QScvOyx95L+OMK8ZcRnsOndTez7YR+KQcGo0xLXvRVNX+nImx1ssS1BtUafrWf7p9vZNmUb+mw9Gp2GkNEhhL0Xho3zXVYQNVp1EsCGj0D0Ktj1EVzarj6Xclad+XjH29D0WWgxCpxq393rCJOQ5EaIMmJrCb4uGhKzLEjMNJKn05BnZYn+ajqZCZk41nTE1lX64wjzos/Rs3vGbrZ8uJXcVLWvXFJLP7JHdOWlh91oWrLR3Rz/5zirx64m6UwSAHXC6tBrZi88AzxLJ2CNBur2Uh8XtqhJzrk16nM5Kerw8X1fqklQ0Dio0UY6H1cCktwIUYa0GnC3AwdLLVcyNGTn6sjQOZOblU3euRSs4zJwquWEtWPprlUmRHlTFIWjfx5l7YS1JJ9NBiCjTnUuDOlBx351eCqwZBOVJp5KZNXYVZxcfhIAx5qOdP+iO/c9fl/Z/UFQqwM82gHiD0LENDj6CxhyQDHCicXqw7MFBL4AfgPByrFs4hD3TJIbIcqBjSX4OGtIzNKQlKXBaGFHurUVhpQ08o5fxcbFBqdaTliY+zTVwixd3HORNePXcH6bun5crosDF57ognWvZrzZRktJiiy5Gblsm7KNHZ/twJBrQGuppc34NnR4q0P5dcr3aAo95kD7KbD/O4j6GjKvLa4cFwlrn4dNr4D/YGj2PHi1KJ+4RLHJO6kQ5SS/imOl4UqGjlwLLVmWLuSmZ2NMTSP7cBz2HvY4eDvIOlWiUkiJSWHDmxs4sEBd481oZcHl3u240rstfQKtGNKs+NUaRVE48scR1ry6htSYVADqd69Pzxk9cW/sXlaXUDQ7T2jzDrR6HY4tgqhZcGWf+lxeOhz4Xn1UD4Fmz0Hjx6WaU0FIciNEObOxAB8nSMrSkJhtgWJpR4adNdZJqRCXQebVTByqO+Dg5XBtEjIhKpbs5Gy2Td3G7mm70WerCxMntA/kwuOd8ajjxCetwd+j+Oe7HHmZVS+v4vxWtfLjXNuZHl/1wK+fX8Xok2ZhDQHD1MeVfbD/ezi2EPIy1Odjw9XHhtFq35wmT4JvF9DKHymmIsmNCcjUQkKrATc7sLeCuAwtORotuV7VMGRkY52YQtrFNDLjK16nY/ndrdr0OXr2fLOHrR9uJSsxC4CsJr6cGdSD7Po1eNgPBgVAcVcfyYjLYMNbG4iYHQEKWNhacP8b99P21bZYlnTym/LiFQzdf4COn6sJzv7vIH6/+pw+S+2nc/QXcKgB/kPURMf9PtPGXAVJclOOLC0t0Wg0ZGRkYGtbjFVuhdmzsYBaTpCUBUnZWoyOtmTZWWOdmArpWSSfTSbjSgZOPhWj03FGRgYajQZLywr6wSPKhGJUOLjoIBvf2khydDIAmjrunOjfleSgRvg4axjbGop798iQayB8VjibJ28m59qIqoCBAXSd2hVnn5LNVGwy1k5qx+Jmz0PsHjj8Exz/FbLVUV2kX4I9n6oPzyB1YsBGj4FzHVNGXWVIclOOdDodzs7OxMfHk5OTg5OTExYWFhXmr3JhOvZasLSChCzINUCmsw2W9josrqaiz8wi63gWlg6WOHg53LK+VVlTFAW9Xk9qaiqpqam4uLig00m5vao4veY0615fR2xULADWXo6cfySM822bo7XQ8qi/Wq2xKuavxMkVJ1k9bnX+7MLeQd70nN4T3/t9y+oSypZGA94h6iPsKzi7HA7Pg7MrwKjesiMuQn1smQDeraHR49DoUXCqpNdcCUhyU86qV6+Ora0tcXFxpKammjocUcEoCmTmQUaeuq1BwSo3FyU1CxKAaLCyt8LG2QatZflOAqjT6fD29sbZuZL8ZS3uyeWIy6x7fR1n1p0BwMrJGuPAduwIDcVobYmvM4xtDY3cine+hGMJrB63mlPXZiq297Sny5QuNB/W3Hz6lllYq31uGj4CmfFw7Fc4Mu9GJ2RQ17W6vBs2vwLebdROyA37g5OP6eI2Q5LclDONRoOLiwvOzs4YDAb0er2pQxIV0MVUmHcAzier2w1ts6m3eicXl6krH2sttDR5rAmtXmyFvad9mcdjYWGBTqeTKmMVkHQmiY1vb+TgQnXdJa2llppPtmLj/R1IsrZDq4EnmsAT9xWvWpOdnM2myZvYM2sPRr0RraWW0LGhdHirA9ZOpr/VWmbsPCBotPpIOgkn/oDjv9/onwNweaf62DROnT+n/kNQvy94NpeJAu+RLJxZCspi0S8hDEb48ygsPAR6I9hbwiMuieR9sZLT1/76tbC1oPXLrWk3oR221aQfV1Fk4cyipV5IZcuHW4icE4lRbwSg8YCmnH64EzsN1QCo6wIvt4YGrnc+n9FgJGJ2BBvf2khmQiYAjfo0ovsX3XFrWMxyjzlKPH4j0fnvwp3XOfqoSU79vuATBrrKv+huUcriM1SSm1IgyY0oS+dTYNpuuNZFgWBveEh/nsh31nJh5wUAbFxsaPd6O1qPaV1xR5mYmCQ3hUu/ks62T7ax99u9GHIMANTvUR+X0V34JdubtFzQadRKzWNNoDhTMJ1ee5q1r67lyoErALj7u9Pjqx406NGgLC+l8rl6VJ31+PTSgreubmblCLW7Q50e6sMM++lIclNBSXIjyprBCEuOw4KDkGcAO0sY3lyhzpETbJy0gbhD6uypDt4OdHirAy1GtMCiuONxqwhJbgrKSsxix+c72D19N3mZaiev2h1q0/LtTiyxrs0uNW+mrguMC4V61e58zrjDcax9bS2nVqqVRRsXG8Imh9HyxZYyMeWdpF2A0//A6WUQswEMuYW3c/WHuj3VRKdmB7Cs/BVbSW4qKEluRHmJSYXpu+DYtSpO8+owOtjIlWWH2Pj2jWG6Tj5OtH+zPS2Gt0BX3GEsZk6SG1VOWg67pu1i5+c784dh12hVg04fduZcg3r8L1JDei5YaG9Uayzu0Hc9/Uo6m97dRMT/IlCMCloLLa1eakWHtztg52ZXDldlZnLTIHo1nFqqjr66Prz8vyxsoFZHtbLj2xk8mqmrnVcyktxUUJLciPJkVGDpcfj5gFrFsbWA4S2gm4+BiNn72PbxNtIupQHg7OvM/W/eT4unJcmp6slNbnoue77dw/ap28m6qk7A59XMi04fdMKtSyO+2ash/JLatn41tVpTx6Xoc+Zl5bHrq11s+2QbuWlqpcHvYT+6Tu1atfvVlCajQZ1HJ3q1+ojdrS7kWRgbVzXZ8emk9tVxv69SJDuS3FRQktwIU7iYqvbFOZqgbgd6wZgQcLPQs+9/+9g2ZRvpl9MBNclpP6k9zYc1r7JJTlVNbnJScwifFc7OL3fmJzVujdwIez+MJo/ex8ZzGn6IhIxr1ZqBAdDfv+hqjWJUOLjwIOvfXJ+/DlSNljXo/kV3aneoXR6XVXVlJcL59RC9Sk120i/evq2tu5rk+HRSH65+FXIUliQ3FZQkN8JUjAr8cwLm7Vcn/7OxgGGB8EBDMGTnEfG/CDXJib2W5NS+luQ8VfWSnKqW3GQlZbF7xm52T9tNdnI2AK4NXWk/qT3NBjcjMVfLzHDYd1lt39BVrdb43mEao3NbzrHmlTVc2quWeZx8nOgypQtNBzY1n/lqKgtFgatH1GQnZiNc2Hz7W1gANm5Qoy3UbAc12kH1luqtLROT5KaCkuRGmNqlNJgRDtf6FRPgCS+HgLejeutg3w/72P7J9htJjq8zbV9rS4vhLarM6KqqktxkXs1k11e7CJ8Znt+nxt3fnQ5vdeC+x+9Do9Oy9gzMjlQnjLTUwZCm0K8x6Iqo1iQcT2D9G+s5tuQYAFaOVtw/8X5Cx4aW+6zZ4jaMBog/oCY6MRvhwhbILWKyWK2lulZWjXbXEp62YO9VfvFeI8lNBSXJjagIjAqsOAk/RkGOAax18FQg9G6kLtSZl5XHvu/3se2TbWRcUVcztvOwo/XLrWk1spXZz5Nj7slN6sVUdk3bxd5v95J3bYprz6aedHirA/79/dHqtMRlwMxwiFRXUsDPDV4OVVepL+q8mydvJnJuJIpBQaPVEPRcEJ0mdyqXCSTFPTDqIS7qRlXn0o6iKzsALvWheghUbwVercCrBViW7c9ZkpsKSpIbUZHEpsOM3XDgWhXnPg+1L07Na7+aeVl5RP0UxY5Pd+SPrrJytKLlCy0JHReKo7ejaQIvY+aa3MQfiWfH5zs4sOAAxjy1o2n1FtXp8HYH/B7yQ6PVoCiw6jTMjYQsvVqtGdpMrdbc7k5SVlIW26duZ/f03eiz1ZnUG/VpRNdPuuLRxKO8Lk+UJsWoTiJ4cTtcuvZIOln0MRotuN2nJjvXkx73pqArvWqdJDcltGHDBr777js8PT2xtLTks88+w8Li9nN/jBs3jmnTpuVvL1q0iAEDBtzxdSS5ERWNUYFVp9QqTpZenSb/yWbQ96YPM6PeyKHfDrH9k+358+TorHQEDguk7attzW60izklN4qicH7beXZ8uoMT/57I3+/b3pd2E9rR8MGG+UtlXElXb1nuV+fTw99dXROq5m3eqvKy8gifFc62KdvITlL76vi086HrJ10r7+KW4vYy49WKzvWE58o+MOQUfYzOWl0iwjP42r/NwS3grufckeSmBPbv30+PHj04dOgQ7u7ujBkzBp1Ox1dffVVo+6SkJJ566ik6d+4MgFarZeTIkUUmQ9dJciMqqv9+sPld+2CrddOvqWJUOLniJNumbCNmR4y6UwONejcidFwodcLqmMWaUuaQ3BgNRo4vPc6Oz3Zw4fosexrwf9iftq+1pVZorRttFVh5LcHNvk2CW+DceiNR86LY/N5mUi+o/TQ87vOgy5QuNOrdyCx+B0QxGPIg4RBc2aMOQY/do24rhqKP02jV0VgezcEj8EbSY+d5x5eU5KYEHnzwQapVq8aCBQsA2LVrF/fffz+nTp2iTp06t7T/6KOP6NOnD82aNSvxa0lyIyoyRYHVp2HOTbckhjSFh/0KfshdrwZs/2Q7J1fcKFV7NfOi9djWNB3YFAubyjvrcWVObrISs4iYHcGeb/aQci4FAJ21jubDmtNmfBvc/rM0d2w6TN8NB2+6Nflya6hRyB1HRVE4vvQ4699cT8K1eQWcfJzo9H4nmg1thraoXsaiasjLhLjIG8nOlT13vp11nb23muR4BKq3s9wDoFpjdQX1ayS5KabU1FTc3NyYOnUq48ePByA7Oxt7e3umTp3Kq6++WqB9dnY2tWvXxt3dnccee4zx48eX6BssyY2oDOIyYNYeiLg29Lexm/qBV9jQ34TjCeyesZv9P+3Pn5rfzsOOli+2pOULLStlv5zKmNxcOXCF3TN3c3DBwfx+L7ZutgQ/H0zrMa1x8HIo0N6owPKT8FPUjU7lTzdXpwb4b7VGURROrznNpnc2cTFcnSvF1tWW9pPa02pkq0qdyIpykJ2srnAeH6V2Wo6LgquHwZh352M1OqjWSE103ANItamHc9BQSW7uZPPmzYSFhfHTTz/x1FNP5e+vVq0aDzzwAL/88kuB9hEREUydOpXIyEhOnjxJ7dq1Wbt2LQ0bNiz0/Dk5OeTk3LgnmZqaio+PjyQ3osJTFFh3Fv4XcWMY8KAAeMSv8GHAWUnXKgaz9pByXq0YaC20NO7bmODng6nXtV6lmduksiQ3+hw9x5ceZ8/Xezi35Vz+/uotqhMyOoSAAQEFhl4bFTiTBNvOw7ubwcFKXQ+qqaeavFZ3uPU1zm44y8Z3NhKzXb0NaWlnSeux6uryNs6mn/dEVFKGXEg8piY615Oe+Kg7jtBKzQbntyjVz1CzTM3j4tRarKura4H9jo6OJCQk3NI+KCiI3377DYAlS5YwbNgwHnvsMSIjIwu9zzxlyhQmT55cBpELUbY0GuhWD1pUV6s4ey+pEwDuiFH74tR2Kdjetpot7V5rR5txbTi25Bi7p+/m/LbzHP3rKEf/Okq1etUIejaI5k83v6WKIEom/kg8EXMiOPDzATITMgHQ6DQ06d+EkNEh+LTzQaPRkJoDu85BRCzsuQSRlyH9pj+W03PhxZbQq8Gt1Zrz286z8e2NRG+KBsDCxoKWL7ak3evt5Ocn7p3OSl3fyqMZ8KS6T1HURUHj96uVnYRD6iPx6J07Lt8Ds6zcLF68mMcee4y1a9fStWvX/P01a9akRYsW/Pvvv0Uev2bNGnr06MH27dtp27btLc9L5UaYA0WBDdHwQ0TJpt6POxTHvh/2sf/n/eSkqP8PtBZaGj/UmMAnA2nQs0GFnP24IlZuctNzOfzHYSJnR97ozA041nCk+fDmBD3fkjhbJyIuq7cTwy9BdDIogE6jVm3++wb+cWcY3LTgvgu7L7Dx7Y2cWXsGUEfFBT0bRPs32+NYWEccIcqaUQ/JpyHhEKnn9uLc/ROp3NyJt7c3oJa4bpaeno6Hx53nZ+jevTvBwcFER0cXmtxYW1tjbW1dyJFCVB4aDXSpC8294Ou9EH4R5h+A7TEwrjXUrVb4cZ4BnvSa0Yuun3Tl8O+H2ff9Pi7susDRP49y9M+j2LrZEjAggGZDm1EzpKaMsvkPQ56B02tOc2jhIY4tOZbfp0mj09CodyOCngmiQc8GaC20hF+Ex9QxEVhoQX/TeomGQv4sbVBNTVCvu7T3Epve28TJ5WrnT62FlubDm9NhUgec77TOghBlSWsBro3VR/VuwCelenqzTG78/f2xtLTMvz0FkJmZSWpqKiEhIcU6R7169ahVq9adGwpRybnZwdvtYdM5+H6f2n9j3Bp4vAk81kTtl1MYSztLmg9rTvNhzbly4ApR86I4tPAQ6bHp7Pl6D3u+3oNbIzcCBgbg398fzwDPKpvoKEaFmB0xHFx4kMO/H85fwBLAtYErLUa0IPCpwFs6ald3gCbucCShYGJzO6+0UW9Fndt6jq0fbeX06tOAmjgFPhlIh7c7UO12WasQZsQsb0sB9OvXD2dnZ+bNmwfA7t276dChA6dPn75j0mIwGOjXrx9///23zHMjqpSkLLWKc30Klbou6mKK9Yr5eWjUGzmz7gwHFhzg2N83qhKgfoj79/fH/xF/arSqUe6JTnnfltLn6Dm74SzHlx7n+NLj+et6Adh72nPfgPtoOqjpHatbeiP8sA++2KXehjIW8o6t1UB9F4VvPU+z7eOtnN96HlCTmqaDmtLh7Q5mNymjMB8yFLwE9u7dS79+/Thx4gR2dnaMHDkSBwcHPv30U9atW8cbb7zB8uXL8fLyYvLkyWi1Wl577TW0Wi3vvPMOffv2LfSWVGEkuRHmRFFg63n4di+k5ap9Ox5rAk/cd/sqTmFy0nI49vcxjiw+wuk1pzHk3JgEzKmWE/V71qdBjwbU61oPG5eyH6FTHslN6sVUzq4/y4l/T3Bq5Sly03Pzn7N2ssb/EX8CBgVQt1NdtEV1bCrEiavQbUEhTxgVfA8d56E9W8k4qK7UrbPS0fzp5rSb0I5qxc1MhTARSW5KaMmSJfz222+4u7vj7OzM+++/j1arZfHixbzwwgtERETg6+vLjBkzePfdd7G1taV9+/a89957+Pv7F/t1JLkR5ig5W01wro0Wpo6LOrS4oWuRhxUqJy2HUytPcfSvo5xcfrLAh75Gq6Fm65rU71GfOmF1qNmqZpmsVF4WyU12SjbntpzjzLoznF13lvgj8QWed6zhSOOHGuPXz486YXXuuaN1jh6+26fOOq3JM+AbcYhmG3ZQ7bJ6C97C1oLg54Np+2pbnG63voIQFYwkNxWUJDfCnG27VsVJyVFvfzzqDwMC1On874Y+W8/ZjWc5vfo0p9eczp8V9zqthRbvIG9qta2FbztfvIO9canjcs+3se41uTHqjSQcT+DCzgtc2HWBCzsvEH80vuBwJQ3UaFmD+t3r0/ihxtQIrlHq8wBlJ2ezeto+wmfuxioxDQCdvRVtxoQQOjZUVuoWlY4kNxWUJDfC3KVkq52Nt6hdOfB1VufFaVQK3ThSzqdwes1pzqw9w/lt50m7lHZLGytHK7yaeeHVzAvPAE+q1a9GtXrVcKntUuxqSHGTm9z0XJLPJZN8Npn4I/HEHYoj7mAc8UfjC9xau861gSt1u9alXtd61O1UF1vXu1s88E6So5PZNX0XkbMj8ytfWncHrPq3YvTHrbAro9cVoqxJclNBSXIjqortMWoVJzlbreI87KfOqVJa09ooikLKuRRidsRwfvt5Luy4QPyReAy5t1m0T6P233H0dsTOww57D3ts3W2xdbXFwsZCfVhboLPS8eUXXzJ65GiMeUYMuQayU7LJSswi62oWWYlZZFzJIDk6mazErMJfC7C0t6Rmq5rUDK2JTxsfaoXWKtNKiaIoXAy/yK6vdnFk8RGUa+O/Pe7zoM0rbWg6qCkW1mY56FVUIZLcVFCS3IiqJDVHreJsvrYyQC0ntYrj5142r2fIM3D1+FWuHLjClQNXiD8ST9KZJJLPJhcYjVWabKrZ4FLbBXc/dzwCPPAM8FQrRnWrlctyE3mZeRz69RB7vt7D5euLgQH1utajzattqN+9fpUdVi/MjyQ3FZQkN6Iq2nUBvt4DSdeqOA81VlcbL69CgqIoZMRlkHQmiYy4DDLjM8mIV//NTs7GkGNAn6NHn63HkGMgcn8kIW1C0Fpq0VnqsHa2xtZVrfLYutli526HSx0XXGq7YO1kmkk6E08lsufbPUT9GEV2Ujagrv4d8EQAoeNDqR5Y3SRxCVGWJLmpoCS5EVVVWo66COeGaHW7hqNaxWly54nAy11FXH4BbiyUGTk3Mn/SPQCXOi60fLElLYa3wM7dzoQRClG2yuIzVG7WCiHumqM1jG8D7X1h5h64lAavr4O+jWFoM7CRd5hCKYpCbGQskT9GcmjhoRv9fDTQoGcDWr3USl2CobCl2oUQdyRvPUKIe9aqJnzjAXMiYe0ZWHpcXatqTGto6mnq6MqX0aB2WC7skRGXQdRPUVzcfZH4wzfmxHGs6UjgU4G0GN4C1/p3MZGQEKIASW6EEKXCwUqd5K+dD8wMh8vpMHE99G4EwwLNs4oTdyiOH9v/iCHPgDHPiFFvRClsfYRC6Kx1+PXzo/nTzanXtZ5UaYQoRWb4diOEMKWWNeCbB2BOFKw5Df+egD0X1cSnmZepoytdGXEZZKdkF5zIrxg6vN2B0LGhZTYnjhBVnfypIIQodfZWMCYE3g8DDzu4kgFvboBv9kBW2YzeNom6nevSdWrXYrd393Pnlcuv0On9TpLYCFGGJLkRQpSZIG/4+gHo1UDdXnEKXloJUbGmjas0tX21LU0HNy2yjUanoXrz6jy97WkcqjuUU2RCVF2S3AghypSdJbzUCj7qBF72EJcBb22EWeFQRnPwlSuNRkPf2X1v//y1hUGHbR6GnZsM6RaiPEhyI4QoF4HVYVYv6N1Q3V51GkaugJsm4K20LGwsGH9pPPae9mh0N2YO1mg11OlUhyfXPmmyiQGFqIokuRFClBtbS3ihJUzpDNUdICET3tkE03dDRq6po7s3jt6ODPx34I1RTxpo2Lshg5YPwtLO0rTBCVHFSHIjhCh3Tb3UKk6fRqBBnRtn5ArYc8nUkd2bmq1q8tCPDwEQMCCAxxc/LgtbCmEC8r9OCGESNhbwfLA6L86McHV248mboUtdeKaFOvtxZdR0UFOaPNYErU5bLotsCiFuJZUbIYRJBXjCjJ7Qr7FaxVl/Vh1RtfuiqSO7ezpLnSQ2QpiQJDdCCJOzsYBnguDTrurim4lZ8MEW+GKnujinEEKUhCQ3QogKw98DZvaE/v6g1cDGaHhxBey8YOrIhBCVyV0lN127dmXVqlWlHYsQQmBtAU83h8+6go8TJGfDR1vh0x2QIlUcIUQx3FVys2HDBh588EHuu+8+5s6dS25uJR/DKYSocBq7w/Se8GgTtYqz5Ry8tAK2x5g6MiFERXdXyY2zszOKonD06FGeffZZfH19+eCDD0hISCjt+IQQVZiVTl1R/PNu4OusVnGmbIOp2yEl+/bHKSVcyFIIYV7uKrm5ePEis2bNws/PD0VRiIuL47333qN27dq8+OKLnDhxorTjFEJUYY3cYFoPeOI+tYqz9bzaF2fruYKJTK5B7YQc8B38fth08QohTOuukhs7OztGjhzJkSNHWLlyJT179gQgKyuLH374gSZNmvDQQw+xZcuWUg1WCFF1WelgaDP4sjvUdYHUHJi6A6ZsVys6B69Ar19gZjik58In2yFbb+qohRCmcM+jpXr06MGKFSs4duwYL730Evb29hiNRv799186depEq1atWLRoEQaDoTTiFUJUcQ1c1QRnUADoNLD9PITOgd6/wpkkuF7IuZoFiw6ZNFQhhImU2lDwhg0bMnPmTC5evMiXX35JvXr1UBSFffv2MWTIEOrWrcsXX3xBampqab1kkTZs2MDjjz/OqFGjGDduHHr97f+ES0pKYsiQIYwdO5YBAwbIbTUhKjhLHQxqCs8Fw9lkyLr239v4n3YzwqV6I0RVVOrz3Dg6OjJ27FhOnDjB0qVL6dy5M4qicOHCBSZMmICPjw/jx48v7ZctYP/+/QwaNIhvvvmGWbNmYTAYeO211wptqygKffr0oUOHDkybNo0JEybQrVs30tLSyjRGIcTdy9bDx9vU0VNZebdvl5QFCw+WX1xCiIqhzCbxy87OJjg4mGnTpjFr1ixq1aqFoiikpaUxffr0snpZAN588026du2Ku7s7AIMGDWLmzJlER0ff0nbx4sWEh4czdOhQAIKCgrC1tWXatGllGqMQ4u49+gd8v0+9BfXfas3NFNQ+OFK9EaJquauFM2fMmEFSUhJJSUkkJibmf33zdl7erX9OaTQalDIeo5mamsqaNWuYOnVq/r7mzZujKAqLFy/m1VdfLdB+8eLF+Pn5YWtrm78vODiY3377jbfffrtMYxVC3J1ALzidBJnX3mYsNKC/zVtLYjYsOFB+sQkhTO+ukpuxY8ei0aiLwpUkWdFqtTg7O+Ps7Hw3L1sskZGR6PV63Nzc8vfZ2Njg5OREZGTkLe3Dw8OpU6dOgX2enp4cPXqUnJwcrK0r6dLEQpixjzrDB53UBCfiMkTGqgttnr3WoVjDjY7FAB9sBT9d2b3vCCEqlrtKbm7WrVs3GjVqlJ+0FPVwcHAojZiLFBcXB4Crq2uB/Y6OjoVOMhgXF0dQUNAtbY1GI4mJiXh7e99yTE5ODjk5N+aBL69O0kKIG7QaaOiqPp64T92XlgP7r0BELOy5CFvO32h/qsmrZOaBnaVp4hVClJ+7Sm6cnJxITU1Fo9GwdetWfH19eemll/Dz8yvt+ErsekXp5ttMAAaDAUvLW9/VNBpNoW2BQtsDTJkyhcmTJ9+y/4knnrjtMUKI8hcIJFt4El1rAJkn1jCgv9xqFqKiKawby726q+TmwoULfP/990yfPp0LFy4wd+5cfvzxRx544AFeffVVOnToUNpxFtv1SktKSkqB/enp6Xh4eBTavrC2Op3ulurPdRMnTiww4is1NRUfHx9+++03nJyc7vUShBClzKjAQ/1msWzpMlOHIoT4j9TU1FLvrnJXo6UcHBx45ZVXOHPmDPPmzaNp06YFJu5r3bo1v//+O0ZjUeMYyoa/vz+Wlpb5t6cAMjMzSU1NJSQk5Jb2gYGBBdoCxMbGEhwcjFZb+LfH2toaJyenAg8hRMWl1YBGKf/3IyGEadzTUHALCwuGDh1KVFQUq1atokuXLiiKwp49exg4cCANGjRgxowZZGRklFa8d+Tq6soDDzzArl278vcdPHgQKysr+vTpc0v7IUOGsH///gJ9aA4cOMCjjz5aLvEKIe5daQzClMU2hTAfpTbPTffu3Vm7di2RkZEMGjQInU5HdHQ048aNw8fHhzfffJPLly+X1ssV6a233mL9+vVkZmYCMG/ePF5++WVq1arFunXraNmyJVeuXAGgT58+BAQEsHz5ckAdPZWTk8PIkSPLJVYhxN1TFFh7BiZtAP09FGb2XVbPEZteerEJIUyn1CfxCwwMZMGCBZw+fZqxY8fi4OBAcnIyU6dOpW7dugwfPpxDh8p2wZeWLVsya9YsRowYwejRo3F1deWTTz4BIDk5mejo6PxKjU6nY9myZfz+++9MmDCBmTNnsn79euzt7cs0RiHEvbmSDpM2wvTdcCAO1p+9u/MYFZgdoZ7jpRWw+Ii6TwhReWmUMp5VLzU1le+++44ZM2Zw6dIlQJ3vpqi1niqb652hUlJSpP+NEGVEb4RjCbDvEsyNguhr4wCCvGFoU+jnp/atuZ2+ffuybFnhHYpj09UkKfwSnEpU9w0KgI611fN7yt86QpSZsvgMvavRUkuWLCEtLe2WR2pq6m33p6en589QXNazFAshKr/4DHVyvojL6gR9B+Mgr5BbTzN7Qq17fD+s7qBODPjTfpi8Wd238JD6AHCzhTa1INhbTXaaeICV7t5eUwhRdu4quXnkkUfy55O5HUlghBAlkZQFS46r/V92XYD4zDsfs+nJe09srtNqYHhzOBIHfxwt+NzVLPj3pPoA0GnUBKd1TWjvC2F1SicGIUTpuOsZigtLXiwtLalWrVqxHkIIcd3uizAnAlafKf4xj/pD3TJ4K3mtLfx1DAxF/H1mUNRK0sE4mLcf3g+DLnXBq+wnYRdCFMNdJTc//vhjoQmLnZ1daccnhDBzeiMM/qvwW063o9XAy63LJh4vBxjaTE1ailN/zjPCxA3wbAt4y3TzlwohbnJXyc1TTz1V2nEIIaqYLefU21C7L5QssdGgVm18y3AdzJGt4JeDJYvrx/2wLxZa1YBRrcBJ1twVwmRKfSi4EEIUx9d74M+jcCGtZMdpNDD61snGS5WXPQxppiZSxaU3qp2fv98Hh+PLLDQhRDFIciOEMInPu0NozZIdowEea1K2VZvrXmwJFiV4h9RqwFoHUzqX/LqEEKXrrjsUCyFESaXlwP4r6oiofZfVDrklUR5Vm+u87OHJZjAnqnjtjQrkGGBGOOy6CC2qq0PH/d3BUoaNC1GuJLkRQpSp9WdgzRkIvwhnk9VOujqNmgzcqcPu9dtCCvCwn5ps+JTjPJnj26hDvt/bBGl5xTvmcjr8ewKWHVfjttRCU09oWUOtBrnalmXEQgiQ5EYIUcY+2KomNTcrapi1jQXkGdQ2CvD9g+qcN/0ag2M5d9J1sIJHm0BDVziZqK5jtfbMjfg97dTY/ns5N19fnhEiYtVHSE3oVq/cwheiypI+N0KIMjWjJ9SvdufOuToNPOKnTszXzkfd16kO9GygDs0u78TmZoHV1SRnfKhacbKzhM+7wW/91VtlRdFp1OrNpPbQuU65hCtElSeVGyFEmWrmBSsHqWs3fbP39reiFNS5a7wd4ed+EHUFGrmWY6DF0NgdtgxTOw5fn7Dv4cbqkPbbVaMaucE3D0A9mbtUiHIjlRshRJm7nA6X0qH+bZIVnUbtU1PHRd3WaNQOufZW5RZisfk6F5yJ+OXWtyZs14s5rjZq1Wbbecg1lFeEQghJboQQZUZvhEWHYOxqdbVtDzv4X28YG6IOndZdywIU4OVyGgVV2mq7qLfTdDfdngr2hn8HwMAA9dp+P6J+D05cNVWUQlQtcltKCFEmziTBtN3qv6AuMvlSK3W0UPf60KMBjFsNx66qMw7XdjFpuPfk5dbqelTWOnizvTqqS6uBpl7Qzhe+3QvnU+DVtfCIPwwKkFXFhShLktwIIUpVngH+OAK/HVb7oThawQstoYNvwc63TTzg34Hqopktqpsu3tLg6wybn1ITmv+uUt7OBwI84Yd9sPkcLD6iLjnxcmvwczdNvEKYO0luhBCl5lSi2nH4+tDvtj4wsiW42BTe3lIH9/uWW3hlqqhZk52t1dXG2/uqy07EpMKEderw9sFNwVreiYUoVfJfSghxz3INaqXmjyPqUGkna3gxWE1c7jRUuioJrQX3ecAPEbAxWr2VtesijGsN/h6mjk4I8yHJjRDinpy4qvatOZ+ibrf3hReCwfk21ZqqztEaXmmjfp9m7YFLaWoVp29jdT4fG3lXFuKeyX8jIcRdyTXAwkPw11G1WuNioy4vcH0Cvsro1JpTrJ+4npyUHJ4JfwY7Vzsy4jKw97Qv9dcKqQlfu8OcSFh3FpYehz2XYEyI2kdHCHH3JLkRQpTY8QS1WhOTqm53qA3PB6t9S8qLIc+ArhRWpDyx/AQbJm0g7mAcivHGjDW/9PqF7MRsEk8l0u2zbrR9te09v9Z/OVrD2FD19t3McLWKM3E99G4ETwVKFUeIuyX/dYQQxZajV6s1fx+7Ua15qRW0qVX2r52XlcfmyZtxqeNC5JxILu29hIWNBXW71KXXzF5Uq1v8KYCPLT3Gxrc2EnckDoyFt7kUfgkAjVZD2uW00riE22pZQ53FeE4UrDkN/5xQqzgvh6jDyYUQJSPJjRCiWI7Gq9Wai9c+5zvVgeeCym/Np7Prz7J96vYC+/TZek4uP8nJ5SfR2eio06kOvWb0wq2BW36b7JRs4o/Ew0mYXm86yf9dxfMONFpNmdyW+i97K/WW1P0+MCMcYtNh4gZ4sCEMCwRbyzIPQQizIcmNEKJI2XpYcEDtE6KgTsL3Uit1Ur7yZFOt6B7KhmwDp1eeZlbDWeisdfh28OWBmQ+QeiGV+V3nE0wwySSX+HWNemO5JDfXBXmrVZy5kbDqNCw/CXsvwegQaF7J5wMSorxoFEW53Tp2ophSU1NxdnYmJSUFJyenOx8gRCVxKE6tIly6Vq3pWhdGtDDNCt3xR+P5psk3d318LrlYcXeLVTl4O1C/e31qtKpBzVY18Qr0wqIcJqeJilW//3EZ6nbP+jC8hboquRDmoiw+QyW5KQWS3Ahzk62Hefvh3xNqtcbNVq0ctKxhmniykrI4u/4sfzz2x12fI80qjef+eo71b64n/lB8gc7DJaW11FI9sDq12taibqe61O5YG9tqtnd9vqJk5cFP+9UKDqjrc40OUSs8QpgDSW6KKSkpidGjR+Pu7k5sbCzvv/8+jRo1KvKYqKgoWrRokb/do0cPVq1aVazXk+RGmJODceosw7Hp6na3evBMi/JboTs3PZcLuy5wfvt5YiNjiY2KJeVcyj2d09bVlmM1jzH3wNz8fSdWnGDDm7eOkirMg989SNqlNC7tucTF8ItkXc0q2EAD3i28qdO5DvW71ad2x9qlXtk5eEXt83TlWhWne30Y0bxirpwuRElIclMMiqLQvn17nnzySZ577jkiIiJ4+OGHOXToEI6Ojrc97vnnn8ff3z9/u0uXLjRt2rRYrynJjTAHWXnXqjXXKgTu1yoEwWVcIchOzubshrOc23KO89vOExsVi2K49W3Jpa4LyeeSbzu66WY21WwIGBRA90+7Y3ntHk7fvn1ZtmxZoe1PrjrJ+jfW35roaAAF3sx4M/88iqKQHJ3MxfCLnNt8juiN0SQcSyhwPisHK+p3r0+jPo1o+GBD7D1Kp8/O9YraPyfUbVNX1IQoDZLcFMMff/zB4MGDSUlJwdZWLRP7+fkxePBg3n777UKPiY6O5ttvv2Xq1Kl39ZqS3IjKbv+1vh1XyqFvh2JUuBx5mVOrTnF61Wlidsbcksw413bGt50vNUJqUL15daoHVsfGxYbPvT4n43oHlP+wqWZD08FN6Ta1W34icrOikpubnV5zmvjj8dRoUYPIuZHYudvR7dNuRR6TdimN6E3RnN1wlpMrTpJ+Of3GkxrwaePDfU/cR5PHmuDoffs/sorrv32hutVT+0I5SBVHVEKS3BTDE088wdGjRzlw4ED+vsGDB7N//34OHTpU6DGjR49m0aJF9OjRg1deeYWgoKASvaYkN6KyysqDuVGw8pS67WmvDkcu7VE5hjwDZzec5eifRzm+9PgtCYq7nzt1OtXBt70vvvf74uxT+CqU/wv5H5f2XMLSwZK89Dysq1kTODSQrlO7YmlTdCZW3OTmXilGhcsRlzn+z3FO/HOC2MjYG09qoE5YHQIGBODf3x87N7u7fp1sPcw/AMtuGsU2qpU687EQlYkkN8VQt25d6tSpw8aNG/P3jRs3jhkzZpCZmYm1dcFhHoqi8OKLL3LkyBF27dqF0Whk5syZvPjii7d9jZycHHJycvK3U1NT8fHxkeRGVCqRsTBjN8RnqtulPZ+KPkfPmbVnOLL4CMeXHSc7KTv/OSsHK+p1rUf9nvVp0KMBLnVcinXO3PRcEk8n4tXMC00JV+Qsr+Tmv1JiUjj29zEO/XqICzsv5O/XWmip36M+LYa3oFHvRuis7m625aPx8NXuG1Wc8p5/SIh7VRbJjdnNcxMXF3dL5cXR0RGj0UhiYiLe3gU7EGg0Gr777jsAzp07x5NPPsmoUaNo2bIlrVq1KvQ1pkyZwuTJk8vmAoQoYxm5arVm9Wl128seXm4NzUphJlxFUYjZEcP+efs5/PthclJu/BFg72mP3yN+NOnfhNodat/Vh7mVgxXVAyvXZC/OPs60HtOa1mNakxydzOHfD3Po10PERsbmT0Bo52FHs6HNCBoRhEeTki0P7u8BM3vCLwdhyXF1tfGoWHUuotBymDlaiIqoUlVuRo8eTWRkZJFtoqKi6NevHwsWLMjfN2nSJD7++GPi4+Nxd3cv8vj09HSCgoIICwvjhx9+KLSNVG5EZbX3krqG0fXBPr0bwVPN7r1ak3Qmif3z93Pg5wMknUnK3+9Y0xH/R/xp8mgTfNr5oNVp7+2F7oGpKje3k3Asgah5Ueyft79AH52arWvSYkQLmg5qilUJh0Idu7bm14Vra351vLbml5NUcUQFVuUrNzNnzrxjm4YNG5KSUnDYaHp6OjqdDldX1zse7+DgwJgxY4p8E7S2tr7l9pYQFVl6rrr69Noz6ra3A4xpDU3vYfVpfY6eo38eZd/3+zi35Vz+fisHK5o82oRmTzajTsc6aLQlu31UVbj7udN1Slc6f9CZU6tOETknkhP/nuDi7otc3H2Rta+tpfnTzQl5KQTXBnd+7wLwc4cZPW+s1r75HOy/UvlXaxeipCpVclMcgYGBxMTEFNgXGxtLcHAwWm3x/mqsV68etWpJPVeYhz0XYeYeSMxSRzb3bQxDm939itOJpxPZ98M+ouZGkZmgdtjRaDXU61qPZk82w6+fX4krDlWZ1kJLo96NaNS7EelX0jkw/wD7vt9H4qlEdk/bze5pu2nQqwEho0Jo0LPBHZNFK53ad6ptLbWKcz4FpmyDDr7XVm4vehULIcyC2SU3Q4YMYcCAAeTk5ORXVw4cOMDw4cOLfY59+/bx9NNPl1WIQpSLtBz4XwRsiFa3azjC2NZQwi4dgLq+0vF/jrPvu32cXnM6f79TLSeCng2ixYgWONWUW7L3ysHLgbavtqXN+DacWn2KPbP2cHLFSU6tPMWplaeoVr8arV5qRdCIIKzvcK+pkRtM6wG/HoLFR2HL+RtVnPt9y+mChDAR090ALyN9+vQhICCA5cuXAxAeHk5OTg4jR44E1P4y7du3Z/78+QDs2rWLgQMHcuqUOhZ27dq15Obm0r59e9NcgBClYPdFGLlCTWy0GnjET+10WtLEJjslmx1f7GBG/Rn8/sjvamKjgQY9GzBg6QBePvsyHd/pKIlNKdNoNTTs1ZBBywcx+uRoQseFYu1sTdLpJNaMX8NXvl+x7o11pF0fInUbVjp4MhC+6A51XCAlBz7ZDh9vg+TsIg8VolIzu8qNTqdj2bJljB8/nl27dnH58mXWr1+Pvb06Q6heryc6OpqrV68C4OLiQlRUFM2aNSMkJIRhw4bxwQcfmPIShLhrqTnwQwRsila3azmp1Rq/ovvR3yLpTBK7Z+wmck4kuem5ANi529HimRYEPxtMtXrVSjdwcVuuDVzp8WUPOn3QiQMLDrDrq11cPX6V7VO3s/PLnTQb0oy2r7YtcpRVQ1f4qjv8fgR+Pww7YtTlHF5oqd6uKuGoeiEqvEo1Wqqikkn8REWwPQa+3av+Ra7VwMN+MLip+td7cSiKQsz2GHZ9tYtjS47lL0PgcZ8HoeNCaTa4GRZ321GnAqhoo6XulmJUOP7PcXZ8toOY7Tf6Fzbq3Yi2E9rie79vkXMAnUmCr3bB2WR1O7QWvNQSymjdTyHuSCbxq6AkuRGmlJIN3+9T+1QA+Dqr1ZpGbsU7/vqH5bYp27i4+2L+/gY9GxA6LpR63eqVeMK8ishckpubxeyMYcdnOzi25Jg6TTFQq00tOr7Tkfo96t/256Y3wh9H4LfD6tcOVurEf53qSBVHlD9JbiooSW6EqWw7r1ZrUnLUas2j/jAgoHjVGqPeyKHfDrFtyjbiD8cDoLPWEfhkIKFjQ0s8mVxFZ47JzXVXT1xlxxc72D9vP4YcAwA1WtagwzsdaNS70W2TnLNJ6oiq09emJgqpoU7+dw+rQghRYpLcVFCS3IjylpytJjXX70rUdoaxoWrfijvRZ+uJmhfF9qnbSb52b8LayZpWo1oR+nIo9p6ls4J1RWPOyc116bHp7Ph8B3u/3UteZh4A1ZtXp8PbHfDr51foMHK9Ef48CosOqV/bW8FzLaBzXaniiPIhyU0FJcmNKC+KAluvVWvSckGngcfvg8ebgOUdqjW56bns/X4vO7/YmT8jrp2HHaHjQmk1shU2Zj4BSlVIbq7LiMtg55c72fP1nvwO4Z4BnrR/qz1NHm1S6EzR51PUvjgnE9XtYG8YHQLuUsURZUySmwpKkhtRHpKy4Ju9cH3txbouarWm/h0GLuWm5xI+K5wdn+8g69q6C061nGj7WluCngnC0q6UVsqs4KpScnNd5tVMdk3bRfiMcHJS1SVj3P3c6fheR+577L5bKjkGI/x9DH45BHkGsLOEZ1pAt3pSxRFlR5KbCkqSG1GWFAU2nVM7Dadfq9YMCFD71xRVrcnLzGPPN3vYPnV7/kzCrg1duf+N+2k2pNldr0JdWVXF5Oa67ORsds/Yza5pu/JXZ/dq5kWnDzrRqM+tfXLOp8D03XBcnTGDFtXVKo6Z3rEUJibJTQUlyY0oK1cz4eu9EH5tEFP9aupIqLpFVGvysvLY+91etk/dTsaVDACq1a9Gx3c70nRgU7QWZjd3Z7FU5eTmupzUHHZN38XOz3fmV3Jqtq5J5w87U7dL3QJJjlGBJcdg/kG1imNrAcNbQM/6UsURpUuSmwpKkhtR2hQFNpyFHyIhIxcstDAwAPr7q18XRp+tZ9//9rFtyrb8PjUudV3o+E5Hmg1pVmWTmuskubkhKzGL7Z9tJ3xGeH7H4zphdej8UWd82hZcYfNCqjqi6liCuh3oBWNCwMuhvKMW5kqSmwpKkhtRmhIyYdYe2HtJ3W7oqlZrarsU3t6QayBiTgRbP9pK2kV1On5nX2c6vN2BwKcC0d2pp3EVIcnNrdJj09k6ZSv7vtuHIVcdQt6gVwM6f9gZ7yDv/HZGBZYdh58PQK5BXXT16ebQq4E6BYEQ90KSmwpKkhtRGhQF1p2F2RGQkadWaAY3VdeFKmRwC4pR4dCvh9j49kaSzqgTlTjVcqL9pPa0GN6iyvWpuRNJbm4v5XwKmz/YTNSPUSgG9SOhyaNN6PxRZ9xumg3yUpraF+fatEg09YSXW0N1qeKIeyDJTQUlyY24V/EZMHMPRFxWtxu7qR8avs63tlUUhdOrT7N+4npio2IBsPeyp8NbHQh6NggL68q7REJZkuTmzq6evMrm9zZzcNFBUEBroSXouSA6vtMRh2v3oYwKLD8JP0VBjgGsdTCsOTzYUKo44u5IclNBSXIj7paiwOrTMCcSsvTq6KehTaGfX+EfFBd2XWDdG+s4t/kcoE6+13ZCW0LHhmJlb1XO0VcuktwU35WDV1g/cT0nl58EwMrBiravtaXN+DZYOai/Z5fTYEY4HIxTjwnwVPvi1HA0VdSispLkpoKS5EbcjSsZMGM37L+ibvu5q31rahXyKxR/NJ4NkzZw7O9jgLpMQsioEO6feD92Mld+sUhyU3LRm6JZO2Etl/aoHcDsvewJey+MFiNaoLPUYVRg5Sn4MQqy9eqyH082g76NpYojik+SmwpKkhtREtc/EH6KUqs1RX0gpMSksHnytb4QRgWNVkPgU4GEvReGc2H3rMRtSXJzdxRF4cgfR1g/cX1+3y63xm50mdJFXdJBo+FKulrFKU6iLsR/SXJTQUlyI4rrSrraIfPAtVJ+Ew94OQRq/ufXJjs5m61TtrJ7+u78hRD9+vnR+aPOZregZXmR5ObeGHIN7P1+L1ve35I/KaRPWx+6fdYNn7Y+KAqsOg1zb77F2gz6SRVH3IEkNxWUJDfiTowKrDgJP+1Xy/fWOngqEHo3KvjGb8gzsPe7vWyevDl/qYTaHWvT9ZOu1AqtZaLozYMkN6UjJzWH7Z9uZ+eXO9Fn6QHwe9iPbp92w7WBK1cyYGY4XOvrjp8bjLlN53ghQJKbCkuSG1GUy2kwPRwO3dTx8uUQ8L6p46WiKBxfdpx1E9Zx9YQ65727vzvdPutGwwca3jI9vig5SW5KV9qlNDa9t4nIOZEoRgWtpZaQ0SF0fLsj1s42rD0DsyMhM0+t4gwOgIdvM62BqNokuamgJLkRhTEq8M8JmLe/6InPLu27xJpX1uSPgLLzsKPT+50Ieiaoys8qXJokuSkb8UfiWfPqGk6tPAWArZstnd7vRPBzwVzN0TJrD+y7NsVBQ1cYFypVHFGQJDcVlCQ34r8uXpuy/mgRU9anxKSw4c0NHFhwAAALGwtCx4Vy/xv3Y+1kbYKozZskN2Xr1KpTrB6/moRrv/QeTTzo/kV36vdowPqz8L+bJqcceG3hV6niCJDkpsKS5EZcZ1RgyXGYf+D2iw3mpOWw7ZNt7PpyF/pstc9CsyHN6PxRZxkBVYYkuSl7Rr2RfT/sY+M7G/P7jDXo1YDuX3RHU9uDb/ZA+LVlRYqzCKyoGiS5qaAkuREAMakwfRccU7vM0Lw6jA4BL3t126g3EjE7gk3vbiIjTl2tu3aH2nT/ojs1WtYwUdRVhyQ35Sc7OZvNH2wmfGY4xjwjGp2Gli+0pOO7YexOt+OHCEi/tiDsE/fBY01uvyCsMH+S3FRQktxUbQajWq1ZcFCt1thZwogW0L3ejWrNmfVnWPXyKuKvLcrj2tCVbp92o/FDjaWzcDmR5Kb8XT15lXUT1nFsiTr5pLWzNR3f6UiDESF8t1/H7otqu7oual+celLFqZIkuamgJLmpus6nqH1rrg1wItgbRrUCj2vVmsTTiax9dW3+m7utqy0d3+1IyxdaysKW5UySG9M5u/Esq8et5sq1Wf5cG7jS9dNuXGnRmO/2aUjPBZ0GHr8PHm+ijq4SVYckNxWUJDdVj8EIfx6FhYdAbwR7S3g2CLrUVas1OWk5bP14K7u+3IUh14BGp6HVyFaEvReGrautqcOvkiS5MS2jwUjUT1FsmLSBjCvqbdl6XevR5ote/J7qzo4YtV1dF3XR2AaupotVlC9JbiooSW6qluhktVpzKlHdblUDXmoF7nagGBX2z9/P+jfWkx6bDkC9bvXo8VUPPO/zNF3QQpKbCiInLYdtU7ax84udGHINaC20tBodguWznZhz1IrUHHWqhEf9YUCAujyJMG9l8Rlqtl24tmzZQocOHdi0adMd2yqKwqRJk3j22WcZPHgw//zzT9kHKCodvREWHYKxq9XExt4KxofCOx3UxObCrgvMaTOHpcOWkh6bTrX61RiwdABDVg+RxEaIa6wdrenycRdGHhlJ44caY9Qb2f3VLiLDZvBi0gHu91EwKvD7EfX/2vVbvkKUhIWpAygLW7duZd68eWzdurVY7SdNmkR0dDQLFy4kMzMTPz8/vL29admyZRlHKiqLM0lqtebauoGE1FT71rjaQurFVNZPXM+B+ep8NVYOVnR4uwOtX26NhbVZ/hcT4p651ndlwJIBnFp1ilVjV3H1+FU2PPM3NVrt5tkP+/FHhgfnU+DVtfCIPwySKo4oAbO9LXXs2DH8/f3ZuHEjYWFht2138eJF6tWrx/Lly+natSsAL7zwAidPnmT9+vXFei25LWW+8gzwxxH47TAYFHCwgheCoWNtMOTo2fnlTrZ+vJW8jDwAmj/dnC4fd8GhusMdzizKm9yWqrgMuQZ2z9zN5smbyU3LBaDRiJaceaIbOxOsAPBxUvvi+LmbMlJRFuS2VAnY2NgUq92yZcvIzc0lKCgof19wcDAbN24kLi6urMITlcCpRBi/Ru00bFCgrQ98+wB0rK1w7O+jfO3/NRsmbSAvI49abWrxTPgzPDT3IUlshCghnZWOtq+0ZdTxUQQ+FQjAiTl70T36Jf0uH8bZSiEmFSasU1cdz9GbOGBR4VX5mnl4eDharZZq1W5MsODp6YmiKOzfv59u3bqZMDphCrkGtVLzxxF1xmEna3gxGO73hYSj8cwfs5Kz688C4FjTkW6fdiNgYIDMVyPEPXL0dqTfT/1o+UJLVo5eyaW9l7j4ymKCm3qT+PqjRGld+esY7LoI41qDv4epIxYVVZVPbuLi4nBxcSnwweToqC7XnJCQUOgxOTk55OTk5G+npqaWbZCi3Jy4qvatOZ+ibt/vAy+0BNu8HNa+tpnd03dj1BvRWetoN6Ed7V5vh5W9lWmDFsLM1AqtxTO7nyHqpyjWvbGOtIOXsRwyk3ZPtedA9/ZcSrNkwjro2xiGNlMXpRXiZpXqV2L06NFERkYW2Wbbtm0lOqdGo8HWtuC8IwaDAQBLS8tCj5kyZQqTJ08u0euIii3XoN5++uuoWq1xtoYXW0I7H4WDCw+y9rW1pF9Wh3Y37tuYHtN6UE0WxRGizGi0GloMb4H/I/5smryJ8Jnh5M7bSsO/95LyxmOc8q3N0uNa9lxSF6UNkAGJ4iaVKrmZOXNmqZ/T29ubzZs3F9iXnq5+iHl4FF7znDhxIuPHj8/fTk1NxcfHp9RjE+XjeIJarYm5VoDr4AvPt4TsE1eYN3Ql57acA9RZVXtO70nDBxqaMFohqhYbFxt6ftWT4GeDWXntlrDrmz/TpHVjzj7dm0vYM3G9ht6N4KlAqeIIVZX/NQgMDGT27NlkZmZiZ2cHQGxsLBYWFgU6Gd/M2toaa2vr8gxTlIEcvVqt+fuYWq1xsYGRLSHIMZuNEzay5+s9KAYFC1sL2k9qT9tX2mIh75xCmIRHEw+Grh3Ksb+PsXr8ath9HL/IM1x65kEutbyPf05YsOcSvBwCTb1MHa0wNbMdLVVcTzzxBJaWluzevTt/34EDB+jevXt+3xthfo7Gw5hV6hIKRgU61YGveyrYbYhiVuNZhM8IRzEo+Pf3Z9SxUXSY1EESGyFMTKPR4P+IPy8deYn2b7XHBiO1v1lCw4/no7mQwOVUIxM3wLd7ISvP1NEKUzLb5CYvT/3N1usLjhmMjY0lODg4fw4bDw8PRo4cyd9//w1AWloaK1eu5IMPPijfgEW5yNbD7Ah1SOnFNHUSvrc7wCCby/zZ9UeWDltKRlwGbo3dGLJmCI8vfhxnX2dThy2EuImlnSWdP+jMi4depH6P+rifOk/gWz/gvHQX2cnZLD8Jo1ZCVKypIxWmYpZ/ih44cIBvvvkGgO+++w4HBwdCQ0MBdaRTdHQ0KSkp+e0/++wzxo8fz5gxY0hKSmLOnDm3vSUlKq9DcTAjHC6lqdtd6sKQOlmEf7CB1d/tQzEqWNpb0vGdjoSODZVVu4Wo4NwaujF45WCO/nWU1WNXY/nHWlx3H+bk0Ae41MCLtzZa0LM+DG8BdoWPDxFmymxnKC5PMkNxxZath3n74d8ToAButjCqpYJuVSTrJ64nMyETgPueuI/un3fHqZb8DM2RzFBs3nIzctnywRZ2frGTXI2WY53bENetFQ7VHfB00DA6BIK8TR2lKExZfIaaZeVGiOsOxsH03XBtgW661YMHlMts7r+ci+EXAbWjYq9Zvajbqa4JIxVC3Asreyu6ftKVwKcCWTlqJRart5Jw5BSHHu7KBf8avLPJhu71YURzddFbYd4kuRFmKSvvWrXmpLrtZgvP+WWT+OVaFs6OAAWsHK0Iey+MkNEh6CzlFpQQ5sDD34Oh64Zy+PfDrBm/BpdvF3H0/hAudQ5mZa4T+y5ZMDoEWtYwdaSiLElyI8zO/li1b82VDHW7Zz2F4EMH2Hr/arKuZgHQbEgzun7aFUdvGREnhLnRaDQEPBFAwwcasnnyZiyn7cT75Bn29wrjnF8N3s10oHt9DSNaqIvhCvMjyY0wG1l5MDcKVp5Stz3tYYjbVaJfWcqa7THqvgBPHvj6AWp3qG26QIUQ5cLa0Zrun3en+bDmrHhpBS4//sGx+1txvm1z/k1zYd9la0a1gpCapo5UlDZJboRZiIyFGbshXu0bTA9fPXWWbGLbVztQDOooqLD3wmj9cmu5BSVEFeMZ4MlTm57i4C8HWfPqGrxPnCWqR0dO1/fi3VRnujbU8VwQOMrcrGZDkhtRqWXkqtWa1afVbS97hb6Z0ZwZsISIC+p6Cv6P+NNjWg+cfWS+GiGqKo1GQ7MhzWjUuxEb391ItW//4mibYM6ENOPfRCciL9szKkRDaC1TRypKgyQ3otLaewlmhsO1bjR0dsvEdeY/RP17DACXui48MOsBWQtKCJHPxsWGXtN70eLpFiwfuZwDv6hVnJNX3Xkn0YVuTax4PhicpIpTqUlyIyqd9FyYEwlrz6jbXnZGOh6OImb4Ss5l69Faamk3oR3t32yPpczcJYQoRPXm1Rm+bTiRP0ZS/Y0VRPnfx6mWzViWYE/EBUdGtdHRTtZDrrQkuRGVyp6LMHMPJGaBBminvYr1xN85ezQOgLqd6/LANw/g3tjdtIEKISo8jVZD0IggGvdtzNrX1rJp0VIie3TkVLIb78Q70b25LS8Ea3C2MXWkoqQkuRGVQloO/C8CNkSr256WeTRftZmkOdvJAey97OnxZQ8CBgag0WhMGaoQopKx97Cn30/9aL4pmmUvrWRHNV9OhjRnSUIm+846MaaDFff7mjpKURKS3IgKb/dFmBUOSdmgQaFF/HmsJv9OUmImaKDVS63o/EFnbFzkzyshxN2rE1aHlyKfo8XnO1j63T/s7Xw/p9NzmXTFkW7B9owK1SJvM5WDJDeiwkrNgR8iYFO0uu2mz6LBT8sxbjiMAajRsgYPfvcgNYJlqlEhROnQWelo/2Z7AgYE8M+olaw86cSJ1s1ZlpjJ3pOOjOtuRwdfkAJxxSbJjaiQtsfAt3shORswGPE7chS7z/7GqDdg7WxNlyldCH4uGK1Oa+pQhRBmqFq9agxdPpDgxUdYNHkN24NacT7bwJtxOXQNtmdsRyuq2Zo6SnE7ktyICiUlG77fB1vOAyg4JadQe9bf2Bw5D6jLJnT7vBsOXg4mjVMIYf40Gg33PXYfb/dowNq3N7JwVzTHW7dg+YZs9p6wZ/yDDnSup5UqTgUkyY2oMLadV6s1KTlgyM6j3tZ9uP28Fp3BiLufOw9884Cs3C2EKHfWTtb0nt6ToH2X+Pm1bayu6cdlg8KkeTl0bGbLhAcccLMzdZTiZpLcCJNLzlaTmu0xoBgV7C7G4TPjL5wvxmFha0GHt8No+0pbdFaybIIQwnRqBNdgwtpH6fjNXr77M5LDLQJZtyuPiFM5vNLHiR5NLKWKU0FIciNMRlFg67VqTVou5KVlU2vFTmr+uw2dwUjDBxvSa2YvqtWtZupQhRACAK1OS5vRIQT0T+OXidv43VCDq4oHby+4yvIGVrwzoBoe9pLhmJokN8IkkrLgm72w8wJqJ+FTl2j03VKc467i4O1Ar5m98H/EX+asEUJUSI41HHlhXi86rTrFF7MOE9HQj+1HjDzycSzPt9YxqLcHWq28f5mKJDeiXCkKbDqndhpOz1XITsik5rJt1NkQjlYx0mpUKzp/2BkbmRJUCFEJNO7ZgK871ubPT/Yw+7Q9iV4efLlZzy8L9vJA8hn8WrjiHeRNjeAaVKtfTf5gKyeS3IhyczUTvt4L4RdBn52HxaHzNJu/Auf4RLwCvejzQx9qhtQ0dZhCCFEilraWDJjclvb7LjPxpd0cDQ3mik9N5lf3JGDNbnw/3YEGsHKwUhOdkBrUCK6Bd7A3rvVd0UiFp9RJciPKnKLAhrPwQySkZytkXk6l5t9bqL8rEmsbC8I+70boy6FoLWTOGiFE5VUz2Juxz/qycMKfRPXoSKK3F1Gd7yemUX2ar9mCQ3Iq57acI2ZnDMY8I6DOpzPm9BgTR25+JLkRZSohE2btgb2XICc1B4uoswT9sQanq0k0fLAhD3z9AC61XUwdphBClIrmw5qz84udOPy2jDPNAzjSPoTTrZpxom0w1mkZNAyPwis6Bo/oC9ilZeBUywmjwSgTkpYySW5EmVAUWHcWZkdAWpaB9PMp+C7bQv09B3Cqbk+vxY9Jh2EhhNnR6rT0nNaTBT0WUD/iEJ5nzrPs1ecwWFqS42jPoS7tOHStbTUlh3aNrDAe0BDkDU08QGa8KB2S3IhSF58BM/dAxGWFzIQsLCLP0GrZepwSk9VFLqXDsBDCjNXvXp963epxdsNZHJNTaf/LEtY9P/iWdkkaa1aeguUnQQEstXCfB7SsAW/eD1LMuXuS3IhSoyiw+jTMiYS09DzSzyZRZ9V26u89iHczT/qseEY6DAshqoQeX/bg22bfAuBz9BTu5y9xtVZ1FG3BjMWg3Pg6zwhRV9THU4Hg61yeEZsXSW5EqbiSATN2Q9RlhfTYNKwizhC6ahOu2ZmEfdZVOgwLIaoUzwBPWgxvQdRPUWiANtu388/Ax4o8RqsBV1v4tKskNvfKbD9ttmzZQocOHdi0aVOx2i9duhSNRpP/eOGFF8o2QDNhVNSS6qgVEH4yh8SDsdRetI52i5YS1MaTkUdG0vaVtpLYCCGqnE4fdKJavWo07tOYqf88SKCXmsDcTn9/2PAkdJEl9O6ZWVZutm7dyrx589i6dWuxj/n111/56quv8rcffvjhsgjNrFxJh+m7IeqSgdSYVGwPnOX+1ZvxtlPo+Yd0GBZCVG2O3o6MPjE6f/u1NjBkSeFtv38QejYon7iqArNMbtq3b4+Hhwdz584tVvtt27bRpk0bxoyRuQaKw6jAipPw036FxNgsMs4l4rdhF3X3HyZkZCu6fNQFaydrU4cphBAVyv2+0NwLDsSp20YFBgbApPvBUd4yS5VZJjcANjbFH40zdepUIiIiOHToEBMmTKBBA0mfb+dyGkwPh6jzeaScS8Hh6Dk6rt5MvTp29NkpHYaFEOJ2NBp4rS0M/huq28MX3dWER5Q+s01uiisjIwMXFxdq1arFnDlzmD9/Pr/99ht9+/a97TE5OTnk5OTkb6emppZHqCZlVOCfE/BTpELixTSyzifjv2U3jU6epPP7nWg9prX0qxFCiDu43xe2DlM7DjtYmToa81Xlkxt7e3vmz58PwMGDBxk0aBADBw7k2LFj+Pj4FHrMlClTmDx5cnmGaVIXU2Habth/Nofkc8m4nIwhdPVmmneoQa8lI2WGYSGEKAEZCVX2KlVyM3r0aCIjI4tss23btrs+f9OmTVm7di1NmjRh/vz5vPnmm4W2mzhxIuPHj8/fTk1NvW0iVJkZFVhyHOZFGLh6Lo3cyynct3k398XH8MDcXtJhWAghRIVUqZKbmTNnlvlrVK9eneHDhxMdHX3bNtbW1lhbm3fvr5hUmLZLIepkNqkxKbiejqHdmi10GOxHlykvyQzDQgghKqxKldyUl3r16pGQkGDqMEzCYLxWrdmrJyE6BX18Ok037SRIf5W+Kx7Dt530fhNCCFGxSXJTiIMHD/LKK6+YOoxydz4FvtqpEHU8g9SLaXicjiFo03Z6vBxEu9cfxcJafl2EEEJUfGY7vCUvLw8AvV5fYH9sbCzBwcGsX78eUGcmfuaZZ4iNjQVg4cKFNGnSpEoNBzcY4ffD8OJfuezckUDmqQSar9jE43GHGbdtCB3f6SiJjRBCiErDLD+xDhw4wDfffAPAd999h4ODA6GhoYA6jDs6OpqUlBQAqlWrxrp16/j9999p27Yto0aNYtCgQSaLvbxFJ8OX241EHU0nIzYdzzPnabUrnL7vtiX42WA0Rc0VLoQQQlRAGkVRlDs3E0VJTU3F2dmZlJQUnJycTB1OseiN8McRmLcjm8ToFDSpmTTduJNu/hY8MKMXjjUcTR2iEKWqb9++LFu2zNRhCCH+oyw+Q82yciOKdiYJvtiiZ/+RdDITMql+5hxtD0Xx6Oed8HvIz9ThCSGEEPdEkpsqJM8Avx9R+GlLFkkxqVikZRG8cTv9OrvSdd5wWQ9KCCGEWZDkpoo4nQSfrs/l4JE0slNy8D4VTecLR3l8Tnd82pjfBIRCCCGqLkluzFyuAX49aOSnTZmkXEzDMjOLkM27GDigFvf/MQydlc7UIQohhBClSpIbM3biKkxdncWhY+nkZeRR48QZHsg+z+N/dse9sbupwxNCCCHKhCQ3ZijXAAsiDMzblE76lQysMrNou3sPw19sRIvhA2V4txBCCLMmyY2ZOZ4AkxencOp8NvocAzWPn+Yxp0QeWd4bh+oOpg5PCCGEKHOS3FRyWYlZXNp7ieg9l/jzvA3hjjUwKhqsM7O4f38Ez09sRuM+7U0dphBCCFFuJLmpRHIzcrkccZlLey5xMfwiF3ZeIOV8ConenkT27Eh6NRdQoNbRU3RPO8uzqwdg7SjDu4UQQlQtktxUAtFboln+/HKunriKYlTUPjMayNNoOdYxlDPBAShosMnMJHDNVmonXOG5i+OxcrAydehCCCFEuZPkphJIPJFIwrGE/G3FqHC1phdR3TuSXs0ZAJ8jJwnYuAOrnFw6z+wliY0QQogqS5KbSiDomSDsPOxY+vRSMjINHGnTkrNB96nVmowMAtdspfrZGNCAk48Twc8FmzpkIYQQwmQkuakk/B7yI3F9Dd74LpZ0B3XUk+/h4wRs2oVlTq7aSIEuU7rIxHxCCCGqNEluKoGsPPhs4RWWHDCAgwO26RkErtmC1/kLYFTbaLQa3P3daTqwqWmDFUIIIUxMa+oARNH2x8ILS/QsPWgAoPbBY0zvpGfK5kep3b52fjvFqNDts24yQZ8QQogqTyo3FVRWHsyNgpWnACyo6WVN2In9jPrr/vzOwk9teIrwWeGsfW0ttdrWokHPBqYMWQghhKgQJLmpgKJiYfpuiM9Ut3s1gOGPumFr2blAO41WQ+sxrWk+rDlWjlZoNFK1EUIIISS5qUAyctVqzerT6raXPYwJgcDqRR9n7SQT9QkhhBDXSXJjYgajunr338dh2XFwtgZLHfRuCE8Fgq2lqSMUQgghKhdJbsrZ1Uz1ttO+WNh7Sf06x3DjeXtL+Lw7NPU0XYxCCCFEZSbJTRnSG+FoAkRehojLEH4JLqapz+k0YFAKtrfQwoKHwdux/GMVQgghzIUkN2XovU0w/yBoAO1/kpn/JjYa4IVgSWyEEEKIeyXz3JShoBpgrbs1sSmMjQU8G1Q+cQkhhBDmTJKbMvSIH6wbCi1rFN1Oq4FngsDFpnziEkIIIcyZJDdlzNcZfu0PH3W6fRsbHTzbovxiEkIIIcyZWSY3n332Gb6+vri5uTF06FCuXr1aZHtFUZg0aRLPPvssgwcP5p9//inVeLQaGNIM/h0IbWvd+tyzQeAsVRshhBCiVJhdh+K5c+eyY8cOpk6dyv79+/niiy+4dOkS69evv+0xkyZNIjo6moULF5KZmYmfnx/e3t60bNmyVGNr6gkLH4HfDsPkzZCpV/vajJC+NkIIIUSpMbvkJiYmhr///huAgQMH4uDgwNtvv82ZM2eoV6/eLe0vXrzIF198wfLlywGws7PjgQce4PXXXy8yIbpbGg0MCIAOteGrXRBWR524TwghhBClw+xuSz377LMFtvv06QNAYmJioe2XLVtGbm4uQUE3yifBwcFs3LiRuLi4MouzhiN81g0ebFhmLyGEEEJUSWaX3NSoUXBokl6vx8HBgYCAgELbh4eHo9VqqVatWv4+T09PFEVh//79ZRqrEEIIIUqf2d2W+q+1a9cyatQobGwK77EbFxeHi4tLgRW1HR3VmfQSEhIKPSYnJ4ecnJz87ZSUFABSU1NLK2whRCnLy8uT/6NCVEDX/18qyh0mhCuBSpXcjB49msjIyCLbbNu2Lf/rjIwMli1bxsqVK2/bXqPRYGtrW2CfwaAu9mRpWfiqlVOmTGHy5Mm37Pfx8SkyNiGEaTk7O5s6BCHEbVy9erXU/o9WquRm5syZJWr/1ltv8dVXXxX5zfL29mbz5s0F9qWnpwPg4eFR6DETJ05k/Pjx+dvJycnUrl2b8+fPm/WbZ2pqKj4+PsTExODk5GTqcMpUVblWuU7zItdpXqrKdaakpODr64urq2upnbNSJTclsWjRIgIDA2ndunWR7QIDA5k9ezaZmZnY2dkBEBsbi4WFRYFOxjeztrbG2vrWIU7Ozs5m/Qt4nZOTU5W4Tqg61yrXaV7kOs1LVblOrbb0ugGbXYdigM2bN3P69GmGDRuWv+92I5+eeOIJLC0t2b17d/6+AwcO0L179/y+N0IIIYSoPMwuudm7dy/vvPMOLVu2ZNWqVaxcuZI5c+YwZcoUQK3KBAcH589h4+HhwciRI/PnxklLS2PlypV88MEHJrsGIYQQQtw9s7otdfLkSbp3705SUhJbtmwp8NzixYsBdaRTdHR0/ggnUJdrGD9+PGPGjCEpKYk5c+bc9pZUYaytrXn33XcLvVVlTqrKdULVuVa5TvMi12le5DrvnkYpzbFXQgghhBAmZna3pYQQQghRtUlyI4QQQgizIsmNEEIIIcyKJDd36bPPPsPX1xc3NzeGDh3K1atXi2yvKAqTJk3i2WefZfDgwfzzzz/lFOm927JlCx06dGDTpk3Far906VI0Gk3+44UXXijbAEtJSa6zsv48k5KSGDJkCGPHjmXAgAGcOHHijsdERUUV+Hn27NmzHCItuQ0bNvD4448zatQoxo0bh16vv23bu/k+VBQluU6AcePGFfj5/frrr+UU6b3Lzs5m+vTphIaG3rHtuXPneOKJJxg3bhxDhgwhNja2HCIsHSW5ToCHH364wM90165dZRzhvYmNjaV///44OzvToEEDvv322yLbl8rPUhElNmfOHKVfv37KwoULlddff12xsLBQOnfuXOQxEydOVAYOHKgoiqJkZGQoPj4+yp49e8oj3HuyZcsWZfjw4QqgbNy4sVjHDBgwQPnqq6/yH9HR0WUbZCko6XVWxp+n0WhU2rVrp3z//feKoijKvn37FF9fXyU1NbXI45577rkCP88DBw6UR7glEhUVpXh5eSnx8fGKoijK6NGjlbFjxxba9m6/DxVBSa5TURQlMTFR6dOnT/7Pbvr06UpeXl55hXtP8vLylLlz5ypNmjRRateuXWTbjIwMpX79+srq1asVRVGUP//8U2nZsqWi1+vLIdJ7U5LrVBRFOXbsmPLYY4/l/0x/+OGHsg/yHvXq1Ut59913lQULFihdunRRAOXnn38utG1p/SwlubkL7733XoHtDz74QAGU06dPF9r+woULipWVlbJ27dr8fc8///wdE6KK4ujRo8X+0N+6dasyffr0sg+qDBT3Oivrz/P3339XLC0tlczMzPx9jRs3Vt5///3bHnP27FllwoQJ5RHePXnggQeUwYMH52/v3LlT0el0ytmzZ29pezffh4qiJNepKIry4YcfKvv37y+n6MrG66+/fscP/U8//VSpWbNm/rZer1fs7e1v+wFaERXnOhVFUUaNGqVcuXKl7AMqJYcOHVL++OOP/O28vDylcePGSvv27QttX1o/S7ktdReeffbZAtt9+vQBIDExsdD2y5YtIzc3t8DcOcHBwWzcuPG2MydXJLdbUb0wU6dOZerUqTz33HOcOnWqDKMqfcW9zsr681y8eDF+fn4FFooNDg7mt99+u+0xX3zxBXPmzGHw4MFERESUR5gllpqaypo1awr8PJo3b46iKPnzW93sbr4PFUFJrzM7O5sZM2YwcOBA3nvvvUq7Inpx/l8uXry4wPdFp9MRGBhY4X+mNyvOdV6+fJk5c+bQq1cvvvzyS3Jycsohsnvj6upK//7987ctLCzo1avXbT8vS+tnKcnNXahRo0aBbb1ej4ODAwEBAYW2Dw8PR6vVUq1atfx9np6eKIrC/v37yzTW8pSRkYGLiwu1av2/vTsPiTL/4wD+Ho/psvKgY8oSy0gHzV3tjmz/CGuD2OgyxT9SC0Gshbbs0IIQOinp2N2oLFo718xODCxCd8HVTbQEAyuzQyizc8zUceb7+0Oa306ONaMz8zjf3i8QHp/nq34+34+jn3lOf2RnZyMsLAyXL19WOiy7c9V6lpWVwc/Pz2zd0KFDce/ePYt/JIUQ0Ov10Gq1yM3NxeTJk796rFwJFRUVaG9vN8utb9++GDRoECoqKjqNt3Ueegtb86yursYPP/wAvV6PrVu3YsKECbh//74zQ3YKg8GA8vJyizW1NC+urKqqCj/++CMaGhrwyy+/YOrUqXj58qXSYX2RRqOBSqUyW9fe3m7x/CJ71pLNjR0UFhYiNTW1y867oaEB3t7eZgX+9NyqxsZGp8ToDAMGDEBOTg5KS0tRWVmJoKAgxMbG4unTp0qHZleuWs+GhoZOT90dOHAgjEajxXdRKpUKhw4dQnFxMe7fv48ZM2YgNTUV//77r7NCtsqnvWWWcrNUD1vnobewNc+IiAicO3cONTU1yM/Px9u3b7FkyRIIye7b+vr1axgMBqvnxZVFR0cjLy8PT548weHDh1FdXY2kpCSlw7LZrVu3sGbNmk7r7VlLqR6/YA+rVq36aof4999/m5Y/fPiAy5cvo6CgoMvxKpXKbBc40NGhAoCnp2cPou0+W/O0VVhYGAoLC6HVapGTk4NNmzZ1+3v1hCPydNV69iTugIAAXLt2DREREThy5AgmTZrUs4Dt6FOTaSk3S3n1xvpZw9Y8/2vBggX4888/MWfOHJSUlGD69OkOi9PZejIvrkqlUmHlypUQQiA5ORn19fUYOXKk0mFZJT8/H7Nnz4ZWq+20zZ61ZHPzmQMHDtg0PiMjA1lZWRg8eHCXYzQaDYqKiszWNTU1Aeh4cKcSbM2zO4YPH47ExETU1dU5/Gd1xRF5umo9x40bZ/ZMNaAjbnd3907vlCzx8vLC6tWre92hRo1GAwAWc7NUD41G06N5UIqteX4uOjoakZGRqKurk6q58fPzg1qt7va8uLKkpCRs3rwZjx8/donm5s2bNzh58iTOnDljcbs9a8nDUj1w5swZhIeHY8qUKV8cFx4ejqamJjQ3N5vWPX/+HB4eHjY9oNMVjRkzBv7+/kqHYVeuWs/w8PBOJzw/f/4ckZGRcHOz7k9Bb6xnSEgIPD09zXJrbm7G+/fvMXny5E7j7TEPSrA1T0t6Y/16SqVSISwszGJNrZ0XV+Xu7o6AgACXqKnBYEBaWhr2798PtVptcYw9a9l7X8m9XFFRER4+fIjly5eb1nV1pUxMTAw8PT1RWlpqWnf37l1ER0ebztWQVVVVFeLi4pQOw65ctZ7x8fG4c+eO2Umzd+/exeLFi63+HuXl5UhISHBEeN3m6+uLefPmmd3IrKqqCmq12nQl43/ZYx6UYGuenzMYDPj48aNUe20+iY+PN5uX9vZ23Lt3r9fXtKd0Oh1GjRqF0aNHKx3KV23cuBEpKSlme5gs/c+0Vy3Z3HTD7du3sWXLFkycOBHXr19HQUEBsrOzsX37dgD/fxd48+ZNAB2HKlJSUpCfnw+g4xeyoKAAmZmZiuVgC71eDwCd7oT6eZ6XLl3CihUrTHeTPH36NLRaLYKCgpwbcDdZm6er1nP+/PkIDQ3FtWvXAHRcNdTa2oqUlBQAQGtrK2bOnImcnBwAwD///IPY2FjTJf2FhYVoa2vDzJkzlUngCzIyMnDz5k3T3rQTJ07g559/hr+/P27cuIGJEyfixYsXAL4+D72ZLXlu3boVmZmZaGlpQVtbG9LT07Fx40Z4eLjW2Qh6vb7Ta/KPP/5AVFSUqUFNSkqCEMJ0u4ILFy5Aq9WaXYLc21mTZ0pKCn799VcYDAbodDqkpaVh586dSoRrk/T0dBiNRrx48QLXr1/H1atXkZaWhtu3bzuuljbdFYdETU2N8PHxEQA6fZw/f14IIURdXZ3w9fUVeXl5pq9ra2sTqampYtWqVSI+Pl7cuHFDqRRscufOHZGcnCwAiEWLFomSkhLTts/zLCoqEgEBAWLgwIFizpw54sqVK0qFbTNb8hTCdetZX18vYmJixLp160R8fLyora01bWtqahL+/v4iKytLCNFxU8Pg4GDRr18/MWvWLHH8+HFlgrZSfn6+WLZsmUhNTRXp6enCYDAIIYTIzc0Vfn5+4vHjx6axX5qH3s7aPPft2ye8vb2FRqMRS5cuFdXV1UqG3S3nz58XoaGhws3NTWRlZZluXrdnzx4xatQo0dTUZBpbXV0tFi9eLNauXSsSEhJEY2OjUmHbzNo809LShJeXlwgMDBTLly8Xz549UzJsq+zevdvi/0sfHx/R1tbmsFqqhJDsukAiIiL6pvGwFBEREUmFzQ0RERFJhc0NERERSYXNDREREUmFzQ0RERFJhc0NERERSYXNDREREUmFzQ0RERFJhc0NERERSYXNDREREUmFzQ0RERFJhc0NERERSYXNDRFJ6dGjRzh48CDi4uIwYcIEeHt7w8PDA4MGDUJYWBhWr16NmpoapcMkIgfgU8GJSDqXLl3CggULvjquT58+OHbsGOLi4hwfFBE5jYfSARAR2VtpaSnc3d0RGRmJ6dOnY/z48fD19UVLSwvq6+tx8eJFlJWVobW1FYmJiZg2bRoCAwOVDpuI7IR7bohIOsXFxQgJCcGQIUO6HLNr1y6sX78eAJCZmYmMjAxnhUdEDsbmhoi+SXq9Hn379oXRaERcXBxOnTqldEhEZCc8oZiIvkkfPnyA0WgEAPA9HpFceM4NEUnHaDTi1q1buHDhAsrLy/Ho0SO8e/cOra2tFsePGDHCyRESkSOxuSEiqZSVlSE5ORmVlZVWf01ISIjjAiIip2NzQ0TSKCgowMKFC9HS0gIACAwMxOzZsxEcHIxhw4ahX79+cHPrOBq/d+9e/PXXXwCA77//XrGYicj+eEIxEUmhsbERwcHBePXqFfr374+jR49i2bJlUKlUFsePHTsWtbW1UKvV0Ol0UKvVTo6YiByFe26ISAo5OTl49eoVAGDHjh2IjY3tcmxlZSVqa2sBAKGhoWxsiCTDq6WISAolJSWm5fnz539x7LZt20zLkZGRDouJiJTB5oaIpPDu3TvTsk6n63LcyZMnkZuba/qczQ2RfNjcEJEUAgICTMu///57p+1CCPz2229ITEw0Wx8REeHw2IjIuXhCMRFJobi4GLNmzTJ9PnfuXPz000/w8fHBgwcPcO7cOVRVVWHKlCl48+YNampq4OnpCZ1Ohz59+igYORHZG5sbIpLGhg0bsHPnzi63x8TE4NChQxg5ciSam5vx3XffoaKiwokREpEz8LAUEUljx44dyMvLQ1RUFLy8vNC/f38EBQUhISEBRUVFOHv2LF6/fo3m5mYAPCRFJCvuuSEiIiKpcM8NERERSYXNDREREUmFzQ0RERFJhc0NERERSYXNDREREUmFzQ0RERFJhc0NERERSYXNDREREUmFzQ0RERFJhc0NERERSYXNDREREUmFzQ0RERFJhc0NERERSYXNDREREUmFzQ0RERFJ5X8yTmQSyPLpRQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(6, 4))\n",
    "x = np.linspace(0.1, 2, 500)  # Avoid x = 0 to prevent division by zero\n",
    "\n",
    "# Calculate the corresponding y values using xy = 1\n",
    "y = 1 / x\n",
    "plt.plot(x, y, color='darkorange', linewidth=2, label='Ground Truth')\n",
    "plt.xlim(-2, 2)\n",
    "plt.ylim(-2, 2)\n",
    "plt.axhline(0, color='k', linewidth=0.5)\n",
    "plt.axvline(0, color='k', linewidth=0.5)\n",
    "\n",
    "\n",
    "def add_arrows(x, y, n_arrows, color):\n",
    "    \"\"\"Add equally spaced arrows to a curve.\"\"\"\n",
    "    for i in range(n_arrows):\n",
    "        idx = int(i * len(x) / (n_arrows + 1))  # Choose indices for arrows\n",
    "        dx = x[idx + 1] - x[idx]  # Change in x\n",
    "        dy = y[idx + 1] - y[idx]  # Change in y\n",
    "        plt.arrow(\n",
    "            x[idx], y[idx], dx, dy,\n",
    "            head_width=0.1, head_length=0.1, fc=color, ec=color,\n",
    "            length_includes_head=True\n",
    "        )\n",
    "\n",
    "        \n",
    "for case in range(4):\n",
    "    a1, w1 = result_dict_mw[case]\n",
    "    a2, w2 = result_dict_standard[case]    \n",
    "    plt.plot(a1, w1, color='purple', label='Sign In GF')\n",
    "    add_arrows(a1, w1, 5,'purple')\n",
    "    plt.plot(a2, w2, color='dodgerblue', label='GF', alpha=0.8)  \n",
    "    add_arrows(a2, w2, 5, 'dodgerblue')\n",
    "\n",
    "    if case == 0:\n",
    "        plt.legend(loc='upper left', fontsize=14)\n",
    "plt.xlabel('$a$', fontsize=22)\n",
    "plt.ylabel('$w$', fontsize=22)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 454,
   "id": "65b5bed7-9e2f-4070-9a23-7ac91830a719",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "initial mw parameters: a = 1.0000000000000002, w1 = 0.06190399316590347, aw=0.06190399316590349\n",
      "during training parameters: a = 0.7226786906099584, w1 = 1.3837408145780592, aw = 1.000000000022829\n",
      "initial mw parameters: a = -0.9999999999999992, w1 = 0.026889219676463037, aw=-0.02688921967646302\n",
      "during training parameters: a = 0.7334866307034051, w1 = 1.3633513661351815, aw = 1.0000000000113787\n",
      "initial mw parameters: a = -1.0000000000000002, w1 = -0.12025404226871184, aw=0.12025404226871186\n",
      "during training parameters: a = 0.7350647531690164, w1 = 1.3604243649322167, aw = 1.000000000014016\n",
      "initial mw parameters: a = 1.0000000000000002, w1 = -0.04181073897072066, aw=-0.041810738970720664\n",
      "during training parameters: a = 0.8745135213223864, w1 = 1.1434928970427685, aw = 1.0000000000000084\n",
      "Total success rate: 0.04\n"
     ]
    }
   ],
   "source": [
    "# MW multi dim case\n",
    "\n",
    "def relu(x):\n",
    "    return np.maximum(0, x)\n",
    "\n",
    "# Define derivative of ReLU\n",
    "def relu_derivative(x):\n",
    "    return np.where(x > 0, 1, 0)\n",
    "\n",
    "d=5\n",
    "np.random.seed(42)\n",
    "num_samples=500\n",
    "x = np.random.randn(num_samples, d)  # Input data (100 samples, 1 feature)\n",
    "y_target = relu(x[:, 0])\n",
    "\n",
    "alpha1 = 0.5\n",
    "alpha2 = 0.1\n",
    "\n",
    "\n",
    "def initialize_aw(case):\n",
    "    if case == 0:\n",
    "        w = np.random.randn(d)\n",
    "        w[0] = 0.1\n",
    "        w = w / np.linalg.norm(w)\n",
    "        a = np.sqrt(np.sum(w**2))\n",
    "    if case == 1:\n",
    "        w = np.random.randn(d)\n",
    "        w[0] = 0.1\n",
    "        w = w / np.linalg.norm(w)\n",
    "        a = -np.sqrt(np.sum(w**2))\n",
    "    if case == 2:\n",
    "        w = np.random.randn(d)\n",
    "        w[0] = -0.1\n",
    "        w = w / np.linalg.norm(w)\n",
    "        a = -np.sqrt(np.sum(w**2))\n",
    "    if case == 3:\n",
    "        w = np.random.randn(d)\n",
    "        w[0] = -0.1\n",
    "        w = w / np.linalg.norm(w)\n",
    "        a = np.sqrt(np.sum(w**2))\n",
    "    return a, w\n",
    "\n",
    "\n",
    "# Initialize parameters\n",
    "def initialize_params(w, alpha=0.5):\n",
    "    u = np.sqrt(w + np.sqrt(w*w + alpha*alpha))\n",
    "    w1 =  (u + alpha/u)/np.sqrt(2) \n",
    "    w2 = (u - alpha/u)/np.sqrt(2)\n",
    "    return w1, w2\n",
    "\n",
    "def rescale_mw(w1, w2, alpha=0.5):\n",
    "    x = w1 * w2\n",
    "    u = np.sqrt(alpha + np.sqrt(x*x + alpha*alpha))\n",
    "    w1 = u\n",
    "    w2 = x/u\n",
    "    return w1, w2\n",
    "\n",
    "result_multi_mw = {}\n",
    "success = 0\n",
    "for case in range(4):\n",
    "    # Initialize parameters\n",
    "    a, w = initialize_aw(case)\n",
    "    \n",
    "    a1, a2 = initialize_params(a, alpha1)\n",
    "    w1, w2 = initialize_params(w, alpha2)\n",
    "    learning_rate = 0.01\n",
    "    epochs = 20000\n",
    "    print(f\"initial mw parameters: a = {a1*a2}, w1 = {w1[0] * w2[0]}, aw={a1*a2*w1[0]*w2[0]}\")\n",
    "    a_vals = []\n",
    "    w_vals = []\n",
    "    # Gradient descent loop\n",
    "    for epoch in range(epochs):\n",
    "        # Compute effective weights and scale factor\n",
    "        a = a1 * a2  # Elementwise product for effective scale factor\n",
    "        w = w1 * w2  # Elementwise product for effective weights\n",
    "\n",
    "        # Forward pass\n",
    "        wx = np.dot(x, w)  # Weighted sum\n",
    "        relu_out = relu(wx)\n",
    "        y_pred = a * relu_out  # Prediction: a scales the ReLU output\n",
    "\n",
    "        # Compute loss (MSE)\n",
    "        loss = np.mean((y_pred - y_target) ** 2)\n",
    "\n",
    "        # Backward pass (compute gradients)\n",
    "        dL_dy = 2 * (y_pred - y_target) / num_samples  # Gradient of loss wrt y_pred\n",
    "\n",
    "        # Gradients wrt a1 and a2\n",
    "        dL_da = np.sum(dL_dy * relu_out)  # Gradient wrt effective scale factor a\n",
    "        dL_da1 = dL_da * a2  # Chain rule: gradient wrt a1\n",
    "        dL_da2 = dL_da * a1  # Chain rule: gradient wrt a2\n",
    "        # print(dL_dy.shape)\n",
    "        # Gradients wrt w1 and w2\n",
    "        # dL_drelu = np.outer(dL_dy, a)  # Gradient wrt ReLU output\n",
    "        dL_drelu = dL_dy * a  # Gradient wrt ReLU output\n",
    "\n",
    "        dL_dwx = dL_drelu * relu_derivative(wx)  # Gradient wrt wx\n",
    "        dL_dw = np.dot(x.T, dL_dwx)  # Gradient wrt effective weights w\n",
    "        dL_dw1 = dL_dw * w2  # Chain rule: gradient wrt w1\n",
    "        dL_dw2 = dL_dw * w1  # Chain rule: gradient wrt w2\n",
    "\n",
    "        # Update parameters\n",
    "        a1 -= learning_rate * dL_da1\n",
    "        a2 -= learning_rate * dL_da2\n",
    "        w1 -= learning_rate * dL_dw1\n",
    "        w2 -= learning_rate * dL_dw2\n",
    "        if epoch % 5 == 4:\n",
    "            a1, a2 = rescale_mw(a1, a2, alpha1)\n",
    "            w1, w2 = rescale_mw(w1, w2, alpha2)\n",
    "        a_vals.append(a1*a2)\n",
    "        w_vals.append(w1[0]*w2[0])\n",
    "    result_multi_mw[case] = [a_vals, w_vals]\n",
    "    \n",
    "    print(f\"during training parameters: a = {a1*a2}, w1 = {w1[0] * w2[0]}, aw = {w1[0]*w2[0]*a1*a2}\")\n",
    "    success += np.allclose(a1*a2*w1[0]*w2[0], 1, 0.1) and a1*a2 > 0 and w1[0]*w2[0] > 0\n",
    "print(f'Total success rate: {success/100:.2f}')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 453,
   "id": "4134ac7f-c757-417e-bee8-5a74b47f5ad6",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Initial parameters: a = 1.0, w = 0.061903993165903455\n",
      "Trained parameters: a = 0.9987577464128559 w = 1.001243798700547 aw = 1.0000000000000053\n",
      "Initial parameters: a = -1.0, w = 0.026889219676463044\n",
      "Trained parameters: a = -0.04801434057346153 w = -0.059740477862532525 aw = 0.002868399650112976\n",
      "Initial parameters: a = -0.9999999999999999, w = -0.12025404226871184\n",
      "Trained parameters: a = -0.04912627181194776 w = -0.05888618703151549 aw = 0.002892858830079423\n",
      "Initial parameters: a = 1.0, w = -0.04181073897072068\n",
      "Trained parameters: a = 0.9986797171363331 w = 1.001322028315002 aw = 1.0000000000000056\n",
      "0.02\n"
     ]
    }
   ],
   "source": [
    "# Standard Multi Dim Case\n",
    "\n",
    "\n",
    "# Define ReLU function\n",
    "def relu(x):\n",
    "    return np.maximum(0, x)\n",
    "\n",
    "# Define derivative of ReLU\n",
    "def relu_derivative(x):\n",
    "    return np.where(x > 0, 1, 0)\n",
    "\n",
    "d=5\n",
    "np.random.seed(42)\n",
    "num_samples=500\n",
    "x = np.random.randn(num_samples, d)  # Input data (100 samples, 1 feature)\n",
    "y_target = relu(x[:, 0])\n",
    "\n",
    "def initialize_aw(case):\n",
    "    if case == 0:\n",
    "        w = np.random.randn(d)\n",
    "        w[0] = 0.1\n",
    "        w = w / np.linalg.norm(w)\n",
    "        a = np.sqrt(np.sum(w**2))\n",
    "    if case == 1:\n",
    "        w = np.random.randn(d)\n",
    "        w[0] = 0.1\n",
    "        w = w / np.linalg.norm(w)\n",
    "        a = -np.sqrt(np.sum(w**2))\n",
    "    if case == 2:\n",
    "        w = np.random.randn(d)\n",
    "        w[0] = -0.1\n",
    "        w = w / np.linalg.norm(w)\n",
    "        a = -np.sqrt(np.sum(w**2))\n",
    "    if case == 3:\n",
    "        w = np.random.randn(d)\n",
    "        w[0] = -0.1\n",
    "        w = w / np.linalg.norm(w)\n",
    "        a = np.sqrt(np.sum(w**2))\n",
    "    return a, w\n",
    "\n",
    "result_multi_std = {}\n",
    "success = 0\n",
    "for case in range(4):\n",
    "    # Initialize parameters\n",
    "    a, w = initialize_aw(case)\n",
    "    \n",
    "    learning_rate = 0.01\n",
    "    epochs = 20000\n",
    "    print(f\"Initial parameters: a = {a}, w = {w[0]}\")\n",
    "    # Gradient descent loop\n",
    "    a_vals = []\n",
    "    w_vals = []\n",
    "    for epoch in range(epochs):\n",
    "        # Forward pass\n",
    "        wx = np.dot(x, w)  # Dot product for weighted sum\n",
    "        relu_out = relu(wx)\n",
    "        y_pred = a * relu_out\n",
    "\n",
    "        # Compute loss (MSE)\n",
    "        loss = np.mean((y_pred - y_target) ** 2)\n",
    "\n",
    "        # Backward pass (compute gradients)\n",
    "        dL_dy = 2 * (y_pred - y_target) / num_samples  # Gradient of loss wrt y_pred\n",
    "        dL_da = np.sum(dL_dy * relu_out)  # Gradient wrt 'a'\n",
    "        dL_drelu = dL_dy * a  # Gradient wrt ReLU output\n",
    "        dL_dwx = dL_drelu * relu_derivative(wx)  # Gradient wrt wx\n",
    "        dL_dw = np.dot(x.T, dL_dwx)  # Gradient wrt weight vector w\n",
    "        # print(dL_dw.shape)\n",
    "        # Update parameters\n",
    "        a -= learning_rate * dL_da\n",
    "        w -= learning_rate * dL_dw\n",
    "        a_vals.append(a)\n",
    "        w_vals.append(w[0])\n",
    "    result_multi_std[case] = [a_vals, w_vals]\n",
    "    # Print final parameters\n",
    "    print(f\"Trained parameters: a = {a} w = {w[0]} aw = {a * w[0]}\")\n",
    "    success += np.allclose(a*w[0], 1, 0.1) and a>0 and w[0]>0\n",
    "print(success/100)\n",
    "# a>0, w0 1 lr=1e-3\n",
    "# w<0, a>0 0.6 lr=1e-2\n",
    "# w>0 a<0 0 lr=1e-3\n",
    "# w<0 a<0 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 463,
   "id": "1e125102-7f82-4323-8219-90d959b074be",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(6, 4))\n",
    "x = np.linspace(0.1, 2, 500)  # Avoid x = 0 to prevent division by zero\n",
    "\n",
    "# Calculate the corresponding y values using xy = 1\n",
    "y = 1 / x\n",
    "plt.plot(x, y, color='darkorange', linewidth=2, label='Ground Truth')\n",
    "plt.xlim(-1.5, 1.5)\n",
    "plt.ylim(-0.5, 1.5)\n",
    "plt.axhline(0, color='k', linewidth=0.5)\n",
    "plt.axvline(0, color='k', linewidth=0.5)\n",
    "\n",
    "\n",
    "def add_arrows(x, y, n_arrows, color):\n",
    "    \"\"\"Add equally spaced arrows to a curve.\"\"\"\n",
    "    for i in range(n_arrows):\n",
    "        idx = int(i * len(x) / (n_arrows + 1))  # Choose indices for arrows\n",
    "        dx = x[idx + 1] - x[idx]  # Change in x\n",
    "        dy = y[idx + 1] - y[idx]  # Change in y\n",
    "        plt.arrow(\n",
    "            x[idx], y[idx], dx, dy,\n",
    "            head_width=0.05, head_length=0.05, fc=color, ec=color,\n",
    "            length_includes_head=True\n",
    "        )\n",
    "\n",
    "        \n",
    "for case in range(4):\n",
    "    a1, w1 = result_multi_mw[case]\n",
    "    a2, w2 = result_multi_std[case]    \n",
    "    plt.plot(a1, w1, color='purple', label='Sign In GF')\n",
    "    add_arrows(a1, w1, 2,'purple')\n",
    "    plt.plot(a2, w2, color='dodgerblue', label='GF', alpha=0.6)  \n",
    "    add_arrows(a2, w2, 2, 'dodgerblue')\n",
    "\n",
    "    if case == 0:\n",
    "        plt.legend(loc='upper left', fontsize=11)\n",
    "plt.xlabel('$a$', fontsize=20)\n",
    "plt.ylabel('$w$', fontsize=20)\n",
    "\n",
    "\n",
    "plt.savefig('plots/signin_gf_multidim.png', bbox_inches='tight')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0b41b90d-57f9-4c4a-bcf9-4a2c2d920f4c",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
