{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import glob\n",
    "from tqdm import tqdm\n",
    "import os\n",
    "import numpy as np\n",
    "import holidays\n",
    "from datetime import datetime, timezone, timedelta"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import math\n",
    "\n",
    "def haversine_distance(lat1, lon1, lat2, lon2):\n",
    "    R = 6371.0  # Radius of the Earth in kilometers\n",
    "\n",
    "    dlat = math.radians(lat2 - lat1)\n",
    "    dlon = math.radians(lon2 - lon1)\n",
    "\n",
    "    a = (math.sin(dlat / 2) ** 2 +\n",
    "         math.cos(math.radians(lat1)) * math.cos(math.radians(lat2)) *\n",
    "         math.sin(dlon / 2) ** 2)\n",
    "    c = 2 * math.atan2(math.sqrt(a), math.sqrt(1 - a))\n",
    "\n",
    "    distance = R * c\n",
    "    return distance\n",
    "\n",
    "def compute_distance(group):\n",
    "    first_row = group.iloc[0]\n",
    "    last_row = group.iloc[-1]\n",
    "    return haversine_distance(first_row['0'], first_row['1'], last_row['0'], last_row['1'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "us_holidays = holidays.US(years=datetime.now().year, state='CA')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████| 536/536 [04:01<00:00,  2.22it/s]\n"
     ]
    }
   ],
   "source": [
    "data_path = './../data_cabspotting/'\n",
    "\n",
    "file_paths = glob.glob(data_path + 'processed_*.csv')\n",
    "\n",
    "dfs = []\n",
    "\n",
    "for file_path in tqdm(file_paths):\n",
    "    if os.path.exists(file_path):\n",
    "        df = pd.read_csv(file_path)\n",
    "        df = df[df['trip_id'] > -0.5]\n",
    "        df = df.sort_values(by=['trip_id', '3'])\n",
    "        distances = df.groupby('trip_id').apply(compute_distance).reset_index()\n",
    "        distances.columns = ['trip_id', 'distance_end_start']\n",
    "        timespent = df.groupby('trip_id')['time_diff'].sum().reset_index()\n",
    "        timespent.columns = ['trip_id', 'time_spent']\n",
    "        distance_total = df.groupby('trip_id')['distance_km'].sum().reset_index()\n",
    "        distance_total.columns = ['trip_id', 'distance_total']\n",
    "\n",
    "        \n",
    "        df = df.drop(columns=['0', '1'])\n",
    "        df['count'] = df.groupby('trip_id')[['trip_id']].transform('count')  \n",
    "        df = df.drop_duplicates(subset=['trip_id','driver'], keep='first')\n",
    "        df = df.merge(distances, on=['trip_id'], how='left')\n",
    "        df = df.merge(timespent, on=['trip_id'], how='left')\n",
    "        df = df.merge(distance_total, on=['trip_id'], how='left')\n",
    "        \n",
    "        df['3'] = pd.to_datetime(df['3'])\n",
    "        df['date_start'] = df['3'].dt.date\n",
    "        df['time_start'] = df['3'].apply(lambda x: x.hour * 60 + x.minute)\n",
    "        df['day_of_Week'] = df['3'].dt.weekday\n",
    "\n",
    "        # Check if the date is a holiday and convert to integer\n",
    "        df['is_Holiday'] = df['date_start'].apply(lambda x: int(x in us_holidays))\n",
    "        \n",
    "        \n",
    "        dfs.append(df)\n",
    "        \n",
    "df_full = pd.concat(dfs, axis=0, ignore_index=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_full = df_full.drop(columns=['3','distance_km'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_full['time_spent'] = np.where((df_full['time_spent']<-1400) & (df_full['time_spent']>-1440), \n",
    "                            df_full['time_spent'] + 1440, \n",
    "                            df_full['time_spent'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(1580965, 12)"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_full.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_full.to_csv('features_per_trip.csv', index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_full = pd.read_csv('features_per_trip.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_full = df_full[df_full['time_spent']>60*3]\n",
    "df_full = df_full[df_full['time_spent']<60*120]\n",
    "\n",
    "df_full = df_full[df_full['distance_total']/df_full['time_spent'] > (7/3600)]\n",
    "df_full = df_full[df_full['distance_total']/df_full['time_spent'] < (150/3600)]\n",
    "\n",
    "df_full = df_full[df_full['distance_total']/df_full['count'] < 2.5]\n",
    "\n",
    "df_full = df_full[df_full['count'] > 3.5]\n",
    "\n",
    "df_full = df_full[df_full['distance_end_start']/df_full['distance_total'] > 0.2]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(752341, 12)"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_full.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_full.to_csv('features_per_trip_clean.csv', index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_full = pd.read_csv('features_per_trip_clean.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "f1 = df_full['time_spent'] >= 60*5\n",
    "f3 = df_full['distance_total'] >= 1\n",
    "df_full = df_full[df_full['count'] > 10]\n",
    "#f4 = df_full['distance_km']/df_full['time_spent'] >= 0.15"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_52881/3448802588.py:1: UserWarning: Boolean Series key will be reindexed to match DataFrame index.\n",
      "  df_full = df_full[f1 & f3]\n"
     ]
    }
   ],
   "source": [
    "df_full = df_full[f1 & f3]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(263106, 12)"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_full.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_full.to_csv('features_per_trip_useful.csv', index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_full = pd.read_csv('features_per_trip_useful.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot: >"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "(df_full['distance_total']/df_full['time_spent']).hist(bins=30)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot: >"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "(df_full['distance_total']/df_full['count']).hist(bins=30)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot: >"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_full['distance_total'].hist(bins=50)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot: >"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_full['count'].hist(bins=50)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<AxesSubplot: >"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "df_full['time_spent'].hist(bins=29)"
   ]
  }
 ],
 "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": 4
}
