{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "c336b696-b25e-4c2d-b018-15ebd5bb193e",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "from tqdm import tqdm\n",
    "import numpy as np\n",
    "from matplotlib import pyplot as plt\n",
    "import os\n",
    "import glob"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "2cbee5d0-68e6-4d3b-9f78-03257c4cad73",
   "metadata": {},
   "outputs": [],
   "source": [
    "chunk_size=5000000"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "887709b2-d9de-46d3-92db-03ba5b06bdd7",
   "metadata": {},
   "outputs": [],
   "source": [
    "common_types = ['Tug','Pilot','Fishing','Tanker','Passenger','Cargo']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "4fe68dab-7571-4370-8d06-a5670ec9e276",
   "metadata": {},
   "outputs": [],
   "source": [
    "dates_used = ['2024-01-01','2024-01-02','2024-01-03', '2024-01-04','2024-01-05','2024-01-06', \n",
    "              '2024-05-01','2024-05-02','2024-05-03','2024-05-04','2024-05-05','2024-05-06',\n",
    "              '2024-06-01','2024-06-02','2024-06-03','2024-06-04','2024-06-05','2024-06-06']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "29728d97-e598-46f4-8e87-aeb822ee0c52",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████| 18/18 [10:32<00:00, 35.14s/it]\n"
     ]
    }
   ],
   "source": [
    "file_pattern = os.path.join('./', \"processed_chunk*\")\n",
    "csv_files = glob.glob(file_pattern)\n",
    "for dat in tqdm(dates_used):\n",
    "\n",
    "    #if f'./processed_chunk_{dat}' in csv_files:\n",
    "    #    print('Already have', dat)\n",
    "    #    continue\n",
    "    \n",
    "    c=0\n",
    "    for chunk in pd.read_csv(f'aisdk-{dat}.csv', \n",
    "                             chunksize=chunk_size, \n",
    "                             usecols=['# Timestamp','MMSI','Latitude', 'Longitude','Width','Ship type','Navigational status','SOG']):\n",
    "        mask1 = chunk['Ship type']!='Undefined'\n",
    "        mask2 = chunk['Latitude']>53\n",
    "        mask3 = chunk['Latitude']<58.5\n",
    "        mask4 = chunk['Longitude']>7.5\n",
    "        mask5 = chunk['Longitude']<15\n",
    "        mask6 = chunk['Navigational status'].str.contains('Under way')\n",
    "        mask_trunc = pd.to_datetime(chunk['# Timestamp'], format='%d/%m/%Y %H:%M:%S').dt.second<12\n",
    "        #mask7 = chunk['Ship type'].isin(common_types)\n",
    "        \n",
    "        df_aux = chunk[mask1&mask2&mask3&mask4&mask5&mask6&mask_trunc]\n",
    "\n",
    "        df_aux.to_csv(f'processed_chunk_{dat}_{c}', index=False)\n",
    "\n",
    "        c = c+1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 148,
   "id": "ffa96d48-f212-4b3f-89eb-2e40707ff724",
   "metadata": {},
   "outputs": [],
   "source": [
    "file_pattern = os.path.join('./', \"processed_chunk*\")\n",
    "csv_files = glob.glob(file_pattern)\n",
    "\n",
    "dataframes = [pd.read_csv(file) for file in csv_files]\n",
    "df_processed = pd.concat(dataframes, ignore_index=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 149,
   "id": "56991f9f-722d-4960-8e16-e6c3111a03b3",
   "metadata": {},
   "outputs": [],
   "source": [
    "mask_lon = df_processed.groupby('MMSI').Longitude.max() - df_processed.groupby('MMSI').Longitude.min() > 4\n",
    "mask_lat = df_processed.groupby('MMSI').Latitude.max() - df_processed.groupby('MMSI').Latitude.min() > 2\n",
    "mask_mmsis = (mask_lon | mask_lat).reset_index()\n",
    "MMSI_utils = mask_mmsis[mask_mmsis[0]].MMSI.tolist()\n",
    "df_processed = df_processed[df_processed['MMSI'].isin(MMSI_utils)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 150,
   "id": "7f9f8ae4-621d-4dae-936b-192325c3e95e",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_processed['datetime_trunc'] = pd.to_datetime(df_processed['# Timestamp'], format='%d/%m/%Y %H:%M:%S').dt.floor('T')\n",
    "df_processed = df_processed.drop_duplicates(subset=['MMSI','datetime_trunc'], keep='first')\n",
    "df_processed = df_processed.sort_values(by=['MMSI','datetime_trunc'], ascending=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 151,
   "id": "42d60146-288a-470a-8878-ce5468acb45f",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_processed = df_processed.reset_index(drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 152,
   "id": "b44bc64f-4b12-48b2-a88b-27c1f412154d",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_processed['Node'] = -1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 153,
   "id": "567e560f-078f-4ce7-9a1f-f97b08008178",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(6317775, 10)"
      ]
     },
     "execution_count": 153,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_processed.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 154,
   "id": "77f08b58-9c3c-4e20-9d4a-f44b1b2a6592",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|████████████████████████████████████████████████████████████████| 61/61 [02:29<00:00,  2.45s/it]\n"
     ]
    }
   ],
   "source": [
    "y_min = 53\n",
    "y_max = 58.5\n",
    "\n",
    "x_min = 7.5\n",
    "x_max = 15\n",
    "\n",
    "dx = 0.09\n",
    "dy = 0.09\n",
    "\n",
    "n_x = int((x_max - x_min)/dx)\n",
    "n_y = int((y_max - y_min)/dy)\n",
    "\n",
    "nd = -1\n",
    "\n",
    "nds = []\n",
    "nxcs = []\n",
    "nycs = []\n",
    "for j in tqdm(range(n_y)):\n",
    "    for i in range(n_x):\n",
    "        nd = nd+1\n",
    "        # Check points in this square\n",
    "        df_processed['Node'] = np.where((df_processed['Longitude']<x_min + dx*(i+1)) \\\n",
    "                              & (df_processed['Longitude']>=x_min + dx*i)\\\n",
    "                              & (df_processed['Latitude']<y_min + dy*(j+1))\\\n",
    "                              & (df_processed['Latitude']>=y_min + dy*j)\n",
    "                              , nd, df_processed['Node'])\n",
    "        nds.append(nd)\n",
    "        nxcs.append(x_min + dx*(i+0.5))\n",
    "        nycs.append(y_min + dy*(j+0.5))\n",
    "        \n",
    "df_nodes = pd.DataFrame(data = {'Node':nds,'nxc':nxcs,'nyc':nycs})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 155,
   "id": "c0ef105e-7d9a-4ed6-a760-9639e2e0febe",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_nodes_useful = df_nodes[df_nodes['Node'].isin(df_processed.Node.unique())]\n",
    "\n",
    "#df_nodes_useful = df_nodes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 156,
   "id": "c3534234-5659-429d-9f5d-216d18d9864d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2513"
      ]
     },
     "execution_count": 156,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(df_nodes_useful)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7ac942d3-a49d-4ab2-a524-5b4dcff90cea",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 157,
   "id": "325d19f2-a255-4275-9018-2eb8cfac4ed2",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_per_node = df_processed[df_processed['Node'].diff()!=0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 158,
   "id": "1cdd35bc-22c2-4fa0-9711-879bcf237b1d",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_cols_grid = (df_nodes['nyc'] == df_nodes['nyc'].iloc[0]).sum()\n",
    "n_rows_grid = len(df_nodes)//n_cols_grid"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 159,
   "id": "9019ab34-bf18-4ae5-8e21-92f8bd1ff032",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_222356/340381785.py:1: 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",
      "  df_per_node['mh_dist_diff'] =  np.abs(df_per_node['Latitude'].diff() + df_per_node['Longitude'].diff())\n"
     ]
    }
   ],
   "source": [
    "df_per_node['mh_dist_diff'] =  np.abs(df_per_node['Latitude'].diff() + df_per_node['Longitude'].diff())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 160,
   "id": "36ad4ee2-76c7-49e4-8a43-f3b0af898202",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_per_node = df_per_node.reset_index(drop=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 161,
   "id": "57c7afa4-32bf-4049-a1bb-9097cab2ae88",
   "metadata": {},
   "outputs": [],
   "source": [
    "lat1 = np.radians(df_per_node['Latitude'])\n",
    "lon1 = np.radians(df_per_node['Longitude'])\n",
    "lat2 = lat1.shift(1)\n",
    "lon2 = lon1.shift(1)\n",
    "\n",
    "delta_lon = lon2 - lon1\n",
    "x = np.sin(delta_lon) * np.cos(lat1)\n",
    "y = np.cos(lat2) * np.sin(lat1) - (np.sin(lat2) * np.cos(lat1) * np.cos(delta_lon))\n",
    "\n",
    "bearing = np.arctan2(x, y)\n",
    "bearing = np.degrees(bearing)\n",
    "bearing = (bearing + 360) % 360\n",
    "\n",
    "df_per_node['bearing'] = bearing"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 162,
   "id": "e51c77fa-623c-40b5-b9c6-2dd7a0867195",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_per_node['direction_change'] = np.abs(df_per_node['bearing'].diff())\n",
    "df_per_node['direction_change_2'] = np.abs(df_per_node['bearing'] - df_per_node['bearing'].shift(2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 163,
   "id": "5b1ce95c-cfa5-4922-81fc-85d8b92f61d9",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_per_node['se'] = np.where(\n",
    "    (df_per_node['SOG']<1) \\\n",
    "    | (df_per_node['mh_dist_diff']>0.25) \\\n",
    "    | (df_per_node['direction_change']>150) \\\n",
    "    | (df_per_node['direction_change_2']>150) \\\n",
    "    | ((df_per_node['Node'].diff().abs()!=1) & (df_per_node['Node'].diff().abs()!=n_cols_grid))\n",
    "    , 1, 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "79299228-fa69-4319-9593-0dab3cd16740",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b8c4b438-6ae1-4c05-8b80-10244e5f8890",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 164,
   "id": "61bdd79a-2c03-4067-89ba-ac6b0ea63edc",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_per_node = df_per_node[df_per_node['Node']!=-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bc2aabd7-2ecc-4f94-b3c8-c9ab697aadcb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 165,
   "id": "a1e321b4-6433-4813-a71a-c241b66ef66a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def create_global_path_id(df):\n",
    "    df['global_path_id'] = (df['MMSI'].shift() != df['MMSI']) | (df['se'].shift() != df['se'])\n",
    "    df['global_path_id'] = df['global_path_id'].cumsum() + 1  # Start IDs from 1\n",
    "    return df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 166,
   "id": "b1fc9086-672f-436e-8336-cae0e4cfc390",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_per_node = create_global_path_id(df_per_node)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 167,
   "id": "7378855e-9176-4b23-8ed6-8a9ef0946a03",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(367083, 16)"
      ]
     },
     "execution_count": 167,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_per_node.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 168,
   "id": "051fedd4-c8db-4289-b23a-6d93b52f6314",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_per_node = df_per_node[df_per_node.groupby('global_path_id').Node.transform('nunique')>20]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 169,
   "id": "0b909a12-f1a3-46e1-af0f-cfa4a4ceb63f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(254914, 16)"
      ]
     },
     "execution_count": 169,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_per_node.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e347ba0c-3bff-45a5-8a37-3e1f54b2b430",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f0863cae-90d6-4343-b4da-101fc40238dc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 170,
   "id": "d9a33ad7-56fd-4d91-b8df-f29665209268",
   "metadata": {},
   "outputs": [],
   "source": [
    "lat_last = df_per_node.groupby('global_path_id').Latitude.last() \n",
    "lat_first = df_per_node.groupby('global_path_id').Latitude.first() \n",
    "lon_last = df_per_node.groupby('global_path_id').Longitude.last() \n",
    "lon_first = df_per_node.groupby('global_path_id').Longitude.first() \n",
    "paths_dists = (np.sqrt((lat_last - lat_first)**2 + (lon_last - lon_first)**2)).reset_index()\n",
    "\n",
    "ids_longs = paths_dists[paths_dists[0]>2.5].global_path_id.tolist()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 171,
   "id": "58ae1152-110b-4a53-bacf-8d21d1bd2a54",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_per_node = df_per_node[df_per_node['global_path_id'].isin(ids_longs)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 172,
   "id": "cd304c0d-8f9f-4434-9403-a76509ccd3ac",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_per_node = df_per_node.sort_values(by=['global_path_id','datetime_trunc'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 173,
   "id": "562479ae-ed51-4d0b-a891-c8961fc2bc18",
   "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># Timestamp</th>\n",
       "      <th>MMSI</th>\n",
       "      <th>Latitude</th>\n",
       "      <th>Longitude</th>\n",
       "      <th>Navigational status</th>\n",
       "      <th>SOG</th>\n",
       "      <th>Width</th>\n",
       "      <th>datetime_trunc</th>\n",
       "      <th>Node</th>\n",
       "      <th>mh_dist_diff</th>\n",
       "      <th>bearing</th>\n",
       "      <th>direction_change</th>\n",
       "      <th>direction_change_2</th>\n",
       "      <th>se</th>\n",
       "      <th>global_path_id</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Ship type</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>Cargo</th>\n",
       "      <td>104332</td>\n",
       "      <td>104332</td>\n",
       "      <td>104332</td>\n",
       "      <td>104332</td>\n",
       "      <td>104332</td>\n",
       "      <td>104325</td>\n",
       "      <td>104298</td>\n",
       "      <td>104332</td>\n",
       "      <td>104332</td>\n",
       "      <td>104332</td>\n",
       "      <td>104332</td>\n",
       "      <td>104332</td>\n",
       "      <td>104332</td>\n",
       "      <td>104332</td>\n",
       "      <td>104332</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Dredging</th>\n",
       "      <td>610</td>\n",
       "      <td>610</td>\n",
       "      <td>610</td>\n",
       "      <td>610</td>\n",
       "      <td>610</td>\n",
       "      <td>610</td>\n",
       "      <td>610</td>\n",
       "      <td>610</td>\n",
       "      <td>610</td>\n",
       "      <td>610</td>\n",
       "      <td>610</td>\n",
       "      <td>610</td>\n",
       "      <td>610</td>\n",
       "      <td>610</td>\n",
       "      <td>610</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Fishing</th>\n",
       "      <td>1030</td>\n",
       "      <td>1030</td>\n",
       "      <td>1030</td>\n",
       "      <td>1030</td>\n",
       "      <td>1030</td>\n",
       "      <td>1030</td>\n",
       "      <td>1030</td>\n",
       "      <td>1030</td>\n",
       "      <td>1030</td>\n",
       "      <td>1030</td>\n",
       "      <td>1030</td>\n",
       "      <td>1030</td>\n",
       "      <td>1030</td>\n",
       "      <td>1030</td>\n",
       "      <td>1030</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>HSC</th>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Law enforcement</th>\n",
       "      <td>227</td>\n",
       "      <td>227</td>\n",
       "      <td>227</td>\n",
       "      <td>227</td>\n",
       "      <td>227</td>\n",
       "      <td>227</td>\n",
       "      <td>227</td>\n",
       "      <td>227</td>\n",
       "      <td>227</td>\n",
       "      <td>227</td>\n",
       "      <td>227</td>\n",
       "      <td>227</td>\n",
       "      <td>227</td>\n",
       "      <td>227</td>\n",
       "      <td>227</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Military</th>\n",
       "      <td>1351</td>\n",
       "      <td>1351</td>\n",
       "      <td>1351</td>\n",
       "      <td>1351</td>\n",
       "      <td>1351</td>\n",
       "      <td>1351</td>\n",
       "      <td>1241</td>\n",
       "      <td>1351</td>\n",
       "      <td>1351</td>\n",
       "      <td>1351</td>\n",
       "      <td>1351</td>\n",
       "      <td>1351</td>\n",
       "      <td>1351</td>\n",
       "      <td>1351</td>\n",
       "      <td>1351</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Other</th>\n",
       "      <td>1611</td>\n",
       "      <td>1611</td>\n",
       "      <td>1611</td>\n",
       "      <td>1611</td>\n",
       "      <td>1611</td>\n",
       "      <td>1611</td>\n",
       "      <td>1611</td>\n",
       "      <td>1611</td>\n",
       "      <td>1611</td>\n",
       "      <td>1611</td>\n",
       "      <td>1611</td>\n",
       "      <td>1611</td>\n",
       "      <td>1611</td>\n",
       "      <td>1611</td>\n",
       "      <td>1611</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Passenger</th>\n",
       "      <td>5494</td>\n",
       "      <td>5494</td>\n",
       "      <td>5494</td>\n",
       "      <td>5494</td>\n",
       "      <td>5494</td>\n",
       "      <td>5494</td>\n",
       "      <td>5494</td>\n",
       "      <td>5494</td>\n",
       "      <td>5494</td>\n",
       "      <td>5494</td>\n",
       "      <td>5494</td>\n",
       "      <td>5494</td>\n",
       "      <td>5494</td>\n",
       "      <td>5494</td>\n",
       "      <td>5494</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Pilot</th>\n",
       "      <td>33</td>\n",
       "      <td>33</td>\n",
       "      <td>33</td>\n",
       "      <td>33</td>\n",
       "      <td>33</td>\n",
       "      <td>33</td>\n",
       "      <td>33</td>\n",
       "      <td>33</td>\n",
       "      <td>33</td>\n",
       "      <td>33</td>\n",
       "      <td>33</td>\n",
       "      <td>33</td>\n",
       "      <td>33</td>\n",
       "      <td>33</td>\n",
       "      <td>33</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Pleasure</th>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "      <td>37</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Sailing</th>\n",
       "      <td>66</td>\n",
       "      <td>66</td>\n",
       "      <td>66</td>\n",
       "      <td>66</td>\n",
       "      <td>66</td>\n",
       "      <td>66</td>\n",
       "      <td>66</td>\n",
       "      <td>66</td>\n",
       "      <td>66</td>\n",
       "      <td>66</td>\n",
       "      <td>66</td>\n",
       "      <td>66</td>\n",
       "      <td>66</td>\n",
       "      <td>66</td>\n",
       "      <td>66</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Tanker</th>\n",
       "      <td>44712</td>\n",
       "      <td>44712</td>\n",
       "      <td>44712</td>\n",
       "      <td>44712</td>\n",
       "      <td>44712</td>\n",
       "      <td>44696</td>\n",
       "      <td>44618</td>\n",
       "      <td>44712</td>\n",
       "      <td>44712</td>\n",
       "      <td>44712</td>\n",
       "      <td>44712</td>\n",
       "      <td>44712</td>\n",
       "      <td>44712</td>\n",
       "      <td>44712</td>\n",
       "      <td>44712</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Towing long/wide</th>\n",
       "      <td>155</td>\n",
       "      <td>155</td>\n",
       "      <td>155</td>\n",
       "      <td>155</td>\n",
       "      <td>155</td>\n",
       "      <td>155</td>\n",
       "      <td>155</td>\n",
       "      <td>155</td>\n",
       "      <td>155</td>\n",
       "      <td>155</td>\n",
       "      <td>155</td>\n",
       "      <td>155</td>\n",
       "      <td>155</td>\n",
       "      <td>155</td>\n",
       "      <td>155</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>Tug</th>\n",
       "      <td>1130</td>\n",
       "      <td>1130</td>\n",
       "      <td>1130</td>\n",
       "      <td>1130</td>\n",
       "      <td>1130</td>\n",
       "      <td>1130</td>\n",
       "      <td>1074</td>\n",
       "      <td>1130</td>\n",
       "      <td>1130</td>\n",
       "      <td>1130</td>\n",
       "      <td>1130</td>\n",
       "      <td>1130</td>\n",
       "      <td>1130</td>\n",
       "      <td>1130</td>\n",
       "      <td>1130</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                  # Timestamp    MMSI  Latitude  Longitude  \\\n",
       "Ship type                                                    \n",
       "Cargo                  104332  104332    104332     104332   \n",
       "Dredging                  610     610       610        610   \n",
       "Fishing                  1030    1030      1030       1030   \n",
       "HSC                        37      37        37         37   \n",
       "Law enforcement           227     227       227        227   \n",
       "Military                 1351    1351      1351       1351   \n",
       "Other                    1611    1611      1611       1611   \n",
       "Passenger                5494    5494      5494       5494   \n",
       "Pilot                      33      33        33         33   \n",
       "Pleasure                   37      37        37         37   \n",
       "Sailing                    66      66        66         66   \n",
       "Tanker                  44712   44712     44712      44712   \n",
       "Towing long/wide          155     155       155        155   \n",
       "Tug                      1130    1130      1130       1130   \n",
       "\n",
       "                  Navigational status     SOG   Width  datetime_trunc    Node  \\\n",
       "Ship type                                                                       \n",
       "Cargo                          104332  104325  104298          104332  104332   \n",
       "Dredging                          610     610     610             610     610   \n",
       "Fishing                          1030    1030    1030            1030    1030   \n",
       "HSC                                37      37      37              37      37   \n",
       "Law enforcement                   227     227     227             227     227   \n",
       "Military                         1351    1351    1241            1351    1351   \n",
       "Other                            1611    1611    1611            1611    1611   \n",
       "Passenger                        5494    5494    5494            5494    5494   \n",
       "Pilot                              33      33      33              33      33   \n",
       "Pleasure                           37      37      37              37      37   \n",
       "Sailing                            66      66      66              66      66   \n",
       "Tanker                          44712   44696   44618           44712   44712   \n",
       "Towing long/wide                  155     155     155             155     155   \n",
       "Tug                              1130    1130    1074            1130    1130   \n",
       "\n",
       "                  mh_dist_diff  bearing  direction_change  direction_change_2  \\\n",
       "Ship type                                                                       \n",
       "Cargo                   104332   104332            104332              104332   \n",
       "Dredging                   610      610               610                 610   \n",
       "Fishing                   1030     1030              1030                1030   \n",
       "HSC                         37       37                37                  37   \n",
       "Law enforcement            227      227               227                 227   \n",
       "Military                  1351     1351              1351                1351   \n",
       "Other                     1611     1611              1611                1611   \n",
       "Passenger                 5494     5494              5494                5494   \n",
       "Pilot                       33       33                33                  33   \n",
       "Pleasure                    37       37                37                  37   \n",
       "Sailing                     66       66                66                  66   \n",
       "Tanker                   44712    44712             44712               44712   \n",
       "Towing long/wide           155      155               155                 155   \n",
       "Tug                       1130     1130              1130                1130   \n",
       "\n",
       "                      se  global_path_id  \n",
       "Ship type                                 \n",
       "Cargo             104332          104332  \n",
       "Dredging             610             610  \n",
       "Fishing             1030            1030  \n",
       "HSC                   37              37  \n",
       "Law enforcement      227             227  \n",
       "Military            1351            1351  \n",
       "Other               1611            1611  \n",
       "Passenger           5494            5494  \n",
       "Pilot                 33              33  \n",
       "Pleasure              37              37  \n",
       "Sailing               66              66  \n",
       "Tanker             44712           44712  \n",
       "Towing long/wide     155             155  \n",
       "Tug                 1130            1130  "
      ]
     },
     "execution_count": 173,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_per_node.groupby('Ship type').count()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 174,
   "id": "33e83665-4eaf-4a51-bc29-407f711d7902",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(160825, 16)"
      ]
     },
     "execution_count": 174,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_per_node.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 175,
   "id": "aea51e09-6531-446e-9b8a-3b5169bb6baf",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_222356/4271976846.py:1: 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",
      "  df_nodes_useful['Node_new'] = np.arange(len(df_nodes_useful))\n"
     ]
    }
   ],
   "source": [
    "df_nodes_useful['Node_new'] = np.arange(len(df_nodes_useful))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 176,
   "id": "9e633300-f3f6-401e-808e-b3a6e4c3210d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# CREATE NODES AND EDGES, SAVE PATHS, SAVE NODES, SAVE EDGES"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 177,
   "id": "aa275990-ca39-4977-9a15-018303c5f02a",
   "metadata": {},
   "outputs": [],
   "source": [
    "dict_map_nodes = dict(zip(df_nodes_useful['Node'], df_nodes_useful['Node_new']))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 178,
   "id": "1475e556-cc09-4b0c-ab4a-0e516ea122bf",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_per_node['Node_new'] = df_per_node['Node'].map(dict_map_nodes)\n",
    "df_nodes['Node_new'] = df_nodes['Node'].map(dict_map_nodes)\n",
    "df_nodes_useful = df_nodes_useful.sort_values(by='Node_new')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 179,
   "id": "938d9650-8ba0-4da3-8f25-f90de3c3e88d",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "def replace_values_with_dict(arr, replace_dict):\n",
    "    vectorized_replace = np.vectorize(lambda x: replace_dict.get(x, x))\n",
    "    return vectorized_replace(arr)\n",
    "\n",
    "def concatenate_and_remove_duplicated_rows(arr1, arr2):\n",
    "    concatenated_array = np.concatenate((arr1, arr2), axis=0)\n",
    "    unique_array = np.unique(concatenated_array, axis=0)\n",
    "    return unique_array"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7a79e0d5-f7e1-4927-a753-f22da23bfe01",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 180,
   "id": "0d1f3a19-3a0f-4301-8a2e-23f4acbed50d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(61, 83)"
      ]
     },
     "execution_count": 180,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(n_rows_grid, n_cols_grid)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 181,
   "id": "9005654b-f007-427c-8c52-c73a954e2692",
   "metadata": {},
   "outputs": [],
   "source": [
    "transition_matrix = []\n",
    "\n",
    "for n in range(0,n_rows_grid*n_cols_grid):\n",
    "    if n%n_cols_grid!=n_cols_grid-1:\n",
    "        transition_matrix.append([n, n+1])\n",
    "    if n%n_cols_grid!=0:\n",
    "        transition_matrix.append([n, n-1])\n",
    "    if n//n_cols_grid!=0:\n",
    "        transition_matrix.append([n, n-n_cols_grid])\n",
    "    if n//n_rows_grid!=n_cols_grid-1:\n",
    "        transition_matrix.append([n, n+n_cols_grid])\n",
    "transition_matrix =np.array(transition_matrix)\n",
    "transition_matrix = transition_matrix[np.isin(transition_matrix[:,0], df_nodes_useful.Node.tolist()) & np.isin(transition_matrix[:,1], df_nodes_useful.Node.tolist())]\n",
    "transitions = replace_values_with_dict(transition_matrix, dict_map_nodes)\n",
    "#transitions = transition_matrix"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 182,
   "id": "2faceb2d-a284-4250-8f66-7a96e68a179a",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_per_node = df_per_node.drop_duplicates(subset=['global_path_id','Node_new'], keep='first')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 183,
   "id": "7593b1de-5047-4bf4-8a2b-b571b5bcf9af",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_per_node['invalid_transition'] = ~((df_per_node.groupby('global_path_id').Node.diff().abs() == n_cols_grid) | (df_per_node.groupby('global_path_id').Node.diff().abs() == 1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 184,
   "id": "1c7c41ca-5aba-4cea-a894-7da2adb38b26",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2741"
      ]
     },
     "execution_count": 184,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_per_node.global_path_id.nunique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 185,
   "id": "3ce3b499-21cd-4c5b-9d13-9844b387149b",
   "metadata": {},
   "outputs": [],
   "source": [
    "useful_paths_transitions = df_per_node.global_path_id.unique()[(df_per_node.groupby('global_path_id').invalid_transition.sum() == 1)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 186,
   "id": "dd231a4b-1944-4c37-b4ca-3f01497e528b",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_per_node = df_per_node[df_per_node['global_path_id'].isin(useful_paths_transitions)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 187,
   "id": "fa18beaf-bccc-4303-9929-7f6498516106",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2472"
      ]
     },
     "execution_count": 187,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_per_node.global_path_id.nunique()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "246c3110-1f89-4e0a-bce2-cd3d62b4ab8b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 188,
   "id": "1248ee91-a03c-492b-bf40-0006c0992158",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.save('edges.npy', transitions)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 189,
   "id": "4a71caa8-45a8-42b5-83b4-1dc61615662c",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_nodes.to_csv('./nodes.csv', index=False)\n",
    "df_nodes_useful.to_csv('./nodes_useful.csv', index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b570abf2-61bf-473c-b79b-438f0c23fd7b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 190,
   "id": "fe3dd563-c1a1-40af-abd6-557c397cab3f",
   "metadata": {},
   "outputs": [],
   "source": [
    "df_per_node.to_csv('./processed_ship_data.csv', index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 191,
   "id": "b9c9b4a7-7393-4044-bb92-a86e95cc9289",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_222356/1378509797.py:5: 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",
      "  nodes_path_example['Node'] = pd.Categorical(nodes_path_example['Node'], categories=path_example, ordered=True)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7f7c37d84e80>"
      ]
     },
     "execution_count": 191,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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vmat/UzUL621P3Hvz4wxU8BngB+lvhgUERERERGRB2TXOX3GmL3GmPtZPM5s/blvt7VFRERERESkud0u+j4FrAElY8yXjTHvuXeAqTtgjDlsjPlT1D8Sugl8ZZe1RUREREREZBs7/XjnBvC7wH8CbgN/Avgo8DVjzPustS/dNfYQkLnr/88B/4O19sp2RYwxB4F7b/qy/e10REREREREBNjhos9a+wLwwl0/+rwx5jPAHwO/DPzwXb/LAh8G+oDHgT8PDDmWehb4ezvp8UGr1CpMZ6cjf59eS1PeLJNeTUPEXf9dxgBUa1UsNpH11FOY9ULsyXc99RRmvRB78l0vxJ5811NPYdYLsSff9ULsyXe9pPcE9XVAuzHWNvmX3++DGfPb1Bd1A9bazYgx7wP+M/Cj1tr/uM3jRb3T97lLly5x5kx0uOKDlFnPkC1mm45ZzC+yWl5lpHckMsfDZcydcdA8D6Rd66mnMOuF2JPveuopzHoh9uS7Xog9+a6nnsKsF2JPvuuF2JPveknv6Y6x/jEm9k5sO+5BefXVVzl79izAWWvtq9uNjzucPQ30AIPUv+v3Pay1LxhjMsBPAU0XfdbaBWDh7p8ZY+LpdBcm9k60dJJFRERERERc7frunfc4BpSA3Dbj+oCRmGuLiIiIiIjIPXa06DPGfM97nsaYdwE/BnzJWlszxgwaYwYajPsJYBT45k5qi4iIiIiIiLudfrzz08aYIvWbuSxQv3vnXwUKwN/aGvMo8Jwx5tPAFaAGvAf4i9Sz+n5j522LiIiIiIiIi50u+j5L/Tt5fwMYBhaB3wN+3lr7xtaYOeqxDj8I/DSQAm4Avwn8orV2aedti4iIiIiIiIudRjZ8gnrIerMxt4H/aSePLyIiIiIiIvGI+0YuIiIiIiIiEhAt+kRERERERBJMiz4REREREZEE06JPREREREQkwbToExERERERSTAt+kRERERERBJMiz4REREREZEE06JPREREREQkwbToExERERERSTAt+kRERERERBJMiz4REREREZEE6251AzvQA/DGG2+0ug8RERERERHv7loL9biMN9baB9fNA2CM+THgc63uQ0REREREpMV+3Fr7+e0GteOibwT4IJAGNlrcTlIcp76Q/nFgusW9yHfT3IRLcxMuzU24NDfh0tyES3MTrlbOTQ8wCXzVWru63eC2+3jn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\n",
      "text/plain": [
       "<Figure size 1080x720 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "id_global_sample = df_per_node.global_path_id.sample().iloc[0]\n",
    "path_example = df_per_node[df_per_node['global_path_id'] == id_global_sample].Node.tolist()\n",
    "nodes_path_example = df_nodes_useful[df_nodes_useful.Node.isin(path_example)]\n",
    "\n",
    "nodes_path_example['Node'] = pd.Categorical(nodes_path_example['Node'], categories=path_example, ordered=True)\n",
    "nodes_path_example = nodes_path_example.sort_values('Node')\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(9,6), dpi=120)\n",
    "ax.scatter(df_nodes['nxc'],df_nodes['nyc'],s=32, c='green', marker='s', alpha=0.2)\n",
    "ax.scatter(df_nodes_useful['nxc'],df_nodes_useful['nyc'],s=32, marker='s',c='blue', alpha=0.5)\n",
    "#ax.scatter(nodes_path_example['nxc'],nodes_path_example['nyc'],c='red',s=5)\n",
    "\n",
    "for p in range(len(nodes_path_example)-1):\n",
    "    ax.plot(nodes_path_example['nxc'][p:p+2],nodes_path_example['nyc'][p:p+2],c='red')\n",
    "\n",
    "ax.scatter(nodes_path_example.iloc[[0,-1]]['nxc'],nodes_path_example.iloc[[0,-1]]['nyc'],c='black',s=20)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "acf259fd-5ad5-47f4-b610-18becfa1a954",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "pao_env",
   "language": "python",
   "name": "pao_env"
  },
  "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.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
