{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "4bf68ff8",
   "metadata": {
    "_cell_guid": "b1076dfc-b9ad-4769-8c92-a6c4dae69d19",
    "_uuid": "8f2839f25d086af736a60e9eeb907d3b93b6e0e5",
    "execution": {
     "iopub.execute_input": "2025-08-14T09:57:24.575595Z",
     "iopub.status.busy": "2025-08-14T09:57:24.575277Z",
     "iopub.status.idle": "2025-08-14T09:57:53.680824Z",
     "shell.execute_reply": "2025-08-14T09:57:53.679665Z"
    },
    "papermill": {
     "duration": 29.111124,
     "end_time": "2025-08-14T09:57:53.682392",
     "exception": false,
     "start_time": "2025-08-14T09:57:24.571268",
     "status": "completed"
    },
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[Linear] Epoch 0/3000 Loss: 103346.625000\n",
      "[Linear] Epoch 100/3000 Loss: 1387.679077\n",
      "[Linear] Epoch 200/3000 Loss: 0.514739\n",
      "[Linear] Epoch 300/3000 Loss: 0.391335\n",
      "[Linear] Epoch 400/3000 Loss: 0.388864\n",
      "[Linear] Epoch 500/3000 Loss: 0.386032\n",
      "[Linear] Epoch 600/3000 Loss: 0.382874\n",
      "[Linear] Epoch 700/3000 Loss: 0.379413\n",
      "[Linear] Epoch 800/3000 Loss: 0.375673\n",
      "[Linear] Epoch 900/3000 Loss: 0.371672\n",
      "[Linear] Epoch 1000/3000 Loss: 0.367426\n",
      "[Linear] Epoch 1100/3000 Loss: 0.362951\n",
      "[Linear] Epoch 1200/3000 Loss: 0.358261\n",
      "[Linear] Epoch 1300/3000 Loss: 0.353367\n",
      "[Linear] Epoch 1400/3000 Loss: 0.348282\n",
      "[Linear] Epoch 1500/3000 Loss: 0.343018\n",
      "[Linear] Epoch 1600/3000 Loss: 0.337584\n",
      "[Linear] Epoch 1700/3000 Loss: 0.331990\n",
      "[Linear] Epoch 1800/3000 Loss: 0.326245\n",
      "[Linear] Epoch 1900/3000 Loss: 0.320358\n",
      "[Linear] Epoch 2000/3000 Loss: 0.314337\n",
      "[Linear] Epoch 2100/3000 Loss: 0.308188\n",
      "[Linear] Epoch 2200/3000 Loss: 0.301919\n",
      "[Linear] Epoch 2300/3000 Loss: 0.295537\n",
      "[Linear] Epoch 2400/3000 Loss: 0.289047\n",
      "[Linear] Epoch 2500/3000 Loss: 0.282457\n",
      "[Linear] Epoch 2600/3000 Loss: 0.275773\n",
      "[Linear] Epoch 2700/3000 Loss: 0.269002\n",
      "[Linear] Epoch 2800/3000 Loss: 0.262151\n",
      "[Linear] Epoch 2900/3000 Loss: 0.255228\n",
      "[Linear] Epoch 2999/3000 Loss: 0.248312\n",
      "[Physics] Epoch 0/5000 Total: 0.7349 MSE: 0.7347\n",
      "[Physics] Epoch 100/5000 Total: 0.1461 MSE: 0.0908\n",
      "[Physics] Epoch 200/5000 Total: 0.0927 MSE: 0.0204\n",
      "[Physics] Epoch 300/5000 Total: 0.0884 MSE: 0.0154\n",
      "[Physics] Epoch 400/5000 Total: 0.0873 MSE: 0.0128\n",
      "[Physics] Epoch 500/5000 Total: 0.0863 MSE: 0.0118\n",
      "[Physics] Epoch 600/5000 Total: 0.0860 MSE: 0.0118\n",
      "[Physics] Epoch 700/5000 Total: 0.0862 MSE: 0.0129\n",
      "[Physics] Epoch 800/5000 Total: 0.0858 MSE: 0.0115\n",
      "[Physics] Epoch 900/5000 Total: 0.0858 MSE: 0.0116\n",
      "[Physics] Epoch 1000/5000 Total: 0.0857 MSE: 0.0113\n",
      "[Physics] Epoch 1100/5000 Total: 0.0857 MSE: 0.0114\n",
      "[Physics] Epoch 1200/5000 Total: 0.0871 MSE: 0.0151\n",
      "[Physics] Epoch 1300/5000 Total: 0.0856 MSE: 0.0115\n",
      "[Physics] Epoch 1400/5000 Total: 0.0857 MSE: 0.0122\n",
      "[Physics] Epoch 1500/5000 Total: 0.0856 MSE: 0.0115\n",
      "[Physics] Epoch 1600/5000 Total: 0.0857 MSE: 0.0120\n",
      "[Physics] Epoch 1700/5000 Total: 0.0856 MSE: 0.0115\n",
      "[Physics] Epoch 1800/5000 Total: 0.0859 MSE: 0.0128\n",
      "[Physics] Epoch 1900/5000 Total: 0.0856 MSE: 0.0115\n",
      "[Physics] Epoch 2000/5000 Total: 0.0858 MSE: 0.0123\n",
      "[Physics] Epoch 2100/5000 Total: 0.0856 MSE: 0.0115\n",
      "[Physics] Epoch 2200/5000 Total: 0.0862 MSE: 0.0127\n",
      "[Physics] Epoch 2300/5000 Total: 0.0856 MSE: 0.0115\n",
      "[Physics] Epoch 2400/5000 Total: 0.0862 MSE: 0.0136\n",
      "[Physics] Epoch 2500/5000 Total: 0.0856 MSE: 0.0116\n",
      "[Physics] Epoch 2600/5000 Total: 0.0876 MSE: 0.0155\n",
      "[Physics] Epoch 2700/5000 Total: 0.0856 MSE: 0.0115\n",
      "[Physics] Epoch 2800/5000 Total: 0.0870 MSE: 0.0108\n",
      "[Physics] Epoch 2900/5000 Total: 0.0856 MSE: 0.0115\n",
      "[Physics] Epoch 3000/5000 Total: 0.0856 MSE: 0.0115\n",
      "[Physics] Epoch 3100/5000 Total: 0.0856 MSE: 0.0119\n",
      "[Physics] Epoch 3200/5000 Total: 0.0855 MSE: 0.0115\n",
      "[Physics] Epoch 3300/5000 Total: 0.0856 MSE: 0.0117\n",
      "[Physics] Epoch 3400/5000 Total: 0.0855 MSE: 0.0115\n",
      "[Physics] Epoch 3500/5000 Total: 0.0862 MSE: 0.0128\n",
      "[Physics] Epoch 3600/5000 Total: 0.0856 MSE: 0.0114\n",
      "[Physics] Epoch 3700/5000 Total: 0.0855 MSE: 0.0115\n",
      "[Physics] Epoch 3800/5000 Total: 0.0856 MSE: 0.0115\n",
      "[Physics] Epoch 3900/5000 Total: 0.0855 MSE: 0.0115\n",
      "[Physics] Epoch 4000/5000 Total: 0.0855 MSE: 0.0115\n",
      "[Physics] Epoch 4100/5000 Total: 0.0856 MSE: 0.0115\n",
      "[Physics] Epoch 4200/5000 Total: 0.0855 MSE: 0.0115\n",
      "[Physics] Epoch 4300/5000 Total: 0.0855 MSE: 0.0115\n",
      "[Physics] Epoch 4400/5000 Total: 0.0855 MSE: 0.0118\n",
      "[Physics] Epoch 4500/5000 Total: 0.0855 MSE: 0.0115\n",
      "[Physics] Epoch 4600/5000 Total: 0.0856 MSE: 0.0123\n",
      "[Physics] Epoch 4700/5000 Total: 0.0856 MSE: 0.0112\n",
      "[Physics] Epoch 4800/5000 Total: 0.0855 MSE: 0.0115\n",
      "[Physics] Epoch 4900/5000 Total: 0.0862 MSE: 0.0110\n",
      "[Physics] Epoch 4999/5000 Total: 0.0855 MSE: 0.0114\n"
     ]
    },
    {
     "data": {
      "image/png": "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vTFw4EDExcUZPb/GjRvDycmpStto53av19nKygrfffcdJk+ejPj4eMTExOhcF8bCwgLBwcEICgqqWuJERFXEwoKIatWmTZswadKke7Zr1KgRUlNTAQB9+vTB8OHDK2xb0fn/S745r6pGjRrp3E5JSdH5YFjyTX4JR0fH+35+c3PzCu/TLiQqkpOTo5yyFwAee+wxrF+/Hi1btoRarYafnx/OnDlT5TxKVi+0OTo6QpIkpbiIjY2962OWfR3fffddWFtb3zOXqjIzM8PLL7+sc6zDK6+8cs/tquM9Vhn38z7Uzu1erzNQvBoUGxuLc+fOITw8HFeuXEFYWBh+++03FBQU4M0338STTz6pU7wTEVU3FhZEZJJKDiIGik9D+8ILL5S7BsSdO3ewc+fOar+wWNnH27JlCz766CMAgEajwddff63c16hRI3h6elbr81dFZmYmNBqNcnvo0KFo3bo1gOIDwP/6669qey4bGxt069YN586dAwBs3boVQUFBOh9W79y5g+zsbDRt2rTc69i4cWO89NJL5R43MjKywlWfynrhhRewZMkS3LlzB46Ojhg/fvw9t7nf95h2EZabm2tQ3hXp06cPfvzxRwDAL7/8ghMnTujsMldUVISUlBS4ubkhLy8PsbGx6NChA3x9fZXd54QQcHR0RGZmJmRZxp9//snCgohqFAsLIjJJr7/+On766ScIIXDlyhV06tQJI0eOhLOzMzIzMxEREYGjR48iJydHuT5EdenSpQsee+wx5SxMH3/8MWJiYuDt7Y1ffvlF5xiMmTNn6lzxubY1bdoUDRs2REZGBgDgvffeQ2pqKoqKirBx48a77v50P+bMmYPRo0cDAG7fvo2uXbsqZ4VKSEjAnj17sGbNGowYMQJdunTB448/rpxBKTAwEPv370ePHj2UixSGhYXh4sWLWLhwIfr06XPfeTk5OeGXX37BzZs34erqChsbm3tuc7/vMTc3N+X/N27cwOTJk9GxY0dIkoQZM2ZUy6rMm2++id27d0OWZWg0GjzyyCMYPXo0PD09kZycjIMHDyIwMBCzZs1CRkYGOnbsCG9vb/j5+aFZs2awtrbG8ePHlat6A0DDhg0NzouI6G5YWBCRSerTpw9WrVqFmTNnoqioCAkJCfj0009r7fm//vprPPbYY7hw4QIA4Pvvv1dOBVvi6aef1tn9xhjMzMww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fh2Ojo7VlBkREdGDhYUFEVElubi4GDsFCCGg0WhgZsY/30REZFq4KxQRUSVp7woVFxcHSZLw448/4pFHHoGNjQ26dOmCkydP6mxz/Phx9O3bF9bW1nB3d8err76KnJwc5f6tW7fC19cXdnZ2cHFxwXPPPadcbwIAQkNDIUkS9u/fjx49esDS0hLHjx+vlf4SERFVBb/yIiIywNtvv41PPvkE7dq1w9tvv42xY8fiypUrMDMzwz///INBgwbhvffew8aNG3Hjxg0EBgYiMDAQmzZtAlB86tclS5bA09MTqampCAoKwqRJk8pdi2HOnDn45JNP0Lp1a+6ORVRfmOoB9wAPuie9WFgQERngjTfewNChxcdxLF68GN7e3rhy5Qq8vLwQHByMcePGYdasWQCAdu3a4bPPPkP//v2xdu1aWFlZYcqUKcpjtW7dGp999hkeeugh3L59G7a2tsp97777Lh5//PFa7RsREVFVcFcoIiIDdO7cWfm/q6srACi7Mv3555/YvHkzbG1tlZ+AgADIsozY2FgAwNmzZzFs2DC0aNECdnZ26N+/PwDoXJsBAHx9fWujO0RERPeNKxZERAYwNzdX/l9yATpZlgEUXzX6//7v//Dqq6+W265FixbIyclBQEAAAgICsG3bNjRp0gTx8fEICAhAQUGBTvsGDRrUYC+IiIgMZ/QVi7Vr16Jz586wt7eHvb09/P39sX///rtus3PnTnh5ecHKygo+Pj7l9kUmIjIF3bt3x4ULF9C2bdtyPxYWFrh06RJu3bqFDz/8EH379oWXl5fOgdtERER1idELi+bNm+PDDz/E2bNn8ccff+DRRx/F8OHDERkZqbd9WFgYxo4di6lTp+L8+fMYMWIERowYgb///ruWMyeiB1VmZibCw8N1fhISEqr8OG+99RbCwsIQGBiI8PBwREdH46effkJgYCCA4lULCwsLfP7554iJicH//vc/LFmypLq7Q0REVCuMvivUsGHDdG6///77WLt2LU6dOgVvb+9y7T/99FMMGjQIb775JgBgyZIlOHToEFatWoV169bpfY78/Hzk5+crt7OysgAAGo0GGo0GQPEuDCqVCrIsQwihtC2Jl7S7V1ylUkGSJL1xoHQXiXvF1Wo1hBB642VzrCjOPunGzaTS9hoBCEg6sdI4YCbphFEkAAmAulxcggShExcANEKCCgKq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h7GS/Vpv374NIQTatWuH//73vzh27BimTJmCO3fuAAAaNGiAoqIi3L59GwDg6uqKBQsWYOvWrThz5gzMzc3RsGFD9OrVyzgdogca5wii2sP5gWqCJGr5L+vt27cxbdo0/PTTTxg/fjy6du2KpKQk7Nq1C5mZmVi7di2aN28OX19f/PzzzxV+q/T000/D09MT7777LszMzDB9+nQcP34cP/30E9q3b1+bXSIyed988w0+/vhjODs7Q61WY8OGDXB1dcXff/+NMWPGoHnz5vjkk0+Ql5eHfv36IT09HVZWVgCArKwsfPrpp5g2bRpcXV2N3BN60HGOIKpdnB+oWtXmflf79u0Ttra2om/fvuXOEx4bGyv69esnPDw8RFZWlnj66adFr169RFJSktLm2rVrIiYmRsyaNUu0bNlSHDt2TNkPNy8vT0iSJN566y1RWFhYm90iMqqS34GyVy+VZVloNBoxb9480axZM7F06VKxf/9+8fjjj4t+/fopp+W8cuWKGDlypGjfvr3YsGGD6Nq1q/j5559rvR9EnCOIqhfnB6pttVpYhISEiA4dOijnNC55o5f8kf/hhx9Ey5YtxZw5c8SNGzeEJElizZo1QpZlERYWJl588UXRqlUr4efnJ86fP688bsn233//vbh48WJtdonIaLQnirIHt5ZMJllZWaJv377i+++/V+4bNWqUcHBwED/99JOyXXx8vHjjjTeEJElCkiTx7bff1kIPiHRxjiCqHpwfyFhqdVcoIQQCAwNx8eJFrFq1Ch07dlQO0pMkCRqNBk8//TSuXr2K8+fP4/XXX8fu3btx6NAhuLu74+eff4ajoyMeeeQRANDZlqi+EELovOfXrVuHEydOIDMzExqNBi+99BL69esHe3t7HDt2DNOnT0dUVBQ++eQTvP/+++jRowc++ugj9OjRo9xjz5s3Dzk5Ofjoo4+UpW6i2sI5gsgwnB/I6Gq7krly5Yro27eveP3113Xi2qcObNiwobh9+7bQaDRCkiQxe/bsco/DqzdSfbd7927h7u4uvL29xbvvviumT58uHnvsMWFtbS1ee+01IYQQqampokmTJsLR0VF4e3uLb775Rtn+6tWr4vjx4yI/P1/5dou/V2RsnCOIDMf5gYzFrLYLmTZt2mDw4MHYs2cPQkJC8Nhjj0GWZeWKpykpKWjYsCGys7PRoEEDHD58GJ07dy73OLx6I9VXGRkZePHFF/Hdd99hzZo1mDhxIqytrZX7p0yZgu3bt6NDhw6YPn06hg8fjoMHD+LUqVOwtbVV2m3atAmZmZno3r27cgVi/l6RsXGOILp/nB/I2Ixy5e2XXnoJdnZ22LJlCwoLC5WrqEZGRuK3337Dq6++ChcXFwDAgAED0KhRI71XgiSqjxISEnD58mWMHj0aL774IqytrSHLsnIu8nnz5qFLly5YtWoVcnNzMWbMGKhUKkybNg27d+/G6dOn8dRTT2Hjxo3o2bOnzqRDZAo4RxDdH84PZGxGKSwaNmyIKVOmICoqCjt37gQAnDhxAv/3f/+Hpk2b4plnnim3TcnEQlTf+fj4YMKECbh69Sq2bNmixEu+TWrbti0GDRqE69ev4/Dhwxg4cCC2bt2K6OhoLFiwAM8//zwA4MyZMxgzZoxR+kB0N5wjiO4P5wcytlq/jkWJwsJCTJo0CTdu3ICNjQ327duHGTNmYMWKFcZIh6hOuXbtGmbNmoXc3Fxs2LABLi4ukGUZQgio1WrEx8ejTZs22Lx5M8aNGwcAyMvLQ3Z2NnJycuDh4WHcDhDdA+cIovvD+YGMyWhf8ZibmyMwMBB///03cnNzcenSJWXCKHt5eSLS1axZM4wYMQK3bt3Cpk2bABR/Y6t9BVUrKytlv3QAsLKyQpMmTThpUJ3AOYLo/nB+IGMy2ooFUHxatNjYWLRu3RpA8WShUql4akCiSsjLy8OsWbNw6dIlfPrpp+jSpQs0Gg0KCwvxzjvv4NSpUzh06BBPC0h1FucIovvD+YGMxag7pUqSpDNhqNVqThhElWRlZaXsA7thwwYAxfvRBgcH4+DBgwgMDISVlRWM+N0BkUE4RxDdH84PZCxGXbEgIsMtWLAAR48eRa9evbB7927Isowvv/wSAwYMMHZqRERkRJwfqLbxNBpEddyzzz6LnJwcrF27FlOnTkV0dDQnDSIi4vxAtY4rFkQPgFOnTulcyIiIiAjg/EC1i4UFEREREREZjLtCERERERGRwVhYEBERERGRwVhYEBERERGRwVhYEBERERGRwVhYEBERERGRwVhYEBERERGRwVhYEBERERGRwVhYEBERERGRwVhYEBERERGRwVhYEBERERGRwVhYEBERERGRwf4ft+Yk99MwcSsAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 800x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "✅ All outputs saved in: results_run_20250814_095732\n"
     ]
    }
   ],
   "source": [
    "# ========================\n",
    "# 1. IMPORTS (REPRODUCIBILITY FIRST)\n",
    "# ========================\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "from matplotlib.ticker import AutoMinorLocator\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "import random\n",
    "import os\n",
    "import json\n",
    "import datetime\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.metrics import mean_absolute_error, r2_score\n",
    "\n",
    "# Set random seeds for reproducibility\n",
    "SEED = 42\n",
    "np.random.seed(SEED)\n",
    "random.seed(SEED)\n",
    "torch.manual_seed(SEED)\n",
    "if torch.cuda.is_available():\n",
    "    torch.cuda.manual_seed_all(SEED)\n",
    "\n",
    "# ========================\n",
    "# 2. DATA PREPROCESSING\n",
    "# ========================\n",
    "def load_and_preprocess(data_path):\n",
    "    df = pd.read_csv(data_path)\n",
    "    df['Time_sec'] = df['Time'].apply(lambda t:\n",
    "                                      int(t.split(':')[0])*3600 +\n",
    "                                      int(t.split(':')[1])*60 +\n",
    "                                      int(t.split(':')[2]))\n",
    "    features = ['Displacement (mm)', 'Load (N)', 'Deviator  Strain']\n",
    "    df_clean = df.dropna(subset=['Time_sec'] + features).copy().reset_index(drop=True)\n",
    "\n",
    "    X = df_clean[['Time_sec']].values.astype(np.float32)\n",
    "    y = df_clean[features].values.astype(np.float32)\n",
    "\n",
    "    norm_stats = {col: (df_clean[col].mean(), df_clean[col].std()) for col in features}\n",
    "    y_norm = np.zeros_like(y)\n",
    "    for i, col in enumerate(features):\n",
    "        mu, std = norm_stats[col]\n",
    "        y_norm[:, i] = (y[:, i] - mu) / std\n",
    "\n",
    "    return X, y_norm, df_clean, norm_stats\n",
    "\n",
    "# ========================\n",
    "# 3. MODEL ARCHITECTURES\n",
    "# ========================\n",
    "class LinearRegressor(nn.Module):\n",
    "    def __init__(self, out_dim):\n",
    "        super().__init__()\n",
    "        self.linear = nn.Linear(1, out_dim)\n",
    "    def forward(self, x):\n",
    "        return self.linear(x)\n",
    "\n",
    "class PhysicsInformedNN(nn.Module):\n",
    "    def __init__(self, hidden=64, out_dim=3):\n",
    "        super().__init__()\n",
    "        self.net = nn.Sequential(\n",
    "            nn.Linear(1, hidden),\n",
    "            nn.Tanh(),\n",
    "            nn.Linear(hidden, hidden),\n",
    "            nn.Tanh(),\n",
    "            nn.Linear(hidden, out_dim)\n",
    "        )\n",
    "    def forward(self, x):\n",
    "        return self.net(x)\n",
    "\n",
    "# ========================\n",
    "# 4. PHYSICS CONSTRAINTS\n",
    "# ========================\n",
    "def monotonicity_penalty(displacement):\n",
    "    delta = displacement[1:] - displacement[:-1]\n",
    "    return torch.mean(torch.relu(-delta))\n",
    "\n",
    "def work_penalty(load, displacement):\n",
    "    delta_disp = displacement[1:] - displacement[:-1]\n",
    "    avg_load = (load[1:] + load[:-1]) / 2\n",
    "    work = avg_load * delta_disp\n",
    "    return torch.mean(torch.relu(-work))\n",
    "\n",
    "# ========================\n",
    "# 5. TRAINING FUNCTIONS\n",
    "# ========================\n",
    "def train_linear_model(X_train, y_train, epochs=3000, lr=0.01):\n",
    "    model = LinearRegressor(y_train.shape[1])\n",
    "    optimizer = optim.Adam(model.parameters(), lr=lr)\n",
    "    loss_fn = nn.MSELoss()\n",
    "    history = {'epoch': [], 'loss': [], 'lr': []}\n",
    "\n",
    "    for epoch in range(epochs):\n",
    "        optimizer.zero_grad()\n",
    "        outputs = model(X_train)\n",
    "        loss = loss_fn(outputs, y_train)\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "        history['epoch'].append(epoch)\n",
    "        history['loss'].append(loss.item())\n",
    "        history['lr'].append(optimizer.param_groups[0]['lr'])\n",
    "        if epoch % 100 == 0 or epoch == epochs - 1:\n",
    "            print(f\"[Linear] Epoch {epoch}/{epochs} Loss: {loss.item():.6f}\")\n",
    "    return model, pd.DataFrame(history)\n",
    "\n",
    "def train_physics_nn(X_train, y_train, epochs=5000, lr=0.001, lambda_mono=0.1, lambda_work=0.1):\n",
    "    model = PhysicsInformedNN(hidden=64, out_dim=y_train.shape[1])\n",
    "    optimizer = optim.Adam(model.parameters(), lr=lr)\n",
    "    mse_loss = nn.MSELoss()\n",
    "    history = {'epoch': [], 'total_loss': [], 'mse_loss': [], 'mono_penalty': [], 'work_penalty': [], 'lr': []}\n",
    "    best_loss = float('inf')\n",
    "    patience = 300\n",
    "    no_improve = 0\n",
    "\n",
    "    for epoch in range(epochs):\n",
    "        model.train()\n",
    "        optimizer.zero_grad()\n",
    "        preds = model(X_train)\n",
    "        mse = mse_loss(preds, y_train)\n",
    "        mono = monotonicity_penalty(preds[:, 0])\n",
    "        work = work_penalty(preds[:, 1], preds[:, 0])\n",
    "        total_loss = mse + lambda_mono * mono + lambda_work * work\n",
    "        total_loss.backward()\n",
    "        optimizer.step()\n",
    "\n",
    "        history['epoch'].append(epoch)\n",
    "        history['total_loss'].append(total_loss.item())\n",
    "        history['mse_loss'].append(mse.item())\n",
    "        history['mono_penalty'].append(mono.item())\n",
    "        history['work_penalty'].append(work.item())\n",
    "        history['lr'].append(optimizer.param_groups[0]['lr'])\n",
    "\n",
    "        if total_loss.item() < best_loss:\n",
    "            best_loss = total_loss.item()\n",
    "            no_improve = 0\n",
    "        else:\n",
    "            no_improve += 1\n",
    "\n",
    "        if epoch % 100 == 0 or epoch == epochs - 1:\n",
    "            print(f\"[Physics] Epoch {epoch}/{epochs} Total: {total_loss.item():.4f} MSE: {mse.item():.4f}\")\n",
    "\n",
    "        if no_improve >= patience:\n",
    "            print(f\"Early stopping at epoch {epoch}\")\n",
    "            break\n",
    "    return model, pd.DataFrame(history)\n",
    "\n",
    "# ========================\n",
    "# 6. METRICS & SAVING\n",
    "# ========================\n",
    "def calculate_metrics(y_true, y_pred, feature_name, norm_stats):\n",
    "    col_map = {\n",
    "        'Displacement': 'Displacement (mm)',\n",
    "        'Load': 'Load (N)',\n",
    "        'Deviator Strain': 'Deviator  Strain'\n",
    "    }\n",
    "    mu, std = norm_stats[col_map[feature_name]]\n",
    "    true_denorm = y_true * std + mu\n",
    "    pred_denorm = y_pred * std + mu\n",
    "    return {\n",
    "        'MAE': mean_absolute_error(true_denorm, pred_denorm),\n",
    "        'R2': r2_score(true_denorm, pred_denorm),\n",
    "        'MaxError': np.max(np.abs(true_denorm - pred_denorm))\n",
    "    }\n",
    "\n",
    "def save_json(obj, path):\n",
    "    # Convert all NumPy floats to native Python floats recursively\n",
    "    def convert(o):\n",
    "        if isinstance(o, dict):\n",
    "            return {k: convert(v) for k, v in o.items()}\n",
    "        elif isinstance(o, list):\n",
    "            return [convert(v) for v in o]\n",
    "        elif isinstance(o, (np.float32, np.float64, np.integer)):\n",
    "            return float(o)\n",
    "        else:\n",
    "            return o\n",
    "\n",
    "    with open(path, 'w') as f:\n",
    "        json.dump(convert(obj), f, indent=4)\n",
    "\n",
    "# ========================\n",
    "# 7. PLOTTING\n",
    "# ========================\n",
    "def plot_training_history(lin_history, phys_history, save_path):\n",
    "    plt.figure(figsize=(6, 4))\n",
    "    plt.plot(lin_history['epoch'], lin_history['loss'], label='Linear MSE')\n",
    "    plt.plot(phys_history['epoch'], phys_history['total_loss'], label='Physics Total')\n",
    "    plt.xlabel(\"Epoch\")\n",
    "    plt.ylabel(\"Loss\")\n",
    "    plt.title(\"Training Loss\")\n",
    "    plt.legend()\n",
    "    plt.grid(True, which='both', linestyle='--', alpha=0.6)\n",
    "    plt.tight_layout()\n",
    "    plt.savefig(save_path, dpi=600)\n",
    "    plt.close()\n",
    "\n",
    "def plot_predictions(X_test, y_test, y_pred_lin, y_pred_phys, norm_stats, save_prefix):\n",
    "    features = ['Displacement (mm)', 'Load (N)', 'Deviator  Strain']\n",
    "    for i, feat in enumerate(features):\n",
    "        mu, std = norm_stats[feat]\n",
    "        true_denorm = y_test[:, i] * std + mu\n",
    "        lin_denorm = y_pred_lin[:, i] * std + mu\n",
    "        phys_denorm = y_pred_phys[:, i] * std + mu\n",
    "        plt.figure(figsize=(6, 4))\n",
    "        plt.scatter(X_test, true_denorm, label='Ground Truth', color='black', s=20, alpha=0.7)\n",
    "        plt.plot(X_test, lin_denorm, 'r-', label='Linear')\n",
    "        plt.plot(X_test, phys_denorm, 'b-', label='Physics')\n",
    "        plt.xlabel(\"Time (sec)\")\n",
    "        plt.ylabel(feat)\n",
    "        plt.title(f\"{feat} Prediction\")\n",
    "        plt.legend()\n",
    "        plt.grid(True, linestyle='--', alpha=0.6)\n",
    "        plt.tight_layout()\n",
    "        plt.savefig(f\"{save_prefix}_{feat.replace(' ', '_')}.png\", dpi=600)\n",
    "        plt.close()\n",
    "\n",
    "def plot_metrics_bar(metrics_dict, save_path='results/metrics_bar.png'):\n",
    "    df = pd.DataFrame(metrics_dict).T.reset_index()\n",
    "    df[['Model', 'Feature']] = df['index'].str.split('_', n=1, expand=True)\n",
    "    \n",
    "    features = df['Feature'].unique()\n",
    "    x = np.arange(len(features)) # numeric positions \n",
    "    width = 0.35 # width of each bar \n",
    "    fig, axes = plt.subplots(1, 2, figsize=(8, 4)) \n",
    "    for i, metric in enumerate(['MAE', 'R2']): \n",
    "        ax = axes[i] \n",
    "        for j, model in enumerate(df['Model'].unique()):\n",
    "            subset = df[df['Model'] == model]\n",
    "            ax.bar(x + (j - 0.5) * width, subset[metric],width=width, label=model if i == 0 else \"\")\n",
    "        ax.set_ylabel(metric, fontsize=11) \n",
    "        ax.set_xticks(x) \n",
    "        ax.set_xticklabels(features, rotation=30, ha='right') \n",
    "        ax.grid(axis='y', linestyle='--', alpha=0.6) \n",
    "        \n",
    "        if i == 0:\n",
    "            ax.legend()\n",
    "    fig.suptitle(\"Performance Metrics\", fontsize=14, fontweight='bold')\n",
    "    fig.tight_layout()\n",
    "    plt.savefig(save_path, dpi=600)\n",
    "    plt.show()\n",
    "\n",
    "# ========================\n",
    "# 8. MAIN EXECUTION\n",
    "# ========================\n",
    "if __name__ == \"__main__\":\n",
    "    DATA_PATH = \"/kaggle/input/triaxial-dataset/Triaxialdata.csv\"\n",
    "    timestamp = datetime.datetime.now().strftime(\"%Y%m%d_%H%M%S\")\n",
    "    results_dir = f\"results_run_{timestamp}\"\n",
    "    os.makedirs(results_dir, exist_ok=True)\n",
    "\n",
    "    X, y, df_clean, norm_stats = load_and_preprocess(DATA_PATH)\n",
    "    X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=SEED)\n",
    "    X_train_t, X_test_t = torch.FloatTensor(X_train), torch.FloatTensor(X_test)\n",
    "    y_train_t, y_test_t = torch.FloatTensor(y_train), torch.FloatTensor(y_test)\n",
    "\n",
    "    # Save raw data splits\n",
    "    pd.DataFrame(X_train, columns=[\"Time_sec\"]).to_csv(f\"{results_dir}/X_train.csv\", index=False)\n",
    "    pd.DataFrame(X_test, columns=[\"Time_sec\"]).to_csv(f\"{results_dir}/X_test.csv\", index=False)\n",
    "    pd.DataFrame(y_train, columns=['Disp_norm', 'Load_norm', 'DevStrain_norm']).to_csv(f\"{results_dir}/y_train.csv\", index=False)\n",
    "    pd.DataFrame(y_test, columns=['Disp_norm', 'Load_norm', 'DevStrain_norm']).to_csv(f\"{results_dir}/y_test.csv\", index=False)\n",
    "\n",
    "    # Save config\n",
    "    save_json({\"SEED\": SEED, \"DATA_PATH\": DATA_PATH}, f\"{results_dir}/config.json\")\n",
    "\n",
    "    # Train and save models\n",
    "    lin_model, lin_history = train_linear_model(X_train_t, y_train_t)\n",
    "    torch.save(lin_model.state_dict(), f\"{results_dir}/linear_model.pth\")\n",
    "    lin_history.to_csv(f\"{results_dir}/linear_training_history.csv\", index=False)\n",
    "\n",
    "    phys_model, phys_history = train_physics_nn(X_train_t, y_train_t)\n",
    "    torch.save(phys_model.state_dict(), f\"{results_dir}/physics_model.pth\")\n",
    "    phys_history.to_csv(f\"{results_dir}/physics_training_history.csv\", index=False)\n",
    "\n",
    "    with torch.no_grad():\n",
    "        y_pred_lin = lin_model(X_test_t).numpy()\n",
    "        y_pred_phys = phys_model(X_test_t).numpy()\n",
    "\n",
    "    # Save predictions\n",
    "    pd.DataFrame(y_pred_lin, columns=['Disp_norm', 'Load_norm', 'DevStrain_norm']).to_csv(f\"{results_dir}/y_pred_linear.csv\", index=False)\n",
    "    pd.DataFrame(y_pred_phys, columns=['Disp_norm', 'Load_norm', 'DevStrain_norm']).to_csv(f\"{results_dir}/y_pred_physics.csv\", index=False)\n",
    "\n",
    "    # Metrics\n",
    "    metrics = {}\n",
    "    features = ['Displacement', 'Load', 'Deviator Strain']\n",
    "    for i, feat in enumerate(features):\n",
    "        metrics[f'Linear_{feat}'] = calculate_metrics(y_test[:, i], y_pred_lin[:, i], feat, norm_stats)\n",
    "        metrics[f'Physics_{feat}'] = calculate_metrics(y_test[:, i], y_pred_phys[:, i], feat, norm_stats)\n",
    "    save_json(metrics, f\"{results_dir}/metrics.json\")\n",
    "\n",
    "    # Plots\n",
    "    plot_training_history(lin_history, phys_history, f\"{results_dir}/training_loss.png\")\n",
    "    plot_predictions(X_test, y_test, y_pred_lin, y_pred_phys, norm_stats, f\"{results_dir}/predictions\")\n",
    "    plot_metrics_bar(metrics, f\"{results_dir}/performance_bar.png\")\n",
    "    print(f\"✅ All outputs saved in: {results_dir}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6a8ec6ab",
   "metadata": {
    "papermill": {
     "duration": 0.003917,
     "end_time": "2025-08-14T09:57:53.691091",
     "exception": false,
     "start_time": "2025-08-14T09:57:53.687174",
     "status": "completed"
    },
    "tags": []
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "60f7e3c7",
   "metadata": {
    "papermill": {
     "duration": 0.003753,
     "end_time": "2025-08-14T09:57:53.698857",
     "exception": false,
     "start_time": "2025-08-14T09:57:53.695104",
     "status": "completed"
    },
    "tags": []
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kaggle": {
   "accelerator": "none",
   "dataSources": [
    {
     "datasetId": 3525734,
     "sourceId": 6148008,
     "sourceType": "datasetVersion"
    }
   ],
   "dockerImageVersionId": 31089,
   "isGpuEnabled": false,
   "isInternetEnabled": true,
   "language": "python",
   "sourceType": "notebook"
  },
  "kernelspec": {
   "display_name": "Python 3",
   "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.11.13"
  },
  "papermill": {
   "default_parameters": {},
   "duration": 36.131845,
   "end_time": "2025-08-14T09:57:55.999401",
   "environment_variables": {},
   "exception": null,
   "input_path": "__notebook__.ipynb",
   "output_path": "__notebook__.ipynb",
   "parameters": {},
   "start_time": "2025-08-14T09:57:19.867556",
   "version": "2.6.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
