{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "27d75c6c",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import networkx as nx\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "import matplotlib.pyplot as plt\n",
    "import torch_geometric\n",
    "from torch_geometric.utils import to_networkx\n",
    "from sklearn.model_selection import KFold\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "9ba63055",
   "metadata": {},
   "outputs": [],
   "source": [
    "cyclone_data = pd.read_csv('IO_out.csv')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "3bdeaa67",
   "metadata": {},
   "outputs": [],
   "source": [
    "G = nx.Graph()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "cde420d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(len(cyclone_data)):\n",
    "    G.add_node(i, vmax=cyclone_data['VMAX'][i])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "7d493e54",
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(0, len(cyclone_data)-1, 6):\n",
    "    for j in range(i+6, len(cyclone_data), 6):\n",
    "        G.add_edge(i, j, time=j-i)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "124f5f1e",
   "metadata": {},
   "outputs": [],
   "source": [
    "edge_index = torch.tensor(list(G.edges)).t().contiguous()\n",
    "x = torch.tensor(cyclone_data['VMAX'].values).view(-1, 1).float()\n",
    "data = torch_geometric.data.Data(x=x, edge_index=edge_index)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "fde6889f",
   "metadata": {},
   "outputs": [],
   "source": [
    "class CycloneGNN(nn.Module):\n",
    "    def __init__(self):\n",
    "        super(CycloneGNN, self).__init__()\n",
    "        self.conv1 = torch_geometric.nn.GCNConv(1, 128)\n",
    "        self.conv2 = torch_geometric.nn.GCNConv(128, 64)\n",
    "        self.conv3 = torch_geometric.nn.GCNConv(64, 1)\n",
    "\n",
    "    def forward(self, x, edge_index):\n",
    "        x = self.conv1(x, edge_index)\n",
    "        x = nn.functional.relu(x)\n",
    "        x = nn.functional.dropout(x, training=self.training)\n",
    "        x = self.conv2(x, edge_index)\n",
    "        x = nn.functional.relu(x)\n",
    "        x = nn.functional.dropout(x, training=self.training)\n",
    "        x = self.conv3(x, edge_index)\n",
    "        \n",
    "        return x\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "72b38afd",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 0 => Loss: 2486.4204, MAE: 44.1636, RMSE: 49.8640, R-squared: -3.9561\n",
      "Epoch: 1 => Loss: 1321.9204, MAE: 29.5304, RMSE: 36.3582, R-squared: -1.6349\n",
      "Epoch: 2 => Loss: 1924.2563, MAE: 28.6800, RMSE: 43.8663, R-squared: -2.8356\n",
      "Epoch: 3 => Loss: 1163.4675, MAE: 25.5575, RMSE: 34.1096, R-squared: -1.3191\n",
      "Epoch: 4 => Loss: 934.1332, MAE: 25.5694, RMSE: 30.5636, R-squared: -0.8620\n",
      "Epoch: 5 => Loss: 996.2410, MAE: 27.1564, RMSE: 31.5633, R-squared: -0.9858\n",
      "Epoch: 6 => Loss: 1057.1664, MAE: 27.9517, RMSE: 32.5141, R-squared: -1.1072\n",
      "Epoch: 7 => Loss: 1086.2986, MAE: 28.0429, RMSE: 32.9590, R-squared: -1.1653\n",
      "Epoch: 8 => Loss: 1095.3817, MAE: 28.2233, RMSE: 33.0965, R-squared: -1.1834\n",
      "Epoch: 9 => Loss: 1063.1732, MAE: 27.9126, RMSE: 32.6063, R-squared: -1.1192\n",
      "Epoch: 10 => Loss: 997.8353, MAE: 27.3347, RMSE: 31.5885, R-squared: -0.9890\n",
      "Epoch: 11 => Loss: 974.5229, MAE: 26.9457, RMSE: 31.2174, R-squared: -0.9425\n",
      "Epoch: 12 => Loss: 902.8936, MAE: 25.6245, RMSE: 30.0482, R-squared: -0.7997\n",
      "Epoch: 13 => Loss: 871.5915, MAE: 24.8061, RMSE: 29.5227, R-squared: -0.7373\n",
      "Epoch: 14 => Loss: 1072.1962, MAE: 26.0805, RMSE: 32.7444, R-squared: -1.1372\n",
      "Epoch: 15 => Loss: 933.3206, MAE: 24.6247, RMSE: 30.5503, R-squared: -0.8604\n",
      "Epoch: 16 => Loss: 1066.1322, MAE: 26.0124, RMSE: 32.6517, R-squared: -1.1251\n",
      "Epoch: 17 => Loss: 967.0540, MAE: 25.5856, RMSE: 31.0975, R-squared: -0.9276\n",
      "Epoch: 18 => Loss: 871.6224, MAE: 25.1778, RMSE: 29.5233, R-squared: -0.7374\n",
      "Epoch: 19 => Loss: 822.9921, MAE: 24.4610, RMSE: 28.6878, R-squared: -0.6404\n",
      "Epoch: 20 => Loss: 896.8821, MAE: 25.6412, RMSE: 29.9480, R-squared: -0.7877\n",
      "Epoch: 21 => Loss: 908.9605, MAE: 25.9269, RMSE: 30.1490, R-squared: -0.8118\n",
      "Epoch: 22 => Loss: 956.9006, MAE: 26.7230, RMSE: 30.9338, R-squared: -0.9074\n",
      "Epoch: 23 => Loss: 943.6757, MAE: 26.6319, RMSE: 30.7193, R-squared: -0.8810\n",
      "Epoch: 24 => Loss: 871.5707, MAE: 25.1782, RMSE: 29.5224, R-squared: -0.7373\n",
      "Epoch: 25 => Loss: 910.8793, MAE: 25.7649, RMSE: 30.1808, R-squared: -0.8156\n",
      "Epoch: 26 => Loss: 846.6086, MAE: 24.7317, RMSE: 29.0965, R-squared: -0.6875\n",
      "Epoch: 27 => Loss: 888.3345, MAE: 25.3962, RMSE: 29.8049, R-squared: -0.7707\n",
      "Epoch: 28 => Loss: 809.3254, MAE: 24.0088, RMSE: 28.4486, R-squared: -0.6132\n",
      "Epoch: 29 => Loss: 896.7795, MAE: 25.4506, RMSE: 29.9463, R-squared: -0.7875\n",
      "Epoch: 30 => Loss: 782.4797, MAE: 23.4288, RMSE: 27.9728, R-squared: -0.5597\n",
      "Epoch: 31 => Loss: 772.1844, MAE: 23.4901, RMSE: 27.7882, R-squared: -0.5392\n",
      "Epoch: 32 => Loss: 858.5990, MAE: 24.5699, RMSE: 29.3019, R-squared: -0.7114\n",
      "Epoch: 33 => Loss: 876.2922, MAE: 24.5554, RMSE: 29.6022, R-squared: -0.7467\n",
      "Epoch: 34 => Loss: 719.3997, MAE: 22.6726, RMSE: 26.8216, R-squared: -0.4340\n",
      "Epoch: 35 => Loss: 718.1976, MAE: 22.3769, RMSE: 26.7992, R-squared: -0.4316\n",
      "Epoch: 36 => Loss: 685.4046, MAE: 21.8915, RMSE: 26.1802, R-squared: -0.3662\n",
      "Epoch: 37 => Loss: 830.9570, MAE: 23.4418, RMSE: 28.8263, R-squared: -0.6563\n",
      "Epoch: 38 => Loss: 633.7419, MAE: 20.5331, RMSE: 25.1742, R-squared: -0.2632\n",
      "Epoch: 39 => Loss: 642.4033, MAE: 20.6614, RMSE: 25.3457, R-squared: -0.2805\n",
      "Epoch: 40 => Loss: 705.9702, MAE: 21.2555, RMSE: 26.5701, R-squared: -0.4072\n",
      "Epoch: 41 => Loss: 663.0589, MAE: 20.6869, RMSE: 25.7499, R-squared: -0.3217\n",
      "Epoch: 42 => Loss: 606.5063, MAE: 20.1497, RMSE: 24.6273, R-squared: -0.2089\n",
      "Epoch: 43 => Loss: 591.1382, MAE: 19.5910, RMSE: 24.3133, R-squared: -0.1783\n",
      "Epoch: 44 => Loss: 585.3314, MAE: 19.3654, RMSE: 24.1936, R-squared: -0.1667\n",
      "Epoch: 45 => Loss: 741.7071, MAE: 21.1160, RMSE: 27.2343, R-squared: -0.4784\n",
      "Epoch: 46 => Loss: 501.2308, MAE: 17.7986, RMSE: 22.3882, R-squared: 0.0009\n",
      "Epoch: 47 => Loss: 570.2786, MAE: 18.8891, RMSE: 23.8805, R-squared: -0.1367\n",
      "Epoch: 48 => Loss: 521.3575, MAE: 17.9266, RMSE: 22.8333, R-squared: -0.0392\n",
      "Epoch: 49 => Loss: 558.2726, MAE: 18.5508, RMSE: 23.6278, R-squared: -0.1128\n",
      "Epoch: 50 => Loss: 514.2013, MAE: 17.7564, RMSE: 22.6760, R-squared: -0.0249\n",
      "Epoch: 51 => Loss: 540.9030, MAE: 18.2102, RMSE: 23.2573, R-squared: -0.0782\n",
      "Epoch: 52 => Loss: 563.4307, MAE: 18.5122, RMSE: 23.7367, R-squared: -0.1231\n",
      "Epoch: 53 => Loss: 467.0750, MAE: 16.3524, RMSE: 21.6119, R-squared: 0.0690\n",
      "Epoch: 54 => Loss: 484.8396, MAE: 16.8841, RMSE: 22.0191, R-squared: 0.0336\n",
      "Epoch: 55 => Loss: 404.0513, MAE: 15.2183, RMSE: 20.1010, R-squared: 0.1946\n",
      "Epoch: 56 => Loss: 500.9581, MAE: 17.1746, RMSE: 22.3821, R-squared: 0.0015\n",
      "Epoch: 57 => Loss: 436.7163, MAE: 15.6655, RMSE: 20.8978, R-squared: 0.1295\n",
      "Epoch: 58 => Loss: 366.4514, MAE: 14.4660, RMSE: 19.1429, R-squared: 0.2696\n",
      "Epoch: 59 => Loss: 456.8436, MAE: 16.0528, RMSE: 21.3739, R-squared: 0.0894\n",
      "Epoch: 60 => Loss: 392.8372, MAE: 14.8013, RMSE: 19.8201, R-squared: 0.2170\n",
      "Epoch: 61 => Loss: 359.1813, MAE: 14.1905, RMSE: 18.9521, R-squared: 0.2841\n",
      "Epoch: 62 => Loss: 395.2005, MAE: 14.6914, RMSE: 19.8797, R-squared: 0.2123\n",
      "Epoch: 63 => Loss: 469.0300, MAE: 16.1123, RMSE: 21.6571, R-squared: 0.0651\n",
      "Epoch: 64 => Loss: 504.6674, MAE: 16.8497, RMSE: 22.4648, R-squared: -0.0059\n",
      "Epoch: 65 => Loss: 443.7773, MAE: 15.1038, RMSE: 21.0660, R-squared: 0.1154\n",
      "Epoch: 66 => Loss: 464.1546, MAE: 15.7686, RMSE: 21.5442, R-squared: 0.0748\n",
      "Epoch: 67 => Loss: 420.9483, MAE: 14.7375, RMSE: 20.5170, R-squared: 0.1609\n",
      "Epoch: 68 => Loss: 383.1412, MAE: 14.3893, RMSE: 19.5740, R-squared: 0.2363\n",
      "Epoch: 69 => Loss: 527.1915, MAE: 17.2783, RMSE: 22.9607, R-squared: -0.0508\n",
      "Epoch: 70 => Loss: 441.0198, MAE: 15.7671, RMSE: 21.0005, R-squared: 0.1209\n",
      "Epoch: 71 => Loss: 380.7554, MAE: 14.2772, RMSE: 19.5130, R-squared: 0.2411\n",
      "Epoch: 72 => Loss: 419.4251, MAE: 14.7898, RMSE: 20.4799, R-squared: 0.1640\n",
      "Epoch: 73 => Loss: 408.0406, MAE: 14.9656, RMSE: 20.2000, R-squared: 0.1867\n",
      "Epoch: 74 => Loss: 421.2975, MAE: 14.8592, RMSE: 20.5255, R-squared: 0.1602\n",
      "Epoch: 75 => Loss: 361.4983, MAE: 13.8242, RMSE: 19.0131, R-squared: 0.2794\n",
      "Epoch: 76 => Loss: 407.0323, MAE: 14.8430, RMSE: 20.1750, R-squared: 0.1887\n",
      "Epoch: 77 => Loss: 438.1950, MAE: 15.7072, RMSE: 20.9331, R-squared: 0.1266\n",
      "Epoch: 78 => Loss: 492.1543, MAE: 16.3540, RMSE: 22.1846, R-squared: 0.0190\n",
      "Epoch: 79 => Loss: 367.9950, MAE: 14.0255, RMSE: 19.1832, R-squared: 0.2665\n",
      "Epoch: 80 => Loss: 411.8947, MAE: 14.4028, RMSE: 20.2952, R-squared: 0.1790\n",
      "Epoch: 81 => Loss: 387.9301, MAE: 14.3197, RMSE: 19.6959, R-squared: 0.2268\n",
      "Epoch: 82 => Loss: 337.6694, MAE: 13.5010, RMSE: 18.3758, R-squared: 0.3269\n",
      "Epoch: 83 => Loss: 416.1940, MAE: 15.1498, RMSE: 20.4008, R-squared: 0.1704\n",
      "Epoch: 84 => Loss: 381.4476, MAE: 14.7831, RMSE: 19.5307, R-squared: 0.2397\n",
      "Epoch: 85 => Loss: 425.4131, MAE: 15.5400, RMSE: 20.6255, R-squared: 0.1520\n",
      "Epoch: 86 => Loss: 376.4301, MAE: 14.2054, RMSE: 19.4018, R-squared: 0.2497\n",
      "Epoch: 87 => Loss: 375.6491, MAE: 13.9468, RMSE: 19.3817, R-squared: 0.2512\n",
      "Epoch: 88 => Loss: 369.9294, MAE: 14.2901, RMSE: 19.2335, R-squared: 0.2626\n",
      "Epoch: 89 => Loss: 344.7246, MAE: 13.4596, RMSE: 18.5668, R-squared: 0.3129\n",
      "Epoch: 90 => Loss: 412.3938, MAE: 15.3632, RMSE: 20.3075, R-squared: 0.1780\n",
      "Epoch: 91 => Loss: 351.2517, MAE: 13.5609, RMSE: 18.7417, R-squared: 0.2999\n",
      "Epoch: 92 => Loss: 344.3101, MAE: 13.0593, RMSE: 18.5556, R-squared: 0.3137\n",
      "Epoch: 93 => Loss: 328.9573, MAE: 13.4270, RMSE: 18.1372, R-squared: 0.3443\n",
      "Epoch: 94 => Loss: 397.7867, MAE: 14.5983, RMSE: 19.9446, R-squared: 0.2071\n",
      "Epoch: 95 => Loss: 353.4824, MAE: 13.7837, RMSE: 18.8011, R-squared: 0.2954\n",
      "Epoch: 96 => Loss: 365.6615, MAE: 14.2581, RMSE: 19.1223, R-squared: 0.2711\n",
      "Epoch: 97 => Loss: 406.6039, MAE: 15.0250, RMSE: 20.1644, R-squared: 0.1895\n",
      "Epoch: 98 => Loss: 342.9891, MAE: 13.4496, RMSE: 18.5200, R-squared: 0.3163\n",
      "Epoch: 99 => Loss: 343.5653, MAE: 13.6219, RMSE: 18.5355, R-squared: 0.3152\n",
      "Epoch: 100 => Loss: 380.9665, MAE: 14.2181, RMSE: 19.5184, R-squared: 0.2406\n",
      "Epoch: 101 => Loss: 332.8988, MAE: 13.1534, RMSE: 18.2455, R-squared: 0.3364\n",
      "Epoch: 102 => Loss: 328.9947, MAE: 13.4871, RMSE: 18.1382, R-squared: 0.3442\n",
      "Epoch: 103 => Loss: 338.1262, MAE: 13.5009, RMSE: 18.3882, R-squared: 0.3260\n",
      "Epoch: 104 => Loss: 314.6101, MAE: 13.0559, RMSE: 17.7373, R-squared: 0.3729\n",
      "Epoch: 105 => Loss: 311.8320, MAE: 12.6379, RMSE: 17.6588, R-squared: 0.3784\n",
      "Epoch: 106 => Loss: 299.0644, MAE: 12.3484, RMSE: 17.2935, R-squared: 0.4039\n",
      "Epoch: 107 => Loss: 424.0564, MAE: 14.9404, RMSE: 20.5926, R-squared: 0.1547\n",
      "Epoch: 108 => Loss: 316.6068, MAE: 12.8424, RMSE: 17.7934, R-squared: 0.3689\n",
      "Epoch: 109 => Loss: 311.3714, MAE: 12.5736, RMSE: 17.6457, R-squared: 0.3794\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch: 110 => Loss: 331.3672, MAE: 13.4405, RMSE: 18.2035, R-squared: 0.3395\n",
      "Epoch: 111 => Loss: 329.0337, MAE: 13.1394, RMSE: 18.1393, R-squared: 0.3441\n",
      "Epoch: 112 => Loss: 300.6731, MAE: 12.3261, RMSE: 17.3399, R-squared: 0.4007\n",
      "Epoch: 113 => Loss: 354.9318, MAE: 13.8054, RMSE: 18.8396, R-squared: 0.2925\n",
      "Epoch: 114 => Loss: 325.2095, MAE: 13.3450, RMSE: 18.0336, R-squared: 0.3518\n",
      "Epoch: 115 => Loss: 335.2104, MAE: 13.4860, RMSE: 18.3088, R-squared: 0.3318\n",
      "Epoch: 116 => Loss: 312.5824, MAE: 12.9695, RMSE: 17.6800, R-squared: 0.3769\n",
      "Epoch: 117 => Loss: 338.1988, MAE: 13.4207, RMSE: 18.3902, R-squared: 0.3259\n",
      "Epoch: 118 => Loss: 311.5905, MAE: 12.2350, RMSE: 17.6519, R-squared: 0.3789\n",
      "Epoch: 119 => Loss: 334.2187, MAE: 13.5667, RMSE: 18.2817, R-squared: 0.3338\n",
      "Epoch: 120 => Loss: 326.3012, MAE: 12.6156, RMSE: 18.0638, R-squared: 0.3496\n",
      "Epoch: 121 => Loss: 316.2018, MAE: 12.6346, RMSE: 17.7821, R-squared: 0.3697\n",
      "Epoch: 122 => Loss: 297.4879, MAE: 11.9257, RMSE: 17.2478, R-squared: 0.4070\n",
      "Epoch: 123 => Loss: 293.5169, MAE: 12.0120, RMSE: 17.1323, R-squared: 0.4149\n",
      "Epoch: 124 => Loss: 325.4189, MAE: 13.3979, RMSE: 18.0394, R-squared: 0.3514\n",
      "Epoch: 125 => Loss: 337.7427, MAE: 13.4758, RMSE: 18.3778, R-squared: 0.3268\n",
      "Epoch: 126 => Loss: 350.9449, MAE: 13.8866, RMSE: 18.7335, R-squared: 0.3005\n",
      "Epoch: 127 => Loss: 314.4707, MAE: 12.8850, RMSE: 17.7333, R-squared: 0.3732\n",
      "Epoch: 128 => Loss: 347.3487, MAE: 12.6392, RMSE: 18.6373, R-squared: 0.3076\n",
      "Epoch: 129 => Loss: 335.6632, MAE: 13.2216, RMSE: 18.3211, R-squared: 0.3309\n",
      "Epoch: 130 => Loss: 385.8365, MAE: 13.1339, RMSE: 19.6427, R-squared: 0.2309\n",
      "Epoch: 131 => Loss: 425.6881, MAE: 15.0745, RMSE: 20.6322, R-squared: 0.1515\n",
      "Epoch: 132 => Loss: 321.8783, MAE: 13.3308, RMSE: 17.9410, R-squared: 0.3584\n",
      "Epoch: 133 => Loss: 316.9697, MAE: 13.0954, RMSE: 17.8036, R-squared: 0.3682\n",
      "Epoch: 134 => Loss: 337.7859, MAE: 13.1020, RMSE: 18.3790, R-squared: 0.3267\n",
      "Epoch: 135 => Loss: 316.1396, MAE: 12.7708, RMSE: 17.7803, R-squared: 0.3698\n",
      "Epoch: 136 => Loss: 315.3059, MAE: 12.9202, RMSE: 17.7569, R-squared: 0.3715\n",
      "Epoch: 137 => Loss: 293.5051, MAE: 12.0454, RMSE: 17.1320, R-squared: 0.4150\n",
      "Epoch: 138 => Loss: 297.9490, MAE: 12.3449, RMSE: 17.2612, R-squared: 0.4061\n",
      "Epoch: 139 => Loss: 300.8687, MAE: 12.5100, RMSE: 17.3456, R-squared: 0.4003\n",
      "Epoch: 140 => Loss: 357.0237, MAE: 13.8157, RMSE: 18.8951, R-squared: 0.2884\n",
      "Epoch: 141 => Loss: 312.9432, MAE: 12.9119, RMSE: 17.6902, R-squared: 0.3762\n",
      "Epoch: 142 => Loss: 317.3801, MAE: 12.6311, RMSE: 17.8152, R-squared: 0.3674\n",
      "Epoch: 143 => Loss: 323.7773, MAE: 12.6999, RMSE: 17.9938, R-squared: 0.3546\n",
      "Epoch: 144 => Loss: 353.9771, MAE: 13.5007, RMSE: 18.8143, R-squared: 0.2944\n",
      "Epoch: 145 => Loss: 322.2313, MAE: 13.0571, RMSE: 17.9508, R-squared: 0.3577\n",
      "Epoch: 146 => Loss: 332.2366, MAE: 13.1005, RMSE: 18.2274, R-squared: 0.3378\n",
      "Epoch: 147 => Loss: 324.9732, MAE: 13.2650, RMSE: 18.0270, R-squared: 0.3522\n",
      "Epoch: 148 => Loss: 291.3069, MAE: 12.3866, RMSE: 17.0677, R-squared: 0.4193\n",
      "Epoch: 149 => Loss: 308.1058, MAE: 12.4339, RMSE: 17.5529, R-squared: 0.3859\n",
      "Epoch: 150 => Loss: 510.5547, MAE: 16.1417, RMSE: 22.5955, R-squared: -0.0177\n",
      "Epoch: 151 => Loss: 305.2673, MAE: 12.6815, RMSE: 17.4719, R-squared: 0.3915\n",
      "Epoch: 152 => Loss: 320.3790, MAE: 13.1410, RMSE: 17.8991, R-squared: 0.3614\n",
      "Epoch: 153 => Loss: 356.9973, MAE: 12.7566, RMSE: 18.8944, R-squared: 0.2884\n",
      "Epoch: 154 => Loss: 344.7300, MAE: 12.6940, RMSE: 18.5669, R-squared: 0.3129\n",
      "Epoch: 155 => Loss: 308.5587, MAE: 12.3971, RMSE: 17.5658, R-squared: 0.3850\n",
      "Epoch: 156 => Loss: 312.1431, MAE: 12.9810, RMSE: 17.6676, R-squared: 0.3778\n",
      "Epoch: 157 => Loss: 380.3128, MAE: 14.4337, RMSE: 19.5016, R-squared: 0.2419\n",
      "Epoch: 158 => Loss: 319.2365, MAE: 12.9728, RMSE: 17.8672, R-squared: 0.3637\n",
      "Epoch: 159 => Loss: 318.3032, MAE: 13.1413, RMSE: 17.8411, R-squared: 0.3655\n",
      "Epoch: 160 => Loss: 279.0225, MAE: 12.1617, RMSE: 16.7040, R-squared: 0.4438\n",
      "Epoch: 161 => Loss: 296.4051, MAE: 12.1574, RMSE: 17.2164, R-squared: 0.4092\n",
      "Epoch: 162 => Loss: 312.3074, MAE: 12.4644, RMSE: 17.6722, R-squared: 0.3775\n",
      "Epoch: 163 => Loss: 294.3024, MAE: 12.2992, RMSE: 17.1552, R-squared: 0.4134\n",
      "Epoch: 164 => Loss: 296.4068, MAE: 12.6545, RMSE: 17.2165, R-squared: 0.4092\n",
      "Epoch: 165 => Loss: 383.0820, MAE: 14.1763, RMSE: 19.5725, R-squared: 0.2364\n",
      "Epoch: 166 => Loss: 377.3897, MAE: 14.2735, RMSE: 19.4265, R-squared: 0.2478\n",
      "Epoch: 167 => Loss: 328.8477, MAE: 12.8373, RMSE: 18.1342, R-squared: 0.3445\n",
      "Epoch: 168 => Loss: 353.5452, MAE: 13.3677, RMSE: 18.8028, R-squared: 0.2953\n",
      "Epoch: 169 => Loss: 328.0196, MAE: 12.9448, RMSE: 18.1113, R-squared: 0.3462\n",
      "Epoch: 170 => Loss: 370.9703, MAE: 14.1518, RMSE: 19.2606, R-squared: 0.2606\n",
      "Epoch: 171 => Loss: 336.4367, MAE: 13.4081, RMSE: 18.3422, R-squared: 0.3294\n",
      "Epoch: 172 => Loss: 388.3442, MAE: 14.4158, RMSE: 19.7065, R-squared: 0.2259\n",
      "Epoch: 173 => Loss: 343.1582, MAE: 12.7572, RMSE: 18.5245, R-squared: 0.3160\n",
      "Epoch: 174 => Loss: 342.9189, MAE: 13.2166, RMSE: 18.5181, R-squared: 0.3165\n",
      "Epoch: 175 => Loss: 313.7516, MAE: 12.8531, RMSE: 17.7130, R-squared: 0.3746\n",
      "Epoch: 176 => Loss: 304.0869, MAE: 12.4881, RMSE: 17.4381, R-squared: 0.3939\n",
      "Epoch: 177 => Loss: 273.4798, MAE: 11.6277, RMSE: 16.5372, R-squared: 0.4549\n",
      "Epoch: 178 => Loss: 290.5527, MAE: 12.1985, RMSE: 17.0456, R-squared: 0.4209\n",
      "Epoch: 179 => Loss: 495.0037, MAE: 15.9771, RMSE: 22.2487, R-squared: 0.0133\n",
      "Epoch: 180 => Loss: 312.9803, MAE: 12.3033, RMSE: 17.6912, R-squared: 0.3761\n",
      "Epoch: 181 => Loss: 304.2913, MAE: 11.7886, RMSE: 17.4439, R-squared: 0.3935\n",
      "Epoch: 182 => Loss: 303.8357, MAE: 12.5528, RMSE: 17.4309, R-squared: 0.3944\n",
      "Epoch: 183 => Loss: 412.4280, MAE: 14.9687, RMSE: 20.3083, R-squared: 0.1779\n",
      "Epoch: 184 => Loss: 320.0958, MAE: 12.5015, RMSE: 17.8912, R-squared: 0.3620\n",
      "Epoch: 185 => Loss: 306.0569, MAE: 12.6755, RMSE: 17.4945, R-squared: 0.3899\n",
      "Epoch: 186 => Loss: 316.0037, MAE: 12.4791, RMSE: 17.7765, R-squared: 0.3701\n",
      "Epoch: 187 => Loss: 329.2805, MAE: 12.7543, RMSE: 18.1461, R-squared: 0.3437\n",
      "Epoch: 188 => Loss: 308.9589, MAE: 12.2870, RMSE: 17.5772, R-squared: 0.3842\n",
      "Epoch: 189 => Loss: 344.7464, MAE: 13.5328, RMSE: 18.5673, R-squared: 0.3128\n",
      "Epoch: 190 => Loss: 318.1019, MAE: 13.0862, RMSE: 17.8354, R-squared: 0.3659\n",
      "Epoch: 191 => Loss: 286.5382, MAE: 12.2756, RMSE: 16.9274, R-squared: 0.4289\n",
      "Epoch: 192 => Loss: 302.8866, MAE: 12.7902, RMSE: 17.4036, R-squared: 0.3963\n",
      "Epoch: 193 => Loss: 300.3724, MAE: 11.7795, RMSE: 17.3313, R-squared: 0.4013\n",
      "Epoch: 194 => Loss: 294.5298, MAE: 12.1308, RMSE: 17.1619, R-squared: 0.4129\n",
      "Epoch: 195 => Loss: 298.8530, MAE: 12.1845, RMSE: 17.2874, R-squared: 0.4043\n",
      "Epoch: 196 => Loss: 307.2528, MAE: 12.5224, RMSE: 17.5286, R-squared: 0.3876\n",
      "Epoch: 197 => Loss: 385.4000, MAE: 14.3542, RMSE: 19.6316, R-squared: 0.2318\n",
      "Epoch: 198 => Loss: 295.1799, MAE: 12.1024, RMSE: 17.1808, R-squared: 0.4116\n",
      "Epoch: 199 => Loss: 359.0262, MAE: 13.9037, RMSE: 18.9480, R-squared: 0.2844\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "model = CycloneGNN().to(device)\n",
    "optimizer = optim.Adam(model.parameters(), lr=0.01)\n",
    "criterion = nn.MSELoss()\n",
    "\n",
    "def calculate_metrics(predictions, targets):\n",
    "    mae = torch.mean(torch.abs(predictions - targets))\n",
    "    rmse = torch.sqrt(torch.mean((predictions - targets) ** 2))\n",
    "    y_mean = torch.mean(targets)\n",
    "    ss_total = torch.sum((targets - y_mean) ** 2)\n",
    "    ss_residual = torch.sum((predictions - targets) ** 2)\n",
    "    r_squared = 1 - (ss_residual / ss_total)\n",
    "    return mae.item(), rmse.item(), r_squared.item()\n",
    "\n",
    "def train(model, optimizer, criterion, data, epochs):\n",
    "    model.train()\n",
    "    maes = []\n",
    "    rmses = []\n",
    "    r_squareds = []\n",
    "    for epoch in range(epochs):\n",
    "        optimizer.zero_grad()\n",
    "        out = model(data.x.to(device), data.edge_index.to(device))\n",
    "        loss = criterion(out, data.x.to(device))\n",
    "        mae, rmse, r_squared = calculate_metrics(out, data.x)\n",
    "        maes.append(mae)\n",
    "        rmses.append(rmse)\n",
    "        r_squareds.append(r_squared)\n",
    "        print(f'Epoch: {epoch} => Loss: {loss:.4f}, MAE: {mae:.4f}, RMSE: {rmse:.4f}, R-squared: {r_squared:.4f}')\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "\n",
    "    plt.plot(maes, label='MAE')\n",
    "    plt.plot(rmses, label='RMSE')\n",
    "    plt.plot(r_squareds, label='R-squared')\n",
    "    plt.xlabel('Epoch')\n",
    "    plt.ylabel('Metric Value')\n",
    "    plt.title('Metrics During Training')\n",
    "    plt.legend()\n",
    "    plt.show()\n",
    "    \n",
    "    \n",
    "train(model, optimizer, criterion, data, 200)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "8e78d389",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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faX4nfq7nG7duqGwsBCffvopd3/cJyUWiyW2lZWV4eCDD8Yvv/yS1I648+1RRx2Fb7/9FvX19aba4QaWNSrDhw/H8OHDNffLbV8A8N///heDBw9OcgBq0aJF0rEEQRAEkeucdtppGDBgAEaOHIlHH30Uhx9+OH777TfMmTMHI0eORL9+/XDrrbdizJgx6NevHwYOHIiZM2dizZo1ms60BQUFuPPOO3HHHXcgPz8fJ510Enbs2IE1a9Zg3LhxKC0tRWFhIT766CN07NgRBQUFKC4uxpQpU3DLLbegdevWGD58OEKhEL755hvs2bMHEydOxKWXXop77rkH48aNwx//+Eds3LgRf/nLX9J6vVwNT96+fTs++OADjBs3LmnfzJkzUVJSgh49emDSpEnYt2+fZjmhUAi1tbWKP4IgCILIRgRBwJw5c3DyySfjqquuQvfu3TF69Ghs3LgRZWVlACR3iD/96U+488470bdvX2zatMnQgfXee+/Fbbfdhj/96U848sgjMWrUKFRXVwMAAoEAnn76abz44ouoqKjAueeeCwC4+uqr8Y9//APTp09Hr169cMopp2D69OkJjUqrVq3w3nvvYe3atejTpw/uuecePProoy5enWQEloIBShCEJB8VOY899hgeeeQR/PbbbygoKEhsf+mll9ClSxeUl5dj9erVmDx5Mg477DDMnTuXW86UKVNw//33J22vqalB69at7TafIHKHpf8APrhN+jylJrNtIQgbNDQ0YMOGDejSpYtivCCyD717WVtbi+LiYkvjt6tRPy+//DIuu+yypIbKvYt79uyJbt26oV+/fli+fDmOPfbYpHImT56MiRMnJr7X1taisrLSvYYTRNZBUT8EQeQmrgkqX375JX788Ue88cYbhscee+yxyMvLw7p167iCSjAYTMSaEwRBEATRfHDNR2XatGno27cvevfubXjsmjVrEIlE0KFDB7eaQxC5DeVRIQgiR7GsUamrq8P69esT3zds2ICVK1eibdu26NSpEwDJNPPmm2/i8ccfT/r9zz//jJkzZ+LMM89ESUkJ1q5di9tuuw19+vTBSSedlMKpEARBEASRa1gWVL755hsMHjw48T3uOzJmzJjEctOzZs0CYwyXXHJJ0u/z8/Px6aef4qmnnkJdXR0qKytx1lln4b777kskmCEIgiCaJ15IMEakhtP30LKg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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(range(len(cyclone_data)), cyclone_data['VMAX'], label='Actual')\n",
    "with torch.no_grad():\n",
    "    out = model(data.x.to(device), data.edge_index.to(device))\n",
    "    plt.plot(range(len(cyclone_data)), out.cpu().numpy(), label='Predicted')\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "14dc7e85",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Actual VMAX (First 30 data points): [ 25  30  35  45  60  65  70  75  80  85  95 100 110 110 100  90  90  80\n",
      "  75  65  60  55  50  50  45  45  40  40  30  30]\n",
      "Predicted VMAX (First 30 data points): [[ 28.991653]\n",
      " [ 16.58093 ]\n",
      " [ 23.199772]\n",
      " [ 34.07021 ]\n",
      " [ 54.66    ]\n",
      " [ 44.88921 ]\n",
      " [ 42.96887 ]\n",
      " [ 21.15669 ]\n",
      " [ 20.033344]\n",
      " [ 88.39291 ]\n",
      " [ 79.54843 ]\n",
      " [ 74.23568 ]\n",
      " [ 40.127625]\n",
      " [133.76823 ]\n",
      " [ 94.54395 ]\n",
      " [108.866066]\n",
      " [ 79.74122 ]\n",
      " [ 31.679413]\n",
      " [ 46.34947 ]\n",
      " [ 67.48662 ]\n",
      " [ 29.79332 ]\n",
      " [ 37.99158 ]\n",
      " [ 47.02028 ]\n",
      " [ 37.350155]\n",
      " [ 48.397243]\n",
      " [ 53.316822]\n",
      " [ 32.455074]\n",
      " [ 18.82608 ]\n",
      " [ 25.830772]\n",
      " [ 15.722138]]\n"
     ]
    }
   ],
   "source": [
    "# Get the actual VMAX values for the first 30 data points\n",
    "actual_vmax = cyclone_data['VMAX'].values[:30]\n",
    "\n",
    "# Get the predicted VMAX values for the first 30 data points\n",
    "with torch.no_grad():\n",
    "    predicted_vmax = model(data.x.to(device), data.edge_index.to(device)).cpu().numpy()[:30]\n",
    "\n",
    "# Print the actual and predicted VMAX values for the first 30 data points\n",
    "print(\"Actual VMAX (First 30 data points):\", actual_vmax)\n",
    "print(\"Predicted VMAX (First 30 data points):\", predicted_vmax)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "7e5fca6d",
   "metadata": {},
   "outputs": [
    {
     "ename": "ValueError",
     "evalue": "optimizer got an empty parameter list",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mValueError\u001b[0m                                Traceback (most recent call last)",
      "\u001b[0;32m/tmp/ipykernel_156567/744207996.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     28\u001b[0m     \u001b[0;31m# Initialize the model and optimizer for each fold\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     29\u001b[0m     \u001b[0mmodel\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mCycloneGNN\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mto\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdevice\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 30\u001b[0;31m     \u001b[0moptimizer\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0moptim\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mAdam\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmodel\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mparameters\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlr\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m0.01\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     31\u001b[0m     \u001b[0mcriterion\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnn\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mMSELoss\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     32\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/lib/python3.9/site-packages/torch/optim/adam.py\u001b[0m in \u001b[0;36m__init__\u001b[0;34m(self, params, lr, betas, eps, weight_decay, amsgrad, foreach, maximize, capturable, differentiable, fused)\u001b[0m\n\u001b[1;32m     31\u001b[0m                         \u001b[0mmaximize\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mmaximize\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mforeach\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mforeach\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcapturable\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mcapturable\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     32\u001b[0m                         differentiable=differentiable, fused=fused)\n\u001b[0;32m---> 33\u001b[0;31m         \u001b[0msuper\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__init__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mparams\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdefaults\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     34\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     35\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mfused\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/lib/python3.9/site-packages/torch/optim/optimizer.py\u001b[0m in \u001b[0;36m__init__\u001b[0;34m(self, params, defaults)\u001b[0m\n\u001b[1;32m    185\u001b[0m         \u001b[0mparam_groups\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mlist\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mparams\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    186\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mparam_groups\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 187\u001b[0;31m             \u001b[0;32mraise\u001b[0m \u001b[0mValueError\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"optimizer got an empty parameter list\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    188\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0misinstance\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mparam_groups\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdict\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    189\u001b[0m             \u001b[0mparam_groups\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0;34m{\u001b[0m\u001b[0;34m'params'\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0mparam_groups\u001b[0m\u001b[0;34m}\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mValueError\u001b[0m: optimizer got an empty parameter list"
     ]
    }
   ],
   "source": [
    "from sklearn.model_selection import KFold\n",
    "import torch_geometric\n",
    "from torch_geometric.utils import to_networkx\n",
    "\n",
    "# ... (your data loading and preprocessing code) ...\n",
    "\n",
    "class CycloneGNN(nn.Module):\n",
    "    # ... (your model definition) ...\n",
    "\n",
    "    device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "\n",
    "# Define the number of folds for cross-validation\n",
    "num_folds = 5\n",
    "\n",
    "# Initialize KFold cross-validation\n",
    "kf = KFold(n_splits=num_folds, shuffle=True, random_state=42)\n",
    "\n",
    "# Lists to store cross-validation metrics\n",
    "cv_maes = []\n",
    "cv_rmses = []\n",
    "cv_r_squareds = []\n",
    "\n",
    "for fold, (train_indices, val_indices) in enumerate(kf.split(data.x)):\n",
    "    # Split the data into train and validation sets\n",
    "    train_data = data.__class__(x=data.x[train_indices], edge_index=data.edge_index)\n",
    "    val_data = data.__class__(x=data.x[val_indices], edge_index=data.edge_index)\n",
    "\n",
    "    # Initialize the model and optimizer for each fold\n",
    "    model = CycloneGNN().to(device)\n",
    "    optimizer = optim.Adam(model.parameters(), lr=0.01)\n",
    "    criterion = nn.MSELoss()\n",
    "\n",
    "    # Training loop\n",
    "    for epoch in range(200):\n",
    "        model.train()\n",
    "        optimizer.zero_grad()\n",
    "        out = model(train_data.x.to(device), train_data.edge_index.to(device))\n",
    "        loss = criterion(out, train_data.x.to(device))\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "\n",
    "    # Calculate metrics on the validation set\n",
    "    model.eval()\n",
    "    with torch.no_grad():\n",
    "        val_out = model(val_data.x.to(device), val_data.edge_index.to(device))\n",
    "        val_mae, val_rmse, val_r_squared = calculate_metrics(val_out, val_data.x)\n",
    "\n",
    "    cv_maes.append(val_mae)\n",
    "    cv_rmses.append(val_rmse)\n",
    "    cv_r_squareds.append(val_r_squared)\n",
    "\n",
    "# Print average cross-validation metrics\n",
    "print(\"Average MAE:\", sum(cv_maes) / num_folds)\n",
    "print(\"Average RMSE:\", sum(cv_rmses) / num_folds)\n",
    "print(\"Average R-squared:\", sum(cv_r_squareds) / num_folds)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1d6708c5",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
