{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Import packages"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy import integrate\n",
    "import sys\n",
    "import os\n",
    "sys.path.append(\"../../\")\n",
    "from uniSI.propagator  import *\n",
    "from uniSI.model       import *\n",
    "from uniSI.view        import *\n",
    "from uniSI.utils       import *\n",
    "from uniSI.survey      import *\n",
    "from uniSI.inversion      import *\n",
    "\n",
    "project_path = \"./data/uniformgrid\"\n",
    "if not os.path.exists(os.path.join(project_path,\"model\")):\n",
    "    os.makedirs(os.path.join(project_path,\"model\"))\n",
    "if not os.path.exists(os.path.join(project_path,\"waveform\")):\n",
    "    os.makedirs(os.path.join(project_path,\"waveform\"))\n",
    "if not os.path.exists(os.path.join(project_path,\"survey\")):\n",
    "    os.makedirs(os.path.join(project_path,\"survey\"))"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Define the basic model parameter"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "device = \"cuda:0\"         # Specify the GPU device\n",
    "dtype = torch.float32     # Set data type to 32-bit floating point\n",
    "ox, oz = 0, 0             # Origin coordinates for x and z directions\n",
    "nz, nx = 44, 100          # Grid dimensions in z and x directions\n",
    "zoomfactor = nz/88       # Zoom Factor to baseline 88, 200\n",
    "dx, dz = 40/zoomfactor, 40/zoomfactor           # Grid spacing in x and z directions\n",
    "nt, dt = int(8000*zoomfactor), 0.002/zoomfactor     # Time steps and time interval#12000 work\n",
    "nabc = int(40*zoomfactor)                 # Thickness of the absorbing boundary layer\n",
    "f0 = 0.1                    # Initial frequency in Hz\n",
    "free_surface = True       # Enable free surface boundary condition\n"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Define the initial velocity model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "model with parameters ['vs', 'rho']:\n",
      "  Model vs  :   324.39 -  2357.17 m/s   , requires_grad = True, constrain bound: None - None\n",
      "  Model rho :  1944.25 -  2485.95 kg/m^3, requires_grad = False, constrain bound: None - None\n",
      "  Model orig: ox =   0.00, oz =   0.00 m\n",
      "  Model grid: dx =  80.00, dz =  80.00 m\n",
      "  Model dims: nx =    100, nz =     38\n",
      "  Model size: 7600\n",
      "  Free surface: True\n",
      "  Absorbing layers: 20\n",
      "\n"
     ]
    }
   ],
   "source": [
    "\n",
    "# Load the Marmousi model dataset\n",
    "marmousi_model = load_marmousi_model(in_dir=\"./datasets/marmousi2_source\")\n",
    "water_depth = int(12*zoomfactor)  # No water layer in the model, just pre-processing for marmousi2\n",
    "# Resample the Marmousi model for the defined coordinates\n",
    "x = np.linspace(5000, 5000 + dx * nx, nx)\n",
    "z = np.linspace(0, dz * nz, nz)\n",
    "vel_model = resample_marmousi_model(x, z, marmousi_model)\n",
    "\n",
    "# Remove the water layer from the velocity model\n",
    "# Remove water layer and replace with minimum rock velocity\n",
    "vp_true = vel_model['vp'].T\n",
    "vs_true = vel_model['vs'].T\n",
    "rho_true = np.power(vp_true, 0.25) * 310 \n",
    "np.savez(os.path.join(project_path, \"model/true_model.npz\"), vs=vs_true)\n",
    "\n",
    "import scipy.ndimage\n",
    "vs_init = scipy.ndimage.gaussian_filter(vs_true, sigma=3)\n",
    "rho_init = scipy.ndimage.gaussian_filter(rho_true, sigma=3)\n",
    "\n",
    "vs_init[water_depth:2+water_depth, :] = vs_true[water_depth:2+water_depth, :] # Source Depth\n",
    "rho_init[water_depth:2+water_depth, :] = rho_true[water_depth:2+water_depth, :] # Source Depth\n",
    "np.savez(os.path.join(project_path, \"model/init_model.npz\"), vs=vs_init)\n",
    "\n",
    "\n",
    "# Here initial model keeps the water layer for cross-scenario comparison\n",
    "vp_true = vp_true[water_depth:, :]  # Remove water layer from velocity model\n",
    "vs_true = vs_true[water_depth:, :]  # Remove water layer from velocity model\n",
    "rho_true = rho_true[water_depth:, :]  # Remove water layer from velocity model\n",
    "vs_init = vs_init[water_depth:, :]  # Remove water layer from velocity model\n",
    "rho_init = rho_init[water_depth:, :]  # Remove water layer from velocity model\n",
    "nz, nx = vp_true.shape  # Update grid dimensions after removing water layer \n",
    "water_mask = np.zeros((nz, nx), dtype=bool)  \n",
    "\n",
    "# Initialize the SHModel with parameters and properties\n",
    "model = SHModel(ox, oz, nx, nz, dx, dz,\n",
    "                      vs=vs_init, rho=rho_init,  \n",
    "                      vs_grad=True,    \n",
    "                      free_surface=free_surface,\n",
    "                      abc_type=\"PML\",\n",
    "                      abc_jerjan_alpha=0.007,\n",
    "                      nabc=nabc,\n",
    "                      device=device,\n",
    "                      dtype=dtype)\n",
    "\n",
    "# Print the model's representation for verification.\n",
    "print(model.__repr__())\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABRwAAAHBCAYAAAALjXeTAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/xnp5ZAAAACXBIWXMAAA9hAAAPYQGoP6dpAACelUlEQVR4nO3dd5xU1d3H8e/MbKODFBFFeESxAvZOsGKNBVs0RMAWE2M0Ro0xIokt1iQ+ah5L7EZjrLHXKHYNGEUliiIiIgpKX9g2c54/yK47O+c3O2f3zs7s7uf9eu1LuXPm3HPr/Pbs7v3GnHNOAAAAAAAAABCBeKEHAAAAAAAAAKDjYMIRAAAAAAAAQGSYcAQAAAAAAAAQGSYcAQAAAAAAAESGCUcAAAAAAAAAkWHCEQAAAAAAAEBkmHAEAAAAAAAAEBkmHAEAAAAAAABEhglHAAAAAAAAAJFhwhEAAAAAAABAZJhwBIACef7557V48eI2X++TTz6p2traNl8vAABAR7Fs2TI9++yzkqQVK1bo2muv1Wabbabf/va3BRnPJZdcouOPP74g647Su+++q7lz5xZ6GAAiwIQjALSx5cuXa/z48Zo5c6bWWmstHXjggUokEorFYhlfpaWl6tu3r7bbbjv98pe/1Oeff97q9Q8YMEAHHnig3nrrrQi2BgAAoHN55JFH9KMf/UjDhw/Xn//8Z+2www469dRT9Z///KdgY7rvvvt05JFHttn6Vq5cqU022URff/11s23nzJmj8ePHa8CAASovL9dGG22kKVOmqKqqKqPthhtuqClTpujyyy/Px7ABtKGYc84VehAA0FnMnz9fY8eO1Z/+9CftvffeDctXrVqlU089Vbfccoskaf3119fuu++ubt266Z133tFrr70mSaqoqND111+vCRMmtGoc8+bN0957762LLrpIhx9+eKv6AgAA6Cwuv/xyPffcc3riiSdUUlIiSUomkxo8eLAWLFigKVOmtPlvOX7yySfaYYcd9PXXXzeMKd9+9atf6Q9/+IMmTJigv/zlL2a7WbNmaeedd9by5cvVs2dPffvttw2vjR07Vk8//XTGe5xzOv7441VdXa1bb71VZWVledkGAPnFbzgCQBtZsmSJxo4dq+OPPz5tslGSunbtqp/97GcN/540aZJuu+02XXfddXr11Vf1xBNPqEuXLqqqqtJxxx2nZ555plVjGTx4sP76179qwoQJevXVV1vVFwAAQGdw44036rrrrtPf//73tIm9RCKhIUOGFGxc9913nw455JA2m2z85JNP9Oc//1mPPfaY7rnnHv373//2tqutrdURRxyh3/3ud1qxYoW++eabhglISXrmmWf04IMPZrwvFovpxhtv1CeffKLTTz89n5sCII+YcASANvKTn/yk4TcZfXr37m2+d7/99tN5550nSUqlUjrrrLNaPZ5tttlGP/nJT3TEEUfoq6++anV/AAAAxaKurk7XXHONtt9+e/Xp00clJSXq3bu3xowZo4cffji4vxkzZujUU0/V5MmTvTVbaWlp6wfdQvfdd5+OOOKINlvf6aefrpNPPln77LOPzjjjDHNS8NZbb9Ull1yiU045ReXl5ZKkjTbaSA899FDDPnzppZe87y0pKdFNN92kG264Qbfffns+NgNAnjHhCABt4B//+IfuvfdenXHGGWZBGovFsvZx3HHHNfz/jBkz9OWXX7Z6XGeffbYWLVqkX/7yl63uCwAAoBj85z//0bbbbquf//zn+te//qWlS5cqmUxq2bJleumll3TooYfqyiuvzLk/55wmTpyoPn36mI+1iccL86317NmzNXfuXO25555tsr4nn3xS06ZN0+TJkyVJ55xzjmbPnq2///3vGW0nTpyoAw44IGP5gAEDtOOOO0rK/gP3kSNH6oADDtCpp56a9qfYANoHJhwBIM+ccw2/nXjQQQe1uJ+BAweqb9++Df+OKkBmt91209/+9reCPugcAAAgCm+++aZ22mknvfvuu9pggw10zTXX6I033tBLL72ks846S4lEQtKaibJZs2bl1Of999+vf//739pvv/0K+puMPvV/Tt0W46qtrdUvfvELXXzxxerZs6ckqVu3brr88st19tlnZ4TAZHv2YkVFhRKJhI455pis6zzqqKO0YsUKXXXVVa3fAABtiglHAO2Sc05PPPGEdt99d02aNEmStGDBAh177LHq2bOn1llnHZ177rlKJpOSpJqaGl1yySXacMMN1bVrV+2666565513Gvp74IEHVFJSkpYQ3dhmm22W9tptt92W81iffPJJvf/++9p0001b/XyfxuNq+hPhRx55RHvssYeGDBmiLl26aOjQoTrhhBOanZgcPXq0UqmULrnkklaNDQAAoJAWLlyogw8+WMuWLdO+++6r9957Tz/72c+0ww47aPTo0br88sv1hz/8QdKaoJdsYSeNXXHFFZLWPOImRDKZVGlpaVoNGY/HM/5EeNWqVfrd736nzTbbTN27d1efPn100EEH6V//+lez6/D9OXXUdXK9P/3pT+revXtDn/WOOeYYrbfeejn/1mhtba1ef/11TZkyRcOHD8/advTo0ZKka665RkuXLs2pfwBFwgFAO/PYY4+5LbbYwklyktyECRPc22+/7dZaay233nrrubKysobXzj//fLdq1Sq35557um7durlBgwY1vNa/f3+3dOnShn6rqqrchAkTGl5v6oUXXnCxWMxJcrfeemvO4x0/fryT5I4++uis7ebMmdOw7ilTpmS8/tlnn6WNPZlMNrz2i1/8wklyF1xwgaurq3NLlixxxxxzjJPkhg4d6iorK831Pvroo06S69q1q1u5cmXO2wUAAFBMfvjDHzpJ7n/+53/c8uXLvW1Wr17tunXr5iS50aNHN9vnJ5980lB/ffTRR2a7MWPGeGu4d99910lyI0aMcE8++aSrrq5Oe33JkiVu1KhRrnv37u7xxx93yWTSTZs2zQ0dOtTFYjHXpUsX16tXL9enTx/38MMPp7139uzZbq211nI1NTUNy/JVJy9YsMD17NnTvfLKK97tnz59uuvRo4ebP39+s/t08uTJ7tRTT222Xb2+ffs6Se6WW27J+T0ACo/fcATQ7uy4446aOnWqNtpoI0lrkvKuvPJKTZ06VfPmzdM333yjMWPGSJL+/Oc/68QTT9Shhx6qb7/9VvPnz9fUqVNVWlqqRYsW6Z577mnot7y8XD/84Q/N9e62225ae+21g8f75JNPSpI22WST4Pc2duGFFzb8/5lnntnwrKA5c+boj3/8o6Q1fx6USCTUu3dvXXvttYrFYvrss8/08ssvm/1usMEGktb8dN16cDcAAEAxmz17dkNdd+GFF6pHjx7edhUVFQ2/Vbd48eJm+62v48rKyhpqplytWrVKv/rVr3T44YfrzTff1L777pvxZ8ZnnHGG3n33XZ166qnaf//9FY/Htc022+gPf/iDnHOqra3V9OnTtXjxYh188MFp773vvvt08MEHp/05db7q5HPOOUcHHHCAdtllF++2br311jrqqKN0zjnnmPvjq6++0oknnqgLL7xQU6dO1QsvvJDTfqzf70899VRO7QEUByYcAbQ7ffv21VprraVRo0ZJkrp06aI777xTW2yxhSSpR48eOvfccyVJ33zzjU444YS0dLzvfe972nXXXSUp47mFzT3/pr6PXM2dO7fhIddDhw7N+X1ffvmlvvnmG0lr/gTmlFNO0c033yxJ+sEPfqAzzzyzoW1lZaUkqU+fPmnj79OnjwYMGCBJDX35NC6e33zzzZzHCAAAUCzuuusupVIp9e7dW4cffnjWtvXPcczluYfTp0+XJK277roqKSnJeTzffPON9txzTw0bNkz33nuvunTpktGmpqamYVJv++23T3vtkEMOUa9evVRXV6d7773Xuw7fn1Pno05+66239MADD+jyyy/Pus0XX3yxHn30UW89+ac//Un77LNPw5+xz5gxQ2PHjs0pMby+VqVOBdoXJhwBtFv1hdu6666bkQzYeHLPN9G3zjrrSJJWrlyZt/FJ0scff9zw/9ZP2n2mTZumww47TOuvv76GDx+uhx56SPvtt5/uvfde3XPPPWnbu8UWW+ihhx7K+Knv9OnTVVtbK0mqq6sz11VRUdGwLxuPFwAAoL2or4N22223Zn9APH/+fEnK6dna9bVRSB336aefapdddtEBBxyga6+91kywXrx4cUPQStPnh8disYYadt68eRnvnTNnjubMmaO99trL23eUdfL222+vFStWaL311vOuq96AAQO0ZMkS7bDDDhmvnX766Xr33Xc1e/ZsHXvssZLW1KcnnXRSww/PLWuttZakNfuhuro6a1sAxSP3H9EAQJGxijcpeyqe9N1PtOsflp0vS5Ysafj/kEL1oIMO0m9/+9uc2x9yyCGSpNWrV+v222/XXXfd1RB0I615eHg2Xbt21erVq3P60yIAAIBiUl1d3fCbiFtvvXXWtl999ZUWLFiQU1vpu1ou1zruvffe084776xUKqWTTjopa9sBAwaoW7duqqys1Jw5czJer6/j6v9ipTHfn1M3Vqx18gYbbKDbb79dG264oc4//3wtWrRITz75ZNbfSu3ataskKZVKaenSpS16xBGAtsdvOAJAHjX+KWwqlcrrum644QZtttlmWrZsmZ588kndeOON6t69e07vrf8peL4nYAEAAKL2/vvvN/xVx+DBg7O2rX8moyTztwMbq6/lcq3j1l57bZWVlWnRokU67LDDGsblE4/HdeKJJ0qS7rjjjrTXli9fro8//ljxeFxHHXVUxnt9f07dnpxzzjkaOHCgpDW/EZpN4z9Hp1YF2g8mHAEgjxpP+K1atSov60ilUg3PdXzooYf0q1/9Kui3KSU1/DlP79698zBCAACA/HnnnXca/r+5icEbb7xRkrTRRhtpp512arbv+lou1zpuwIABevjhh9WlSxe98sorOuWUU7K2v/TSS3XggQfq3//+t84880wtXbpUCxcu1IknnqjKykpdfvnl2myzzdLe89lnn2n27Nk5TZgWq9LSUu23336S5H2+ZWP1dapErQq0J0w4AkAjjR8Gnq1gbe5PlOutv/76Df/f3PNpWuqaa67Rvffeqx/+8IfacsstW9THihUrJKnhJ80AAADtReMJxxkzZpjt7r77br3xxhuSpDPPPDPjuYk+9bVcSB239dZbN4Sj3HTTTbruuuvMtuXl5brgggu02Wab6fXXX9cGG2ygESNGaMWKFXr66af1y1/+MuM9zf05dXtRX3dut912WdvV16k9evRo+PNqAMWPCUcAaKTxbwZ+9dVXaa8tXry44eHZNTU1OfW36aabNhSDvgd+N5brJGZTzzzzjKTsz+rJNnm6cuXKhj8XaumEJQAAQKE0nnC86667tHDhwow2L730kn784x9LWhOCcsIJJ+TU98iRIyWtCZoJqdWOOeYYnXnmmZLWBKY8//zz3nbvvfee9thjD/3jH//Qq6++qsWLF+vrr7/WE088obFjx3rfc9999+nII4/MeSzFatasWRo1apR23HHHrO2++eYbSdSpQHvDhCOAdmv16tWS5E2ra5zK7JscrH/+S30f9TbccEMlEglJ0uWXX97Q7vnnn9cxxxzT0G7mzJmSmv+znS5dumj77beX1PzzaZYtW+b9/+b06dNHkvTXv/614af6n3/+uY4//viGFMaFCxdq/vz5euCBBzLe/9FHHzX8/6677przegEAAArNOddQ/2yzzTb69ttvteuuu+quu+7S22+/rWeeeUYnn3yy9txzT61cuVKDBg3SAw88kPUHtY3ttttuktbUjPVhMz71vwHZuC699NJLtddee6murk6HH3643n///Yz3nXzyyaqsrNT06dP1/vvv68MPP9SsWbM0e/ZszZs3L6NW/eyzz/TJJ580++fU+aiTQy1fvlyzZ8/2vvbuu+/qmWee0c0339xsP/W1KnUq0M44AGiHvvjiC7fOOus4SW799dd3CxYsaHgtmUy6KVOmOElOkrvqqqtcMplseH3+/Plu2LBhTpJbd9113dy5c9P6Hj9+fMN7e/fu7QYMGOA23HBD99lnn7khQ4Y0vLbXXnu5adOmNTvWP/7xj06S23XXXc02K1ascBMmTGjoe8MNN3Qff/xxTvvikUceaXhfPB53gwcPdt27d3d3332323LLLZ0kV15e7jbffHP39ddfZ7z/rrvucpLcqFGjclofAABAsfjkk08a6qCHH37Y7bfffg3/bvo1atSojLqvObW1ta5fv35Oknvuuee8baZPn+4qKiqcJLftttu6lStXNrz28ssvN6x/wIAB7qmnnkp779Zbb22OV5IrLS11Bx54oPv888+dc85dccUVbuLEiVnHnM86OcSIESOcJLfDDju4xx57zNXU1LhkMukeeeQRN2rUKPfKK68020ddXV3Dvv33v//d4rEAaHtMOAJody655BIXi8XSirFYLOZ+/OMfu7lz57rS0tKMYq2srMzNmjXLnXzyyRmvxWIxd/HFFzf0X1lZ6Y4//njXu3dv17dvX3fCCSe4b775xjnn3LBhw9xhhx3mXnzxxZzHu3TpUte7d2/XpUsXV1NTk/H6AQcckLE99V/du3fPqdC77rrr3NChQ13Xrl3dvvvu6z744APnnHM33HCD6969u9t7773Nfk466SQnyV177bU5bxMAAEAxuP/++xvqpjlz5rjq6mp3ySWXuM0339x17drV9e7d240ePdrdcMMNrra2tkXr+O1vf+skuYsuuijjtR122CGjfkskEu6CCy5wdXV13rq0oqLCVVVVOeecW7BggVt//fXdyJEj3cCBA13Xrl1dPB7PeM8WW2zh6urq3Pbbb+8ef/xxc6z5rpND3H777W7jjTd2ZWVlrrS01A0aNMjtv//+7k9/+lPapGw2r732WsNELoD2JeZcCx8aBgDI2YUXXqjzzz9fzzzzjPbee+9CDyfN+uuvr1QqpdmzZ6u8vLzQwwEAAMjZeeedp4svvli9evXS0qVL87KO5cuXa+jQodp000316quvRtr35ZdfrqVLl+qSSy7JeK2urk5LlizR1KlT9aMf/UhvvfWWRowYEen6i93555+vCy+8UI8++qgOPPDAQg8HQACe4QgAbeD000/X0KFDGxILi8ULL7ygefPm6U9/+hOTjQAAoN2pD4zJ50Rcz5499bvf/U6vv/56w3O8o/DEE0/o97//vSZPnux9vaSkRP3799fhhx+uzTbbLOfnTnYUdXV1uvvuu3XAAQcw2Qi0Q53rjgUABdKjRw89+OCDeuyxx/TGG28UejgNpkyZoh/96Ec6/PDDCz0UAACAYPUTjvVp0vly6qmn6qijjmpInm6tVCqlk08+WaWlpc1OJE6bNk21tbXafPPNI1l3e3H77bdrxYoVuummmwo9FAAtUNQTjqtXr9b555+v4cOHq6KiQoMGDdJxxx3XkLoKAO3JVlttpVtuuUWTJk3St99+W+jh6Morr1RZWVnR/dYlAOQLtSXQsXzzzTcN12++Jxwl6eabb9bixYt19dVXt7qv5cuX68svv9SiRYs0ZswYPfnkk6qqqkprs2zZMt1www06+OCDO92k26xZs3TRRRfpqaee0jrrrFPo4QBogaJ9hmNVVZV23313vfHGG1pnnXU0evRoffbZZ3rrrbfUv39/vfHGG9pggw0KPUwACPb000/riiuu0D333KP+/fsXZAw33XSTXnnlFV1//fXq0qVLQcYAAG2J2hLoeJ577rmGZ2O/9tpr2mmnnfK+zlWrVmnChAnab7/9dNxxx7Wqr+uvv16nn366qqurJUmJRELrrLOOunTpopUrV+qrr77S+uuvr/vvv1/bbrttFMNvFz766CP9/Oc/1+WXX65Ro0YVejgAWqhof8Pxoosu0htvvKGddtpJs2bN0r333qs333xTV111lRYtWtTqmzsAFMo+++yj22+/XZdddlneHm6ezdVXX63u3bvr9ttvZ7IRQKdBbQl0PPV/Th2LxdosTKVr16667777VFZWpr/+9a+t6uvkk0/Wf/7zH5111lkaNWqUunTpoq+//lorVqzQyJEj9X//93/66KOPOtVk47Rp03TnnXfq3nvvZbIRaOeK8jcca2pqNGDAAC1btkxvv/22ttpqq7TXR40apRkzZmjatGnaZpttCjRKAAAAtAfUlgAAAG2rpNAD8Hn11Ve1bNkyDRs2LKMglKTDDz9cM2bM0KOPPppzUZhKpfTll1+qR48eisViUQ8ZAACg6DjntGLFCg0aNKjTpZs2Rm0JAAAQjVzry6KccHz33XclSVtvvbX39frlM2bMyLnPL7/8UoMHD2794AAAANqZefPmab311iv0MAqG2hIAACBazdWXRTnh+Pnnn0uSOfD65XPnzs25zx49ekiStt3rfpWUdmvlCAEAAIpfXW2lpj13eEMd1Fnls7b83mFPUVsCAIBOo662Ui89sG+z9WVRTjiuXLlS0poH8vp067amqFuxYoXZR3V1dUPaV+O2JaXdKAoBAECn0tn/5DfvtWVZ96iGCgAA0C40V1922If5/P73v1evXr0avviTFwAAALQUtSUAAEDuinLCsXv3NT8lXrVqlff1yspKScr665u//vWvtWzZsoavefPmRT9QAAAAFD1qSwAAgLZVlH9Svf7660uSvvjiC+/r9cuHDBli9lFeXq7y8vLoBwcAAIB2hdoSAACgbRXlhOOoUaMkSW+//bb39frlI0eODO67pLxMJaVlLR9ckairrslr/4nStj01otqeWJZI9tb33frnX6XqkkHtE6WlufedDOs7hEulgtpHMW5rnfGShL8fz7612sYT/uXJ2jrvch/rfIiib2vbrfPbul5D1rnWoAE5t5WkpHEul3Vp/f21elVVzm3Lu1YE9b34y0Xe5SHXj3WMLVEc+3zK532zmITs26j2SchnqXWeWPeaXgP6epfHm4y9tmZlzmPoyPJZWw7aYJDKKjpGKM+Xsxfkre8+A9fKW9+WBZ/Ob3UfFV27RDASo+/ure970dwvg9r3XW+gd3l518zJ9BXfLm/RmJqq9dT51atWB/XRvU8v7/IefXtmLLPGXbnMv7zvumt7l38z7yvv8n6DM/dhjz7+57h+/fnX3uWWrj0yswZC+47H/J9hK5csy1hm7df+g/tHss4Dj8r9nlpV7bzL1+rV+u/BFn5r1NZG1/365F4HPPeM/wdZq1eGnePWcfYJPa9qVlc33yhCJUb9UxLwPWJ74LumsrGutxDWteljnSerl/trw3GTdvEuLy3NvFBWr1quf/6t+TEU5XcZu+yyi3r16qXZs2frnXfeyXj9/vvvlyR9//vfb+ORAQAAoL2htgQAAGhbRTnhWFZWpp/97GeSpFNOOaXhuTqS9Ic//EEzZszQmDFjtM022xRqiAAAAGgnqC0BAADaVlH+SbUknXfeeXruuef02muvaaONNtLo0aM1d+5cvfnmm+rfv79uueWWQg8RAAAA7QS1JQAAQNspyt9wlKSKigq98MILmjx5srp27aqHH35Yc+fO1cSJE/X2229rgw02KPQQAQAA0E5QWwIAALSdov0N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ixYt0plnnqmNN95YXbp00VprraWtt95aZ511VqGHVjAvvvhi1nOn/uuCCy4o9FDRAVFb2qgts6O+bB61Ze6oLTNRW+aG2jITtWW0OsVvOFZVVWn33XfXG2+8oXXWWUejR4/WZ599prfeekv9+/fXG2+8oQ022KDQwyyYQw45RP/4xz8ylneCU6NZf/nLX3TiiSdKkjbddFNtscUWWr58uV577TWtWLFCm2yyiaZOnaoBAwYUeKSF1a9fP1VWVmrkyJFad911JUkffPCBZs2apdLSUj344IM68MADCzzK4jBx4kTdcccdcs5p2LBh+uSTTwo9pILbbbfdNHXqVB122GHq3r17xuu//OUvNWLEiAKMrHhMnz5d++yzj7799lttvvnmDfeimTNn6osvvlBdXV2hh1gQH374oS699FLva8lkUnfddZck6Z///Kd23333thwaOjhqy+yoLbOjvmwetWXuqC0zUVs2j9rSj9oyYq4T+M1vfuMkuZ122smtWLGiYflVV13lJLkxY8YUbnBF4NJLL3WTJ092jzzyiFuwYIErLy93neTUaNZtt93mTjrpJDdz5sy05V9++aXbaqutnCR39NFHF2h0xeOVV15xq1evzlh+3XXXOUlu7bXXdrW1tQUYWXF57rnnnCR30kknOUlu2LBhhR5SURgzZoyT5ObMmVPooRSlhQsXun79+rmuXbu6f/zjHxmvv/nmmwUYVfF74oknnCQ3ePBgl0qlCj0cdDDUltlRW2ZHfdk8asvcUFv6UVtmR23ZMtSW4Tr8J391dbXr1auXk+TefvvtjNdHjhzpJLlp06YVYHTFiaIwN6+99pqT5MrLy111dXWhh1O0hg0b5iS5d999t9BDKahVq1a5YcOGuc0228zNmjWLorARisLsfvKTnzhJ7rrrriv0UNqVY445xkly55xzTqGHgg6G2jIctWXuqC+bR225BrWljdoyO2rLlqG2DNfhn+H46quvatmyZRo2bJi22mqrjNcPP/xwSdKjjz7a1kNDOzdq1ChJUnV1tb799tsCj6Z4lZaWSpLKysoKPJLC+t3vfqdPP/1U119/fcM+AZqzevVq3XXXXerWrZsmTZpU6OG0G5WVlQ1/zvmjH/2owKNBR0NtiXyivmweteUa1JZoCWrLlqG2bJmSQg8g3959911J0tZbb+19vX75jBkz2mxM6Bg+/fRTSWuKnrXWWqvAoylOd955pz766CNttNFG2mijjQo9nIKZMWOGrrrqKk2aNKnhOV/IdPPNN+vbb79VPB7X8OHDdcghh2j99dcv9LAKatq0aVqxYoV23XVXdenSRU8++aSeffZZVVVVafjw4TryyCM1aNCgQg+z6Dz44IOqrKzUVlttpc0226zQw0EHQ22JfKK+zI7acg1qy9xQW2aitmwZasuW6fATjp9//rkkab311vO+Xr987ty5bTYmdAxXX321JGnfffdVeXl5gUdTHK644gp98MEHqqys1H/+8x998MEHGjRokO655x4lEolCD68gUqmUTjjhBPXu3VuXX355oYdT1C666KK0f5955pmaPHmyJk+eXKARFd7MmTMlSQMGDPCGMJx77rm6+eabdfTRRxdieEWr/oHe/AQa+UBtiXyivkxHbZmJ2jJ31JaZqC1bhtqyZTr8n1SvXLlSktS1a1fv6926dZMkrVixos3GhPbviSee0M0336zS0lJdeOGFhR5O0Xj66ad1++236/7779cHH3ygIUOG6J577tE222xT6KEVzDXXXKN//etfuuKKK9S3b99CD6cofe9739Odd96p2bNna9WqVfroo4908cUXq6SkROeff37DN1+d0ZIlSyRJjzzyiJ566ildd911WrhwoT777DOdeeaZWr16tSZMmKB33nmnsAMtIgsWLNDzzz+vRCJBsYy8oLZEvlBfZqK2zERt2TxqSxu1ZThqy5br8BOOQNQ+/PBDjR8/Xs45XXHFFQ3P2oH03HPPyTmnJUuW6KWXXtJGG22kMWPG6OKLLy700Ari888/13nnnacxY8Zo4sSJhR5O0brgggs0fvx4bbDBBurSpYuGDx+uc889Vw8//LAk6be//a1Wr15d2EEWSCqVkiTV1dXpggsu0E9/+lP1799fQ4YM0RVXXKEjjjhCtbW1uuKKKwo80uJxzz33KJlMau+999bAgQMLPRwAyAn1pR+1ZTpqy9xQW9qoLcNRW7Zch59w7N69uyRp1apV3tcrKyslST169GizMaH9mj9/vvbdd18tWbJEZ5xxhk477bRCD6ko9e7dW6NHj9YTTzyhbbbZRpMnT9a//vWvQg+rzZ1yyimqqanR9ddfX+ihtEtjx47Vtttuq6VLl+rNN98s9HAKov4zTJL3wd71y6ZOndpmYyp2/MkL8o3aElGjvmweteUa1JatQ21JbdkS1JYt1+Gf4Vj/UNgvvvjC+3r98iFDhrTZmNA+LV68WGPHjtXcuXM1adIkXXnllYUeUtErLS3VUUcdpenTp+vRRx/VdtttV+ghtanHHntMvXv31sknn5y2vKqqStKabzB22203SdLf/vY3fmLmsdFGG2natGlasGBBoYdSEPWfTV27dlX//v0zXh86dKgkaeHChW05rKL1n//8R//+97/VvXt3HXLIIYUeDjooaktEifoyDLUltWVrUVtSW4agtmydDj/hWP/nCG+//bb39frlI0eObLMxof1ZuXKl9ttvP82cOVPjxo3TTTfdpFgsVuhhtQv9+vWTJC1atKjAIymMpUuXmj8hrKqqanitvlBEuvrnzNQ/E62z2WqrrSRJq1evVnV1dUaAwOLFiyWl/7S6M7vzzjslSePGjTOfrwe0FrUlokJ92TLUltSWrUFtSW0ZgtqydTr8n1Tvsssu6tWrl2bPnu198On9998vSfr+97/fxiNDe1FdXa2DDz5Yb731lvbZZ59OnYrXEvVFz7Bhwwo8krbnnPN+zZkzR9KafVK/rP6nifjOokWL9PLLL0uStt566wKPpjDWX399jRo1Ss457zcX9cvqi8fOzDmnu+++WxJ/8oL8orZEFKgvW47aktqypagtqS1DUFu2XoefcCwrK9PPfvYzSWueeVH/XB1J+sMf/qAZM2ZozJgxnTrpDLZkMqmjjz5a//znPzV69Gg9+OCDKisrK/Swisqrr76qp556quEBxPVqa2t1zTXX6M4771SXLl101FFHFWiEKGavvfaaHn74YSWTybTln332mQ499FBVVlbqoIMO0nrrrVegERbe2WefLUk688wz0/7855133tFVV10lSRl/WtUZvfzyy5o7d67WXXdd7bHHHoUeDjowaku0FvVldtSWaA1qy+ZRW+aG2rL1OvyfVEvSeeedp+eee06vvfaaNtpoI40ePVpz587Vm2++qf79++uWW24p9BAL6vHHH9eFF17Y8O+amhpJ0o477tiwbPLkyTrggAPafGyFdu211+qhhx6StObPN376059621155ZUNf97R2Xz88ceaNGmS+vXrp2222UZ9+/bVN998o/fee08LFixQRUWFbrvtNg0ePLjQQ0URmjVrliZNmqSBAwdq6623Vu/evTV37lxNnz5dVVVV2nzzzXXTTTcVepgFdcwxx+iZZ57R7bffrs0220w777yzVq9erddee03V1dU68cQTdcQRRxR6mAVX/0DvY445RvF4h/95KgqM2jI7asvsqC+zo7ZEa1BbNo/aMjfUlhFwncSqVavc5MmT3bBhw1xZWZkbOHCgmzhxops3b16hh1Zwt956q5OU9evWW28t9DALYsqUKc3uG0luzpw5hR5qwXz66afu3HPPdbvssotbZ511XGlpqevWrZvbfPPN3amnnuo+/vjjQg+x6MyZM8dJcsOGDSv0UApu5syZ7ic/+YnbeuutXf/+/V1JSYnr1auX23HHHd1VV13lVq1aVeghFoVUKuVuvPFGt80227iuXbu6bt26uZ122snddttthR5aUaiqqnJ9+vRxkty7775b6OGgk6C2tFFbZkd9mR21ZThqy+9QW+aG2jI7astoxJxzLp8TmgAAAAAAAAA6D34vFAAAAAAAAEBkmHAEAAAAAAAAEBkmHAEAAAAAAABEhglHAAAAAAAAAJFhwhEAAAAAAABAZJhwBAAAAAAAABAZJhwBAAAAAAAARIYJRwAAAAAAAACRYcIRACLmnOvQ6wMAAEDbor4E0N4w4QgAEXr66af1f//3f0omk3r00Ud10EEHaa+99srrOv/5z3/qz3/+M4UhAABAB0R9CaA9YsIRQKdx2WWXqW/fvorFYg1f5eXlmjhxYkObhx56SMOGDWt4vV+/frr11ltz6v/aa6/Vhx9+qJ/+9Kd6//339cEHH+jRRx9VXV1dnrZojT333FNDhw7VxIkT874uAAAAfIf6EgD8Yo4fWQDoRKqrq3XJJZfoggsukLSmSDz77LPT2lRVVal79+768Y9/rCuuuEJdu3Zttt8HHnhAf/vb33Tfffel9dOlSxeNGTNGL774YqTb4XPhhRdq+fLluuKKK/K+LgAAAKxBfQkAmZhwBNApnXPOObrsssu0xRZbaPr06SorK2t47eKLL9a8efN0/fXX59TXwoULtdlmm2nq1KnafPPNG5Y75xSPx9usIKyqqtIGG2ygO+64I+9/ZgMAAIB01JcA8B3+pBpAp3TxxRfre9/7nt5//32df/75DcsfeeQRvfDCC7r22mtz7uuyyy7ToEGD0opBSYrFYpGNNxcVFRU68sgjNXny5DZdLwAAAKgvAaAxJhwBdEqJREJ33HGHevXqpSuuuEIvv/yy3nvvPZ133nm69957VVJSklM/VVVVuvHGGzV27Nic2p999tkNz+/ZcMMN9cADD+jWW2/VIYccoj59+ujTTz/VTTfdpIkTJ6p///7aaaedNHPmTH355Zf61a9+pTFjxqhfv37605/+5O3/e9/7nt544w299tprue4KAAAARID6EgC+w4QjgE5ryJAh+r//+z+lUikde+yxOuaYY/TXv/5Vffv2zbmPZ555RitXrtRmm22WU/uf/OQnWnvttfX444/rk08+0WGHHaZJkyapd+/eWrp0qW666SYdeOCBuu222/Tyyy9r2rRpOvzww3XPPffooosu0tSpUzV+/Hj94he/0DvvvJPR/xZbbCFJeuyxx3LeBgAAAESD+hIA1mDCEUCndvTRR2v8+PH67LPPNHjwYI0YMSLo/a+//rokadiwYc22/c9//qMf/ehHevHFF7X//vunvbbeeutJkk466SSts846kqRNNtlEI0aMUGVlpX75y1+qtLRUkrT33ntLkqZOnZqxjiFDhigej+v5558P2g4AAABEg/oSAJhwBACtu+66Ki8v15NPPql77rkn6L0ff/yxJKlXr15Z273++uv68Y9/rHvvvVebbLJJxuv1f2LT9Lk8PXv2zFjWrVs3SdKyZcsy+ikvL1f37t31+eef574RAAAAiBT1JYDOjglHAJ3aPffco88++0wPPvigJOmUU07R/Pnzc35/fVHWtWtXs82SJUu0zz77qLq6Wv369WvdgBtJpVLe5d26ddM333wT2XoAAACQO+pLAGDCEUAnNm3aNP3v//6vbrnlFu2///768Y9/rCVLlmjixIlyzuXUR/1Pg6urq802ffr00eTJk/XWW2/p5JNPjmTs2cRiMSUSibyvBwAAAOmoLwFgDSYcAXRKCxYs0AknnKB77rmn4afHV111lYYNG6bnnntO//u//5tTPwMGDJAkrVy5Mmu7s846S0cccYRuu+02XX311a0bfDNWrFjRMC4AAAC0DepLAPgOE44AOp0VK1bokEMO0VVXXaWhQ4c2LO/WrZvuvPNOxeNxnXPOOd6UvqZGjRolSfriiy8yXmv6U+xbb71Vm2++uc4880w999xzaa/V//mK7yff1k/Dfcurqqq0cuXK4IeTAwAAoOWoLwEgHROOADqV6dOna/To0UokEtpzzz0zXt9pp500fPhwVVVV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n+LG8SluHJ/ixvEpLp0qNAYAAAAAAABAfvEbjgAAAAAAAAAiw4QjAAAAAAAAgMgw4QgAAAAAAAAgMkw4dnCrV6/W+eefr+HDh6uiokKDBg3Scccdp/nz5+fcx9KlS3X33Xfr6KOP1v/8z/+orKxMPXr00A477KCrr75atbW1edyC4hHFvvT5+OOP1aVLF8ViMe21114RjbZ4Rb0fP/vsM5188sn6n//5H5WXl6tfv37aaaeddMUVV0Q88uIT5b589tlndcABB6h///4qLS1V3759NXbsWD300EN5GHlxmT59ui699FKNGzdO6623nmKxmGKxWIv7W7JkiU477TQNGTJE5eXlGjJkiE4//XQtXbo0ukEXqaj2JZ87QH6tWrVKDz/8sI4//nhtvPHGqqioULdu3TRq1ChdcMEFWrlypfne2267Tdtvv726d++utdZaS/vvv79ee+21rOt79dVXtf/++2uttdZS9+7dtf322+uOO+7I+p4vvvhCkyZN0qBBg1RRUaHhw4drypQpqqqqatE2tyctOT7z5s3Tn//8Z02cOFGbbrqp4vG4YrGYXnzxxWbXx/EJE3p8UqmUXn75ZZ199tnaZptt1KNHD5WXl2vYsGE6+eSTNWfOnKzr4/iEacn188gjj2jChAkaMWKE+vXrp9LSUg0YMED777+/Hnvssazr4/iEac3nT2N77bVXQ535xRdfmO04PgXm0GGtXr3a7bjjjk6SW2edddyRRx7ptt9+eyfJ9e/f382ePTunfn7zm984SS4Wi7mtttrKHXXUUW6PPfZw5eXlTpLbddddXWVlZZ63prCi2pc+u+22m4vFYk6S23PPPSMcdfGJej8+8cQTrmvXri4Wi7ltttnG/eAHP3B77723GzhwoBs2bFietqI4RLkv//jHPzZc4zvvvLM76qij3M4779xwXp577rl53JLCO/jgg52kjK+WWLRokdtwww2dJLfBBhu4I4880m2++eZOkhs+fLj79ttvIx59cYlqX/K5A+TXTTfd1HB9brrppu6II45w++yzj+vRo4eT5DbZZBP39ddfZ7zvtNNOc5Jcly5d3MEHH+z22WcfV1JS4hKJhHvooYe867r//vtdIpFwsVjMjRkzxh122GGud+/eTpL75S9/6X3Pxx9/7Pr16+ckuS222MIdeeSRboMNNnCS3C677OKqqqqi3B1FpyXHp/6zvOnXCy+8kHVdHJ9wocfn448/bmg/cOBAd9BBB7lDDz3Urbvuuk6S69Gjh3v55Ze96+L4hGvJ9XPYYYe5WCzmtthiC7f//vu7o446yu2www4N/fz617/2rovjE66lnz+N3XrrrQ11oiQ3b948bzuOT+Ex4diB1X/DttNOO7kVK1Y0LL/qqqucJDdmzJic+rnkkkvc2Wef7ebOnZu2fNasWW799dfPehPuKKLal0395S9/cZLcSSed1CkmHKPcj//5z39cRUWF69+/v3v11VfTXksmk+5f//pXVMMuSlHty4ULF7ry8nJXWlrqXnzxxbTXpk6d6srLy10sFmvVpHqxu/TSS93kyZPdI4884hYsWNAwqdUSP/zhD50kN27cOFdbW9uw/NRTT3WS3IQJEyIadXGKal/yuQPk12233eZOOukkN3PmzLTlX375pdtqq62cJHf00Uenvfbss886Sa5v375u1qxZDctfe+01V1ZW5nr37u2WLFmS9p5vv/3W9ezZ00lyDzzwQMPyr776quGHM74JsV122cVJcj//+c8bltXW1rpDDz3USXJTpkxp+ca3Ay05Pv/4xz/c6aef7v7617+6WbNmubFjxzY74cjxaZnQ4/PJJ5+4vffe2z3//PMulUo1LK+qqnITJ050ktz666/vampq0vrj+LRMS66ft99+233zzTcZfb3xxhuue/fuLhaLuRkzZqS9xvFpmZYcn8YWLlzo1lprLTd27Fg3ZMgQc8KR41McmHDsoKqrq12vXr2cJPf2229nvD5y5EgnyU2bNq1V67n77rudJDd06NBW9VPM8rUvv/rqK9enTx+39957uxdeeKHDTzhGvR/3228/J8k9/vjjUQ+16EW5Lx999FEnye2zzz7e1w866CAnyd17772tHnd70dJJsi+//NLF43FXVlbmvvrqq7TXqqqqXP/+/V0ikWj2p7YdSWsmby2d4XMHKKTXXnvNSXLl5eWuurq6YXn95+4f//jHjPf8/Oc/d5LclVdembb8sssuc5LcwQcfnPGeBx980ElyBx54YNryN99800lyAwYMyPhNkq+++sqVlpa6Pn36pP1QpzOxjk9T++yzT7MTjhyf6OV6fOqtWrWqoaZr+oNfjk/0Qo+Pc84df/zxTpK7+uqr05ZzfKKXy/E55phjXEVFhfvkk0+yTjhyfIoDz3DsoF599VUtW7ZMw4YN01ZbbZXx+uGHHy5JevTRR1u1nlGjRkmSvvzyy1b1U8zytS9PO+00rV69Wn/+858jGWexi3I/zps3T08//bQ22GAD7b///pGPtdhFuS/Ly8tzWmffvn3DBtkJPfXUU0qlUho9erTWXnvttNfKy8v1/e9/X8lkUk888USBRtgxdIbPHaCQ6q+x6upqffvtt5LWPDP4n//8p6TvPmMasz53Hn/8cfM9BxxwgCoqKvTcc8+lPRer/j3f//73Mz6j1l57bY0ePVpLlizRK6+80qLta+98x6elOD7RCz0+Xbp00fDhwyVlfq5xfKLXkuuntLRUklRWVpa2nOMTveaOz1NPPaW7775bv/nNbzRs2LCsfXF8igMTjh3Uu+++K0naeuutva/XL58xY0ar1vPpp59KkgYOHNiqfopZPvblE088oXvvvVfnnnuuNtxww9YPsh2Icj+++OKLSqVS2nnnnVVXV6e///3vOu200/Szn/1M119/vZYsWRLdwItQlPty++23V+/evfXPf/5TU6dOTXvtpZde0tNPP62NNtpIo0ePbuWoO762uu92dp3hcwcopPprrLS0VGuttZYk6aOPPlJ1dbX69++v9dZbL+M91v0t232xrKxMW2yxhaqqqjRr1qyc3pNtXZ2F7/i0FMcneqHHJ5VKae7cuZIyP9c4PtELPT7vvfee7r33XpWWlmrvvfdOe43jE71sx6eyslI/+clPtMkmm+jss89uti+OT3FgwrGD+vzzzyXJWxQ2Xl7/AddSV199tSTp4IMPblU/xSzqfVlZWamf/vSn2njjjfWrX/0qmkG2A1Hux5kzZ0qSunfvrtGjR+uoo47S//7v/+q6667TT37yE2244YZ64YUXIhp58YlyX/bq1Us333yz4vG4dt99d+266676wQ9+oF133VW77babtttuOz399NMZP9VFpra673Z2neFzByik+mts3333bfgNj+bub926dVPv3r21ZMkSrVixQpK0fPlyLVu2LOv7fPdF7qXZ+Y5PS3B88iP0+Nxzzz1auHCh+vfvr5133rlhOccnP5o7Po8++qgmTpyoH/7whxo9erS23HJLrVq1SjfddFPab9RxfPIj2/E5//zz9dlnn+n6669v9vsSjk/xKCn0AJAf9XHyXbt29b7erVs3SWooClvi+uuv13PPPafevXvrnHPOaXE/xS7qfXneeedp7ty5euGFFzrVJE6U+7H+Nxj/8pe/qHv37rr77ru17777atGiRbrwwgt111136dBDD9UHH3ygddddN6ItKB5Rn5Pjxo3Tk08+qSOPPFKvvvpqw/KePXtq7NixHXIf5kNb3Hc7u87yuQMUyhNPPKGbb75ZpaWluvDCCxuWN3d/k9bc45YuXaoVK1aoR48eDe/J9j7ffZF7qc06Pi3B8Yle6PGZN2+eTj/9dEnSBRdckDbBwvGJXi7H591339Xtt9/e8O8uXbro6quv1o9+9KO0dhyf6GU7Pm+//bauvvpqTZgwQWPGjGm2L45P8eA3HNEiL7/8sk477TTFYjHdcsstGjRoUKGH1C5MmzZN//u//6tjjz1Wu+22W6GH026lUilJUl1dnW644QYdffTR6tOnj4YPH64777xT2223nZYtW9Zpno/ZWldddZX22msvfe9739OMGTO0cuVKzZgxQ3vssYfOP/98jRs3rtBDBPjcAfLsww8/1Pjx4+Wc0xVXXNHwLC0UB45PcQs9PpWVlRo3bpy++eYbHXLIITr55JPbaKSdU67H57zzzpNzTqtXr9Z7772nSZMm6aSTTtLBBx+smpqaNh5155Ht+CSTSZ1wwgnq3bu3rrzyygKOEi3BhGMH1b17d0nSqlWrvK9XVlZKknr06BHc9/vvv99w07366qt16KGHtnyg7UBU+7Kurk4nnnhip71ZRnlO1vfVvXt3HXHEERmvT5o0SZIynknYUUS5L1988UWdeeaZ2nLLLXXfffdpxIgR6tatm0aMGKH7779fW265pR5//HE9+eST0W1AB5XP+25n19k+d4C2Nn/+fO27775asmSJzjjjDJ122mlprzd3f5My73H178n2Pt99kXtppuaOT0twfKITenxqa2t1xBFHaNq0adp111119913Z7Th+ESnJddPRUWFtthiC1133XU69dRT9dhjj+maa65peJ3jE53mjs+f/vQn/fvf/9bll1+ufv365dQnx6d4MOHYQa2//vqSpC+++ML7ev3yIUOGBPU7Z84cjR07VkuWLNFvf/tbnXrqqa0baDsQ1b784osv9M4776isrExHHHGEdtttt4av+j+nmD59esOyjibKc7K+zfrrr69YLJbx+tChQyVJCxcubMlQi16U+/LOO++UJB166KGKx9M/EhKJRMNvN7700kstHm9nka/7bmfXGT93gLa0ePFijR07VnPnztWkSZO8PxRt7v5WWVmppUuXqk+fPg3fiPXs2VO9evXK+j7ffZF7abpcjk9LcHyiEXp8UqmUJkyYoCeffFJbbrmlHn30UXXp0iWjHccnGlFcP/V/Tv2Pf/yjYRnHJxq5HJ9HH31UsVhMt99+e9r3z7vttpu++uorSWr43vqpp56SxPEpJkw4dlD1v4b89ttve1+vXz5y5Mic+1ywYIH23ntvLViwQKeddpqmTJnS+oG2A1Hvy6+++kpTp05N+6pPxFq6dGnDso4myv241VZbSZKZRr148WJJ6T/d6kii3Jf1H5z1H8pN1S/v6MnfUcjHfbez66yfO0BbWblypfbbbz/NnDlT48aN00033eT9Qd7GG2+s8vJyLVq0SPPnz8943bq/Zbsv1tbW6v3331dFRYWGDx+e03uyrasjyvX4tBTHp3VacnxOPfVU3XPPPRo+fLiefvpp9e7d22zL8WmdqK6f+t+qW7RoUdpyjk/rhBwf55xeeumljO+hq6urJUlvvPGGpk6d2jABKXF8ioZDh1RdXe169erlJLl///vfGa+PHDnSSXLTpk3Lqb/Fixe7ESNGOElu0qRJLpVKRTzi4hX1vvR54YUXnCS35557tmKkxS3K/VhbW+v69u3rYrGY+/DDDzNeP/HEE50kd9xxx0Ux9KIT5b489thjnSR37LHHel8fP368k+R+//vft3bY7UZ5eblrycfjl19+6eLxuCsrK3Nff/112mtVVVWuf//+LpFIZLzWkbV0XzrXuT93gLZQVVXl9thjDyfJ7bPPPq66ujpr+/32289Jcn/84x8zXvv5z3/uJLkrr7wybflll13mJLmDDz444z0PPvigk+QOPPDAtOVvvvmmk+QGDBjgqqqq0l776quvXGlpqevTp4+rqanJbUPbqdDj09Q+++zjJLkXXnjBbMPxabmWHJ/f/OY3TpJbf/313dy5c5ttz/FpudZeP43deuutTpI74IAD0pZzfFouquMzZMgQJ8nNmzcv4zWOT3FgwrEDq/9Q23nnnd3KlSsbll911VVOkhszZkxa+2uuucZtvPHG7pxzzklbXllZ6XbaaScnyR155JGurq6uLYZfVKLal5bOMOHoXLT78eKLL27YZ8uWLWtY/uyzz7rS0lIXi8Xcm2++mbdtKbSo9mX9B24ikXCPPvpo2msPP/ywi8fjLh6Peyd2O6rmJsmynZc//OEPnSR32GGHudra2obl9d+MT5gwIR9DLlot3Zd87gD5VVdX5w499FAnyY0ePdpVVlY2+55nn33WSXJ9+/Z1s2bNalj+2muvufLycte7d2+3ZMmStPd8++23rmfPnk6Se+CBBxqWf/31127DDTc0J8R22WUXJ8mddtppDctqa2vduHHjnCQ3ZcqU0E1uV1pyfJrKZcKR49MyLTk+f/jDH5wkN3DgwLTrJxuOT8uEHp+FCxe6G2+80dvumWeecf3793eS3P3335/2GsenZaK4v9XLNuHI8SkOTDh2YKtXr3Y77LCDk+TWWWcdd+SRRzb8u3///m727Nlp7adMmeL9hvj0009vmJA45phj3IQJE7xfHVlU+9LSWSYco9yPNTU1bq+99nKS3Nprr+0OPvhgt8suu7hEIuEkuYsvvriNtqowotqXqVTKHXHEEU6Sk+S23XZbd8QRR7htt922YVlH35ePPfaY22GHHRq+YrGYk5S27LHHHmton+28XLRokRs2bJiT5IYNG+aOOuoot8UWWzhJbqONNnLffvttG25Z24tqX/K5A+TXn/70p4Z7/KGHHmpeY4sWLUp732mnneYkua5du7qDDz7Y7bfffq6kpMQlEgn30EMPedd1//33u3g87mKxmNt9993d4Ycf7nr37u0kuTPOOMP7nlmzZrm+ffs6SW7EiBHuqKOOchtssEHDD9qa/uZJR9OS4/Pll1+m3Wvr/xJi0003bVh2wQUXZKyL4xMu9Pj8+9//bvg83Gmnncz2L7/8csa6OD7hQo/PnDlzGu5ro0ePdkcffbQ76KCD3CabbNLQzy9+8Qvvujg+4Vr6+eOTbcLROY5PMWDCsYNbtWqVmzx5shs2bJgrKytzAwcOdBMnTvRelNY3fhMmTGi4KWT76uii2JeWzjLh6Fy0+7GmpsZddtllbvPNN3cVFRWuZ8+ebo899sj4Tb2OKqp9mUql3M033+y+973vud69e7uSkhLXr18/t//++7snn3yyDbaksOr/VCbb16233trQvrnz8ttvv3WnnnqqGzx4sCsrK3ODBw92P//5zzN+86cjimpf8rkD5Ff9tdfc15w5czLee+utt7ptttnGde3a1fXu3dvtu+++7tVXX826vldeecXtu+++rnfv3q5r165u2223dbfddlvW93z++edu4sSJbuDAga6srMxtuOGGbvLkyW716tWt2fR2oSXHp37SJNuX9bnF8QkTenzq6/yQz8fGOD5hQo9PZWWlu/zyy93+++/vhgwZ4rp06eLKy8vd0KFD3Q9+8IOsvyXsHMcnVGs+f5pqbsLROY5PocWcc04AAAAAAAAAEAFSqgEAAAAAAABEhglHAAAAAAAAAJFhwhEAAAAAAABAZJhwBAAAAAAAABAZJhwBAAAAAAAARIYJRwAAAAAAAACRYcIRAAAAAAAAQGSYcAQAAAAAAAAQGSYcAQAAcvDSSy/p+9//vgYNGqRYLKaHH3446P1VVVWaOHGiRowYoZKSEh1yyCHedi+++KK23nprlZeXa8MNN9Rtt93W6rEDAAAAbYkJRwAAgBxUVlZq1KhRuu6661r0/mQyqS5duujnP/+59tprL2+bOXPm6IADDtDuu++ud955R6effrpOOOEEPf30060ZOgAAANCmYs45V+hBAAAAtCexWEwPPfRQ2m8pVldX6ze/+Y3uueceLV26VFtssYUuu+wy7bbbbhnvnzhxopYuXZrxW5K/+tWv9Pjjj+v9999vWPaDH/xAS5cu1VNPPZWnrQEAAACixW84AgAAROBnP/uZXn/9df3tb3/TjBkzdMQRR2jffffVxx9/nHMfr7/+esZvP+6zzz56/fXXox4uAAAAkDdMOAIAALTS559/rltvvVX33XefRo8erWHDhunMM8/UrrvuqltvvTXnfr766iutvfbaacvWXnttLV++XKtXr4562AAAAEBelBR6AAAAAO3de++9p2QyqeHDh6ctr66uVt++fQs0KgAAAKAwmHAEAABopZUrVyqRSGj69OlKJBJpr3Xv3j3nfgYOHKivv/46bdnXX3+tnj17qkuXLpGMFQAAAMg3JhwBAABaaauttlIymdTChQs1evToFvez00476Yknnkhb9uyzz2qnnXZq7RABAACANsOEIwAAQA5WrlypTz75pOHfc+bM0TvvvKO11lpLw4cP1w9/+EMde+yxuuqqq7TVVltp0aJFev755zVy5EgdcMABkqSZM2eqpqZGixcv1ooVK/TOO+9IkrbccktJ0sknn6xrr71WZ599to477jj985//1N///nc9/vjjbb25AAAAQIvFnHOu0IMAAAAodi+++KJ23333jOUTJkzQbbfdptraWl100UW64447NH/+fPXr10877rijfve732nEiBGSpKFDh2ru3LkZfTQux1588UX94he/0MyZM7Xeeutp8uTJmjhxYt62CwAAAIgaE44AAAAAAAAAIhMv9AAAAAAAAAAAdBxMOAIAAAAAAACIDBOOAAAAAAAAACLDhCMAAAAAAACAyDDhCAAAAAAAACAyTDgCAAAAAAAAiAwTjgAAAAAAAAAiw4QjAAAAAAAAgMgw4QgAAAAAAAAgMkw4AgAAAAAAAIgME44AAAAAAAAAIsOEIwAAAAAAAIDI/D9gmM/Z5318MQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1600x500 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot the primary wave velocity (vp) and density (rho) of the model\n",
    "model._plot_mu_rho(figsize=(16,5),wspace=0.15,cbar_pad_fraction=0.1, cmap='coolwarm',save_path=os.path.join(project_path,\"model/true_vp_rho.png\"))"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Define the observed systems: Survey = Source + Receiver"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "# Define source positions in the model\n",
    "src_z = np.array([1 for i in range(int(2*zoomfactor), nx-1, int(5*np.ceil(zoomfactor)))])  # Z-coordinates for sources\n",
    "src_x = np.array([i for i in range(int(2*zoomfactor), nx-1, int(5*np.ceil(zoomfactor)))])  # X-coordinates for sources\n",
    "\n",
    "t0=2\n",
    "# Generate wavelet for the source\n",
    "src_t, src_v = wavelet(nt, dt, f0, amp0=1,t0=t0)  # Create time and wavelet amplitude\n",
    "src_t_2, src_v_2 = wavelet(nt, dt, 2*f0, amp0=1,t0=t0)  # Create time and wavelet amplitude\n",
    "src_t_3, src_v_3 = wavelet(nt, dt, 3*f0, amp0=1,t0=t0)  # Create time and wavelet amplitude\n",
    "src_t_4, src_v_4 = wavelet(nt, dt, 4*f0, amp0=1,t0=t0)  # Create time and wavelet amplitude\n",
    "src_t_5, src_v_5 = wavelet(nt, dt, 5*f0, amp0=1,t0=t0)  # Create time and wavelet amplitude\n",
    "src_t_6, src_v_6 = wavelet(nt, dt, 6*f0, amp0=1,t0=t0)  # Create time and wavelet amplitude\n",
    "src_t_7, src_v_7 = wavelet(nt, dt, 7*f0, amp0=1,t0=t0)  # Create time and wavelet amplitude\n",
    "src_t_8, src_v_8 = wavelet(nt, dt, 8*f0, amp0=1,t0=t0)  # Create time and wavelet amplitude\n",
    "src_t_9, src_v_9 = wavelet(nt, dt, 9*f0, amp0=1,t0=t0)  # Create time and wavelet amplitude\n",
    "src_t_10, src_v_10 = wavelet(nt, dt, 10*f0, amp0=1,t0=t0)  # Create time and wavelet amplitude\n",
    "src_v = src_v + src_v_2 + src_v_3 + src_v_4 + src_v_5 + src_v_6 + src_v_7 + src_v_8 + src_v_9 + src_v_10\n",
    "# Normalize the wavelet\n",
    "src_v = src_v / np.max(np.abs(src_v))  # Normalize wavelet to maximum amplitude\n",
    "#src_v = src_v * np.hanning(len(src_v))  # Apply Hanning window to wavelet\n",
    "#src_v = integrate.cumtrapz(src_v, axis=-1, initial=0)  # Integrate wavelet to get velocity\n",
    "\n",
    "source = Source(nt=nt, dt=dt, f0=f0)  # Initialize source object\n",
    "\n",
    "# SH wave\n",
    "mt_sh = np.array([[0, 1, 0],\n",
    "                  [1, 0, 0],\n",
    "                  [0, 0, 0]])\n",
    "\n",
    "# Method 1: Add multiple sources at once (commented out)\n",
    "# source.add_sources(src_x=src_x, src_z=src_z, src_wavelet=src_v, src_type='mt', src_mt=np.array([[1,0,0],[0,1,0],[0,0,1]]))\n",
    "\n",
    "# Method 2: Loop through each source position to add them individually\n",
    "for i in range(len(src_x)):\n",
    "    source.add_source(src_x=src_x[i], src_z=src_z[i], src_wavelet=src_v, src_type=\"mt\", src_mt=mt_sh)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define receiver positions in the model\n",
    "rcv_z = np.array([1 for i in range(0, nx, int(1*np.ceil(zoomfactor)))])  # Z-coordinates for receivers\n",
    "rcv_x = np.array([j for j in range(0, nx, int(1*np.ceil(zoomfactor)))])  # X-coordinates for receivers\n",
    "\n",
    "receiver = Receiver(nt=nt, dt=dt)  # Initialize receiver object\n",
    "\n",
    "# Method 1: Add all receivers at once (commented out)\n",
    "# receiver.add_receivers(rcv_x=rcv_x, rcv_z=rcv_z, rcv_type='pr')\n",
    "\n",
    "# Method 2: Loop through each receiver position to add them individually\n",
    "for i in range(len(rcv_x)):\n",
    "    receiver.add_receiver(rcv_x=rcv_x[i], rcv_z=rcv_z[i], rcv_type=\"vy\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Survey Information:\n",
      "Seismic Source:\n",
      "  Source wavelet: 4000 samples at 4.00 ms\n",
      "  Source number : 20\n",
      "  Source types  : ['mt']\n",
      "  Source x range: 1 - 96 (grids)\n",
      "  Source z range: 1 - 1 (grids)\n",
      "\n",
      "Seismic Receiver:\n",
      "  Receiver data   : 4000 samples at 4.00 ms\n",
      "  Receiver number : 100\n",
      "  Receiver types  : ['vy']\n",
      "  Receiver x range: 0 - 99 (grids)\n",
      "  Receiver z range: 1 - 1 (grids)\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# Create a survey object using the defined source and receiver\n",
    "survey = Survey(source=source, receiver=receiver)\n",
    "\n",
    "# Print a representation of the survey object to check its configuration\n",
    "print(survey.__repr__())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot the wavelet used in the source\n",
    "source.plot_wavelet(save_path=os.path.join(project_path, \"survey/wavelets.png\"))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x800 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot the survey configuration over the velocity model\n",
    "survey.plot(model.vs, cmap='coolwarm', save_path=os.path.join(project_path, \"survey/observed_system.png\"))"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Define the propagator"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Initialize the wave propagator using the specified model and survey configuration\n",
    "F = SHPropagator(model, survey, ifvisualWave=False, projectpath=project_path, device=device)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAr0AAAIHCAYAAACSdeTLAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/xnp5ZAAAACXBIWXMAAA9hAAAPYQGoP6dpAABbnElEQVR4nO3deXQUVd7G8Sdk6expAkF2kLAMLqyKAgYiBmURAcV1dEjEBcURRMZRBBfUUQdBouKIvgjqKM6YURD3IIpoAoIoKCgwyhI2CZB9aUhy3z843ZOmO4FAku4U3885fQ59763qX91OdZ4U1VUBxhgjAAAAwMIa+boAAAAAoK4RegEAAGB5hF4AAABYHqEXAAAAlkfoBQAAgOURegEAAGB5hF4AAABYHqEXAAAAlkfoBQAAgOURegE0eBkZGbrmmmvUsWNHX5dS7zZu3Khbb71VYWFhvi7ltJSfn685c+aoQ4cOWrhwoUf/XXfdpZiYGC1atKjG6/7pp5/UunVr9evXTyUlJbVQLXB6I/QCp5FHH31UL7/88gmNXbNmje655x516tRJAQEBbo/g4GBFRUUpMjJSLVu2VGJioh577DFlZWV5XdfQoUPVqFEjj/UEBASoUaNGuvfee09qe7777jtddNFF6t+/v9555x2VlZWd1Hoaop07d+ryyy/XOeeco//7v/9TaWmpr0s67UybNk1nnnmm7rnnHm3bts3rmNdee035+fl66623arz+Tz/9VLt371ZmZqY2bdp0quUCMABOCw6HwzRv3tx069atRsvl5+eb6OhoI8k0b97cbN++3dVXWFhoPv30U3PxxRcbSSYwMNCkpqZ6XU9BQYG56aabjCQjycTExJgPP/zQHD58+KS3qbi42Bw5csSMGzfOSDLt2rU76XU1NA6Hw5SWlppHHnnENaeoX/n5+Wbbtm0mICDASDILFizwGPPcc8+ZPn36mBUrVtR4/Xv27DFJSUkmJSXFlJeX10LFwOmNI73AaeJf//qX9u3bpw0bNuirr7464eWioqLUpUsXSZLNZlO7du1cfREREbr00kv1+eefa+zYsSovL9fEiRP1/PPPe6wnMjJSd999t+v5ddddp2HDhik4OPiktyksLExBQUHq1avXSa+joQoJCZHNZlPv3r19XcppKyoqSu3bt1dsbGyVY/785z9r9erVGjBggNf+3Nxc3XXXXV77WrRoofT0dL366qtq1Ihf18CpYi8CThPPPfec698vvPBCjZYNDw+vtj8gIEAvvPCC7Ha7JOmRRx7RkSNHPMZVDgdxcXE1qqE6oaGhtbauhoZzeX3vVN6D559/XoWFhbVYDYCqEHqB00BGRobWrl2rs846S5L03nvvaffu3bX6GpGRka6jWYcOHdJPP/3kMaby0arAwMBae+3T+ShYbc4jTs7JvgcbNmzQ3/72t1quBkBVTt/fFMBp5LnnntOgQYP0+OOPS5LKysr00ksv1frrBAUFuf5NGAOqtn79eg0ZMoQvIAL1iNALWNzu3bv1n//8RxMmTNCIESPUsmVLSdIrr7yiw4cP19rrVFRUaO3atZIku92uzp0719q6a+qHH37Q0KFDFRUVpRYtWujPf/6zcnJyqhy/bt063XTTTYqPj1dkZKTatWuncePGacuWLW7jJk6c6HYVisTERFffnj17FBQU5HZliu3bt7st/8UXX2jEiBEaNGiQJGnv3r26+eab1aRJEzVr1kz33XefysvLq6zzrbfeUkJCguLi4hQdHa2RI0fqv//9b5XjHQ6HUlNTdd5556l58+aKjIzU2WefrYceesjrJbCWL1+uq6++Wp06dZIkLV26VPHx8WrZsqU+++wzr1feeOqpp9zWkZSU5DZm+fLlVdZ3rBUrVmjUqFFq0aKFoqKidO655+qpp56q8nJde/bs0f3336+uXbvKbrfrjDPO0BVXXKH09HSv43ft2qX7779fsbGx2r59u4wxmjt3rrp06aKIiAglJSVVO5+//PKL/vSnP6l169aKjo7WOeecU+1VGQ4ePKg5c+bo7LPP1iOPPOJqX7RokYYMGaIDBw5IOvq+2u122e12Pfroo65xX331lW666aZqT5/YunWr7rzzTnXq1EnR0dFq2bKlrrvuOq1Zs8br+M2bN+uOO+5QRESEJOnw4cN67LHH1L59e0VFRWn06NHKzs6u8vWABs3X36QDULemTp1qWrdubcrKyowxxjz00EOub/u/8cYbJ7SOgQMHHvfqCHPnznWtd/bs2V7HbNu2zTXm4YcfrummVGnBggWu+j799FMTFhZmgoKCXK8lyfzhD38w2dnZXusODQ01zz33nCktLTUOh8O88sorxmazGZvNZt555x238b///rvp1q2bkWQGDhzo1ldeXm4ee+wx12tu27bNGGPMF198YS677DJX+8CBA82PP/5oWrZsac444wwTGRnp6nvsscc8aiwvLzc33nijCQkJMS+//LI5cuSIOXjwoLn99ttNo0aNvF69obS01Fx44YUmJCTEfPLJJ8YYY7Zu3Wq6d+9uJJmrr77aNTYjI8NcdNFFrvW0a9fOLF++3DRt2tTVdvnll5uVK1cau93uatuwYYPX9+NPf/qTCQsLq9EVC6ZOnWpiYmLMokWLTElJicnPzzcjRowwksx5551nioqK3MZ//fXXJi4uztxyyy2u93X58uWmbdu2RpK59957XWNzc3PNXXfdZSIiIly1b9myxVx11VUmPDzctGjRwtXepUsXc+TIEY/6lixZYkJDQ81VV11l9u3bZ8rLy82//vUvExUV5XoPKl+9YdasWebss8+u9ud97NixRpIZO3asW/tvv/1mRo0aZcLCwqq9Mse7775rIiIizLRp00x+fr4pKysz7777rmncuLFp1KiRmTNnjmvsjh07TEpKitt+kZeXZy666CITHR1tmjVr5mq/5JJLjvd2AQ0SoRewsJKSEtO0aVO3IJWVlWUCAwONJHPBBRec0Hqcobdly5Zm//79rvaioiLz/fffm3vvvdcEBgaaiIgI8/TTT1e5nroOvdHR0WbgwIEmIyPDVFRUmJ07d5rRo0e7XvOaa65xW27ZsmUmICDA3HfffR7rnDdvnpFkgoKCzNq1a936pk6d6jX0GmPML7/84hF6i4uLjTHGjBw50hXAhw0bZjIzM40xxhw5csQMHz7cdVm4Y02bNs1IMs8++6xbe0VFhenfv7/XYOSck379+rm1v/fee0aSadSokasup7vuustIMmeccYa54YYbTHFxsUlLSzMDBgwwH374oTHGmFdffdX1ev/97389ajXGmOHDh5u77rrLa583zz//vJFk/v3vf7u1f/LJJ67Xeumll1zt+/btM02bNjUXXHCBqaiocFvmxx9/NMHBwUaSK/SVl5cbh8Ph2nZJZsSIEeb55583paWlxhhjFi1a5Opz/pHg9NNPPxmbzWZ69+7tEYhffvll13LHXrKsvLzcFahrEnqdXnzxxSpD78aNG43NZvP4mTbGmE8//dS13OLFi40xRy9xV15ebp599llX37XXXmvefPNN1x/ETz75pKvvl19+8VoT0JARegELmz9/vgkODjb79u1za3eG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sDxCLwAAACyP0AsAAADLI/QCAADA8gi9AAAAsDxCLwAAACyP0AsAAADLI/QCAADA8gi9AAAAsDxCLwAAACyP0AsAAADLI/QCAADA8gi9AAAAsDxCLwAAACyP0AsAAADLI/QCAADA8gi9AAAAsDxCLwAAACyP0AsAAADLI/QCAADA8gi9AAAAsDy/Db3fffednnrqKV155ZVq3bq1AgICFBAQcNzlFi5cqD59+igyMlKxsbEaNmyYMjIy6qFiAAAA+KsgXxdQlccee0xLliyp0TKTJk1SamqqwsLCdOmll6q0tFTp6en67LPPlJaWplGjRtVNsQAAAPBrfht6+/btq27duun888/X+eefr/bt28vhcFQ5ftmyZUpNTVWTJk2UmZmpTp06SZIyMzOVmJiolJQUJSYmym6319MWAAAAwF/4bej961//WqPxs2fPliRNmzbNFXilo+F5/Pjxeu655zR//nzde++9tVonAAAA/J/fntNbEyUlJVq+fLkkacyYMR79zralS5fWa10AAADwD5YIvZs3b5bD4VBcXJxat27t0d+rVy9J0oYNG+q7NAAAAPgBvz29oSZ27twpSV4DryRFRETIbrcrJydHBQUFioqK8jrO4XC4nTecn59f+8UCAACg3lniSG9hYaEkKTw8vMoxERERkqSCgoIqxzz55JOKiYlxPdq0aVO7hQIAAMAnLBF6a8sDDzygvLw81yMrK8vXJQEAAKAWWOL0hsjISElScXFxlWOKiookqcpTGyTJZrPJZrPVbnEAAADwOUsc6W3btq0kadeuXV77i4qKlJubq8aNG1cbegEAAGBNlgi9Xbp0kc1mU3Z2tnbv3u3Rv27dOklSt27d6rs0AAAA+AFLhN6wsDANGjRIkvTOO+949KelpUmSRowYUa91AQAAwD9YIvRK0uTJkyVJjz/+uLZu3epqz8zM1Lx582S32zVu3DhflQcAAAAf8tsvsn344Yd67LHHXM8PHz4sSbrwwgtdbdOnT9fw4cMlSUlJSZo4caJSU1PVo0cPDR48WIcPH1Z6erqMMVqwYIHsdnu9bgMAAAD8g9+G3uzsbK1evdqjvXJbdna2W9+cOXPUo0cPvfDCC0pPT1dISIiSkpI0ffp09evXr85rBgAAgH/y29CbnJys5OTkelsOAAAA1mWZc3oBAACAqhB6AQAAYHmEXgAAAFge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6NFDq1atqnYZQi8AAAD8wQmH3oCAAN1yyy3asGGD+vfvr//+979KSEjQ1KlTdeTIEa/LBAYG1lqhBw8eVLNmzRQQEKCOHTtWO3bhwoXq06ePIiMjFRsbq2HDhikjI6PWagEAAEDDUuOrN5x55plasWKFnn76aQUFBenpp59Wnz599OOPP9ZFfS733nuvDhw4cNxxkyZNUkpKin766SclJSWpT58+Sk9P14ABA7R48eI6rREAAAD+6aQuWRYQEKC//OUvWrNmjbp166b169fr/PPP19NPPy1jTG3XqM8//1yvvfaabr311mrHLVu2TKmpqWrSpInWr1+vxYsX65NPPtFXX32lwMBApaSkKDc3t9brAwAAgH874dBbVlbm0XbOOedozZo1euCBB1ReXq6pU6cqISFBv/32myTVSgAuKSnR7bffrrPOOktTpkypduzs2bMlSdOmTVOnTp1c7X379tX48eOVm5ur+fPnn3JNAAAAaFhOOPTu2LHDa3tQUJCeeOIJrVy5UvHx8crIyFCPHj30j3/8o1YKfPTRR/Xbb7/ppZdeUnBwcJXjSkpKtHz5cknSmDFjPPqdbUuXLq2VugAAANBwnHDozcrK0oQJE3Tw4EGv/RdeeKHWr1+vO+64Q0VFRbrrrru0cuXKUypuw4YNmjVrllJSUpSQkFDt2M2bN8vhcCguLk6tW7f26O/Vq5drnQAAADi9nHDo/fTTT9W/f3+99dZbVQbHsLAwzZ07V5988olatGhxSqc3VFRU6JZbbpHdbtff//73447fuXOnJHkNvJIUEREhu92unJwcFRQUeB3jcDiUn5/v9gAAAEDDF3SiAwcPHnzCKx08eLB++ukn/fWvfz2poiTp+eef15o1a7RgwQI1adLkuOMLCwslSeHh4VWOiYiIUG5urgoKChQVFeXR/+STT+rRRx896ZoBAADgn07q6g0nwm63a968eSe17M6dOzVt2jQNHDhQycnJtVtYNR544AHl5eW5HllZWfX22gAAAKg7J3yktz5NmDBBhw8f1ksvvXTCy0RGRkpStbdHLioqkiSvR3klyWazyWaz1aBSAAAANAR+GXo/+OAD2e12jR8/3q29tLRUkrR7924lJiZKkt5++201b97cdcvjXbt2eV1nUVGRcnNz1bhx4ypDLwAAAKzJL0OvJOXm5mrFihVe+0pLS119ziDcpUsX2Ww2ZWdna/fu3WrVqpXbMuvWrZMkdevWrQ6rBgAAgD+qs3N6T4Uxxutj27ZtkqT4+HhXW/v27SUdvXLEoEGDJEnvvPOOxzrT0tIkSSNGjKifjQAAAIDf8MvQe7ImT54sSXr88ce1detWV3tmZqbmzZsnu92ucePG+ao8AAAA+IilQm9SUpImTpyogwcPqkePHho1apSGDRumAQMGqKysTAsWLJDdbvd1mQAAAKhnlgq9kjRnzhwtWLBAXbt2VXp6ujIzM5WUlKSvvvpKo0aN8nV5AAAA8AG//SKbN+3btz+hu7wlJyfX6/V9AQAA4N8sd6QXAAAAOBahFwAAAJZH6AUAAIDlEXoBAABgeYReAAAAWB6hFwAAAJZH6AUAAIDlEXoBAABgeYReAAAAWB6hFwAAAJZH6AUAAIDlEXoBAABgeYReAAAAWB6hFwAAAJZH6AUAAIDlEXoBAABgeYReAAAAWB6hFwAAAJZH6AUAAIDlEXoBAABgeYReAAAAWB6hFwAAAJZH6AUAAIDlEXoBAABgeYReAAAAWB6hFwAAAJZH6AUAAIDl+W3oTUxMVEBAQJWPTz75xOtyCxcuVJ8+fRQZGanY2FgNGzZMGRkZ9Vw9AAAA/EmQrws4nquuukqRkZEe7a1atfJomzRpklJTUxUWFqZLL71UpaWlSk9P12effaa0tDSNGjWqHioGAACAv/H70PvMM8+offv2xx23bNkypaamqkmTJsrMzFSnTp0kSZmZmUpMTFRKSooSExNlt9vrtmAAAAD4Hb89vaGmZs+eLUmaNm2aK/BKUt++fTV+/Hjl5uZq/vz5vioPAAAAPmSJ0FtSUqLly5dLksaMGePR72xbunRpvdYFAAAA/+D3pzfMnz9fBw8eVKNGjdS5c2eNGjVKbdu2dRuzefNmORwOxcXFqXXr1h7r6NWrlyRpw4YN9VIzAAAA/Ivfh97HH3/c7fmUKVM0ffp0TZ8+3dW2c+dOSfIaeCUpIiJCdrtdOTk5KigoUFRUlNdxDodDDofD9Tw/P/9UywcAAIAf8NvTGwYMGKA33nhDv/76q4qLi7V582Y98cQTCgoK0kMPPaTU1FTX2MLCQklSeHh4leuLiIiQJBUUFFQ55sknn1RMTIzr0aZNm1raGgAAAPiS34beGTNm6MYbb1SHDh0UFhamzp07a+rUqVq8eLEk6ZFHHlFJSUmtvuYDDzygvLw81yMrK6tW1w8AAADf8NvQW5VLL71U5513nnJzc7V69WpJcl3Ht7i4uMrlioqKJKnKUxskyWazKTo62u0BAACAhq/BhV5JrkuS7d27V5JcX2zbtWuX1/FFRUXKzc1V48aNqw29AAAAsKYGGXpzcnIk/e883S5dushmsyk7O1u7d+/2GL9u3TpJUrdu3eqvSAAAAPiNBhd6s7OztXLlSkn/uxRZWFiYBg0aJEl65513PJZJS0uTJI0YMaKeqgQAAIA/8cvQm5GRocWLF6u8vNytffv27Ro9erSKiop0xRVXuF2ibPLkyZKOXuJs69atrvbMzEzNmzdPdrtd48aNq58NAAAAgF/xy+v0btmyRSkpKWrevLl69eolu92uHTt26LvvvlNpaanOPvtsvfLKK27LJCUlaeLEiUpNTVWPHj00ePBgHT58WOnp6TLGaMGCBbLb7b7ZIAAAAPiUX4beCy64QHfccYdWr16tNWvWKCcnRxEREerRo4euvvpq3XHHHQoLC/NYbs6cOerRo4deeOEFpaenKyQkRElJSZo+fbr69evngy0BAACAP/DL0Nu1a1e9+OKLJ7VscnKykpOTa7cgAAAANGh+eU4vAAAAUJsIvQAAALA8Qi8AAAAsj9ALAAAAyyP0AgAAwPIIvQAAALA8Qi8AAAAsj9ALAAAAyyP0AgAAwPIIvQAAALA8Qi8AAAAsj9ALAAAAyyP0AgAAwPIIvQAAALA8Qi8AAAAsj9ALAAAAyyP0AgAAwPIIvQAAALA8Qi8AAAAsj9ALAAAAyyP0AgAAwPIIvQAAALA8Qi8AAAAsj9ALAAAAyyP0AgAAwPIIvQAAALA8Qi8AAAAsz+9Db3Z2tqZMmaIuXbooLCxMsbGx6tWrl/7yl794Hb906VINHDhQ0dHRio6OVmJioj788MN6rhoAAAD+xK9D73fffaeuXbtq1qxZCg4O1siRI3XhhRfq0KFDevbZZz3Gz5kzR1dccYUyMjLUv39/DRo0SN9++60uv/xyvfDCCz7YAgAAAPiDIF8XUJXs7GwNGTJEJSUlWrJkia644gq3/m+//dbt+ebNmzVlyhTZbDZ98cUX6tu3ryRpy5Yt6tevn+655x4NGTJEHTt2rLdtAAAAgH/w2yO9Dz/8sA4cOKCZM2d6BF5J6tOnj9vz1NRUlZeXa/z48a7AK0mdO3fWgw8+qLKyMqWmptZ53QAAAPA/fhl6S0pK9M9//lMRERFKSUk5oWWc5+2OGTPGo8/ZtnTp0torEgAAAA2GX57esHbtWhUUFOiiiy5SWFiYPv74Y6Wnp6u0tFSdO3fWNddco5YtW7rG5+bmaufOnZKknj17eqyvTZs2atq0qXbs2KH8/HxFR0fX27ac7ioqKnxdAgAAgH+G3k2bNkmSmjVrplGjRmnJkiVu/VOnTtX8+fN1/fXXS5Ir8DZu3FgRERFe19m6dWsdOHBAO3bs0LnnnluH1QMAAMDf+OXpDTk5OZKk999/X5988onmzp2r/fv3a/v27ZoyZYpKSko0duxY/fDDD5KkwsJCSVJ4eHiV63SG4YKCgirHOBwO5efnuz0AAADQ8Pll6HX+l3hZWZlmzJihO++8U3FxcWrXrp1mzpypq6++WkeOHNHMmTNr9XWffPJJxcTEuB5t2rSp1fUDAADAN/wy9EZGRrr+7e2LbM62FStWuI0vLi6ucp1FRUWSpKioqCrHPPDAA8rLy3M9srKyal48AAAA/I5fntPbrl07SUdPV4iLi/Pob9++vSRp//79kqS2bdtKOnpaRFFRkdfzenft2uW2bm9sNptsNtsp1X46Kysr83UJAAAAXvnlkV7nFRhKSkrkcDg8+g8dOiTpf0d47Xa7K/h+//33HuOzsrJ04MABtWvXjis3AAAAnIb8MvS2bdtW3bt3lzHGdQpDZc62ypcnGz58uCQpLS3NY7yzbcSIEXVRLgAAAPycX4ZeSbrvvvskSVOmTNHevXtd7T/88INmzZolSRo/fryrfeLEiQoMDNRLL72kVatWudq3bt2qJ554QkFBQZo4cWI9VQ8AAAB/4pfn9ErSDTfcoM8++0yvvfaazjrrLPXr108lJSXKyMiQw+HQrbfeqquvvto1vkuXLpo5c6YmT56shIQEDR48WCEhIfrss89UUlKi5557Th07dvThFlnPkSNHfF0CAADACfHb0CtJCxYsUP/+/TVv3jx9+eWXCggIUK9evXT77bdr7NixHuPvuecedezYUTNnztTKlSslSeedd57uu+8+XX755fVdPgAAAPyEX4fegIAA3Xrrrbr11ltPeJkRI0Zw7i4AAADc+O05vQAAAEBt8esjvfAfhw8f9nUJAAAAJ40jvQAAALA8Qi8AAAAsj9ALAAAAyyP0AgAAwPL4Ihu8Ki0t9XUJAAAAtYYjvQAAALA8Qi8AAAAsj9ALAAAAy+OcXkiSSkpKfF0CAABAneFILwAAACyP0AsAAADLI/QCAADA8gi9AAAAsDy+yHYaKioq8nUJAAAA9YojvQAAALA8Qi8AAAAsj9ALAAAAy+Oc3tNAYWGhr0sAAADwKY70AgAAwPIIvQAAALA8Qi8AAAAsj9ALAAAAy+OLbBZTUFDg6xIAAAD8Dkd6AQAAYHmEXgAAAFgeoRcAAACW55fn9H755Ze6+OKLjzvu0Ucf1UMPPeTWtnDhQr344ovatGmTQkJCdOGFF2ratGnq169fXZXrU3l5eb4uAQAAwO/5Zeht3ry5xo4d67WvvLxc//znPyVJCQkJbn2TJk1SamqqwsLCdOmll6q0tFTp6en67LPPlJaWplGjRtV16QAAAPBDfhl6//CHP2jhwoVe+z7++GP985//VJs2bZSYmOhqX7ZsmVJTU9WkSRNlZmaqU6dOkqTMzEwlJiYqJSVFiYmJstvtdb8BAAAA8CsN7pxe51HeP/7xjwoICHC1z549W5I0bdo0V+CVpL59+2r8+PHKzc3V/Pnz67dYAAAA+IUGFXqLioq0ZMkSSdJNN93kai8pKdHy5cslSWPGjPFYztm2dOnSeqgSAAAA/sYvT2+oyrvvvquioiL17NlTZ511lqt98+bNcjgciouLU+vWrT2W69WrlyRpw4YN9VZrXcjJyfF1CQAAAA1Sgwq9zlMbKh/llaSdO3dKktfAK0kRERGy2+3KyclRQUGBoqKivI5zOBxyOByu5/n5+bVRNgAAAHyswZzesHfvXn3++ecKDAzU9ddf79ZXWFgoSQoPD69y+YiICEnV36b3ySefVExMjOvRpk2bWqgcAAAAvtZgQu+iRYtUXl6uwYMHq3nz5nXyGg888IDy8vJcj6ysrDp5HQAAANSvBnN6Q1WnNkhSZGSkJKm4uLjK5YuKiiSpylMbJMlms8lms51KmbWKc3gBAABqR4M40vvzzz/r+++/V2RkpNcbTLRt21aStGvXLq/LFxUVKTc3V40bN6429AIAAMCaGkTofeONNyRJV155pdfzdrt06SKbzabs7Gzt3r3bo3/dunWSpG7dutVtoQAAAPBLfh96jTF66623JHk/tUGSwsLCNGjQIEnSO++849GflpYmSRoxYkQdVQkAAAB/5vfn9K5cuVI7duxQq1atXMHWm8mTJ+vjjz/W448/ruHDh7vdhnjevHmy2+0aN25cfZV9Ug4ePOjrEgAAACzJ74/0Or/AdsMNN6hRo6rLTUpK0sSJE3Xw4EH16NFDo0aN0rBhwzRgwACVlZVpwYIFstvt9VQ1AAAA/Ilfh16Hw+E6NeHGG2887vg5c+ZowYIF6tq1q9LT05WZmamkpCR99dVXXr8ABwAAgNODX5/eYLPZdOjQoRotk5ycrOTk5LopCAAAAA2SXx/pBQAAAGqDXx/ptbLs7GxflwAAAHDa4EgvAAAALI/QCwAAAMsj9AIAAMDyOKe3nvz+++++LgEAAOC0xZFeAAAAWB6hFwAAAJZH6AUAAIDlEXoBAABgeXyRrQ7wpTUAAAD/wpFeAAAAWB6hFwAAAJZH6AUAAIDlcU5vLdi7d6+vSwAAAEA1ONILAAAAyyP0AgAAwPIIvQAAALA8Qi8AAAAsjy+y1RBfWgMAAGh4ONILAAAAyyP0AgAAwPIIvdUwxvi6BAAAAJyA4+U2Qm81CgoKfF0CAAAATsDxcluA4XBmlSoqKrRnzx4ZY9S2bVtlZWUpOjra12VZUn5+vtq0acMc1xHmt+4xx3WL+a17zHHdY47rhjFGBQUFatmypRo1qvp4LldvqEajRo3UunVr5efnS5Kio6P5Ia1jzHHdYn7rHnNct5jfuscc1z3muPbFxMQcdwynNwAAAMDyCL0AAACwPELvCbDZbHr44Ydls9l8XYplMcd1i/mte8xx3WJ+6x5zXPeYY9/ii2wAAACwPI70AgAAwPIIvQAAALA8Qi8AAAAsj9BbjZKSEj300EPq3LmzQkND1bJlS918883avXu3r0trEIqLi7V48WKNGzdOXbp0UWhoqCIiItS9e3fNmDFDhYWFVS67cOFC9enTR5GRkYqNjdWwYcOUkZFRj9U3TAcPHlSzZs0UEBCgjh07VjuWOa6Z7OxsTZkyRV26dFFYWJhiY2PVq1cv/eUvf/E6funSpRo4cKDrepyJiYn68MMP67nqhmPNmjW65ppr1LJlSwUHB8tutyshIUELFizwemvR8vJyPfvsszr33HMVFhamuLg4XXPNNfr55599UL3vfffdd3rqqad05ZVXqnXr1goICFBAQMBxlzuZz4FvvvlGw4YNU2xsrCIjI9WnTx+9/vrrtbUpfqsmc1xRUaGVK1fqvvvuU+/evRUVFSWbzab4+HiNHz9e27Ztq/a1Ttc5rnMGXpWUlJgLL7zQSDItWrQw11xzjenTp4+RZOLi4syvv/7q6xL93iuvvGIkGUmma9eu5uqrrzaXXXaZiYqKMpLMH/7wB/P77797LDdx4kQjyYSFhZmRI0eayy67zAQFBZnAwEDz3nvv1f+GNCBjx441AQEBRpKJj4+vchxzXDNr1641TZo0MZLM2Wefba699lozdOhQ065dOxMYGOgx/tlnnzWSTFBQkBkyZIgZOXKkCQsLM5LM888/74Mt8G9paWkmMDDQSDK9evUy11xzjbn44otNUFCQkWRuuOEGt/Hl5eVm9OjRRpKx2+3mqquuMgMHDjQBAQEmPDzcrF692kdb4jsjR450fd5WflTnZD4HnO9VQECAGThwoLnqqquM3W43ksy9995bB1vmP2oyx1u3bnX1N2/e3FxxxRVm9OjRplWrVkaSiYqKMitXrvS67Ok8x3WN0FuFBx980Egyffv2NQUFBa72WbNmGUlm4MCBviuugVi4cKG57bbbzKZNm9za9+zZY3r27Gkkmeuvv96tLz093UgyTZo0MVu2bHG1Z2RkmJCQEGO3201OTk59lN/gLFu2zEgyt912W7Whlzmumf3795umTZua8PBws2TJEo/+YwPWL7/8YgIDA43NZjMZGRmu9s2bN5smTZqYoKAgs3Xr1jqvu6E4cuSIadasmZFk3nzzTbe+TZs2mdjYWCPJLF++3NXu/IO6U6dOZt++fa72tLQ0I8l07NjRHDlypN62wR889dRTZvr06eb99983e/fuNTabrdrQezKfAwcPHjTR0dFGkvnPf/7jat+3b5/p2LGjkWS++OKL2t40v1GTOf7vf/9rBg8ebD7//HNTUVHhai8tLTXJyclGkmnbtq05fPiw23Kn+xzXNUKvFw6Hw8TExBhJZt26dR793bp1M5LM2rVrfVCdNWRkZBhJxmazGYfD4WofOnSokWSeffZZj2XuvvtuI8k888wz9Vhpw1BcXGzi4+PNWWedZbZs2VJt6GWOa+aOO+4wkszcuXNrNH7ixIkefbNnzzaSzF133VXLVTZcP/74o5FkunTp4rXf+TP59NNPu9q6du1qJHk9GnnFFVcYSSYtLa2uSm4Qjhd6T+Zz4OmnnzaSzMiRIz2Weffdd40kc/nll59q6Q3G8ea4KsXFxa6M8eWXX7r1Mcd1i3N6vfjmm2+Ul5en+Ph49ezZ06N/zJgxko6es4eT0717d0mSw+HQwYMHJR09h3r58uWS/jfHlTHvVXv00Uf122+/6aWXXlJwcHCV45jjmikpKdE///lPRUREKCUl5YSWcZ63y/yemBO9SH+TJk0kSdu2bdPPP/+ssLAwDR8+3GMcc3x8J/s5UN3P9vDhwxUaGqply5aptLS0tku2lLCwMHXu3FmStGfPHrc+5rhuEXq9WL9+vSSpV69eXvud7Rs2bKi3mqzmt99+kyQFBwcrNjZWkrR582Y5HA7FxcWpdevWHssw795t2LBBs2bNUkpKihISEqodyxzXzNq1a1VQUKCePXsqLCxMH3/8sSZPnqw777xTc+bM8fiFlZubq507d0qS1z+Y27Rpo6ZNm2rHjh3Kz8+vl23wdx06dFB8fLw2b96st956y63v559/1j//+U81btxYo0ePlvS/z+dzzjnH6x94/Awf38l+DlT3uzEkJETnnHOOSktLtWXLljqo2joqKiq0Y8cOSVLz5s3d+pjjukXo9cL5S8vbh0HlducPLWouNTVVkjRkyBDXkZ7jzXtERITsdrtycnJUUFBQP4X6uYqKCt1yyy2y2+36+9//ftzxzHHNbNq0SZLUrFkzjRo1SsOGDdOzzz6rf/zjH7rnnnvUsWNHLVq0yDXeOb+NGzdWRESE13Xy+eEuMDBQr732mux2u/74xz+qd+/euu666zRo0CB169ZNrVu31ueff+7645jP51N3Mp8D+fn5ysvLq3Y55v7ELFq0SPv371dcXJz69evnameO6x6h1wvnpbTCw8O99jt/mREKTs5HH32k+fPnKzg4WI899pir/XjzLjH3x3r++ee1Zs0azZw50/Xfv9VhjmsmJydHkvT+++/rk08+0dy5c7V//35t375dU6ZMUUlJicaOHasffvhBEvN7svr3768VK1aoQ4cOWrdunf71r3/piy++UKNGjTR48GB16NDBNZbP51N3Mj+nlS8xydyfvKysLE2aNEmSNGPGDLfTe5jjukfoRb365ZdfdOONN8oYo5kzZ7rO7UXN7dy5U9OmTdPAgQOVnJzs63IsqaKiQpJUVlamGTNm6M4771RcXJzatWunmTNn6uqrr9aRI0c0c+ZMH1fasC1atEh9+vRRmzZttHr1ahUWFmrLli1KTk7WrFmzNGjQIDkcDl+XCZySoqIiXXnllTpw4IBGjRql8ePH+7qk0w6h14vIyEhJR2+u4E1RUZEkKSoqqt5qsoLdu3dryJAhysnJ0eTJkzVx4kS3/uPNu8TcVzZhwgQdPnxYL7300gkvwxzXjHO+JHn9IpuzbcWKFW7jmd8Tt3XrVo0dO1ZNmzbVBx98oD59+igiIkKdOnXSvHnzdPnll2vdunV69dVXJfH5XBtO5ue08r7A3NfckSNHdPXVV2vt2rW66KKLPM5fl5jj+kDo9aJt27aSpF27dnntd7a3a9eu3mpq6A4dOqRLL71UO3bsUEpKip555hmPMceb96KiIuXm5qpx48bs8JI++OADhYeHa/z48UpMTHQ9rrvuOklH/8hwtu3bt08Sc1xTzn08PDxccXFxHv3t27eXJO3fv1/S/+Y3JyfH9cvpWHx+uHv77bd15MgRDRkyxO2XvtM111wjSfrqq68k8flcG07mcyA6OloxMTHVLsfce1dRUaGxY8fq448/Vo8ePbR06VKFhYV5jGOO6x6h1wvnf7mvW7fOa7+zvVu3bvVWU0NWWFiooUOHatOmTbryyiv1yiuveL11Y5cuXWSz2ZSdne31Vs/Mu6fc3FytWLHC7bF69WpJUmlpqavNeXkb5rhmnFdgKCkp8frf64cOHZL0vyM0drvdFSi+//57j/FZWVk6cOCA2rVrp+jo6Loqu0Fx/hJ3/rI/lrPdeX618/P5p59+0pEjRzzG8zN8fCf7OVDd78YjR47op59+UmhoqOtyXDjqz3/+sxYtWqTOnTvr008/ld1ur3Isc1y3CL1e9O/fXzExMfr1119dX1CpLC0tTZI0YsSIeq6s4XE4HBo5cqS+/fZbXXbZZVq0aJECAwO9jg0LC9OgQYMkSe+8845HP/Puzhy9uYzHw3lP9/j4eFeb84gkc1wzbdu2Vffu3WWMcZ3CUJmzrfLlyZzXjnXOZWXMryfnJZvWrl3rtX/NmjWS/ndU/cwzz1TXrl1VUlLiuqZpZczx8Z3s50B1P9sffPCBSktLlZSUpNDQ0NouucGaNm2aXnzxRbVt21bp6elq1qxZteOZ4zrmq7ti+DvnbYj79etnCgsLXe3chvjElZWVmdGjRxtJJiEhwRQVFR13mepujWmz2bhF7gnYtm3bSd+GmDn29OabbxpJ5txzzzV79uxxtX///feuW+T++9//drVXvg1xZmamq33Lli3chtiL7777zkgyksyLL77o1peZmWkiIiKMJJOenu5qr3wb4t9//93V/p///Oe0vQ3xsU7lNsRVfQ5UdYvc33///bS8Re7x5th5B8bmzZu7zXF1mOO6ReitQklJibnggguMJNOiRQtzzTXXuJ7HxcWZX3/91dcl+r05c+a4fpmNHj3ajB071usjOzvbbbmJEycaSSY8PNyMHDnSDB061AQFBZnAwECvtx2Fu+OFXmOY45oaO3askWTsdrsZNmyYufjii12/8G699VaP8c5fdkFBQWbo0KFm5MiRJiwszEgyzz33nA+2wL9NmTLF9Vlx9tlnm6uvvtr079/fNGrUyEgyt912m9v48vJy1x/UjRs3NmPGjDGJiYkmICDAhIWFmVWrVvloS3zngw8+MBdccIHrERAQYCS5tX3wwQduy5zM50BaWppp1KiRCQgIMBdffLEZM2aMsdvtRpKZPHlyPWyp79Rkjr///ntXf9++fav8/bdy5UqP1zmd57iuEXqrUVxcbKZPn27i4+NNSEiIad68uUlOTjZZWVm+Lq1BePjhh12/yKp7bNu2zWPZBQsWmN69e5vw8HBjt9vNkCFDzDfffFP/G9EAnUjoNYY5romKigrz8ssvu+YrIiLC9O3b1yxcuLDKZd5//32TkJBgIiMjTWRkpElISDBLly6tx6oblnfffddceumlrqPhjRs3NhdffLF56623vI4vKyszs2bNMmeffbYJDQ01TZo0MWPGjDEbN26s58r9w4IFC477WbtgwQKvy9X0c+Drr782Q4YMMXa73YSHh5vzzjuv2n3BKmoyx1988cUJ/f7z9p4Yc/rOcV0LMMaYkzovAgAAAGgg+CIbAAAALI/QCwAAAMsj9AIAAMDyCL0AAACwPEIvAAAALI/QCwAAAMsj9AIAAMDyCL0AAACwPEIvAAAALI/QCwAAAMsj9AKAxTz99NNq0qSJAgICXA+bzabk5GTXmPfee0/x8fGu/qZNm2rBggW+KxoA6liAMcb4uggAQO1yOBz629/+phkzZkg6GoTvu+8+tzGlpaWKjIzU7bffrpkzZyo8PNwXpQJAvSD0AoCF3X///Xr66ad1zjnn6LvvvlNISIir74knnlBWVpZeeuklH1YIAPWD0xsAwMKeeOIJDRgwQD/99JMe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rcT5Raldu3Z57Xe2t2vXrt5qwv84T6jfu3evjys5vRxvvygqKlJubq4aN27s1x92VsV+cWoOHTqkSy+9VDt27FBKSoqeeeYZjzHsA3XnROb/eNgHaldwcLCuvfZaGWNcV2Owyj5A6K3EeamUdevWee13tnfr1q3easL/5OTkSPrfeUOoH126dJHNZlN2drbXW3GzX/gW+8XJKyws1NChQ7Vp0yZdeeWVeuWVV7zeDpp9oG6c6PwfD/tA7WvatKkkKTs7W5J19gFCbyX9+/dXTEyMfv31V/3www8e/WlpaZKkESNG1HNlyM7O1sqVKyVVfUk51I2wsDANGjRIkvTOO+949LNf+I4xRu+9954k9ouacjgcGjlypL799ltddtllbt9UPxb7QO2ryfxXh32gbqxYsUKSFB8fL8lC+4CPzyn2O87bEPfr188UFha62rkNcd375ptvzHvvvWfKysrc2rdt22b69+9vJJkrrrjCR9VZ26nchthmszWI20/6s+rmf//+/eaFF14w+fn5bu0FBQXm9ttvN5JM8+bNTVFRUX2UagllZWVm9OjRRpJJSEg4obljH6g9NZ1/9oHa9/XXX5uPP/7YlJeXu7UfPnzYPPfcc6ZRo0YmLCzM7Ny509VnhX0gwBhjfBO3/VNpaakSExO1evVqtWjRQgkJCdqxY4dWr16tuLg4rVq1Sh06dPB1mZa0cOFCpaSkqHnz5urVq5fsdrt27Nih7777TqWlpTr77LO1fPlyNWvWzNelNngffvih2yWBvv32WxljdMEFF7japk+fruHDh7ueT5o0SampqQoPD9fgwYN1+PBhpaenyxijtLQ0jRo1qj43oUGryfxv375dZ555piIjI3X++eerRYsWys7O1rp163Tw4EHZ7XZ98MEH6t+/vy82pUFKTU3VpEmTJEmjR49WdHS013HPPPOM6795JfaB2lLT+WcfqH3O37dNmzZV79691aRJEx04cEA//vij9u7dq9DQUL322mu65ppr3JZr8PuADwO33youLjbTp0838fHxJiQkxDRv3twkJyebrKwsX5dmaZs2bTJ33HGH6dWrl4mLizNBQUEmJibGXHjhhWbWrFlcqqwWLViwwEiq9uHtHvcLFiwwvXv3NuHh4cZut5shQ4aYb775pv43oIGryfzn5+ebv/71r2bgwIGmVatWxmazmfDwcHP22Webe++91+zatcu3G9MAPfzww8edf0lm27ZtHsuyD5y6ms4/+0Dt++2338zUqVNN//79TYsWLUxwcLCJiIgwZ599tvnzn/9stm7dWuWyDXkf4EgvAAAALI8vsgEAAMDyCL0AAACwPEIvAAAALI/QCwAAAMsj9AIAAMDyCL0AAACwPEIvAAAALI/QCwAAAMsj9AIAAMDyCL0AAACwPEIvAAAALI/QCwAAAMsj9AIAAMDy/h+ODMRCDLnqrQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 800x800 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Retrieve the damping array from the propagator and plot it to visualize boundary conditions\n",
    "damp = F.damp\n",
    "plot_damp(damp, save_path=os.path.join(project_path, \"model/boundary_condition.png\"))"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Load observed datasets"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Seismic Data:\n",
      "  Source number : 20\n",
      "  Receiver number : 100\n",
      "  Time samples : 4000 samples at 4.00 ms\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# Create an instance of SeismicData using the survey object.\n",
    "d_obs = SeismicData(survey)\n",
    "\n",
    "# Load observed waveform data from a specified file.\n",
    "d_obs.load(os.path.join(project_path, \"waveform/obs_data.npz\"))\n",
    "\n",
    "# Add noise to the observed data\n",
    "d_obs.add_noise(noise_level=0.01)\n",
    "\n",
    "# Print a summary representation of the observed seismic data.\n",
    "print(d_obs.__repr__())"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "##  Inversion"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "./data/uniformgrid/inversion\n",
      "Iteration Range: 0 - 280\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 1/280, Loss: 1595.8704, LR: 0.5, Time: 6.68s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 2/280, Loss: 1584.2859, LR: 0.5, Time: 5.23s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 3/280, Loss: 1572.6614, LR: 0.5, Time: 4.80s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 4/280, Loss: 1560.9706, LR: 0.5, Time: 5.34s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 5/280, Loss: 1549.2825, LR: 0.5, Time: 4.89s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 6/280, Loss: 1537.5203, LR: 0.5, Time: 4.95s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 7/280, Loss: 1525.7512, LR: 0.5, Time: 4.96s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 8/280, Loss: 1513.9474, LR: 0.5, Time: 4.96s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 9/280, Loss: 1502.0710, LR: 0.5, Time: 4.97s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 10/280, Loss: 1490.1775, LR: 0.5, Time: 4.99s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 11/280, Loss: 1478.2561, LR: 0.5, Time: 5.58s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 12/280, Loss: 1466.3057, LR: 0.5, Time: 4.97s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 13/280, Loss: 1454.3762, LR: 0.5, Time: 4.99s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 14/280, Loss: 1442.4270, LR: 0.5, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 15/280, Loss: 1430.4777, LR: 0.5, Time: 5.01s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 16/280, Loss: 1418.5448, LR: 0.5, Time: 4.99s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 17/280, Loss: 1406.6277, LR: 0.5, Time: 5.01s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 18/280, Loss: 1394.7249, LR: 0.5, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 19/280, Loss: 1382.8132, LR: 0.5, Time: 4.99s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 20/280, Loss: 1370.9105, LR: 0.5, Time: 5.04s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 21/280, Loss: 1359.0222, LR: 0.5, Time: 5.70s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 22/280, Loss: 1347.1064, LR: 0.5, Time: 4.97s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 23/280, Loss: 1335.1984, LR: 0.5, Time: 5.01s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 24/280, Loss: 1323.3135, LR: 0.5, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 25/280, Loss: 1311.4850, LR: 0.5, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 26/280, Loss: 1299.6943, LR: 0.5, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 27/280, Loss: 1287.9584, LR: 0.5, Time: 5.04s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 28/280, Loss: 1276.2538, LR: 0.5, Time: 5.02s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 29/280, Loss: 1264.5293, LR: 0.5, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 30/280, Loss: 1252.8489, LR: 0.5, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 31/280, Loss: 1241.2150, LR: 0.5, Time: 5.64s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 32/280, Loss: 1229.6619, LR: 0.5, Time: 4.98s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 33/280, Loss: 1218.1833, LR: 0.5, Time: 5.01s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 34/280, Loss: 1206.7932, LR: 0.5, Time: 5.01s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 35/280, Loss: 1195.5088, LR: 0.5, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 36/280, Loss: 1184.3481, LR: 0.5, Time: 5.01s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 37/280, Loss: 1173.2870, LR: 0.5, Time: 4.98s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 38/280, Loss: 1162.3176, LR: 0.5, Time: 4.99s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 39/280, Loss: 1151.4421, LR: 0.5, Time: 5.02s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 40/280, Loss: 1140.7019, LR: 0.5, Time: 4.99s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 41/280, Loss: 1130.0947, LR: 0.5, Time: 5.61s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 42/280, Loss: 1119.6241, LR: 0.5, Time: 4.98s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 43/280, Loss: 1109.2878, LR: 0.5, Time: 5.01s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 44/280, Loss: 1099.0944, LR: 0.5, Time: 5.02s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 45/280, Loss: 1089.0513, LR: 0.5, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 46/280, Loss: 1079.1565, LR: 0.5, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 47/280, Loss: 1069.4102, LR: 0.5, Time: 5.04s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 48/280, Loss: 1059.8027, LR: 0.5, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 49/280, Loss: 1050.2742, LR: 0.5, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 50/280, Loss: 1040.8724, LR: 0.375, Time: 5.01s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 51/280, Loss: 1031.6162, LR: 0.375, Time: 5.59s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 52/280, Loss: 1024.7747, LR: 0.375, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 53/280, Loss: 1018.0178, LR: 0.375, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 54/280, Loss: 1011.3474, LR: 0.375, Time: 5.01s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 55/280, Loss: 1004.7620, LR: 0.375, Time: 5.01s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 56/280, Loss: 998.2765, LR: 0.375, Time: 5.02s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 57/280, Loss: 991.8978, LR: 0.375, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 58/280, Loss: 985.6223, LR: 0.375, Time: 5.01s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 59/280, Loss: 979.4563, LR: 0.375, Time: 4.99s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 60/280, Loss: 973.4005, LR: 0.375, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 61/280, Loss: 967.4500, LR: 0.375, Time: 5.57s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 62/280, Loss: 961.6001, LR: 0.375, Time: 4.99s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 63/280, Loss: 955.8514, LR: 0.375, Time: 5.01s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 64/280, Loss: 950.2199, LR: 0.375, Time: 5.01s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 65/280, Loss: 944.7045, LR: 0.375, Time: 4.99s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 66/280, Loss: 939.3121, LR: 0.375, Time: 4.99s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 67/280, Loss: 934.0370, LR: 0.375, Time: 5.04s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 68/280, Loss: 928.8726, LR: 0.375, Time: 5.01s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 69/280, Loss: 923.8279, LR: 0.375, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 70/280, Loss: 918.9014, LR: 0.375, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 71/280, Loss: 914.0890, LR: 0.375, Time: 5.60s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 72/280, Loss: 909.4019, LR: 0.375, Time: 4.99s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 73/280, Loss: 904.8223, LR: 0.375, Time: 5.01s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 74/280, Loss: 900.3555, LR: 0.375, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 75/280, Loss: 895.9935, LR: 0.375, Time: 5.02s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 76/280, Loss: 891.7457, LR: 0.375, Time: 5.01s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 77/280, Loss: 887.6085, LR: 0.375, Time: 5.01s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 78/280, Loss: 883.5925, LR: 0.375, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 79/280, Loss: 879.6971, LR: 0.375, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 80/280, Loss: 875.9106, LR: 0.375, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 81/280, Loss: 872.2161, LR: 0.375, Time: 5.71s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 82/280, Loss: 868.6337, LR: 0.375, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 83/280, Loss: 865.1510, LR: 0.375, Time: 5.02s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 84/280, Loss: 861.7701, LR: 0.375, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 85/280, Loss: 858.4800, LR: 0.375, Time: 4.99s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 86/280, Loss: 855.2643, LR: 0.375, Time: 4.99s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 87/280, Loss: 852.1562, LR: 0.375, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 88/280, Loss: 849.1450, LR: 0.375, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 89/280, Loss: 846.2335, LR: 0.375, Time: 5.05s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 90/280, Loss: 843.4109, LR: 0.375, Time: 5.02s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 91/280, Loss: 840.6641, LR: 0.375, Time: 5.61s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 92/280, Loss: 837.9601, LR: 0.375, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 93/280, Loss: 835.3284, LR: 0.375, Time: 5.01s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 94/280, Loss: 832.7769, LR: 0.375, Time: 5.01s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 95/280, Loss: 830.2834, LR: 0.375, Time: 5.02s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 96/280, Loss: 827.8615, LR: 0.375, Time: 5.04s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 97/280, Loss: 825.4947, LR: 0.375, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 98/280, Loss: 823.1693, LR: 0.375, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 99/280, Loss: 820.8931, LR: 0.375, Time: 5.05s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 100/280, Loss: 818.6740, LR: 0.28125, Time: 5.00s\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 101/280, Loss: 816.4965, LR: 0.28125, Time: 5.59s\n",
      "Improvement: 397.67347168\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 102/280, Loss: 814.9016, LR: 0.28125, Time: 5.01s\n",
      "Improvement: 390.68070801\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 103/280, Loss: 813.3339, LR: 0.28125, Time: 5.03s\n",
      "Improvement: 383.68151489\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 104/280, Loss: 811.7996, LR: 0.28125, Time: 5.01s\n",
      "Improvement: 376.68000854\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 105/280, Loss: 810.2939, LR: 0.28125, Time: 5.00s\n",
      "Improvement: 369.67896118\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 106/280, Loss: 808.8124, LR: 0.28125, Time: 5.02s\n",
      "Improvement: 362.68336792\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 107/280, Loss: 807.3613, LR: 0.28125, Time: 5.02s\n",
      "Improvement: 355.69703003\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 108/280, Loss: 805.9312, LR: 0.28125, Time: 5.02s\n",
      "Improvement: 348.72435181\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 109/280, Loss: 804.5168, LR: 0.28125, Time: 5.04s\n",
      "Improvement: 341.77084717\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 110/280, Loss: 803.1331, LR: 0.28125, Time: 5.00s\n",
      "Improvement: 334.84065674\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 111/280, Loss: 801.7799, LR: 0.28125, Time: 5.62s\n",
      "Improvement: 327.93793457\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 112/280, Loss: 800.4613, LR: 0.28125, Time: 5.03s\n",
      "Improvement: 321.06659912\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 113/280, Loss: 799.1765, LR: 0.28125, Time: 5.01s\n",
      "Improvement: 314.22960205\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 114/280, Loss: 797.9209, LR: 0.28125, Time: 5.01s\n",
      "Improvement: 307.43144043\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 115/280, Loss: 796.6938, LR: 0.28125, Time: 5.01s\n",
      "Improvement: 300.67619141\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 116/280, Loss: 795.4981, LR: 0.28125, Time: 5.01s\n",
      "Improvement: 293.96781860\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 117/280, Loss: 794.3281, LR: 0.28125, Time: 5.01s\n",
      "Improvement: 287.31018311\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 118/280, Loss: 793.1787, LR: 0.28125, Time: 5.01s\n",
      "Improvement: 280.70701660\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 119/280, Loss: 792.0533, LR: 0.28125, Time: 5.01s\n",
      "Improvement: 274.16280029\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 120/280, Loss: 790.9491, LR: 0.28125, Time: 5.04s\n",
      "Improvement: 267.68166504\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 121/280, Loss: 789.8722, LR: 0.28125, Time: 5.60s\n",
      "Improvement: 261.26733643\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 122/280, Loss: 788.8221, LR: 0.28125, Time: 5.00s\n",
      "Improvement: 254.92484009\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 123/280, Loss: 787.7979, LR: 0.28125, Time: 5.01s\n",
      "Improvement: 248.65780762\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 124/280, Loss: 786.8029, LR: 0.28125, Time: 5.01s\n",
      "Improvement: 242.46969971\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 125/280, Loss: 785.8308, LR: 0.28125, Time: 5.00s\n",
      "Improvement: 236.36312500\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 126/280, Loss: 784.8860, LR: 0.28125, Time: 5.00s\n",
      "Improvement: 230.34134766\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 127/280, Loss: 783.9719, LR: 0.28125, Time: 5.04s\n",
      "Improvement: 224.40708374\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 128/280, Loss: 783.0882, LR: 0.28125, Time: 5.01s\n",
      "Improvement: 218.56394287\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 129/280, Loss: 782.2354, LR: 0.28125, Time: 5.02s\n",
      "Improvement: 212.81653198\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 130/280, Loss: 781.4116, LR: 0.28125, Time: 5.00s\n",
      "Improvement: 207.16774902\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 131/280, Loss: 780.6170, LR: 0.28125, Time: 5.60s\n",
      "Improvement: 201.61975464\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 132/280, Loss: 779.8489, LR: 0.28125, Time: 5.03s\n",
      "Improvement: 196.17488525\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 133/280, Loss: 779.1040, LR: 0.28125, Time: 5.02s\n",
      "Improvement: 190.83517822\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 134/280, Loss: 778.3818, LR: 0.28125, Time: 5.00s\n",
      "Improvement: 185.60248047\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 135/280, Loss: 777.6873, LR: 0.28125, Time: 5.05s\n",
      "Improvement: 180.47776123\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 136/280, Loss: 777.0198, LR: 0.28125, Time: 5.01s\n",
      "Improvement: 175.46097412\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 137/280, Loss: 776.3810, LR: 0.28125, Time: 5.00s\n",
      "Improvement: 170.55386475\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 138/280, Loss: 775.7706, LR: 0.28125, Time: 5.03s\n",
      "Improvement: 165.75790039\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 139/280, Loss: 775.1893, LR: 0.28125, Time: 5.03s\n",
      "Improvement: 161.07460938\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 140/280, Loss: 774.6368, LR: 0.28125, Time: 4.99s\n",
      "Improvement: 156.50427002\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 141/280, Loss: 774.1131, LR: 0.28125, Time: 5.73s\n",
      "Improvement: 152.04667603\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 142/280, Loss: 773.6127, LR: 0.28125, Time: 4.99s\n",
      "Improvement: 147.70034302\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 143/280, Loss: 773.1385, LR: 0.28125, Time: 5.01s\n",
      "Improvement: 143.46495239\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 144/280, Loss: 772.6931, LR: 0.28125, Time: 5.00s\n",
      "Improvement: 139.34027954\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 145/280, Loss: 772.2766, LR: 0.28125, Time: 5.01s\n",
      "Improvement: 135.32505981\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 146/280, Loss: 771.8787, LR: 0.28125, Time: 5.02s\n",
      "Improvement: 131.41881470\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 147/280, Loss: 771.5018, LR: 0.28125, Time: 5.00s\n",
      "Improvement: 127.62036255\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 148/280, Loss: 771.1481, LR: 0.28125, Time: 5.00s\n",
      "Improvement: 123.92811646\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 149/280, Loss: 770.8206, LR: 0.28125, Time: 4.99s\n",
      "Improvement: 120.34194458\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 150/280, Loss: 770.5178, LR: 0.2109375, Time: 4.99s\n",
      "Improvement: 116.86109741\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 151/280, Loss: 770.2401, LR: 0.2109375, Time: 5.60s\n",
      "Improvement: 113.48383057\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 152/280, Loss: 770.0460, LR: 0.2109375, Time: 5.01s\n",
      "Improvement: 110.18348267\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 153/280, Loss: 769.8601, LR: 0.2109375, Time: 5.01s\n",
      "Improvement: 106.95928101\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 154/280, Loss: 769.6873, LR: 0.2109375, Time: 5.01s\n",
      "Improvement: 103.81057007\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 155/280, Loss: 769.5284, LR: 0.2109375, Time: 5.01s\n",
      "Improvement: 100.73651855\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 156/280, Loss: 769.3845, LR: 0.2109375, Time: 5.01s\n",
      "Improvement: 97.73579468\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 157/280, Loss: 769.2516, LR: 0.2109375, Time: 5.02s\n",
      "Improvement: 94.80725952\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 158/280, Loss: 769.1343, LR: 0.2109375, Time: 5.01s\n",
      "Improvement: 91.94937378\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 159/280, Loss: 769.0333, LR: 0.2109375, Time: 5.00s\n",
      "Improvement: 89.16025269\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 160/280, Loss: 768.9487, LR: 0.2109375, Time: 5.00s\n",
      "Improvement: 86.43859009\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 161/280, Loss: 768.8795, LR: 0.2109375, Time: 5.60s\n",
      "Improvement: 83.78319702\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 162/280, Loss: 768.8257, LR: 0.2109375, Time: 4.99s\n",
      "Improvement: 81.19313354\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 163/280, Loss: 768.7853, LR: 0.2109375, Time: 5.03s\n",
      "Improvement: 78.66745972\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 164/280, Loss: 768.7600, LR: 0.2109375, Time: 5.02s\n",
      "Improvement: 76.20469727\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 165/280, Loss: 768.7499, LR: 0.2109375, Time: 5.00s\n",
      "Improvement: 73.80336304\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 166/280, Loss: 768.7545, LR: 0.2109375, Time: 5.00s\n",
      "Improvement: 71.46195557\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 167/280, Loss: 768.7720, LR: 0.2109375, Time: 5.00s\n",
      "Improvement: 69.17889893\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 168/280, Loss: 768.8031, LR: 0.2109375, Time: 5.01s\n",
      "Improvement: 66.95253296\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 169/280, Loss: 768.8447, LR: 0.2109375, Time: 5.01s\n",
      "Improvement: 64.78121460\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 170/280, Loss: 768.8979, LR: 0.2109375, Time: 5.04s\n",
      "Improvement: 62.66319214\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 171/280, Loss: 768.9633, LR: 0.2109375, Time: 5.60s\n",
      "Improvement: 60.59703369\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 172/280, Loss: 769.0410, LR: 0.2109375, Time: 4.99s\n",
      "Improvement: 58.58105957\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 173/280, Loss: 769.1306, LR: 0.2109375, Time: 5.01s\n",
      "Improvement: 56.61391724\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 174/280, Loss: 769.2300, LR: 0.2109375, Time: 5.01s\n",
      "Improvement: 54.69432129\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 175/280, Loss: 769.3401, LR: 0.2109375, Time: 5.05s\n",
      "Improvement: 52.82088135\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 176/280, Loss: 769.4618, LR: 0.2109375, Time: 5.01s\n",
      "Improvement: 50.99217041\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 177/280, Loss: 769.5943, LR: 0.2109375, Time: 4.99s\n",
      "Improvement: 49.20698853\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 178/280, Loss: 769.7354, LR: 0.2109375, Time: 5.00s\n",
      "Improvement: 47.46395996\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 179/280, Loss: 769.8865, LR: 0.2109375, Time: 5.02s\n",
      "Improvement: 45.76170532\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 180/280, Loss: 770.0483, LR: 0.2109375, Time: 5.02s\n",
      "Improvement: 44.09898804\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 181/280, Loss: 770.2205, LR: 0.2109375, Time: 5.61s\n",
      "Improvement: 42.47493652\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 182/280, Loss: 770.4025, LR: 0.2109375, Time: 5.01s\n",
      "Improvement: 40.88817017\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 183/280, Loss: 770.5939, LR: 0.2109375, Time: 4.99s\n",
      "Improvement: 39.33743164\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 184/280, Loss: 770.7938, LR: 0.2109375, Time: 4.99s\n",
      "Improvement: 37.82142700\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 185/280, Loss: 771.0026, LR: 0.2109375, Time: 5.00s\n",
      "Improvement: 36.33926514\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 186/280, Loss: 771.2208, LR: 0.2109375, Time: 5.01s\n",
      "Improvement: 34.89035522\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 187/280, Loss: 771.4485, LR: 0.2109375, Time: 5.03s\n",
      "Improvement: 33.47349976\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 188/280, Loss: 771.6861, LR: 0.2109375, Time: 5.00s\n",
      "Improvement: 32.08770264\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 189/280, Loss: 771.9333, LR: 0.2109375, Time: 5.00s\n",
      "Improvement: 30.73193970\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 190/280, Loss: 772.1904, LR: 0.2109375, Time: 5.00s\n",
      "Improvement: 29.40538696\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 191/280, Loss: 772.4569, LR: 0.2109375, Time: 5.60s\n",
      "Improvement: 28.10749146\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 192/280, Loss: 772.7314, LR: 0.2109375, Time: 4.99s\n",
      "Improvement: 26.83816895\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 193/280, Loss: 773.0161, LR: 0.2109375, Time: 5.03s\n",
      "Improvement: 25.59682007\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 194/280, Loss: 773.3115, LR: 0.2109375, Time: 5.00s\n",
      "Improvement: 24.38277588\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 195/280, Loss: 773.6178, LR: 0.2109375, Time: 5.02s\n",
      "Improvement: 23.19581543\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 196/280, Loss: 773.9352, LR: 0.2109375, Time: 5.01s\n",
      "Improvement: 22.03502930\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 197/280, Loss: 774.2622, LR: 0.2109375, Time: 5.01s\n",
      "Improvement: 20.89996460\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 198/280, Loss: 774.6002, LR: 0.2109375, Time: 5.02s\n",
      "Improvement: 19.79049927\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 199/280, Loss: 774.9485, LR: 0.2109375, Time: 5.01s\n",
      "Improvement: 18.70649048\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 200/280, Loss: 775.3073, LR: 0.158203125, Time: 5.00s\n",
      "Improvement: 17.64757935\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 201/280, Loss: 775.6753, LR: 0.158203125, Time: 5.60s\n",
      "Improvement: 16.61374634\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 202/280, Loss: 775.9584, LR: 0.158203125, Time: 5.00s\n",
      "Improvement: 15.59838501\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 203/280, Loss: 776.2466, LR: 0.158203125, Time: 5.00s\n",
      "Improvement: 14.60117920\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 204/280, Loss: 776.5399, LR: 0.158203125, Time: 5.00s\n",
      "Improvement: 13.62187988\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 205/280, Loss: 776.8384, LR: 0.158203125, Time: 5.02s\n",
      "Improvement: 12.66036987\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 206/280, Loss: 777.1418, LR: 0.158203125, Time: 4.99s\n",
      "Improvement: 11.71666382\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 207/280, Loss: 777.4502, LR: 0.158203125, Time: 5.02s\n",
      "Improvement: 10.79049683\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 208/280, Loss: 777.7638, LR: 0.158203125, Time: 4.99s\n",
      "Improvement: 9.88196899\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 209/280, Loss: 778.0824, LR: 0.158203125, Time: 4.99s\n",
      "Improvement: 8.99131836\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 210/280, Loss: 778.4061, LR: 0.158203125, Time: 5.02s\n",
      "Improvement: 8.11848389\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 211/280, Loss: 778.7350, LR: 0.158203125, Time: 5.75s\n",
      "Improvement: 7.26336670\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 212/280, Loss: 779.0688, LR: 0.158203125, Time: 5.04s\n",
      "Improvement: 6.42579102\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 213/280, Loss: 779.4077, LR: 0.158203125, Time: 5.01s\n",
      "Improvement: 5.60551758\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 214/280, Loss: 779.7511, LR: 0.158203125, Time: 5.00s\n",
      "Improvement: 4.80247803\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 215/280, Loss: 780.0991, LR: 0.158203125, Time: 5.01s\n",
      "Improvement: 4.01661377\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 216/280, Loss: 780.4519, LR: 0.158203125, Time: 5.01s\n",
      "Improvement: 3.24779175\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 217/280, Loss: 780.8093, LR: 0.158203125, Time: 5.01s\n",
      "Improvement: 2.49592407\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 218/280, Loss: 781.1715, LR: 0.158203125, Time: 5.01s\n",
      "Improvement: 1.76104370\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 219/280, Loss: 781.5387, LR: 0.158203125, Time: 5.02s\n",
      "Improvement: 1.04299194\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 220/280, Loss: 781.9107, LR: 0.158203125, Time: 5.01s\n",
      "Improvement: 0.34171143\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 221/280, Loss: 782.2876, LR: 0.158203125, Time: 5.60s\n",
      "Improvement: 0.34295166\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 222/280, Loss: 782.6688, LR: 0.158203125, Time: 4.98s\n",
      "Improvement: 1.01112915\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 223/280, Loss: 783.0546, LR: 0.158203125, Time: 5.00s\n",
      "Improvement: 1.66295410\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 224/280, Loss: 783.4449, LR: 0.158203125, Time: 5.01s\n",
      "Improvement: 2.29870850\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 225/280, Loss: 783.8400, LR: 0.158203125, Time: 4.99s\n",
      "Improvement: 2.91852051\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 226/280, Loss: 784.2395, LR: 0.158203125, Time: 5.00s\n",
      "Improvement: 3.52255859\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 227/280, Loss: 784.6436, LR: 0.158203125, Time: 5.00s\n",
      "Improvement: 4.11109497\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 228/280, Loss: 785.0521, LR: 0.158203125, Time: 5.01s\n",
      "Improvement: 4.68448608\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 229/280, Loss: 785.4649, LR: 0.158203125, Time: 5.02s\n",
      "Improvement: 5.24303345\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 230/280, Loss: 785.8807, LR: 0.158203125, Time: 5.02s\n",
      "Improvement: 5.78694580\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 231/280, Loss: 786.3010, LR: 0.158203125, Time: 5.62s\n",
      "Improvement: 6.31648804\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 232/280, Loss: 786.7257, LR: 0.158203125, Time: 4.99s\n",
      "Improvement: 6.83187988\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 233/280, Loss: 787.1553, LR: 0.158203125, Time: 4.99s\n",
      "Improvement: 7.33330933\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 234/280, Loss: 787.5897, LR: 0.158203125, Time: 5.00s\n",
      "Improvement: 7.82098633\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 235/280, Loss: 788.0291, LR: 0.158203125, Time: 5.01s\n",
      "Improvement: 8.29520996\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 236/280, Loss: 788.4733, LR: 0.158203125, Time: 5.01s\n",
      "Improvement: 8.75624023\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 237/280, Loss: 788.9224, LR: 0.158203125, Time: 5.04s\n",
      "Improvement: 9.20436890\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 238/280, Loss: 789.3765, LR: 0.158203125, Time: 5.01s\n",
      "Improvement: 9.63986816\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 239/280, Loss: 789.8356, LR: 0.158203125, Time: 5.02s\n",
      "Improvement: 10.06303223\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 240/280, Loss: 790.2987, LR: 0.158203125, Time: 5.01s\n",
      "Improvement: 10.47412598\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 241/280, Loss: 790.7668, LR: 0.158203125, Time: 5.60s\n",
      "Improvement: 10.87344849\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 242/280, Loss: 791.2403, LR: 0.158203125, Time: 4.99s\n",
      "Improvement: 11.26125244\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 243/280, Loss: 791.7170, LR: 0.158203125, Time: 5.05s\n",
      "Improvement: 11.63771973\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 244/280, Loss: 792.1986, LR: 0.158203125, Time: 5.03s\n",
      "Improvement: 12.00309326\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 245/280, Loss: 792.6851, LR: 0.158203125, Time: 5.00s\n",
      "Improvement: 12.35761597\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 246/280, Loss: 793.1755, LR: 0.158203125, Time: 5.00s\n",
      "Improvement: 12.70129272\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 247/280, Loss: 793.6700, LR: 0.158203125, Time: 5.01s\n",
      "Improvement: 13.03424194\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 248/280, Loss: 794.1694, LR: 0.158203125, Time: 5.01s\n",
      "Improvement: 13.35658569\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 249/280, Loss: 794.6735, LR: 0.158203125, Time: 5.02s\n",
      "Improvement: 13.66852661\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 250/280, Loss: 795.1821, LR: 0.11865234375, Time: 5.02s\n",
      "Improvement: 13.97023560\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 251/280, Loss: 795.6953, LR: 0.11865234375, Time: 5.61s\n",
      "Improvement: 14.26193115\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 252/280, Loss: 796.0828, LR: 0.11865234375, Time: 4.99s\n",
      "Improvement: 14.54617188\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 253/280, Loss: 796.4722, LR: 0.11865234375, Time: 5.03s\n",
      "Improvement: 14.82295532\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 254/280, Loss: 796.8636, LR: 0.11865234375, Time: 5.01s\n",
      "Improvement: 15.09237671\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 255/280, Loss: 797.2572, LR: 0.11865234375, Time: 5.01s\n",
      "Improvement: 15.35455200\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 256/280, Loss: 797.6530, LR: 0.11865234375, Time: 5.00s\n",
      "Improvement: 15.60962646\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 257/280, Loss: 798.0510, LR: 0.11865234375, Time: 5.00s\n",
      "Improvement: 15.85767090\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 258/280, Loss: 798.4512, LR: 0.11865234375, Time: 5.00s\n",
      "Improvement: 16.09882935\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 259/280, Loss: 798.8538, LR: 0.11865234375, Time: 5.01s\n",
      "Improvement: 16.33327515\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 260/280, Loss: 799.2587, LR: 0.11865234375, Time: 5.02s\n",
      "Improvement: 16.56117798\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 261/280, Loss: 799.6658, LR: 0.11865234375, Time: 5.62s\n",
      "Improvement: 16.78268555\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 262/280, Loss: 800.0754, LR: 0.11865234375, Time: 5.00s\n",
      "Improvement: 16.99795410\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 263/280, Loss: 800.4873, LR: 0.11865234375, Time: 5.01s\n",
      "Improvement: 17.20709717\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 264/280, Loss: 800.9016, LR: 0.11865234375, Time: 5.01s\n",
      "Improvement: 17.41028564\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 265/280, Loss: 801.3184, LR: 0.11865234375, Time: 5.02s\n",
      "Improvement: 17.60768555\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 266/280, Loss: 801.7374, LR: 0.11865234375, Time: 5.01s\n",
      "Improvement: 17.79944580\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 267/280, Loss: 802.1583, LR: 0.11865234375, Time: 5.01s\n",
      "Improvement: 17.98567993\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 268/280, Loss: 802.5817, LR: 0.11865234375, Time: 5.01s\n",
      "Improvement: 18.16651489\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 269/280, Loss: 803.0074, LR: 0.11865234375, Time: 5.01s\n",
      "Improvement: 18.34201050\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 270/280, Loss: 803.4357, LR: 0.11865234375, Time: 5.01s\n",
      "Improvement: 18.51225464\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 271/280, Loss: 803.8664, LR: 0.11865234375, Time: 5.58s\n",
      "Improvement: 18.67734497\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 272/280, Loss: 804.2993, LR: 0.11865234375, Time: 5.01s\n",
      "Improvement: 18.83739868\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 273/280, Loss: 804.7342, LR: 0.11865234375, Time: 5.04s\n",
      "Improvement: 18.99251221\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 274/280, Loss: 805.1716, LR: 0.11865234375, Time: 5.00s\n",
      "Improvement: 19.14274780\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 275/280, Loss: 805.6113, LR: 0.11865234375, Time: 5.00s\n",
      "Improvement: 19.28817749\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 276/280, Loss: 806.0532, LR: 0.11865234375, Time: 5.06s\n",
      "Improvement: 19.42889648\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 277/280, Loss: 806.4973, LR: 0.11865234375, Time: 5.04s\n",
      "Improvement: 19.56498657\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 278/280, Loss: 806.9434, LR: 0.11865234375, Time: 5.00s\n",
      "Improvement: 19.69647827\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 279/280, Loss: 807.3914, LR: 0.11865234375, Time: 5.01s\n",
      "Improvement: 19.82343994\n",
      "Batch: 1/1, Random Shots: 0 to 20\n",
      "Iteration 280/280, Loss: 807.8414, LR: 0.11865234375, Time: 5.01s\n",
      "Improvement: 19.94600586\n"
     ]
    }
   ],
   "source": [
    "# Import the L2 misfit function for waveform inversion.\n",
    "from uniSI.inversion.misfit import Misfit_waveform_L2,Misfit_global_correlation, Misfit_traveltime\n",
    "\n",
    "torch.cuda.empty_cache()\n",
    "os.environ['PYTORCH_CUDA_ALLOC_CONF'] = 'max_split_size_mb:512'\n",
    "\n",
    "iteration = 280 # 300\n",
    "\n",
    "# Initialize the optimizer (Adam) for model parameters with a learning rate.\n",
    "optimizer = torch.optim.Adam(model.parameters(), lr=0.5) #\n",
    "\n",
    "# Set up a learning rate scheduler to adjust the learning rate over time.\n",
    "scheduler = torch.optim.lr_scheduler.StepLR(optimizer, step_size=50, gamma=0.75, last_epoch=-1)\n",
    "\n",
    "# Configure the misfit function to compute the loss based on the observed data.\n",
    "loss_fn = Misfit_waveform_L2(dt=dt)\n",
    "# loss_fn = Misfit_global_correlation(dt=dt)\n",
    "# loss_fn = Misfit_traveltime(dt=dt)\n",
    "\n",
    "\n",
    "grad_mask = np.ones_like(vs_init)\n",
    "# Free Surface\n",
    "grad_mask[:2,:] = 0\n",
    "grad_mask[-1,:] = 0\n",
    "grad_mask[:,0] = 0\n",
    "grad_mask[:,-1] = 0\n",
    "gradient_processor = GradProcessor(grad_mask=grad_mask,forw_illumination=True) \n",
    "\n",
    "\n",
    "# Print inversion save path\n",
    "print(os.path.join(project_path, \"inversion\"))\n",
    "\n",
    "# Initialize the acoustic full waveform inversion (Inversion) object.\n",
    "inversion = SHInversion(propagator=F,\n",
    "                  model=model,\n",
    "                  optimizer=optimizer,\n",
    "                  scheduler=scheduler,\n",
    "                  loss_fn=loss_fn,\n",
    "                  obs_data=d_obs,\n",
    "                  gradient_processor=gradient_processor,\n",
    "                  waveform_normalize=True, \n",
    "                  cache_result=True,  \n",
    "                  save_fig_epoch=10,  \n",
    "                  save_fig_path=os.path.join(project_path, \"inversion\"),\n",
    "                  min_improvement=1e-7)\n",
    "\n",
    "# Run the forward modeling for the specified number of iterations.\n",
    "inversion.forward(iteration=iteration, batch_size=None, checkpoint_segments=1)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Retrieve the inversion results: updated velocity and loss values.\n",
    "iter_vs = inversion.iter_vs\n",
    "iter_rho = inversion.iter_rho\n",
    "iter_loss = inversion.iter_loss\n",
    "\n",
    "# Save the iteration results to files for later analysis.\n",
    "save_dir = os.path.join(project_path, \"inversion\")\n",
    "os.makedirs(save_dir, exist_ok=True)  \n",
    "np.savez(os.path.join(project_path, \"inversion/iter_vs.npz\"), data=np.array(iter_vs))\n",
    "np.savez(os.path.join(project_path, \"inversion/iter_loss.npz\"), data=np.array(iter_loss))\n",
    "np.savez(os.path.join(project_path, \"inversion/water_depth.npz\"), data=water_depth)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## visualize the inverted results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAssAAAIVCAYAAAAnPLKEAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/xnp5ZAAAACXBIWXMAAA9hAAAPYQGoP6dpAABeXElEQVR4nO3deXiM9/7/8ddkj0RCyEaC2IrYSWwt1VpiKW1ttbVVuqCoHq2jTjentbY9XdTSDYfa29p3jVK0OChFS7VIJJYKiURElvn94Zv5iWRIIsk9kzwf1zXXZO77kzvvcXf05c77/nxMZrPZLAAAAADZOBhdAAAAAGCrCMsAAACAFYRlAAAAwArCMgAAAGAFYRkAAACwgrAMAAAAWEFYBgAAAKwgLAMAAABWOBldQHGUkZGhmJgYlS5dWiaTyehyAAAAcBuz2ayrV6+qQoUKcnCwfv2YsFwIYmJiFBwcbHQZAAAAuIuoqCgFBQVZ3U9YLgSlS5eWdPMP38vLy+BqAAAAcLuEhAQFBwdbcps1hOVCkNl64eXlRVgGAACwYXdrmeUGPwAAAMAKwjIAAABgBWEZAAAAsIKwDAAAAFhBWAYAAACsICwDAAAAVhCWAQAAACsIywAAAIAVhGUAAADACsIyAAAAYIXNheXExES9+eabioiIkI+Pj0wmk+bOnZvj2IyMDM2cOVMNGzaUu7u7ypUrp4ceeki//PJLtnFTp05VSEiI3NzcVL9+fS1atCjHYx47dkwRERHy9PSUj4+PBg4cqIsXLxb02wQAAIAdcDK6gNv9/fffmjBhgipVqqQGDRpo27ZtVsc+88wz+vrrr/Xkk0/qxRdfVFJSkg4cOKALFy5kGTd+/HhNnjxZzz77rMLCwrRy5Ur169dPJpNJTzzxhGVcdHS0WrduLW9vb02cOFGJiYl67733dPjwYe3Zs0cuLi6F9bYBAABgg2wuLAcGBio2NlYBAQHat2+fwsLCchy3dOlSzZs3T99++60ee+wxq8c7e/as3n//fQ0fPlzTp0+XJA0ZMkRt2rTRK6+8ol69esnR0VGSNHHiRCUlJel///ufKlWqJEkKDw9X+/btNXfuXD333HMF/G4BAABgy2yuDcPV1VUBAQF3HffBBx8oPDxcjz32mDIyMpSUlJTjuJUrVyo1NVXDhg2zbDOZTBo6dKiio6O1e/duy/ZvvvlGXbt2tQRlSWrXrp1q1qyppUuX3sO7AgAAgD2yubCcGwkJCdqzZ4/CwsL02muvydvbW56enqpatWq2UHvgwAF5eHiodu3aWbaHh4db9ks3r0BfuHBBTZs2zfbzwsPDLeMAAABQcthcG0ZunDx5UmazWYsXL5aTk5OmTp0qb29vffTRR3riiSfk5eWliIgISVJsbKz8/f1lMpmyHCMwMFCSFBMTYxl36/bbx8bFxSklJUWurq7Z9qekpCglJcXyOiEhoWDeKAAAAAxll1eWExMTJUmXLl3SypUrNXToUPXr109bt25VuXLl9M4771jGJicn5xhw3dzcLPtvfc7N2NtNmjRJ3t7elkdwcPA9vLu8uX79ulauXKnIyMgi+5kAAAAlhV2GZXd3d0lSSEiImjVrZtnu6empRx55RHv27FFaWppl7K1XfTNdv349y7Eyn3Mz9nbjxo1TfHy85REVFZXft5ZnH3/8sR599FG9++67RfYzAQAASgq7DMsVKlSQJPn7+2fb5+fnp9TUVMsNf4GBgTp37pzMZnOWcZltF5nHymy/yNx++1gfH58crzpLN69Ge3l5ZXkUlZ49e0qSIiMjdf78+SL7uQAAACWB3YblgIAAnT17Ntu+mJgYubm5qXTp0pKkhg0b6tq1azp27FiWcT///LNlvyRVrFhRvr6+2rdvX7Zj7tmzxzLO1lStWlVhYWHKyMjQN998Y3Q5AAAAxYpdhmVJ6tOnj6KiorR582bLtr///lsrV67UQw89JAeHm2+te/fucnZ21owZMyzjzGazZs2apYoVK6ply5aW7T169NCaNWuytFFs3bpVx48fV69evYrgXeVPnz59JElLliwxuBIAAIDixWS+vT/BBkyfPl1XrlxRTEyMZs6cqccff1yNGjWSJI0YMULe3t46f/68GjVqpMTERL388svy9vbWrFmzFBUVpd27d6tBgwaW47366quaNm2annvuOYWFhWnFihVau3atvv76a/Xr188yLioqSo0aNVKZMmU0atQoJSYmatq0aQoKCtLevXuttmHcLiEhQd7e3oqPjy+SloyoqChVqlRJJpNJ0dHRltYSAAAA5Cy3ec0mw3KVKlV0+vTpHPf99ddfqlKliiTpzz//1JgxY7R161alpqaqRYsWmjx5crZV/zIyMjRlyhTNnj1bsbGxqlGjhsaNG6f+/ftnO/6R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AQAoAIRloJjw9fXVkiVL5OjoqAULFmj27NlGlwQAgN0jLAPFSOvWrTVp0iRJN1f627t3r8EVAQBg3wjLQDEzZswYPfroo7px44Z69uypS5cuGV0SAAB2i7AMFDMmk0lz585V9erVdebMGQ0cOFAZGRlGlwUAgF0iLAPFkLe3t5YvXy43NzetX79e7777rtElAQBglwjLQDHVoEEDzZw5U5L05ptvavPmzQZXBACA/SEsA8XY008/rSFDhshsNqtv3746deqU0SUBAGBXCMtAMffJJ5+ocePGunTpkrp3786CJQAA5AFhGSjm3NzctGLFCvn5+enQoUN66qmnuOEPAIBcIiwDJUBwcLC+/fZbOTs765tvvtE777xjdEkAANgFwjJQQrRq1SrLDX/fffedwRUBAGD7CMtACTJ48GCNGDFCkjRw4EAdOHDA4IoAALBthGWghPnggw/Url07JSUlqWvXroqKijK6JAAAbBZhGShhnJyctGzZMoWGhiomJkadO3dWfHy80WUBAGCTCMtACVSmTBmtXbtWAQEB+vXXX9WrVy+lpqYaXRYAADaHsAyUUJUrV9batWvl4eGhzZs364UXXpDZbDa6LAAAbAphGSjBGjdurCVLlsjBwUFfffWV3n33XaNLAgDAphCWgRKuS5cumj59uiTp9ddf14IFCwyuCAAA20FYBqChQ4fqlVdekSQ988wz2rx5s8EVAQBgGwjLACRJkydPVu/evZWamqrHHntMe/bsMbokAAAMR1gGIElycHDQf//7X7Vv315JSUnq1KmTjh49anRZAAAYirAMwMLV1VXffvutwsPDFRcXpw4dOuj06dNGlwUAgGEIywCy8PT01Lp161SnTh2dPXtW7du31/nz540uCwAAQxCWAWRTrlw5bdq0SZUrV9aJEyf08MMP6+LFi0aXBQBAkSMsA8hRxYoVtWXLFlWoUEFHjhxRu3btdOnSJaPLAgCgSBGWAVhVvXp1ff/99/L399ehQ4fUoUMHXblyxeiyAAAoMoRlAHd033336fvvv5evr6/279+vjh07Kj4+3uiyAAAoEoRlAHdVp04dbdmyRT4+PtqzZ4/atWunuLg4o8sCAKDQEZYB5Er9+vW1detWlS9fXvv27VPbtm114cIFo8sCAKBQEZYB5FrDhg21bds2BQQE6NChQ3rwwQcVExNjdFkAABQawjKAPAkNDdX27dsVFBSkY8eOqU2bNixcAgAotgjLAPKsRo0a2r59u0JCQvTHH3+oZcuWOnLkiNFlAQBQ4AjLAPIlJCREO3bsUGhoqGJiYvTAAw9o165dRpcFAECBIiwDyLeKFStq+/btatGihS5fvqx27dpp3bp1RpcFAECBISwDuCc+Pj7avHmzOnXqpOTkZHXr1k1fffWV0WUBAFAgCMsA7pmHh4dWrlypAQMGKD09XYMHD9b48eOVkZFhdGkAANwTwjKAAuHs7Kx58+Zp/PjxkqSJEyeqf//+un79usGVAQCQf4RlAAXGwcFB77zzjr766is5OTlp8eLFateunS5evGh0aQAA5AthGUCBGzRokDZs2CBvb2/t3LlTYWFhOnDggNFlAQCQZ4RlAIXi4Ycf1q5du1S9enWdPn1arVq10qJFi4wuCwCAPCEsAyg0derU0Z49exQREaHk5GT169dPY8eOVXp6utGlAQCQK4RlAIWqbNmyWrNmjcaOHStJmjp1qjp37qy4uDiDKwMA4O4IywAKnaOjoyZPnqzFixfL3d1dmzZtUnh4uA4dOmR0aQAA3BFhGUCR6dOnj3bv3q3KlSvr5MmTCg8P1+zZs2U2m40uDQCAHBGWARSpBg0aaN++fercubNSUlL0wgsvqG/fvkpISDC6NAAAsiEsAyhy5cuX1+rVqzVt2jQ5OTlpyZIlaty4sfbu3Wt0aQAAZEFYBmAIBwcHjRkzRjt27LC0ZbRo0UJvv/22UlNTjS4PAABJhGUABmvevLkOHDigPn36KD09XW+99Zbuv/9+HT9+3OjSAAAgLAMwXtmyZbV48WItXLhQZcqU0Z49e9SwYUN9+umn3PwHADAUYRmAzejbt68OHz6sdu3aKTk5WS+++KIiIiIUHR1tdGkAgBKKsAzApgQFBWnjxo36+OOP5ebmpk2bNqlOnTqaNWuWMjIyjC4PAFDCEJYB2BwHBweNGDFC+/fvV7NmzXT16lUNHTpUDz74oH7//XejywMAlCCEZQA2q3bt2tq5c6c++ugjeXh4aMeOHWrQoIEmTpzIjBkAgCJBWAZg0xwdHTVy5Ej9+uuv6tixo1JSUjR+/Hg1bdpUP//8s9HlAQCKOcIyALtQpUoVrV+/XvPnz1e5cuV06NAhNW/eXIMHD9bFixeNLg8AUEwRlgHYDZPJpAEDBujo0aN68sknJUlfffWVatasqU8//VRpaWkGVwgAKG4IywDsjp+fn+bNm6cff/xRDRs21JUrV/Tiiy+qadOm2rlzp9HlAQCKEcIyALvVqlUr7du3T59++qnKlCmjX375Rffff7/69++vM2fOGF0eAKAYICwDsGuOjo4aNmyYjh8/riFDhshkMmnhwoWqWbOmxo0bp4SEBKNLBADYMcIygGLB19dXn3/+ufbu3as2bdooJSVFkydPVvXq1TVr1iz6mQEA+UJYBlCsNGnSRJGRkVqxYoVq1qypixcvaujQoapfv74WLVqk69evG10iAMCOEJYBFDsmk0ndu3fXr7/+qo8//ljlypXTsWPH1K9fP1WsWFEvvfSSDh8+bHSZAAA7YDKbzWajiyhuEhIS5O3trfj4eHl5eRldDlDiXblyRR9++KG+/PJLRUdHW7Y3a9ZMQ4YMUZ8+fVS6dGkDKwQAFLXc5jXCciEgLAO2KT09XZs2bdIXX3yhVatWWfqYPTw81KdPHw0aNEitWrWSyWQyuFIAQGHLbV6z2zaMEydO6IknnlBQUJBKlSqlWrVqacKECbp27VqWcbt27dL999+vUqVKKSAgQCNHjlRiYmK246WkpGjs2LGqUKGC3N3d1axZM23evLmo3g6AIuDo6KhOnTrpm2++UXR0tKZNm6b77rtPSUlJ+uqrr/TAAw+oWrVqeuONN3TixAmjywWAEsFsNuvChQvav3+/Ll26ZHQ52djlleWoqCjVr19f3t7eeuGFF+Tj46Pdu3dr7ty56tatm1auXClJOnjwoFq0aKHatWvrueeeU3R0tN577z21bdtW69evz3LMvn37avny5XrppZdUo0YNzZ07V3v37lVkZKTuv//+PNXHlWXAfpjNZu3cuVNffvmlli9fnuUf082aNdPAgQPVp08flS9f3sAqAcA+ZWRk6OLFi4qOjlZ0dLSioqJy/PrGjRuSpK+//lr9+vUrktqKdRvGxIkTNX78eP36668KDQ21bH/qqaf03//+V3FxcSpbtqw6d+6sgwcP6rfffrP8IXzxxRd69tlntXHjRnXo0EGStGfPHjVr1kzTpk3TmDFjJEnXr19X3bp15efnp127duWpPsIyYJ+uXbumlStXav78+dq0aZPS09MlSU5OTurcubP69++vLl26yMPDw+BKAcB4mUHYWgCOiorS2bNnLUH4Tkwm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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "from uniSI.inversion.misfit import Misfit_waveform_L2,Misfit_global_correlation\n",
    "\n",
    "# plot the misfit\n",
    "plt.figure(figsize=(8,6))\n",
    "plt.plot(iter_loss,c='k')\n",
    "plt.xlabel(\"Iterations\", fontsize=12)\n",
    "plt.ylabel(\"L2-norm Misfits\", fontsize=12)\n",
    "plt.tick_params(labelsize=12)\n",
    "plt.savefig(os.path.join(project_path,\"inversion/misfit.png\"),bbox_inches='tight',dpi=100)\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "cudass",
   "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.9.21"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
