{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "4af3a624-46c6-475a-8ad1-0d93735eecca",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import torch"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "76dd99b5-ebd9-413c-8777-2e8a1e57e920",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "from scipy.stats import pearsonr\n",
    "from scipy.optimize import minimize"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fc227fab-c8d1-4679-a133-399e5640c0de",
   "metadata": {},
   "source": [
    "### ETTh1 modified \n",
    "1. Load ETTh1 with 7 channels.\n",
    "2. Sample only 3 channels.\n",
    "3. Change the correlations among these three channels with a certain patten. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "e68afdc4-6e87-48d6-8cc4-c52e1e5c7730",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "seed = 2024\n",
    "np.random.seed(seed)\n",
    "ETTh1_df = pd.read_csv('./dataset/ETTh1.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "a922228b-8c39-4a1b-aab0-682f18abfeab",
   "metadata": {
    "tags": []
   },
   "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</th>\n",
       "      <th>HUFL</th>\n",
       "      <th>HULL</th>\n",
       "      <th>MUFL</th>\n",
       "      <th>MULL</th>\n",
       "      <th>LUFL</th>\n",
       "      <th>LULL</th>\n",
       "      <th>OT</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>2016-07-01 00:00:00</td>\n",
       "      <td>5.827</td>\n",
       "      <td>2.009</td>\n",
       "      <td>1.599</td>\n",
       "      <td>0.462</td>\n",
       "      <td>4.203</td>\n",
       "      <td>1.340</td>\n",
       "      <td>30.531000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2016-07-01 01:00:00</td>\n",
       "      <td>5.693</td>\n",
       "      <td>2.076</td>\n",
       "      <td>1.492</td>\n",
       "      <td>0.426</td>\n",
       "      <td>4.142</td>\n",
       "      <td>1.371</td>\n",
       "      <td>27.787001</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>2016-07-01 02:00:00</td>\n",
       "      <td>5.157</td>\n",
       "      <td>1.741</td>\n",
       "      <td>1.279</td>\n",
       "      <td>0.355</td>\n",
       "      <td>3.777</td>\n",
       "      <td>1.218</td>\n",
       "      <td>27.787001</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>2016-07-01 03:00:00</td>\n",
       "      <td>5.090</td>\n",
       "      <td>1.942</td>\n",
       "      <td>1.279</td>\n",
       "      <td>0.391</td>\n",
       "      <td>3.807</td>\n",
       "      <td>1.279</td>\n",
       "      <td>25.044001</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>2016-07-01 04:00:00</td>\n",
       "      <td>5.358</td>\n",
       "      <td>1.942</td>\n",
       "      <td>1.492</td>\n",
       "      <td>0.462</td>\n",
       "      <td>3.868</td>\n",
       "      <td>1.279</td>\n",
       "      <td>21.948000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17415</th>\n",
       "      <td>2018-06-26 15:00:00</td>\n",
       "      <td>-1.674</td>\n",
       "      <td>3.550</td>\n",
       "      <td>-5.615</td>\n",
       "      <td>2.132</td>\n",
       "      <td>3.472</td>\n",
       "      <td>1.523</td>\n",
       "      <td>10.904000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17416</th>\n",
       "      <td>2018-06-26 16:00:00</td>\n",
       "      <td>-5.492</td>\n",
       "      <td>4.287</td>\n",
       "      <td>-9.132</td>\n",
       "      <td>2.274</td>\n",
       "      <td>3.533</td>\n",
       "      <td>1.675</td>\n",
       "      <td>11.044000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17417</th>\n",
       "      <td>2018-06-26 17:00:00</td>\n",
       "      <td>2.813</td>\n",
       "      <td>3.818</td>\n",
       "      <td>-0.817</td>\n",
       "      <td>2.097</td>\n",
       "      <td>3.716</td>\n",
       "      <td>1.523</td>\n",
       "      <td>10.271000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17418</th>\n",
       "      <td>2018-06-26 18:00:00</td>\n",
       "      <td>9.243</td>\n",
       "      <td>3.818</td>\n",
       "      <td>5.472</td>\n",
       "      <td>2.097</td>\n",
       "      <td>3.655</td>\n",
       "      <td>1.432</td>\n",
       "      <td>9.778000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17419</th>\n",
       "      <td>2018-06-26 19:00:00</td>\n",
       "      <td>10.114</td>\n",
       "      <td>3.550</td>\n",
       "      <td>6.183</td>\n",
       "      <td>1.564</td>\n",
       "      <td>3.716</td>\n",
       "      <td>1.462</td>\n",
       "      <td>9.567000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>17420 rows × 8 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                      date    HUFL   HULL   MUFL   MULL   LUFL   LULL  \\\n",
       "0      2016-07-01 00:00:00   5.827  2.009  1.599  0.462  4.203  1.340   \n",
       "1      2016-07-01 01:00:00   5.693  2.076  1.492  0.426  4.142  1.371   \n",
       "2      2016-07-01 02:00:00   5.157  1.741  1.279  0.355  3.777  1.218   \n",
       "3      2016-07-01 03:00:00   5.090  1.942  1.279  0.391  3.807  1.279   \n",
       "4      2016-07-01 04:00:00   5.358  1.942  1.492  0.462  3.868  1.279   \n",
       "...                    ...     ...    ...    ...    ...    ...    ...   \n",
       "17415  2018-06-26 15:00:00  -1.674  3.550 -5.615  2.132  3.472  1.523   \n",
       "17416  2018-06-26 16:00:00  -5.492  4.287 -9.132  2.274  3.533  1.675   \n",
       "17417  2018-06-26 17:00:00   2.813  3.818 -0.817  2.097  3.716  1.523   \n",
       "17418  2018-06-26 18:00:00   9.243  3.818  5.472  2.097  3.655  1.432   \n",
       "17419  2018-06-26 19:00:00  10.114  3.550  6.183  1.564  3.716  1.462   \n",
       "\n",
       "              OT  \n",
       "0      30.531000  \n",
       "1      27.787001  \n",
       "2      27.787001  \n",
       "3      25.044001  \n",
       "4      21.948000  \n",
       "...          ...  \n",
       "17415  10.904000  \n",
       "17416  11.044000  \n",
       "17417  10.271000  \n",
       "17418   9.778000  \n",
       "17419   9.567000  \n",
       "\n",
       "[17420 rows x 8 columns]"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ETTh1_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "d4c9df42-aa84-4d44-85f1-f83561938766",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "cols = ETTh1_df.columns[1:]\n",
    "data = ETTh1_df[cols]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "3ae1e804-d5fc-4100-908d-97b13fadf256",
   "metadata": {
    "tags": []
   },
   "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>HUFL</th>\n",
       "      <th>HULL</th>\n",
       "      <th>MUFL</th>\n",
       "      <th>MULL</th>\n",
       "      <th>LUFL</th>\n",
       "      <th>LULL</th>\n",
       "      <th>OT</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>HUFL</th>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.114672</td>\n",
       "      <td>0.987355</td>\n",
       "      <td>0.066002</td>\n",
       "      <td>0.291418</td>\n",
       "      <td>0.023606</td>\n",
       "      <td>0.059916</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>HULL</th>\n",
       "      <td>0.114672</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.068817</td>\n",
       "      <td>0.930491</td>\n",
       "      <td>0.259487</td>\n",
       "      <td>0.377641</td>\n",
       "      <td>0.224354</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>MUFL</th>\n",
       "      <td>0.987355</td>\n",
       "      <td>0.068817</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.046266</td>\n",
       "      <td>0.177491</td>\n",
       "      <td>-0.046519</td>\n",
       "      <td>0.050854</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>MULL</th>\n",
       "      <td>0.066002</td>\n",
       "      <td>0.930491</td>\n",
       "      <td>0.046266</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.128607</td>\n",
       "      <td>0.069419</td>\n",
       "      <td>0.220004</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LUFL</th>\n",
       "      <td>0.291418</td>\n",
       "      <td>0.259487</td>\n",
       "      <td>0.177491</td>\n",
       "      <td>0.128607</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.334563</td>\n",
       "      <td>0.118836</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>LULL</th>\n",
       "      <td>0.023606</td>\n",
       "      <td>0.377641</td>\n",
       "      <td>-0.046519</td>\n",
       "      <td>0.069419</td>\n",
       "      <td>0.334563</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.067455</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>OT</th>\n",
       "      <td>0.059916</td>\n",
       "      <td>0.224354</td>\n",
       "      <td>0.050854</td>\n",
       "      <td>0.220004</td>\n",
       "      <td>0.118836</td>\n",
       "      <td>0.067455</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "          HUFL      HULL      MUFL      MULL      LUFL      LULL        OT\n",
       "HUFL  1.000000  0.114672  0.987355  0.066002  0.291418  0.023606  0.059916\n",
       "HULL  0.114672  1.000000  0.068817  0.930491  0.259487  0.377641  0.224354\n",
       "MUFL  0.987355  0.068817  1.000000  0.046266  0.177491 -0.046519  0.050854\n",
       "MULL  0.066002  0.930491  0.046266  1.000000  0.128607  0.069419  0.220004\n",
       "LUFL  0.291418  0.259487  0.177491  0.128607  1.000000  0.334563  0.118836\n",
       "LULL  0.023606  0.377641 -0.046519  0.069419  0.334563  1.000000  0.067455\n",
       "OT    0.059916  0.224354  0.050854  0.220004  0.118836  0.067455  1.000000"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data.corr()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "107f743e-3016-4012-a48f-cce7e58251f7",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['HUFL', 'HULL', 'MUFL', 'MULL', 'LUFL', 'LULL', 'OT'], dtype='object')"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cols"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "id": "4680c3f7-926a-4b4d-9df1-dd1ec1b62918",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "def get_shifted_data(df, seed, n_sampled_cols, repeat, max_lead_steps):\n",
    "    np.random.seed(seed)\n",
    "    sampled_cols = np.random.choice(cols, n_sampled_cols, replace=False)\n",
    "    print(sampled_cols)\n",
    "    tmp_df = df[sampled_cols]\n",
    "    for col in sampled_cols:\n",
    "        for i in range(repeat):\n",
    "            lead_steps = np.random.randint(1, max_lead_steps)\n",
    "            tmp_arr = np.zeros(len(tmp_df[col]))\n",
    "            tmp_arr[lead_steps:] = tmp_df[col][:-lead_steps]\n",
    "            tmp_arr[:lead_steps] = tmp_df[col].mean()\n",
    "            tmp_df[col+f'-{i+1}'] = tmp_arr\n",
    "    return tmp_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "id": "851dcbc2-500a-4073-bea1-fa92922a43b9",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "sampled_cols = np.random.choice(cols, 3, replace=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "id": "e252a006-9109-4403-9f44-73174757d83c",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "tmp_df = data[sampled_cols]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "12b08895-b2e1-42ae-b5c6-c26ea1a73c31",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "mean_vals = tmp_df.mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "185b019e-43e0-47c0-972a-2b13ea213a73",
   "metadata": {
    "tags": []
   },
   "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>MUFL</th>\n",
       "      <th>HULL</th>\n",
       "      <th>MULL</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1.599</td>\n",
       "      <td>2.009</td>\n",
       "      <td>0.462</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1.492</td>\n",
       "      <td>2.076</td>\n",
       "      <td>0.426</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>1.279</td>\n",
       "      <td>1.741</td>\n",
       "      <td>0.355</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1.279</td>\n",
       "      <td>1.942</td>\n",
       "      <td>0.391</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1.492</td>\n",
       "      <td>1.942</td>\n",
       "      <td>0.462</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17415</th>\n",
       "      <td>-5.615</td>\n",
       "      <td>3.550</td>\n",
       "      <td>2.132</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17416</th>\n",
       "      <td>-9.132</td>\n",
       "      <td>4.287</td>\n",
       "      <td>2.274</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17417</th>\n",
       "      <td>-0.817</td>\n",
       "      <td>3.818</td>\n",
       "      <td>2.097</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17418</th>\n",
       "      <td>5.472</td>\n",
       "      <td>3.818</td>\n",
       "      <td>2.097</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17419</th>\n",
       "      <td>6.183</td>\n",
       "      <td>3.550</td>\n",
       "      <td>1.564</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>17420 rows × 3 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "        MUFL   HULL   MULL\n",
       "0      1.599  2.009  0.462\n",
       "1      1.492  2.076  0.426\n",
       "2      1.279  1.741  0.355\n",
       "3      1.279  1.942  0.391\n",
       "4      1.492  1.942  0.462\n",
       "...      ...    ...    ...\n",
       "17415 -5.615  3.550  2.132\n",
       "17416 -9.132  4.287  2.274\n",
       "17417 -0.817  3.818  2.097\n",
       "17418  5.472  3.818  2.097\n",
       "17419  6.183  3.550  1.564\n",
       "\n",
       "[17420 rows x 3 columns]"
      ]
     },
     "execution_count": 59,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tmp_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "2230a095-b092-463a-9d80-feaed7938b74",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "ename": "KeyError",
     "evalue": "'OT'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyError\u001b[0m                                  Traceback (most recent call last)",
      "File \u001b[0;32m~/anaconda3/lib/python3.11/site-packages/pandas/core/indexes/base.py:3653\u001b[0m, in \u001b[0;36mIndex.get_loc\u001b[0;34m(self, key)\u001b[0m\n\u001b[1;32m   3652\u001b[0m \u001b[38;5;28;01mtry\u001b[39;00m:\n\u001b[0;32m-> 3653\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_engine\u001b[38;5;241m.\u001b[39mget_loc(casted_key)\n\u001b[1;32m   3654\u001b[0m \u001b[38;5;28;01mexcept\u001b[39;00m \u001b[38;5;167;01mKeyError\u001b[39;00m \u001b[38;5;28;01mas\u001b[39;00m err:\n",
      "File \u001b[0;32m~/anaconda3/lib/python3.11/site-packages/pandas/_libs/index.pyx:147\u001b[0m, in \u001b[0;36mpandas._libs.index.IndexEngine.get_loc\u001b[0;34m()\u001b[0m\n",
      "File \u001b[0;32m~/anaconda3/lib/python3.11/site-packages/pandas/_libs/index.pyx:176\u001b[0m, in \u001b[0;36mpandas._libs.index.IndexEngine.get_loc\u001b[0;34m()\u001b[0m\n",
      "File \u001b[0;32mpandas/_libs/hashtable_class_helper.pxi:7080\u001b[0m, in \u001b[0;36mpandas._libs.hashtable.PyObjectHashTable.get_item\u001b[0;34m()\u001b[0m\n",
      "File \u001b[0;32mpandas/_libs/hashtable_class_helper.pxi:7088\u001b[0m, in \u001b[0;36mpandas._libs.hashtable.PyObjectHashTable.get_item\u001b[0;34m()\u001b[0m\n",
      "\u001b[0;31mKeyError\u001b[0m: 'OT'",
      "\nThe above exception was the direct cause of the following exception:\n",
      "\u001b[0;31mKeyError\u001b[0m                                  Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[60], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m tmp_df[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mOT\u001b[39m\u001b[38;5;124m'\u001b[39m]\u001b[38;5;241m.\u001b[39mmean()\n",
      "File \u001b[0;32m~/anaconda3/lib/python3.11/site-packages/pandas/core/frame.py:3761\u001b[0m, in \u001b[0;36mDataFrame.__getitem__\u001b[0;34m(self, key)\u001b[0m\n\u001b[1;32m   3759\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mcolumns\u001b[38;5;241m.\u001b[39mnlevels \u001b[38;5;241m>\u001b[39m \u001b[38;5;241m1\u001b[39m:\n\u001b[1;32m   3760\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_getitem_multilevel(key)\n\u001b[0;32m-> 3761\u001b[0m indexer \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mcolumns\u001b[38;5;241m.\u001b[39mget_loc(key)\n\u001b[1;32m   3762\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m is_integer(indexer):\n\u001b[1;32m   3763\u001b[0m     indexer \u001b[38;5;241m=\u001b[39m [indexer]\n",
      "File \u001b[0;32m~/anaconda3/lib/python3.11/site-packages/pandas/core/indexes/base.py:3655\u001b[0m, in \u001b[0;36mIndex.get_loc\u001b[0;34m(self, key)\u001b[0m\n\u001b[1;32m   3653\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_engine\u001b[38;5;241m.\u001b[39mget_loc(casted_key)\n\u001b[1;32m   3654\u001b[0m \u001b[38;5;28;01mexcept\u001b[39;00m \u001b[38;5;167;01mKeyError\u001b[39;00m \u001b[38;5;28;01mas\u001b[39;00m err:\n\u001b[0;32m-> 3655\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mKeyError\u001b[39;00m(key) \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01merr\u001b[39;00m\n\u001b[1;32m   3656\u001b[0m \u001b[38;5;28;01mexcept\u001b[39;00m \u001b[38;5;167;01mTypeError\u001b[39;00m:\n\u001b[1;32m   3657\u001b[0m     \u001b[38;5;66;03m# If we have a listlike key, _check_indexing_error will raise\u001b[39;00m\n\u001b[1;32m   3658\u001b[0m     \u001b[38;5;66;03m#  InvalidIndexError. Otherwise we fall through and re-raise\u001b[39;00m\n\u001b[1;32m   3659\u001b[0m     \u001b[38;5;66;03m#  the TypeError.\u001b[39;00m\n\u001b[1;32m   3660\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_check_indexing_error(key)\n",
      "\u001b[0;31mKeyError\u001b[0m: 'OT'"
     ]
    }
   ],
   "source": [
    "tmp_df['OT'].mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "ba9cde8c-f4bf-40f2-b9e5-3679928ced97",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "50\n",
      "91\n",
      "62\n",
      "59\n",
      "13\n",
      "2\n"
     ]
    }
   ],
   "source": [
    "for col in sampled_cols:\n",
    "    for i in range(2):\n",
    "        lead_steps = np.random.randint(100)\n",
    "        print(lead_steps)\n",
    "        tmp_arr = np.zeros(len(tmp_df[col]))\n",
    "        tmp_arr[lead_steps:] = tmp_df[col][:-lead_steps]\n",
    "        tmp_arr[:lead_steps] = tmp_df[col].mean()\n",
    "        tmp_df[col+f'-{i+1}'] = tmp_arr"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "e0384a81-23ad-4026-ba43-b11fe7d75cd6",
   "metadata": {
    "tags": []
   },
   "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>MUFL</th>\n",
       "      <th>HULL</th>\n",
       "      <th>MULL</th>\n",
       "      <th>MUFL-1</th>\n",
       "      <th>MUFL-2</th>\n",
       "      <th>HULL-1</th>\n",
       "      <th>HULL-2</th>\n",
       "      <th>MULL-1</th>\n",
       "      <th>MULL-2</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1.599</td>\n",
       "      <td>2.009</td>\n",
       "      <td>0.462</td>\n",
       "      <td>4.300239</td>\n",
       "      <td>4.300239</td>\n",
       "      <td>2.242242</td>\n",
       "      <td>2.242242</td>\n",
       "      <td>0.881568</td>\n",
       "      <td>0.881568</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1.492</td>\n",
       "      <td>2.076</td>\n",
       "      <td>0.426</td>\n",
       "      <td>4.300239</td>\n",
       "      <td>4.300239</td>\n",
       "      <td>2.242242</td>\n",
       "      <td>2.242242</td>\n",
       "      <td>0.881568</td>\n",
       "      <td>0.881568</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>1.279</td>\n",
       "      <td>1.741</td>\n",
       "      <td>0.355</td>\n",
       "      <td>4.300239</td>\n",
       "      <td>4.300239</td>\n",
       "      <td>2.242242</td>\n",
       "      <td>2.242242</td>\n",
       "      <td>0.881568</td>\n",
       "      <td>0.462000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1.279</td>\n",
       "      <td>1.942</td>\n",
       "      <td>0.391</td>\n",
       "      <td>4.300239</td>\n",
       "      <td>4.300239</td>\n",
       "      <td>2.242242</td>\n",
       "      <td>2.242242</td>\n",
       "      <td>0.881568</td>\n",
       "      <td>0.426000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1.492</td>\n",
       "      <td>1.942</td>\n",
       "      <td>0.462</td>\n",
       "      <td>4.300239</td>\n",
       "      <td>4.300239</td>\n",
       "      <td>2.242242</td>\n",
       "      <td>2.242242</td>\n",
       "      <td>0.881568</td>\n",
       "      <td>0.355000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17415</th>\n",
       "      <td>-5.615</td>\n",
       "      <td>3.550</td>\n",
       "      <td>2.132</td>\n",
       "      <td>-3.518000</td>\n",
       "      <td>4.122000</td>\n",
       "      <td>5.090000</td>\n",
       "      <td>5.626000</td>\n",
       "      <td>3.553000</td>\n",
       "      <td>1.528000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17416</th>\n",
       "      <td>-9.132</td>\n",
       "      <td>4.287</td>\n",
       "      <td>2.274</td>\n",
       "      <td>-4.797000</td>\n",
       "      <td>4.300000</td>\n",
       "      <td>6.162000</td>\n",
       "      <td>5.760000</td>\n",
       "      <td>3.482000</td>\n",
       "      <td>2.132000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17417</th>\n",
       "      <td>-0.817</td>\n",
       "      <td>3.818</td>\n",
       "      <td>2.097</td>\n",
       "      <td>-3.482000</td>\n",
       "      <td>6.183000</td>\n",
       "      <td>5.827000</td>\n",
       "      <td>4.957000</td>\n",
       "      <td>3.518000</td>\n",
       "      <td>2.132000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17418</th>\n",
       "      <td>5.472</td>\n",
       "      <td>3.818</td>\n",
       "      <td>2.097</td>\n",
       "      <td>-0.569000</td>\n",
       "      <td>8.955000</td>\n",
       "      <td>5.626000</td>\n",
       "      <td>5.425000</td>\n",
       "      <td>2.310000</td>\n",
       "      <td>2.274000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17419</th>\n",
       "      <td>6.183</td>\n",
       "      <td>3.550</td>\n",
       "      <td>1.564</td>\n",
       "      <td>2.239000</td>\n",
       "      <td>12.117000</td>\n",
       "      <td>5.760000</td>\n",
       "      <td>5.760000</td>\n",
       "      <td>2.239000</td>\n",
       "      <td>2.097000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>17420 rows × 9 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "        MUFL   HULL   MULL    MUFL-1     MUFL-2    HULL-1    HULL-2    MULL-1  \\\n",
       "0      1.599  2.009  0.462  4.300239   4.300239  2.242242  2.242242  0.881568   \n",
       "1      1.492  2.076  0.426  4.300239   4.300239  2.242242  2.242242  0.881568   \n",
       "2      1.279  1.741  0.355  4.300239   4.300239  2.242242  2.242242  0.881568   \n",
       "3      1.279  1.942  0.391  4.300239   4.300239  2.242242  2.242242  0.881568   \n",
       "4      1.492  1.942  0.462  4.300239   4.300239  2.242242  2.242242  0.881568   \n",
       "...      ...    ...    ...       ...        ...       ...       ...       ...   \n",
       "17415 -5.615  3.550  2.132 -3.518000   4.122000  5.090000  5.626000  3.553000   \n",
       "17416 -9.132  4.287  2.274 -4.797000   4.300000  6.162000  5.760000  3.482000   \n",
       "17417 -0.817  3.818  2.097 -3.482000   6.183000  5.827000  4.957000  3.518000   \n",
       "17418  5.472  3.818  2.097 -0.569000   8.955000  5.626000  5.425000  2.310000   \n",
       "17419  6.183  3.550  1.564  2.239000  12.117000  5.760000  5.760000  2.239000   \n",
       "\n",
       "         MULL-2  \n",
       "0      0.881568  \n",
       "1      0.881568  \n",
       "2      0.462000  \n",
       "3      0.426000  \n",
       "4      0.355000  \n",
       "...         ...  \n",
       "17415  1.528000  \n",
       "17416  2.132000  \n",
       "17417  2.132000  \n",
       "17418  2.274000  \n",
       "17419  2.097000  \n",
       "\n",
       "[17420 rows x 9 columns]"
      ]
     },
     "execution_count": 66,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tmp_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "id": "c3c15ef1-38e5-4a0c-aefe-5fc9bf428544",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['OT' 'MUFL' 'HULL']\n",
      "['OT' 'MUFL' 'HULL']\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/42/rh4k9zjj0ln515z91bg2ll_00000gn/T/ipykernel_93013/779220239.py:12: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  tmp_df[col+f'-{i+1}'] = tmp_arr\n",
      "/var/folders/42/rh4k9zjj0ln515z91bg2ll_00000gn/T/ipykernel_93013/779220239.py:12: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  tmp_df[col+f'-{i+1}'] = tmp_arr\n",
      "/var/folders/42/rh4k9zjj0ln515z91bg2ll_00000gn/T/ipykernel_93013/779220239.py:12: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  tmp_df[col+f'-{i+1}'] = tmp_arr\n",
      "/var/folders/42/rh4k9zjj0ln515z91bg2ll_00000gn/T/ipykernel_93013/779220239.py:12: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  tmp_df[col+f'-{i+1}'] = tmp_arr\n",
      "/var/folders/42/rh4k9zjj0ln515z91bg2ll_00000gn/T/ipykernel_93013/779220239.py:12: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  tmp_df[col+f'-{i+1}'] = tmp_arr\n",
      "/var/folders/42/rh4k9zjj0ln515z91bg2ll_00000gn/T/ipykernel_93013/779220239.py:12: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  tmp_df[col+f'-{i+1}'] = tmp_arr\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['LUFL' 'HULL' 'MULL']\n",
      "['LUFL' 'OT' 'LULL']\n",
      "['LUFL' 'OT' 'MULL']\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/42/rh4k9zjj0ln515z91bg2ll_00000gn/T/ipykernel_93013/779220239.py:12: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  tmp_df[col+f'-{i+1}'] = tmp_arr\n",
      "/var/folders/42/rh4k9zjj0ln515z91bg2ll_00000gn/T/ipykernel_93013/779220239.py:12: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  tmp_df[col+f'-{i+1}'] = tmp_arr\n",
      "/var/folders/42/rh4k9zjj0ln515z91bg2ll_00000gn/T/ipykernel_93013/779220239.py:12: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  tmp_df[col+f'-{i+1}'] = tmp_arr\n",
      "/var/folders/42/rh4k9zjj0ln515z91bg2ll_00000gn/T/ipykernel_93013/779220239.py:12: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  tmp_df[col+f'-{i+1}'] = tmp_arr\n",
      "/var/folders/42/rh4k9zjj0ln515z91bg2ll_00000gn/T/ipykernel_93013/779220239.py:12: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  tmp_df[col+f'-{i+1}'] = tmp_arr\n",
      "/var/folders/42/rh4k9zjj0ln515z91bg2ll_00000gn/T/ipykernel_93013/779220239.py:12: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  tmp_df[col+f'-{i+1}'] = tmp_arr\n",
      "/var/folders/42/rh4k9zjj0ln515z91bg2ll_00000gn/T/ipykernel_93013/779220239.py:12: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  tmp_df[col+f'-{i+1}'] = tmp_arr\n",
      "/var/folders/42/rh4k9zjj0ln515z91bg2ll_00000gn/T/ipykernel_93013/779220239.py:12: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  tmp_df[col+f'-{i+1}'] = tmp_arr\n",
      "/var/folders/42/rh4k9zjj0ln515z91bg2ll_00000gn/T/ipykernel_93013/779220239.py:12: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  tmp_df[col+f'-{i+1}'] = tmp_arr\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['OT' 'MUFL' 'LUFL']\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/42/rh4k9zjj0ln515z91bg2ll_00000gn/T/ipykernel_93013/779220239.py:12: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  tmp_df[col+f'-{i+1}'] = tmp_arr\n",
      "/var/folders/42/rh4k9zjj0ln515z91bg2ll_00000gn/T/ipykernel_93013/779220239.py:12: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  tmp_df[col+f'-{i+1}'] = tmp_arr\n",
      "/var/folders/42/rh4k9zjj0ln515z91bg2ll_00000gn/T/ipykernel_93013/779220239.py:12: SettingWithCopyWarning: \n",
      "A value is trying to be set on a copy of a slice from a DataFrame.\n",
      "Try using .loc[row_indexer,col_indexer] = value instead\n",
      "\n",
      "See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
      "  tmp_df[col+f'-{i+1}'] = tmp_arr\n"
     ]
    }
   ],
   "source": [
    "for i in range(6):\n",
    "    dfff = get_shifted_data(data, i, 3, 2, 100)\n",
    "    dfff.to_csv(f'./dataset/shifted_data_{i}.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "id": "a937d460-4185-4e5a-85e3-56e867fb1c25",
   "metadata": {
    "tags": []
   },
   "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>HULL</th>\n",
       "      <th>LULL</th>\n",
       "      <th>MULL</th>\n",
       "      <th>HULL-1</th>\n",
       "      <th>HULL-2</th>\n",
       "      <th>LULL-1</th>\n",
       "      <th>LULL-2</th>\n",
       "      <th>MULL-1</th>\n",
       "      <th>MULL-2</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>2.009</td>\n",
       "      <td>1.340</td>\n",
       "      <td>0.462</td>\n",
       "      <td>2.242242</td>\n",
       "      <td>2.242242</td>\n",
       "      <td>0.856932</td>\n",
       "      <td>0.856932</td>\n",
       "      <td>0.881568</td>\n",
       "      <td>0.881568</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>2.076</td>\n",
       "      <td>1.371</td>\n",
       "      <td>0.426</td>\n",
       "      <td>2.242242</td>\n",
       "      <td>2.242242</td>\n",
       "      <td>0.856932</td>\n",
       "      <td>0.856932</td>\n",
       "      <td>0.881568</td>\n",
       "      <td>0.881568</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>1.741</td>\n",
       "      <td>1.218</td>\n",
       "      <td>0.355</td>\n",
       "      <td>2.242242</td>\n",
       "      <td>2.242242</td>\n",
       "      <td>0.856932</td>\n",
       "      <td>0.856932</td>\n",
       "      <td>0.881568</td>\n",
       "      <td>0.881568</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1.942</td>\n",
       "      <td>1.279</td>\n",
       "      <td>0.391</td>\n",
       "      <td>2.242242</td>\n",
       "      <td>2.242242</td>\n",
       "      <td>0.856932</td>\n",
       "      <td>0.856932</td>\n",
       "      <td>0.881568</td>\n",
       "      <td>0.881568</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1.942</td>\n",
       "      <td>1.279</td>\n",
       "      <td>0.462</td>\n",
       "      <td>2.242242</td>\n",
       "      <td>2.242242</td>\n",
       "      <td>0.856932</td>\n",
       "      <td>0.856932</td>\n",
       "      <td>0.881568</td>\n",
       "      <td>0.881568</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17415</th>\n",
       "      <td>3.550</td>\n",
       "      <td>1.523</td>\n",
       "      <td>2.132</td>\n",
       "      <td>5.760000</td>\n",
       "      <td>3.952000</td>\n",
       "      <td>0.975000</td>\n",
       "      <td>1.401000</td>\n",
       "      <td>1.102000</td>\n",
       "      <td>1.350000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17416</th>\n",
       "      <td>4.287</td>\n",
       "      <td>1.675</td>\n",
       "      <td>2.274</td>\n",
       "      <td>3.885000</td>\n",
       "      <td>5.492000</td>\n",
       "      <td>1.919000</td>\n",
       "      <td>1.310000</td>\n",
       "      <td>1.350000</td>\n",
       "      <td>1.954000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17417</th>\n",
       "      <td>3.818</td>\n",
       "      <td>1.523</td>\n",
       "      <td>2.097</td>\n",
       "      <td>4.153000</td>\n",
       "      <td>6.631000</td>\n",
       "      <td>1.279000</td>\n",
       "      <td>1.675000</td>\n",
       "      <td>1.315000</td>\n",
       "      <td>1.990000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17418</th>\n",
       "      <td>3.818</td>\n",
       "      <td>1.432</td>\n",
       "      <td>2.097</td>\n",
       "      <td>4.086000</td>\n",
       "      <td>5.492000</td>\n",
       "      <td>1.401000</td>\n",
       "      <td>1.736000</td>\n",
       "      <td>0.888000</td>\n",
       "      <td>1.031000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17419</th>\n",
       "      <td>3.550</td>\n",
       "      <td>1.462</td>\n",
       "      <td>1.564</td>\n",
       "      <td>2.344000</td>\n",
       "      <td>6.698000</td>\n",
       "      <td>1.157000</td>\n",
       "      <td>1.767000</td>\n",
       "      <td>1.350000</td>\n",
       "      <td>1.386000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>17420 rows × 9 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "        HULL   LULL   MULL    HULL-1    HULL-2    LULL-1    LULL-2    MULL-1  \\\n",
       "0      2.009  1.340  0.462  2.242242  2.242242  0.856932  0.856932  0.881568   \n",
       "1      2.076  1.371  0.426  2.242242  2.242242  0.856932  0.856932  0.881568   \n",
       "2      1.741  1.218  0.355  2.242242  2.242242  0.856932  0.856932  0.881568   \n",
       "3      1.942  1.279  0.391  2.242242  2.242242  0.856932  0.856932  0.881568   \n",
       "4      1.942  1.279  0.462  2.242242  2.242242  0.856932  0.856932  0.881568   \n",
       "...      ...    ...    ...       ...       ...       ...       ...       ...   \n",
       "17415  3.550  1.523  2.132  5.760000  3.952000  0.975000  1.401000  1.102000   \n",
       "17416  4.287  1.675  2.274  3.885000  5.492000  1.919000  1.310000  1.350000   \n",
       "17417  3.818  1.523  2.097  4.153000  6.631000  1.279000  1.675000  1.315000   \n",
       "17418  3.818  1.432  2.097  4.086000  5.492000  1.401000  1.736000  0.888000   \n",
       "17419  3.550  1.462  1.564  2.344000  6.698000  1.157000  1.767000  1.350000   \n",
       "\n",
       "         MULL-2  \n",
       "0      0.881568  \n",
       "1      0.881568  \n",
       "2      0.881568  \n",
       "3      0.881568  \n",
       "4      0.881568  \n",
       "...         ...  \n",
       "17415  1.350000  \n",
       "17416  1.954000  \n",
       "17417  1.990000  \n",
       "17418  1.031000  \n",
       "17419  1.386000  \n",
       "\n",
       "[17420 rows x 9 columns]"
      ]
     },
     "execution_count": 78,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dfff"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7c763744-a221-4224-8bbe-2a369d233d84",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
