{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "# This is a slightly modified copy of the TensorFlow tutorial:\n",
    "# https://www.tensorflow.org/tutorials/structured_data/time_series\n",
    "import matplotlib as mpl\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import urllib\n",
    "import zipfile\n",
    "\n",
    "mpl.rcParams['figure.figsize'] = (8, 6)\n",
    "mpl.rcParams['axes.grid'] = False"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Downloading the data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "url = \"https://storage.googleapis.com/tensorflow/tf-keras-datasets/jena_climate_2009_2016.csv.zip\"\n",
    "data_folder = \".\"\n",
    "filename_csv = f\"{data_folder}/jena_climate_2009_2016.csv\"\n",
    "urllib.request.urlretrieve(url, filename=f\"{filename_csv}.zip\")\n",
    "with zipfile.ZipFile(f\"{filename_csv}.zip\", 'r') as zip_ref:\n",
    "    zip_ref.extractall(data_folder)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Cleaning and analyzing the data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Date Time</th>\n",
       "      <th>p (mbar)</th>\n",
       "      <th>T (degC)</th>\n",
       "      <th>Tpot (K)</th>\n",
       "      <th>Tdew (degC)</th>\n",
       "      <th>rh (%)</th>\n",
       "      <th>VPmax (mbar)</th>\n",
       "      <th>VPact (mbar)</th>\n",
       "      <th>VPdef (mbar)</th>\n",
       "      <th>sh (g/kg)</th>\n",
       "      <th>H2OC (mmol/mol)</th>\n",
       "      <th>rho (g/m**3)</th>\n",
       "      <th>wv (m/s)</th>\n",
       "      <th>max. wv (m/s)</th>\n",
       "      <th>wd (deg)</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>01.01.2009 00:10:00</td>\n",
       "      <td>996.52</td>\n",
       "      <td>-8.02</td>\n",
       "      <td>265.40</td>\n",
       "      <td>-8.90</td>\n",
       "      <td>93.3</td>\n",
       "      <td>3.33</td>\n",
       "      <td>3.11</td>\n",
       "      <td>0.22</td>\n",
       "      <td>1.94</td>\n",
       "      <td>3.12</td>\n",
       "      <td>1307.75</td>\n",
       "      <td>1.03</td>\n",
       "      <td>1.75</td>\n",
       "      <td>152.3</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>01.01.2009 00:20:00</td>\n",
       "      <td>996.57</td>\n",
       "      <td>-8.41</td>\n",
       "      <td>265.01</td>\n",
       "      <td>-9.28</td>\n",
       "      <td>93.4</td>\n",
       "      <td>3.23</td>\n",
       "      <td>3.02</td>\n",
       "      <td>0.21</td>\n",
       "      <td>1.89</td>\n",
       "      <td>3.03</td>\n",
       "      <td>1309.80</td>\n",
       "      <td>0.72</td>\n",
       "      <td>1.50</td>\n",
       "      <td>136.1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>01.01.2009 00:30:00</td>\n",
       "      <td>996.53</td>\n",
       "      <td>-8.51</td>\n",
       "      <td>264.91</td>\n",
       "      <td>-9.31</td>\n",
       "      <td>93.9</td>\n",
       "      <td>3.21</td>\n",
       "      <td>3.01</td>\n",
       "      <td>0.20</td>\n",
       "      <td>1.88</td>\n",
       "      <td>3.02</td>\n",
       "      <td>1310.24</td>\n",
       "      <td>0.19</td>\n",
       "      <td>0.63</td>\n",
       "      <td>171.6</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>01.01.2009 00:40:00</td>\n",
       "      <td>996.51</td>\n",
       "      <td>-8.31</td>\n",
       "      <td>265.12</td>\n",
       "      <td>-9.07</td>\n",
       "      <td>94.2</td>\n",
       "      <td>3.26</td>\n",
       "      <td>3.07</td>\n",
       "      <td>0.19</td>\n",
       "      <td>1.92</td>\n",
       "      <td>3.08</td>\n",
       "      <td>1309.19</td>\n",
       "      <td>0.34</td>\n",
       "      <td>0.50</td>\n",
       "      <td>198.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>01.01.2009 00:50:00</td>\n",
       "      <td>996.51</td>\n",
       "      <td>-8.27</td>\n",
       "      <td>265.15</td>\n",
       "      <td>-9.04</td>\n",
       "      <td>94.1</td>\n",
       "      <td>3.27</td>\n",
       "      <td>3.08</td>\n",
       "      <td>0.19</td>\n",
       "      <td>1.92</td>\n",
       "      <td>3.09</td>\n",
       "      <td>1309.00</td>\n",
       "      <td>0.32</td>\n",
       "      <td>0.63</td>\n",
       "      <td>214.3</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "             Date Time  p (mbar)  T (degC)  Tpot (K)  Tdew (degC)  rh (%)  \\\n",
       "0  01.01.2009 00:10:00    996.52     -8.02    265.40        -8.90    93.3   \n",
       "1  01.01.2009 00:20:00    996.57     -8.41    265.01        -9.28    93.4   \n",
       "2  01.01.2009 00:30:00    996.53     -8.51    264.91        -9.31    93.9   \n",
       "3  01.01.2009 00:40:00    996.51     -8.31    265.12        -9.07    94.2   \n",
       "4  01.01.2009 00:50:00    996.51     -8.27    265.15        -9.04    94.1   \n",
       "\n",
       "   VPmax (mbar)  VPact (mbar)  VPdef (mbar)  sh (g/kg)  H2OC (mmol/mol)  \\\n",
       "0          3.33          3.11          0.22       1.94             3.12   \n",
       "1          3.23          3.02          0.21       1.89             3.03   \n",
       "2          3.21          3.01          0.20       1.88             3.02   \n",
       "3          3.26          3.07          0.19       1.92             3.08   \n",
       "4          3.27          3.08          0.19       1.92             3.09   \n",
       "\n",
       "   rho (g/m**3)  wv (m/s)  max. wv (m/s)  wd (deg)  \n",
       "0       1307.75      1.03           1.75     152.3  \n",
       "1       1309.80      0.72           1.50     136.1  \n",
       "2       1310.24      0.19           0.63     171.6  \n",
       "3       1309.19      0.34           0.50     198.0  \n",
       "4       1309.00      0.32           0.63     214.3  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>p (mbar)</th>\n",
       "      <th>T (degC)</th>\n",
       "      <th>Tpot (K)</th>\n",
       "      <th>Tdew (degC)</th>\n",
       "      <th>rh (%)</th>\n",
       "      <th>VPmax (mbar)</th>\n",
       "      <th>VPact (mbar)</th>\n",
       "      <th>VPdef (mbar)</th>\n",
       "      <th>sh (g/kg)</th>\n",
       "      <th>H2OC (mmol/mol)</th>\n",
       "      <th>rho (g/m**3)</th>\n",
       "      <th>wv (m/s)</th>\n",
       "      <th>max. wv (m/s)</th>\n",
       "      <th>wd (deg)</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>count</th>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mean</th>\n",
       "      <td>989.212776</td>\n",
       "      <td>9.450147</td>\n",
       "      <td>283.492743</td>\n",
       "      <td>4.955854</td>\n",
       "      <td>76.008259</td>\n",
       "      <td>13.576251</td>\n",
       "      <td>9.533756</td>\n",
       "      <td>4.042412</td>\n",
       "      <td>6.022408</td>\n",
       "      <td>9.640223</td>\n",
       "      <td>1216.062748</td>\n",
       "      <td>1.702224</td>\n",
       "      <td>3.056555</td>\n",
       "      <td>174.743738</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>std</th>\n",
       "      <td>8.358481</td>\n",
       "      <td>8.423365</td>\n",
       "      <td>8.504471</td>\n",
       "      <td>6.730674</td>\n",
       "      <td>16.476175</td>\n",
       "      <td>7.739020</td>\n",
       "      <td>4.184164</td>\n",
       "      <td>4.896851</td>\n",
       "      <td>2.656139</td>\n",
       "      <td>4.235395</td>\n",
       "      <td>39.975208</td>\n",
       "      <td>65.446714</td>\n",
       "      <td>69.016932</td>\n",
       "      <td>86.681693</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>min</th>\n",
       "      <td>913.600000</td>\n",
       "      <td>-23.010000</td>\n",
       "      <td>250.600000</td>\n",
       "      <td>-25.010000</td>\n",
       "      <td>12.950000</td>\n",
       "      <td>0.950000</td>\n",
       "      <td>0.790000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.500000</td>\n",
       "      <td>0.800000</td>\n",
       "      <td>1059.450000</td>\n",
       "      <td>-9999.000000</td>\n",
       "      <td>-9999.000000</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25%</th>\n",
       "      <td>984.200000</td>\n",
       "      <td>3.360000</td>\n",
       "      <td>277.430000</td>\n",
       "      <td>0.240000</td>\n",
       "      <td>65.210000</td>\n",
       "      <td>7.780000</td>\n",
       "      <td>6.210000</td>\n",
       "      <td>0.870000</td>\n",
       "      <td>3.920000</td>\n",
       "      <td>6.290000</td>\n",
       "      <td>1187.490000</td>\n",
       "      <td>0.990000</td>\n",
       "      <td>1.760000</td>\n",
       "      <td>124.900000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50%</th>\n",
       "      <td>989.580000</td>\n",
       "      <td>9.420000</td>\n",
       "      <td>283.470000</td>\n",
       "      <td>5.220000</td>\n",
       "      <td>79.300000</td>\n",
       "      <td>11.820000</td>\n",
       "      <td>8.860000</td>\n",
       "      <td>2.190000</td>\n",
       "      <td>5.590000</td>\n",
       "      <td>8.960000</td>\n",
       "      <td>1213.790000</td>\n",
       "      <td>1.760000</td>\n",
       "      <td>2.960000</td>\n",
       "      <td>198.100000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>75%</th>\n",
       "      <td>994.720000</td>\n",
       "      <td>15.470000</td>\n",
       "      <td>289.530000</td>\n",
       "      <td>10.070000</td>\n",
       "      <td>89.400000</td>\n",
       "      <td>17.600000</td>\n",
       "      <td>12.350000</td>\n",
       "      <td>5.300000</td>\n",
       "      <td>7.800000</td>\n",
       "      <td>12.490000</td>\n",
       "      <td>1242.770000</td>\n",
       "      <td>2.860000</td>\n",
       "      <td>4.740000</td>\n",
       "      <td>234.100000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>max</th>\n",
       "      <td>1015.350000</td>\n",
       "      <td>37.280000</td>\n",
       "      <td>311.340000</td>\n",
       "      <td>23.110000</td>\n",
       "      <td>100.000000</td>\n",
       "      <td>63.770000</td>\n",
       "      <td>28.320000</td>\n",
       "      <td>46.010000</td>\n",
       "      <td>18.130000</td>\n",
       "      <td>28.820000</td>\n",
       "      <td>1393.540000</td>\n",
       "      <td>28.490000</td>\n",
       "      <td>23.500000</td>\n",
       "      <td>360.000000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "            p (mbar)       T (degC)       Tpot (K)    Tdew (degC)  \\\n",
       "count  420551.000000  420551.000000  420551.000000  420551.000000   \n",
       "mean      989.212776       9.450147     283.492743       4.955854   \n",
       "std         8.358481       8.423365       8.504471       6.730674   \n",
       "min       913.600000     -23.010000     250.600000     -25.010000   \n",
       "25%       984.200000       3.360000     277.430000       0.240000   \n",
       "50%       989.580000       9.420000     283.470000       5.220000   \n",
       "75%       994.720000      15.470000     289.530000      10.070000   \n",
       "max      1015.350000      37.280000     311.340000      23.110000   \n",
       "\n",
       "              rh (%)   VPmax (mbar)   VPact (mbar)   VPdef (mbar)  \\\n",
       "count  420551.000000  420551.000000  420551.000000  420551.000000   \n",
       "mean       76.008259      13.576251       9.533756       4.042412   \n",
       "std        16.476175       7.739020       4.184164       4.896851   \n",
       "min        12.950000       0.950000       0.790000       0.000000   \n",
       "25%        65.210000       7.780000       6.210000       0.870000   \n",
       "50%        79.300000      11.820000       8.860000       2.190000   \n",
       "75%        89.400000      17.600000      12.350000       5.300000   \n",
       "max       100.000000      63.770000      28.320000      46.010000   \n",
       "\n",
       "           sh (g/kg)  H2OC (mmol/mol)   rho (g/m**3)       wv (m/s)  \\\n",
       "count  420551.000000    420551.000000  420551.000000  420551.000000   \n",
       "mean        6.022408         9.640223    1216.062748       1.702224   \n",
       "std         2.656139         4.235395      39.975208      65.446714   \n",
       "min         0.500000         0.800000    1059.450000   -9999.000000   \n",
       "25%         3.920000         6.290000    1187.490000       0.990000   \n",
       "50%         5.590000         8.960000    1213.790000       1.760000   \n",
       "75%         7.800000        12.490000    1242.770000       2.860000   \n",
       "max        18.130000        28.820000    1393.540000      28.490000   \n",
       "\n",
       "       max. wv (m/s)       wd (deg)  \n",
       "count  420551.000000  420551.000000  \n",
       "mean        3.056555     174.743738  \n",
       "std        69.016932      86.681693  \n",
       "min     -9999.000000       0.000000  \n",
       "25%         1.760000     124.900000  \n",
       "50%         2.960000     198.100000  \n",
       "75%         4.740000     234.100000  \n",
       "max        23.500000     360.000000  "
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "full_df = pd.read_csv(filename_csv)\n",
    "display(full_df.head())\n",
    "display(full_df.describe())"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Clean the data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>p (mbar)</th>\n",
       "      <th>T (degC)</th>\n",
       "      <th>Tpot (K)</th>\n",
       "      <th>Tdew (degC)</th>\n",
       "      <th>rh (%)</th>\n",
       "      <th>VPmax (mbar)</th>\n",
       "      <th>VPact (mbar)</th>\n",
       "      <th>VPdef (mbar)</th>\n",
       "      <th>sh (g/kg)</th>\n",
       "      <th>H2OC (mmol/mol)</th>\n",
       "      <th>rho (g/m**3)</th>\n",
       "      <th>Wx</th>\n",
       "      <th>Wy</th>\n",
       "      <th>max Wx</th>\n",
       "      <th>max Wy</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>count</th>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "      <td>420551.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mean</th>\n",
       "      <td>989.212776</td>\n",
       "      <td>9.450147</td>\n",
       "      <td>283.492743</td>\n",
       "      <td>4.955854</td>\n",
       "      <td>76.008259</td>\n",
       "      <td>13.576251</td>\n",
       "      <td>9.533756</td>\n",
       "      <td>4.042412</td>\n",
       "      <td>6.022408</td>\n",
       "      <td>9.640223</td>\n",
       "      <td>1216.062748</td>\n",
       "      <td>-0.626802</td>\n",
       "      <td>-0.408377</td>\n",
       "      <td>-1.016537</td>\n",
       "      <td>-0.736739</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>std</th>\n",
       "      <td>8.358481</td>\n",
       "      <td>8.423365</td>\n",
       "      <td>8.504471</td>\n",
       "      <td>6.730674</td>\n",
       "      <td>16.476175</td>\n",
       "      <td>7.739020</td>\n",
       "      <td>4.184164</td>\n",
       "      <td>4.896851</td>\n",
       "      <td>2.656139</td>\n",
       "      <td>4.235395</td>\n",
       "      <td>39.975208</td>\n",
       "      <td>1.987296</td>\n",
       "      <td>1.551618</td>\n",
       "      <td>3.091820</td>\n",
       "      <td>2.611119</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>min</th>\n",
       "      <td>913.600000</td>\n",
       "      <td>-23.010000</td>\n",
       "      <td>250.600000</td>\n",
       "      <td>-25.010000</td>\n",
       "      <td>12.950000</td>\n",
       "      <td>0.950000</td>\n",
       "      <td>0.790000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.500000</td>\n",
       "      <td>0.800000</td>\n",
       "      <td>1059.450000</td>\n",
       "      <td>-12.185638</td>\n",
       "      <td>-8.898422</td>\n",
       "      <td>-19.641473</td>\n",
       "      <td>-17.481020</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25%</th>\n",
       "      <td>984.200000</td>\n",
       "      <td>3.360000</td>\n",
       "      <td>277.430000</td>\n",
       "      <td>0.240000</td>\n",
       "      <td>65.210000</td>\n",
       "      <td>7.780000</td>\n",
       "      <td>6.210000</td>\n",
       "      <td>0.870000</td>\n",
       "      <td>3.920000</td>\n",
       "      <td>6.290000</td>\n",
       "      <td>1187.490000</td>\n",
       "      <td>-1.471247</td>\n",
       "      <td>-1.371162</td>\n",
       "      <td>-2.466904</td>\n",
       "      <td>-2.322774</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50%</th>\n",
       "      <td>989.580000</td>\n",
       "      <td>9.420000</td>\n",
       "      <td>283.470000</td>\n",
       "      <td>5.220000</td>\n",
       "      <td>79.300000</td>\n",
       "      <td>11.820000</td>\n",
       "      <td>8.860000</td>\n",
       "      <td>2.190000</td>\n",
       "      <td>5.590000</td>\n",
       "      <td>8.960000</td>\n",
       "      <td>1213.790000</td>\n",
       "      <td>-0.632737</td>\n",
       "      <td>-0.294725</td>\n",
       "      <td>-1.119319</td>\n",
       "      <td>-0.525339</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>75%</th>\n",
       "      <td>994.720000</td>\n",
       "      <td>15.470000</td>\n",
       "      <td>289.530000</td>\n",
       "      <td>10.070000</td>\n",
       "      <td>89.400000</td>\n",
       "      <td>17.600000</td>\n",
       "      <td>12.350000</td>\n",
       "      <td>5.300000</td>\n",
       "      <td>7.800000</td>\n",
       "      <td>12.490000</td>\n",
       "      <td>1242.770000</td>\n",
       "      <td>0.307492</td>\n",
       "      <td>0.449802</td>\n",
       "      <td>0.634185</td>\n",
       "      <td>0.822203</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>max</th>\n",
       "      <td>1015.350000</td>\n",
       "      <td>37.280000</td>\n",
       "      <td>311.340000</td>\n",
       "      <td>23.110000</td>\n",
       "      <td>100.000000</td>\n",
       "      <td>63.770000</td>\n",
       "      <td>28.320000</td>\n",
       "      <td>46.010000</td>\n",
       "      <td>18.130000</td>\n",
       "      <td>28.820000</td>\n",
       "      <td>1393.540000</td>\n",
       "      <td>27.064704</td>\n",
       "      <td>7.849152</td>\n",
       "      <td>13.473980</td>\n",
       "      <td>14.302308</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "            p (mbar)       T (degC)       Tpot (K)    Tdew (degC)  \\\n",
       "count  420551.000000  420551.000000  420551.000000  420551.000000   \n",
       "mean      989.212776       9.450147     283.492743       4.955854   \n",
       "std         8.358481       8.423365       8.504471       6.730674   \n",
       "min       913.600000     -23.010000     250.600000     -25.010000   \n",
       "25%       984.200000       3.360000     277.430000       0.240000   \n",
       "50%       989.580000       9.420000     283.470000       5.220000   \n",
       "75%       994.720000      15.470000     289.530000      10.070000   \n",
       "max      1015.350000      37.280000     311.340000      23.110000   \n",
       "\n",
       "              rh (%)   VPmax (mbar)   VPact (mbar)   VPdef (mbar)  \\\n",
       "count  420551.000000  420551.000000  420551.000000  420551.000000   \n",
       "mean       76.008259      13.576251       9.533756       4.042412   \n",
       "std        16.476175       7.739020       4.184164       4.896851   \n",
       "min        12.950000       0.950000       0.790000       0.000000   \n",
       "25%        65.210000       7.780000       6.210000       0.870000   \n",
       "50%        79.300000      11.820000       8.860000       2.190000   \n",
       "75%        89.400000      17.600000      12.350000       5.300000   \n",
       "max       100.000000      63.770000      28.320000      46.010000   \n",
       "\n",
       "           sh (g/kg)  H2OC (mmol/mol)   rho (g/m**3)             Wx  \\\n",
       "count  420551.000000    420551.000000  420551.000000  420551.000000   \n",
       "mean        6.022408         9.640223    1216.062748      -0.626802   \n",
       "std         2.656139         4.235395      39.975208       1.987296   \n",
       "min         0.500000         0.800000    1059.450000     -12.185638   \n",
       "25%         3.920000         6.290000    1187.490000      -1.471247   \n",
       "50%         5.590000         8.960000    1213.790000      -0.632737   \n",
       "75%         7.800000        12.490000    1242.770000       0.307492   \n",
       "max        18.130000        28.820000    1393.540000      27.064704   \n",
       "\n",
       "                  Wy         max Wx         max Wy  \n",
       "count  420551.000000  420551.000000  420551.000000  \n",
       "mean       -0.408377      -1.016537      -0.736739  \n",
       "std         1.551618       3.091820       2.611119  \n",
       "min        -8.898422     -19.641473     -17.481020  \n",
       "25%        -1.371162      -2.466904      -2.322774  \n",
       "50%        -0.294725      -1.119319      -0.525339  \n",
       "75%         0.449802       0.634185       0.822203  \n",
       "max         7.849152      13.473980      14.302308  "
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Process the wind features.\n",
    "data = full_df.copy()\n",
    "wv = data.pop('wv (m/s)').copy()\n",
    "max_wv = data.pop('max. wv (m/s)').copy()\n",
    "wd_rad = data.pop('wd (deg)')*np.pi / 180\n",
    "wv.replace(to_replace=-9999.0, value=0, inplace=True)\n",
    "max_wv.replace(to_replace=-9999.0, value=0, inplace=True)\n",
    "\n",
    "# Calculate the wind x and y components.\n",
    "data['Wx'] = wv*np.cos(wd_rad)\n",
    "data['Wy'] = wv*np.sin(wd_rad)\n",
    "# Calculate the max wind x and y components.\n",
    "data['max Wx'] = max_wv*np.cos(wd_rad)\n",
    "data['max Wy'] = max_wv*np.sin(wd_rad)\n",
    "\n",
    "data.describe()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Create time embeddings.\n",
    "datetime = pd.to_datetime(data[\"Date Time\"], format='%d.%m.%Y %H:%M:%S')\n",
    "data[\"Date Time\"] = datetime\n",
    "\n",
    "data[\"sin(hour)\"] = np.sin(datetime.dt.hour)\n",
    "data[\"cos(hour)\"] = np.cos(datetime.dt.hour)\n",
    "data[\"sin(day)\"] = np.sin(datetime.dt.day)\n",
    "data[\"cos(day)\"] = np.cos(datetime.dt.day)\n",
    "data[\"sin(month)\"] = np.sin(datetime.dt.month)\n",
    "data[\"cos(month)\"] = np.cos(datetime.dt.month)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Non-consecutive entries.\n",
      "Index 40377 -> 40378:\n",
      "\t2009-10-08 09:40:00 -> 2009-10-08 10:10:00\n",
      "Index 78765 -> 78766:\n",
      "\t2010-07-02 00:00:00 -> 2010-07-01 00:10:00\n",
      "Index 230018 -> 230019:\n",
      "\t2013-05-16 08:50:00 -> 2013-05-16 09:10:00\n",
      "Index 274564 -> 274565:\n",
      "\t2014-03-21 17:20:00 -> 2014-03-20 11:00:00\n",
      "Index 293555 -> 293556:\n",
      "\t2014-07-30 08:00:00 -> 2014-07-30 08:20:00\n",
      "Index 301672 -> 301673:\n",
      "\t2014-09-24 17:00:00 -> 2014-09-25 09:00:00\n",
      "Index 411266 -> 411267:\n",
      "\t2016-10-25 10:30:00 -> 2016-10-28 12:50:00\n",
      "\n",
      "Total rows: 420551\n"
     ]
    }
   ],
   "source": [
    "# See if all entries are consecutive (spoiler: no).\n",
    "DATETIME = 'Date Time'\n",
    "T = 'T (degC)'\n",
    "\n",
    "diff = datetime[1:].reset_index(drop=True) - datetime[:-1]\n",
    "goal = pd.Timedelta(10, unit=\"m\")\n",
    "skip_mask = (diff - goal).abs() > pd.Timedelta(1, unit=\"s\")\n",
    "\n",
    "print(\"Non-consecutive entries.\")\n",
    "for i in np.where(skip_mask)[0]:\n",
    "    print(f\"Index {i} -> {i+1}:\")\n",
    "    print(f\"\\t{datetime[i]} -> {datetime[i+1]}\")\n",
    "\n",
    "print()\n",
    "print(f\"Total rows: {len(datetime)}\")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Use the largest consecutive chunk.\n",
    "data_chunk = data.loc[78766:230018]\n",
    "chunk_size = len(data_chunk)\n",
    "\n",
    "# Split the data.\n",
    "train_frac, val_frac = 0.7, 0.2\n",
    "assert train_frac + val_frac < 1 \n",
    "train_size = int(chunk_size * train_frac)\n",
    "val_size = int(chunk_size * val_frac)\n",
    "\n",
    "train_df = data_chunk[:train_size]\n",
    "val_df = data_chunk[train_size:train_size+val_size]\n",
    "test_df = data_chunk[train_size+val_size:]\n",
    "full_splits = {\"train\": train_df, \"val\": val_df, \"test\": test_df}\n",
    "\n",
    "# Make sure dataframes start at HH:00:00.\n",
    "for label, split in full_splits.items():\n",
    "    minute = split.iloc[0][\"Date Time\"].minute\n",
    "    shift = (60 - minute) // 10\n",
    "    full_splits[label] = split.iloc[shift:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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W29hzZo1+PTTTzFr1iw8+uijAMoysW+88QYyMjKwb98+7Nu3DyNGjAAADB8+HAsXLsTEiROxcuVKXH311RgwYAA2bdpkaJmfe+45DBkyBMuXL0erVq1www034O6778bIkSOxZMkSCIKA4cOHVyw/b948DBkyBPfffz/Wrl2L999/HxMmTMDzzz9vaLmIiMJhoEtEZINWrVph+/btFb8/8MAD6Nu3Lxo1aoTzzjsPY8aMwTfffAOgLBObmZkJj8dTkXlNT0/Hzp07MX78eEyaNAm9e/dG06ZNMWLECJx99tkBzRGMcOutt+Kaa65BixYt8Nhjj2H79u248cYb0b9/f7Ru3Rr3339/QCb52WefxeOPP45bbrkFTZo0wQUXXIDnnnsO77//vqHlIiIKh210iYhsIAgCPB5Pxe8zZszA2LFjsX79euTl5aG0tBSFhYUoKChAamqq5DpWrVoFn8+HFi1aBLxeVFSE6tWrG1reDh06VPyck5MDAGjfvn3Aa4WFhcjLy0NGRgZWrFiBBQsWBGRwfT6f4nciIjISA10iIhusW7cOjRs3BgBs374dl156Ke699148//zzyMrKwvz583H77bejuLhYNijMz89HXFwcli5diri4uID30tPTDS1vQkJCxc/lAbrUa+WjSeTn5+PZZ5/F4MGDQ9aVnJxsaNmIiOQw0CUistisWbOwatUqPPjggwCApUuXwu/347XXXoPXW9airLzZQrnExET4fL6A1zp16gSfz4eDBw+id+/e1hRepc6dO2PDhg1o1qyZ3UUhohjGQJeIyERFRUXYv39/wPBiY8eOxaWXXoohQ4YAAJo1a4aSkhK8/fbbGDhwIBYsWID33nsvYD2NGjVCfn4+Zs6ciY4dOyI1NRUtWrTAjTfeiCFDhuC1115Dp06dcOjQIcycORMdOnTAJZdcYsdXBgCMGjUKl156KRo0aICrrroKXq8XK1aswOrVqzFmzBjbykVEsYWd0YiITDRt2jTUrl0bjRo1woABAzB79my89dZbmDx5ckVzg44dO2LcuHF46aWX0K5dO3z55ZcYO3ZswHp69eqFe+65B9deey2ys7Px8ssvAwDGjx+PIUOG4OGHH0bLli1x+eWXY/HixWjQoIHl31Wsf//+mDJlCn7//Xd069YNZ555Jl5//XU0bNjQ1nIRUWzxCIIg2F0IIiIiIiKjMaNLRERERFGJgS4RERERRSUGukREREQUlRjoEhEREVFUYqBLRERERFGJgS4RERERRSUGukREREQUlRjoEhEREVFUYqBLRERERFGJgS4RERERRSUGukREREQUlRjoEhEREVFU+n82O3aoz3Zw9QAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# We can use step=6 to predict hourly weather,\n",
    "# or step=1 to predict weather in 10-min intervals.\n",
    "step = 6\n",
    "\n",
    "splits = dict()\n",
    "_, ax = plt.subplots()\n",
    "for label, df in full_splits.items():\n",
    "    df = df.loc[step-1::step].copy().reset_index(drop=True)\n",
    "    df[DATETIME] = pd.to_datetime(df[DATETIME],\n",
    "                                     format='%d.%m.%Y %H:%M:%S')\n",
    "\n",
    "    splits[label] = df\n",
    "    ax.plot(df[DATETIME], df[T], label=label)\n",
    "\n",
    "ax.set_xlabel(DATETIME)\n",
    "ax.set_ylabel(T)\n",
    "ax.legend();"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Split: train\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Date Time</th>\n",
       "      <th>p (mbar)</th>\n",
       "      <th>T (degC)</th>\n",
       "      <th>Tpot (K)</th>\n",
       "      <th>Tdew (degC)</th>\n",
       "      <th>rh (%)</th>\n",
       "      <th>VPmax (mbar)</th>\n",
       "      <th>VPact (mbar)</th>\n",
       "      <th>VPdef (mbar)</th>\n",
       "      <th>sh (g/kg)</th>\n",
       "      <th>...</th>\n",
       "      <th>Wx</th>\n",
       "      <th>Wy</th>\n",
       "      <th>max Wx</th>\n",
       "      <th>max Wy</th>\n",
       "      <th>sin(hour)</th>\n",
       "      <th>cos(hour)</th>\n",
       "      <th>sin(day)</th>\n",
       "      <th>cos(day)</th>\n",
       "      <th>sin(month)</th>\n",
       "      <th>cos(month)</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>count</th>\n",
       "      <td>17646</td>\n",
       "      <td>17646.000000</td>\n",
       "      <td>17646.000000</td>\n",
       "      <td>17646.000000</td>\n",
       "      <td>17646.000000</td>\n",
       "      <td>17646.000000</td>\n",
       "      <td>17646.000000</td>\n",
       "      <td>17646.000000</td>\n",
       "      <td>17646.000000</td>\n",
       "      <td>17646.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>17646.000000</td>\n",
       "      <td>17646.000000</td>\n",
       "      <td>17646.000000</td>\n",
       "      <td>17646.000000</td>\n",
       "      <td>17646.000000</td>\n",
       "      <td>17646.000000</td>\n",
       "      <td>17646.000000</td>\n",
       "      <td>17646.000000</td>\n",
       "      <td>17646.000000</td>\n",
       "      <td>17646.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mean</th>\n",
       "      <td>2011-07-03 15:30:00</td>\n",
       "      <td>989.763984</td>\n",
       "      <td>8.976777</td>\n",
       "      <td>282.976329</td>\n",
       "      <td>4.374322</td>\n",
       "      <td>75.525140</td>\n",
       "      <td>13.278498</td>\n",
       "      <td>9.261409</td>\n",
       "      <td>4.016952</td>\n",
       "      <td>5.850483</td>\n",
       "      <td>...</td>\n",
       "      <td>-0.704152</td>\n",
       "      <td>-0.496661</td>\n",
       "      <td>-1.144820</td>\n",
       "      <td>-0.890057</td>\n",
       "      <td>0.040806</td>\n",
       "      <td>-0.022546</td>\n",
       "      <td>0.006154</td>\n",
       "      <td>-0.027290</td>\n",
       "      <td>-0.008540</td>\n",
       "      <td>-0.039175</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>min</th>\n",
       "      <td>2010-07-01 01:00:00</td>\n",
       "      <td>918.500000</td>\n",
       "      <td>-20.800000</td>\n",
       "      <td>251.700000</td>\n",
       "      <td>-23.190000</td>\n",
       "      <td>13.060000</td>\n",
       "      <td>1.160000</td>\n",
       "      <td>0.930000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.580000</td>\n",
       "      <td>...</td>\n",
       "      <td>-10.749092</td>\n",
       "      <td>-6.972702</td>\n",
       "      <td>-17.405172</td>\n",
       "      <td>-13.159010</td>\n",
       "      <td>-0.999990</td>\n",
       "      <td>-0.999961</td>\n",
       "      <td>-0.999990</td>\n",
       "      <td>-0.999961</td>\n",
       "      <td>-0.999990</td>\n",
       "      <td>-0.989992</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25%</th>\n",
       "      <td>2010-12-31 20:15:00</td>\n",
       "      <td>984.600000</td>\n",
       "      <td>3.000000</td>\n",
       "      <td>277.050000</td>\n",
       "      <td>-0.220000</td>\n",
       "      <td>64.592500</td>\n",
       "      <td>7.580000</td>\n",
       "      <td>6.010000</td>\n",
       "      <td>0.840000</td>\n",
       "      <td>3.790000</td>\n",
       "      <td>...</td>\n",
       "      <td>-1.504010</td>\n",
       "      <td>-1.514802</td>\n",
       "      <td>-2.507099</td>\n",
       "      <td>-2.592326</td>\n",
       "      <td>-0.699246</td>\n",
       "      <td>-0.653644</td>\n",
       "      <td>-0.750987</td>\n",
       "      <td>-0.748058</td>\n",
       "      <td>-0.544021</td>\n",
       "      <td>-0.839072</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50%</th>\n",
       "      <td>2011-07-03 15:30:00</td>\n",
       "      <td>989.870000</td>\n",
       "      <td>9.090000</td>\n",
       "      <td>283.125000</td>\n",
       "      <td>4.730000</td>\n",
       "      <td>79.000000</td>\n",
       "      <td>11.560000</td>\n",
       "      <td>8.570000</td>\n",
       "      <td>2.130000</td>\n",
       "      <td>5.410000</td>\n",
       "      <td>...</td>\n",
       "      <td>-0.695584</td>\n",
       "      <td>-0.359751</td>\n",
       "      <td>-1.220955</td>\n",
       "      <td>-0.631454</td>\n",
       "      <td>0.070560</td>\n",
       "      <td>-0.070537</td>\n",
       "      <td>-0.008851</td>\n",
       "      <td>0.004426</td>\n",
       "      <td>0.141120</td>\n",
       "      <td>0.004426</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>75%</th>\n",
       "      <td>2012-01-03 10:45:00</td>\n",
       "      <td>995.150000</td>\n",
       "      <td>15.287500</td>\n",
       "      <td>289.400000</td>\n",
       "      <td>9.810000</td>\n",
       "      <td>89.200000</td>\n",
       "      <td>17.397500</td>\n",
       "      <td>12.140000</td>\n",
       "      <td>5.310000</td>\n",
       "      <td>7.680000</td>\n",
       "      <td>...</td>\n",
       "      <td>0.185483</td>\n",
       "      <td>0.415608</td>\n",
       "      <td>0.398064</td>\n",
       "      <td>0.756075</td>\n",
       "      <td>0.791738</td>\n",
       "      <td>0.660317</td>\n",
       "      <td>0.762558</td>\n",
       "      <td>0.646919</td>\n",
       "      <td>0.656987</td>\n",
       "      <td>0.753902</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>max</th>\n",
       "      <td>2012-07-05 06:00:00</td>\n",
       "      <td>1012.740000</td>\n",
       "      <td>34.920000</td>\n",
       "      <td>309.160000</td>\n",
       "      <td>20.030000</td>\n",
       "      <td>100.000000</td>\n",
       "      <td>56.040000</td>\n",
       "      <td>23.470000</td>\n",
       "      <td>39.500000</td>\n",
       "      <td>14.930000</td>\n",
       "      <td>...</td>\n",
       "      <td>6.795160</td>\n",
       "      <td>6.581224</td>\n",
       "      <td>10.039012</td>\n",
       "      <td>10.841980</td>\n",
       "      <td>0.990607</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.990607</td>\n",
       "      <td>0.991203</td>\n",
       "      <td>0.989358</td>\n",
       "      <td>0.960170</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>std</th>\n",
       "      <td>NaN</td>\n",
       "      <td>8.517143</td>\n",
       "      <td>8.800039</td>\n",
       "      <td>8.984467</td>\n",
       "      <td>7.199793</td>\n",
       "      <td>16.976128</td>\n",
       "      <td>7.653803</td>\n",
       "      <td>4.238895</td>\n",
       "      <td>4.829669</td>\n",
       "      <td>2.695774</td>\n",
       "      <td>...</td>\n",
       "      <td>1.961196</td>\n",
       "      <td>1.579727</td>\n",
       "      <td>3.056272</td>\n",
       "      <td>2.673979</td>\n",
       "      <td>0.697443</td>\n",
       "      <td>0.715161</td>\n",
       "      <td>0.714299</td>\n",
       "      <td>0.699322</td>\n",
       "      <td>0.722651</td>\n",
       "      <td>0.690091</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>8 rows × 22 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                 Date Time      p (mbar)      T (degC)      Tpot (K)  \\\n",
       "count                17646  17646.000000  17646.000000  17646.000000   \n",
       "mean   2011-07-03 15:30:00    989.763984      8.976777    282.976329   \n",
       "min    2010-07-01 01:00:00    918.500000    -20.800000    251.700000   \n",
       "25%    2010-12-31 20:15:00    984.600000      3.000000    277.050000   \n",
       "50%    2011-07-03 15:30:00    989.870000      9.090000    283.125000   \n",
       "75%    2012-01-03 10:45:00    995.150000     15.287500    289.400000   \n",
       "max    2012-07-05 06:00:00   1012.740000     34.920000    309.160000   \n",
       "std                    NaN      8.517143      8.800039      8.984467   \n",
       "\n",
       "        Tdew (degC)        rh (%)  VPmax (mbar)  VPact (mbar)  VPdef (mbar)  \\\n",
       "count  17646.000000  17646.000000  17646.000000  17646.000000  17646.000000   \n",
       "mean       4.374322     75.525140     13.278498      9.261409      4.016952   \n",
       "min      -23.190000     13.060000      1.160000      0.930000      0.000000   \n",
       "25%       -0.220000     64.592500      7.580000      6.010000      0.840000   \n",
       "50%        4.730000     79.000000     11.560000      8.570000      2.130000   \n",
       "75%        9.810000     89.200000     17.397500     12.140000      5.310000   \n",
       "max       20.030000    100.000000     56.040000     23.470000     39.500000   \n",
       "std        7.199793     16.976128      7.653803      4.238895      4.829669   \n",
       "\n",
       "          sh (g/kg)  ...            Wx            Wy        max Wx  \\\n",
       "count  17646.000000  ...  17646.000000  17646.000000  17646.000000   \n",
       "mean       5.850483  ...     -0.704152     -0.496661     -1.144820   \n",
       "min        0.580000  ...    -10.749092     -6.972702    -17.405172   \n",
       "25%        3.790000  ...     -1.504010     -1.514802     -2.507099   \n",
       "50%        5.410000  ...     -0.695584     -0.359751     -1.220955   \n",
       "75%        7.680000  ...      0.185483      0.415608      0.398064   \n",
       "max       14.930000  ...      6.795160      6.581224     10.039012   \n",
       "std        2.695774  ...      1.961196      1.579727      3.056272   \n",
       "\n",
       "             max Wy     sin(hour)     cos(hour)      sin(day)      cos(day)  \\\n",
       "count  17646.000000  17646.000000  17646.000000  17646.000000  17646.000000   \n",
       "mean      -0.890057      0.040806     -0.022546      0.006154     -0.027290   \n",
       "min      -13.159010     -0.999990     -0.999961     -0.999990     -0.999961   \n",
       "25%       -2.592326     -0.699246     -0.653644     -0.750987     -0.748058   \n",
       "50%       -0.631454      0.070560     -0.070537     -0.008851      0.004426   \n",
       "75%        0.756075      0.791738      0.660317      0.762558      0.646919   \n",
       "max       10.841980      0.990607      1.000000      0.990607      0.991203   \n",
       "std        2.673979      0.697443      0.715161      0.714299      0.699322   \n",
       "\n",
       "         sin(month)    cos(month)  \n",
       "count  17646.000000  17646.000000  \n",
       "mean      -0.008540     -0.039175  \n",
       "min       -0.999990     -0.989992  \n",
       "25%       -0.544021     -0.839072  \n",
       "50%        0.141120      0.004426  \n",
       "75%        0.656987      0.753902  \n",
       "max        0.989358      0.960170  \n",
       "std        0.722651      0.690091  \n",
       "\n",
       "[8 rows x 22 columns]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Split: val\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Date Time</th>\n",
       "      <th>p (mbar)</th>\n",
       "      <th>T (degC)</th>\n",
       "      <th>Tpot (K)</th>\n",
       "      <th>Tdew (degC)</th>\n",
       "      <th>rh (%)</th>\n",
       "      <th>VPmax (mbar)</th>\n",
       "      <th>VPact (mbar)</th>\n",
       "      <th>VPdef (mbar)</th>\n",
       "      <th>sh (g/kg)</th>\n",
       "      <th>...</th>\n",
       "      <th>Wx</th>\n",
       "      <th>Wy</th>\n",
       "      <th>max Wx</th>\n",
       "      <th>max Wy</th>\n",
       "      <th>sin(hour)</th>\n",
       "      <th>cos(hour)</th>\n",
       "      <th>sin(day)</th>\n",
       "      <th>cos(day)</th>\n",
       "      <th>sin(month)</th>\n",
       "      <th>cos(month)</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>count</th>\n",
       "      <td>5041</td>\n",
       "      <td>5041.000000</td>\n",
       "      <td>5041.000000</td>\n",
       "      <td>5041.000000</td>\n",
       "      <td>5041.000000</td>\n",
       "      <td>5041.000000</td>\n",
       "      <td>5041.000000</td>\n",
       "      <td>5041.000000</td>\n",
       "      <td>5041.000000</td>\n",
       "      <td>5041.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>5041.000000</td>\n",
       "      <td>5041.000000</td>\n",
       "      <td>5041.000000</td>\n",
       "      <td>5041.000000</td>\n",
       "      <td>5041.000000</td>\n",
       "      <td>5041.000000</td>\n",
       "      <td>5041.000000</td>\n",
       "      <td>5041.000000</td>\n",
       "      <td>5041.000000</td>\n",
       "      <td>5041.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mean</th>\n",
       "      <td>2012-10-18 07:00:00</td>\n",
       "      <td>987.771773</td>\n",
       "      <td>9.626106</td>\n",
       "      <td>283.782866</td>\n",
       "      <td>5.403525</td>\n",
       "      <td>77.444892</td>\n",
       "      <td>13.919187</td>\n",
       "      <td>9.797187</td>\n",
       "      <td>4.121887</td>\n",
       "      <td>6.194614</td>\n",
       "      <td>...</td>\n",
       "      <td>-0.933157</td>\n",
       "      <td>-0.525336</td>\n",
       "      <td>-1.495976</td>\n",
       "      <td>-0.903899</td>\n",
       "      <td>0.040947</td>\n",
       "      <td>-0.022384</td>\n",
       "      <td>-0.003075</td>\n",
       "      <td>-0.018518</td>\n",
       "      <td>0.107632</td>\n",
       "      <td>0.023620</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>min</th>\n",
       "      <td>2012-07-05 07:00:00</td>\n",
       "      <td>962.800000</td>\n",
       "      <td>-12.260000</td>\n",
       "      <td>261.580000</td>\n",
       "      <td>-13.770000</td>\n",
       "      <td>25.460000</td>\n",
       "      <td>2.380000</td>\n",
       "      <td>2.100000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1.320000</td>\n",
       "      <td>...</td>\n",
       "      <td>-10.411725</td>\n",
       "      <td>-5.700253</td>\n",
       "      <td>-15.139543</td>\n",
       "      <td>-11.250273</td>\n",
       "      <td>-0.999990</td>\n",
       "      <td>-0.999961</td>\n",
       "      <td>-0.999990</td>\n",
       "      <td>-0.999961</td>\n",
       "      <td>-0.999990</td>\n",
       "      <td>-0.911130</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25%</th>\n",
       "      <td>2012-08-26 19:00:00</td>\n",
       "      <td>983.150000</td>\n",
       "      <td>3.600000</td>\n",
       "      <td>277.810000</td>\n",
       "      <td>1.470000</td>\n",
       "      <td>67.770000</td>\n",
       "      <td>7.910000</td>\n",
       "      <td>6.790000</td>\n",
       "      <td>0.730000</td>\n",
       "      <td>4.300000</td>\n",
       "      <td>...</td>\n",
       "      <td>-1.891983</td>\n",
       "      <td>-1.421573</td>\n",
       "      <td>-3.090043</td>\n",
       "      <td>-2.339394</td>\n",
       "      <td>-0.544021</td>\n",
       "      <td>-0.653644</td>\n",
       "      <td>-0.750987</td>\n",
       "      <td>-0.748058</td>\n",
       "      <td>-0.544021</td>\n",
       "      <td>-0.839072</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50%</th>\n",
       "      <td>2012-10-18 07:00:00</td>\n",
       "      <td>988.130000</td>\n",
       "      <td>9.090000</td>\n",
       "      <td>283.390000</td>\n",
       "      <td>5.850000</td>\n",
       "      <td>81.000000</td>\n",
       "      <td>11.560000</td>\n",
       "      <td>9.260000</td>\n",
       "      <td>1.980000</td>\n",
       "      <td>5.840000</td>\n",
       "      <td>...</td>\n",
       "      <td>-0.783433</td>\n",
       "      <td>-0.385699</td>\n",
       "      <td>-1.361482</td>\n",
       "      <td>-0.656428</td>\n",
       "      <td>0.141120</td>\n",
       "      <td>0.004426</td>\n",
       "      <td>-0.008851</td>\n",
       "      <td>0.004426</td>\n",
       "      <td>0.412118</td>\n",
       "      <td>0.004426</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>75%</th>\n",
       "      <td>2012-12-09 19:00:00</td>\n",
       "      <td>992.690000</td>\n",
       "      <td>16.200000</td>\n",
       "      <td>290.190000</td>\n",
       "      <td>10.300000</td>\n",
       "      <td>90.000000</td>\n",
       "      <td>18.440000</td>\n",
       "      <td>12.540000</td>\n",
       "      <td>5.460000</td>\n",
       "      <td>7.920000</td>\n",
       "      <td>...</td>\n",
       "      <td>-0.004677</td>\n",
       "      <td>0.326410</td>\n",
       "      <td>-0.008587</td>\n",
       "      <td>0.598604</td>\n",
       "      <td>0.656987</td>\n",
       "      <td>0.753902</td>\n",
       "      <td>0.762558</td>\n",
       "      <td>0.660317</td>\n",
       "      <td>0.841471</td>\n",
       "      <td>0.753902</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>max</th>\n",
       "      <td>2013-01-31 07:00:00</td>\n",
       "      <td>1006.780000</td>\n",
       "      <td>35.480000</td>\n",
       "      <td>309.460000</td>\n",
       "      <td>20.130000</td>\n",
       "      <td>100.000000</td>\n",
       "      <td>57.800000</td>\n",
       "      <td>23.610000</td>\n",
       "      <td>41.710000</td>\n",
       "      <td>14.960000</td>\n",
       "      <td>...</td>\n",
       "      <td>6.796456</td>\n",
       "      <td>4.391918</td>\n",
       "      <td>9.293322</td>\n",
       "      <td>7.049285</td>\n",
       "      <td>0.990607</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.990607</td>\n",
       "      <td>0.991203</td>\n",
       "      <td>0.989358</td>\n",
       "      <td>0.843854</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>std</th>\n",
       "      <td>NaN</td>\n",
       "      <td>7.203462</td>\n",
       "      <td>8.809508</td>\n",
       "      <td>8.769159</td>\n",
       "      <td>6.608703</td>\n",
       "      <td>15.823419</td>\n",
       "      <td>8.336765</td>\n",
       "      <td>4.177278</td>\n",
       "      <td>5.307041</td>\n",
       "      <td>2.649954</td>\n",
       "      <td>...</td>\n",
       "      <td>1.945580</td>\n",
       "      <td>1.428832</td>\n",
       "      <td>2.994923</td>\n",
       "      <td>2.377958</td>\n",
       "      <td>0.697468</td>\n",
       "      <td>0.715233</td>\n",
       "      <td>0.714039</td>\n",
       "      <td>0.699996</td>\n",
       "      <td>0.737149</td>\n",
       "      <td>0.666832</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>8 rows × 22 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                 Date Time     p (mbar)     T (degC)     Tpot (K)  \\\n",
       "count                 5041  5041.000000  5041.000000  5041.000000   \n",
       "mean   2012-10-18 07:00:00   987.771773     9.626106   283.782866   \n",
       "min    2012-07-05 07:00:00   962.800000   -12.260000   261.580000   \n",
       "25%    2012-08-26 19:00:00   983.150000     3.600000   277.810000   \n",
       "50%    2012-10-18 07:00:00   988.130000     9.090000   283.390000   \n",
       "75%    2012-12-09 19:00:00   992.690000    16.200000   290.190000   \n",
       "max    2013-01-31 07:00:00  1006.780000    35.480000   309.460000   \n",
       "std                    NaN     7.203462     8.809508     8.769159   \n",
       "\n",
       "       Tdew (degC)       rh (%)  VPmax (mbar)  VPact (mbar)  VPdef (mbar)  \\\n",
       "count  5041.000000  5041.000000   5041.000000   5041.000000   5041.000000   \n",
       "mean      5.403525    77.444892     13.919187      9.797187      4.121887   \n",
       "min     -13.770000    25.460000      2.380000      2.100000      0.000000   \n",
       "25%       1.470000    67.770000      7.910000      6.790000      0.730000   \n",
       "50%       5.850000    81.000000     11.560000      9.260000      1.980000   \n",
       "75%      10.300000    90.000000     18.440000     12.540000      5.460000   \n",
       "max      20.130000   100.000000     57.800000     23.610000     41.710000   \n",
       "std       6.608703    15.823419      8.336765      4.177278      5.307041   \n",
       "\n",
       "         sh (g/kg)  ...           Wx           Wy       max Wx       max Wy  \\\n",
       "count  5041.000000  ...  5041.000000  5041.000000  5041.000000  5041.000000   \n",
       "mean      6.194614  ...    -0.933157    -0.525336    -1.495976    -0.903899   \n",
       "min       1.320000  ...   -10.411725    -5.700253   -15.139543   -11.250273   \n",
       "25%       4.300000  ...    -1.891983    -1.421573    -3.090043    -2.339394   \n",
       "50%       5.840000  ...    -0.783433    -0.385699    -1.361482    -0.656428   \n",
       "75%       7.920000  ...    -0.004677     0.326410    -0.008587     0.598604   \n",
       "max      14.960000  ...     6.796456     4.391918     9.293322     7.049285   \n",
       "std       2.649954  ...     1.945580     1.428832     2.994923     2.377958   \n",
       "\n",
       "         sin(hour)    cos(hour)     sin(day)     cos(day)   sin(month)  \\\n",
       "count  5041.000000  5041.000000  5041.000000  5041.000000  5041.000000   \n",
       "mean      0.040947    -0.022384    -0.003075    -0.018518     0.107632   \n",
       "min      -0.999990    -0.999961    -0.999990    -0.999961    -0.999990   \n",
       "25%      -0.544021    -0.653644    -0.750987    -0.748058    -0.544021   \n",
       "50%       0.141120     0.004426    -0.008851     0.004426     0.412118   \n",
       "75%       0.656987     0.753902     0.762558     0.660317     0.841471   \n",
       "max       0.990607     1.000000     0.990607     0.991203     0.989358   \n",
       "std       0.697468     0.715233     0.714039     0.699996     0.737149   \n",
       "\n",
       "        cos(month)  \n",
       "count  5041.000000  \n",
       "mean      0.023620  \n",
       "min      -0.911130  \n",
       "25%      -0.839072  \n",
       "50%       0.004426  \n",
       "75%       0.753902  \n",
       "max       0.843854  \n",
       "std       0.666832  \n",
       "\n",
       "[8 rows x 22 columns]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Split: test\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Date Time</th>\n",
       "      <th>p (mbar)</th>\n",
       "      <th>T (degC)</th>\n",
       "      <th>Tpot (K)</th>\n",
       "      <th>Tdew (degC)</th>\n",
       "      <th>rh (%)</th>\n",
       "      <th>VPmax (mbar)</th>\n",
       "      <th>VPact (mbar)</th>\n",
       "      <th>VPdef (mbar)</th>\n",
       "      <th>sh (g/kg)</th>\n",
       "      <th>...</th>\n",
       "      <th>Wx</th>\n",
       "      <th>Wy</th>\n",
       "      <th>max Wx</th>\n",
       "      <th>max Wy</th>\n",
       "      <th>sin(hour)</th>\n",
       "      <th>cos(hour)</th>\n",
       "      <th>sin(day)</th>\n",
       "      <th>cos(day)</th>\n",
       "      <th>sin(month)</th>\n",
       "      <th>cos(month)</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>count</th>\n",
       "      <td>2520</td>\n",
       "      <td>2520.000000</td>\n",
       "      <td>2520.000000</td>\n",
       "      <td>2520.000000</td>\n",
       "      <td>2520.000000</td>\n",
       "      <td>2520.000000</td>\n",
       "      <td>2520.000000</td>\n",
       "      <td>2520.000000</td>\n",
       "      <td>2520.000000</td>\n",
       "      <td>2520.000000</td>\n",
       "      <td>...</td>\n",
       "      <td>2520.000000</td>\n",
       "      <td>2520.000000</td>\n",
       "      <td>2520.000000</td>\n",
       "      <td>2520.000000</td>\n",
       "      <td>2520.000000</td>\n",
       "      <td>2520.000000</td>\n",
       "      <td>2520.000000</td>\n",
       "      <td>2520.000000</td>\n",
       "      <td>2520.000000</td>\n",
       "      <td>2520.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>mean</th>\n",
       "      <td>2013-03-24 20:30:00</td>\n",
       "      <td>987.192250</td>\n",
       "      <td>4.022754</td>\n",
       "      <td>278.208056</td>\n",
       "      <td>0.139214</td>\n",
       "      <td>77.955956</td>\n",
       "      <td>9.219536</td>\n",
       "      <td>6.741492</td>\n",
       "      <td>2.477837</td>\n",
       "      <td>4.259968</td>\n",
       "      <td>...</td>\n",
       "      <td>0.281682</td>\n",
       "      <td>0.364608</td>\n",
       "      <td>0.366877</td>\n",
       "      <td>0.475304</td>\n",
       "      <td>0.040825</td>\n",
       "      <td>-0.022538</td>\n",
       "      <td>0.034886</td>\n",
       "      <td>-0.024238</td>\n",
       "      <td>-0.067491</td>\n",
       "      <td>-0.545259</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>min</th>\n",
       "      <td>2013-01-31 09:00:00</td>\n",
       "      <td>962.600000</td>\n",
       "      <td>-13.150000</td>\n",
       "      <td>261.390000</td>\n",
       "      <td>-16.170000</td>\n",
       "      <td>27.430000</td>\n",
       "      <td>2.210000</td>\n",
       "      <td>1.720000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1.080000</td>\n",
       "      <td>...</td>\n",
       "      <td>-7.304919</td>\n",
       "      <td>-4.816706</td>\n",
       "      <td>-10.858348</td>\n",
       "      <td>-8.768077</td>\n",
       "      <td>-0.999990</td>\n",
       "      <td>-0.999961</td>\n",
       "      <td>-0.999990</td>\n",
       "      <td>-0.999961</td>\n",
       "      <td>-0.958924</td>\n",
       "      <td>-0.989992</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25%</th>\n",
       "      <td>2013-02-26 14:45:00</td>\n",
       "      <td>981.330000</td>\n",
       "      <td>-1.082500</td>\n",
       "      <td>272.910000</td>\n",
       "      <td>-4.252500</td>\n",
       "      <td>67.397500</td>\n",
       "      <td>5.640000</td>\n",
       "      <td>4.457500</td>\n",
       "      <td>0.540000</td>\n",
       "      <td>2.810000</td>\n",
       "      <td>...</td>\n",
       "      <td>-0.965627</td>\n",
       "      <td>-0.710925</td>\n",
       "      <td>-1.662181</td>\n",
       "      <td>-1.185328</td>\n",
       "      <td>-0.595763</td>\n",
       "      <td>-0.680155</td>\n",
       "      <td>-0.663634</td>\n",
       "      <td>-0.748058</td>\n",
       "      <td>-0.756802</td>\n",
       "      <td>-0.989992</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50%</th>\n",
       "      <td>2013-03-24 20:30:00</td>\n",
       "      <td>987.895000</td>\n",
       "      <td>1.290000</td>\n",
       "      <td>275.930000</td>\n",
       "      <td>-0.670000</td>\n",
       "      <td>82.200000</td>\n",
       "      <td>6.710000</td>\n",
       "      <td>5.820000</td>\n",
       "      <td>1.260000</td>\n",
       "      <td>3.670000</td>\n",
       "      <td>...</td>\n",
       "      <td>0.087716</td>\n",
       "      <td>0.271324</td>\n",
       "      <td>0.178612</td>\n",
       "      <td>0.516446</td>\n",
       "      <td>0.070560</td>\n",
       "      <td>-0.070537</td>\n",
       "      <td>0.141120</td>\n",
       "      <td>0.004426</td>\n",
       "      <td>0.141120</td>\n",
       "      <td>-0.653644</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>75%</th>\n",
       "      <td>2013-04-20 02:15:00</td>\n",
       "      <td>993.292500</td>\n",
       "      <td>9.622500</td>\n",
       "      <td>283.630000</td>\n",
       "      <td>5.362500</td>\n",
       "      <td>90.700000</td>\n",
       "      <td>11.982500</td>\n",
       "      <td>8.952500</td>\n",
       "      <td>3.002500</td>\n",
       "      <td>5.662500</td>\n",
       "      <td>...</td>\n",
       "      <td>1.927461</td>\n",
       "      <td>1.380470</td>\n",
       "      <td>3.018605</td>\n",
       "      <td>2.122767</td>\n",
       "      <td>0.701904</td>\n",
       "      <td>0.683713</td>\n",
       "      <td>0.762558</td>\n",
       "      <td>0.660317</td>\n",
       "      <td>0.909297</td>\n",
       "      <td>-0.416147</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>max</th>\n",
       "      <td>2013-05-16 08:00:00</td>\n",
       "      <td>1004.850000</td>\n",
       "      <td>25.650000</td>\n",
       "      <td>301.060000</td>\n",
       "      <td>15.180000</td>\n",
       "      <td>100.000000</td>\n",
       "      <td>32.980000</td>\n",
       "      <td>17.280000</td>\n",
       "      <td>23.880000</td>\n",
       "      <td>10.960000</td>\n",
       "      <td>...</td>\n",
       "      <td>5.904970</td>\n",
       "      <td>7.430575</td>\n",
       "      <td>8.096236</td>\n",
       "      <td>11.422832</td>\n",
       "      <td>0.990607</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.990607</td>\n",
       "      <td>0.991203</td>\n",
       "      <td>0.909297</td>\n",
       "      <td>0.540302</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>std</th>\n",
       "      <td>NaN</td>\n",
       "      <td>7.876609</td>\n",
       "      <td>7.334021</td>\n",
       "      <td>7.318959</td>\n",
       "      <td>6.180752</td>\n",
       "      <td>16.218276</td>\n",
       "      <td>5.385874</td>\n",
       "      <td>3.081914</td>\n",
       "      <td>3.255233</td>\n",
       "      <td>1.950761</td>\n",
       "      <td>...</td>\n",
       "      <td>2.166432</td>\n",
       "      <td>1.772009</td>\n",
       "      <td>3.340493</td>\n",
       "      <td>2.838680</td>\n",
       "      <td>0.697553</td>\n",
       "      <td>0.715291</td>\n",
       "      <td>0.712168</td>\n",
       "      <td>0.701005</td>\n",
       "      <td>0.724239</td>\n",
       "      <td>0.417004</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>8 rows × 22 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                 Date Time     p (mbar)     T (degC)     Tpot (K)  \\\n",
       "count                 2520  2520.000000  2520.000000  2520.000000   \n",
       "mean   2013-03-24 20:30:00   987.192250     4.022754   278.208056   \n",
       "min    2013-01-31 09:00:00   962.600000   -13.150000   261.390000   \n",
       "25%    2013-02-26 14:45:00   981.330000    -1.082500   272.910000   \n",
       "50%    2013-03-24 20:30:00   987.895000     1.290000   275.930000   \n",
       "75%    2013-04-20 02:15:00   993.292500     9.622500   283.630000   \n",
       "max    2013-05-16 08:00:00  1004.850000    25.650000   301.060000   \n",
       "std                    NaN     7.876609     7.334021     7.318959   \n",
       "\n",
       "       Tdew (degC)       rh (%)  VPmax (mbar)  VPact (mbar)  VPdef (mbar)  \\\n",
       "count  2520.000000  2520.000000   2520.000000   2520.000000   2520.000000   \n",
       "mean      0.139214    77.955956      9.219536      6.741492      2.477837   \n",
       "min     -16.170000    27.430000      2.210000      1.720000      0.000000   \n",
       "25%      -4.252500    67.397500      5.640000      4.457500      0.540000   \n",
       "50%      -0.670000    82.200000      6.710000      5.820000      1.260000   \n",
       "75%       5.362500    90.700000     11.982500      8.952500      3.002500   \n",
       "max      15.180000   100.000000     32.980000     17.280000     23.880000   \n",
       "std       6.180752    16.218276      5.385874      3.081914      3.255233   \n",
       "\n",
       "         sh (g/kg)  ...           Wx           Wy       max Wx       max Wy  \\\n",
       "count  2520.000000  ...  2520.000000  2520.000000  2520.000000  2520.000000   \n",
       "mean      4.259968  ...     0.281682     0.364608     0.366877     0.475304   \n",
       "min       1.080000  ...    -7.304919    -4.816706   -10.858348    -8.768077   \n",
       "25%       2.810000  ...    -0.965627    -0.710925    -1.662181    -1.185328   \n",
       "50%       3.670000  ...     0.087716     0.271324     0.178612     0.516446   \n",
       "75%       5.662500  ...     1.927461     1.380470     3.018605     2.122767   \n",
       "max      10.960000  ...     5.904970     7.430575     8.096236    11.422832   \n",
       "std       1.950761  ...     2.166432     1.772009     3.340493     2.838680   \n",
       "\n",
       "         sin(hour)    cos(hour)     sin(day)     cos(day)   sin(month)  \\\n",
       "count  2520.000000  2520.000000  2520.000000  2520.000000  2520.000000   \n",
       "mean      0.040825    -0.022538     0.034886    -0.024238    -0.067491   \n",
       "min      -0.999990    -0.999961    -0.999990    -0.999961    -0.958924   \n",
       "25%      -0.595763    -0.680155    -0.663634    -0.748058    -0.756802   \n",
       "50%       0.070560    -0.070537     0.141120     0.004426     0.141120   \n",
       "75%       0.701904     0.683713     0.762558     0.660317     0.909297   \n",
       "max       0.990607     1.000000     0.990607     0.991203     0.909297   \n",
       "std       0.697553     0.715291     0.712168     0.701005     0.724239   \n",
       "\n",
       "        cos(month)  \n",
       "count  2520.000000  \n",
       "mean     -0.545259  \n",
       "min      -0.989992  \n",
       "25%      -0.989992  \n",
       "50%      -0.653644  \n",
       "75%      -0.416147  \n",
       "max       0.540302  \n",
       "std       0.417004  \n",
       "\n",
       "[8 rows x 22 columns]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# The data looks reasonable.\n",
    "for label, df in splits.items():\n",
    "    print(f'Split: {label}')\n",
    "    display(df.describe())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Split train:\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Date Time</th>\n",
       "      <th>p (mbar)</th>\n",
       "      <th>T (degC)</th>\n",
       "      <th>Tpot (K)</th>\n",
       "      <th>Tdew (degC)</th>\n",
       "      <th>rh (%)</th>\n",
       "      <th>VPmax (mbar)</th>\n",
       "      <th>VPact (mbar)</th>\n",
       "      <th>VPdef (mbar)</th>\n",
       "      <th>sh (g/kg)</th>\n",
       "      <th>...</th>\n",
       "      <th>Wx</th>\n",
       "      <th>Wy</th>\n",
       "      <th>max Wx</th>\n",
       "      <th>max Wy</th>\n",
       "      <th>sin(hour)</th>\n",
       "      <th>cos(hour)</th>\n",
       "      <th>sin(day)</th>\n",
       "      <th>cos(day)</th>\n",
       "      <th>sin(month)</th>\n",
       "      <th>cos(month)</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>2010-07-01 01:00:00</td>\n",
       "      <td>991.81</td>\n",
       "      <td>17.35</td>\n",
       "      <td>291.19</td>\n",
       "      <td>13.87</td>\n",
       "      <td>80.0</td>\n",
       "      <td>19.84</td>\n",
       "      <td>15.87</td>\n",
       "      <td>3.97</td>\n",
       "      <td>10.02</td>\n",
       "      <td>...</td>\n",
       "      <td>0.284939</td>\n",
       "      <td>0.335276</td>\n",
       "      <td>0.621685</td>\n",
       "      <td>0.731511</td>\n",
       "      <td>0.841471</td>\n",
       "      <td>0.540302</td>\n",
       "      <td>0.841471</td>\n",
       "      <td>0.540302</td>\n",
       "      <td>0.656987</td>\n",
       "      <td>0.753902</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2010-07-01 02:00:00</td>\n",
       "      <td>991.69</td>\n",
       "      <td>16.39</td>\n",
       "      <td>290.24</td>\n",
       "      <td>13.57</td>\n",
       "      <td>83.4</td>\n",
       "      <td>18.67</td>\n",
       "      <td>15.57</td>\n",
       "      <td>3.10</td>\n",
       "      <td>9.82</td>\n",
       "      <td>...</td>\n",
       "      <td>-0.696884</td>\n",
       "      <td>-0.450835</td>\n",
       "      <td>-0.940374</td>\n",
       "      <td>-0.608355</td>\n",
       "      <td>0.909297</td>\n",
       "      <td>-0.416147</td>\n",
       "      <td>0.841471</td>\n",
       "      <td>0.540302</td>\n",
       "      <td>0.656987</td>\n",
       "      <td>0.753902</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2010-07-01 03:00:00</td>\n",
       "      <td>991.32</td>\n",
       "      <td>15.59</td>\n",
       "      <td>289.47</td>\n",
       "      <td>13.17</td>\n",
       "      <td>85.5</td>\n",
       "      <td>17.74</td>\n",
       "      <td>15.17</td>\n",
       "      <td>2.57</td>\n",
       "      <td>9.57</td>\n",
       "      <td>...</td>\n",
       "      <td>-1.238217</td>\n",
       "      <td>-0.609278</td>\n",
       "      <td>-1.973968</td>\n",
       "      <td>-0.971313</td>\n",
       "      <td>0.141120</td>\n",
       "      <td>-0.989992</td>\n",
       "      <td>0.841471</td>\n",
       "      <td>0.540302</td>\n",
       "      <td>0.656987</td>\n",
       "      <td>0.753902</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>2010-07-01 04:00:00</td>\n",
       "      <td>990.97</td>\n",
       "      <td>15.07</td>\n",
       "      <td>288.98</td>\n",
       "      <td>13.05</td>\n",
       "      <td>87.7</td>\n",
       "      <td>17.16</td>\n",
       "      <td>15.05</td>\n",
       "      <td>2.11</td>\n",
       "      <td>9.50</td>\n",
       "      <td>...</td>\n",
       "      <td>-0.929489</td>\n",
       "      <td>0.030834</td>\n",
       "      <td>-1.519164</td>\n",
       "      <td>0.050396</td>\n",
       "      <td>-0.756802</td>\n",
       "      <td>-0.653644</td>\n",
       "      <td>0.841471</td>\n",
       "      <td>0.540302</td>\n",
       "      <td>0.656987</td>\n",
       "      <td>0.753902</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>2010-07-01 05:00:00</td>\n",
       "      <td>991.09</td>\n",
       "      <td>14.82</td>\n",
       "      <td>288.72</td>\n",
       "      <td>13.03</td>\n",
       "      <td>89.0</td>\n",
       "      <td>16.88</td>\n",
       "      <td>15.02</td>\n",
       "      <td>1.86</td>\n",
       "      <td>9.48</td>\n",
       "      <td>...</td>\n",
       "      <td>-0.381048</td>\n",
       "      <td>0.083082</td>\n",
       "      <td>-0.664391</td>\n",
       "      <td>0.144861</td>\n",
       "      <td>-0.958924</td>\n",
       "      <td>0.283662</td>\n",
       "      <td>0.841471</td>\n",
       "      <td>0.540302</td>\n",
       "      <td>0.656987</td>\n",
       "      <td>0.753902</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 22 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "            Date Time  p (mbar)  T (degC)  Tpot (K)  Tdew (degC)  rh (%)  \\\n",
       "0 2010-07-01 01:00:00    991.81     17.35    291.19        13.87    80.0   \n",
       "1 2010-07-01 02:00:00    991.69     16.39    290.24        13.57    83.4   \n",
       "2 2010-07-01 03:00:00    991.32     15.59    289.47        13.17    85.5   \n",
       "3 2010-07-01 04:00:00    990.97     15.07    288.98        13.05    87.7   \n",
       "4 2010-07-01 05:00:00    991.09     14.82    288.72        13.03    89.0   \n",
       "\n",
       "   VPmax (mbar)  VPact (mbar)  VPdef (mbar)  sh (g/kg)  ...        Wx  \\\n",
       "0         19.84         15.87          3.97      10.02  ...  0.284939   \n",
       "1         18.67         15.57          3.10       9.82  ... -0.696884   \n",
       "2         17.74         15.17          2.57       9.57  ... -1.238217   \n",
       "3         17.16         15.05          2.11       9.50  ... -0.929489   \n",
       "4         16.88         15.02          1.86       9.48  ... -0.381048   \n",
       "\n",
       "         Wy    max Wx    max Wy  sin(hour)  cos(hour)  sin(day)  cos(day)  \\\n",
       "0  0.335276  0.621685  0.731511   0.841471   0.540302  0.841471  0.540302   \n",
       "1 -0.450835 -0.940374 -0.608355   0.909297  -0.416147  0.841471  0.540302   \n",
       "2 -0.609278 -1.973968 -0.971313   0.141120  -0.989992  0.841471  0.540302   \n",
       "3  0.030834 -1.519164  0.050396  -0.756802  -0.653644  0.841471  0.540302   \n",
       "4  0.083082 -0.664391  0.144861  -0.958924   0.283662  0.841471  0.540302   \n",
       "\n",
       "   sin(month)  cos(month)  \n",
       "0    0.656987    0.753902  \n",
       "1    0.656987    0.753902  \n",
       "2    0.656987    0.753902  \n",
       "3    0.656987    0.753902  \n",
       "4    0.656987    0.753902  \n",
       "\n",
       "[5 rows x 22 columns]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Split val:\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Date Time</th>\n",
       "      <th>p (mbar)</th>\n",
       "      <th>T (degC)</th>\n",
       "      <th>Tpot (K)</th>\n",
       "      <th>Tdew (degC)</th>\n",
       "      <th>rh (%)</th>\n",
       "      <th>VPmax (mbar)</th>\n",
       "      <th>VPact (mbar)</th>\n",
       "      <th>VPdef (mbar)</th>\n",
       "      <th>sh (g/kg)</th>\n",
       "      <th>...</th>\n",
       "      <th>Wx</th>\n",
       "      <th>Wy</th>\n",
       "      <th>max Wx</th>\n",
       "      <th>max Wy</th>\n",
       "      <th>sin(hour)</th>\n",
       "      <th>cos(hour)</th>\n",
       "      <th>sin(day)</th>\n",
       "      <th>cos(day)</th>\n",
       "      <th>sin(month)</th>\n",
       "      <th>cos(month)</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>2012-07-05 07:00:00</td>\n",
       "      <td>986.53</td>\n",
       "      <td>17.87</td>\n",
       "      <td>292.16</td>\n",
       "      <td>16.47</td>\n",
       "      <td>91.5</td>\n",
       "      <td>20.50</td>\n",
       "      <td>18.76</td>\n",
       "      <td>1.74</td>\n",
       "      <td>11.91</td>\n",
       "      <td>...</td>\n",
       "      <td>-0.661501</td>\n",
       "      <td>-0.257908</td>\n",
       "      <td>-1.155297</td>\n",
       "      <td>-0.450432</td>\n",
       "      <td>0.656987</td>\n",
       "      <td>0.753902</td>\n",
       "      <td>-0.958924</td>\n",
       "      <td>0.283662</td>\n",
       "      <td>0.656987</td>\n",
       "      <td>0.753902</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2012-07-05 08:00:00</td>\n",
       "      <td>986.07</td>\n",
       "      <td>19.15</td>\n",
       "      <td>293.49</td>\n",
       "      <td>16.59</td>\n",
       "      <td>85.1</td>\n",
       "      <td>22.22</td>\n",
       "      <td>18.91</td>\n",
       "      <td>3.31</td>\n",
       "      <td>12.01</td>\n",
       "      <td>...</td>\n",
       "      <td>2.169812</td>\n",
       "      <td>0.762835</td>\n",
       "      <td>3.584907</td>\n",
       "      <td>1.260335</td>\n",
       "      <td>0.989358</td>\n",
       "      <td>-0.145500</td>\n",
       "      <td>-0.958924</td>\n",
       "      <td>0.283662</td>\n",
       "      <td>0.656987</td>\n",
       "      <td>0.753902</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2012-07-05 09:00:00</td>\n",
       "      <td>986.06</td>\n",
       "      <td>20.43</td>\n",
       "      <td>294.77</td>\n",
       "      <td>17.12</td>\n",
       "      <td>81.3</td>\n",
       "      <td>24.05</td>\n",
       "      <td>19.55</td>\n",
       "      <td>4.50</td>\n",
       "      <td>12.43</td>\n",
       "      <td>...</td>\n",
       "      <td>1.585392</td>\n",
       "      <td>0.555818</td>\n",
       "      <td>2.472456</td>\n",
       "      <td>0.866811</td>\n",
       "      <td>0.412118</td>\n",
       "      <td>-0.911130</td>\n",
       "      <td>-0.958924</td>\n",
       "      <td>0.283662</td>\n",
       "      <td>0.656987</td>\n",
       "      <td>0.753902</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>2012-07-05 10:00:00</td>\n",
       "      <td>986.33</td>\n",
       "      <td>21.10</td>\n",
       "      <td>295.42</td>\n",
       "      <td>17.77</td>\n",
       "      <td>81.3</td>\n",
       "      <td>25.06</td>\n",
       "      <td>20.38</td>\n",
       "      <td>4.69</td>\n",
       "      <td>12.95</td>\n",
       "      <td>...</td>\n",
       "      <td>0.771091</td>\n",
       "      <td>0.604830</td>\n",
       "      <td>1.164504</td>\n",
       "      <td>0.913416</td>\n",
       "      <td>-0.544021</td>\n",
       "      <td>-0.839072</td>\n",
       "      <td>-0.958924</td>\n",
       "      <td>0.283662</td>\n",
       "      <td>0.656987</td>\n",
       "      <td>0.753902</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>2012-07-05 11:00:00</td>\n",
       "      <td>986.34</td>\n",
       "      <td>21.98</td>\n",
       "      <td>296.30</td>\n",
       "      <td>18.05</td>\n",
       "      <td>78.4</td>\n",
       "      <td>26.45</td>\n",
       "      <td>20.74</td>\n",
       "      <td>5.71</td>\n",
       "      <td>13.18</td>\n",
       "      <td>...</td>\n",
       "      <td>1.895195</td>\n",
       "      <td>0.537715</td>\n",
       "      <td>3.020767</td>\n",
       "      <td>0.857069</td>\n",
       "      <td>-0.999990</td>\n",
       "      <td>0.004426</td>\n",
       "      <td>-0.958924</td>\n",
       "      <td>0.283662</td>\n",
       "      <td>0.656987</td>\n",
       "      <td>0.753902</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 22 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "            Date Time  p (mbar)  T (degC)  Tpot (K)  Tdew (degC)  rh (%)  \\\n",
       "0 2012-07-05 07:00:00    986.53     17.87    292.16        16.47    91.5   \n",
       "1 2012-07-05 08:00:00    986.07     19.15    293.49        16.59    85.1   \n",
       "2 2012-07-05 09:00:00    986.06     20.43    294.77        17.12    81.3   \n",
       "3 2012-07-05 10:00:00    986.33     21.10    295.42        17.77    81.3   \n",
       "4 2012-07-05 11:00:00    986.34     21.98    296.30        18.05    78.4   \n",
       "\n",
       "   VPmax (mbar)  VPact (mbar)  VPdef (mbar)  sh (g/kg)  ...        Wx  \\\n",
       "0         20.50         18.76          1.74      11.91  ... -0.661501   \n",
       "1         22.22         18.91          3.31      12.01  ...  2.169812   \n",
       "2         24.05         19.55          4.50      12.43  ...  1.585392   \n",
       "3         25.06         20.38          4.69      12.95  ...  0.771091   \n",
       "4         26.45         20.74          5.71      13.18  ...  1.895195   \n",
       "\n",
       "         Wy    max Wx    max Wy  sin(hour)  cos(hour)  sin(day)  cos(day)  \\\n",
       "0 -0.257908 -1.155297 -0.450432   0.656987   0.753902 -0.958924  0.283662   \n",
       "1  0.762835  3.584907  1.260335   0.989358  -0.145500 -0.958924  0.283662   \n",
       "2  0.555818  2.472456  0.866811   0.412118  -0.911130 -0.958924  0.283662   \n",
       "3  0.604830  1.164504  0.913416  -0.544021  -0.839072 -0.958924  0.283662   \n",
       "4  0.537715  3.020767  0.857069  -0.999990   0.004426 -0.958924  0.283662   \n",
       "\n",
       "   sin(month)  cos(month)  \n",
       "0    0.656987    0.753902  \n",
       "1    0.656987    0.753902  \n",
       "2    0.656987    0.753902  \n",
       "3    0.656987    0.753902  \n",
       "4    0.656987    0.753902  \n",
       "\n",
       "[5 rows x 22 columns]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Split test:\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Date Time</th>\n",
       "      <th>p (mbar)</th>\n",
       "      <th>T (degC)</th>\n",
       "      <th>Tpot (K)</th>\n",
       "      <th>Tdew (degC)</th>\n",
       "      <th>rh (%)</th>\n",
       "      <th>VPmax (mbar)</th>\n",
       "      <th>VPact (mbar)</th>\n",
       "      <th>VPdef (mbar)</th>\n",
       "      <th>sh (g/kg)</th>\n",
       "      <th>...</th>\n",
       "      <th>Wx</th>\n",
       "      <th>Wy</th>\n",
       "      <th>max Wx</th>\n",
       "      <th>max Wy</th>\n",
       "      <th>sin(hour)</th>\n",
       "      <th>cos(hour)</th>\n",
       "      <th>sin(day)</th>\n",
       "      <th>cos(day)</th>\n",
       "      <th>sin(month)</th>\n",
       "      <th>cos(month)</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>2013-01-31 09:00:00</td>\n",
       "      <td>987.08</td>\n",
       "      <td>6.35</td>\n",
       "      <td>280.56</td>\n",
       "      <td>0.21</td>\n",
       "      <td>64.65</td>\n",
       "      <td>9.59</td>\n",
       "      <td>6.20</td>\n",
       "      <td>3.39</td>\n",
       "      <td>3.92</td>\n",
       "      <td>...</td>\n",
       "      <td>-2.404042</td>\n",
       "      <td>-3.308880</td>\n",
       "      <td>-4.108619</td>\n",
       "      <td>-5.655029</td>\n",
       "      <td>0.412118</td>\n",
       "      <td>-0.911130</td>\n",
       "      <td>-0.404038</td>\n",
       "      <td>0.914742</td>\n",
       "      <td>0.841471</td>\n",
       "      <td>0.540302</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2013-01-31 10:00:00</td>\n",
       "      <td>987.23</td>\n",
       "      <td>6.93</td>\n",
       "      <td>281.12</td>\n",
       "      <td>0.29</td>\n",
       "      <td>62.52</td>\n",
       "      <td>9.98</td>\n",
       "      <td>6.24</td>\n",
       "      <td>3.74</td>\n",
       "      <td>3.94</td>\n",
       "      <td>...</td>\n",
       "      <td>-3.461041</td>\n",
       "      <td>-2.414456</td>\n",
       "      <td>-6.175744</td>\n",
       "      <td>-4.308258</td>\n",
       "      <td>-0.544021</td>\n",
       "      <td>-0.839072</td>\n",
       "      <td>-0.404038</td>\n",
       "      <td>0.914742</td>\n",
       "      <td>0.841471</td>\n",
       "      <td>0.540302</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2013-01-31 11:00:00</td>\n",
       "      <td>986.67</td>\n",
       "      <td>7.36</td>\n",
       "      <td>281.60</td>\n",
       "      <td>0.46</td>\n",
       "      <td>61.45</td>\n",
       "      <td>10.28</td>\n",
       "      <td>6.32</td>\n",
       "      <td>3.96</td>\n",
       "      <td>3.99</td>\n",
       "      <td>...</td>\n",
       "      <td>-5.745275</td>\n",
       "      <td>-3.562221</td>\n",
       "      <td>-8.371443</td>\n",
       "      <td>-5.190515</td>\n",
       "      <td>-0.999990</td>\n",
       "      <td>0.004426</td>\n",
       "      <td>-0.404038</td>\n",
       "      <td>0.914742</td>\n",
       "      <td>0.841471</td>\n",
       "      <td>0.540302</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>2013-01-31 12:00:00</td>\n",
       "      <td>984.88</td>\n",
       "      <td>7.74</td>\n",
       "      <td>282.13</td>\n",
       "      <td>0.30</td>\n",
       "      <td>59.17</td>\n",
       "      <td>10.55</td>\n",
       "      <td>6.24</td>\n",
       "      <td>4.31</td>\n",
       "      <td>3.95</td>\n",
       "      <td>...</td>\n",
       "      <td>-4.186592</td>\n",
       "      <td>-2.069142</td>\n",
       "      <td>-6.427808</td>\n",
       "      <td>-3.176820</td>\n",
       "      <td>-0.536573</td>\n",
       "      <td>0.843854</td>\n",
       "      <td>-0.404038</td>\n",
       "      <td>0.914742</td>\n",
       "      <td>0.841471</td>\n",
       "      <td>0.540302</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>2013-01-31 13:00:00</td>\n",
       "      <td>984.42</td>\n",
       "      <td>7.86</td>\n",
       "      <td>282.28</td>\n",
       "      <td>0.48</td>\n",
       "      <td>59.46</td>\n",
       "      <td>10.64</td>\n",
       "      <td>6.32</td>\n",
       "      <td>4.31</td>\n",
       "      <td>4.01</td>\n",
       "      <td>...</td>\n",
       "      <td>-2.618246</td>\n",
       "      <td>-2.441554</td>\n",
       "      <td>-6.223820</td>\n",
       "      <td>-5.803806</td>\n",
       "      <td>0.420167</td>\n",
       "      <td>0.907447</td>\n",
       "      <td>-0.404038</td>\n",
       "      <td>0.914742</td>\n",
       "      <td>0.841471</td>\n",
       "      <td>0.540302</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 22 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "            Date Time  p (mbar)  T (degC)  Tpot (K)  Tdew (degC)  rh (%)  \\\n",
       "0 2013-01-31 09:00:00    987.08      6.35    280.56         0.21   64.65   \n",
       "1 2013-01-31 10:00:00    987.23      6.93    281.12         0.29   62.52   \n",
       "2 2013-01-31 11:00:00    986.67      7.36    281.60         0.46   61.45   \n",
       "3 2013-01-31 12:00:00    984.88      7.74    282.13         0.30   59.17   \n",
       "4 2013-01-31 13:00:00    984.42      7.86    282.28         0.48   59.46   \n",
       "\n",
       "   VPmax (mbar)  VPact (mbar)  VPdef (mbar)  sh (g/kg)  ...        Wx  \\\n",
       "0          9.59          6.20          3.39       3.92  ... -2.404042   \n",
       "1          9.98          6.24          3.74       3.94  ... -3.461041   \n",
       "2         10.28          6.32          3.96       3.99  ... -5.745275   \n",
       "3         10.55          6.24          4.31       3.95  ... -4.186592   \n",
       "4         10.64          6.32          4.31       4.01  ... -2.618246   \n",
       "\n",
       "         Wy    max Wx    max Wy  sin(hour)  cos(hour)  sin(day)  cos(day)  \\\n",
       "0 -3.308880 -4.108619 -5.655029   0.412118  -0.911130 -0.404038  0.914742   \n",
       "1 -2.414456 -6.175744 -4.308258  -0.544021  -0.839072 -0.404038  0.914742   \n",
       "2 -3.562221 -8.371443 -5.190515  -0.999990   0.004426 -0.404038  0.914742   \n",
       "3 -2.069142 -6.427808 -3.176820  -0.536573   0.843854 -0.404038  0.914742   \n",
       "4 -2.441554 -6.223820 -5.803806   0.420167   0.907447 -0.404038  0.914742   \n",
       "\n",
       "   sin(month)  cos(month)  \n",
       "0    0.841471    0.540302  \n",
       "1    0.841471    0.540302  \n",
       "2    0.841471    0.540302  \n",
       "3    0.841471    0.540302  \n",
       "4    0.841471    0.540302  \n",
       "\n",
       "[5 rows x 22 columns]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Save the data.\n",
    "for label, split in splits.items():\n",
    "    print(f\"Split {label}:\")\n",
    "    display(split.head())\n",
    "    split.to_csv(f\"{data_folder}/{label}.csv\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "ml",
   "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.12.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
