\section{Correctness: A Brief Summary}\label{sec:correctness}

In this section, we briefly discuss the correctness of the algorithm from data independence (Section~\ref{sec:correctness:init_update}), unbiasedness (Section~\ref{sec:correctness:unbiasedness_query}) and variance (Section~\ref{sec:correctness:variance_query}) aspects.


\subsection{Data Independence of \textsc{Initialize} and \textsc{Update}.}\label{sec:correctness:init_update}

We will show that procedure \textsc{Initialize} is independent of the input data. Hence, it is convenient for procedure \textsc{Update} to change only a small part of the stored data, without re-initializing the whole data structure.
For \textsc{Initialize}, it first samples data points by doing $n$ rounds of Bernoulli trials on each data point (Algorithm~\ref{alg:dynamic_KDE_initialize}, line~\ref{lin:sample}). Then it invokes \textsc{LSH.Initialize} to hash the sampled data points into some buckets, which will be stored into an LSH instance $\mathcal{H}_{a,r}$ (Algorithm~\ref{alg:dynamic_KDE_initialize}, Line~\ref{lin:instance_LSH}).
For \textsc{Update}, it finds the bucket where the old data point is hashed (Algorithm~\ref{alg:LSH_public_app}, Line~\ref{lin:update_hashtable} and  Line~\ref{lin:insert}) and replaces it with the new one. Thus procedure \textsc{Update} maintains the initialized structure.

 
\subsection{Unbiasedness of \textsc{Query}}\label{sec:correctness:unbiasedness_query}
 


We now present %prove
the unbiasedness of the estimator (up to some inverse polynomial error).

 

\begin{lemma}[unbiasedness of the \textsc{Query}, informal version of Lemma~\ref{lem:unbias_query_formal}]\label{lem:unbias_query}
Given $f_{\mathsf{KDE}}^{*} \in(0,1)$, $f_{\mathsf{KDE}} \geq f_{\mathsf{KDE}}^{*}$, $\epsilon \in(f_{\mathsf{KDE}}^{10}, 1)$ and $q \in \mathbb{R}^{d}$, we claim that estimator $T_{a}$ for any $a \in[K_{1}]$ constructed in line~\ref{lin:output_Z_a} Algorithm~\ref{alg:dynamic_KDE_query} satisfies $(1-n^{-9}) n f_{\mathsf{KDE}}^{*} \leq \E[T_{a}] \leq n f_{\mathsf{KDE}}^{*}$.
\end{lemma}

\subsection{Variance Bound for \textsc{Query}}\label{sec:correctness:variance_query}

 


We present the variance bound of our estimator.
 

\begin{lemma}[Variance bound for \textsc{Query}, informal version of Lemma~\ref{lem:variance_query_formal}]\label{lem:variance_query}
Given $f_{\mathsf{KDE}}^{*} \in(0,1)$, $f_{\mathsf{KDE}}/4 \leq f_{\mathsf{KDE}}^{*} \leq f_{\mathsf{KDE}}$, $\epsilon \in(f_{\mathsf{KDE}}^{10}, 1)$ and $q \in \mathbb{R}^{d}$, 
 
\textsc{Query} can output a $(1 \pm \epsilon)$-factor approximation to $f_{\mathsf{KDE}}^{*}$.
\end{lemma}


