1
0
Fork 0

Merge branch 'develop' into main

This commit is contained in:
Alexander Hess 2020-12-14 13:41:18 +01:00
commit 9ee3396a24
Signed by: alexander
GPG key ID: 344EA5AB10D868E0
20 changed files with 45 additions and 195 deletions

View file

@ -6,5 +6,5 @@ to generate the academic paper
based on the
[urban-meal-delivery](https://github.com/webartifex/urban-meal-delivery)
research project.
The paper is accepted for publication by the journal
The paper is [published](https://authors.elsevier.com/a/1cCON4sj-4lyZW) in the journal
[Transportation Research Part E: Logistics and Transportation Review](https://www.journals.elsevier.com/transportation-research-part-e-logistics-and-transportation-review).

BIN
paper.pdf

Binary file not shown.

View file

@ -52,8 +52,6 @@
\newpage
\input{tex/apx/peak_results}
\newpage
\input{tex/apx/glossary}
\newpage
\bibliographystyle{static/elsarticle-harv}
\bibliography{tex/references}

BIN
paper_published_in_tre.pdf Normal file

Binary file not shown.

View file

@ -11,8 +11,7 @@ A common feature of these platforms is that they do not operate kitchens but
related processes in simple smartphone apps, and managing the delivery via
a fleet of either employees or crowd-sourced sub-contractors.
Various kinds of urban delivery platforms
(\gls{udp}; \ref{glossary} provides a glossary with all abbreviations)
Various kinds of urban delivery platforms (UDP)
have received attention in recent scholarly publications.
\cite{hou2018} look into heuristics to simultaneously optimize courier
scheduling and routing in general, while \cite{masmoudi2018} do so
@ -20,8 +19,7 @@ Various kinds of urban delivery platforms
the effect of different fulfillment strategies in the context of urban
meal delivery.
\cite{ehmke2018} and \cite{alcaraz2019} focus their research on the routing
aspect, which is commonly modeled as a so-called vehicle routing problem
(\gls{vrp}).
aspect, which is commonly modeled as a so-called vehicle routing problem (VRP).
Not covered in the recent literature is research focusing on the demand
forecasting problem a UDP faces.
@ -69,7 +67,7 @@ In this paper, we develop a rigorous methodology as to how to build and
We implement such a system with a broad set of commonly used forecasting
methods.
We not only apply established (i.e., "classical") time series methods but also
machine learning (\gls{ml}) models that have gained traction in recent
machine learning (ML) models that have gained traction in recent
years due to advancements in computing power and availability of larger
amounts of data.
In that regard, the classical methods serve as benchmarks for the ML methods.

View file

@ -40,8 +40,7 @@ Their main advantages stem from the fact that the models calibrate themselves
\cite{cleveland1990} introduce a seasonal and trend decomposition using a
repeated locally weighted regression - the so-called Loess procedure - to
smoothen the trend and seasonal components, which can be viewed as a
generalization of the methods above and is denoted by the acronym
\gls{stl}.
generalization of the methods above and is denoted by the acronym STL.
In contrast to the X11, X13, and SEATS methods, the STL supports seasonalities
of any lag $k$ that must, however, be determined with additional
statistical tests or set with out-of-band knowledge by the forecaster

View file

@ -4,8 +4,7 @@
ML methods have been employed in all kinds of prediction tasks in recent
years.
In this section, we restrict ourselves to the models that performed well in
our study: Random Forest (\gls{rf}) and Support Vector Regression
(\gls{svr}).
our study: Random Forest (RF) and Support Vector Regression (SVR).
RFs are in general well-suited for datasets without a priori knowledge about
the patterns, while SVR is known to perform well on time series data, as
shown by \cite{hansen2006} in general and \cite{bao2004} specifically for

View file

@ -5,7 +5,7 @@ Because ML models are trained by minimizing a loss function $L$, the
resulting value of $L$ underestimates the true error we see when
predicting into the actual future by design.
To counter that, one popular and model-agnostic approach is cross-validation
(\gls{cv}), as summarized, for example, by \cite{hastie2013}.
(CV), as summarized, for example, by \cite{hastie2013}.
CV is a resampling technique, which ranomdly splits the samples into a
training and a test set.
Trained on the former, an ML model makes forecasts on the latter.

View file

@ -2,7 +2,7 @@
\label{rf}
\cite{breiman1984} introduce the classification and regression tree
(\gls{cart}) model that is built around the idea that a single binary
(CART) model that is built around the idea that a single binary
decision tree maps learned combinations of intervals of the feature
columns to a label.
Thus, each sample in the training set is associated with one leaf node that

View file

@ -2,7 +2,7 @@
\label{svm}
\cite{vapnik1963} and \cite{vapnik1964} introduce the so-called support vector
machine (\gls{svm}) model, and \cite{vapnik2013} summarizes the research
machine (SVM) model, and \cite{vapnik2013} summarizes the research
conducted since then.
In its basic version, SVMs are linear classifiers, modeling a binary
decision, that fit a hyperplane into the feature space of $\mat{X}$ to

View file

@ -41,7 +41,7 @@ These numerical instabilities occurred so often in our studies that we argue
against using such measures.
\item \textbf{Scaled Errors}:
\cite{hyndman2006} contribute this category and introduce the mean absolute
scaled error (\gls{mase}).
scaled error (MASE).
It is defined as the MAE from the actual forecasting method on the test day
(i.e., "out-of-sample") divided by the MAE from the (seasonal) na\"{i}ve
method on the entire training set (i.e., "in-sample").

View file

@ -15,21 +15,21 @@ As the models in this family do not include the test day's demand data in
The models in this family are as follows; we use prefixes, such as "h" here,
when methods are applied in other families as well:
\begin{enumerate}
\item \textit{\gls{naive}}:
\item \textit{naive}:
Observation from the same time step one week prior
\item \textit{\gls{trivial}}:
\item \textit{trivial}:
Predict $0$ for all time steps
\item \textit{\gls{hcroston}}:
\item \textit{hcroston}:
Intermittent demand method introduced by \cite{croston1972}
\item \textit{\gls{hholt}},
\textit{\gls{hhwinters}},
\textit{\gls{hses}},
\textit{\gls{hsma}}, and
\textit{\gls{htheta}}:
\item \textit{hholt},
\textit{hhwinters},
\textit{hses},
\textit{hsma}, and
\textit{htheta}:
Exponential smoothing without calibration
\item \textit{\gls{hets}}:
\item \textit{hets}:
ETS calibrated as described by \cite{hyndman2008b}
\item \textit{\gls{harima}}:
\item \textit{harima}:
ARIMA calibrated as described by \cite{hyndman2008a}
\end{enumerate}
\textit{naive} and \textit{trivial} provide an absolute benchmark for the

View file

@ -16,17 +16,17 @@ By decomposing the raw time series, all long-term patterns are assumed to be
a potential trend and auto-correlations.
The models in this family are:
\begin{enumerate}
\item \textit{\gls{fnaive}},
\textit{\gls{pnaive}}:
\item \textit{fnaive},
\textit{pnaive}:
Sum of STL's trend and seasonal components' na\"{i}ve forecasts
\item \textit{\gls{vholt}},
\textit{\gls{vses}}, and
\textit{\gls{vtheta}}:
\item \textit{vholt},
\textit{vses}, and
\textit{vtheta}:
Exponential smoothing without calibration and seasonal
fit
\item \textit{\gls{vets}}:
\item \textit{vets}:
ETS calibrated as described by \cite{hyndman2008b}
\item \textit{\gls{varima}}:
\item \textit{varima}:
ARIMA calibrated as described by \cite{hyndman2008a}
\end{enumerate}
As mentioned in Sub-section \ref{unified_cv}, we include the sum of the

View file

@ -8,13 +8,13 @@ Instead of obtaining an $H$-step-ahead forecast, we retrain a model after
every time step and only predict one step.
The remainder is as in the previous sub-section, and the models are:
\begin{enumerate}
\item \textit{\gls{rtholt}},
\textit{\gls{rtses}}, and
\textit{\gls{rttheta}}:
\item \textit{rtholt},
\textit{rtses}, and
\textit{rttheta}:
Exponential smoothing without calibration and seasonal fit
\item \textit{\gls{rtets}}:
\item \textit{rtets}:
ETS calibrated as described by \cite{hyndman2008b}
\item \textit{\gls{rtarima}}:
\item \textit{rtarima}:
ARIMA calibrated as described by \cite{hyndman2008a}
\end{enumerate}
Retraining \textit{fnaive} and \textit{pnaive} did not increase accuracy, and

View file

@ -10,7 +10,7 @@ Based on the seasonally-adjusted time series $a_t$, we employ the feature
The ML models are trained once before a test day starts.
For training, the matrix and vector are populated such that $y_T$ is set to
the last time step of the day before the forecasts, $a_T$.
As the splitting during CV is done with whole days, the \gls{ml} models are
As the splitting during CV is done with whole days, the ML models are
trained with training sets consisting of samples from all times of a day
in an equal manner.
Thus, the ML models learn to predict each time of the day.
@ -20,8 +20,8 @@ For prediction on a test day, the $H$ observations preceding the time
As a result, real-time data are included.
The models in this family are:
\begin{enumerate}
\item \textit{\gls{vrfr}}: RF trained on the matrix as described
\item \textit{\gls{vsvr}}: SVR trained on the matrix as described
\item \textit{vrfr}: RF trained on the matrix as described
\item \textit{vsvr}: SVR trained on the matrix as described
\end{enumerate}
We tried other ML models such as gradient boosting machines but found
only RFs and SVRs to perform well in our study.

View file

@ -2,7 +2,7 @@
\label{overall_results}
Table \ref{t:results} summarizes the overall best-performing models grouped by
training horizon and a pixel's average daily demand (\gls{add}) for a
training horizon and a pixel's average daily demand (ADD) for a
pixel size of $1~\text{km}^2$ and 60-minute time steps.
Each combination of pixel and test day counts as one case, and the total
number of cases is denoted as $n$.

View file

@ -19,11 +19,11 @@ Thus, we suggest conducting more detailed analyses on how to incorporate model
Future research should also integrate our forecasting system into a predictive
routing application and evaluate its business impact.
This embeds our research into the vast literature on the VRP.
Initially introduced by \cite{dantzig1959}, \gls{vrp}s are concerned with
Initially introduced by \cite{dantzig1959}, VRPs are concerned with
finding optimal routes serving customers.
We refer to \cite{toth2014} for a comprehensive overview.
The two variants relevant for the UDP case are the dynamic VRP and
the pickup and delivery problem (\gls{pdp}).
the pickup and delivery problem (PDP).
A VRP is dynamic if the data to solve a problem only becomes available
as the operations are underway.
\cite{thomas2010}, \cite{pillac2013}, and \cite{psaraftis2016} describe how
@ -39,7 +39,7 @@ Forecasts by our system extend this idea naturally as dummy nodes could be
The concrete case of a meal delivering UDP is contained in a recent
literature stream started by \cite{ulmer2017} and extended by
\cite{reyes2018} and \cite{yildiz2018}: They coin the term meal delivery
routing problem (\gls{mdrp}).
routing problem (MDRP).
The MDRP is a special case of the dynamic PDP where the defining
characteristic is that once a vehicle is scheduled, a modification of the
route is inadmissible.

View file

@ -1,144 +0,0 @@
\section{Glossary}
\label{glossary}
% Abbreviations for technical terms.
\newglossaryentry{add}{
name=ADD, description={Average Daily Demand}
}
\newglossaryentry{cart}{
name=CART, description={Classification and Regression Trees}
}
\newglossaryentry{cv}{
name=CV, description={Cross Validation}
}
\newglossaryentry{mase}{
name=MASE, description={Mean Absolute Scaled Error}
}
\newglossaryentry{mdrp}{
name=MDRP, description={Meal Delivery Routing Proplem}
}
\newglossaryentry{ml}{
name=ML, description={Machine Learning}
}
\newglossaryentry{pdp}{
name=PDP, description={Pickup and Delivery Problem}
}
\newglossaryentry{rf}{
name=RF, description={Random Forest}
}
\newglossaryentry{stl}{
name=STL, description={Seasonal and Trend Decomposition using Loess}
}
\newglossaryentry{svm}{
name=SVM, description={Support Vector Machine}
}
\newglossaryentry{svr}{
name=SVR, description={Support Vector Regression}
}
\newglossaryentry{udp}{
name=UDP, description={Urban Delivery Platform}
}
\newglossaryentry{vrp}{
name=VRP, description={Vehicle Routing Problem}
}
% Model names.
\newglossaryentry{naive}{
name=naive, description={(Seasonal) Na\"{i}ve Method}
}
\newglossaryentry{fnaive}{
name=fnaive, description={"Flexible" STL Decomposition,
with tuned ns parameter}
}
\newglossaryentry{pnaive}{
name=pnaive, description={"Periodic" STL Decomposition,
with ns parameter set to large number}
}
\newglossaryentry{trivial}{
name=trivial, description={Trivial Method}
}
\newglossaryentry{hcroston}{
name=hcroston, description={Croston's Method,
trained on horizontal time series}
}
\newglossaryentry{hholt}{
name=hholt, description={Holt's Linear Trend Method,
trained on horizontal time series}
}
\newglossaryentry{vholt}{
name=vholt, description={Holt's Linear Trend Method,
trained on vertical time series}
}
\newglossaryentry{rtholt}{
name=rtholt, description={Holt's Linear Trend Method,
(re)trained on vertical time series}
}
\newglossaryentry{hhwinters}{
name=hhwinters, description={Holt-Winter's Seasonal Method,
trained on horizontal time series}
}
\newglossaryentry{hses}{
name=hses, description={Simple Exponential Smoothing Method,
trained on horizontal time series}
}
\newglossaryentry{vses}{
name=vses, description={Simple Exponential Smoothing Method,
trained on vertical time series}
}
\newglossaryentry{rtses}{
name=rtses, description={Simple Exponential Smoothing Method,
(re)trained on vertical time series}
}
\newglossaryentry{hsma}{
name=hsma, description={Simple Moving Average Method,
trained on horizontal time series}
}
\newglossaryentry{htheta}{
name=htheta, description={Theta Method,
trained on horizontal time series}
}
\newglossaryentry{vtheta}{
name=vtheta, description={Theta Method,
trained on vertical time series}
}
\newglossaryentry{rttheta}{
name=rttheta, description={Theta Method,
(re)trained on vertical time series}
}
\newglossaryentry{hets}{
name=hets, description={ETS State Space Method,
trained on horizontal time series}
}
\newglossaryentry{vets}{
name=vets, description={ETS State Space Method,
trained on vertical time series}
}
\newglossaryentry{rtets}{
name=rtets, description={ETS State Space Method,
(re)trained on vertical time series}
}
\newglossaryentry{harima}{
name=harima, description={Autoregressive Integrated Moving Average
Method,
trained on horizontal time series}
}
\newglossaryentry{varima}{
name=varima, description={Autoregressive Integrated Moving Average
Method,
trained on vertical time series}
}
\newglossaryentry{rtarima}{
name=rtarima, description={Autoregressive Integrated Moving Average
Method,
(re)trained on vertical time series}
}
\newglossaryentry{vrfr}{
name=vrfr, description={Random Forest Regression Method,
trained on vertical time series}
}
\newglossaryentry{vsvr}{
name=vsvr, description={Support Vector Regression Method,
trained on vertical time series}
}
\printglossary[title=]

View file

@ -1,7 +1,7 @@
\begin{frontmatter}
\journal{Transportation Research Part E}
\title{Real-time Demand Forecasting for an Urban Delivery Platform}
\title{Real-time demand forecasting for an urban delivery platform}
\author[WHU]{Alexander Hess\fnref{emails}\fnref{corresponding}}
\author[WHU]{Stefan Spinler\fnref{emails}}

View file

@ -1,12 +1,12 @@
% Use the document width more effectively.
\usepackage[margin=2.5cm]{geometry}
\usepackage[acronym]{glossaries}
\makeglossaries
% Enable captions for figures and tables.
\usepackage{caption}
% Enable math formulae.
\usepackage{amsmath}
% Enable diagonal lines in tables.
\usepackage{static/slashbox}