{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "416ed70f",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "import deepwave\n",
    "from deepwave import scalar\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import torch.nn as nn\n",
    "import math\n",
    "import tinycudann as tcnn\n",
    "from scipy.ndimage import gaussian_filter\n",
    "device = torch.device('cuda:3' if torch.cuda.is_available()\n",
    "                      else 'cpu')\n",
    "dtype = torch.float32\n",
    "torch.manual_seed(2025)\n",
    "torch.cuda.manual_seed_all(2025)\n",
    "torch.backends.cudnn.deterministic = True\n",
    "torch.backends.cudnn.benchmark = False\n",
    "np.random.seed(2025)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "863628b6",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('overthrust.bin', 'rb') as f:\n",
    "    data = np.fromfile(f, dtype=np.float32)\n",
    "reshaped_data = data.reshape(187, 801, order='F')\n",
    "sample_interval = 2\n",
    "v_true = torch.from_numpy(reshaped_data[None, ::sample_interval, ::sample_interval]).to(device)\n",
    "vp_overthrust = v_true[0]\n",
    "nx = vp_overthrust.shape[1]\n",
    "nz = vp_overthrust.shape[0]\n",
    "            \n",
    "sigma = 10.0 \n",
    "v_init = gaussian_filter(vp_overthrust.detach().cpu(), sigma=sigma)\n",
    "v_init = torch.from_numpy(v_init).to(device)\n",
    "\n",
    "dx = 15\n",
    "dz = 15         "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "b4ab022b",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_shots = 20\n",
    "n_sources_per_shot = 1\n",
    "d_source = 18\n",
    "first_source = 20 \n",
    "source_depth = 2\n",
    "\n",
    "n_receivers_per_shot = 401\n",
    "d_receiver = 1 \n",
    "first_receiver = 0  \n",
    "receiver_depth = 2  \n",
    "\n",
    "freq = 10\n",
    "nt = 1200\n",
    "dt = 0.004\n",
    "peak_time = 1.5 / freq\n",
    "\n",
    "source_locations = torch.zeros(n_shots, n_sources_per_shot, 2,\n",
    "                               dtype=torch.long, device=device)\n",
    "source_locations[..., 1] = source_depth\n",
    "source_locations[:, 0, 0] = (torch.arange(n_shots) * d_source +\n",
    "                             first_source)\n",
    "\n",
    "receiver_locations = torch.zeros(n_shots, n_receivers_per_shot, 2,\n",
    "                                 dtype=torch.long, device=device)\n",
    "receiver_locations[..., 1] = receiver_depth\n",
    "receiver_locations[:, :, 0] = (\n",
    "    (torch.arange(n_receivers_per_shot) * d_receiver +\n",
    "     first_receiver)\n",
    "    .repeat(n_shots, 1)\n",
    ")\n",
    "\n",
    "wavelet = (\n",
    "    deepwave.wavelets.ricker(freq, nt, dt, peak_time)\n",
    "    .repeat(n_shots, n_sources_per_shot, 1)\n",
    "    .to(device)\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0d44bf25",
   "metadata": {},
   "outputs": [],
   "source": [
    "out = scalar(vp_overthrust.T, dx, dt, source_amplitudes=wavelet,\n",
    "             source_locations=source_locations,\n",
    "             receiver_locations=receiver_locations,\n",
    "             accuracy=4,\n",
    "             pml_width=[100,100,0,100])\n",
    "observed_data = out[-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "47125097",
   "metadata": {},
   "outputs": [],
   "source": [
    "def wrap(v, chunk, wavefield_0, wavefield_m1, psiy_m1, psix_m1,\n",
    "         zetay_m1, zetax_m1):\n",
    "    return scalar(\n",
    "                  v, dx, dt,\n",
    "                  source_amplitudes=chunk,\n",
    "                  source_locations=source_locations,\n",
    "                  receiver_locations=receiver_locations,\n",
    "                  pml_width=[100,100,0,100],\n",
    "                  wavefield_0=wavefield_0,\n",
    "                  wavefield_m1=wavefield_m1,\n",
    "                  psiy_m1=psiy_m1,\n",
    "                  accuracy=4,\n",
    "                  psix_m1=psix_m1,\n",
    "                  zetay_m1=zetay_m1,\n",
    "                  zetax_m1=zetax_m1,\n",
    "              )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "9c5d1b31",
   "metadata": {},
   "outputs": [],
   "source": [
    "class SineLayer(nn.Module):\n",
    "    def __init__(self, in_features, out_features,omega_0,mid_sinre, bias=True,\n",
    "                 is_first=False): \n",
    "        super().__init__()\n",
    "        self.omega_0 = omega_0\n",
    "        self.is_first = is_first\n",
    "        self.mid_sinre = mid_sinre\n",
    "        self.in_features = in_features\n",
    "        self.linear = nn.Linear(in_features, out_features, bias=bias)\n",
    "        self.init_weights()\n",
    "    \n",
    "    def init_weights(self):\n",
    "        with torch.no_grad():\n",
    "            if self.is_first:\n",
    "                self.linear.weight.uniform_(-1 / self.in_features, \n",
    "                                             1 / self.in_features)      \n",
    "            else:\n",
    "                self.linear.weight.uniform_(-np.sqrt(6 / self.mid_sinre) / self.omega_0, \n",
    "                                             np.sqrt(6 / self.mid_sinre) / self.omega_0)\n",
    "        \n",
    "    def forward(self, input):\n",
    "        return torch.sin(self.omega_0 * self.linear(input))\n",
    "    \n",
    "class HashLayer(nn.Module):\n",
    "    def __init__(self, in_features, config):\n",
    "        super().__init__()\n",
    "        self.encoder = tcnn.Encoding(in_features, config)\n",
    "        self.out_dim = self.encoder.n_output_dims\n",
    "    \n",
    "    def forward(self, x):\n",
    "        return self.encoder(x) \n",
    "    \n",
    "class Hash_INR(nn.Module):\n",
    "    def __init__(self, in_features=2, out_features=1, mid_sinre=[256, 128, 64, 32], \n",
    "                 mid_mlp=[64, 64], omega_0=[30, 30, 30, 30], config=None):\n",
    "        super().__init__()\n",
    "        self.hash = HashLayer(in_features, config[\"encoding\"])\n",
    "        hash_feat_dim = config[\"encoding\"][\"n_levels\"]*2 \n",
    "    \n",
    "        self.mlp_out = nn.Sequential(\n",
    "            nn.Linear(hash_feat_dim, mid_mlp[0]),\n",
    "            nn.GELU(),\n",
    "            nn.Linear(mid_mlp[0], mid_mlp[1]),\n",
    "            nn.GELU(),\n",
    "            nn.Linear(mid_mlp[1], out_features)\n",
    "        )\n",
    "    \n",
    "    def forward(self, x, nx, nz):\n",
    "        hash_feat = self.hash(x)\n",
    "        return self.mlp_out(hash_feat.float()).reshape(nz, nx)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "7046c0ef",
   "metadata": {},
   "outputs": [],
   "source": [
    "config = {\n",
    "    \"encoding\": {\n",
    "    \"otype\": \"HashGrid\",  \n",
    "    \"n_levels\": 16,            \n",
    "    \"n_features_per_level\": 2,\n",
    "    \"log2_hashmap_size\": 15,\n",
    "    \"base_resolution\": 50,   \n",
    "    \"per_level_scale\": 1.05     \n",
    "    }\n",
    "}   \n",
    "model = Hash_INR(\n",
    "    in_features=2,          \n",
    "    out_features=1,          \n",
    "    mid_mlp=[64,64],        \n",
    "    config=config\n",
    ").to(device)\n",
    "input = torch.stack(torch.meshgrid(\n",
    "    torch.linspace(0, 1, nz),\n",
    "    torch.linspace(0, 1, nx),\n",
    "    indexing='ij'), dim=-1).reshape(-1, 2).to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "544525c1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "loss: 5.619814872741699 in epoch: 0\n",
      "loss: 5.325564861297607 in epoch: 1\n",
      "loss: 5.2012481689453125 in epoch: 2\n",
      "loss: 5.213586807250977 in epoch: 3\n",
      "loss: 5.274521350860596 in epoch: 4\n",
      "loss: 5.3066887855529785 in epoch: 5\n",
      "loss: 5.292159080505371 in epoch: 6\n",
      "loss: 5.247066020965576 in epoch: 7\n",
      "loss: 5.194636821746826 in epoch: 8\n",
      "loss: 5.153890132904053 in epoch: 9\n",
      "loss: 5.134407997131348 in epoch: 10\n",
      "loss: 5.133935928344727 in epoch: 11\n",
      "loss: 5.140674114227295 in epoch: 12\n",
      "loss: 5.140728950500488 in epoch: 13\n",
      "loss: 5.125905513763428 in epoch: 14\n",
      "loss: 5.09642219543457 in epoch: 15\n",
      "loss: 5.058518886566162 in epoch: 16\n",
      "loss: 5.020081996917725 in epoch: 17\n",
      "loss: 4.986639499664307 in epoch: 18\n",
      "loss: 4.958982944488525 in epoch: 19\n",
      "loss: 4.933180332183838 in epoch: 20\n",
      "loss: 4.902904987335205 in epoch: 21\n",
      "loss: 4.862784385681152 in epoch: 22\n",
      "loss: 4.810791969299316 in epoch: 23\n",
      "loss: 4.748566627502441 in epoch: 24\n",
      "loss: 4.679905414581299 in epoch: 25\n",
      "loss: 4.608245372772217 in epoch: 26\n",
      "loss: 4.534269332885742 in epoch: 27\n",
      "loss: 4.454967021942139 in epoch: 28\n",
      "loss: 4.365190029144287 in epoch: 29\n",
      "loss: 4.261077880859375 in epoch: 30\n",
      "loss: 4.142685890197754 in epoch: 31\n",
      "loss: 4.013568878173828 in epoch: 32\n",
      "loss: 3.877518892288208 in epoch: 33\n",
      "loss: 3.734825849533081 in epoch: 34\n",
      "loss: 3.581747531890869 in epoch: 35\n",
      "loss: 3.414931297302246 in epoch: 36\n",
      "loss: 3.2366387844085693 in epoch: 37\n",
      "loss: 3.054164409637451 in epoch: 38\n",
      "loss: 2.872296094894409 in epoch: 39\n",
      "loss: 2.6880037784576416 in epoch: 40\n",
      "loss: 2.498760461807251 in epoch: 41\n",
      "loss: 2.3129189014434814 in epoch: 42\n",
      "loss: 2.1415114402770996 in epoch: 43\n",
      "loss: 1.9850804805755615 in epoch: 44\n",
      "loss: 1.8453359603881836 in epoch: 45\n",
      "loss: 1.735142707824707 in epoch: 46\n",
      "loss: 1.6521391868591309 in epoch: 47\n",
      "loss: 1.58646821975708 in epoch: 48\n",
      "loss: 1.5434740781784058 in epoch: 49\n",
      "loss: 1.507825493812561 in epoch: 50\n",
      "loss: 1.4672000408172607 in epoch: 51\n",
      "loss: 1.420212745666504 in epoch: 52\n",
      "loss: 1.3566780090332031 in epoch: 53\n",
      "loss: 1.2872490882873535 in epoch: 54\n",
      "loss: 1.212072730064392 in epoch: 55\n",
      "loss: 1.138185977935791 in epoch: 56\n",
      "loss: 1.070281982421875 in epoch: 57\n",
      "loss: 1.006996750831604 in epoch: 58\n",
      "loss: 0.9541227221488953 in epoch: 59\n",
      "loss: 0.9078683853149414 in epoch: 60\n",
      "loss: 0.8699485659599304 in epoch: 61\n",
      "loss: 0.837985634803772 in epoch: 62\n",
      "loss: 0.8093373775482178 in epoch: 63\n",
      "loss: 0.7840264439582825 in epoch: 64\n",
      "loss: 0.7580209970474243 in epoch: 65\n",
      "loss: 0.7319775223731995 in epoch: 66\n",
      "loss: 0.7040810585021973 in epoch: 67\n",
      "loss: 0.674628734588623 in epoch: 68\n",
      "loss: 0.6449049711227417 in epoch: 69\n",
      "loss: 0.6149008870124817 in epoch: 70\n",
      "loss: 0.5869660973548889 in epoch: 71\n",
      "loss: 0.5605998039245605 in epoch: 72\n",
      "loss: 0.5373795032501221 in epoch: 73\n",
      "loss: 0.516346275806427 in epoch: 74\n",
      "loss: 0.4976632595062256 in epoch: 75\n",
      "loss: 0.4800300896167755 in epoch: 76\n",
      "loss: 0.46333563327789307 in epoch: 77\n",
      "loss: 0.44681647419929504 in epoch: 78\n",
      "loss: 0.4305223822593689 in epoch: 79\n",
      "loss: 0.41395875811576843 in epoch: 80\n",
      "loss: 0.39753004908561707 in epoch: 81\n",
      "loss: 0.38113945722579956 in epoch: 82\n",
      "loss: 0.36551937460899353 in epoch: 83\n",
      "loss: 0.3506680428981781 in epoch: 84\n",
      "loss: 0.33721843361854553 in epoch: 85\n",
      "loss: 0.32481861114501953 in epoch: 86\n",
      "loss: 0.31357187032699585 in epoch: 87\n",
      "loss: 0.30281421542167664 in epoch: 88\n",
      "loss: 0.2925513982772827 in epoch: 89\n",
      "loss: 0.2823839485645294 in epoch: 90\n",
      "loss: 0.27251219749450684 in epoch: 91\n",
      "loss: 0.26292261481285095 in epoch: 92\n",
      "loss: 0.253822922706604 in epoch: 93\n",
      "loss: 0.2460496872663498 in epoch: 94\n",
      "loss: 0.2380439043045044 in epoch: 95\n",
      "loss: 0.2301630973815918 in epoch: 96\n",
      "loss: 0.22392502427101135 in epoch: 97\n",
      "loss: 0.21643251180648804 in epoch: 98\n",
      "loss: 0.21080946922302246 in epoch: 99\n",
      "loss: 0.20420131087303162 in epoch: 100\n",
      "loss: 0.1981685906648636 in epoch: 101\n",
      "loss: 0.19248875975608826 in epoch: 102\n",
      "loss: 0.18616081774234772 in epoch: 103\n",
      "loss: 0.18101352453231812 in epoch: 104\n",
      "loss: 0.17537067830562592 in epoch: 105\n",
      "loss: 0.17024187743663788 in epoch: 106\n",
      "loss: 0.165567085146904 in epoch: 107\n",
      "loss: 0.16050602495670319 in epoch: 108\n",
      "loss: 0.15616312623023987 in epoch: 109\n",
      "loss: 0.1516442894935608 in epoch: 110\n",
      "loss: 0.14721140265464783 in epoch: 111\n",
      "loss: 0.14322245121002197 in epoch: 112\n",
      "loss: 0.13896946609020233 in epoch: 113\n",
      "loss: 0.13505227863788605 in epoch: 114\n",
      "loss: 0.1313289999961853 in epoch: 115\n",
      "loss: 0.12751397490501404 in epoch: 116\n",
      "loss: 0.12407843768596649 in epoch: 117\n",
      "loss: 0.1206991896033287 in epoch: 118\n",
      "loss: 0.11728793382644653 in epoch: 119\n",
      "loss: 0.11415819823741913 in epoch: 120\n",
      "loss: 0.11103837192058563 in epoch: 121\n",
      "loss: 0.107931949198246 in epoch: 122\n",
      "loss: 0.10505877435207367 in epoch: 123\n",
      "loss: 0.1022230014204979 in epoch: 124\n",
      "loss: 0.09941315650939941 in epoch: 125\n",
      "loss: 0.09679865837097168 in epoch: 126\n",
      "loss: 0.09424856305122375 in epoch: 127\n",
      "loss: 0.09170588105916977 in epoch: 128\n",
      "loss: 0.08929282426834106 in epoch: 129\n",
      "loss: 0.0869583860039711 in epoch: 130\n",
      "loss: 0.0846351683139801 in epoch: 131\n",
      "loss: 0.082405686378479 in epoch: 132\n",
      "loss: 0.08028333634138107 in epoch: 133\n",
      "loss: 0.07819676399230957 in epoch: 134\n",
      "loss: 0.07615654915571213 in epoch: 135\n",
      "loss: 0.07420826703310013 in epoch: 136\n",
      "loss: 0.0723215863108635 in epoch: 137\n",
      "loss: 0.07046215236186981 in epoch: 138\n",
      "loss: 0.06917209178209305 in epoch: 139\n",
      "loss: 0.0696820542216301 in epoch: 140\n",
      "loss: 0.06746736168861389 in epoch: 141\n",
      "loss: 0.06376779824495316 in epoch: 142\n",
      "loss: 0.0629146620631218 in epoch: 143\n",
      "loss: 0.06269250065088272 in epoch: 144\n",
      "loss: 0.060070086270570755 in epoch: 145\n",
      "loss: 0.05772438645362854 in epoch: 146\n",
      "loss: 0.05736316740512848 in epoch: 147\n",
      "loss: 0.05638022720813751 in epoch: 148\n",
      "loss: 0.05405125766992569 in epoch: 149\n",
      "loss: 0.052612949162721634 in epoch: 150\n",
      "loss: 0.052188992500305176 in epoch: 151\n",
      "loss: 0.05094119906425476 in epoch: 152\n",
      "loss: 0.049074944108724594 in epoch: 153\n",
      "loss: 0.04806329682469368 in epoch: 154\n",
      "loss: 0.04750946909189224 in epoch: 155\n",
      "loss: 0.04628117009997368 in epoch: 156\n",
      "loss: 0.04480413347482681 in epoch: 157\n",
      "loss: 0.043937407433986664 in epoch: 158\n",
      "loss: 0.043324731290340424 in epoch: 159\n",
      "loss: 0.04228443652391434 in epoch: 160\n",
      "loss: 0.04106695204973221 in epoch: 161\n",
      "loss: 0.0402304045855999 in epoch: 162\n",
      "loss: 0.03962218761444092 in epoch: 163\n",
      "loss: 0.03878338262438774 in epoch: 164\n",
      "loss: 0.03776833415031433 in epoch: 165\n",
      "loss: 0.036936454474925995 in epoch: 166\n",
      "loss: 0.036330122500658035 in epoch: 167\n",
      "loss: 0.035678524523973465 in epoch: 168\n",
      "loss: 0.0348656140267849 in epoch: 169\n",
      "loss: 0.034054290503263474 in epoch: 170\n",
      "loss: 0.03340056911110878 in epoch: 171\n",
      "loss: 0.03284627944231033 in epoch: 172\n",
      "loss: 0.03224286437034607 in epoch: 173\n",
      "loss: 0.03155585005879402 in epoch: 174\n",
      "loss: 0.030879994854331017 in epoch: 175\n",
      "loss: 0.030298052355647087 in epoch: 176\n",
      "loss: 0.029789529740810394 in epoch: 177\n",
      "loss: 0.029275791719555855 in epoch: 178\n",
      "loss: 0.028715230524539948 in epoch: 179\n",
      "loss: 0.02813810482621193 in epoch: 180\n",
      "loss: 0.027598334476351738 in epoch: 181\n",
      "loss: 0.02711673080921173 in epoch: 182\n",
      "loss: 0.02666919119656086 in epoch: 183\n",
      "loss: 0.02622242644429207 in epoch: 184\n",
      "loss: 0.025758560746908188 in epoch: 185\n",
      "loss: 0.025287460535764694 in epoch: 186\n",
      "loss: 0.02482692524790764 in epoch: 187\n",
      "loss: 0.02439257875084877 in epoch: 188\n",
      "loss: 0.023986399173736572 in epoch: 189\n",
      "loss: 0.023600183427333832 in epoch: 190\n",
      "loss: 0.02322501502931118 in epoch: 191\n",
      "loss: 0.022853363305330276 in epoch: 192\n",
      "loss: 0.022483600303530693 in epoch: 193\n",
      "loss: 0.02211674489080906 in epoch: 194\n",
      "loss: 0.021755527704954147 in epoch: 195\n",
      "loss: 0.021401455625891685 in epoch: 196\n",
      "loss: 0.021056601777672768 in epoch: 197\n",
      "loss: 0.020723285153508186 in epoch: 198\n",
      "loss: 0.020399946719408035 in epoch: 199\n",
      "loss: 0.020086010918021202 in epoch: 200\n",
      "loss: 0.019781187176704407 in epoch: 201\n",
      "loss: 0.019484320655465126 in epoch: 202\n",
      "loss: 0.01919526606798172 in epoch: 203\n",
      "loss: 0.018913449719548225 in epoch: 204\n",
      "loss: 0.01863856613636017 in epoch: 205\n",
      "loss: 0.018371934071183205 in epoch: 206\n",
      "loss: 0.01811387576162815 in epoch: 207\n",
      "loss: 0.0178664717823267 in epoch: 208\n",
      "loss: 0.017633844166994095 in epoch: 209\n",
      "loss: 0.017425257712602615 in epoch: 210\n",
      "loss: 0.017257504165172577 in epoch: 211\n",
      "loss: 0.017172327265143394 in epoch: 212\n",
      "loss: 0.017261741682887077 in epoch: 213\n",
      "loss: 0.01770230382680893 in epoch: 214\n",
      "loss: 0.018874000757932663 in epoch: 215\n",
      "loss: 0.021192245185375214 in epoch: 216\n",
      "loss: 0.025007780641317368 in epoch: 217\n",
      "loss: 0.02793441340327263 in epoch: 218\n",
      "loss: 0.02682383917272091 in epoch: 219\n",
      "loss: 0.01991811767220497 in epoch: 220\n",
      "loss: 0.01516442745923996 in epoch: 221\n",
      "loss: 0.01719849184155464 in epoch: 222\n",
      "loss: 0.02111811935901642 in epoch: 223\n",
      "loss: 0.020368659868836403 in epoch: 224\n",
      "loss: 0.015767604112625122 in epoch: 225\n",
      "loss: 0.014543005265295506 in epoch: 226\n",
      "loss: 0.017283448949456215 in epoch: 227\n",
      "loss: 0.018120132386684418 in epoch: 228\n",
      "loss: 0.015469006262719631 in epoch: 229\n",
      "loss: 0.013705153949558735 in epoch: 230\n",
      "loss: 0.015121790580451488 in epoch: 231\n",
      "loss: 0.016275299713015556 in epoch: 232\n",
      "loss: 0.014729161746799946 in epoch: 233\n",
      "loss: 0.01318901963531971 in epoch: 234\n",
      "loss: 0.01382248755544424 in epoch: 235\n",
      "loss: 0.014739582315087318 in epoch: 236\n",
      "loss: 0.013988742604851723 in epoch: 237\n",
      "loss: 0.012763520702719688 in epoch: 238\n",
      "loss: 0.012882993556559086 in epoch: 239\n",
      "loss: 0.013580859638750553 in epoch: 240\n",
      "loss: 0.013281537219882011 in epoch: 241\n",
      "loss: 0.012388245202600956 in epoch: 242\n",
      "loss: 0.012188167311251163 in epoch: 243\n",
      "loss: 0.0126187140122056 in epoch: 244\n",
      "loss: 0.012636657804250717 in epoch: 245\n",
      "loss: 0.012051566503942013 in epoch: 246\n",
      "loss: 0.011679572984576225 in epoch: 247\n",
      "loss: 0.011844638735055923 in epoch: 248\n",
      "loss: 0.011990653350949287 in epoch: 249\n",
      "loss: 0.011710411868989468 in epoch: 250\n",
      "loss: 0.011316129937767982 in epoch: 251\n",
      "loss: 0.011239259503781796 in epoch: 252\n",
      "loss: 0.011365578509867191 in epoch: 253\n",
      "loss: 0.011315838433802128 in epoch: 254\n",
      "loss: 0.01104173343628645 in epoch: 255\n",
      "loss: 0.010813437402248383 in epoch: 256\n",
      "loss: 0.010790971107780933 in epoch: 257\n",
      "loss: 0.010827495716512203 in epoch: 258\n",
      "loss: 0.010730814188718796 in epoch: 259\n",
      "loss: 0.010527445934712887 in epoch: 260\n",
      "loss: 0.010375919751822948 in epoch: 261\n",
      "loss: 0.010338569059967995 in epoch: 262\n",
      "loss: 0.010329017415642738 in epoch: 263\n",
      "loss: 0.010246969759464264 in epoch: 264\n",
      "loss: 0.010101595893502235 in epoch: 265\n",
      "loss: 0.009971833787858486 in epoch: 266\n",
      "loss: 0.009905636310577393 in epoch: 267\n",
      "loss: 0.009872657246887684 in epoch: 268\n",
      "loss: 0.009814090095460415 in epoch: 269\n",
      "loss: 0.009712652303278446 in epoch: 270\n",
      "loss: 0.009600223042070866 in epoch: 271\n",
      "loss: 0.009515378624200821 in epoch: 272\n",
      "loss: 0.009461242705583572 in epoch: 273\n",
      "loss: 0.009412319399416447 in epoch: 274\n",
      "loss: 0.009345293045043945 in epoch: 275\n",
      "loss: 0.009258629754185677 in epoch: 276\n",
      "loss: 0.009169896133244038 in epoch: 277\n",
      "loss: 0.00909388903528452 in epoch: 278\n",
      "loss: 0.00903388112783432 in epoch: 279\n",
      "loss: 0.008980614133179188 in epoch: 280\n",
      "loss: 0.008921879343688488 in epoch: 281\n",
      "loss: 0.008852637372910976 in epoch: 282\n",
      "loss: 0.008777697570621967 in epoch: 283\n",
      "loss: 0.008705326355993748 in epoch: 284\n",
      "loss: 0.00864036288112402 in epoch: 285\n",
      "loss: 0.008582496084272861 in epoch: 286\n",
      "loss: 0.008527468889951706 in epoch: 287\n",
      "loss: 0.008470972068607807 in epoch: 288\n",
      "loss: 0.008411032147705555 in epoch: 289\n",
      "loss: 0.008348400704562664 in epoch: 290\n",
      "loss: 0.008285450749099255 in epoch: 291\n",
      "loss: 0.008223829790949821 in epoch: 292\n",
      "loss: 0.00816532876342535 in epoch: 293\n",
      "loss: 0.008109907619655132 in epoch: 294\n",
      "loss: 0.008056956343352795 in epoch: 295\n",
      "loss: 0.008004538714885712 in epoch: 296\n",
      "loss: 0.007951989769935608 in epoch: 297\n",
      "loss: 0.00789843313395977 in epoch: 298\n",
      "loss: 0.007844354026019573 in epoch: 299\n",
      "loss: 0.007790199015289545 in epoch: 300\n",
      "loss: 0.007736781612038612 in epoch: 301\n",
      "loss: 0.007683813571929932 in epoch: 302\n",
      "loss: 0.0076317982748150826 in epoch: 303\n",
      "loss: 0.007580425590276718 in epoch: 304\n",
      "loss: 0.007530172821134329 in epoch: 305\n",
      "loss: 0.007480436470359564 in epoch: 306\n",
      "loss: 0.007431361824274063 in epoch: 307\n",
      "loss: 0.0073831831105053425 in epoch: 308\n",
      "loss: 0.007335921283811331 in epoch: 309\n",
      "loss: 0.007289540953934193 in epoch: 310\n",
      "loss: 0.007244478911161423 in epoch: 311\n",
      "loss: 0.007201413623988628 in epoch: 312\n",
      "loss: 0.0071611362509429455 in epoch: 313\n",
      "loss: 0.00712440675124526 in epoch: 314\n",
      "loss: 0.007092040032148361 in epoch: 315\n",
      "loss: 0.007067240308970213 in epoch: 316\n",
      "loss: 0.00705487746745348 in epoch: 317\n",
      "loss: 0.0070656174793839455 in epoch: 318\n",
      "loss: 0.007116592954844236 in epoch: 319\n",
      "loss: 0.007240981329232454 in epoch: 320\n",
      "loss: 0.007492359261959791 in epoch: 321\n",
      "loss: 0.007989347912371159 in epoch: 322\n",
      "loss: 0.008884410373866558 in epoch: 323\n",
      "loss: 0.010502424091100693 in epoch: 324\n",
      "loss: 0.012983730062842369 in epoch: 325\n",
      "loss: 0.01661255769431591 in epoch: 326\n",
      "loss: 0.019634079188108444 in epoch: 327\n",
      "loss: 0.020457938313484192 in epoch: 328\n",
      "loss: 0.0158337764441967 in epoch: 329\n",
      "loss: 0.009483171626925468 in epoch: 330\n",
      "loss: 0.006431523244827986 in epoch: 331\n",
      "loss: 0.008625878021121025 in epoch: 332\n",
      "loss: 0.012410206720232964 in epoch: 333\n",
      "loss: 0.0127706378698349 in epoch: 334\n",
      "loss: 0.009556261822581291 in epoch: 335\n",
      "loss: 0.006500387564301491 in epoch: 336\n",
      "loss: 0.006946439854800701 in epoch: 337\n",
      "loss: 0.00936749018728733 in epoch: 338\n",
      "loss: 0.01004075538367033 in epoch: 339\n",
      "loss: 0.008201445452868938 in epoch: 340\n",
      "loss: 0.00625980319455266 in epoch: 341\n",
      "loss: 0.00650821253657341 in epoch: 342\n",
      "loss: 0.007983999326825142 in epoch: 343\n",
      "loss: 0.008308572694659233 in epoch: 344\n",
      "loss: 0.00711330771446228 in epoch: 345\n",
      "loss: 0.006002269685268402 in epoch: 346\n",
      "loss: 0.006237141788005829 in epoch: 347\n",
      "loss: 0.007116595283150673 in epoch: 348\n",
      "loss: 0.007247778121381998 in epoch: 349\n",
      "loss: 0.0064885253086686134 in epoch: 350\n",
      "loss: 0.005824525840580463 in epoch: 351\n",
      "loss: 0.005970851052552462 in epoch: 352\n",
      "loss: 0.006492429878562689 in epoch: 353\n",
      "loss: 0.0065726060420274734 in epoch: 354\n",
      "loss: 0.006117751821875572 in epoch: 355\n",
      "loss: 0.005686020944267511 in epoch: 356\n",
      "loss: 0.0057214051485061646 in epoch: 357\n",
      "loss: 0.006028004921972752 in epoch: 358\n",
      "loss: 0.006127120926976204 in epoch: 359\n",
      "loss: 0.00588672561571002 in epoch: 360\n",
      "loss: 0.005579026415944099 in epoch: 361\n",
      "loss: 0.005509332288056612 in epoch: 362\n",
      "loss: 0.005654545966535807 in epoch: 363\n",
      "loss: 0.005766134709119797 in epoch: 364\n",
      "loss: 0.005686679854989052 in epoch: 365\n",
      "loss: 0.0054892683401703835 in epoch: 366\n",
      "loss: 0.005364611279219389 in epoch: 367\n",
      "loss: 0.005388600751757622 in epoch: 368\n",
      "loss: 0.005471986252814531 in epoch: 369\n",
      "loss: 0.00548798032104969 in epoch: 370\n",
      "loss: 0.005400029011070728 in epoch: 371\n",
      "loss: 0.005281440913677216 in epoch: 372\n",
      "loss: 0.005215863231569529 in epoch: 373\n",
      "loss: 0.0052243624813854694 in epoch: 374\n",
      "loss: 0.005259297788143158 in epoch: 375\n",
      "loss: 0.005258603021502495 in epoch: 376\n",
      "loss: 0.005205619148910046 in epoch: 377\n",
      "loss: 0.005130302626639605 in epoch: 378\n",
      "loss: 0.005076345521956682 in epoch: 379\n",
      "loss: 0.005060623865574598 in epoch: 380\n",
      "loss: 0.005066227167844772 in epoch: 381\n",
      "loss: 0.0050650895573198795 in epoch: 382\n",
      "loss: 0.005040700081735849 in epoch: 383\n",
      "loss: 0.004997537937015295 in epoch: 384\n",
      "loss: 0.004951572045683861 in epoch: 385\n",
      "loss: 0.004918225109577179 in epoch: 386\n",
      "loss: 0.0049016717821359634 in epoch: 387\n",
      "loss: 0.004893722478300333 in epoch: 388\n",
      "loss: 0.004882709588855505 in epoch: 389\n",
      "loss: 0.004862342961132526 in epoch: 390\n",
      "loss: 0.004833486396819353 in epoch: 391\n",
      "loss: 0.004801261704415083 in epoch: 392\n",
      "loss: 0.004771833773702383 in epoch: 393\n",
      "loss: 0.0047484757378697395 in epoch: 394\n",
      "loss: 0.004731141962110996 in epoch: 395\n",
      "loss: 0.004716465249657631 in epoch: 396\n",
      "loss: 0.004700709134340286 in epoch: 397\n",
      "loss: 0.00468143867328763 in epoch: 398\n",
      "loss: 0.004659153986722231 in epoch: 399\n",
      "loss: 0.004635344259440899 in epoch: 400\n",
      "loss: 0.004611849784851074 in epoch: 401\n",
      "loss: 0.0045896717347204685 in epoch: 402\n",
      "loss: 0.0045690154656767845 in epoch: 403\n",
      "loss: 0.004549715202301741 in epoch: 404\n",
      "loss: 0.004531437531113625 in epoch: 405\n",
      "loss: 0.004513646475970745 in epoch: 406\n",
      "loss: 0.004495824221521616 in epoch: 407\n",
      "loss: 0.004477742128074169 in epoch: 408\n",
      "loss: 0.004459423944354057 in epoch: 409\n",
      "loss: 0.004440973978489637 in epoch: 410\n",
      "loss: 0.004422317259013653 in epoch: 411\n",
      "loss: 0.004403696395456791 in epoch: 412\n",
      "loss: 0.004385116044431925 in epoch: 413\n",
      "loss: 0.004366664215922356 in epoch: 414\n",
      "loss: 0.004348537418991327 in epoch: 415\n",
      "loss: 0.0043306369334459305 in epoch: 416\n",
      "loss: 0.004312632605433464 in epoch: 417\n",
      "loss: 0.004294661805033684 in epoch: 418\n",
      "loss: 0.004276993218809366 in epoch: 419\n",
      "loss: 0.004259500186890364 in epoch: 420\n",
      "loss: 0.0042421105317771435 in epoch: 421\n",
      "loss: 0.004225072450935841 in epoch: 422\n",
      "loss: 0.004208146594464779 in epoch: 423\n",
      "loss: 0.004191500600427389 in epoch: 424\n",
      "loss: 0.004175177775323391 in epoch: 425\n",
      "loss: 0.004159457981586456 in epoch: 426\n",
      "loss: 0.004144224803894758 in epoch: 427\n",
      "loss: 0.004129908978939056 in epoch: 428\n",
      "loss: 0.004116985015571117 in epoch: 429\n",
      "loss: 0.004105877596884966 in epoch: 430\n",
      "loss: 0.004097952041774988 in epoch: 431\n",
      "loss: 0.004095169249922037 in epoch: 432\n",
      "loss: 0.004102362785488367 in epoch: 433\n",
      "loss: 0.00412824796512723 in epoch: 434\n",
      "loss: 0.004188852850347757 in epoch: 435\n",
      "loss: 0.004309538286179304 in epoch: 436\n",
      "loss: 0.004544086288660765 in epoch: 437\n",
      "loss: 0.0049778493121266365 in epoch: 438\n",
      "loss: 0.005797424353659153 in epoch: 439\n",
      "loss: 0.007246721535921097 in epoch: 440\n",
      "loss: 0.009882649406790733 in epoch: 441\n",
      "loss: 0.01387951709330082 in epoch: 442\n",
      "loss: 0.01964435540139675 in epoch: 443\n",
      "loss: 0.023763690143823624 in epoch: 444\n",
      "loss: 0.023769568651914597 in epoch: 445\n",
      "loss: 0.015354742296040058 in epoch: 446\n",
      "loss: 0.006299139931797981 in epoch: 447\n",
      "loss: 0.004193738102912903 in epoch: 448\n",
      "loss: 0.009226561523973942 in epoch: 449\n",
      "loss: 0.01401234045624733 in epoch: 450\n",
      "loss: 0.0118380356580019 in epoch: 451\n",
      "loss: 0.006117787212133408 in epoch: 452\n",
      "loss: 0.0038323691114783287 in epoch: 453\n",
      "loss: 0.006817197427153587 in epoch: 454\n",
      "loss: 0.00978827103972435 in epoch: 455\n",
      "loss: 0.008111546747386456 in epoch: 456\n",
      "loss: 0.004595301114022732 in epoch: 457\n",
      "loss: 0.003965112846344709 in epoch: 458\n",
      "loss: 0.00621928833425045 in epoch: 459\n",
      "loss: 0.007371698040515184 in epoch: 460\n",
      "loss: 0.0055982982739806175 in epoch: 461\n",
      "loss: 0.0037704554852098227 in epoch: 462\n",
      "loss: 0.004244910553097725 in epoch: 463\n",
      "loss: 0.0056887781247496605 in epoch: 464\n",
      "loss: 0.005698747467249632 in epoch: 465\n",
      "loss: 0.004299571271985769 in epoch: 466\n",
      "loss: 0.0036109001375734806 in epoch: 467\n",
      "loss: 0.004316077567636967 in epoch: 468\n",
      "loss: 0.005000177770853043 in epoch: 469\n",
      "loss: 0.004592712968587875 in epoch: 470\n",
      "loss: 0.0037391996011137962 in epoch: 471\n",
      "loss: 0.0036278190091252327 in epoch: 472\n",
      "loss: 0.0041723125614225864 in epoch: 473\n",
      "loss: 0.0043962388299405575 in epoch: 474\n",
      "loss: 0.003981730435043573 in epoch: 475\n",
      "loss: 0.0035370748955756426 in epoch: 476\n",
      "loss: 0.003617399139329791 in epoch: 477\n",
      "loss: 0.0039579859003424644 in epoch: 478\n",
      "loss: 0.003990760073065758 in epoch: 479\n",
      "loss: 0.003684510011225939 in epoch: 480\n",
      "loss: 0.0034563825465738773 in epoch: 481\n",
      "loss: 0.0035467357374727726 in epoch: 482\n",
      "loss: 0.0037414429243654013 in epoch: 483\n",
      "loss: 0.003733335994184017 in epoch: 484\n",
      "loss: 0.0035383403301239014 in epoch: 485\n",
      "loss: 0.003402086440473795 in epoch: 486\n",
      "loss: 0.0034530600532889366 in epoch: 487\n",
      "loss: 0.003563474165275693 in epoch: 488\n",
      "loss: 0.0035602881107479334 in epoch: 489\n",
      "loss: 0.0034470276441425085 in epoch: 490\n",
      "loss: 0.0033542481251060963 in epoch: 491\n",
      "loss: 0.003363547381013632 in epoch: 492\n",
      "loss: 0.003423235611990094 in epoch: 493\n",
      "loss: 0.003435688093304634 in epoch: 494\n",
      "loss: 0.003378140041604638 in epoch: 495\n",
      "loss: 0.0033114932011812925 in epoch: 496\n",
      "loss: 0.003293937537819147 in epoch: 497\n",
      "loss: 0.0033178122248500586 in epoch: 498\n",
      "loss: 0.0033352989703416824 in epoch: 499\n"
     ]
    }
   ],
   "source": [
    "params = []\n",
    "params += [x for x in model.parameters()]\n",
    "optimiser = torch.optim.Adam(params, lr=0.001)\n",
    "loss_fn = torch.nn.MSELoss()\n",
    "\n",
    "n_epochs = 500\n",
    "v_true = vp_overthrust.to(device)\n",
    "n_segments = 1\n",
    "\n",
    "for epoch in range(n_epochs):\n",
    "    pml_width = 100\n",
    "    wavefield_size = [n_shots, nx + 2 * pml_width,\n",
    "                          nz + 1 * pml_width]\n",
    "    wavefield_0 = torch.zeros(*wavefield_size, device=device)\n",
    "    wavefield_m1 = torch.zeros(*wavefield_size, device=device)\n",
    "    psiy_m1 = torch.zeros(*wavefield_size, device=device)\n",
    "    psix_m1 = torch.zeros(*wavefield_size, device=device)\n",
    "    zetay_m1 = torch.zeros(*wavefield_size, device=device)\n",
    "    zetax_m1 = torch.zeros(*wavefield_size, device=device)\n",
    "    optimiser.zero_grad()\n",
    "    receiver_amplitudes = torch.zeros(n_shots,\n",
    "                                          n_receivers_per_shot, nt,\n",
    "                                          device=device)\n",
    "    k = 0\n",
    "    optimiser.zero_grad()\n",
    "    v_gen = model(input,nx,nz) * 1000 + v_init\n",
    "    for i, chunk in enumerate(torch.chunk(wavelet,\n",
    "                                              n_segments,\n",
    "                                              dim=-1)):\n",
    "        if i == n_segments - 1:\n",
    "            (wavefield_0, wavefield_m1, psiy_m1, psix_m1,\n",
    "                 zetay_m1, zetax_m1, receiver_amplitudes_chunk) = \\\n",
    "                wrap(v_gen.T, chunk, wavefield_0,\n",
    "                         wavefield_m1,\n",
    "                         psiy_m1, psix_m1,\n",
    "                         zetay_m1, zetax_m1)\n",
    "        else:\n",
    "            (wavefield_0, wavefield_m1, psiy_m1, psix_m1,\n",
    "                 zetay_m1, zetax_m1, receiver_amplitudes_chunk) = \\\n",
    "            torch.utils.checkpoint.checkpoint(wrap, v_gen.T, chunk,\n",
    "                                                   wavefield_0,\n",
    "                                                   wavefield_m1,\n",
    "                                                   psiy_m1, psix_m1,\n",
    "                                                   zetay_m1,\n",
    "                                                   zetax_m1)\n",
    "        receiver_amplitudes[..., k:k+chunk.shape[-1]] = \\\n",
    "                receiver_amplitudes_chunk\n",
    "        k += chunk.shape[-1]\n",
    "\n",
    "    loss = torch.sum((receiver_amplitudes - observed_data) ** 2) * 1e-6\n",
    "    loss.backward()\n",
    "\n",
    "    print(\"loss:\",loss.item(),\"in epoch:\",epoch)\n",
    "    optimiser.step()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "49d83266",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(5, 5))\n",
    "gs = fig.add_gridspec(1, 1)\n",
    "ax = fig.add_subplot(gs[0, 0])\n",
    "im = ax.imshow(v_gen.detach().cpu()/1000, vmin=2.5, vmax=6, aspect='1', cmap='RdBu_r')\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "FWIWULAB",
   "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.8.19"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
