{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "9db76765-2e54-438f-a159-eb3e30dddb0a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from torch import nn\n",
    "from torch import Tensor\n",
    "from torch import optim\n",
    "import torch.nn.functional as F\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "b41b1021-0dd7-4b52-b682-fe7a3d731bf7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "%pylab is deprecated, use %matplotlib inline and import the required libraries.\n",
      "Populating the interactive namespace from numpy and matplotlib\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/ebuild/installs/software/Anaconda3/2024.02-1/lib/python3.11/site-packages/IPython/core/magics/pylab.py:162: UserWarning: pylab import has clobbered these variables: ['plt']\n",
      "`%matplotlib` prevents importing * from pylab and numpy\n",
      "  warn(\"pylab import has clobbered these variables: %s\"  % clobbered +\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib as plt\n",
    "%pylab inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "44d25799-b9ae-4433-b4ab-6cd46932738c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Train X shape: torch.Size([5452, 10, 1]), y shape: torch.Size([5452, 10, 1])\n",
      "Test X shape: torch.Size([580, 10, 1]), y shape: torch.Size([580, 10, 1])\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import torch\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "\n",
    "# Device and seed setup\n",
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "torch.manual_seed(42)\n",
    "np.random.seed(42)\n",
    "\n",
    "# === Load dataset ===\n",
    "data = pd.read_csv(\"spatial_avg_data-ERAsinglelevel_2020-24_daily.csv\")\n",
    "\n",
    "# === Extract relevant features ===\n",
    "s_data = data[[\"asn\", \"rsn\", \"siconc\"]].values\n",
    "\n",
    "# === Train-test split ===\n",
    "train_data = s_data[:5461]\n",
    "test_data = s_data[5461:6050]\n",
    "\n",
    "# === Scale features using only training stats ===\n",
    "scaler = StandardScaler()\n",
    "train_scaled = scaler.fit_transform(train_data)\n",
    "test_scaled = scaler.transform(test_data)\n",
    "\n",
    "# === Define constants for computing snow depth proxy ===\n",
    "A, B = 600, 300\n",
    "\n",
    "def compute_snow_depth_proxy(data):\n",
    "    siconc_term = (data[:, 2] * A) / (A - B)\n",
    "    albedo_density_term = (data[:, 0] * data[:, 1]) / (A - B)\n",
    "    return (siconc_term + albedo_density_term).reshape(-1, 1)\n",
    "\n",
    "# === Compute and normalize snow depth proxy ===\n",
    "train_depth = compute_snow_depth_proxy(train_scaled)\n",
    "test_depth = compute_snow_depth_proxy(test_scaled)\n",
    "\n",
    "mean_depth, std_depth = train_depth.mean(), train_depth.std()\n",
    "train_depth_norm = (train_depth - mean_depth) / std_depth\n",
    "test_depth_norm = (test_depth - mean_depth) / std_depth\n",
    "\n",
    "# === Convert to sequences ===\n",
    "def create_sequences(inputs, targets, seq_len):\n",
    "    X, Y = [], []\n",
    "    for i in range(len(inputs) - seq_len + 1):\n",
    "        X.append(inputs[i:i+seq_len])\n",
    "        Y.append(targets[i:i+seq_len])  # supervision at end of sequence\n",
    "    return np.array(X), np.array(Y)\n",
    "\n",
    "seq_length = 10\n",
    "X_train_seq, y_train_seq = create_sequences(train_scaled[:, 1:2], train_depth_norm, seq_length)  # only snow density as input\n",
    "X_test_seq, y_test_seq = create_sequences(test_scaled[:, 1:2], test_depth_norm, seq_length)\n",
    "\n",
    "# === Convert to PyTorch tensors ===\n",
    "X_train_tensor = torch.tensor(X_train_seq, dtype=torch.float32).to(device)\n",
    "y_train_tensor = torch.tensor(y_train_seq, dtype=torch.float32).to(device)\n",
    "X_test_tensor = torch.tensor(X_test_seq, dtype=torch.float32).to(device)\n",
    "y_test_tensor = torch.tensor(y_test_seq, dtype=torch.float32).to(device)\n",
    "\n",
    "# === Confirm shapes ===\n",
    "print(f\"Train X shape: {X_train_tensor.shape}, y shape: {y_train_tensor.shape}\")\n",
    "print(f\"Test X shape: {X_test_tensor.shape}, y shape: {y_test_tensor.shape}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "42a03fdb-73ed-42bb-a0d0-8202b96c4b23",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "import torch.nn.functional as F\n",
    "import numpy as np\n",
    "\n",
    "# Data Augmentation Function for Contrastive Learning\n",
    "def augment_data(x, noise_std=0.01):\n",
    "\n",
    "    noise = torch.randn_like(x) * noise_std  # Add Gaussian noise\n",
    "    x_aug = x + noise\n",
    "    return x_aug\n",
    "\n",
    "\n",
    "import torch\n",
    "import torch.nn.functional as F\n",
    "\n",
    "def contrastive_loss(z_i, z_j, scale=0.05):\n",
    "\n",
    "    batch_size = z_i.size(0)\n",
    "\n",
    "    # Normalize embeddings\n",
    "    z_i = F.normalize(z_i, dim=1)\n",
    "    z_j = F.normalize(z_j, dim=1)\n",
    "\n",
    "    # Create a large similarity matrix\n",
    "    similarity_matrix = torch.matmul(z_i, z_j.T) / scale\n",
    "\n",
    "    #Create a similarity matrix that combines z_i and z_j\n",
    "    combined_z = torch.cat([z_i,z_j], dim=0)\n",
    "    combined_similarity = torch.matmul(combined_z, combined_z.T) / scale\n",
    "\n",
    "    #create labels.\n",
    "    labels = torch.arange(batch_size, device=z_i.device)\n",
    "    combined_labels = torch.cat([labels, labels], dim=0) #correct label concatination.\n",
    "\n",
    "    #remove diagonal.\n",
    "    mask = ~torch.eye(combined_labels.shape[0], device=combined_labels.device).bool()\n",
    "    combined_similarity = combined_similarity.masked_select(mask).view(combined_labels.shape[0], -1)\n",
    "    #Do not repeat labels.\n",
    "    #combined_labels = combined_labels.repeat(2)\n",
    "\n",
    "    loss = F.cross_entropy(combined_similarity, combined_labels)\n",
    "    return loss\n",
    "class BiLSTMContrastive(nn.Module):\n",
    "    def __init__(self, input_dim=1, hidden_dim=64, num_layers=2, output_dim=1, dropout_rate=0.4):\n",
    "        super(BiLSTMContrastive, self).__init__()\n",
    "        self.hidden_dim = hidden_dim\n",
    "        self.num_layers = num_layers\n",
    "        self.dropout_rate = dropout_rate\n",
    "        self.bidirectional = True\n",
    "        self.num_directions = 2 if self.bidirectional else 1\n",
    "\n",
    "        # BiLSTM Encoder\n",
    "        self.encoder_lstm = nn.LSTM(input_dim, hidden_dim, num_layers,\n",
    "                                    batch_first=True, dropout=dropout_rate, bidirectional=self.bidirectional)\n",
    "\n",
    "        # BiLSTM Decoder\n",
    "        self.decoder_lstm = nn.LSTM(hidden_dim * self.num_directions, hidden_dim,\n",
    "                                    num_layers, batch_first=True, dropout=dropout_rate, bidirectional=self.bidirectional)\n",
    "\n",
    "        # Adjusted FC layers due to doubled hidden size\n",
    "        self.fc_depth = nn.Linear(hidden_dim * self.num_directions, output_dim)\n",
    "\n",
    "        self.fc_params = nn.Sequential(\n",
    "            nn.Linear(hidden_dim * self.num_directions, 32),\n",
    "            nn.ReLU(),\n",
    "            nn.Linear(32, 16),\n",
    "            nn.ReLU(),\n",
    "            nn.Linear(16, 3)\n",
    "        )\n",
    "\n",
    "    def forward(self, x, x_aug):\n",
    "        # === Original Encoding\n",
    "        encoder_out_x, (h_n_x, c_n_x) = self.encoder_lstm(x)\n",
    "        decoder_out_x, _ = self.decoder_lstm(encoder_out_x, (h_n_x, c_n_x))\n",
    "\n",
    "        # === Augmented Encoding\n",
    "        encoder_out_aug, (h_n_aug, c_n_aug) = self.encoder_lstm(x_aug)\n",
    "        decoder_out_aug, _ = self.decoder_lstm(encoder_out_aug, (h_n_aug, c_n_aug))\n",
    "\n",
    "        # === Depth Prediction (per timestep)\n",
    "        depth_pred = self.fc_depth(decoder_out_x).squeeze(-1)  # (batch, time)\n",
    "\n",
    "        # === Parameter Estimation from last timestep\n",
    "        lstm_out_last_x = decoder_out_x[:, -1, :]  # (batch, hidden*2)\n",
    "        params_pred = self.fc_params(lstm_out_last_x)  # (batch, 3)\n",
    "        w_est_raw, b_est_raw, c_est_raw = params_pred[:, 0:1], params_pred[:, 1:2], params_pred[:, 2:3]\n",
    "\n",
    "        # === Stability Constraints\n",
    "        w_est = torch.sigmoid(w_est_raw) * 2.0 - 1.0\n",
    "        b_est = torch.exp(b_est_raw)\n",
    "        c_est = torch.tanh(c_est_raw) * 10.0\n",
    "\n",
    "        # === Mean snow density feature index (assuming 0 is density)\n",
    "        mean_snow_density = x[:, :, 0].mean(dim=1, keepdim=True)\n",
    "\n",
    "        # === Broadcast\n",
    "        b_est_exp = b_est.expand_as(depth_pred)\n",
    "        c_est_exp = c_est.expand_as(depth_pred)\n",
    "        w_est_exp = w_est.expand_as(depth_pred)\n",
    "        mean_density_exp = mean_snow_density.expand_as(depth_pred)\n",
    "\n",
    "        # === Physics-based Estimate\n",
    "        estimated_snow_depth = w_est_exp * mean_density_exp + b_est_exp * depth_pred + c_est_exp\n",
    "\n",
    "        # === Contrastive Loss\n",
    "        contrastive_loss_value = contrastive_loss(\n",
    "            decoder_out_x[:, -1, :], decoder_out_aug[:, -1, :]\n",
    "        ).mean()\n",
    "\n",
    "        return depth_pred, params_pred, estimated_snow_depth, contrastive_loss_value\n",
    "\n",
    "\n",
    "\n",
    "    \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "3164e58b-3e95-49a4-b144-e04cc49d76de",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Let's use 2 GPUs!\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/asampath/.local/lib/python3.11/site-packages/torch/nn/parallel/_functions.py:70: UserWarning: Was asked to gather along dimension 0, but all input tensors were scalars; will instead unsqueeze and return a vector.\n",
      "  warnings.warn(\n",
      "/home/asampath/.local/lib/python3.11/site-packages/torch/nn/modules/loss.py:610: UserWarning: Using a target size (torch.Size([16, 1])) that is different to the input size (torch.Size([16, 10])). This will likely lead to incorrect results due to broadcasting. Please ensure they have the same size.\n",
      "  return F.mse_loss(input, target, reduction=self.reduction)\n",
      "/tmp/ipykernel_221124/1180400121.py:55: DeprecationWarning: Calling np.sum(generator) is deprecated, and in the future will give a different result. Use np.sum(np.fromiter(generator)) or the python sum builtin instead.\n",
      "  l1_norm = sum(p.abs().sum() for p in model.parameters())\n",
      "/tmp/ipykernel_221124/1180400121.py:60: DeprecationWarning: Calling np.sum(generator) is deprecated, and in the future will give a different result. Use np.sum(np.fromiter(generator)) or the python sum builtin instead.\n",
      "  l2_norm = sum(p.pow(2.0).sum() for p in model.parameters())\n",
      "/home/asampath/.local/lib/python3.11/site-packages/torch/nn/modules/loss.py:610: UserWarning: Using a target size (torch.Size([12, 1])) that is different to the input size (torch.Size([12, 10])). This will likely lead to incorrect results due to broadcasting. Please ensure they have the same size.\n",
      "  return F.mse_loss(input, target, reduction=self.reduction)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0/500, Loss: 10.4762\n",
      "Epoch 50/500, Loss: 3.4459\n",
      "Epoch 100/500, Loss: 3.4236\n",
      "Epoch 150/500, Loss: 3.3965\n",
      "Epoch 200/500, Loss: 3.3676\n",
      "Epoch 250/500, Loss: 3.3552\n",
      "Epoch 300/500, Loss: 3.3301\n",
      "Epoch 350/500, Loss: 3.3317\n",
      "Epoch 400/500, Loss: 3.3286\n",
      "Epoch 450/500, Loss: 3.3145\n",
      "(580, 10)\n",
      "(580, 10)\n",
      "Training results saved to training_results.pth\n",
      "Data successfully written to average_depths.csv\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# === Device Setup ===\n",
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "\n",
    "# === Initialize Model & Optimizer ===\n",
    "model = BiLSTMContrastive()  # Move model to device\n",
    "criterion_depth = nn.MSELoss()  # Loss for depth prediction\n",
    "criterion_estimated_snow_depth = nn.MSELoss()  # Loss for predicted\n",
    "optimizer = optim.Adam(model.parameters(), lr=0.0005) # removed weight_decay from here.\n",
    "\n",
    "# Check for multiple GPUs and wrap with DataParallel if available\n",
    "if torch.cuda.device_count() > 1:\n",
    "    print(f\"Let's use {torch.cuda.device_count()} GPUs!\")\n",
    "    model = nn.DataParallel(model)\n",
    "\n",
    "# Move model to device\n",
    "model = model.to(device)\n",
    "\n",
    "# === Training Setup ===\n",
    "epochs = 500\n",
    "batch_size = 16\n",
    "\n",
    "# Convert data to PyTorch datasets\n",
    "train_dataset = torch.utils.data.TensorDataset(X_train_tensor, y_train_tensor)\n",
    "train_dataloader = torch.utils.data.DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n",
    "\n",
    "test_dataset = torch.utils.data.TensorDataset(X_test_tensor, y_test_tensor)\n",
    "test_dataloader = torch.utils.data.DataLoader(test_dataset, batch_size=batch_size, shuffle=False)\n",
    "\n",
    "# === Store losses & predictions ===\n",
    "train_losses = []\n",
    "\n",
    "# === Training Loop ===\n",
    "for epoch in range(epochs):\n",
    "    total_loss = 0\n",
    "    model.train()  # Set to training mode\n",
    "\n",
    "    for batch_x, batch_y in train_dataloader:\n",
    "        batch_x, batch_y = batch_x.to(device), batch_y.to(device)  # move batch to device.\n",
    "        optimizer.zero_grad()\n",
    "        batch_x_aug = augment_data(batch_x)\n",
    "        # Correct Forward Pass\n",
    "        depth_pred, params_pred, estimated_snow_depth_pred, contrastive_loss_value = model(batch_x, batch_x_aug)\n",
    "        loss_depth = criterion_depth(depth_pred, batch_y[:, -1, :])\n",
    "        loss_estimated_snow_depth = criterion_depth(estimated_snow_depth_pred, batch_y[:, -1, :])\n",
    "        contrastive_loss_value = torch.mean(contrastive_loss_value)  # Ensure scalar\n",
    "        loss = loss_depth + loss_estimated_snow_depth + contrastive_loss_value\n",
    "\n",
    "        # L1 Regularization\n",
    "        l1_lambda = 0.001  # Adjust lambda as needed\n",
    "        l1_norm = sum(p.abs().sum() for p in model.parameters())\n",
    "        loss += l1_lambda * l1_norm\n",
    "\n",
    "        #L2 Regularization\n",
    "        l2_lambda = 1e-5 #adjust lambda as needed.\n",
    "        l2_norm = sum(p.pow(2.0).sum() for p in model.parameters())\n",
    "        loss+= l2_lambda * l2_norm\n",
    "\n",
    "        # Backpropagation\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "\n",
    "        total_loss += loss.item()\n",
    "\n",
    "    # Store loss for visualization\n",
    "    train_losses.append(total_loss / len(train_dataloader))\n",
    "\n",
    "    # Print Progress Every 50 Epochs\n",
    "    if epoch % 50 == 0:\n",
    "        print(f\"Epoch {epoch}/{epochs}, Loss: {train_losses[-1]:.4f}\")\n",
    "\n",
    "# === After Training: Evaluate on Test Set ===\n",
    "model.eval()\n",
    "depth_predictions = []\n",
    "estimated_depth_predictions = []\n",
    "with torch.no_grad():\n",
    "    for batch_x, _ in test_dataloader:\n",
    "        batch_x = batch_x.to(device)\n",
    "        batch_x_aug = augment_data(batch_x)  # create augmented data.\n",
    "        depth_pred, params_pred, estimated_snow_depth, contrastive_loss_value = model(batch_x, batch_x_aug)  # unpack 4 values.\n",
    "        depth_predictions.append(depth_pred.cpu())\n",
    "        estimated_depth_predictions.append(estimated_snow_depth.cpu())\n",
    "\n",
    "# Convert Predictions to NumPy\n",
    "estimated_depth_predictions_np = torch.cat(estimated_depth_predictions).squeeze().numpy()\n",
    "depth_predictions_np = torch.cat(depth_predictions).squeeze().numpy()\n",
    "true_depths_np = y_test_tensor.cpu().squeeze().numpy()\n",
    "print(depth_predictions_np.shape)\n",
    "print(true_depths_np.shape)\n",
    "avg_pred = depth_predictions_np.mean(axis=1)\n",
    "avg_est = estimated_depth_predictions_np.mean(axis=1)\n",
    "avg_true = true_depths_np.mean(axis=1)\n",
    "# === Save Training Results ===\n",
    "torch.save(\n",
    "    {\n",
    "        \"epoch\": epochs,\n",
    "        \"model_state_dict\": model.state_dict(),\n",
    "        \"optimizer_state_dict\": optimizer.state_dict(),\n",
    "        \"train_losses\": train_losses,\n",
    "        \"depth_predictions_np\": depth_predictions_np,\n",
    "        \"estimated_depth_predictions_np\": estimated_depth_predictions_np,\n",
    "        \"true_depths_np\": true_depths_np,\n",
    "    },\n",
    "    \"BiLSTM-training_results.pth\",\n",
    ")\n",
    "print(\"Training results saved to training_results.pth\")\n",
    "\n",
    "# === Write to CSV file ===\n",
    "df = pd.DataFrame({\n",
    "    'avg_pred': avg_pred,\n",
    "    'avg_est': avg_est,\n",
    "    'avg_true': avg_true\n",
    "})\n",
    "\n",
    "# Write to a CSV file\n",
    "df.to_csv('BiLSTM-average_depths.csv', index=False)  # index=False prevents writing the row numbers to the CSV\n",
    "print(\"Data successfully written to average_depths.csv\")\n",
    "\n",
    "# === Plot Training Loss ===\n",
    "# === Plot all three in the same figure ===\n",
    "plt.figure(figsize=(8, 5))\n",
    "plt.plot(range(len(avg_true)), avg_true, label=\"True Depth\", marker='o', linestyle='-')\n",
    "\n",
    "plt.plot(\n",
    "    range(len(avg_est)),\n",
    "    avg_est,\n",
    "    label=\"Physics-Refined Depth (BiLSTM)\",\n",
    "    marker='s',\n",
    "    linestyle=\"-.\",\n",
    "    color=\"green\",\n",
    ")\n",
    "\n",
    "plt.xlabel(\"Sample Index\")\n",
    "plt.ylabel(\"Avg Snow Depth anomalies\")\n",
    "plt.title(\"Averaged Snow Depth Prediction\")\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "#plt.ylim(0, 1)  # Set y-axis limits between 0 and 1\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "bd7b3cfb-1188-4819-a748-882a768be28a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " Prediction:\n",
      "  MSE  = 0.5263\n",
      "  RMSE = 0.7255\n",
      "  Mean = 0.0153\n",
      "\n",
      "Physics-Refined Prediction:\n",
      "  MSE  = 0.5177\n",
      "  RMSE = 0.7195\n",
      "  Mean = 0.0046\n",
      "\n",
      "Ground Truth Mean:\n",
      "  Mean = 0.0152\n"
     ]
    }
   ],
   "source": [
    "# Arrays: shape (samples, timesteps)\n",
    "# depth_predictions_np         → LSTM prediction\n",
    "# estimated_depth_predictions_np → Physics-refined prediction\n",
    "# true_depths_np               → Ground truth\n",
    "\n",
    "from sklearn.metrics import mean_squared_error\n",
    "\n",
    "# === Overall metrics (flattened)\n",
    "mse = mean_squared_error(true_depths_np.flatten(), depth_predictions_np.flatten())\n",
    "rmse = np.sqrt(mse)\n",
    "mean = depth_predictions_np.mean()\n",
    "\n",
    "mse_phys = mean_squared_error(true_depths_np.flatten(), estimated_depth_predictions_np.flatten())\n",
    "rmse_phys = np.sqrt(mse_phys)\n",
    "mean_phys = estimated_depth_predictions_np.mean()\n",
    "\n",
    "mean_true = true_depths_np.mean()\n",
    "\n",
    "print(\" Prediction:\")\n",
    "print(f\"  MSE  = {mse:.4f}\")\n",
    "print(f\"  RMSE = {rmse:.4f}\")\n",
    "print(f\"  Mean = {mean:.4f}\\n\")\n",
    "\n",
    "print(\"Physics-Refined Prediction:\")\n",
    "print(f\"  MSE  = {mse_phys:.4f}\")\n",
    "print(f\"  RMSE = {rmse_phys:.4f}\")\n",
    "print(f\"  Mean = {mean_phys:.4f}\\n\")\n",
    "\n",
    "print(\"Ground Truth Mean:\")\n",
    "print(f\"  Mean = {mean_true:.4f}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "2bc59f1e-c033-4498-901a-dfdebfd957a9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "RMSE values saved to rmse_values.csv\n"
     ]
    },
    {
     "data": {
      "image/png": "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JcFh7rdb9WzCFlk9Tt0Ea5vNpoiICEVHR+uGG27QqFGj9NFHH0kqG1K0aNEitW7dWjabTQ6HQ+np6br11lsVFhamoKAgXXDBBfrjjz9crvvPf/5T4eHhCgwM1IQJE5SXl+fy+rHDk+x2u55++mm1bdtWNptNLVq00KxZsyRJMTExkqRu3brJYrHo/PPPd563ePFixcbGysfHRx07dtT8+fNd7vPrr7+qW7du8vHxUXx8vNauXVutz8XPz08RERFq0aKFrr76al188cX6+uuvK9QbO3asli5dqtzcXGfZokWLNHbsWJd6CQkJioyM1Jw5c9SlSxe1adNGl1xyiV599VV5e3u71A0LC1NERITL4eFR9VfEpUuX6vLLL69QXvpvGxERoa5du+rBBx/Unj17dPDgQUk178H59NNPdfvtt+vaa69VTEyMzjnnHE2YMEFTpkyRJJf2BgcHy2KxVCir6ecmSWeddZYiIiL04YcfVqudZwpCAwAAp4mcgqIqj7zCYme9SRe2010XtNWzCVv0zNeblVNQpGe+3qxnE7borgva6tb+rat13drg6+vr0qOwbds2vfPOO3r//fedXy6HDh2qlJQULV++XImJierevbsuvPBCHTlyRJL0zjvv6LHHHtOsWbO0Zs0aRUZGVvgyf6ypU6fq6aef1qOPPqqNGzfqrbfeUnh4uCTji78kffPNN0pOTtYHH3wgSXrllVc0bdo0zZo1S5s2bdJTTz2lRx99VP/3f/8nScrOztZll12mDh06KDExUY8//niVvShm/vjjD/3444/y8vKq8FpcXJxiYmL0/vvvS5L27NmjlStXavTo0S71IiIilJycrJUrV9b4/maOHj2q9evXKz4+3rReVlaW3nzzTbVt2/aE9xKJiIjQihUrnKHjZFT3cyvVs2dPrVq16qTvezphczcAAE4TnaZ/VeVrAzuEavFNPZ3PX121U5I0b8U2zVuxzVk+b8U2/brziJb9o4+zrO/T/9OR7IIK19z1z6En1d5ff/1Vb731li688EJnWUFBgf773/8qNDRUkrRixQqtW7dOqampstlskqR///vf+uijj/Tee+/p1ltv1fPPP6/x48fr5ptvliTNnDlT33zzTYXehlKZmZl64YUX9OKLLzr/0tymTRv17dtXkpz3DgkJUUREhPO8J598Us8884yuuuoqSUaPxMaNG/Xyyy9r7NixevPNN1VcXKxFixbJz89PnTt31t69e3Xbbbcd97OYP3++Xn31VRUWFqqgoEAeHh566aWXKq170003adGiRbrxxhu1ePFiXXrppc42l7r22mv11VdfacCAAYqIiFDv3r114YUXasyYMQoKCnKp27x5c5fnzZo10+bNmyu9999//y2Hw6GoqKgKr3322WfO4T7Z2dmKjIzUZ599ZtprYebZZ5/VNddco4iICHXu3FnnnnuurrjiCg0ZMuSErledz61Us2bNqt1LdKagpwEAANSZ0i+WPj4+6tOnj/r376958+Y5X2/ZsqXLF7nExERlZWUpJCREAQEBzmPnzp3avn27JGnTpk3q06ePy32OfV7epk2blJ+f7xJWjufgwYPas2ePJkyY4NKOmTNnurTjnHPOcdl0z6wd5Y0aNUpJSUn66aefdN1112n8+PG6+uqrK61744036qefftKOHTu0ZMkSjR8/vkIdq9WqxYsXa+/evZozZ46ioqI0a9Ysde7cWcnJyS51V61apaSkJOfx1VdVh8/S4T0+Pj4VXhs4cKDzGr/88osGDRqkIUOG6O+//67WZ3CsTp06af369fr5559100036cCBAxo2bJgzHNZUdT63Ur6+vsrJyTmh+5yu6GkAAOA0sfGJwVW+5nHMBk+Jj16kBd9t17wV2+Rltaiw2KG7Lmir285vU6HuDw8OrLU2Dhw4UAsWLJCXl5eioqIqDMHx9/d3eW632xUZGemyKlCpE53Y7OvrW+NzSicPv/LKK+rVq5fLa1arVZLkcDhOqD2SMVG7bdu2kqQ33nhDnTt31muvvaYJEyZUqBsSEqLLLrvMOXdjyJAhyszMrPS6zZo10+jRozV69GjNnDlT7du313/+8x/NmDHDWScmJqban2XTpk0lGcOUjv0rvb+/v/M9SMaQoODgYL3yyiuaOXNmta5/LA8PD/Xo0UM9evTQPffcozfeeEOjR4/WtGnTnHNPqqsmn9uRI0eq7IU4U9HTAADAacLP27PKw8fL6lL31VU7NW/FNk25uL22zrpUUy5ur3krtunVVTsr1K3qmiei9Itly5YtKx2zf6zu3bsrJSVFnp6eatu2rctR+gU2Nja2wnKaxz4vr127dvL19dW3335b6eulE4WLi8vmgYSHh6tZs2basWNHhXaUfnnt1KmT/vjjD5fJtmbtqIqXl5cefvhhPfLII1X+tXv8+PH67rvvNGbMGGdoOZ7GjRsrMjLypJa4bdOmjYKCgrRx48bj1rVYLPLw8HD5PE5Wp06dJOmE30N1P7f169erW7duJ3SP0xU9DQAAnGFKV0macnF7TbqwnSQ5H58tWW619Lm7XXTRRerTp4+GDx+up59+Wh06dND+/fu1fPlyDR8+XPHx8br77rs1duxYxcfHq2/fvnrzzTe1YcMGtW7dutJr+vj46MEHH9QDDzwgb29vnXfeeTp48KA2bNigCRMmKCwsTL6+vvryyy/VvHlz+fj4KDg4WI8//rgmTZqkoKAgDRkyRPn5+VqzZo2OHj2qKVOm6IYbbtC0adM0YcIEPfLII9q1a5f+/e9/n9D7vuGGG/Twww9XuSTtJZdcooMHD1aYn1Dq5ZdfVlJSkq688kq1adNGeXl5ev3117VhwwaX4WCSsaHZsfM/QkJCKg11Hh4euuiii/TDDz9U2CwvPz/fub/D0aNH9eKLLyorK0vDhg0zfa+VzZ/o1KmTbrjhBp133nk699xzFRERoZ07d2rq1Klq3769OnbsaHrNqhzvc5OknJwcJSYm6qmnnjqhe5yuCA0AAJxhiu0Ol8BQqvR5sf3Eh9nUNovFouXLl2vatGkaP368Dh48qIiICPXv39+52tH111+v7du368EHH1ReXp6uvvpq3XbbbaZj8x999FF5enpq+vTp2r9/vyIjIzVx4kRJkqenp+bOnasnnnhC06dPV79+/fTdd9/p5ptvlp+fn/71r3/pgQcekL+/v8466yxNnjxZkhQQEKBPP/1UEydOVLdu3dSpUyc9/fTTVc5NMOPt7a0777xTc+bM0cSJEyvsJ2CxWJw9LZXp2bOnfvjhB02cOFH79+9XQECAOnfurI8++kgDBgxwqduhQ4cK5//000/q3bt3pde+9dZbNWHCBM2ZM8dlkvOXX36pyMhISVJgYKA6duyod99912XJ2sqMGDGiQtnOnTs1ePBgvf3225o9e7bS09MVERGhCy64QI8//ni193o41vE+N0n6+OOP1aJFC/Xr1++E7nG6sjhOZgBeA5SRkaHg4GClp6ebpkwAAOqrvLw87dy5UzExMZVOSAVOJYfDod69e2vy5MkaOXKku5tT63r27KnJkyfrhhtucHdTaoXZfy9q8r2YOQ0AAACoNovFooULF6qoqHb26qhPUlNTdc0115yWYehkMTwJAAAANXLOOefonHPOcXczal1YWJgeeOABdzejXqKnAQAAAIApQgMAAAAAU4QGAAAAAKYIDQAAAABMERoAAAAAmCI0AAAAADBFaAAAAABgitAAAADqhe+++04Wi0VpaWmn5Pq7du2SxWJRUlLSKbl+bUlJSdHFF18sf39/NWrUSJKxodpHH310yu/dqlUrPf/886f8PnVpxYoV6tixo+x2e43OawifRY8ePfTBBx/Uyb0IDQAAnGnS9kj7k6o+0vacktuOGzdOFotFFotFXl5eat26te677z5lZ2efkvsdKzo6WsnJyerSpcspuf7jjz/ufH8eHh6KiorSqFGjtGdPzT7P5557TsnJyUpKStKWLVskScnJyRoyZMipaHaNVPc9nn/++bJYLPrnP/9Z4RqXXnqpLBaLHn/8cWfZjh07NHLkSEVFRcnHx0fNmzfXFVdc4Xz/kpz3PfZYunSpaZsfeOABTZs2TR4extfeJUuWuJwfEBCguLi4Cl++f/vtN916663O58cLEe+//7569eql4OBgBQYGqnPnzrr33ntdPo+qjlatWp3Q5/boo4/qoYceqnEgOhHsCA0AwJkkbY/0YpxUlF91HU+bdGei1Ci61m9/ySWXaPHixSosLNSqVat08803Kzs7WwsWLKj1ex3LarUqIiLilN6jc+fO+uabb2S327V9+3bdcccduu666/TTTz9V+xrbt29XXFyc2rVr5yw71e2uieq+x+joaC1evFgPPfSQs2z//v1asWKFIiMjnWUFBQW6+OKL1bFjR33wwQeKjIzU3r17tXz5cqWnp7tcc/Hixbrkkktcykp7YyqzevVqbd26Vddee61LeVBQkDZv3ixJyszM1OLFi3Xddddpw4YN6tChgyQpNDS02p/JN998oxEjRuipp57S5ZdfLovFoo0bN+rbb7+VJH3wwQcqKCiQJO3Zs0c9e/bUN998o86dO0syfjdLVfdzk6ShQ4fqlltu0VdffXXKQyU9DQAAnElyDpsHBsl4PefwKbm9zWZTRESEoqOjdcMNN2jUqFEVht0kJiYqPj5efn5+Ovfcc51f7nbt2iUPDw+tWbPGpf68efPUsmVLORwOHT16VKNGjVJoaKh8fX3Vrl07LV682Hn+scOTNmzYoKFDhyooKEiBgYHq16+ftm/fLskYLtWzZ0/nMKHzzjtPf//9t+n78/T0VEREhKKiotSvXz/dcsst+vnnn5WRkeGs8+mnnyouLk4+Pj5q3bq1ZsyYoaKiIknGX7Pff/99vf7667JYLBo3bpwk1+FJpe/jgw8+0MCBA+Xn56dzzjmnwpf21atXq3///vL19VV0dLQmTZrk0quTmpqqYcOGydfXVzExMXrzzTdN31tN3qMkXXbZZTp8+LB+/PFHZ9mSJUs0aNAghYWFOcs2btyoHTt2aP78+erdu7datmyp8847T7NmzVKPHj1crtmoUSNFRES4HD4+PlW2denSpRo0aFCFOhaLxXl+u3btNHPmTHl4eOjPP/901qnJ8KTPPvtMffv21f33368OHTqoffv2Gj58uObNmydJatKkifN+pWEkJCSkQllNPjfJCBuXXnqp3n777Wq182QQGgAAOF0UZB//KMqtvevWAl9fXxUWFrqUTZs2Tc8884zWrFkjT09PjR8/XpLxJe6iiy5yhoBSixcvdg59evTRR7Vx40Z98cUX2rRpkxYsWKCmTZtWeu99+/apf//+8vHx0YoVK5SYmKjx48erqKhIRUVFGj58uAYMGKA///xTP/30k2699VZZLJZqv7eUlBR98MEHslqtzr8kf/XVV7rxxhs1adIkbdy4US+//LKWLFmiWbNmSTKGxFxyySW67rrrlJycrBdeeKHK60+bNk333XefkpKS1L59e40cOdIZPtatW6fBgwfrqquu0p9//qlly5bphx9+0J133uk8f9y4cdq1a5dWrFih9957T/Pnz1dqamq1319V77GUt7e3Ro0a5fLvtWTJEue/Z6nQ0FB5eHjovffeU3FxcY3ufzwrV65UfHy8aZ3i4mL93//9nySpe/fuJ3SfiIgIbdiwQevXrz+h88ur7udWqmfPnlq1atVJ3/d4GJ4EAMDp4qmoU3Pd58+qvOfh8fSKZTXw66+/6q233tKFF17oUj5r1iwNGDBAkvTQQw9p6NChysvLk4+Pj26++WZNnDhRzz77rGw2m/744w8lJSU5x6Pv3r1b3bp1c35RLB0rXpmXXnpJwcHBWrp0qby8vCRJ7du3lyQdOXJE6enpuuyyy9SmTRtJUmxs7HHf07p16xQQECC73a7cXCOgTZo0Sf7+/s739tBDD2ns2LGSpNatW+vJJ5/UAw88oMcee0yhoaGy2Wzy9fU97pCk++67T0OHDpUkzZgxQ507d9a2bdvUsWNH/etf/9INN9ygyZMnS5LatWunuXPnasCAAVqwYIF2796tL774Qj///LN69eolSXrttddq5T2WN2HCBPXt21cvvPCCEhMTlZ6erqFDh7qMy2/WrJnmzp2rBx54QDNmzFB8fLwGDhyoUaNGqXXr1i7XGzlyZIVw8ueff1aoV2rXrl2Kiqr4v4v09HQFBARIknJzc+Xl5aWFCxc6/61r6q677tKqVat01llnqWXLlurdu7cGDRqkUaNGyWaz1fh61fncSjVr1ky7d++W3W53zts4FehpAAAAdeazzz5TQECAfHx81KdPH/Xv3985hKPU2Wef7fy5dAx36V/Ahw8fLk9PT3344YeSpEWLFmngwIHOcHDbbbdp6dKl6tq1qx544AGtXr26yrYkJSWpX79+zsBQXpMmTTRu3DgNHjxYw4YN0wsvvKDk5GRJRjAJCAhwHk899ZTzvA4dOigpKUm//fabZs2apa5duzp7ESRj6NUTTzzhcv4tt9yi5ORk5eTk1OSjNP2cEhMTtWTJEpf7DB48WHa7XTt37tSmTZvk6enp8lf4jh07ms4PqO57PLaN7dq103vvvadFixZp9OjRlX7ed9xxh1JSUvTGG2+oT58+evfdd9W5c2clJCS41HvuueeUlJTkckRHVz33Jjc3t9LhS4GBgc7z165dq6eeekr/+Mc/9Omnnx73/VfG399fn3/+ubZt26ZHHnlEAQEBuvfee9WzZ88a/7tK1f/cJKO3zm63Kz//OMMOTxI9DQAAnC4e3n/8Oil/SosuOX698iavO7H2VGLgwIFasGCBvLy8FBUVVekXofJlpcOBSleH8fb21ujRo7V48WJdddVVeuutt1zGnQ8ZMkR///23Pv/8c33zzTe68MILdccdd+jf//53hfv4+vqatnXx4sWaNGmSvvzySy1btkyPPPKIEhISFB8f7zIvokmTJs6fvb291bZtW0nGhOGtW7fqtttu03//+1/n+5gxY4auuuqqCvczG5tfGbPPyW636x//+IcmTZpU4bwWLVo454nUZLhVqeO9x2ONHz9eL730kjZu3Khff/21yusGBgbq8ssv1+WXX66ZM2dq8ODBmjlzpi6++GJnnYiICOe9q6Np06Y6evRohXIPDw+X65x99tn6+uuv9fTTT2vYsGHVvv6x2rRpozZt2ujmm2/WtGnT1L59ey1btkw33XRTja9V3c/tyJEj8vPzO+7v88mipwEAgNOFt//xD88T+GJR1bVOgL+/v9q2bauWLVtW+ZfT47n55pv1zTffaP78+SosLKzwBTw0NFTjxo3TG2+8oeeff14LFy6s9Dpnn322Vq1aVWFORXndunXT1KlTtXr1anXp0kVvvfWWPD091bZtW+dRPjQc69FHH9Xbb7+t33//XZIxZn7z5s0u55cetTm0pHv37tqwYUOl9/H29lZsbKyKiopcJpVv3rz5hPbIOPY9HuuGG27QunXr1KVLF3Xq1Kla17RYLOrYseNJL8fbrVs3bdy4sVp1rVarc7hVbWjVqpX8/PxO+D1U93Nbv379Cc/FqAl6GgAAQIMSGxur3r1768EHH9T48eNd/sI6ffp0xcXFqXPnzsrPz9dnn31W5Tj9O++8U/PmzdOIESM0depUBQcH6+eff1bPnj3l7e2thQsX6vLLL1dUVJQ2b96sLVu2aMyYMTVqa+vWrXXFFVdo+vTp+uyzzzR9+nRddtllio6O1rXXXutcsWfdunWaOXPmSX0u5T344IPq3bu37rjjDt1yyy3y9/fXpk2blJCQoHnz5qlDhw665JJLdMstt2jhwoXy9PTU5MmTT+iv1ce+x2M1btxYycnJVYbEpKQkPfbYYxo9erQ6deokb29vff/991q0aJEefPBBl7ppaWlKSUlxKQsMDKx0PoUkDR482DnJuTyHw+G8Tm5urhISEvTVV19p+vTppu913759FTYHbNGihebOnaucnBxdeumlatmypdLS0jR37lwVFha69JTUxPE+t1KrVq3SoEGDTugeNUFPAwAAZxK/EGMfBjOeNqNePTZhwgQVFBRUWFHG29tbU6dO1dlnn63+/fvLarVWuflXSEiIVqxYoaysLA0YMEBxcXF65ZVX5OXlJT8/P/3111+6+uqr1b59e916662688479Y9//KPGbb333nv1+eef65dfftHgwYP12WefKSEhQT169FDv3r317LPPqmXLlif0OVTl7LPP1vfff6+tW7eqX79+6tatmx599FGXdf4XL16s6OhoDRgwQFdddZVuvfXWCkt6Vlf591iZRo0aVfnFvnnz5mrVqpVmzJihXr16qXv37nrhhRc0Y8YMTZs2zaXuTTfdpMjISJfj2Dkx5d14443a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WOPGjavbxqDBO//881lyFdXy2WefaerUqdq6datiYmI0ZcoU3XLLLe5uFhqAzMxMPfroo/rwww+VmpqqqKgojRw5UtOnT5e3t7e7m4cTQGgAAAAAYIo5DQAAAABMERoAAAAAmCI0AAAAADBFaAAAAABgitAAAAAAwBShAQAAAIApQgMAAAAAU4QGAAAAAKYIDQCAU+Lxxx9X165d3d0MAEAtYEdoAECNWSwW09fHjh2rF198Ufn5+QoJCamjVgEAThVCAwCgxlJSUpw/L1u2TNOnT9fmzZudZb6+vgoODnZH0wAApwDDkwAANRYREeE8goODZbFYKpQdOzxp3LhxGj58uJ566imFh4erUaNGmjFjhoqKinT//ferSZMmat68uRYtWuRyr3379un6669X48aNFRISoiuuuEK7du2q2zcMAGc4QgMAoM6sWLFC+/fv18qVK/Xss8/q8ccf12WXXabGjRvrl19+0cSJEzVx4kTt2bNHkpSTk6OBAwcqICBAK1eu1A8//KCAgABdcsklKigocPO7AYAzB6EBAFBnmjRporlz56pDhw4aP368OnTooJycHD388MNq166dpk6dKm9vb/3444+SpKVLl8rDw0OvvvqqzjrrLMXGxmrx4sXavXu3vvvuO/e+GQA4g3i6uwEAgDNH586d5eFR9veq8PBwdenSxfncarUqJCREqampkqTExERt27ZNgYGBLtfJy8vT9u3b66bRAABCAwCg7nh5ebk8t1gslZbZ7XZJkt1uV1xcnN58880K1woNDT11DQUAuCA0AADqre7du2vZsmUKCwtTUFCQu5sDAGcs5jQAAOqtUaNGqWnTprriiiu0atUq7dy5U99//73uvvtu7d27193NA4AzBqEBAFBv+fn5aeXKlWrRooWuuuoqxcbGavz48crNzaXnAQDqEJu7AQAAADBFTwMAAAAAU4QGAAAAAKYIDQAAAABMERoAAAAAmCI0AAAAADBFaAAAAABgitAAAAAAwBShAQAAAIApQgMAAAAAU4QGAAAAAKYIDQAAAABMERoAAAAAmPp/Dr8X45EEqf0AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 800x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Compute RMSE at each time step\n",
    "rmse_lstm_per_t = np.sqrt(np.mean((depth_predictions_np - true_depths_np) ** 2, axis=0))\n",
    "rmse_phys_per_t = np.sqrt(\n",
    "    np.mean((estimated_depth_predictions_np - true_depths_np) ** 2, axis=0)\n",
    ")\n",
    "\n",
    "# Create DataFrame for RMSE values\n",
    "rmse_df = pd.DataFrame({'rmse_lstm_per_t': rmse_lstm_per_t, 'rmse_phys_per_t': rmse_phys_per_t})\n",
    "# save to csv\n",
    "rmse_df.to_csv('BiLSTM-rmse_values.csv', index=False)\n",
    "print(\"RMSE values saved to rmse_values.csv\")\n",
    "\n",
    "# Plot RMSE per timestep\n",
    "plt.figure(figsize=(8, 5))\n",
    "plt.plot(\n",
    "    rmse_lstm_per_t, label=\"Predicted RMSE (BiLSTM)\", marker=\"x\", linestyle=\"--\"\n",
    ")\n",
    "plt.plot(\n",
    "    rmse_phys_per_t,\n",
    "    label=\"Physics-Refined RMSE (BiLSTM)\",\n",
    "    marker=\"s\",\n",
    "    linestyle=\"-.\",\n",
    ")\n",
    "\n",
    "plt.xlabel(\"Time\")\n",
    "plt.ylabel(\"RMSE\")\n",
    "plt.title(\"RMSE\")\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "plt.ylim(0, 1)  # set the ylim 0 to 1\n",
    "plt.show()\n",
    "\n",
    "\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "myenv",
   "language": "python",
   "name": "myenv"
  },
  "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.11.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
