{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "ae641287",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_data_path = \"beach_profile_data/processed_data/beachdata_train.xlsx\"\n",
    "test_data_path = \"beach_profile_data/processed_data/beachdata_test.xlsx\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "37f9be27",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "from sklearn.preprocessing import StandardScaler, LabelEncoder\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "\n",
    "\n",
    "def load_data(train_path: str, test_path: str):\n",
    "    \"\"\"Loads the training and test datasets from Excel files and returns them as pandas DataFrames.\"\"\"\n",
    "    # Load training data\n",
    "    train_df = pd.read_excel(train_path)\n",
    "    # Load test data\n",
    "    test_df = pd.read_excel(test_path)\n",
    "    return train_df, test_df\n",
    "\n",
    "\n",
    "def preprocess_data(train_df: pd.DataFrame, test_df: pd.DataFrame):\n",
    "    \"\"\"Preprocesses data by encoding categorical features and scaling numerical features.\"\"\"\n",
    "    # Identify categorical columns for encoding\n",
    "    categorical_features = ['Dominant Wave Direction']\n",
    "    # Encode categorical features using label encoding\n",
    "    for feature in categorical_features:\n",
    "        label_encoder = LabelEncoder()\n",
    "        train_df[feature] = label_encoder.fit_transform(train_df[feature])\n",
    "        test_df[feature] = label_encoder.transform(test_df[feature])\n",
    "    \n",
    "    # Select columns for scaling (excluding 'x' and 'y' columns)\n",
    "    numerical_features = train_df.drop(columns=['x', 'y'] + categorical_features).columns\n",
    "    scaler = StandardScaler()\n",
    "    # Scale the numerical columns\n",
    "    train_df[numerical_features] = scaler.fit_transform(train_df[numerical_features])\n",
    "    test_df[numerical_features] = scaler.transform(test_df[numerical_features])\n",
    "    \n",
    "    feature_names = list(train_df.columns)\n",
    "    \n",
    "    return train_df, test_df, feature_names\n",
    "\n",
    "\n",
    "def feature_selection(train_df: pd.DataFrame, feature_names: list):\n",
    "    \"\"\"Performs feature selection based on correlation with the target 'y'.\"\"\"\n",
    "    # Calculate correlation matrix\n",
    "    correlation_matrix = train_df.corr()\n",
    "    # Select features with correlation coefficient > 0.2 with 'y'\n",
    "    threshold = 0.2\n",
    "    selected_features = correlation_matrix.index[abs(correlation_matrix['y']) > threshold]\n",
    "    filtered_df = train_df[selected_features]\n",
    "    \n",
    "    selected_feature_names = list(selected_features.drop(['y']))\n",
    "    return filtered_df, selected_feature_names\n",
    "\n",
    "\n",
    "def bruun_dean_model_parameters(df: pd.DataFrame):\n",
    "    \"\"\"Computes additional parameters based on Bruun and Dean models and adds them to the DataFrame.\"\"\"\n",
    "    # Calculate horizontal retreat using Bruun model formula\n",
    "    df['horizontal_retreat'] = df['Mean Grain Size'] * df['Intertidal Slope'] / (df['Profile Length'] + 1)\n",
    "    # Include any other attributes from the Dean model you want to consider\n",
    "    # Currently, only the horizontal_retreat is added as a sample attributable to Bruun model\n",
    "    \n",
    "    return df\n",
    "\n",
    "\n",
    "def train_deep_learning_model(train_df: pd.DataFrame):\n",
    "    \"\"\"Defines and trains a PyTorch-based deep learning model using the processed dataset.\"\"\"\n",
    "    # Define a simple neural network architecture\n",
    "    class SimpleNN(nn.Module):\n",
    "        def __init__(self, input_size):\n",
    "            super(SimpleNN, self).__init__()\n",
    "            self.fc1 = nn.Linear(input_size, 64)  # Input layer\n",
    "            self.fc2 = nn.Linear(64, 32)  # Hidden layer\n",
    "            self.fc3 = nn.Linear(32, 1)  # Output layer\n",
    "        \n",
    "        def forward(self, x):\n",
    "            x = torch.relu(self.fc1(x))\n",
    "            x = torch.relu(self.fc2(x))\n",
    "            x = self.fc3(x)\n",
    "            return x\n",
    "    \n",
    "    # Prepare features and targets\n",
    "    X_train = train_df.drop(columns=['y']).values\n",
    "    y_train = train_df['y'].values\n",
    "\n",
    "    # Convert to PyTorch tensors\n",
    "    X_train_tensor = torch.tensor(X_train, dtype=torch.float32)\n",
    "    y_train_tensor = torch.tensor(y_train, dtype=torch.float32).view(-1, 1)\n",
    "    \n",
    "    # Initialize the Network, Loss Function, and Optimizer\n",
    "    model = SimpleNN(input_size=X_train_tensor.shape[1])\n",
    "    criterion = nn.MSELoss()  # Mean Squared Error Loss\n",
    "    optimizer = optim.Adam(model.parameters(), lr=0.001)\n",
    "    \n",
    "    # Training loop\n",
    "    epochs = 1000\n",
    "    for epoch in range(epochs):\n",
    "        model.train()\n",
    "        optimizer.zero_grad()  # Zero the gradients\n",
    "        outputs = model(X_train_tensor)  # Forward pass\n",
    "        loss = criterion(outputs, y_train_tensor)  # Calculate Loss\n",
    "        loss.backward()  # Backward pass\n",
    "        optimizer.step()  # Update weights\n",
    "    \n",
    "    return model\n",
    "\n",
    "\n",
    "def evaluate_model(model, test_df: pd.DataFrame):\n",
    "    \"\"\"Evaluates the trained deep learning model on the test dataset.\"\"\"\n",
    "    # Prepare test features\n",
    "    X_test = test_df.drop(columns=['y']).values\n",
    "    y_test = test_df['y'].values\n",
    "\n",
    "    # Convert to PyTorch tensors\n",
    "    X_test_tensor = torch.tensor(X_test, dtype=torch.float32)\n",
    "    y_test_tensor = torch.tensor(y_test, dtype=torch.float32).view(-1, 1)\n",
    "    \n",
    "    # Evaluate model\n",
    "    model.eval()\n",
    "    with torch.no_grad():\n",
    "        predictions = model(X_test_tensor)  # Get predictions\n",
    "        criterion = nn.MSELoss()\n",
    "        mse = criterion(predictions, y_test_tensor).item()  # Calculate Mean Squared Error\n",
    "    \n",
    "    return mse\n",
    "\n",
    "\n",
    "def main():\n",
    "    \"\"\"Main function to execute the pipeline.\"\"\"\n",
    "    # Define file paths\n",
    "    train_path = \"beach_profile_data/processed_data/beachdata_train.xlsx\"\n",
    "    test_path = \"beach_profile_data/processed_data/beachdata_test.xlsx\"\n",
    "    \n",
    "    # Load the data\n",
    "    train_df, test_df = load_data(train_path, test_path)\n",
    "    \n",
    "    # Preprocess the data\n",
    "    train_df, test_df, feature_names = preprocess_data(train_df, test_df)\n",
    "    \n",
    "    # Perform feature selection\n",
    "    # train_df, selected_feature_names = feature_selection(train_df, feature_names)\n",
    "    \n",
    "    # Enhance dataset with Bruun-Dean models parameters\n",
    "    train_df = bruun_dean_model_parameters(train_df)\n",
    "    test_df = bruun_dean_model_parameters(test_df)\n",
    "    \n",
    "    # Train the deep learning model\n",
    "    model = train_deep_learning_model(train_df)\n",
    "    \n",
    "    # Evaluate the model\n",
    "    mse = evaluate_model(model, test_df)\n",
    "    \n",
    "    return mse"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "78ddcc0f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.8388117551803589"
      ]
     },
     "execution_count": 49,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "main()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "114f0839",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/100, Loss: nan\n",
      "Epoch 2/100, Loss: nan\n",
      "Epoch 3/100, Loss: nan\n",
      "Epoch 4/100, Loss: nan\n",
      "Epoch 5/100, Loss: nan\n",
      "Epoch 6/100, Loss: nan\n",
      "Epoch 7/100, Loss: nan\n",
      "Epoch 8/100, Loss: nan\n",
      "Epoch 9/100, Loss: nan\n",
      "Epoch 10/100, Loss: nan\n",
      "Epoch 11/100, Loss: nan\n",
      "Epoch 12/100, Loss: nan\n",
      "Epoch 13/100, Loss: nan\n",
      "Epoch 14/100, Loss: nan\n",
      "Epoch 15/100, Loss: nan\n",
      "Epoch 16/100, Loss: nan\n",
      "Epoch 17/100, Loss: nan\n",
      "Epoch 18/100, Loss: nan\n",
      "Epoch 19/100, Loss: nan\n",
      "Epoch 20/100, Loss: nan\n",
      "Epoch 21/100, Loss: nan\n",
      "Epoch 22/100, Loss: nan\n",
      "Epoch 23/100, Loss: nan\n",
      "Epoch 24/100, Loss: nan\n",
      "Epoch 25/100, Loss: nan\n",
      "Epoch 26/100, Loss: nan\n",
      "Epoch 27/100, Loss: nan\n",
      "Epoch 28/100, Loss: nan\n",
      "Epoch 29/100, Loss: nan\n",
      "Epoch 30/100, Loss: nan\n",
      "Epoch 31/100, Loss: nan\n",
      "Epoch 32/100, Loss: nan\n",
      "Epoch 33/100, Loss: nan\n",
      "Epoch 34/100, Loss: nan\n",
      "Epoch 35/100, Loss: nan\n",
      "Epoch 36/100, Loss: nan\n",
      "Epoch 37/100, Loss: nan\n",
      "Epoch 38/100, Loss: nan\n",
      "Epoch 39/100, Loss: nan\n",
      "Epoch 40/100, Loss: nan\n",
      "Epoch 41/100, Loss: nan\n",
      "Epoch 42/100, Loss: nan\n",
      "Epoch 43/100, Loss: nan\n",
      "Epoch 44/100, Loss: nan\n",
      "Epoch 45/100, Loss: nan\n",
      "Epoch 46/100, Loss: nan\n",
      "Epoch 47/100, Loss: nan\n",
      "Epoch 48/100, Loss: nan\n",
      "Epoch 49/100, Loss: nan\n",
      "Epoch 50/100, Loss: nan\n",
      "Epoch 51/100, Loss: nan\n",
      "Epoch 52/100, Loss: nan\n",
      "Epoch 53/100, Loss: nan\n",
      "Epoch 54/100, Loss: nan\n",
      "Epoch 55/100, Loss: nan\n",
      "Epoch 56/100, Loss: nan\n",
      "Epoch 57/100, Loss: nan\n",
      "Epoch 58/100, Loss: nan\n",
      "Epoch 59/100, Loss: nan\n",
      "Epoch 60/100, Loss: nan\n",
      "Epoch 61/100, Loss: nan\n",
      "Epoch 62/100, Loss: nan\n",
      "Epoch 63/100, Loss: nan\n",
      "Epoch 64/100, Loss: nan\n",
      "Epoch 65/100, Loss: nan\n",
      "Epoch 66/100, Loss: nan\n",
      "Epoch 67/100, Loss: nan\n",
      "Epoch 68/100, Loss: nan\n",
      "Epoch 69/100, Loss: nan\n",
      "Epoch 70/100, Loss: nan\n",
      "Epoch 71/100, Loss: nan\n",
      "Epoch 72/100, Loss: nan\n",
      "Epoch 73/100, Loss: nan\n",
      "Epoch 74/100, Loss: nan\n",
      "Epoch 75/100, Loss: nan\n",
      "Epoch 76/100, Loss: nan\n",
      "Epoch 77/100, Loss: nan\n",
      "Epoch 78/100, Loss: nan\n",
      "Epoch 79/100, Loss: nan\n",
      "Epoch 80/100, Loss: nan\n",
      "Epoch 81/100, Loss: nan\n",
      "Epoch 82/100, Loss: nan\n",
      "Epoch 83/100, Loss: nan\n",
      "Epoch 84/100, Loss: nan\n",
      "Epoch 85/100, Loss: nan\n",
      "Epoch 86/100, Loss: nan\n",
      "Epoch 87/100, Loss: nan\n",
      "Epoch 88/100, Loss: nan\n",
      "Epoch 89/100, Loss: nan\n",
      "Epoch 90/100, Loss: nan\n",
      "Epoch 91/100, Loss: nan\n",
      "Epoch 92/100, Loss: nan\n",
      "Epoch 93/100, Loss: nan\n",
      "Epoch 94/100, Loss: nan\n",
      "Epoch 95/100, Loss: nan\n",
      "Epoch 96/100, Loss: nan\n",
      "Epoch 97/100, Loss: nan\n",
      "Epoch 98/100, Loss: nan\n",
      "Epoch 99/100, Loss: nan\n",
      "Epoch 100/100, Loss: nan\n",
      "Test Loss: nan\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "from torch.utils.data import Dataset, DataLoader\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "from sklearn.preprocessing import StandardScaler, OneHotEncoder\n",
    "from sklearn.compose import ColumnTransformer\n",
    "from sklearn.pipeline import Pipeline\n",
    "from sklearn.model_selection import train_test_split\n",
    "\n",
    "\n",
    "# Bruun/Dean inspired model comment\n",
    "# Bruun: Δy = S * (ΔSL) / (L + ΔSL/S)\n",
    "# Dean: y = A * x^(2/3) (empirical beach profile)\n",
    "# We'll provide A * x^(2/3) as an additional feature.\n",
    "\n",
    "def dean_feature(x):\n",
    "    return np.power(x, 2 / 3)\n",
    "\n",
    "\n",
    "# Custom Dataset\n",
    "class BeachProfileDataset(Dataset):\n",
    "    def __init__(self, dataframe, preprocessor=None, fit_preprocessor=False):\n",
    "        self.df = dataframe.copy()\n",
    "        self.x_raw = self.df['x'].values.reshape(-1, 1)\n",
    "        self.y = self.df['y'].values.astype(np.float32)\n",
    "        self.df['dean_feature'] = dean_feature(self.df['x'])\n",
    "\n",
    "        self.feature_cols = [col for col in self.df.columns if col != 'y']\n",
    "        self.X = self.df[self.feature_cols]\n",
    "\n",
    "        if preprocessor is None:\n",
    "            categorical_cols = self.X.select_dtypes(include='object').columns.tolist()\n",
    "            numerical_cols = self.X.select_dtypes(include=['int64', 'float64']).columns.tolist()\n",
    "\n",
    "            self.preprocessor = ColumnTransformer([\n",
    "                ('num', StandardScaler(), numerical_cols),\n",
    "                ('cat', OneHotEncoder(sparse_output=False, handle_unknown='ignore'), categorical_cols)\n",
    "            ])\n",
    "        else:\n",
    "            self.preprocessor = preprocessor\n",
    "\n",
    "        if fit_preprocessor:\n",
    "            self.X = self.preprocessor.fit_transform(self.X)\n",
    "        else:\n",
    "            self.X = self.preprocessor.transform(self.X)\n",
    "\n",
    "        self.X = torch.tensor(self.X, dtype=torch.float32)\n",
    "        self.y = torch.tensor(self.y, dtype=torch.float32).view(-1, 1)\n",
    "\n",
    "    def __len__(self):\n",
    "        return len(self.y)\n",
    "\n",
    "    def __getitem__(self, idx):\n",
    "        return self.X[idx], self.y[idx]\n",
    "\n",
    "\n",
    "# Neural Network Model\n",
    "class BeachNet(nn.Module):\n",
    "    def __init__(self, input_dim):\n",
    "        super(BeachNet, self).__init__()\n",
    "        self.model = nn.Sequential(\n",
    "            nn.Linear(input_dim, 64),\n",
    "            nn.ReLU(),\n",
    "            nn.Linear(64, 32),\n",
    "            nn.ReLU(),\n",
    "            nn.Linear(32, 1)\n",
    "        )\n",
    "\n",
    "    def forward(self, x):\n",
    "        return self.model(x)\n",
    "\n",
    "\n",
    "# Load Data\n",
    "train_df = pd.read_excel(\"beach_profile_data/processed_data/beachdata_train.xlsx\")\n",
    "test_df = pd.read_excel(\"beach_profile_data/processed_data/beachdata_test.xlsx\")\n",
    "train_df = train_df.dropna()\n",
    "test_df = test_df.dropna()\n",
    "\n",
    "# Initialize Datasets\n",
    "train_dataset = BeachProfileDataset(train_df, fit_preprocessor=True)\n",
    "test_dataset = BeachProfileDataset(test_df, preprocessor=train_dataset.preprocessor)\n",
    "\n",
    "train_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)\n",
    "test_loader = DataLoader(test_dataset, batch_size=32, shuffle=False)\n",
    "\n",
    "# Model Initialization\n",
    "input_dim = train_dataset.X.shape[1]\n",
    "model = BeachNet(input_dim)\n",
    "\n",
    "# Training Components\n",
    "criterion = nn.MSELoss()\n",
    "optimizer = torch.optim.Adam(model.parameters(), lr=0.001)\n",
    "\n",
    "# Training Loop\n",
    "def train_model(model, loader, optimizer, criterion, epochs=100):\n",
    "    model.train()\n",
    "    for epoch in range(epochs):\n",
    "        epoch_loss = 0.0\n",
    "        for inputs, targets in loader:\n",
    "            optimizer.zero_grad()\n",
    "            outputs = model(inputs)\n",
    "            loss = criterion(outputs, targets)\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "            epoch_loss += loss.item()\n",
    "        print(f\"Epoch {epoch + 1}/{epochs}, Loss: {epoch_loss / len(loader):.4f}\")\n",
    "\n",
    "# Evaluation Loop\n",
    "def evaluate_model(model, loader, criterion):\n",
    "    model.eval()\n",
    "    total_loss = 0.0\n",
    "    with torch.no_grad():\n",
    "        for inputs, targets in loader:\n",
    "            outputs = model(inputs)\n",
    "            loss = criterion(outputs, targets)\n",
    "            total_loss += loss.item()\n",
    "    print(f\"Test Loss: {total_loss / len(loader):.4f}\")\n",
    "\n",
    "\n",
    "# Train and Evaluate\n",
    "train_model(model, train_loader, optimizer, criterion, epochs=100)\n",
    "evaluate_model(model, test_loader, criterion)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "f4263a6b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Plot saved as cumulative_runnable_code.png\n"
     ]
    },
    {
     "data": {
      "image/png": "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NlEHKkafz8jIUHm+fHHXvsrCzs5OvuoIAMyfP1+thFrdaSWVLad59eqVSveGxcfHF3sNrAzvWVU+WQfyViJR7PC//PJLob8QxQRVlcSlKnwsm09xzlZJN9tIpVJcvHhRrfbzd5YrieKNHq1atVLrHPkU719QN05NderUSemmG39/f62NVij+ta/qzUaK5d58PZ2dnZXeCN/c3bAwly5dKvGjWMUbfsr79S8tdfp/UlISbt68WWKbZfHRumIfuH//vtJSoUVR/B04ODhoNF89n4uLi/zG0qysLOzatQsA8OjRI/mSa2ZmZiUugVYcOzs7fPbZZ9i3b5/82J07d/DkyRMNItc+dX/Purw+KVKnzwNQWja2KGXR552dnVGrVi35Y1WuffHx8fjnn3/kj0v7XlIRfPHFF/JlgO/du6f0x3BJ1MlpsrOzlV6zykAURZVyC8W8wt7evsA1sDK8Z1WLZB3I6/D5H31kZmbixx9/LFBGcb5xaGhoiUmJLue/a5vimrwlfbS0d+9etf/6jIiIKHHZuPj4eKUllEpa6rEoAwYMkH+/evXqcp3nJwgCZs2aJX985coVrFixQu12cnNzCywxpThqf/369RITxvT0dGzfvr3Q+vkUX+MtW7aUGNfmzZtLLKP4+gcEBCiNaFRU6vT/devWqXSDmeJScNq6Ia1JkybyaSVSqVSlN+7169fLvy/t/6nCKN44mh+HYjwDBw5Ua45xUTp06KC0SsSLFy80blOb1P096/L6pEidPh8SEqLSvh9l0ecB5X67cePGEstv3LhRPkji5OSExo0bay2W8lajRg18+eWX8seLFi1S+bVVzGlKWm5z//79leJa/SZ137cKuwZWhvesapOs16xZE5988on88f/+978Cq400adJEntBHR0crrSv7pkOHDhW4saoyq1evnvz7/fv3F1kuLi4On3/+eanOMXPmzGJXmpk5c6b8P4mbm1upN6/68MMP5SMR165dw6JFi1SuGx8fr/F6z6NHj1a6a3/27NlKG9mUJDw8HD179iywpJu7u7vSMnnTpk0r9qI9b948+ZJnlpaWhd7op7gG986dO4sdPbt48WKhGyu9afDgwWjQoAGAvP9HH3/8scoJSWpqqlrzUrVF1f7/8OFDlfuT4lJvkZGRpQ9OgSAImDx5svzx4sWLi217//79Stepjz76SCtxAHn7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uhT5nLOzc7HPl7XU1FQ8evRI/jgsLAw3btyAtbU1XF1dMWfOHERGRmLz5s0AgI8++gi//PILZs2ahfHjx+PUqVPYuXMnDh06pKsfgYiIiIhIicZLNy5YsAAA4O3trXEwmrh69Sq6desmf5w/XWXs2LHYuHEjoqOj5ctEAkDdunVx6NAhfP7551i5ciVq166NdevWcdlGIiIiIqowtJas61rXrl2LnTdf2O6kXbt2xfXr18swKiIiIiKi0qt869cQEREREVUTTNaJiIiIiCoolabBLF68WOnx/Pnzi3xOE4rtEhERERFVdyol6wsXLlRa7kYxqX7zOU0wWSciIiIiek3lG0zzb94sagdTTVXWtS+JiIiIiMqKSsl6cSu+VJTVYIiIiIiIqhom60REREREFRRXgyEiIiIiqqCYrBMRERERVVBM1omIiIiIKigm60REREREFZRKN5ieO3eurOMAAHTu3LlczkNEREREVBmolKx37dq1zNdBFwQBubm5ZXoOIiIiIqLKRO1NkYiIiIiIqHyolKx37tyZO4wSEREREZUzlZL1M2fOlHEYRERERET0Jq4GQ0RERERUQTFZJyIiIiKqoJisExERERFVUEzWiYiIiIgqKCbrREREREQVlEqrwejr68u/f3PzIsXnNMFNkYiIiIiqNqlMRHBYAkLiBdiEJcC3QS3o63F58OKolKyLoghBEArdGKm454iIiIiIAODo7WgsOnAX0UmZAPSx+eFVOFoZY4GfB/o2c9R1eBWWytNgikvGmagTERERUVGO3o7GlK3X/k3UX4tJysSUrddw9Ha0jiKr+FRK1mUymfxLKpUW+ZwmX2+2S0RERESVn1QmYtGBuyhsaDf/2KIDdyGVcfC3MCpNgyEiIiIiKk56di6iEjMRnZSB6MRMRP37793opAIj6opEANFJmbgclgDf+jblF3AlwWSdiIiIiIqVnSvDi+RMRCVmICop442kPO/7xPQcjc4Rm1J0Ql+dMVknIiIiqsakMhFxKVnykfDopAxEJr7+PiopE/GpWVDlFkVziQEcrYzhWMMETlbGcLQyQUZ2Ltace1Ji3VoWxlr4aaoeJutEREREVZQoikhIy0Z0Ut6oeHTS6+kp+Y9fJGciV4X54kYGevIE3LGGMZwU/nWqkfe9pbFhgXpSmYh9oVGIScosdN66AMDByhjeda01/4Gr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KZzHxMQgJiamBaIiIiIiItKckeoiqs2cOROJiYkoKirCoEGD8M9//hM///xzq5/QT0RERESkT1qPrMtkMoVzURTx4Ycf4sMPP9SoHUEQUFlZqW04RERERERthtbJuiiKEARB+q8gCAqvERERERFR02idrAP/S8qZnBMRERER6Y7ONkUiIiIiIiLd0skDpkREREREpHtM1omIiIiIDBSTdSIiIiIiA8VknYiIiIjIQOlkNZiGlJWVobi4GHK5XO06Hh4ezRUOEREREVGro7Nkvbq6Gtu2bcPnn3+OkydPoqCgQKP63BSJiIiIiEiRTpL17OxshIaG4ty5cwC43joRERERkS5onazfv38fzz77LLKyshSuW1hYwN7eHiYmJtregoiIiIjosaR1sr5u3TpkZWVBEAQYGxvjzTffxKuvvgofHx9dxEdERERE9NjSOlnfvXu3dLxt2za8+OKL2jZJRERERETQwdKNV65cgSAI8PPzY6JORERERKRDWifr5eXlAABfX19tmyIiIiIiojq0TtY7deoEABqtp05ERERERKppnawHBgZCFEVp2UYiIiIiItINrZP1mTNnwsjICBkZGTh16pQuYiIiIiIiIuggWR8wYADeeecdiKKIv/71r7h9+7Yu4iIiIiIieuxpnawDwNKlSxEdHY3MzEz07dsX69atw61bt3TRNBERERHRY0vrdda7du0qHZuYmCA/Px+RkZGIjIyEnZ0d7OzsIAiCynYEQcDVq1e1DYeIiIiIqM3QOlnPzs5WSMZrj0VRRGFhIYqKilS2IYqiWgk9EREREdHjROtkHahJtpvyGhERERERNU7rZD0rK0sXcRARERER0SO0TtY9PT11EQcRERERET1CJ6vBEBERERGR7jFZJyIiIiIyUEzWiYiIiIgMFJN1IiIiIiIDpdNNkbTBTZGIiIiIiBTpfFMkddRde10QBG6KRERERETUgGbfFKkxtUk6N00iIiIiImpYi22KVF1djaKiIpw7dw47d+7Evn37YG5ujvj4eDzzzDPahkFERERE1Oa0+KZIvr6+mDJlCvbt24eJEydi5syZ2LlzJ55//nltQyEiIiIialP0thrM2LFjkZCQALlcjmnTpuHmzZv6CoWIiIiIyCDpdenGKVOmwMPDA8XFxdiwYYNO2oyPj0fnzp1hbm6OgIAAnDhxotGymzZtwtCh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",
      "text/plain": [
       "<Figure size 800x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "# Data from the previous analysis\n",
    "iterations = [1, 2, 3, 4, 5]\n",
    "cumulative_runnable_code = [10/30, 16/30, 24/30, 27/30, 28/30]\n",
    "\n",
    "# Create the plot\n",
    "plt.figure(figsize=(8, 5)) # Adjust figure size for better readability\n",
    "plt.plot(iterations, cumulative_runnable_code, marker='o', linestyle='-')\n",
    "\n",
    "# Add title and labels\n",
    "plt.title('Runnable Code ratio vs. Iteration Number', fontsize=24, pad=25)\n",
    "plt.xlabel('Iteration Number', fontsize=24)\n",
    "plt.ylabel('Runnable Code probability', fontsize=24)\n",
    "\n",
    "# Add grid for better readability\n",
    "plt.grid(True)\n",
    "\n",
    "# Set x-axis ticks to be integers\n",
    "plt.xticks(iterations)\n",
    "# Set y-axis ticks to start from 0 and have reasonable intervals\n",
    "plt.yticks(np.arange(0.2, 1.1, 0.1)) \n",
    "\n",
    "print(\"Plot saved as cumulative_runnable_code.png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "72bf7646",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np # Often useful, though not strictly necessary for this basic plot\n",
    "\n",
    "# --- 1. Data (Replace with your actual data) ---\n",
    "iterations = [1, 2, 3, 4, 5]\n",
    "human_eval_data = [64.6, 82.9, 88.4, 90.2, 90.9]\n",
    "human_eval_et_data = [52.4, 76.2, 84.1, 87.8, 89.6]\n",
    "mbpp_data = [63.9, 85.5, 91.1, 93.7, 93.0]\n",
    "mbpp_et_data = [52.2, 78.5, 86.4, 89.0, 90.4]\n",
    "\n",
    "# --- 2. Create the Plot ---\n",
    "plt.figure(figsize=(10, 6)) # Adjust figure size as needed\n",
    "\n",
    "# Plot each data series\n",
    "plt.plot(iterations, human_eval_data, label='HumanEval', color='blue', linestyle='-', marker='o', linewidth=2, markersize=8)\n",
    "plt.plot(iterations, human_eval_et_data, label='HumanEval-ET', color='red', linestyle='--', marker='s', linewidth=2, markersize=8)\n",
    "plt.plot(iterations, mbpp_data, label='MBPP', color='green', linestyle='-.', marker='^', linewidth=2, markersize=8)\n",
    "plt.plot(iterations, mbpp_et_data, label='MBPP-ET', color='magenta', linestyle=':', marker='d', linewidth=2, markersize=8)\n",
    "\n",
    "# --- 3. Customize the Plot ---\n",
    "# Title and Labels\n",
    "plt.title('Pass@1 of LCP with Different Number of Iterations on GPT-3.5-turbo', fontsize=18)\n",
    "plt.xlabel('Iterations', fontsize=16)\n",
    "plt.ylabel('Pass@1 (%)', fontsize=16)\n",
    "\n",
    "# X and Y axis ticks and limits\n",
    "plt.xticks(iterations, fontsize=14) # Ensure ticks are at 1, 2, 3, 4, 5\n",
    "plt.yticks(np.arange(45, 101, 5), fontsize=14) # Y-axis ticks from 55 to 100 with a step of 5\n",
    "plt.ylim(45, 100) # Set Y-axis limits\n",
    "\n",
    "# Legend\n",
    "plt.legend(fontsize=16)\n",
    "\n",
    "# Grid\n",
    "plt.grid(True, linestyle='--', alpha=0.7) # Light gray dashed grid\n",
    "\n",
    "# Improve layout\n",
    "plt.tight_layout()\n",
    "\n",
    "# --- 4. Show or Save the Plot ---\n",
    "plt.show()\n",
    "# To save the figure:\n",
    "# plt.savefig('pass1_lcp_graph.png', dpi=300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "02f33886",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np # Often useful, though not strictly necessary for this basic plot\n",
    "\n",
    "# --- 1. Data (Replace with your actual data) ---\n",
    "iterations = [1, 2, 3, 4, 5]\n",
    "human_eval_data = [64.6, 82.9, 88.4, 90.2, 90.9]\n",
    "human_eval_et_data = [52.4, 76.2, 84.1, 87.8, 89.6]\n",
    "mbpp_data = [63.9, 85.5, 91.1, 93.7, 93.0]\n",
    "mbpp_et_data = [52.2, 78.5, 86.4, 89.0, 90.4]\n",
    "\n",
    "# --- 2. Create the Plot ---\n",
    "plt.figure(figsize=(10, 6)) # Adjust figure size as needed\n",
    "\n",
    "# Plot each data series\n",
    "plt.plot(iterations, human_eval_data, label='HumanEval', color='blue', linestyle='-', marker='o', linewidth=2, markersize=8)\n",
    "plt.plot(iterations, human_eval_et_data, label='HumanEval-ET', color='red', linestyle='--', marker='s', linewidth=2, markersize=8)\n",
    "plt.plot(iterations, mbpp_data, label='MBPP', color='green', linestyle='-.', marker='^', linewidth=2, markersize=8)\n",
    "plt.plot(iterations, mbpp_et_data, label='MBPP-ET', color='magenta', linestyle=':', marker='d', linewidth=2, markersize=8)\n",
    "\n",
    "# --- 3. Customize the Plot ---\n",
    "# Title and Labels\n",
    "# Increase fontsize for the title (e.g., from 18 to 22)\n",
    "plt.title('Pass@1 of LCP with Different Number of Iterations on GPT-3.5-turbo', fontsize=20)\n",
    "# Increase fontsize for the x-axis label (e.g., from 16 to 20)\n",
    "plt.xlabel('Iterations', fontsize=30)\n",
    "# Increase fontsize for the y-axis label (e.g., from 16 to 20)\n",
    "plt.ylabel('Pass@1 (%)', fontsize=30)\n",
    "\n",
    "# X and Y axis ticks and limits\n",
    "# You can also increase tick label font sizes if needed\n",
    "plt.xticks(iterations, fontsize=16) # Increased from 14 to 16\n",
    "plt.yticks(np.arange(45, 101, 5), fontsize=16) # Increased from 14 to 16\n",
    "plt.ylim(45, 100) # Set Y-axis limits\n",
    "\n",
    "# Legend\n",
    "# Increase fontsize for the legend (e.g., from 16 to 20)\n",
    "plt.legend(fontsize=30)\n",
    "\n",
    "# Grid\n",
    "plt.grid(True, linestyle='--', alpha=0.7) # Light gray dashed grid\n",
    "\n",
    "# Improve layout\n",
    "plt.tight_layout()\n",
    "\n",
    "# --- 4. Show or Save the Plot ---\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e70d1aa7",
   "metadata": {},
   "source": [
    "### baseline test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "871a5fb3",
   "metadata": {},
   "outputs": [],
   "source": [
    "import re\n",
    "import traceback\n",
    "\n",
    "def extract_python_code_simplified(llm_output):\n",
    "    # Try to find ```python ... ``` block\n",
    "    python_block_match = re.search(r\"```python\\n(.*?)\\n```\", llm_output, re.DOTALL)\n",
    "    if python_block_match:\n",
    "        return python_block_match.group(1).strip()\n",
    "    \n",
    "    # Try to find generic ``` ... ``` block\n",
    "    generic_block_match = re.search(r\"```\\n(.*?)\\n```\", llm_output, re.DOTALL)\n",
    "    if generic_block_match:\n",
    "        return generic_block_match.group(1).strip()\n",
    "        \n",
    "    # If no blocks found, assume the entire output is code\n",
    "    return llm_output.strip()\n",
    "\n",
    "def check_code_runnability_simplified(python_code):\n",
    "    if not python_code:\n",
    "        return False, \"No Python code provided to check.\"\n",
    "\n",
    "    execution_scope = {}\n",
    "    \n",
    "    try:\n",
    "        # Compile and execute the script's top-level code\n",
    "        # This will define functions, including main(), in execution_scope\n",
    "        compiled_code = compile(python_code, '<string>', 'exec')\n",
    "        exec(compiled_code, execution_scope)\n",
    "    except SyntaxError as e:\n",
    "        return False, f\"Syntax Error: {e.msg} (line {e.lineno}, offset {e.offset})\"\n",
    "    except Exception as e:\n",
    "        # Errors during the initial exec (e.g., import errors at top level, issues in global code)\n",
    "        return False, f\"Error during script execution (outside main): {type(e).__name__}: {e}\\n{traceback.format_exc()}\"\n",
    "\n",
    "    # Check if main() was defined\n",
    "    if \"main\" not in execution_scope:\n",
    "        return False, \"Code does not define a main() function.\"\n",
    "    \n",
    "    main_func = execution_scope[\"main\"]\n",
    "    \n",
    "    if not callable(main_func):\n",
    "        return False, \"'main' is defined but is not a callable function.\"\n",
    "\n",
    "    # Call the main function\n",
    "    try:\n",
    "        main_func()\n",
    "    except Exception as e:\n",
    "        return False, f\"Error during main() execution: {type(e).__name__}: {e}\\n{traceback.format_exc()}\"\n",
    "    \n",
    "    return True, \"Code is syntactically correct and main() executed successfully.\"\n",
    "\n",
    "def extract_and_test_llm_code_simplified(llm_output):\n",
    "    extracted_code = extract_python_code_simplified(llm_output)\n",
    "    \n",
    "    # Since extract_python_code_simplified always returns a string,\n",
    "    # we don't need to check if extracted_code is None (unless it's empty).\n",
    "    if not extracted_code: # Handles case where llm_output itself was empty or only whitespace\n",
    "        return False, \"No Python code found or extracted.\", \"\"\n",
    "    \n",
    "    is_runnable, message = check_code_runnability_simplified(extracted_code)\n",
    "    return is_runnable, message, extracted_code"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3f628cee",
   "metadata": {},
   "outputs": [],
   "source": [
    "# All other relevant columns you might select as features are expected to be in numerical (integer or float) or categorical (string) format.\n",
    "\n",
    "base_prompt = \"\"\"Please refer to the Bruun model and the Dean model to build a mathematical model to discuss the change of sea level height with respect to the distance from the starting point, and build a deep learning model based on our data. The following is our data path and structure:\n",
    "\n",
    "Data File Paths:\n",
    "\n",
    "Training Data: \"beach_profile_data/processed_data/beachdata_train.xlsx\"\n",
    "Test Data: \"beach_profile_data/processed_data/beachdata_test.xlsx\"\n",
    "Data Structure Insights:\n",
    "The training and testing datasets contain several columns. Key columns include:\n",
    "\n",
    "x: A numerical column representing the distance from a profile's origin; this is a primary input for predicting y.\n",
    "y: A numerical column representing the elevation; this is the target variable for prediction.\n",
    "All other relevant columns you might select as features are expected to be in numerical (integer or float) or categorical (string) format.\n",
    "\n",
    "create the code directly and The script should not run the main training or evaluation logic directly when the script file is executed. Instead, it should define all necessary functions with a main function main() that can be run WITHOUT ANY input. DO NOT USE tensorflow. Use provided data path in your code.\"\"\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "3520674f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test Loss: 0.8933709357395645\n",
      "Test Loss: 0.6456502918154001\n",
      "Epoch 0, Loss: 2.3373\n",
      "Epoch 1, Loss: 1.5680\n",
      "Epoch 2, Loss: 1.0930\n",
      "Epoch 3, Loss: 1.4445\n",
      "Epoch 4, Loss: 0.8948\n",
      "Epoch 5, Loss: 0.9418\n",
      "Epoch 6, Loss: 0.9090\n",
      "Epoch 7, Loss: 0.7271\n",
      "Epoch 8, Loss: 0.8081\n",
      "Epoch 9, Loss: 0.7366\n",
      "Epoch 10, Loss: 0.7620\n",
      "Epoch 11, Loss: 0.8191\n",
      "Epoch 12, Loss: 0.7962\n",
      "Epoch 13, Loss: 0.7093\n",
      "Epoch 14, Loss: 0.8877\n",
      "Epoch 15, Loss: 0.8819\n",
      "Epoch 16, Loss: 0.8429\n",
      "Epoch 17, Loss: 0.7975\n",
      "Epoch 18, Loss: 0.6852\n",
      "Epoch 19, Loss: 0.7418\n",
      "Epoch 20, Loss: 0.8705\n",
      "Epoch 21, Loss: 0.7138\n",
      "Epoch 22, Loss: 0.6889\n",
      "Epoch 23, Loss: 0.6921\n",
      "Epoch 24, Loss: 0.7269\n",
      "Epoch 25, Loss: 0.6661\n",
      "Epoch 26, Loss: 0.7310\n",
      "Epoch 27, Loss: 0.6847\n",
      "Epoch 28, Loss: 0.6812\n",
      "Epoch 29, Loss: 0.7103\n",
      "Epoch 30, Loss: 0.6840\n",
      "Epoch 31, Loss: 0.6819\n",
      "Epoch 32, Loss: 0.7459\n",
      "Epoch 33, Loss: 0.6929\n",
      "Epoch 34, Loss: 0.7093\n",
      "Epoch 35, Loss: 0.6916\n",
      "Epoch 36, Loss: 0.7129\n",
      "Epoch 37, Loss: 0.7082\n",
      "Epoch 38, Loss: 0.7124\n",
      "Epoch 39, Loss: 0.6713\n",
      "Epoch 40, Loss: 0.6819\n",
      "Epoch 41, Loss: 0.6715\n",
      "Epoch 42, Loss: 0.6749\n",
      "Epoch 43, Loss: 0.6833\n",
      "Epoch 44, Loss: 0.6719\n",
      "Epoch 45, Loss: 0.6722\n",
      "Epoch 46, Loss: 0.6750\n",
      "Epoch 47, Loss: 0.6854\n",
      "Epoch 48, Loss: 0.6883\n",
      "Epoch 49, Loss: 0.6689\n",
      "Epoch 50, Loss: 0.6707\n",
      "Epoch 51, Loss: 0.6620\n",
      "Epoch 52, Loss: 0.6748\n",
      "Epoch 53, Loss: 0.6729\n",
      "Epoch 54, Loss: 0.6575\n",
      "Epoch 55, Loss: 0.6669\n",
      "Epoch 56, Loss: 0.6624\n",
      "Epoch 57, Loss: 0.6593\n",
      "Epoch 58, Loss: 0.6644\n",
      "Epoch 59, Loss: 0.6580\n",
      "Epoch 60, Loss: 0.6840\n",
      "Epoch 61, Loss: 0.6595\n",
      "Epoch 62, Loss: 0.6572\n",
      "Epoch 63, Loss: 0.6568\n",
      "Epoch 64, Loss: 0.6734\n",
      "Epoch 65, Loss: 0.6600\n",
      "Epoch 66, Loss: 0.6729\n",
      "Epoch 67, Loss: 0.6526\n",
      "Epoch 68, Loss: 0.6497\n",
      "Epoch 69, Loss: 0.6630\n",
      "Epoch 70, Loss: 0.6512\n",
      "Epoch 71, Loss: 0.6576\n",
      "Epoch 72, Loss: 0.6546\n",
      "Epoch 73, Loss: 0.6680\n",
      "Epoch 74, Loss: 0.6502\n",
      "Epoch 75, Loss: 0.6508\n",
      "Epoch 76, Loss: 0.6625\n",
      "Epoch 77, Loss: 0.6469\n",
      "Epoch 78, Loss: 0.6535\n",
      "Epoch 79, Loss: 0.6696\n",
      "Epoch 80, Loss: 0.6672\n",
      "Epoch 81, Loss: 0.6520\n",
      "Epoch 82, Loss: 0.6628\n",
      "Epoch 83, Loss: 0.6626\n",
      "Epoch 84, Loss: 0.6527\n",
      "Epoch 85, Loss: 0.6506\n",
      "Epoch 86, Loss: 0.6583\n",
      "Epoch 87, Loss: 0.6588\n",
      "Epoch 88, Loss: 0.6506\n",
      "Epoch 89, Loss: 0.6545\n",
      "Epoch 90, Loss: 0.6595\n",
      "Epoch 91, Loss: 0.6641\n",
      "Epoch 92, Loss: 0.6679\n",
      "Epoch 93, Loss: 0.6605\n",
      "Epoch 94, Loss: 0.6650\n",
      "Epoch 95, Loss: 0.6556\n",
      "Epoch 96, Loss: 0.6457\n",
      "Epoch 97, Loss: 0.6728\n",
      "Epoch 98, Loss: 0.6610\n",
      "Epoch 99, Loss: 0.6890\n",
      "Predictions: [array([1.6198033], dtype=float32), array([1.4871467], dtype=float32), array([1.3640963], dtype=float32), array([1.2471838], dtype=float32), array([1.152139], dtype=float32), array([1.0360154], dtype=float32), array([0.9035622], dtype=float32), array([0.768125], dtype=float32), array([0.6581423], dtype=float32), array([0.56027144], dtype=float32), array([0.46938512], dtype=float32), array([0.3913764], dtype=float32), array([0.34131193], dtype=float32), array([0.32737568], dtype=float32), array([0.30890185], dtype=float32), array([1.6198033], dtype=float32), array([1.5434114], dtype=float32), array([1.480285], dtype=float32), array([1.4107547], dtype=float32), array([1.3425965], dtype=float32), array([1.2874246], dtype=float32), array([1.2264885], dtype=float32), array([1.1678519], dtype=float32), array([1.1072992], dtype=float32), array([1.0375484], dtype=float32), array([0.97277987], dtype=float32), array([0.903173], dtype=float32), array([0.8300058], dtype=float32), array([0.761898], dtype=float32), array([0.6901959], dtype=float32), array([0.63521767], dtype=float32), array([0.55711305], dtype=float32), array([0.50033283], dtype=float32), array([0.4363913], dtype=float32), array([0.36400935], dtype=float32), array([0.32038593], dtype=float32), array([0.25383806], dtype=float32), array([0.16214882], dtype=float32), array([0.10789411], dtype=float32), array([1.6198033], dtype=float32), array([1.5200821], dtype=float32), array([1.3234495], dtype=float32), array([1.2349198], dtype=float32), array([0.5036578], dtype=float32), array([0.5008443], dtype=float32), array([0.46785048], dtype=float32), array([0.42974123], dtype=float32), array([0.4115819], dtype=float32), array([0.37321696], dtype=float32), array([0.33058324], dtype=float32), array([0.11567609], dtype=float32), array([0.04849366], dtype=float32), array([-0.02624603], dtype=float32), array([1.6198033], dtype=float32), array([1.5141352], dtype=float32), array([1.4167016], dtype=float32), array([1.3261323], dtype=float32), array([1.2238058], dtype=float32), array([1.1145809], dtype=float32), array([0.9638862], dtype=float32), array([0.7833033], dtype=float32), array([0.61346865], dtype=float32), array([0.44790074], dtype=float32), array([0.2836838], dtype=float32), array([0.16664271], dtype=float32), array([0.06565927], dtype=float32), array([-0.06098338], dtype=float32), array([-0.23580058], dtype=float32), array([-0.36009905], dtype=float32), array([-0.45400319], dtype=float32), array([-0.43057796], dtype=float32), array([-0.3976209], dtype=float32), array([-0.35805163], dtype=float32), array([-0.29762807], dtype=float32), array([-0.2342601], dtype=float32), array([-0.17571737], dtype=float32), array([-0.13949086], dtype=float32), array([-0.12119426], dtype=float32), array([1.6198033], dtype=float32), array([1.5438688], dtype=float32), array([1.4761682], dtype=float32), array([1.3851382], dtype=float32), array([1.2809092], dtype=float32), array([1.1617199], dtype=float32), array([1.0942688], dtype=float32), array([0.98427725], dtype=float32), array([0.8537462], dtype=float32), array([0.68283045], dtype=float32), array([0.56027144], dtype=float32), array([0.46145633], dtype=float32), array([0.37500724], dtype=float32), array([0.2939406], dtype=float32), array([0.25049138], dtype=float32), array([1.6198033], dtype=float32), array([1.5626236], dtype=float32), array([1.5008698], dtype=float32), array([1.4386584], dtype=float32), array([1.3782768], dtype=float32), array([1.3200004], dtype=float32), array([1.2697952], dtype=float32), array([1.210009], dtype=float32), array([1.1379588], dtype=float32), array([1.0793222], dtype=float32), array([0.9877264], dtype=float32), array([0.8541353], dtype=float32), array([0.74166024], dtype=float32), array([0.5670314], dtype=float32), array([0.4550622], dtype=float32), array([0.32295695], dtype=float32), array([0.24942045], dtype=float32), array([0.17753302], dtype=float32), array([0.1311305], dtype=float32), array([0.08202718], dtype=float32), array([0.0243933], dtype=float32), array([-0.03542729], dtype=float32), array([-0.10327192], dtype=float32), array([-0.16565622], dtype=float32), array([-0.20742054], dtype=float32), array([-0.30584964], dtype=float32), array([-0.36043188], dtype=float32), array([1.6196204], dtype=float32), array([1.4700384], dtype=float32), array([1.3332651], dtype=float32), array([1.2213529], dtype=float32), array([1.0837679], dtype=float32), array([0.9860403], dtype=float32), array([0.7099805], dtype=float32), array([0.5293879], dtype=float32), array([0.3266071], dtype=float32), array([0.20947395], dtype=float32), array([0.1125633], dtype=float32), array([0.00654749], dtype=float32), array([-0.05718895], dtype=float32), array([-0.25057963], dtype=float32), array([-0.418084], dtype=float32), array([-0.44926116], dtype=float32), array([-0.41855463], dtype=float32), array([-0.34651634], dtype=float32), array([-0.274704], dtype=float32), array([-0.17892654], dtype=float32), array([-0.12360294], dtype=float32), array([-0.11273099], dtype=float32), array([-0.10998489], dtype=float32), array([1.6198033], dtype=float32), array([1.5338051], dtype=float32), array([1.3042873], dtype=float32), array([1.0444468], dtype=float32), array([0.59554034], dtype=float32), array([0.3123299], dtype=float32), array([0.17739902], dtype=float32), array([0.05853562], dtype=float32), array([-0.16216137], dtype=float32), array([-0.44716296], dtype=float32), array([-0.37793717], dtype=float32), array([-0.25944236], dtype=float32), array([-0.14448257], dtype=float32), array([-0.11932166], dtype=float32), array([-0.1025386], dtype=float32), array([1.6198033], dtype=float32), array([1.0505787], dtype=float32), array([0.545092], dtype=float32), array([0.10975735], dtype=float32), array([-0.350113], dtype=float32), array([-0.39767143], dtype=float32), array([-0.24383838], dtype=float32), array([-0.12514831], dtype=float32), array([-0.10256805], dtype=float32), array([-0.23066457], dtype=float32), array([-0.5636012], dtype=float32), array([-0.8136689], dtype=float32), array([-1.1177211], dtype=float32), array([-1.4642154], dtype=float32), array([-1.7676431], dtype=float32), array([-1.9472557], dtype=float32), array([-1.9557985], dtype=float32), array([-2.0289352], dtype=float32), array([1.6198033], dtype=float32), array([1.5100185], dtype=float32), array([1.4377435], dtype=float32), array([1.2544653], dtype=float32), array([0.6763646], dtype=float32), array([0.12849997], dtype=float32), array([-0.24993034], dtype=float32), array([-0.4222177], dtype=float32), array([-0.20157291], dtype=float32), array([-0.10825141], dtype=float32), array([-0.50493926], dtype=float32), array([-0.8810802], dtype=float32), array([-1.5201122], dtype=float32), array([-1.7095135], dtype=float32), array([1.6198033], dtype=float32), array([1.549358], dtype=float32), array([1.5086462], dtype=float32), array([1.4496368], dtype=float32), array([1.393372], dtype=float32), array([1.329331], dtype=float32), array([1.269412], dtype=float32), array([1.2000445], dtype=float32), array([1.124162], dtype=float32), array([1.0578604], dtype=float32), array([1.0042062], dtype=float32), array([0.9483188], dtype=float32), array([0.8934432], dtype=float32), array([0.82922745], dtype=float32), array([0.7700709], dtype=float32), array([0.6640204], dtype=float32), array([0.10329066], dtype=float32), array([-0.03614451], dtype=float32), array([1.6198033], dtype=float32), array([1.5489005], dtype=float32), array([1.452839], dtype=float32), array([1.3554049], dtype=float32), array([1.2510161], dtype=float32), array([1.1467733], dtype=float32), array([1.1076823], dtype=float32), array([0.9762292], dtype=float32), array([0.8444057], dtype=float32), array([0.69601583], dtype=float32), array([0.57085216], dtype=float32), array([0.44790074], dtype=float32), array([0.32647154], dtype=float32), array([0.22104026], dtype=float32), array([0.12959604], dtype=float32), array([0.02539758], dtype=float32), array([-0.13961907], dtype=float32), array([-0.42769763], dtype=float32), array([-0.41828558], dtype=float32), array([-0.24428226], dtype=float32), array([-0.14277305], dtype=float32), array([1.6198033], dtype=float32), array([1.5196247], dtype=float32), array([1.4148718], dtype=float32), array([1.3042873], dtype=float32), array([1.2149911], dtype=float32), array([1.1195629], dtype=float32), array([1.0298835], dtype=float32), array([0.72259], dtype=float32), array([0.21434681], dtype=float32), array([-0.21056594], dtype=float32), array([-0.42328033], dtype=float32), array([-0.29128507], dtype=float32), array([-0.15239336], dtype=float32)]\n",
      "Actuals: [array([2.5328531], dtype=float32), array([2.1941197], dtype=float32), array([1.9249394], dtype=float32), array([1.6349837], dtype=float32), array([1.3161227], dtype=float32), array([0.9584201], dtype=float32), array([0.62329984], dtype=float32), array([0.28185654], dtype=float32), array([-0.01171239], dtype=float32), array([-0.2772794], dtype=float32), array([-0.47961614], dtype=float32), array([-0.7298272], dtype=float32), array([-0.8824832], dtype=float32), array([-0.9574562], dtype=float32), array([-1.0369456], dtype=float32), array([2.66654], dtype=float32), array([2.4560735], dtype=float32), array([2.276319], dtype=float32), array([2.070369], dtype=float32), array([1.8906145], dtype=float32), array([1.6873745], dtype=float32), array([1.5049101], dtype=float32), array([1.3107028], dtype=float32), array([1.0948168], dtype=float32), array([0.8689945], dtype=float32), array([0.65852815], dtype=float32), array([0.43993214], dtype=float32), array([0.21139999], dtype=float32), array([0.00093363], dtype=float32), array([-0.19959654], dtype=float32), array([-0.4136761], dtype=float32), array([-0.55729896], dtype=float32), array([-0.7686686], dtype=float32), array([-1.0044272], dtype=float32), array([-1.3016093], dtype=float32), array([-1.4551684], dtype=float32), array([-1.7749327], dtype=float32), array([-1.825517], dtype=float32), array([-1.9492677], dtype=float32), array([2.588857], dtype=float32), array([2.3973598], dtype=float32), array([2.107404], dtype=float32), array([1.9411987], dtype=float32), array([0.44896504], dtype=float32), array([0.401994], dtype=float32), array([0.2954059], dtype=float32), array([0.19152765], dtype=float32), array([0.12287764], dtype=float32), array([-0.01442232], dtype=float32), array([-0.19417681], dtype=float32), array([-0.9845548], dtype=float32), array([-1.1137252], dtype=float32), array([-1.2311528], dtype=float32), array([2.6195688], dtype=float32), array([2.3675513], dtype=float32), array([2.1715374], dtype=float32), array([2.0152683], dtype=float32), array([1.798479], dtype=float32), array([1.6087883], dtype=float32), array([1.4335502], dtype=float32), array([1.267345], dtype=float32), array([1.1887589], dtype=float32), array([1.0713313], dtype=float32), array([0.89880306], dtype=float32), array([0.69917613], dtype=float32), array([0.4191565], dtype=float32), array([0.25566116], dtype=float32), array([0.11745797], dtype=float32), array([0.01628951], dtype=float32), array([-0.0912018], dtype=float32), array([-0.22940506], dtype=float32), array([-0.38657746], dtype=float32), array([-0.5464595], dtype=float32), array([-0.71898776], dtype=float32), array([-0.8490614], dtype=float32), array([-0.96377915], dtype=float32), array([-1.0450752], dtype=float32), array([-1.1218548], dtype=float32), array([2.8002267], dtype=float32), array([2.6051161], dtype=float32), array([2.4443307], dtype=float32), array([2.263673], dtype=float32), array([2.1372125], dtype=float32), array([1.9935895], dtype=float32), array([1.8951309], dtype=float32), array([1.7524112], dtype=float32), array([1.5979488], dtype=float32), array([1.3658035], dtype=float32), array([1.1607568], dtype=float32), array([0.9864221], dtype=float32), array([0.8427991], dtype=float32), array([0.6467854], dtype=float32), array([0.5167117], dtype=float32), array([2.7162209], dtype=float32), array([2.535563], dtype=float32), array([2.3621316], dtype=float32), array([2.1661177], dtype=float32), array([1.9728137], dtype=float32), array([1.798479], dtype=float32), array([1.6566626], dtype=float32), array([1.5130397], dtype=float32), array([1.3450278], dtype=float32), array([1.2221805], dtype=float32), array([1.1056563], dtype=float32), array([0.9620333], dtype=float32), array([0.811184], dtype=float32), array([0.54742354], dtype=float32), array([0.36134598], dtype=float32), array([0.11294149], dtype=float32), array([-0.0830722], dtype=float32), array([-0.30076495], dtype=float32), array([-0.42270896], dtype=float32), array([-0.5708484], dtype=float32), array([-0.7180845], dtype=float32), array([-0.8490614], dtype=float32), array([-0.98816794], dtype=float32), array([-1.1209514], dtype=float32), array([-1.181472], dtype=float32), array([-1.3540002], dtype=float32), array([-1.4642013], dtype=float32), array([2.8047433], dtype=float32), array([2.3747776], dtype=float32), array([2.032431], dtype=float32), array([1.7406685], dtype=float32), array([1.3847727], dtype=float32), array([1.3043798], dtype=float32), array([1.2339233], dtype=float32), array([1.1128826], dtype=float32), array([0.98100233], dtype=float32), array([0.8157004], dtype=float32), array([0.65672153], dtype=float32), array([0.5103887], dtype=float32), array([0.42367294], dtype=float32), array([0.19514082], dtype=float32), array([-0.05507024], dtype=float32), array([-0.27908602], dtype=float32), array([-0.4967787], dtype=float32), array([-0.83009225], dtype=float32), array([-1.0432687], dtype=float32), array([-1.3269013], dtype=float32), array([-1.746931], dtype=float32), array([-1.9872059], dtype=float32), array([-2.0513391], dtype=float32), array([2.6457644], dtype=float32), array([2.395553], dtype=float32), array([2.226638], dtype=float32), array([2.1019843], dtype=float32), array([1.9366822], dtype=float32), array([1.723506], dtype=float32), array([1.592529], dtype=float32), array([1.558204], dtype=float32), array([1.3947088], dtype=float32), array([1.130045], dtype=float32), array([0.68382025], dtype=float32), array([0.25927433], dtype=float32), array([-0.23482485], dtype=float32), array([-0.5834945], dtype=float32), array([-0.9935877], dtype=float32), array([2.6024063], dtype=float32), array([2.388327], dtype=float32), array([2.216702], dtype=float32), array([1.907777], dtype=float32), array([1.5464613], dtype=float32), array([1.2158575], dtype=float32), array([0.8915767], dtype=float32), array([0.5275512], dtype=float32), array([0.16262238], dtype=float32), array([-0.20591958], dtype=float32), array([-0.5518792], dtype=float32), array([-0.8373187], dtype=float32), array([-1.1019825], dtype=float32), array([-1.3133521], dtype=float32), array([-1.5581435], dtype=float32), array([-1.688217], dtype=float32), array([-1.7586738], dtype=float32), array([-1.8788112], dtype=float32), array([2.7460294], dtype=float32), array([2.567178], dtype=float32), array([2.410909], dtype=float32), array([2.1877966], dtype=float32), array([1.9375855], dtype=float32), array([1.5003936], dtype=float32), array([1.0812675], dtype=float32), array([0.77956885], dtype=float32), array([0.3450868], dtype=float32), array([0.00635342], dtype=float32), array([-0.6521444], dtype=float32), array([-0.93758374], dtype=float32), array([-1.3567101], dtype=float32), array([-1.4109074], dtype=float32), array([2.6629267], dtype=float32), array([2.438911], dtype=float32), array([2.244704], dtype=float32), array([2.085725], dtype=float32), array([1.9303592], dtype=float32), array([1.70815], dtype=float32), array([1.5103298], dtype=float32), array([1.2619252], dtype=float32), array([1.0189404], dtype=float32), array([0.7434373], dtype=float32), array([0.57452226], dtype=float32), array([0.42367294], dtype=float32), array([0.24211182], dtype=float32), array([0.06055073], dtype=float32), array([-0.10565449], dtype=float32), array([-0.4317418], dtype=float32), array([-1.7586738], dtype=float32), array([-1.8788112], dtype=float32), array([2.5635648], dtype=float32), array([2.410909], dtype=float32), array([2.229348], dtype=float32), array([2.0595295], dtype=float32), array([1.9068736], dtype=float32), array([1.7713803], dtype=float32), array([1.714473], dtype=float32), array([1.5302022], dtype=float32), array([1.3775463], dtype=float32), array([1.2248904], dtype=float32), array([1.0776542], dtype=float32), array([0.9466773], dtype=float32), array([0.8030544], dtype=float32), array([0.5952979], dtype=float32), array([0.3938644], dtype=float32), array([0.1590092], dtype=float32), array([-0.04965051], dtype=float32), array([-0.23843797], dtype=float32), array([-0.31341097], dtype=float32), array([-0.63227195], dtype=float32), array([-0.7180845], dtype=float32), array([2.456977], dtype=float32), array([2.1850867], dtype=float32), array([1.9050671], dtype=float32), array([1.6783415], dtype=float32), array([1.4308404], dtype=float32), array([1.2158575], dtype=float32), array([1.0397161], dtype=float32), array([1.145401], dtype=float32), array([0.9629366], dtype=float32), array([0.8202169], dtype=float32), array([0.5790387], dtype=float32), array([0.35140982], dtype=float32), array([0.21501316], dtype=float32)]\n",
      "Epoch [1/100], Loss: 0.4927\n",
      "Epoch [2/100], Loss: 0.2880\n",
      "Epoch [3/100], Loss: 0.0888\n",
      "Epoch [4/100], Loss: 0.0520\n",
      "Epoch [5/100], Loss: 0.0419\n",
      "Epoch [6/100], Loss: 0.0403\n",
      "Epoch [7/100], Loss: 0.0295\n",
      "Epoch [8/100], Loss: 0.0405\n",
      "Epoch [9/100], Loss: 0.0267\n",
      "Epoch [10/100], Loss: 0.0388\n",
      "Epoch [11/100], Loss: 0.0412\n",
      "Epoch [12/100], Loss: 0.0545\n",
      "Epoch [13/100], Loss: 0.0252\n",
      "Epoch [14/100], Loss: 0.0269\n",
      "Epoch [15/100], Loss: 0.0407\n",
      "Epoch [16/100], Loss: 0.0323\n",
      "Epoch [17/100], Loss: 0.0245\n",
      "Epoch [18/100], Loss: 0.0203\n",
      "Epoch [19/100], Loss: 0.0306\n",
      "Epoch [20/100], Loss: 0.0249\n",
      "Epoch [21/100], Loss: 0.0322\n",
      "Epoch [22/100], Loss: 0.0249\n",
      "Epoch [23/100], Loss: 0.0274\n",
      "Epoch [24/100], Loss: 0.0219\n",
      "Epoch [25/100], Loss: 0.0243\n",
      "Epoch [26/100], Loss: 0.0411\n",
      "Epoch [27/100], Loss: 0.0302\n",
      "Epoch [28/100], Loss: 0.0269\n",
      "Epoch [29/100], Loss: 0.0176\n",
      "Epoch [30/100], Loss: 0.0335\n",
      "Epoch [31/100], Loss: 0.0373\n",
      "Epoch [32/100], Loss: 0.0335\n",
      "Epoch [33/100], Loss: 0.0218\n",
      "Epoch [34/100], Loss: 0.0283\n",
      "Epoch [35/100], Loss: 0.0205\n",
      "Epoch [36/100], Loss: 0.0274\n",
      "Epoch [37/100], Loss: 0.0153\n",
      "Epoch [38/100], Loss: 0.0213\n",
      "Epoch [39/100], Loss: 0.0148\n",
      "Epoch [40/100], Loss: 0.0332\n",
      "Epoch [41/100], Loss: 0.0255\n",
      "Epoch [42/100], Loss: 0.0269\n",
      "Epoch [43/100], Loss: 0.0256\n",
      "Epoch [44/100], Loss: 0.0268\n",
      "Epoch [45/100], Loss: 0.0243\n",
      "Epoch [46/100], Loss: 0.0243\n",
      "Epoch [47/100], Loss: 0.0219\n",
      "Epoch [48/100], Loss: 0.0238\n",
      "Epoch [49/100], Loss: 0.0161\n",
      "Epoch [50/100], Loss: 0.0277\n",
      "Epoch [51/100], Loss: 0.0194\n",
      "Epoch [52/100], Loss: 0.0189\n",
      "Epoch [53/100], Loss: 0.0253\n",
      "Epoch [54/100], Loss: 0.0135\n",
      "Epoch [55/100], Loss: 0.0155\n",
      "Epoch [56/100], Loss: 0.0197\n",
      "Epoch [57/100], Loss: 0.0095\n",
      "Epoch [58/100], Loss: 0.0152\n",
      "Epoch [59/100], Loss: 0.0221\n",
      "Epoch [60/100], Loss: 0.0257\n",
      "Epoch [61/100], Loss: 0.0124\n",
      "Epoch [62/100], Loss: 0.0154\n",
      "Epoch [63/100], Loss: 0.0216\n",
      "Epoch [64/100], Loss: 0.0226\n",
      "Epoch [65/100], Loss: 0.0224\n",
      "Epoch [66/100], Loss: 0.0240\n",
      "Epoch [67/100], Loss: 0.0217\n",
      "Epoch [68/100], Loss: 0.0129\n",
      "Epoch [69/100], Loss: 0.0193\n",
      "Epoch [70/100], Loss: 0.0216\n",
      "Epoch [71/100], Loss: 0.0243\n",
      "Epoch [72/100], Loss: 0.0332\n",
      "Epoch [73/100], Loss: 0.0135\n",
      "Epoch [74/100], Loss: 0.0270\n",
      "Epoch [75/100], Loss: 0.0194\n",
      "Epoch [76/100], Loss: 0.0215\n",
      "Epoch [77/100], Loss: 0.0184\n",
      "Epoch [78/100], Loss: 0.0211\n",
      "Epoch [79/100], Loss: 0.0151\n",
      "Epoch [80/100], Loss: 0.0244\n",
      "Epoch [81/100], Loss: 0.0351\n",
      "Epoch [82/100], Loss: 0.0147\n",
      "Epoch [83/100], Loss: 0.0288\n",
      "Epoch [84/100], Loss: 0.0238\n",
      "Epoch [85/100], Loss: 0.0241\n",
      "Epoch [86/100], Loss: 0.0066\n",
      "Epoch [87/100], Loss: 0.0209\n",
      "Epoch [88/100], Loss: 0.0102\n",
      "Epoch [89/100], Loss: 0.0202\n",
      "Epoch [90/100], Loss: 0.0214\n",
      "Epoch [91/100], Loss: 0.0238\n",
      "Epoch [92/100], Loss: 0.0350\n",
      "Epoch [93/100], Loss: 0.0073\n",
      "Epoch [94/100], Loss: 0.0218\n",
      "Epoch [95/100], Loss: 0.0121\n",
      "Epoch [96/100], Loss: 0.0324\n",
      "Epoch [97/100], Loss: 0.0133\n",
      "Epoch [98/100], Loss: 0.0087\n",
      "Epoch [99/100], Loss: 0.0185\n",
      "Epoch [100/100], Loss: 0.0224\n",
      "Predictions: [[0.91325355]\n",
      " [0.8953078 ]\n",
      " [0.8786616 ]\n",
      " [0.86077774]\n",
      " [0.845431  ]\n",
      " [0.8266809 ]\n",
      " [0.8054553 ]\n",
      " [0.7839204 ]\n",
      " [0.7644278 ]\n",
      " [0.74382114]\n",
      " [0.721853  ]\n",
      " [0.7029791 ]\n",
      " [0.69041705]\n",
      " [0.68670416]\n",
      " [0.68026847]\n",
      " [0.91325355]\n",
      " [0.9029192 ]\n",
      " [0.8943795 ]\n",
      " [0.88497347]\n",
      " [0.87575316]\n",
      " [0.86727524]\n",
      " [0.8574362 ]\n",
      " [0.8479681 ]\n",
      " [0.83819085]\n",
      " [0.8269283 ]\n",
      " [0.8164704 ]\n",
      " [0.80539346]\n",
      " [0.7937597 ]\n",
      " [0.7829304 ]\n",
      " [0.77104914]\n",
      " [0.75960094]\n",
      " [0.74307853]\n",
      " [0.7293407 ]\n",
      " [0.71387035]\n",
      " [0.6963577 ]\n",
      " [0.6844145 ]\n",
      " [0.6558252 ]\n",
      " [0.61281735]\n",
      " [0.5821858 ]\n",
      " [0.91325355]\n",
      " [0.8997633 ]\n",
      " [0.8730922 ]\n",
      " [0.8587975 ]\n",
      " [0.7301452 ]\n",
      " [0.72946453]\n",
      " [0.7214817 ]\n",
      " [0.7122614 ]\n",
      " [0.70786774]\n",
      " [0.6985855 ]\n",
      " [0.6875706 ]\n",
      " [0.58657944]\n",
      " [0.55044043]\n",
      " [0.52490544]\n",
      " [0.91325355]\n",
      " [0.89895874]\n",
      " [0.885778  ]\n",
      " [0.8735254 ]\n",
      " [0.857003  ]\n",
      " [0.8393667 ]\n",
      " [0.815047  ]\n",
      " [0.7863339 ]\n",
      " [0.7550217 ]\n",
      " [0.716655  ]\n",
      " [0.66943914]\n",
      " [0.6153544 ]\n",
      " [0.5584851 ]\n",
      " [0.51945674]\n",
      " [0.49643812]\n",
      " [0.48032275]\n",
      " [0.46071365]\n",
      " [0.4483875 ]\n",
      " [0.44544277]\n",
      " [0.44387162]\n",
      " [0.44192967]\n",
      " [0.44020167]\n",
      " [0.44018298]\n",
      " [0.44016555]\n",
      " [0.44014534]\n",
      " [0.91325355]\n",
      " [0.90298104]\n",
      " [0.89382267]\n",
      " [0.8815081 ]\n",
      " [0.86622334]\n",
      " [0.84697807]\n",
      " [0.83608687]\n",
      " [0.81832683]\n",
      " [0.7975345 ]\n",
      " [0.7696258 ]\n",
      " [0.74382114]\n",
      " [0.7199347 ]\n",
      " [0.6990187 ]\n",
      " [0.67408025]\n",
      " [0.65427804]\n",
      " [0.91325355]\n",
      " [0.90551823]\n",
      " [0.8971642 ]\n",
      " [0.8887483 ]\n",
      " [0.88057995]\n",
      " [0.8725353 ]\n",
      " [0.86442876]\n",
      " [0.85477525]\n",
      " [0.8431415 ]\n",
      " [0.8336735 ]\n",
      " [0.8188838 ]\n",
      " [0.79759634]\n",
      " [0.77971256]\n",
      " [0.7452443 ]\n",
      " [0.71838766]\n",
      " [0.6853427 ]\n",
      " [0.6537831 ]\n",
      " [0.62055254]\n",
      " [0.5953047 ]\n",
      " [0.56758165]\n",
      " [0.54004425]\n",
      " [0.5234278 ]\n",
      " [0.5138694 ]\n",
      " [0.50562704]\n",
      " [0.5001091 ]\n",
      " [0.48780325]\n",
      " [0.4802766 ]\n",
      " [0.9132288 ]\n",
      " [0.8929934 ]\n",
      " [0.8744907 ]\n",
      " [0.8566069 ]\n",
      " [0.83439136]\n",
      " [0.8186115 ]\n",
      " [0.77467537]\n",
      " [0.7363705 ]\n",
      " [0.6864938 ]\n",
      " [0.63531756]\n",
      " [0.58482194]\n",
      " [0.5341567 ]\n",
      " [0.51997846]\n",
      " [0.4946511 ]\n",
      " [0.47227898]\n",
      " [0.45531455]\n",
      " [0.44633588]\n",
      " [0.44348004]\n",
      " [0.4412054 ]\n",
      " [0.44018406]\n",
      " [0.44014868]\n",
      " [0.44013107]\n",
      " [0.4401264 ]\n",
      " [0.91325355]\n",
      " [0.9016197 ]\n",
      " [0.86999816]\n",
      " [0.82804227]\n",
      " [0.7512469 ]\n",
      " [0.6815061 ]\n",
      " [0.6204907 ]\n",
      " [0.5547722 ]\n",
      " [0.50608885]\n",
      " [0.46527812]\n",
      " [0.44466123]\n",
      " [0.4407232 ]\n",
      " [0.44017085]\n",
      " [0.44014224]\n",
      " [0.440106  ]\n",
      " [0.91325355]\n",
      " [0.82903236]\n",
      " [0.7401701 ]\n",
      " [0.58323777]\n",
      " [0.48170808]\n",
      " [0.44544482]\n",
      " [0.44023022]\n",
      " [0.4401503 ]\n",
      " [0.4400904 ]\n",
      " [0.44768837]\n",
      " [0.4221053 ]\n",
      " [0.38615403]\n",
      " [0.34277055]\n",
      " [0.30298844]\n",
      " [0.27322668]\n",
      " [0.26581052]\n",
      " [0.26552203]\n",
      " [0.2630531 ]\n",
      " [0.91325355]\n",
      " [0.8984018 ]\n",
      " [0.88862455]\n",
      " [0.8619535 ]\n",
      " [0.7682644 ]\n",
      " [0.59381956]\n",
      " [0.4947296 ]\n",
      " [0.44654307]\n",
      " [0.4401913 ]\n",
      " [0.44012347]\n",
      " [0.43052274]\n",
      " [0.37642616]\n",
      " [0.29742554]\n",
      " [0.27840635]\n",
      " [0.91325355]\n",
      " [0.90372366]\n",
      " [0.89821625]\n",
      " [0.89023346]\n",
      " [0.882622  ]\n",
      " [0.8739585 ]\n",
      " [0.86436677]\n",
      " [0.8531662 ]\n",
      " [0.84091365]\n",
      " [0.8302082 ]\n",
      " [0.82154465]\n",
      " [0.81257176]\n",
      " [0.8038465 ]\n",
      " [0.79363596]\n",
      " [0.78422993]\n",
      " [0.76566535]\n",
      " [0.57958674]\n",
      " [0.52331233]\n",
      " [0.91325355]\n",
      " [0.9036618 ]\n",
      " [0.8906666 ]\n",
      " [0.87748575]\n",
      " [0.8613965 ]\n",
      " [0.8445646 ]\n",
      " [0.8382528 ]\n",
      " [0.8170272 ]\n",
      " [0.79604936]\n",
      " [0.772163  ]\n",
      " [0.74604887]\n",
      " [0.716655  ]\n",
      " [0.6864566 ]\n",
      " [0.6406641 ]\n",
      " [0.5944384 ]\n",
      " [0.54047745]\n",
      " [0.5090672 ]\n",
      " [0.47092602]\n",
      " [0.4463206 ]\n",
      " [0.44024426]\n",
      " [0.44016904]\n",
      " [0.91325355]\n",
      " [0.89970136]\n",
      " [0.8855304 ]\n",
      " [0.86999816]\n",
      " [0.8555796 ]\n",
      " [0.84017104]\n",
      " [0.8256906 ]\n",
      " [0.7766803 ]\n",
      " [0.63757   ]\n",
      " [0.49969354]\n",
      " [0.44660315]\n",
      " [0.44172922]\n",
      " [0.44017538]], Actuals: [[0.94401044]\n",
      " [0.87425596]\n",
      " [0.8188244 ]\n",
      " [0.75911456]\n",
      " [0.69345236]\n",
      " [0.6197917 ]\n",
      " [0.55078125]\n",
      " [0.48046875]\n",
      " [0.4200149 ]\n",
      " [0.3653274 ]\n",
      " [0.3236607 ]\n",
      " [0.2721354 ]\n",
      " [0.24069941]\n",
      " [0.22526042]\n",
      " [0.20889136]\n",
      " [0.97154015]\n",
      " [0.9281994 ]\n",
      " [0.891183  ]\n",
      " [0.84877235]\n",
      " [0.81175596]\n",
      " [0.7699033 ]\n",
      " [0.7323289 ]\n",
      " [0.6923363 ]\n",
      " [0.6478795 ]\n",
      " [0.6013765 ]\n",
      " [0.55803573]\n",
      " [0.5130208 ]\n",
      " [0.46595982]\n",
      " [0.42261904]\n",
      " [0.3813244 ]\n",
      " [0.3372396 ]\n",
      " [0.30766368]\n",
      " [0.2641369 ]\n",
      " [0.2155878 ]\n",
      " [0.15438989]\n",
      " [0.12276786]\n",
      " [0.05691964]\n",
      " [0.04650298]\n",
      " [0.02101935]\n",
      " [0.95554316]\n",
      " [0.9161086 ]\n",
      " [0.8563988 ]\n",
      " [0.82217264]\n",
      " [0.51488096]\n",
      " [0.5052083 ]\n",
      " [0.48325893]\n",
      " [0.46186757]\n",
      " [0.44773066]\n",
      " [0.41945684]\n",
      " [0.38244048]\n",
      " [0.21968006]\n",
      " [0.19308035]\n",
      " [0.1688988 ]\n",
      " [0.9618676 ]\n",
      " [0.9099702 ]\n",
      " [0.86960566]\n",
      " [0.8374256 ]\n",
      " [0.7927827 ]\n",
      " [0.7537202 ]\n",
      " [0.7176339 ]\n",
      " [0.6834077 ]\n",
      " [0.6672247 ]\n",
      " [0.64304316]\n",
      " [0.60751486]\n",
      " [0.56640625]\n",
      " [0.5087426 ]\n",
      " [0.4750744 ]\n",
      " [0.4466146 ]\n",
      " [0.42578125]\n",
      " [0.40364584]\n",
      " [0.37518603]\n",
      " [0.34281993]\n",
      " [0.30989584]\n",
      " [0.27436757]\n",
      " [0.24758184]\n",
      " [0.22395833]\n",
      " [0.20721726]\n",
      " [0.19140625]\n",
      " [0.9990699 ]\n",
      " [0.9588914 ]\n",
      " [0.92578125]\n",
      " [0.8885789 ]\n",
      " [0.8625372 ]\n",
      " [0.8329613 ]\n",
      " [0.812686  ]\n",
      " [0.7832961 ]\n",
      " [0.7514881 ]\n",
      " [0.703683  ]\n",
      " [0.6614583 ]\n",
      " [0.625558  ]\n",
      " [0.59598213]\n",
      " [0.5556176 ]\n",
      " [0.52883184]\n",
      " [0.9817708 ]\n",
      " [0.94456846]\n",
      " [0.9088542 ]\n",
      " [0.86848956]\n",
      " [0.828683  ]\n",
      " [0.7927827 ]\n",
      " [0.7635789 ]\n",
      " [0.73400295]\n",
      " [0.6994048 ]\n",
      " [0.67410713]\n",
      " [0.6501116 ]\n",
      " [0.62053573]\n",
      " [0.5894717 ]\n",
      " [0.53515625]\n",
      " [0.4968378 ]\n",
      " [0.44568452]\n",
      " [0.40531993]\n",
      " [0.36049107]\n",
      " [0.33537945]\n",
      " [0.30487353]\n",
      " [0.27455357]\n",
      " [0.24758184]\n",
      " [0.21893601]\n",
      " [0.19159226]\n",
      " [0.17912947]\n",
      " [0.1436012 ]\n",
      " [0.12090774]\n",
      " [1.        ]\n",
      " [0.9114583 ]\n",
      " [0.84095985]\n",
      " [0.78087795]\n",
      " [0.70758927]\n",
      " [0.6910342 ]\n",
      " [0.6765253 ]\n",
      " [0.6515997 ]\n",
      " [0.624442  ]\n",
      " [0.59040177]\n",
      " [0.5576637 ]\n",
      " [0.5275298 ]\n",
      " [0.50967264]\n",
      " [0.46261162]\n",
      " [0.41108632]\n",
      " [0.36495537]\n",
      " [0.32012647]\n",
      " [0.2514881 ]\n",
      " [0.20758928]\n",
      " [0.14918154]\n",
      " [0.06268601]\n",
      " [0.01320685]\n",
      " [0.        ]\n",
      " [0.9672619 ]\n",
      " [0.9157366 ]\n",
      " [0.88095236]\n",
      " [0.8552827 ]\n",
      " [0.8212426 ]\n",
      " [0.77734375]\n",
      " [0.75037205]\n",
      " [0.7433036 ]\n",
      " [0.70963544]\n",
      " [0.6551339 ]\n",
      " [0.56324404]\n",
      " [0.47581846]\n",
      " [0.37406993]\n",
      " [0.30226934]\n",
      " [0.21781994]\n",
      " [0.9583333 ]\n",
      " [0.9142485 ]\n",
      " [0.87890625]\n",
      " [0.81529015]\n",
      " [0.74088544]\n",
      " [0.6728051 ]\n",
      " [0.60602677]\n",
      " [0.531064  ]\n",
      " [0.45591518]\n",
      " [0.38002232]\n",
      " [0.30877978]\n",
      " [0.25      ]\n",
      " [0.19549851]\n",
      " [0.15197173]\n",
      " [0.1015625 ]\n",
      " [0.07477678]\n",
      " [0.06026786]\n",
      " [0.03552827]\n",
      " [0.9879092 ]\n",
      " [0.9510789 ]\n",
      " [0.9188988 ]\n",
      " [0.8729539 ]\n",
      " [0.8214286 ]\n",
      " [0.7313988 ]\n",
      " [0.64508927]\n",
      " [0.5829613 ]\n",
      " [0.4934896 ]\n",
      " [0.4237351 ]\n",
      " [0.28813243]\n",
      " [0.22935268]\n",
      " [0.14304316]\n",
      " [0.13188244]\n",
      " [0.9707961 ]\n",
      " [0.92466515]\n",
      " [0.88467264]\n",
      " [0.85193455]\n",
      " [0.81994045]\n",
      " [0.77418154]\n",
      " [0.7334449 ]\n",
      " [0.6822917 ]\n",
      " [0.6322545 ]\n",
      " [0.5755208 ]\n",
      " [0.5407366 ]\n",
      " [0.50967264]\n",
      " [0.47228423]\n",
      " [0.43489584]\n",
      " [0.40066963]\n",
      " [0.33351934]\n",
      " [0.06026786]\n",
      " [0.03552827]\n",
      " [0.95033485]\n",
      " [0.9188988 ]\n",
      " [0.88151044]\n",
      " [0.84654015]\n",
      " [0.8151042 ]\n",
      " [0.78720236]\n",
      " [0.7754836 ]\n",
      " [0.7375372 ]\n",
      " [0.7061012 ]\n",
      " [0.67466515]\n",
      " [0.6443452 ]\n",
      " [0.6173735 ]\n",
      " [0.58779764]\n",
      " [0.54501486]\n",
      " [0.5035342 ]\n",
      " [0.45517114]\n",
      " [0.4122024 ]\n",
      " [0.37332588]\n",
      " [0.3578869 ]\n",
      " [0.2922247 ]\n",
      " [0.27455357]\n",
      " [0.92838544]\n",
      " [0.8723958 ]\n",
      " [0.81473213]\n",
      " [0.76804316]\n",
      " [0.7170759 ]\n",
      " [0.6728051 ]\n",
      " [0.6365327 ]\n",
      " [0.6582961 ]\n",
      " [0.6207217 ]\n",
      " [0.59133184]\n",
      " [0.5416667 ]\n",
      " [0.49479166]\n",
      " [0.46670386]]\n",
      "Epoch 1, Loss: 3.7043889901217293\n",
      "Epoch 2, Loss: 1.410523838856641\n",
      "Epoch 3, Loss: 1.1487928646452286\n",
      "Epoch 4, Loss: 0.9188877817462472\n",
      "Epoch 5, Loss: 1.6977183170178358\n",
      "Epoch 6, Loss: 1.0241828083115465\n",
      "Epoch 7, Loss: 0.7451395543620867\n",
      "Epoch 8, Loss: 1.0437169075012207\n",
      "Epoch 9, Loss: 0.7602501380092958\n",
      "Epoch 10, Loss: 0.9433818538399303\n",
      "Epoch 11, Loss: 1.2507526147014953\n",
      "Epoch 12, Loss: 0.9937785092522117\n",
      "Epoch 13, Loss: 0.7053799488965202\n",
      "Epoch 14, Loss: 0.9530435217654004\n",
      "Epoch 15, Loss: 2.419162459233228\n",
      "Epoch 16, Loss: 0.9721927200170124\n",
      "Epoch 17, Loss: 1.1001348166781313\n",
      "Epoch 18, Loss: 0.7016444074756959\n",
      "Epoch 19, Loss: 0.7740493758636362\n",
      "Epoch 20, Loss: 0.7624277437434477\n",
      "Epoch 21, Loss: 0.773796937044929\n",
      "Epoch 22, Loss: 0.6945864531923743\n",
      "Epoch 23, Loss: 0.8072178894106079\n",
      "Epoch 24, Loss: 0.7061951979994774\n",
      "Epoch 25, Loss: 0.7993042433963102\n",
      "Epoch 26, Loss: 0.6789901383659419\n",
      "Epoch 27, Loss: 0.7403324653997141\n",
      "Epoch 28, Loss: 0.8973507263204631\n",
      "Epoch 29, Loss: 0.9245107353610151\n",
      "Epoch 30, Loss: 0.6725148357012692\n",
      "Epoch 31, Loss: 0.7615772985360202\n",
      "Epoch 32, Loss: 0.9464802645585116\n",
      "Epoch 33, Loss: 0.9111652181429022\n",
      "Epoch 34, Loss: 0.7076561617500642\n",
      "Epoch 35, Loss: 0.7761778125868124\n",
      "Epoch 36, Loss: 0.6674819303786054\n",
      "Epoch 37, Loss: 0.7337790140334297\n",
      "Epoch 38, Loss: 0.665539364604389\n",
      "Epoch 39, Loss: 0.6731428977321176\n",
      "Epoch 40, Loss: 0.7295427304856917\n",
      "Epoch 41, Loss: 0.6822792098802679\n",
      "Epoch 42, Loss: 0.6926130761995035\n",
      "Epoch 43, Loss: 0.7230483251897728\n",
      "Epoch 44, Loss: 1.0136774944908478\n",
      "Epoch 45, Loss: 0.7570897643180454\n",
      "Epoch 46, Loss: 0.7072847117395962\n",
      "Epoch 47, Loss: 0.7919925315415158\n",
      "Epoch 48, Loss: 0.7176552423659492\n",
      "Epoch 49, Loss: 0.7097018694176394\n",
      "Epoch 50, Loss: 0.9814616187530405\n",
      "Epoch 51, Loss: 0.9912201411583844\n",
      "Epoch 52, Loss: 0.9482942933545393\n",
      "Epoch 53, Loss: 0.8034820096457705\n",
      "Epoch 54, Loss: 0.7154957617030424\n",
      "Epoch 55, Loss: 0.6914603094405988\n",
      "Epoch 56, Loss: 0.8134758744169684\n",
      "Epoch 57, Loss: 0.7884387380498297\n",
      "Epoch 58, Loss: 0.9531327039003372\n",
      "Epoch 59, Loss: 0.7280776526998071\n",
      "Epoch 60, Loss: 0.7201496332007296\n",
      "Epoch 61, Loss: 0.8636572343461654\n",
      "Epoch 62, Loss: 1.177676399841028\n",
      "Epoch 63, Loss: 1.0081577975960339\n",
      "Epoch 64, Loss: 0.9039953438674703\n",
      "Epoch 65, Loss: 0.6761494103599998\n",
      "Epoch 66, Loss: 0.7080347235588467\n",
      "Epoch 67, Loss: 0.7136972380035064\n",
      "Epoch 68, Loss: 0.6817317973164951\n",
      "Epoch 69, Loss: 0.7070973287610447\n",
      "Epoch 70, Loss: 0.690859343199169\n",
      "Epoch 71, Loss: 0.6775968828622032\n",
      "Epoch 72, Loss: 0.660523430827786\n",
      "Epoch 73, Loss: 0.7314560527310652\n",
      "Epoch 74, Loss: 0.8164368867874146\n",
      "Epoch 75, Loss: 0.7367480186855092\n",
      "Epoch 76, Loss: 0.7215046821271672\n",
      "Epoch 77, Loss: 0.6698912042467033\n",
      "Epoch 78, Loss: 0.7665590956149733\n",
      "Epoch 79, Loss: 0.6678016527610666\n",
      "Epoch 80, Loss: 0.6899584303883946\n",
      "Epoch 81, Loss: 0.6806909012443879\n",
      "Epoch 82, Loss: 0.8265124826746828\n",
      "Epoch 83, Loss: 0.7329323129618869\n",
      "Epoch 84, Loss: 0.6879712246796664\n",
      "Epoch 85, Loss: 0.6724221872932771\n",
      "Epoch 86, Loss: 0.6754232119111454\n",
      "Epoch 87, Loss: 0.9002556590472951\n",
      "Epoch 88, Loss: 0.7435011118650436\n",
      "Epoch 89, Loss: 0.6795137962874245\n",
      "Epoch 90, Loss: 0.6902259307749131\n",
      "Epoch 91, Loss: 0.6815033444915625\n",
      "Epoch 92, Loss: 0.6876482192207786\n",
      "Epoch 93, Loss: 0.7228574875523063\n",
      "Epoch 94, Loss: 0.8857291003360468\n",
      "Epoch 95, Loss: 0.8726726327748859\n",
      "Epoch 96, Loss: 0.6967408968245282\n",
      "Epoch 97, Loss: 0.7449890447451788\n",
      "Epoch 98, Loss: 0.7517672143876553\n",
      "Epoch 99, Loss: 0.6716302146806437\n",
      "Epoch 100, Loss: 0.6616629909943131\n",
      "Test Loss: 0.6945888088084757\n",
      "Test Loss: 0.7094122460111976\n",
      "Test Loss: 0.6545696510002017\n"
     ]
    }
   ],
   "source": [
    "from LLM_call import LLMModel\n",
    "from tqdm import tqdm\n",
    "\n",
    "llm = LLMModel(api_key=\"sk-rifpc-2Gg7xjJ4qrwzWY7hUhZKT3BlbkFJBkz9CHkx9LkVsSciz9Tg\", model=\"gpt-4o\")\n",
    "result_dict = {}\n",
    "\n",
    "for i in range(10):\n",
    "    output = llm.LLM_response(base_prompt, model=\"gpt-4o\")\n",
    "    is_runnable, message, extracted_code = extract_and_test_llm_code_simplified(output)\n",
    "    result_dict[i] = {\n",
    "        \"output\": output,\n",
    "        \"is_runnable\": is_runnable,\n",
    "        \"message\": message,\n",
    "        \"extracted_code\": extracted_code\n",
    "    }\n",
    "# save the result_dict to a file\n",
    "import json\n",
    "with open(\"result_dict_baseline.json\", \"w\") as f:\n",
    "    json.dump(result_dict, f, indent=4)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "bb1c487d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "9\n"
     ]
    }
   ],
   "source": [
    "# total runnable code\n",
    "total_runnable_code = sum(1 for result in result_dict.values() if result[\"is_runnable\"])\n",
    "print(total_runnable_code)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "eb0c2505",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "import pandas as pd\n",
      "import numpy as np\n",
      "import torch\n",
      "import torch.nn as nn\n",
      "import torch.optim as optim\n",
      "from torch.utils.data import Dataset, DataLoader\n",
      "\n",
      "# Define mathematical model functions\n",
      "def bruun_model(x, sea_level_rise):\n",
      "    # Bruun's rule is a simplistic model assuming a constant slope\n",
      "    # and relates the horizontal retreat distance (x) with sea-level rise.\n",
      "    return x - sea_level_rise * (x / initial_width)\n",
      "\n",
      "def dean_model(x, sea_level_rise):\n",
      "    # Dean model assumes profile convexity and allows calculation of new profile\n",
      "    return x - np.sqrt(sea_level_rise * x / initial_width)\n",
      "\n",
      "# Define a PyTorch Dataset\n",
      "class BeachProfileDataset(Dataset):\n",
      "    def __init__(self, file_path):\n",
      "        self.data = pd.read_excel(file_path)\n",
      "    \n",
      "    def __len__(self):\n",
      "        return len(self.data)\n",
      "    \n",
      "    def __getitem__(self, idx):\n",
      "        x = self.data.iloc[idx]['x']\n",
      "        y = self.data.iloc[idx]['y']\n",
      "        return torch.tensor([x], dtype=torch.float32), torch.tensor([y], dtype=torch.float32)\n",
      "\n",
      "# Define a PyTorch Model\n",
      "class BeachProfileModel(nn.Module):\n",
      "    def __init__(self):\n",
      "        super(BeachProfileModel, self).__init__()\n",
      "        self.linear1 = nn.Linear(1, 128)\n",
      "        self.relu = nn.ReLU()\n",
      "        self.linear2 = nn.Linear(128, 64)\n",
      "        self.linear3 = nn.Linear(64, 1)\n",
      "    \n",
      "    def forward(self, x):\n",
      "        x = self.linear1(x)\n",
      "        x = self.relu(x)\n",
      "        x = self.linear2(x)\n",
      "        x = self.relu(x)\n",
      "        x = self.linear3(x)\n",
      "        return x\n",
      "\n",
      "# Function to train the model\n",
      "def train_model(train_loader, model, criterion, optimizer, epochs):\n",
      "    for epoch in range(epochs):\n",
      "        for x, y in train_loader:\n",
      "            optimizer.zero_grad()\n",
      "            outputs = model(x)\n",
      "            loss = criterion(outputs, y)\n",
      "            loss.backward()\n",
      "            optimizer.step()\n",
      "\n",
      "# Function to evaluate the model\n",
      "def evaluate_model(test_loader, model, criterion):\n",
      "    total_loss = 0\n",
      "    with torch.no_grad():\n",
      "        for x, y in test_loader:\n",
      "            outputs = model(x)\n",
      "            loss = criterion(outputs, y)\n",
      "            total_loss += loss.item()\n",
      "    return total_loss / len(test_loader)\n",
      "\n",
      "# Main function\n",
      "def main():\n",
      "    # Constants\n",
      "    global initial_width\n",
      "    initial_width = 1000  # assumed constant width of the beach for the models\n",
      "    \n",
      "    # Load Dataset\n",
      "    train_data_path = \"beach_profile_data/processed_data/beachdata_train.xlsx\"\n",
      "    test_data_path = \"beach_profile_data/processed_data/beachdata_test.xlsx\"\n",
      "    \n",
      "    train_dataset = BeachProfileDataset(train_data_path)\n",
      "    test_dataset = BeachProfileDataset(test_data_path)\n",
      "    \n",
      "    train_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)\n",
      "    test_loader = DataLoader(test_dataset, batch_size=32, shuffle=False)\n",
      "    \n",
      "    # Initialize Model, Loss Function and Optimizer\n",
      "    model = BeachProfileModel()\n",
      "    criterion = nn.MSELoss()\n",
      "    optimizer = optim.Adam(model.parameters(), lr=0.001)\n",
      "    epochs = 50\n",
      "\n",
      "    # Train the model\n",
      "    train_model(train_loader, model, criterion, optimizer, epochs)\n",
      "\n",
      "    # Evaluate the model\n",
      "    test_loss = evaluate_model(test_loader, model, criterion)\n",
      "    print(f\"Test Loss: {test_loss}\")\n",
      "\n",
      "# Ensure the script is not executed on import\n",
      "if __name__ == \"__main__\":\n",
      "    main()\n"
     ]
    }
   ],
   "source": [
    "code_sample = result_dict[1][\"extracted_code\"]\n",
    "print(code_sample)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "07e42b9b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "from torch.utils.data import Dataset, DataLoader\n",
    "\n",
    "# Define mathematical model functions\n",
    "def bruun_model(x, sea_level_rise):\n",
    "    # Bruun's rule is a simplistic model assuming a constant slope\n",
    "    # and relates the horizontal retreat distance (x) with sea-level rise.\n",
    "    return x - sea_level_rise * (x / initial_width)\n",
    "\n",
    "def dean_model(x, sea_level_rise):\n",
    "    # Dean model assumes profile convexity and allows calculation of new profile\n",
    "    return x - np.sqrt(sea_level_rise * x / initial_width)\n",
    "\n",
    "# Define a PyTorch Dataset\n",
    "class BeachProfileDataset(Dataset):\n",
    "    def __init__(self, file_path):\n",
    "        self.data = pd.read_excel(file_path)\n",
    "    \n",
    "    def __len__(self):\n",
    "        return len(self.data)\n",
    "    \n",
    "    def __getitem__(self, idx):\n",
    "        x = self.data.iloc[idx]['x']\n",
    "        y = self.data.iloc[idx]['y']\n",
    "        return torch.tensor([x], dtype=torch.float32), torch.tensor([y], dtype=torch.float32)\n",
    "\n",
    "# Define a PyTorch Model\n",
    "class BeachProfileModel(nn.Module):\n",
    "    def __init__(self):\n",
    "        super(BeachProfileModel, self).__init__()\n",
    "        self.linear1 = nn.Linear(1, 128)\n",
    "        self.relu = nn.ReLU()\n",
    "        self.linear2 = nn.Linear(128, 64)\n",
    "        self.linear3 = nn.Linear(64, 1)\n",
    "    \n",
    "    def forward(self, x):\n",
    "        x = self.linear1(x)\n",
    "        x = self.relu(x)\n",
    "        x = self.linear2(x)\n",
    "        x = self.relu(x)\n",
    "        x = self.linear3(x)\n",
    "        return x\n",
    "\n",
    "# Function to train the model\n",
    "def train_model(train_loader, model, criterion, optimizer, epochs):\n",
    "    for epoch in range(epochs):\n",
    "        for x, y in train_loader:\n",
    "            optimizer.zero_grad()\n",
    "            outputs = model(x)\n",
    "            loss = criterion(outputs, y)\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "\n",
    "# Function to evaluate the model\n",
    "def evaluate_model(test_loader, model, criterion):\n",
    "    total_loss = 0\n",
    "    output_list = []\n",
    "    with torch.no_grad():\n",
    "        for x, y in test_loader:\n",
    "            outputs = model(x)\n",
    "            # append outputs and y to output_list for further analysis\n",
    "            output_list.append((outputs, y))\n",
    "            # loss = criterion(outputs, y)\n",
    "            # total_loss += loss.item()\n",
    "    return output_list\n",
    "\n",
    "# Main function\n",
    "def main():\n",
    "    # Constants\n",
    "    global initial_width\n",
    "    initial_width = 1000  # assumed constant width of the beach for the models\n",
    "    \n",
    "    # Load Dataset\n",
    "    train_data_path = \"beach_profile_data/processed_data/beachdata_train.xlsx\"\n",
    "    test_data_path = \"beach_profile_data/processed_data/beachdata_test.xlsx\"\n",
    "    \n",
    "    train_dataset = BeachProfileDataset(train_data_path)\n",
    "    test_dataset = BeachProfileDataset(test_data_path)\n",
    "    \n",
    "    train_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)\n",
    "    test_loader = DataLoader(test_dataset, batch_size=32, shuffle=False)\n",
    "    \n",
    "    # Initialize Model, Loss Function and Optimizer\n",
    "    model = BeachProfileModel()\n",
    "    criterion = nn.MSELoss()\n",
    "    optimizer = optim.Adam(model.parameters(), lr=0.001)\n",
    "    epochs = 50\n",
    "\n",
    "    # Train the model\n",
    "    train_model(train_loader, model, criterion, optimizer, epochs)\n",
    "\n",
    "    # Evaluate the model\n",
    "    test_loss = evaluate_model(test_loader, model, criterion)\n",
    "    # print(f\"Test Loss: {test_loss}\")\n",
    "\n",
    "# Ensure the script is not executed on import\n",
    "if __name__ == \"__main__\":\n",
    "    main()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "id": "8afd0982",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[(tensor([[2.6853],\n",
      "        [2.4010],\n",
      "        [2.2390],\n",
      "        [2.0052],\n",
      "        [1.8089],\n",
      "        [1.5889],\n",
      "        [1.3951],\n",
      "        [1.1997],\n",
      "        [1.0285],\n",
      "        [0.8891],\n",
      "        [0.7433],\n",
      "        [0.6293],\n",
      "        [0.5619],\n",
      "        [0.5420],\n",
      "        [0.5147],\n",
      "        [2.6853],\n",
      "        [2.4326],\n",
      "        [2.3921],\n",
      "        [2.2996],\n",
      "        [2.2004],\n",
      "        [2.0830],\n",
      "        [1.9639],\n",
      "        [1.8432],\n",
      "        [1.7102],\n",
      "        [1.5912],\n",
      "        [1.4959],\n",
      "        [1.3945],\n",
      "        [1.2883],\n",
      "        [1.1907],\n",
      "        [1.0837],\n",
      "        [0.9955],\n",
      "        [0.8841]]), tensor([[ 2.5080],\n",
      "        [ 2.1330],\n",
      "        [ 1.8350],\n",
      "        [ 1.5140],\n",
      "        [ 1.1610],\n",
      "        [ 0.7650],\n",
      "        [ 0.3940],\n",
      "        [ 0.0160],\n",
      "        [-0.3090],\n",
      "        [-0.6030],\n",
      "        [-0.8270],\n",
      "        [-1.1040],\n",
      "        [-1.2730],\n",
      "        [-1.3560],\n",
      "        [-1.4440],\n",
      "        [ 2.6560],\n",
      "        [ 2.4230],\n",
      "        [ 2.2240],\n",
      "        [ 1.9960],\n",
      "        [ 1.7970],\n",
      "        [ 1.5720],\n",
      "        [ 1.3700],\n",
      "        [ 1.1550],\n",
      "        [ 0.9160],\n",
      "        [ 0.6660],\n",
      "        [ 0.4330],\n",
      "        [ 0.1910],\n",
      "        [-0.0620],\n",
      "        [-0.2950],\n",
      "        [-0.5170],\n",
      "        [-0.7540],\n",
      "        [-0.9130]])), (tensor([[0.7915],\n",
      "        [0.6944],\n",
      "        [0.5938],\n",
      "        [0.5297],\n",
      "        [0.4688],\n",
      "        [0.4469],\n",
      "        [0.4314],\n",
      "        [2.6853],\n",
      "        [2.4206],\n",
      "        [2.1613],\n",
      "        [1.9807],\n",
      "        [0.7969],\n",
      "        [0.7924],\n",
      "        [0.7410],\n",
      "        [0.6845],\n",
      "        [0.6577],\n",
      "        [0.6057],\n",
      "        [0.5466],\n",
      "        [0.4336],\n",
      "        [0.4152],\n",
      "        [0.4178],\n",
      "        [2.6853],\n",
      "        [2.4186],\n",
      "        [2.3062],\n",
      "        [2.1678],\n",
      "        [1.9585],\n",
      "        [1.7262],\n",
      "        [1.4829],\n",
      "        [1.2214],\n",
      "        [0.9646],\n",
      "        [0.7114],\n",
      "        [0.4862]]), tensor([[-1.1470],\n",
      "        [-1.4080],\n",
      "        [-1.7370],\n",
      "        [-1.9070],\n",
      "        [-2.2610],\n",
      "        [-2.3170],\n",
      "        [-2.4540],\n",
      "        [ 2.5700],\n",
      "        [ 2.3580],\n",
      "        [ 2.0370],\n",
      "        [ 1.8530],\n",
      "        [ 0.2010],\n",
      "        [ 0.1490],\n",
      "        [ 0.0310],\n",
      "        [-0.0840],\n",
      "        [-0.1600],\n",
      "        [-0.3120],\n",
      "        [-0.5110],\n",
      "        [-1.3860],\n",
      "        [-1.5290],\n",
      "        [-1.6590],\n",
      "        [ 2.6040],\n",
      "        [ 2.3250],\n",
      "        [ 2.1080],\n",
      "        [ 1.9350],\n",
      "        [ 1.6950],\n",
      "        [ 1.4850],\n",
      "        [ 1.2910],\n",
      "        [ 1.1070],\n",
      "        [ 1.0200],\n",
      "        [ 0.8900],\n",
      "        [ 0.6990]])), (tensor([[0.4482],\n",
      "        [0.4193],\n",
      "        [0.4193],\n",
      "        [0.4257],\n",
      "        [0.4303],\n",
      "        [0.4359],\n",
      "        [0.4409],\n",
      "        [0.4460],\n",
      "        [0.4510],\n",
      "        [0.4573],\n",
      "        [0.4638],\n",
      "        [0.4704],\n",
      "        [0.4767],\n",
      "        [0.4838],\n",
      "        [2.6853],\n",
      "        [2.4327],\n",
      "        [2.3867],\n",
      "        [2.2715],\n",
      "        [2.0709],\n",
      "        [1.8298],\n",
      "        [1.6814],\n",
      "        [1.5128],\n",
      "        [1.3223],\n",
      "        [1.0709],\n",
      "        [0.8891],\n",
      "        [0.7314],\n",
      "        [0.6081],\n",
      "        [0.4969],\n",
      "        [0.4680],\n",
      "        [2.6853],\n",
      "        [2.4467],\n",
      "        [2.4144]]), tensor([[ 0.4780],\n",
      "        [ 0.1680],\n",
      "        [-0.0130],\n",
      "        [-0.1660],\n",
      "        [-0.2780],\n",
      "        [-0.3970],\n",
      "        [-0.5500],\n",
      "        [-0.7240],\n",
      "        [-0.9010],\n",
      "        [-1.0920],\n",
      "        [-1.2360],\n",
      "        [-1.3630],\n",
      "        [-1.4530],\n",
      "        [-1.5380],\n",
      "        [ 2.8040],\n",
      "        [ 2.5880],\n",
      "        [ 2.4100],\n",
      "        [ 2.2100],\n",
      "        [ 2.0700],\n",
      "        [ 1.9110],\n",
      "        [ 1.8020],\n",
      "        [ 1.6440],\n",
      "        [ 1.4730],\n",
      "        [ 1.2160],\n",
      "        [ 0.9890],\n",
      "        [ 0.7960],\n",
      "        [ 0.6370],\n",
      "        [ 0.4200],\n",
      "        [ 0.2760],\n",
      "        [ 2.7110],\n",
      "        [ 2.5110],\n",
      "        [ 2.3190]])), (tensor([[2.3341],\n",
      "        [2.2640],\n",
      "        [2.1530],\n",
      "        [2.0498],\n",
      "        [1.9310],\n",
      "        [1.7778],\n",
      "        [1.6527],\n",
      "        [1.5179],\n",
      "        [1.3228],\n",
      "        [1.1618],\n",
      "        [0.8987],\n",
      "        [0.7219],\n",
      "        [0.5347],\n",
      "        [0.4678],\n",
      "        [0.4509],\n",
      "        [0.4380],\n",
      "        [0.4240],\n",
      "        [0.4155],\n",
      "        [0.4182],\n",
      "        [0.4209],\n",
      "        [0.4232],\n",
      "        [0.4247],\n",
      "        [0.4282],\n",
      "        [0.4303],\n",
      "        [2.6841],\n",
      "        [2.3787],\n",
      "        [2.1823],\n",
      "        [1.9536],\n",
      "        [1.6592],\n",
      "        [1.5154],\n",
      "        [1.1164],\n",
      "        [0.8389]]), tensor([[ 2.1020],\n",
      "        [ 1.8880],\n",
      "        [ 1.6950],\n",
      "        [ 1.5380],\n",
      "        [ 1.3790],\n",
      "        [ 1.1930],\n",
      "        [ 1.0570],\n",
      "        [ 0.9280],\n",
      "        [ 0.7690],\n",
      "        [ 0.6020],\n",
      "        [ 0.3100],\n",
      "        [ 0.1040],\n",
      "        [-0.1710],\n",
      "        [-0.3880],\n",
      "        [-0.6290],\n",
      "        [-0.7640],\n",
      "        [-0.9280],\n",
      "        [-1.0910],\n",
      "        [-1.2360],\n",
      "        [-1.3900],\n",
      "        [-1.5370],\n",
      "        [-1.6040],\n",
      "        [-1.7950],\n",
      "        [-1.9170],\n",
      "        [ 2.8090],\n",
      "        [ 2.3330],\n",
      "        [ 1.9540],\n",
      "        [ 1.6310],\n",
      "        [ 1.2370],\n",
      "        [ 1.1480],\n",
      "        [ 1.0700],\n",
      "        [ 0.9360]])), (tensor([[0.5408],\n",
      "        [0.4584],\n",
      "        [0.4327],\n",
      "        [0.4163],\n",
      "        [0.4192],\n",
      "        [0.4262],\n",
      "        [0.4325],\n",
      "        [0.4375],\n",
      "        [0.4431],\n",
      "        [0.4523],\n",
      "        [0.4596],\n",
      "        [0.4701],\n",
      "        [0.4827],\n",
      "        [0.4889],\n",
      "        [0.4906],\n",
      "        [2.6853],\n",
      "        [2.4283],\n",
      "        [2.1143],\n",
      "        [1.6013],\n",
      "        [0.9392],\n",
      "        [0.5183],\n",
      "        [0.4508],\n",
      "        [0.4174],\n",
      "        [0.4230],\n",
      "        [0.4346],\n",
      "        [0.4485],\n",
      "        [0.4612],\n",
      "        [0.4748],\n",
      "        [0.4850],\n",
      "        [0.4979],\n",
      "        [2.6853],\n",
      "        [1.6104]]), tensor([[ 0.7900],\n",
      "        [ 0.6070],\n",
      "        [ 0.4310],\n",
      "        [ 0.2690],\n",
      "        [ 0.1730],\n",
      "        [-0.0800],\n",
      "        [-0.3570],\n",
      "        [-0.6050],\n",
      "        [-0.8460],\n",
      "        [-1.2150],\n",
      "        [-1.4510],\n",
      "        [-1.7650],\n",
      "        [-2.2300],\n",
      "        [-2.4960],\n",
      "        [-2.5670],\n",
      "        [ 2.6330],\n",
      "        [ 2.3560],\n",
      "        [ 2.1690],\n",
      "        [ 2.0310],\n",
      "        [ 1.8480],\n",
      "        [ 1.6120],\n",
      "        [ 1.4670],\n",
      "        [ 1.4290],\n",
      "        [ 1.2480],\n",
      "        [ 0.9550],\n",
      "        [ 0.4610],\n",
      "        [-0.0090],\n",
      "        [-0.5560],\n",
      "        [-0.9420],\n",
      "        [-1.3960],\n",
      "        [ 2.5850],\n",
      "        [ 2.3480]])), (tensor([[0.8645],\n",
      "        [0.4319],\n",
      "        [0.4299],\n",
      "        [0.4460],\n",
      "        [0.4628],\n",
      "        [0.4821],\n",
      "        [0.5034],\n",
      "        [0.5213],\n",
      "        [0.5410],\n",
      "        [0.5561],\n",
      "        [0.5744],\n",
      "        [0.5967],\n",
      "        [0.6250],\n",
      "        [0.6421],\n",
      "        [0.6429],\n",
      "        [0.6499],\n",
      "        [2.6853],\n",
      "        [2.4173],\n",
      "        [2.3327],\n",
      "        [2.0197],\n",
      "        [1.0586],\n",
      "        [0.4373],\n",
      "        [0.4262],\n",
      "        [0.4424],\n",
      "        [0.4675],\n",
      "        [0.4916],\n",
      "        [0.5375],\n",
      "        [0.5602],\n",
      "        [0.6018],\n",
      "        [0.6194],\n",
      "        [2.6853],\n",
      "        [2.4359]]), tensor([[ 2.1580],\n",
      "        [ 1.8160],\n",
      "        [ 1.4160],\n",
      "        [ 1.0500],\n",
      "        [ 0.6910],\n",
      "        [ 0.2880],\n",
      "        [-0.1160],\n",
      "        [-0.5240],\n",
      "        [-0.9070],\n",
      "        [-1.2230],\n",
      "        [-1.5160],\n",
      "        [-1.7500],\n",
      "        [-2.0210],\n",
      "        [-2.1650],\n",
      "        [-2.2430],\n",
      "        [-2.3760],\n",
      "        [ 2.7440],\n",
      "        [ 2.5460],\n",
      "        [ 2.3730],\n",
      "        [ 2.1260],\n",
      "        [ 1.8490],\n",
      "        [ 1.3650],\n",
      "        [ 0.9010],\n",
      "        [ 0.5670],\n",
      "        [ 0.0860],\n",
      "        [-0.2890],\n",
      "        [-1.0180],\n",
      "        [-1.3340],\n",
      "        [-1.7980],\n",
      "        [-1.8580],\n",
      "        [ 2.6520],\n",
      "        [ 2.4040]])), (tensor([[2.4168],\n",
      "        [2.3510],\n",
      "        [2.2806],\n",
      "        [2.1743],\n",
      "        [2.0490],\n",
      "        [1.9111],\n",
      "        [1.7473],\n",
      "        [1.6211],\n",
      "        [1.5421],\n",
      "        [1.4603],\n",
      "        [1.3803],\n",
      "        [1.2872],\n",
      "        [1.2024],\n",
      "        [1.0382],\n",
      "        [0.4301],\n",
      "        [0.4182],\n",
      "        [2.6853],\n",
      "        [2.4356],\n",
      "        [2.3559],\n",
      "        [2.2234],\n",
      "        [2.0128],\n",
      "        [1.7972],\n",
      "        [1.7110],\n",
      "        [1.5009],\n",
      "        [1.3089],\n",
      "        [1.0938],\n",
      "        [0.9041],\n",
      "        [0.7114],\n",
      "        [0.5406],\n",
      "        [0.4611],\n",
      "        [0.4376],\n",
      "        [0.4154]]), tensor([[ 2.1890],\n",
      "        [ 2.0130],\n",
      "        [ 1.8410],\n",
      "        [ 1.5950],\n",
      "        [ 1.3760],\n",
      "        [ 1.1010],\n",
      "        [ 0.8320],\n",
      "        [ 0.5270],\n",
      "        [ 0.3400],\n",
      "        [ 0.1730],\n",
      "        [-0.0280],\n",
      "        [-0.2290],\n",
      "        [-0.4130],\n",
      "        [-0.7740],\n",
      "        [-2.2430],\n",
      "        [-2.3760],\n",
      "        [ 2.5420],\n",
      "        [ 2.3730],\n",
      "        [ 2.1720],\n",
      "        [ 1.9840],\n",
      "        [ 1.8150],\n",
      "        [ 1.6650],\n",
      "        [ 1.6020],\n",
      "        [ 1.3980],\n",
      "        [ 1.2290],\n",
      "        [ 1.0600],\n",
      "        [ 0.8970],\n",
      "        [ 0.7520],\n",
      "        [ 0.5930],\n",
      "        [ 0.3630],\n",
      "        [ 0.1400],\n",
      "        [-0.1200]])), (tensor([[0.4222],\n",
      "        [0.4329],\n",
      "        [0.4431],\n",
      "        [0.4628],\n",
      "        [0.4754],\n",
      "        [2.6853],\n",
      "        [2.4204],\n",
      "        [2.3042],\n",
      "        [2.1143],\n",
      "        [1.9409],\n",
      "        [1.7372],\n",
      "        [1.5799],\n",
      "        [1.1345],\n",
      "        [0.4595],\n",
      "        [0.4248],\n",
      "        [0.4422],\n",
      "        [0.4580],\n",
      "        [0.4732]]), tensor([[-0.3510],\n",
      "        [-0.5600],\n",
      "        [-0.6430],\n",
      "        [-0.9960],\n",
      "        [-1.0910],\n",
      "        [ 2.4240],\n",
      "        [ 2.1230],\n",
      "        [ 1.8130],\n",
      "        [ 1.5620],\n",
      "        [ 1.2880],\n",
      "        [ 1.0500],\n",
      "        [ 0.8550],\n",
      "        [ 0.9720],\n",
      "        [ 0.7700],\n",
      "        [ 0.6120],\n",
      "        [ 0.3450],\n",
      "        [ 0.0930],\n",
      "        [-0.0580]]))]\n"
     ]
    }
   ],
   "source": [
    "# Load Dataset\n",
    "train_data_path = \"beach_profile_data/processed_data/beachdata_train.xlsx\"\n",
    "test_data_path = \"beach_profile_data/processed_data/beachdata_test.xlsx\"\n",
    "\n",
    "train_dataset = BeachProfileDataset(train_data_path)\n",
    "test_dataset = BeachProfileDataset(test_data_path)\n",
    "\n",
    "train_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)\n",
    "test_loader = DataLoader(test_dataset, batch_size=32, shuffle=False)\n",
    "\n",
    "# Initialize Model, Loss Function and Optimizer\n",
    "model = BeachProfileModel()\n",
    "criterion = nn.MSELoss()\n",
    "optimizer = optim.Adam(model.parameters(), lr=0.001)\n",
    "epochs = 50\n",
    "\n",
    "# Train the model\n",
    "train_model(train_loader, model, criterion, optimizer, epochs)\n",
    "\n",
    "# Evaluate the model\n",
    "test_loss = evaluate_model(test_loader, model, criterion)\n",
    "print(test_loss)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "fd693194",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "import pandas as pd\n",
      "import numpy as np\n",
      "from sklearn.preprocessing import StandardScaler, OneHotEncoder\n",
      "from sklearn.compose import ColumnTransformer\n",
      "from sklearn.pipeline import Pipeline\n",
      "from torch import nn\n",
      "import torch\n",
      "from torch.utils.data import DataLoader, TensorDataset\n",
      "\n",
      "def load_and_preprocess_data():\n",
      "    # Load the datasets using pandas\n",
      "    train_data = pd.read_excel(\"beach_profile_data/processed_data/beachdata_train.xlsx\")\n",
      "    test_data = pd.read_excel(\"beach_profile_data/processed_data/beachdata_test.xlsx\")\n",
      "    \n",
      "    # Define relevant columns, including features and target\n",
      "    features = ['Annual Mean Period', 'Annual Mean Spring Tidal Range', \n",
      "                'Annual Mean Tidal Range', 'Breaker Wave Height Hb', \n",
      "                'Deep Water Wave Height Hd', 'Dimensionless Settling Velocity', \n",
      "                'High Tide Sediment Settling Velocity', 'Intertidal Slope', \n",
      "                'Kurtosis', 'Latitude', 'Longitude', 'Mean Grain Size', \n",
      "                'Mean Grain Size (Mz)', 'Mean Wave Height', 'Period', \n",
      "                'Profile Azimuth', 'Profile Length', 'Relative Tidal Range', \n",
      "                'Skewness', 'Sorting Coefficient', 'x']\n",
      "    \n",
      "    # Separate features and target variable\n",
      "    X_train = train_data[features]\n",
      "    y_train = train_data['y']\n",
      "    X_test = test_data[features]\n",
      "    y_test = test_data['y']\n",
      "    \n",
      "    # Preprocess the 'Dominant Wave Direction' feature (one-hot encoding)\n",
      "    preprocessor = ColumnTransformer(\n",
      "        transformers=[\n",
      "            ('num', StandardScaler(), features),\n",
      "            ('cat', OneHotEncoder(), ['Dominant Wave Direction'])\n",
      "        ])\n",
      "    \n",
      "    # Create the pipeline for preprocessing\n",
      "    X_train = preprocessor.fit_transform(train_data)\n",
      "    X_test = preprocessor.transform(test_data)\n",
      "    \n",
      "    return X_train, y_train, X_test, y_test\n",
      "\n",
      "def apply_bruun_dean_models(dataframe):\n",
      "    # Bruun rule is generally linear, Dean model is power law (x^(2/3) relationship)\n",
      "    # Create initial predictions using the equations\n",
      "    dataframe['Bruun_Prediction'] = dataframe['x']  # Placeholder, usually needs a coefficient\n",
      "    dataframe['Dean_Prediction'] = dataframe['x'] ** (2 / 3)\n",
      "    return dataframe\n",
      "\n",
      "def build_deep_learning_model(inputshape):\n",
      "    class SimpleMLP(nn.Module):\n",
      "        def __init__(self):\n",
      "            super(SimpleMLP, self).__init__()\n",
      "            self.fc1 = nn.Linear(inputshape, 64)\n",
      "            self.fc2 = nn.Linear(64, 32)\n",
      "            self.fc3 = nn.Linear(32, 1)\n",
      "            self.relu = nn.ReLU()\n",
      "        \n",
      "        def forward(self, x):\n",
      "            x = self.relu(self.fc1(x))\n",
      "            x = self.relu(self.fc2(x))\n",
      "            x = self.fc3(x)\n",
      "            return x\n",
      "    \n",
      "    model = SimpleMLP()\n",
      "    return model\n",
      "\n",
      "def train_deep_learning_model(model, X_train, y_train):\n",
      "    # Prepare data loader for training\n",
      "    train_dataset = TensorDataset(torch.tensor(X_train, dtype=torch.float32), torch.tensor(y_train.values, dtype=torch.float32))\n",
      "    train_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)\n",
      "    \n",
      "    # Initialize optimizer and loss function\n",
      "    criterion = nn.MSELoss()\n",
      "    optimizer = torch.optim.Adam(model.parameters(), lr=0.001)\n",
      "    \n",
      "    # Training loop\n",
      "    for epoch in range(100):  # Simple fixed number of epochs for illustration\n",
      "        for X_batch, y_batch in train_loader:\n",
      "            optimizer.zero_grad()\n",
      "            outputs = model(X_batch)\n",
      "            loss = criterion(outputs.flatten(), y_batch)\n",
      "            loss.backward()\n",
      "            optimizer.step()\n",
      "    \n",
      "    return model\n",
      "\n",
      "def evaluate_deep_learning_model(model, X_test, y_test):\n",
      "    # Prepare data loader for testing\n",
      "    test_dataset = TensorDataset(torch.tensor(X_test, dtype=torch.float32), torch.tensor(y_test.values, dtype=torch.float32))\n",
      "    test_loader = DataLoader(test_dataset, batch_size=32, shuffle=False)\n",
      "    \n",
      "    # Set the model to evaluation mode\n",
      "    model.eval()\n",
      "    \n",
      "    # Initialize loss and performance metrics\n",
      "    criterion = nn.MSELoss()\n",
      "    total_loss = 0\n",
      "    \n",
      "    with torch.no_grad():\n",
      "        for X_batch, y_batch in test_loader:\n",
      "            outputs = model(X_batch)\n",
      "            loss = criterion(outputs.flatten(), y_batch)\n",
      "            total_loss += loss.item()\n",
      "    \n",
      "    average_loss = total_loss / len(test_loader)\n",
      "    results = {\n",
      "        \"Mean Squared Error\": average_loss,\n",
      "    }\n",
      "    return results\n",
      "\n",
      "def main():\n",
      "    # Load and preprocess the data\n",
      "    X_train, y_train, X_test, y_test = load_and_preprocess_data()\n",
      "\n",
      "    # Load dataframe and apply the Bruun and Dean models\n",
      "    df_train = pd.DataFrame(X_train, columns=['x'] + list(range(X_train.shape[1] - 1)))\n",
      "    df_train = apply_bruun_dean_models(df_train)\n",
      "\n",
      "    # Build the deep learning model\n",
      "    model = build_deep_learning_model(X_train.shape[1])\n",
      "\n",
      "    # Train the model\n",
      "    trained_model = train_deep_learning_model(model, X_train, y_train)\n",
      "\n",
      "    # Evaluate the model\n",
      "    evaluation_results = evaluate_deep_learning_model(trained_model, X_test, y_test)\n",
      "\n",
      "    return evaluation_results\n"
     ]
    }
   ],
   "source": [
    "print(\"import pandas as pd\\nimport numpy as np\\nfrom sklearn.preprocessing import StandardScaler, OneHotEncoder\\nfrom sklearn.compose import ColumnTransformer\\nfrom sklearn.pipeline import Pipeline\\nfrom torch import nn\\nimport torch\\nfrom torch.utils.data import DataLoader, TensorDataset\\n\\ndef load_and_preprocess_data():\\n    # Load the datasets using pandas\\n    train_data = pd.read_excel(\\\"beach_profile_data/processed_data/beachdata_train.xlsx\\\")\\n    test_data = pd.read_excel(\\\"beach_profile_data/processed_data/beachdata_test.xlsx\\\")\\n    \\n    # Define relevant columns, including features and target\\n    features = ['Annual Mean Period', 'Annual Mean Spring Tidal Range', \\n                'Annual Mean Tidal Range', 'Breaker Wave Height Hb', \\n                'Deep Water Wave Height Hd', 'Dimensionless Settling Velocity', \\n                'High Tide Sediment Settling Velocity', 'Intertidal Slope', \\n                'Kurtosis', 'Latitude', 'Longitude', 'Mean Grain Size', \\n                'Mean Grain Size (Mz)', 'Mean Wave Height', 'Period', \\n                'Profile Azimuth', 'Profile Length', 'Relative Tidal Range', \\n                'Skewness', 'Sorting Coefficient', 'x']\\n    \\n    # Separate features and target variable\\n    X_train = train_data[features]\\n    y_train = train_data['y']\\n    X_test = test_data[features]\\n    y_test = test_data['y']\\n    \\n    # Preprocess the 'Dominant Wave Direction' feature (one-hot encoding)\\n    preprocessor = ColumnTransformer(\\n        transformers=[\\n            ('num', StandardScaler(), features),\\n            ('cat', OneHotEncoder(), ['Dominant Wave Direction'])\\n        ])\\n    \\n    # Create the pipeline for preprocessing\\n    X_train = preprocessor.fit_transform(train_data)\\n    X_test = preprocessor.transform(test_data)\\n    \\n    return X_train, y_train, X_test, y_test\\n\\ndef apply_bruun_dean_models(dataframe):\\n    # Bruun rule is generally linear, Dean model is power law (x^(2/3) relationship)\\n    # Create initial predictions using the equations\\n    dataframe['Bruun_Prediction'] = dataframe['x']  # Placeholder, usually needs a coefficient\\n    dataframe['Dean_Prediction'] = dataframe['x'] ** (2 / 3)\\n    return dataframe\\n\\ndef build_deep_learning_model(inputshape):\\n    class SimpleMLP(nn.Module):\\n        def __init__(self):\\n            super(SimpleMLP, self).__init__()\\n            self.fc1 = nn.Linear(inputshape, 64)\\n            self.fc2 = nn.Linear(64, 32)\\n            self.fc3 = nn.Linear(32, 1)\\n            self.relu = nn.ReLU()\\n        \\n        def forward(self, x):\\n            x = self.relu(self.fc1(x))\\n            x = self.relu(self.fc2(x))\\n            x = self.fc3(x)\\n            return x\\n    \\n    model = SimpleMLP()\\n    return model\\n\\ndef train_deep_learning_model(model, X_train, y_train):\\n    # Prepare data loader for training\\n    train_dataset = TensorDataset(torch.tensor(X_train, dtype=torch.float32), torch.tensor(y_train.values, dtype=torch.float32))\\n    train_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)\\n    \\n    # Initialize optimizer and loss function\\n    criterion = nn.MSELoss()\\n    optimizer = torch.optim.Adam(model.parameters(), lr=0.001)\\n    \\n    # Training loop\\n    for epoch in range(100):  # Simple fixed number of epochs for illustration\\n        for X_batch, y_batch in train_loader:\\n            optimizer.zero_grad()\\n            outputs = model(X_batch)\\n            loss = criterion(outputs.flatten(), y_batch)\\n            loss.backward()\\n            optimizer.step()\\n    \\n    return model\\n\\ndef evaluate_deep_learning_model(model, X_test, y_test):\\n    # Prepare data loader for testing\\n    test_dataset = TensorDataset(torch.tensor(X_test, dtype=torch.float32), torch.tensor(y_test.values, dtype=torch.float32))\\n    test_loader = DataLoader(test_dataset, batch_size=32, shuffle=False)\\n    \\n    # Set the model to evaluation mode\\n    model.eval()\\n    \\n    # Initialize loss and performance metrics\\n    criterion = nn.MSELoss()\\n    total_loss = 0\\n    \\n    with torch.no_grad():\\n        for X_batch, y_batch in test_loader:\\n            outputs = model(X_batch)\\n            loss = criterion(outputs.flatten(), y_batch)\\n            total_loss += loss.item()\\n    \\n    average_loss = total_loss / len(test_loader)\\n    results = {\\n        \\\"Mean Squared Error\\\": average_loss,\\n    }\\n    return results\\n\\ndef main():\\n    # Load and preprocess the data\\n    X_train, y_train, X_test, y_test = load_and_preprocess_data()\\n\\n    # Load dataframe and apply the Bruun and Dean models\\n    df_train = pd.DataFrame(X_train, columns=['x'] + list(range(X_train.shape[1] - 1)))\\n    df_train = apply_bruun_dean_models(df_train)\\n\\n    # Build the deep learning model\\n    model = build_deep_learning_model(X_train.shape[1])\\n\\n    # Train the model\\n    trained_model = train_deep_learning_model(model, X_train, y_train)\\n\\n    # Evaluate the model\\n    evaluation_results = evaluate_deep_learning_model(trained_model, X_test, y_test)\\n\\n    return evaluation_results\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "f39236fc",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "from sklearn.preprocessing import StandardScaler, OneHotEncoder\n",
    "from sklearn.compose import ColumnTransformer\n",
    "from sklearn.pipeline import Pipeline\n",
    "from torch import nn\n",
    "import torch\n",
    "from torch.utils.data import DataLoader, TensorDataset\n",
    "\n",
    "def load_and_preprocess_data():\n",
    "    # Load the datasets using pandas\n",
    "    train_data = pd.read_excel(\"beach_profile_data/processed_data/beachdata_train.xlsx\")\n",
    "    test_data = pd.read_excel(\"beach_profile_data/processed_data/beachdata_test.xlsx\")\n",
    "    \n",
    "    # Define relevant columns, including features and target\n",
    "    features = ['Annual Mean Period', 'Annual Mean Spring Tidal Range', \n",
    "                'Annual Mean Tidal Range', 'Breaker Wave Height Hb', \n",
    "                'Deep Water Wave Height Hd', 'Dimensionless Settling Velocity', \n",
    "                'High Tide Sediment Settling Velocity', 'Intertidal Slope', \n",
    "                'Kurtosis', 'Latitude', 'Longitude', 'Mean Grain Size', \n",
    "                'Mean Grain Size (Mz)', 'Mean Wave Height', 'Period', \n",
    "                'Profile Azimuth', 'Profile Length', 'Relative Tidal Range', \n",
    "                'Skewness', 'Sorting Coefficient', 'x']\n",
    "    \n",
    "    # Separate features and target variable\n",
    "    X_train = train_data[features]\n",
    "    y_train = train_data['y']\n",
    "    X_test = test_data[features]\n",
    "    y_test = test_data['y']\n",
    "    \n",
    "    # Preprocess the 'Dominant Wave Direction' feature (one-hot encoding)\n",
    "    preprocessor = ColumnTransformer(\n",
    "        transformers=[\n",
    "            ('num', StandardScaler(), features),\n",
    "            ('cat', OneHotEncoder(), ['Dominant Wave Direction'])\n",
    "        ])\n",
    "    \n",
    "    # Create the pipeline for preprocessing\n",
    "    X_train = preprocessor.fit_transform(train_data)\n",
    "    X_test = preprocessor.transform(test_data)\n",
    "    \n",
    "    return X_train, y_train, X_test, y_test\n",
    "\n",
    "def apply_bruun_dean_models(dataframe):\n",
    "    # Bruun rule is generally linear, Dean model is power law (x^(2/3) relationship)\n",
    "    # Create initial predictions using the equations\n",
    "    dataframe['Bruun_Prediction'] = dataframe['x']  # Placeholder, usually needs a coefficient\n",
    "    dataframe['Dean_Prediction'] = dataframe['x'] ** (2 / 3)\n",
    "    return dataframe\n",
    "\n",
    "def build_deep_learning_model(inputshape):\n",
    "    class SimpleMLP(nn.Module):\n",
    "        def __init__(self):\n",
    "            super(SimpleMLP, self).__init__()\n",
    "            self.fc1 = nn.Linear(inputshape, 64)\n",
    "            self.fc2 = nn.Linear(64, 32)\n",
    "            self.fc3 = nn.Linear(32, 1)\n",
    "            self.relu = nn.ReLU()\n",
    "        \n",
    "        def forward(self, x):\n",
    "            x = self.relu(self.fc1(x))\n",
    "            x = self.relu(self.fc2(x))\n",
    "            x = self.fc3(x)\n",
    "            return x\n",
    "    \n",
    "    model = SimpleMLP()\n",
    "    return model\n",
    "\n",
    "def train_deep_learning_model(model, X_train, y_train):\n",
    "    # Prepare data loader for training\n",
    "    train_dataset = TensorDataset(torch.tensor(X_train, dtype=torch.float32), torch.tensor(y_train.values, dtype=torch.float32))\n",
    "    train_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)\n",
    "    \n",
    "    # Initialize optimizer and loss function\n",
    "    criterion = nn.MSELoss()\n",
    "    optimizer = torch.optim.Adam(model.parameters(), lr=0.001)\n",
    "    \n",
    "    # Training loop\n",
    "    for epoch in range(100):  # Simple fixed number of epochs for illustration\n",
    "        for X_batch, y_batch in train_loader:\n",
    "            optimizer.zero_grad()\n",
    "            outputs = model(X_batch)\n",
    "            loss = criterion(outputs.flatten(), y_batch)\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "    \n",
    "    return model\n",
    "\n",
    "def evaluate_deep_learning_model(model, X_test, y_test):\n",
    "    # Prepare data loader for testing\n",
    "    test_dataset = TensorDataset(torch.tensor(X_test, dtype=torch.float32), torch.tensor(y_test.values, dtype=torch.float32))\n",
    "    test_loader = DataLoader(test_dataset, batch_size=32, shuffle=False)\n",
    "    \n",
    "    # Set the model to evaluation mode\n",
    "    model.eval()\n",
    "    \n",
    "    # Initialize loss and performance metrics\n",
    "    criterion = nn.MSELoss()\n",
    "    total_loss = 0\n",
    "    \n",
    "    with torch.no_grad():\n",
    "        for X_batch, y_batch in test_loader:\n",
    "            outputs = model(X_batch)\n",
    "            loss = criterion(outputs.flatten(), y_batch)\n",
    "            total_loss += loss.item()\n",
    "    \n",
    "    average_loss = total_loss / len(test_loader)\n",
    "    results = {\n",
    "        \"Mean Squared Error\": average_loss,\n",
    "    }\n",
    "    return results\n",
    "\n",
    "def main():\n",
    "    # Load and preprocess the data\n",
    "    X_train, y_train, X_test, y_test = load_and_preprocess_data()\n",
    "\n",
    "    # Load dataframe and apply the Bruun and Dean models\n",
    "    df_train = pd.DataFrame(X_train, columns=['x'] + list(range(X_train.shape[1] - 1)))\n",
    "    df_train = apply_bruun_dean_models(df_train)\n",
    "\n",
    "    # Build the deep learning model\n",
    "    model = build_deep_learning_model(X_train.shape[1])\n",
    "\n",
    "    # Train the model\n",
    "    trained_model = train_deep_learning_model(model, X_train, y_train)\n",
    "\n",
    "    # Evaluate the model\n",
    "    evaluation_results = evaluate_deep_learning_model(trained_model, X_test, y_test)\n",
    "\n",
    "    return evaluation_results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "e381564a",
   "metadata": {},
   "outputs": [],
   "source": [
    "result_temp = main()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "6e3e1fd1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'Mean Squared Error': 1.0713630467653275}\n"
     ]
    }
   ],
   "source": [
    "print(result_temp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "ea198e8f",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "from sklearn.preprocessing import LabelEncoder, StandardScaler\n",
    "from sklearn.model_selection import train_test_split\n",
    "\n",
    "# Bruun model: y = y0 - (S / (L + x))\n",
    "def bruun_model(x, y0, S, L):\n",
    "    \"\"\"\n",
    "    Bruun model for sea level change with respect to distance.\n",
    "    x: distance from origin\n",
    "    y0: initial elevation\n",
    "    S: sea level rise\n",
    "    L: width of active profile\n",
    "    Returns: elevation at distance x\n",
    "    \"\"\"\n",
    "    return y0 - (S / (L + x))\n",
    "\n",
    "# Dean model: y = A * x^(2/3)\n",
    "def dean_model(x, A):\n",
    "    \"\"\"\n",
    "    Dean model for equilibrium beach profile.\n",
    "    x: distance from origin\n",
    "    A: dimensional profile scale parameter\n",
    "    Returns: elevation at distance x\n",
    "    \"\"\"\n",
    "    return A * np.power(x, 2/3)\n",
    "\n",
    "class BeachProfileNet(nn.Module):\n",
    "    def __init__(self, input_dim):\n",
    "        super(BeachProfileNet, self).__init__()\n",
    "        self.model = nn.Sequential(\n",
    "            nn.Linear(input_dim, 64),\n",
    "            nn.ReLU(),\n",
    "            nn.Linear(64, 32),\n",
    "            nn.ReLU(),\n",
    "            nn.Linear(32, 1)\n",
    "        )\n",
    "    def forward(self, x):\n",
    "        return self.model(x)\n",
    "\n",
    "def load_and_preprocess_data(train_path, test_path):\n",
    "    # Load data\n",
    "    train_df = pd.read_excel(train_path)\n",
    "    test_df = pd.read_excel(test_path)\n",
    "\n",
    "    # Concatenate for consistent encoding\n",
    "    full_df = pd.concat([train_df, test_df], axis=0, ignore_index=True)\n",
    "\n",
    "    # Encode 'Dominant Wave Direction'\n",
    "    if 'Dominant Wave Direction' in full_df.columns:\n",
    "        le = LabelEncoder()\n",
    "        full_df['Dominant Wave Direction'] = le.fit_transform(full_df['Dominant Wave Direction'].astype(str))\n",
    "\n",
    "    # Select features\n",
    "    feature_cols = [col for col in full_df.columns if col not in ['y']]\n",
    "    X = full_df[feature_cols].values\n",
    "    y = full_df['y'].values.reshape(-1, 1)\n",
    "\n",
    "    # Standardize features\n",
    "    scaler_X = StandardScaler()\n",
    "    scaler_y = StandardScaler()\n",
    "    X_scaled = scaler_X.fit_transform(X)\n",
    "    y_scaled = scaler_y.fit_transform(y)\n",
    "\n",
    "    # Split back to train/test\n",
    "    X_train = X_scaled[:len(train_df)]\n",
    "    y_train = y_scaled[:len(train_df)]\n",
    "    X_test = X_scaled[len(train_df):]\n",
    "    y_test = y_scaled[len(train_df):]\n",
    "\n",
    "    return X_train, y_train, X_test, y_test, scaler_X, scaler_y, feature_cols\n",
    "\n",
    "def train_model(X_train, y_train, input_dim, epochs=100, lr=0.001):\n",
    "    model = BeachProfileNet(input_dim)\n",
    "    criterion = nn.MSELoss()\n",
    "    optimizer = optim.Adam(model.parameters(), lr=lr)\n",
    "    X_train_tensor = torch.tensor(X_train, dtype=torch.float32)\n",
    "    y_train_tensor = torch.tensor(y_train, dtype=torch.float32)\n",
    "    for epoch in range(epochs):\n",
    "        model.train()\n",
    "        optimizer.zero_grad()\n",
    "        outputs = model(X_train_tensor)\n",
    "        loss = criterion(outputs, y_train_tensor)\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "    return model\n",
    "\n",
    "def evaluate_model(model, X_test, y_test, scaler_y):\n",
    "    model.eval()\n",
    "    X_test_tensor = torch.tensor(X_test, dtype=torch.float32)\n",
    "    with torch.no_grad():\n",
    "        preds = model(X_test_tensor).numpy()\n",
    "    preds_rescaled = scaler_y.inverse_transform(preds)\n",
    "    y_test_rescaled = scaler_y.inverse_transform(y_test)\n",
    "    mse = np.mean((preds_rescaled - y_test_rescaled) ** 2)\n",
    "    return mse, preds_rescaled, y_test_rescaled\n",
    "\n",
    "def main():\n",
    "    train_path = \"beach_profile_data/processed_data/beachdata_train.xlsx\"\n",
    "    test_path = \"beach_profile_data/processed_data/beachdata_test.xlsx\"\n",
    "    X_train, y_train, X_test, y_test, scaler_X, scaler_y, feature_cols = load_and_preprocess_data(train_path, test_path)\n",
    "    input_dim = X_train.shape[1]\n",
    "    model = train_model(X_train, y_train, input_dim)\n",
    "    mse, preds, y_true = evaluate_model(model, X_test, y_test, scaler_y)\n",
    "    print(f\"Test MSE: {mse:.4f}\")\n",
    "    # Example usage of Bruun and Dean models\n",
    "    x_example = np.linspace(0, 100, 100)\n",
    "    y_bruun = bruun_model(x_example, y0=5, S=1, L=50)\n",
    "    y_dean = dean_model(x_example, A=0.1)\n",
    "    print(\"Bruun model example output (first 5):\", y_bruun[:5])\n",
    "    print(\"Dean model example output (first 5):\", y_dean[:5])\n",
    "\n",
    "# The script does not execute anything unless main() is called. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "538231a3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test MSE: 0.8063\n",
      "Bruun model example output (first 5): [4.98       4.98039604 4.9807767  4.98114286 4.98149533]\n",
      "Dean model example output (first 5): [0.         0.10067227 0.15980727 0.20940676 0.25367823]\n"
     ]
    }
   ],
   "source": [
    "main()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d11de23b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "from torch.utils.data import Dataset, DataLoader\n",
    "from sklearn.preprocessing import LabelEncoder, StandardScaler\n",
    "from sklearn.model_selection import train_test_split\n",
    "\n",
    "# -----------------------------\n",
    "# 1. Mathematical Models\n",
    "# -----------------------------\n",
    "\n",
    "def bruun_model(x, S, L, h, B):\n",
    "    \"\"\"\n",
    "    Bruun Rule: y(x) = S - (S / L) * (x - (h * L / S) + B)\n",
    "    S: Sea level rise\n",
    "    L: Width of active profile\n",
    "    h: Depth of closure\n",
    "    B: Berm height\n",
    "    x: Distance from origin (numpy array or float)\n",
    "    Returns predicted elevation y.\n",
    "    \"\"\"\n",
    "    return S - (S / L) * (x - (h * L / S) + B)\n",
    "\n",
    "def dean_model(x, A):\n",
    "    \"\"\"\n",
    "    Dean Profile: y(x) = A * x^(2/3)\n",
    "    A: Dean parameter (related to sediment size)\n",
    "    x: Distance from origin (numpy array or float)\n",
    "    Returns predicted elevation y.\n",
    "    \"\"\"\n",
    "    return A * np.power(x, 2/3)\n",
    "\n",
    "# -----------------------------\n",
    "# 2. Dataset and Preprocessing\n",
    "# -----------------------------\n",
    "\n",
    "class BeachProfileDataset(Dataset):\n",
    "    def __init__(self, df, feature_cols, target_col, scaler=None, label_encoders=None, fit_scaler=False):\n",
    "        self.X = df[feature_cols].copy()\n",
    "        self.y = df[target_col].values.astype(np.float32)\n",
    "        self.label_encoders = label_encoders or {}\n",
    "        # Encode categorical features\n",
    "        for col in self.X.select_dtypes(include=['object', 'category']).columns:\n",
    "            if col not in self.label_encoders:\n",
    "                self.label_encoders[col] = LabelEncoder()\n",
    "                self.X[col] = self.label_encoders[col].fit_transform(self.X[col])\n",
    "            else:\n",
    "                self.X[col] = self.label_encoders[col].transform(self.X[col])\n",
    "        # Scale features\n",
    "        if scaler is None:\n",
    "            scaler = StandardScaler()\n",
    "            if fit_scaler:\n",
    "                self.X = scaler.fit_transform(self.X)\n",
    "            else:\n",
    "                self.X = scaler.transform(self.X)\n",
    "        else:\n",
    "            if fit_scaler:\n",
    "                self.X = scaler.fit_transform(self.X)\n",
    "            else:\n",
    "                self.X = scaler.transform(self.X)\n",
    "        self.X = self.X.astype(np.float32)\n",
    "        self.scaler = scaler\n",
    "\n",
    "    def __len__(self):\n",
    "        return len(self.y)\n",
    "\n",
    "    def __getitem__(self, idx):\n",
    "        return self.X[idx], self.y[idx]\n",
    "\n",
    "# -----------------------------\n",
    "# 3. Neural Network Model\n",
    "# -----------------------------\n",
    "\n",
    "class BeachProfileNet(nn.Module):\n",
    "    def __init__(self, input_dim):\n",
    "        super().__init__()\n",
    "        self.model = nn.Sequential(\n",
    "            nn.Linear(input_dim, 64),\n",
    "            nn.ReLU(),\n",
    "            nn.Linear(64, 32),\n",
    "            nn.ReLU(),\n",
    "            nn.Linear(32, 1)\n",
    "        )\n",
    "    def forward(self, x):\n",
    "        return self.model(x).squeeze(-1)\n",
    "\n",
    "# -----------------------------\n",
    "# 4. Training and Evaluation\n",
    "# -----------------------------\n",
    "\n",
    "def train_model(model, dataloader, criterion, optimizer, device, epochs=50):\n",
    "    model.train()\n",
    "    for epoch in range(epochs):\n",
    "        epoch_loss = 0.0\n",
    "        for X_batch, y_batch in dataloader:\n",
    "            X_batch = X_batch.to(device)\n",
    "            y_batch = y_batch.to(device)\n",
    "            optimizer.zero_grad()\n",
    "            outputs = model(X_batch)\n",
    "            loss = criterion(outputs, y_batch)\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "            epoch_loss += loss.item() * len(y_batch)\n",
    "        avg_loss = epoch_loss / len(dataloader.dataset)\n",
    "        if epoch % 10 == 0 or epoch == epochs - 1:\n",
    "            print(f\"Epoch {epoch+1}/{epochs}, Loss: {avg_loss:.4f}\")\n",
    "    return model\n",
    "\n",
    "def evaluate_model(model, dataloader, criterion, device):\n",
    "    model.eval()\n",
    "    total_loss = 0.0\n",
    "    preds = []\n",
    "    trues = []\n",
    "    with torch.no_grad():\n",
    "        for X_batch, y_batch in dataloader:\n",
    "            X_batch = X_batch.to(device)\n",
    "            y_batch = y_batch.to(device)\n",
    "            outputs = model(X_batch)\n",
    "            loss = criterion(outputs, y_batch)\n",
    "            total_loss += loss.item() * len(y_batch)\n",
    "            preds.append(outputs.cpu().numpy())\n",
    "            trues.append(y_batch.cpu().numpy())\n",
    "    avg_loss = total_loss / len(dataloader.dataset)\n",
    "    preds = np.concatenate(preds)\n",
    "    trues = np.concatenate(trues)\n",
    "    return avg_loss, preds, trues\n",
    "\n",
    "# -----------------------------\n",
    "# 5. Main Function\n",
    "# -----------------------------\n",
    "\n",
    "def main():\n",
    "    # Data paths\n",
    "    train_path = \"beach_profile_data/processed_data/beachdata_train.xlsx\"\n",
    "    test_path = \"beach_profile_data/processed_data/beachdata_test.xlsx\"\n",
    "\n",
    "    # Load data\n",
    "    train_df = pd.read_excel(train_path)\n",
    "    test_df = pd.read_excel(test_path)\n",
    "\n",
    "    # Feature selection\n",
    "    # Use all numeric columns and 'Dominant Wave Direction' as features, except 'y' (target)\n",
    "    feature_cols = [col for col in train_df.columns if col not in ['y']]\n",
    "    target_col = 'y'\n",
    "\n",
    "    # Find categorical columns\n",
    "    cat_cols = train_df.select_dtypes(include=['object', 'category']).columns.tolist()\n",
    "    # Ensure 'Dominant Wave Direction' is encoded\n",
    "    if 'Dominant Wave Direction' not in cat_cols:\n",
    "        cat_cols.append('Dominant Wave Direction')\n",
    "\n",
    "    # Fit label encoders on train, apply to test\n",
    "    label_encoders = {}\n",
    "    for col in cat_cols:\n",
    "        le = LabelEncoder()\n",
    "        train_df[col] = le.fit_transform(train_df[col])\n",
    "        test_df[col] = le.transform(test_df[col])\n",
    "        label_encoders[col] = le\n",
    "\n",
    "    # Standardize features\n",
    "    scaler = StandardScaler()\n",
    "    train_X = scaler.fit_transform(train_df[feature_cols])\n",
    "    test_X = scaler.transform(test_df[feature_cols])\n",
    "\n",
    "    # Dataset and DataLoader\n",
    "    train_dataset = BeachProfileDataset(train_df, feature_cols, target_col, scaler=scaler, label_encoders=label_encoders, fit_scaler=False)\n",
    "    test_dataset = BeachProfileDataset(test_df, feature_cols, target_col, scaler=scaler, label_encoders=label_encoders, fit_scaler=False)\n",
    "\n",
    "    train_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)\n",
    "    test_loader = DataLoader(test_dataset, batch_size=32, shuffle=False)\n",
    "\n",
    "    # Model\n",
    "    device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "    model = BeachProfileNet(input_dim=len(feature_cols)).to(device)\n",
    "    criterion = nn.MSELoss()\n",
    "    optimizer = torch.optim.Adam(model.parameters(), lr=0.001)\n",
    "\n",
    "    # Train\n",
    "    model = train_model(model, train_loader, criterion, optimizer, device, epochs=50)\n",
    "    \n",
    "    # Evaluate\n",
    "    test_loss, preds, trues = evaluate_model(model, test_loader, criterion, device)\n",
    "    print(f\"Test MSE Loss: {test_loss:.4f}\")\n",
    "\n",
    "    # Example usage of mathematical models\n",
    "    # Bruun model: y(x) = S - (S / L) * (x - (h * L / S) + B)\n",
    "    x = np.linspace(0, 100, 101)\n",
    "    y_bruun = bruun_model(x, S=1.0, L=100, h=10, B=2)\n",
    "    y_dean = dean_model(x, A=0.1)\n",
    "    print(\"Bruun model example output:\", y_bruun[:5])\n",
    "    print(\"Dean model example output:\", y_dean[:5])\n",
    "\n",
    "# Note: The script does NOT execute anything on import. Call main() to run the workflow.\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "3c7218ee",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/50, Loss: 2.0188\n",
      "Epoch 11/50, Loss: 0.1938\n",
      "Epoch 21/50, Loss: 0.0484\n",
      "Epoch 31/50, Loss: 0.0227\n",
      "Epoch 41/50, Loss: 0.0135\n",
      "Epoch 50/50, Loss: 0.0130\n",
      "Test MSE Loss: 0.6765\n",
      "Bruun model example output: [10.98 10.97 10.96 10.95 10.94]\n",
      "Dean model example output: [0.         0.1        0.15874011 0.20800838 0.25198421]\n"
     ]
    }
   ],
   "source": [
    "main()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "fc1af093",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "from torch.utils.data import Dataset, DataLoader\n",
    "from sklearn.preprocessing import StandardScaler, LabelEncoder\n",
    "from sklearn.model_selection import train_test_split\n",
    "\n",
    "# --- Bruun Model ---\n",
    "def bruun_model(x, A, B):\n",
    "    \"\"\"\n",
    "    Bruun Rule: y = A - B * x\n",
    "    x: distance from starting point\n",
    "    A, B: empirical parameters\n",
    "    \"\"\"\n",
    "    return A - B * x\n",
    "\n",
    "# --- Dean Model ---\n",
    "def dean_model(x, h, A):\n",
    "    \"\"\"\n",
    "    Dean Profile: y = h - A * x^{2/3}\n",
    "    x: distance from starting point\n",
    "    h, A: empirical parameters\n",
    "    \"\"\"\n",
    "    return h - A * np.power(x, 2/3)\n",
    "\n",
    "# --- Custom Dataset ---\n",
    "class BeachProfileDataset(Dataset):\n",
    "    def __init__(self, df, feature_cols, target_col, scaler=None, label_encoders=None, fit_scaler=False):\n",
    "        self.X = df[feature_cols].copy()\n",
    "        self.y = df[target_col].values.astype(np.float32)\n",
    "        self.scaler = scaler\n",
    "        self.label_encoders = label_encoders or {}\n",
    "        # Encode categorical columns\n",
    "        for col in self.X.select_dtypes(include=['object', 'category']).columns:\n",
    "            if col not in self.label_encoders:\n",
    "                self.label_encoders[col] = LabelEncoder()\n",
    "                self.X[col] = self.label_encoders[col].fit_transform(self.X[col])\n",
    "            else:\n",
    "                self.X[col] = self.label_encoders[col].transform(self.X[col])\n",
    "        # Standardize numerical columns\n",
    "        num_cols = self.X.select_dtypes(include=[np.number]).columns\n",
    "        if fit_scaler:\n",
    "            self.scaler = StandardScaler()\n",
    "            self.X[num_cols] = self.scaler.fit_transform(self.X[num_cols])\n",
    "        else:\n",
    "            self.X[num_cols] = self.scaler.transform(self.X[num_cols])\n",
    "        self.X = self.X.values.astype(np.float32)\n",
    "    def __len__(self):\n",
    "        return len(self.y)\n",
    "    def __getitem__(self, idx):\n",
    "        return self.X[idx], self.y[idx]\n",
    "\n",
    "# --- Neural Network Model ---\n",
    "class BeachProfileNet(nn.Module):\n",
    "    def __init__(self, input_dim):\n",
    "        super().__init__()\n",
    "        self.net = nn.Sequential(\n",
    "            nn.Linear(input_dim, 64),\n",
    "            nn.ReLU(),\n",
    "            nn.Linear(64, 32),\n",
    "            nn.ReLU(),\n",
    "            nn.Linear(32, 1)\n",
    "        )\n",
    "    def forward(self, x):\n",
    "        return self.net(x).squeeze(-1)\n",
    "\n",
    "# --- Data Loading and Preprocessing ---\n",
    "def load_data(train_path, test_path):\n",
    "    train_df = pd.read_excel(train_path)\n",
    "    test_df = pd.read_excel(test_path)\n",
    "    # Select features\n",
    "    feature_cols = [col for col in train_df.columns if col not in ['y']]\n",
    "    target_col = 'y'\n",
    "    # Handle categorical encoding and scaling\n",
    "    scaler = StandardScaler()\n",
    "    label_encoders = {}\n",
    "    train_dataset = BeachProfileDataset(train_df, feature_cols, target_col, scaler=None, label_encoders=label_encoders, fit_scaler=True)\n",
    "    test_dataset = BeachProfileDataset(test_df, feature_cols, target_col, scaler=train_dataset.scaler, label_encoders=train_dataset.label_encoders, fit_scaler=False)\n",
    "    return train_dataset, test_dataset, feature_cols, label_encoders\n",
    "\n",
    "# --- Training Function ---\n",
    "def train_model(model, train_loader, num_epochs=50, lr=0.001):\n",
    "    criterion = nn.MSELoss()\n",
    "    optimizer = optim.Adam(model.parameters(), lr=lr)\n",
    "    for epoch in range(num_epochs):\n",
    "        model.train()\n",
    "        running_loss = 0.0\n",
    "        for X_batch, y_batch in train_loader:\n",
    "            optimizer.zero_grad()\n",
    "            outputs = model(X_batch)\n",
    "            loss = criterion(outputs, y_batch)\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "            running_loss += loss.item() * X_batch.size(0)\n",
    "        epoch_loss = running_loss / len(train_loader.dataset)\n",
    "        # Optionally print or log epoch_loss\n",
    "    return model\n",
    "\n",
    "# --- Evaluation Function ---\n",
    "def evaluate_model(model, test_loader):\n",
    "    model.eval()\n",
    "    predictions = []\n",
    "    targets = []\n",
    "    with torch.no_grad():\n",
    "        for X_batch, y_batch in test_loader:\n",
    "            outputs = model(X_batch)\n",
    "            predictions.append(outputs.numpy())\n",
    "            targets.append(y_batch.numpy())\n",
    "    predictions = np.concatenate(predictions)\n",
    "    targets = np.concatenate(targets)\n",
    "    mse = np.mean((predictions - targets) ** 2)\n",
    "    return mse, predictions, targets\n",
    "\n",
    "# --- Main Function ---\n",
    "def main():\n",
    "    train_path = \"beach_profile_data/processed_data/beachdata_train.xlsx\"\n",
    "    test_path = \"beach_profile_data/processed_data/beachdata_test.xlsx\"\n",
    "    train_dataset, test_dataset, feature_cols, label_encoders = load_data(train_path, test_path)\n",
    "    train_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)\n",
    "    test_loader = DataLoader(test_dataset, batch_size=32, shuffle=False)\n",
    "    model = BeachProfileNet(input_dim=len(feature_cols))\n",
    "    model = train_model(model, train_loader, num_epochs=100, lr=0.001)\n",
    "    mse, predictions, targets = evaluate_model(model, test_loader)\n",
    "    print(f\"Test MSE: {mse:.4f}\")\n",
    "\n",
    "    # scaler = train_dataset.scaler\n",
    "    # Example usage of Bruun and Dean models\n",
    "    # x = np.linspace(0, 100, 100)\n",
    "    # y_bruun = bruun_model(x, A=5, B=0.01)\n",
    "    # y_dean = dean_model(x, h=5, A=0.05)\n",
    "    return model, feature_cols, label_encoders\n",
    "\n",
    "# --- Predict on New Data Function ---\n",
    "def predict_on_new_data(model, data_path, feature_cols, label_encoders, target_col='y'):\n",
    "    \"\"\"\n",
    "    Use the trained model to predict y for a new data file.\n",
    "    Returns:\n",
    "        x_list: list of x values (distance)\n",
    "        true_y_list: list of true y values (elevation)\n",
    "        predict_y_list: list of predicted y values\n",
    "    \"\"\"\n",
    "    df = pd.read_excel(data_path)\n",
    "    dataset = BeachProfileDataset(df, feature_cols, target_col, scaler=None, label_encoders=label_encoders, fit_scaler=True)\n",
    "    loader = DataLoader(dataset, batch_size=32, shuffle=False)\n",
    "    model.eval()\n",
    "    preds = []\n",
    "    with torch.no_grad():\n",
    "        for X_batch, _ in loader:\n",
    "            outputs = model(X_batch)\n",
    "            preds.append(outputs.numpy())\n",
    "    predict_y_list = np.concatenate(preds)\n",
    "    x_list = df['x'].tolist() if 'x' in df.columns else []\n",
    "    true_y_list = df[target_col].tolist() if target_col in df.columns else []\n",
    "    return x_list, true_y_list, predict_y_list.tolist()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c8a8ab3d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Test MSE: 1.3644\n"
     ]
    }
   ],
   "source": [
    "model, feature_cols, label_encoders = main()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "c2de6655",
   "metadata": {},
   "outputs": [],
   "source": [
    "x, y_ture, y_predict_windsurf = predict_on_new_data(model, \"beach_profile_data/processed_data/beachdata_single.xlsx\", feature_cols, label_encoders)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "cc5252db",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[3.1889779567718506, 3.0834944248199463, 2.940502405166626, 2.79541277885437, 2.618284225463867, 2.432966709136963, 2.3636436462402344, 2.128037214279175, 1.9000465869903564, 1.6492371559143066, 1.3736672401428223, 1.075880527496338, 0.7956051826477051, 0.42224252223968506, 0.12308330833911896, -0.33442050218582153, -0.8215712308883667, -1.581803798675537, -2.2708511352539062, -3.517547845840454, -4.310803413391113]\n"
     ]
    }
   ],
   "source": [
    "print(y_predict_windsurf)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "3f212bfd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# x_plot, y_true_plot, y_base, y_new = base_plot_output\n",
    "x_plot = [\n",
    "    0.0, 1.55, 3.65, 5.78, 8.38, 11.1, 12.12, 15.55, 18.94, 22.8,\n",
    "    27.02, 31.77, 36.65, 44.05, 51.52, 60.24, 70.7, 87.22, 103.04, 133.36,\n",
    "    152.91\n",
    "]\n",
    "\n",
    "y_true_plot = [\n",
    "    2.542, 2.373, 2.172, 1.984, 1.815, 1.665, 1.602, 1.398, 1.229, 1.06,\n",
    "    0.897, 0.752, 0.593, 0.363, 0.14, -0.12, -0.351, -0.56, -0.643, -0.996,\n",
    "    -1.091\n",
    "]\n",
    "\n",
    "y_base = [\n",
    "    2.6769042, 2.3924885, 2.261987, 2.0599403, 1.8234198, 1.5171967,\n",
    "    1.4008808, 1.0747753, 0.8327296, 0.56248415, 0.26728857, -0.06498109,\n",
    "    -0.37953135, -0.734211, -0.93088466, -1.1578621, -1.4238784, -1.8433229,\n",
    "    -2.244999, -3.014831, -3.5112088\n",
    "]\n",
    "\n",
    "y_new = [\n",
    "    2.58881326, 2.34806979, 2.15122727, 2.05923818, 1.80919691, 1.49883877,\n",
    "    1.48476992, 1.23896293, 0.95764242, 0.79837616, 0.59810174, 0.37667743,\n",
    "    0.03520706, -0.19719144, -0.38670532, -0.70037132, -0.85904528, -1.20291644,\n",
    "    -1.46837316, -1.99559494, -2.33455231\n",
    "]\n",
    "\n",
    "y_cursor = [0.8379809856414795, 0.78484046459198, 0.7128432989120483, 0.6398176550865173, 0.550678014755249, 0.4574241638183594, 0.423924058675766, 0.3131944537162781, 0.2031436562538147, 0.06935437768697739, -0.0769127607345581, -0.24154895544052124, -0.4045321047306061, -0.633338451385498, -0.8579303026199341, -1.120104193687439, -1.4370406866073608, -1.9201208353042603, -2.3576247692108154, -3.22664475440979, -3.73905086517334]\n",
    "\n",
    "y_windsurf = [2.4715735912323, 2.36767578125, 2.227688789367676, 2.086095094680786, 1.9133492708206177, 1.7348555326461792, 1.6676647663116455, 1.4444841146469116, 1.228782057762146, 0.9605395197868347, 0.660384476184845, 0.3696815073490143, 0.11881380528211594, -0.1538306027650833, -0.40887412428855896, -0.6236438751220703, -0.789034366607666, -1.0666532516479492, -1.326110601425171, -1.806679129600525, -2.1190149784088135]\n",
    "\n",
    "plt.figure(figsize=(10, 6))\n",
    "plt.plot(x_plot,    y_true_plot,        label='Ground Truth',   marker='o', linestyle='-',  color='blue')\n",
    "plt.plot(x_plot,    y_base,        label='Baseline',      marker='x', linestyle='--', color='red')\n",
    "plt.plot(x_plot,    y_new,   label='Our framework',   marker='.', linestyle=':',  color='green')\n",
    "plt.plot(x_plot,    y_windsurf,   label='Windsurf',   marker='.', linestyle=':',  color='yellow')\n",
    "plt.plot(x_plot,    y_cursor,   label='cursor',   marker='.', linestyle=':',  color='purple')\n",
    "\n",
    "plt.xlabel(\"X (Distance along profile)\", fontsize=24)\n",
    "plt.ylabel(\"Y (Elevation/Profile Value)\", fontsize=24)\n",
    "# plt.title(\"Beach Profile: Ground Truth vs. Baseline vs. Our framework\", fontsize=24, pad=25)\n",
    "plt.legend(fontsize=20)\n",
    "plt.grid(True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "40d8dc4d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "from sklearn.preprocessing import StandardScaler, LabelEncoder\n",
    "from sklearn.model_selection import train_test_split\n",
    "from torch.utils.data import Dataset, DataLoader\n",
    "\n",
    "# --- Bruun and Dean Model References (for documentation and possible feature engineering) ---\n",
    "# Bruun Model: Δy = (S / (L + x)) * ΔS, where S is the active profile height, L is the width, x is distance, ΔS is sea level rise\n",
    "# Dean Model: y = A * x^(2/3), where A is a profile scale parameter\n",
    "# These are not used directly in the deep learning model, but can inspire feature engineering.\n",
    "\n",
    "def load_and_process_data(filepath, scaler=None, label_encoder=None, fit_scaler=False, fit_label_encoder=False):\n",
    "    df = pd.read_excel(filepath)\n",
    "    # Select features\n",
    "    feature_cols = [col for col in df.columns if col not in ['y']]\n",
    "    X = df[feature_cols].copy()\n",
    "    y = df['y'].values.astype(np.float32)\n",
    "\n",
    "    # Encode Dominant Wave Direction\n",
    "    if 'Dominant Wave Direction' in X.columns:\n",
    "        if label_encoder is None:\n",
    "            label_encoder = LabelEncoder()\n",
    "        if fit_label_encoder:\n",
    "            X['Dominant Wave Direction'] = label_encoder.fit_transform(X['Dominant Wave Direction'])\n",
    "        else:\n",
    "            X['Dominant Wave Direction'] = label_encoder.transform(X['Dominant Wave Direction'])\n",
    "    else:\n",
    "        label_encoder = None\n",
    "\n",
    "    # Standardize numerical features\n",
    "    num_cols = X.select_dtypes(include=[np.number]).columns.tolist()\n",
    "    if scaler is None:\n",
    "        scaler = StandardScaler()\n",
    "    if fit_scaler:\n",
    "        X[num_cols] = scaler.fit_transform(X[num_cols])\n",
    "    else:\n",
    "        X[num_cols] = scaler.transform(X[num_cols])\n",
    "\n",
    "    return X.values.astype(np.float32), y, scaler, label_encoder, df['x'].values.tolist(), df['y'].values.tolist()\n",
    "\n",
    "class BeachProfileDataset(Dataset):\n",
    "    def __init__(self, X, y):\n",
    "        self.X = torch.tensor(X, dtype=torch.float32)\n",
    "        self.y = torch.tensor(y, dtype=torch.float32)\n",
    "    def __len__(self):\n",
    "        return len(self.X)\n",
    "    def __getitem__(self, idx):\n",
    "        return self.X[idx], self.y[idx]\n",
    "\n",
    "class BeachProfileNet(nn.Module):\n",
    "    def __init__(self, input_dim):\n",
    "        super().__init__()\n",
    "        self.net = nn.Sequential(\n",
    "            nn.Linear(input_dim, 64),\n",
    "            nn.ReLU(),\n",
    "            nn.Linear(64, 32),\n",
    "            nn.ReLU(),\n",
    "            nn.Linear(32, 1)\n",
    "        )\n",
    "    def forward(self, x):\n",
    "        return self.net(x).squeeze(-1)\n",
    "\n",
    "def train_model(model, train_loader, val_loader, epochs=100, lr=1e-3, device='cpu'):\n",
    "    criterion = nn.MSELoss()\n",
    "    optimizer = optim.Adam(model.parameters(), lr=lr)\n",
    "    model.to(device)\n",
    "    for epoch in range(epochs):\n",
    "        model.train()\n",
    "        for X_batch, y_batch in train_loader:\n",
    "            X_batch, y_batch = X_batch.to(device), y_batch.to(device)\n",
    "            optimizer.zero_grad()\n",
    "            output = model(X_batch)\n",
    "            loss = criterion(output, y_batch)\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "        # Optionally add validation loss printout\n",
    "    return model\n",
    "\n",
    "def evaluate_model(model, loader, device='cpu'):\n",
    "    model.eval()\n",
    "    preds = []\n",
    "    trues = []\n",
    "    with torch.no_grad():\n",
    "        for X_batch, y_batch in loader:\n",
    "            X_batch = X_batch.to(device)\n",
    "            output = model(X_batch)\n",
    "            preds.extend(output.cpu().numpy())\n",
    "            trues.extend(y_batch.numpy())\n",
    "    return preds, trues\n",
    "\n",
    "def main():\n",
    "    train_path = \"beach_profile_data/processed_data/beachdata_train.xlsx\"\n",
    "    test_path = \"beach_profile_data/processed_data/beachdata_test.xlsx\"\n",
    "    # Load and process training data\n",
    "    X_train, y_train, scaler, label_encoder, _, _ = load_and_process_data(\n",
    "        train_path, scaler=None, label_encoder=None, fit_scaler=True, fit_label_encoder=True)\n",
    "    # Load and process test data\n",
    "    X_test, y_test, _, _, _, _ = load_and_process_data(\n",
    "        test_path, scaler=scaler, label_encoder=label_encoder, fit_scaler=False, fit_label_encoder=False)\n",
    "    # Datasets and loaders\n",
    "    train_dataset = BeachProfileDataset(X_train, y_train)\n",
    "    test_dataset = BeachProfileDataset(X_test, y_test)\n",
    "    train_loader = DataLoader(train_dataset, batch_size=32, shuffle=True)\n",
    "    test_loader = DataLoader(test_dataset, batch_size=32, shuffle=False)\n",
    "    # Model\n",
    "    input_dim = X_train.shape[1]\n",
    "    model = BeachProfileNet(input_dim)\n",
    "    device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "    model = train_model(model, train_loader, test_loader, epochs=100, lr=1e-3, device=device)\n",
    "    # Evaluate\n",
    "    preds, trues = evaluate_model(model, test_loader, device=device)\n",
    "    return model, scaler, label_encoder\n",
    "\n",
    "def predict_on_new_data(model, scaler, label_encoder, new_data_path):\n",
    "    X_new, y_new, _, _, x_list, true_y_list = load_and_process_data(\n",
    "        new_data_path, scaler=scaler, label_encoder=label_encoder, fit_scaler=False, fit_label_encoder=False)\n",
    "    model.eval()\n",
    "    device = next(model.parameters()).device\n",
    "    X_tensor = torch.tensor(X_new, dtype=torch.float32).to(device)\n",
    "    with torch.no_grad():\n",
    "        y_pred = model(X_tensor).cpu().numpy().tolist()\n",
    "    return x_list, true_y_list, y_pred "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "ea979364",
   "metadata": {},
   "outputs": [],
   "source": [
    "model, scaler, label_enc = main()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "c495f977",
   "metadata": {},
   "outputs": [],
   "source": [
    "x_list, true_y_list, y_pred_cursor =  predict_on_new_data(model, scaler, label_enc, \"beach_profile_data/processed_data/beachdata_single.xlsx\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "c44baf24",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.8379809856414795, 0.78484046459198, 0.7128432989120483, 0.6398176550865173, 0.550678014755249, 0.4574241638183594, 0.423924058675766, 0.3131944537162781, 0.2031436562538147, 0.06935437768697739, -0.0769127607345581, -0.24154895544052124, -0.4045321047306061, -0.633338451385498, -0.8579303026199341, -1.120104193687439, -1.4370406866073608, -1.9201208353042603, -2.3576247692108154, -3.22664475440979, -3.73905086517334]\n"
     ]
    }
   ],
   "source": [
    "print(y_pred_cursor)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "79c75001",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "llm",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.19"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
