{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 7,
   "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": 8,
   "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": 9,
   "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",
    "# \"asn\" = snow albedo, \"rsn\" = snow density, \"siconc\" = sea ice concentration\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": 10,
   "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",
    "# === Attention Block ===\n",
    "# === Multihead Self-Attention Wrapper ===\n",
    "class MultiHeadSelfAttention(nn.Module):\n",
    "    def __init__(self, hidden_dim, num_heads=2):\n",
    "        super(MultiHeadSelfAttention, self).__init__()\n",
    "        self.attn = nn.MultiheadAttention(embed_dim=hidden_dim, num_heads=num_heads, batch_first=True)\n",
    "        self.norm = nn.LayerNorm(hidden_dim)\n",
    "        self.dropout = nn.Dropout(0.2)\n",
    "\n",
    "    def forward(self, x):\n",
    "        attn_output, _ = self.attn(x, x, x)\n",
    "        out = self.norm(x + self.dropout(attn_output))  # Residual + Norm\n",
    "        return out\n",
    "\n",
    "# === Bayesian LSTM + Multi-Head Attention ===\n",
    "class LSTMContrastiveWithAttention(nn.Module):\n",
    "    def __init__(self, input_dim=1, hidden_dim=64, num_layers=2, output_dim=1, dropout_rate=0.4, num_heads=4):\n",
    "        super().__init__()\n",
    "        self.encoder_lstm = nn.LSTM(input_dim, hidden_dim, num_layers, batch_first=True, dropout=dropout_rate)\n",
    "        self.attention = MultiHeadSelfAttention(hidden_dim, num_heads=num_heads)\n",
    "        self.decoder_lstm = nn.LSTM(hidden_dim, hidden_dim, num_layers, batch_first=True, dropout=dropout_rate)\n",
    "\n",
    "        self.fc_depth = nn.Linear(hidden_dim, output_dim)\n",
    "        self.fc_params = nn.Sequential(\n",
    "            nn.Linear(hidden_dim, 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 sequence\n",
    "        enc_x, (h_x, c_x) = self.encoder_lstm(x)\n",
    "        attn_x = self.attention(enc_x)\n",
    "        dec_x, _ = self.decoder_lstm(attn_x, (h_x, c_x))\n",
    "\n",
    "        # === Augmented sequence\n",
    "        enc_aug, (h_aug, c_aug) = self.encoder_lstm(x_aug)\n",
    "        attn_aug = self.attention(enc_aug)\n",
    "        dec_aug, _ = self.decoder_lstm(attn_aug, (h_aug, c_aug))\n",
    "\n",
    "        # === Depth Prediction\n",
    "        depth_pred = self.fc_depth(dec_x).squeeze(-1)\n",
    "\n",
    "        # === Parameter Estimation\n",
    "        last_out = dec_x[:, -1, :]\n",
    "        params_pred = self.fc_params(last_out)\n",
    "        w_raw, b_raw, c_raw = params_pred[:, 0:1], params_pred[:, 1:2], params_pred[:, 2:3]\n",
    "\n",
    "        w = torch.sigmoid(w_raw) * 2.0 - 1.0\n",
    "        b = torch.exp(b_raw)\n",
    "        c = torch.tanh(c_raw) * 10.0\n",
    "\n",
    "        mean_density = x[:, :, 0].mean(dim=1, keepdim=True)\n",
    "        w_exp = w.expand_as(depth_pred)\n",
    "        b_exp = b.expand_as(depth_pred)\n",
    "        c_exp = c.expand_as(depth_pred)\n",
    "        mean_density_exp = mean_density.expand_as(depth_pred)\n",
    "\n",
    "        estimated_snow_depth = w_exp * mean_density_exp + b_exp * depth_pred + c_exp\n",
    "\n",
    "        contrastive_loss_val = contrastive_loss(dec_x[:, -1, :], dec_aug[:, -1, :]).mean()\n",
    "\n",
    "        return depth_pred, params_pred, estimated_snow_depth, contrastive_loss_val"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "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_221125/2700612979.py:72: 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_221125/2700612979.py:77: 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: 8.7343\n",
      "Epoch 50/500, Loss: 3.3442\n",
      "Epoch 100/500, Loss: 3.2551\n",
      "Epoch 150/500, Loss: 3.2123\n",
      "Epoch 200/500, Loss: 3.1940\n",
      "Epoch 250/500, Loss: 3.1959\n",
      "Epoch 300/500, Loss: 3.1971\n",
      "Epoch 350/500, Loss: 3.1615\n",
      "Epoch 400/500, Loss: 3.1656\n",
      "Epoch 450/500, Loss: 3.1564\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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h2PGjBnVHmZVHevXr8euXbtw8ODBGj/33bt3YWNjg/Pnz6NLly41fn5VsHfvXnzxxRe4fPkytLTKHrn6ur+fqmPR3gRsPFFx9u5vPu4CT0dZhWWIiKjuVfTMW5kGMYfi3LlzOHfuHN555x00btwYt27dwvz589G6dWuFoQgODg4ICQnBe++9B4lEghkzZmDx4sWws7ODnZ0dFi9eDKlUitGjR9fj3fzD2tha5QOG8jx//hyJiYkIDQ3FwoUL67s61MCMHz8eT548wbNnz2psCee8vDykpaVhzpw56N69u9oGEwCQlZWFsLCwcoOJ+jLXqx06WzXGrN8v43luvsK+xlJthHh3YDBBRKSGVOuvUTn09fWxfft2BAUFISsrCzKZDJ6enoiMjISurq5YLikpCRkZGeL7WbNm4cWLF5g8eTKePHmCbt264dChQ7Weg+JN4O/vj23btmH48OGlhjsRVUZLSwtz586t0XOeOnUK7u7usLe3x2+//Vaj51Y1xXk2VNEgJxkGOFrg7M1HOHPrIQAJXFs3RfdWTTkRm4hITTXYIU91pTaHPBER1Rb+fiIioqp4nSFPDSaxHRERERERqR4GFEREREREVG0MKGoAR40Rkarh7yUiIqorDCheQ3FW5+zs7HquCRGRopcvXwIANDU167kmRESk7hrEKk+qSlNTEyYmJkhPTwdQlBysoizcRER1obCwEA8ePIBUKlW5pWWJiEj98C/NayrOyF0cVBARqQINDQ1YW1vzSw4iIqp1DChek0QigUwmQ7NmzZCXl1ff1SEiAgDo6OhAQ4OjWomIqPYxoKghmpqaHKtMRERERG8cfn1FRERERETVxoCCiIiIiIiqjQEFERERERFVG+dQVKI4OVRmZmY914SIiIiIqHYUP+tWJzEqA4pKPHv2DABgZWVVzzUhIiIiIqpdz549g7GxcZWOkQjVCUPeIIWFhUhNTYWRkVG9rOeemZkJKysr3L17F40aNarz61P1sN0aJrZbw8R2a5jYbg0X265hqqzdBEHAs2fPYGlpWeVlx9lDUQkNDQ20aNGivquBRo0a8T9tA8R2a5jYbg0T261hYrs1XGy7hqmidqtqz0QxTsomIiIiIqJqY0BBRERERETVxoBCxenq6iIoKAi6urr1XRWqArZbw8R2a5jYbg0T263hYts1TLXZbpyUTURERERE1cYe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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",
    "import numpy as np\n",
    "import pandas as pd\n",
    "\n",
    "# === Device Setup ===\n",
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "\n",
    "# === Initialize Model & Optimizer ===\n",
    "model = LSTMContrastiveWithAttention()  # 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(\n",
    "    train_dataset, batch_size=batch_size, shuffle=True\n",
    ")\n",
    "\n",
    "test_dataset = torch.utils.data.TensorDataset(X_test_tensor, y_test_tensor)\n",
    "test_dataloader = torch.utils.data.DataLoader(\n",
    "    test_dataset, batch_size=batch_size, shuffle=False\n",
    ")\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(\n",
    "            device\n",
    "        )  # move batch to device.\n",
    "        optimizer.zero_grad()\n",
    "        batch_x_aug = augment_data(batch_x)\n",
    "        # Correct Forward Pass\n",
    "        (\n",
    "            depth_pred,\n",
    "            params_pred,\n",
    "            estimated_snow_depth_pred,\n",
    "            contrastive_loss_value,\n",
    "        ) = model(batch_x, batch_x_aug)\n",
    "        loss_depth = criterion_depth(depth_pred, batch_y[:, -1, :])\n",
    "        loss_estimated_snow_depth = criterion_depth(\n",
    "            estimated_snow_depth_pred, batch_y[:, -1, :]\n",
    "        )\n",
    "        contrastive_loss_value = torch.mean(\n",
    "            contrastive_loss_value\n",
    "        )  # 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(\n",
    "            batch_x\n",
    "        )  # create augmented data.\n",
    "        (\n",
    "            depth_pred,\n",
    "            params_pred,\n",
    "            estimated_snow_depth,\n",
    "            contrastive_loss_value,\n",
    "        ) = model(\n",
    "            batch_x, batch_x_aug\n",
    "        )  # 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 = (\n",
    "    torch.cat(estimated_depth_predictions).squeeze().numpy()\n",
    ")\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",
    "\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",
    "    \"PhysCL-Inv-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('PhysCL-Inv-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 (PhysCL-Inv)\",\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()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "bd7b3cfb-1188-4819-a748-882a768be28a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " Prediction:\n",
      "  MSE  = 0.3942\n",
      "  RMSE = 0.6278\n",
      "  Mean = 0.0193\n",
      "\n",
      "Physics-Refined Prediction:\n",
      "  MSE  = 0.3568\n",
      "  RMSE = 0.5973\n",
      "  Mean = -0.0022\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": 13,
   "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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WxQREaGAgACdf/752rhxo911//WvfykyMlL+/v666aabVFBQYPf+sd2TysrK9NRTT6lt27by9PRUixYtNGfOHElSXFycJKlnz54ymUwaPHiw7bylS5eqU6dO8vLyUseOHbVw4UK7+/zyyy/q2bOnvLy8FB8frw0bNtTq++Lj46OoqCi1aNFCV199tS644AJ99dVXDuUmTJigFStWKD8/33ZsyZIlmjBhgl25hIQERUdHa968eeratavatGmjiy66SK+++qo8PDzsykZERCgqKspuM5tr/vi2YsUKXX755Q7Hnf1sKyQmJio+Pl4+Pj7q37+/tm3bJsnaumM2m7V+/Xq78gsWLFDLli1lGIaOHj2qsWPHKjw8XN7e3mrXrp0tQO3fv1/Tpk3TtGnTtGTJEg0ePFitWrXSwIED9eqrr2rWrFk1Pk9dmUwmvfrqq7ryyittLTgff/yxJOvvVfPmzfXSSy/ZnfPbb7/JZDJp586dkqTQ0FD1799fb731Vr3V63RAaAAAoAHkFZXUuBUUl9rKTRvaTv88v63mJ2zX019tU15RiZ7+apvmJ2zXP89vq1sGtq7VdeuDt7e3XYvCX3/9pbffflvvvfeerXvQJZdcopSUFH322WdKTExUr169NHToUKWnp0uS3n77bT3yyCOaM2eO1q9fr+joaIcP88eaMWOGnnrqKT388MPasmWLli9frsjISEnWD/6S9PXXXys5OVnvv/++JOmVV17RzJkzNWfOHG3dulVPPvmkHn74Yf3nP/+RJOXm5urSSy9Vhw4dlJiYqEcfffSE/tK+ceNG/fDDD3J3d3d4r3fv3oqLi9N7770nSdq3b5/WrFmjcePG2ZWLiopScnKy1qxZU+f7O3P06FH98ccfio+PP27ZY3+2kjRz5kw9/fTTWr9+vdzc3DRp0iRJ1i5Aw4YNc2hFWbp0qa3rU8XP6vPPP9fWrVu1aNEihYWFSZLeeecdFRUV6b777qu2LvXdyjR79myNGjVKv//+uy6++GKNHTtW6enpMpvNGj16tN5880278suXL1e/fv3UunXlf1t9+vTR2rVr67VeTR2LuwEA0AA6z/qyxveGdAjX0hv72PZfXbtLkrRg1V9asOov2/EFq/7SL7vStfIf/WzHznvqW6XnFjlcc/e/Ljmp+v7yyy9avny5hg4dajtWVFSk//73vwoPD5ckrVq1Sps2bVJqaqo8PT0lSf/+97/14Ycf6t1339Utt9yiZ599VpMmTdLkyZMlSU888YS+/vprh9aGCtnZ2Xruuef0wgsv2P5C36ZNG5133nmSZLt3aGiooqKibOc9/vjjevrpp3XVVVdJsrZIbNmyRYsXL9aECRP05ptvqrS0VEuWLJGPj4+6dOmi/fv369Zbbz3u92LhwoV69dVXVVxcrKKiIpnNZr344ovVlr3xxhu1ZMkS3XDDDVq6dKkuvvhiW50rXHvttfryyy81aNAgRUVFqW/fvho6dKjGjx+vgIAAu7LNmze322/WrJmtBeBYe/bskWEYiomJcfo81f1sJWnOnDkaNGiQJOmBBx7QJZdcooKCAnl5eWny5MmaMmWK5s+fL09PT23cuFFJSUm20LZ371717NnTFliqdo/asWOHAgICTnpF4tqaOHGixowZI0l68skntWDBAv3yyy+66KKLNHbsWM2fP1979uxRy5YtVVZWphUrVtiNAZGs3+fdu3c3SH2bCloaAACAJOmTTz6Rn5+fvLy81K9fPw0cOFALFiywvd+yZUu7D8CJiYnKyclRaGio/Pz8bNuuXbv0999/S5K2bt2qfv362d3n2P2qtm7dqsLCQocPtM4cPnxY+/bt00033WRXjyeeeMKuHt27d7dbdM9ZPaoaO3askpKS9OOPP2rUqFGaNGmSrr766mrL3nDDDfrxxx+1c+dOLVu2zPbX+qosFouWLl2q/fv3a968eYqJidGcOXPUpUsXJScn25Vdu3atkpKSbNuXX9YcPiu6RXl5eTm8d7yfrSR169bN9rriA35qaqokaeTIkXJzc9MHH3wgydrtasiQIbZwcOutt2rFihXq0aOH7rvvPq1bt852LcMwTnqtgCeffNLuZ7t3794ay1Z9Dl9fX/n7+9ueo2fPnurYsaOt69Hq1auVmpqqUaNG2V3D29tbeXl5J1Xn0w0tDQAANIAtj11Y43vmYz5QJT48TIu++1sLVv0ld4tJxaWG/nl+W906uI1D2e/vH1JvdRwyZIgWLVokd3d3xcTEOHTB8fX1tdsvKytTdHS03axAFU60y4m3t3edz6kYPPzKK6/onHPOsXvPYrFIsn5wPVGBgYFq27atJOmNN95Qly5d9Nprr+mmm25yKBsaGqpLL73UNnZjxIgRys7Orva6zZo107hx4zRu3Dg98cQTat++vV566SXNnj3bViYuLq7W38uK7kBHjx51aN043s9Wkt2xig/5Fd9bDw8PjRs3TkuXLtVVV12l5cuX281aNGLECO3Zs0effvqpvv76aw0dOlRTp07Vv//9b7Vv316ZmZlKTk4+4daGKVOm2H2wd9aacuyzmUwmuwHmY8eO1fLly/XAAw9o+fLluvDCC23fuwrp6ekO38MzHS0NAAA0AB8Ptxo3L3eLXdlX1+7SglV/afoF7bVjzsWafkF7LVj1l15du8uhbE3XPBG+vr5q27atWrZsWe2HymP16tVLKSkpcnNzU9u2be22ig9hnTp1cpiG9Nj9qtq1aydvb29988031b5fMVC4tLRyHEhkZKSaNWumnTt3OtSjYuB0586dtXHjRrtBys7qURN3d3c9+OCDeuihh2r8S/SkSZP03Xffafz48bbQcjzBwcGKjo4+qWlQ27Rpo4CAAG3ZssXhvbr+bKszefJkff3111q4cKGKi4ttXcEqhIeHa+LEiXrjjTf07LPP6uWXX5YkXXPNNfLw8NC8efOqvW5tplgNCQmx+7m6uZ34372vv/56bdq0SYmJiXr33Xc1duxYhzJ//PGHevbsecL3OB3R0gAAQCNSMUvS9Avaa9rQdpJk+zq/fLrVin1XGzZsmPr166eRI0fqqaeeUocOHXTw4EF99tlnGjlypOLj43XHHXdowoQJio+P13nnnac333xTmzdvtht0WpWXl5fuv/9+3XffffLw8NC5556rw4cPa/PmzbrpppsUEREhb29vffHFF2revLm8vLwUGBioRx99VNOmTVNAQIBGjBihwsJCrV+/XkePHtX06dN1/fXXa+bMmbrpppv00EMPaffu3fr3v/99Qs99/fXX68EHH6xx2tKLLrpIhw8fdhifUGHx4sVKSkrSlVdeqTZt2qigoECvv/66Nm/e7NBlKDU11WH8R2hoaLUf/M1ms4YNG6bvv//+lCyW16lTJ/Xt21f333+/Jk2aZNcqNGvWLPXu3VtdunRRYWGhPvnkE3Xq1EmSdSraZ555RrfffruysrI0fvx4tWrVSvv379frr78uPz8/u2lXN23aJH9/f7t7V10M8GTFxcWpf//+uummm1RSUqIrrrjCoczatWv1+OOP19s9Twe0NAAA0IiUlhl2gaHCtKHtNP2C9iotO/FuNvXNZDLps88+08CB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t6pHjx61fpaqjv0djIyMrLHs8Z5j7NixGjRokFJTU5WQkCAvLy+HmbrS09MlWbuSnUqEBgAAGoKH4wcfB27OPyif8HVrydfXt04f+qozefJkde3aVQsXLlRxcbHDB/Dw8HBNnDhREydO1IABA3TvvfdWGxq6deum//znPyouLq42vEhSz5491bNnT82YMUP9+vXT8uXL1bdv31o/w8MPP6z27dvrrrvuUq9evdSrVy9t27btpL8Hx9OrVy9t3ry5xvt06tRJJSUlWr9+vfr06SNJ2rZt2wmtkXHsMx7r+uuv1z333KPu3burc+fOtbqmyWRSx44dnbYU1UbPnj21ZcsWh+Nms/mkfwYXX3yxfH19tWjRIn3++edas2aN3fve3t62EDR16lR17NhRmzZtUs+ePdW5c2c9/fTTuu666xzGNWRkZBy3xcfb27vefof69++v2NhYrVy5Up9//rmuvfZauxYXyTrIu3nz5jWOD6ovhAYAAFBvOnXqpL59++r+++/XpEmT7FoMZs2apd69e6tLly4qLCzUJ598ok6dOlV7ndtvv10LFizQ6NGjNWPGDAUGBuqnn35Snz595OHhoZdfflmXX365YmJitG3bNm3fvl3jx4+vU11bt26tK664QrNmzdInn3yiWbNm6dJLL1VsbKyuvfZamc1m/f7779q0aZOeeOKJk/q+VHX//ferb9++mjp1qm6++Wb5+vpq69atSkhI0IIFC9ShQwdddNFFuvnmm/Xyyy/Lzc1Nd95553FbX2rzjMcKDg5WcnJyjcEsKSlJjzzyiMaNG6fOnTvLw8NDq1ev1pIlS3T//ffblc3IyFBKSordMX9//2pbCiTpwgsv1H/+8586P1NtWCwWTZw4UTNmzFDbtm3Vr18/23vLli1TaWmpzjnnHPn4+Oi///2vvL291bJlS5lMJi1dulTDhg3TwIED9eCDD6pjx47KycnR//73P3311Vd2U67u2rXLYUHCtm3bys/Pr16ew2Qy6frrr9dLL72k7du369tvv3Uos3btWg0fPrxe7ucMYxoAAGgsfEKt6zA44+ZpLdeI3XTTTSoqKnKYicfDw0MzZsxQt27dNHDgQFkslhoX/woNDdWqVauUk5OjQYMGqXfv3nrllVfk7u4uHx8f/fnnn7r66qvVvn173XLLLbr99tv1j3/8o851vfvuu/Xpp5/q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",
      "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('PhysCL-Inv-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 (PhysCL-Inv)\", marker=\"x\", linestyle=\"--\"\n",
    ")\n",
    "plt.plot(\n",
    "    rmse_phys_per_t,\n",
    "    label=\"Physics-Refined RMSE (PhysCL-Inv)\",\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"
   ]
  }
 ],
 "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
}
