\label{section:expirements}

In this section, a commonly used neural ODE academic example~\cite{lopez2023nnv,lopez2022reachabilityanalysisgeneralclass} is used to demonstrate the verification proxy between the two models, which is the Fixed-Point Attractor (FPA)~\cite{musau2018continuous} that consists of one nonlinear neural ODE. 

\noindent \textbf{Experiment Setting:} All the experiments\footnote{Code available in the following repository: \url{https://github.com/ab-sayed/Formal-Error-Bound-for-Safety-Verification-of-neural-ODE}} herein are run on MATLAB 2024b with Continuous Reachability Analyzer (CORA) version 2024.4.0 with an Intel (R) Core (TM) i5-1145G7 CPU@2.60 GHz and 32 GB of RAM. 

\subsection{System description}
\label{subsect:system desc}

The FPA system is a nonlinear dynamical system with dynamics that converge to a fixed point (an equilibrium state) under certain conditions~\cite{beer1995dynamics}, and the fixed-point aspect makes it a useful model for studying convergence and stability, which are important in safety-critical applications where the system must not diverge or enter unsafe states.
As in the proposed benchmark in~\cite{musau2018continuous}, we consider here the following $5$-dimensional neural ODE approximating the FPA dynamics:
$$\dot{x} = f(x) = \tau x + W \text{tanh}(x),$$
%
where $x \in \mathbb{R}^5$ is the state vector, $\tau=-10^{-6}$ is a time constant for the neurons, $W \in \mathbb{R}^{5\times5}$ is a composite weight matrix defined as
$W=\begin{pmatrix}0_{2\times 2} & A\\0_{3\times 2} & BA\end{pmatrix}$ with
$A=\begin{pmatrix}-1.20327 & -0.07202 & -0.93635\\1.18810 & -1.50015 & 0.93519\end{pmatrix}$ and
$B=\begin{pmatrix}1.21464 & -0.10502\\ 0.12023 & 0.19387\\ -1.36695 & 0.12201\end{pmatrix}$, and $\text{tanh}(x)$ is the hyperbolic tangent activation function applied element-wise to the state vector $x$. 

We choose our safety property defined by the input set $\mathcal{X}_{in}\approx[0.45,0.55]\times[0.72,0.88]\times[0.47,0.58]\times[0.19,0.24]\times[-0.64,-0.53]$ (its exact numerical values are provided in the code linked below) and the safe set $\mathcal{X}_{s} = [0.2, 0.6] \times [0.3, 0.85] \subset \mathbb{R}^{2}$, that only focuses on the projection of the state onto its first two dimensions, i.e., using an output function $h(x)=(x_{1}, x_{2})$.
In the case of the neural ODE, we thus want to verify that for all initial state $x(0)\in\mathcal{X}_{in}$, we have $h(x(1))\in\mathcal{X}_{s}$.


\subsection{Computing the error bound}
\label{subsect:error bound comp}

Using CORA~\cite{althoff2015introduction}, we compute the error bound $\Omega_{\varepsilon}(\mathcal{X}_{in})$ from Theorem~\ref{thm:error} as follows. First, we over-approximate the reachable tube of the neural ODE $\mathcal{R}^{\text{tube}}_{\text{neural ODE}}$ over the time interval $[0,1]$ as a sequence of zonotopes, where each zonotope corresponds to an intermediate time range. For each zonotope in the reachable tube, we bound the image of the error function~\eqref{eq:error function} by applying a discrete-time reachability analysis method at $t=1$. This results in a new zonotope that over-approximates the error set starting from that particular reachable tube zonotope. The total error set is thus guaranteed to be contained in the union of these error zonotopes across all time steps. To simplify its use in the safety verification experiments in Section~\ref{subsect:safety verif}, we compute the interval hull of this union, yielding a hyperrectangle that over-approximates $\textcolor{red}{\Omega_{\varepsilon}(\mathcal{X}_{in})}$ illustrated in Figure~\ref{fig:error} in red, and showing 20 error zonotopes in different colors, corresponding to the error bound of each intermediate time range used in the reachable tube.

\begin{figure}[htb]
    \centering
    % \includegraphics[width=\columnwidth]{figures/Interval of zonotopes.png}
    \includegraphics[width=\columnwidth]{figures/eps/error_bound_fig.eps}
    \caption{Illustration of the error over-approximation}
    \label{fig:error}
\end{figure}

\bigskip
To contextualize our proposed error bound, we compare it with the error bound proposed in~\cite{sander2022residualneuralnetworksdiscretize}. For that, we first compute the infinity norm of our error set $\|\Omega_{\varepsilon}(\mathcal{X}_{in})\|_{\infty}=0.064$, which corresponds to a positive and scalar bound on the error, thus implying that its set representation in the state space (represented in yellow in Figure~\ref{fig:error bound comparison}) is necessarily symmetrical around $0$ and with the width that is identical on all dimensions (since the infinity norm takes the largest width across all dimensions).
The set-based error bound ($\Omega_{\varepsilon}(\mathcal{X}_{in})$ represented in red) obtained from our method is thus always contained in this infinity norm.

Next, we compute the Lipschitz constant for the vector field of the neural ODE $L=\|\tau+W\|_\infty=3.62$, and then we obtain the error bound in~\cite{sander2022residualneuralnetworksdiscretize} as $\frac{(e^{L}-1)}{L} \|\Omega_{\varepsilon}(\mathcal{X}_{in})\|_{\infty}=0.64$. 
This final error bound, represented in magenta in Figure~\ref{fig:error bound comparison}, is 10 times wider (on each dimension) than the infinity norm of our error set in yellow, and about $16$ millions times larger (in volume over the $5$-dimensional state space) than our error set $\Omega_{\varepsilon}(\mathcal{X}_{in})$ in red.
The improved tightness of our proposed approach is therefore very significant.

\begin{figure}[htb]
    \centering
    % \includegraphics[width=\columnwidth]{figures/Interval of zonotopes.png}
    \includegraphics[width=\columnwidth]{figures/eps/error_bound_comparison_with_Sander_fig.eps}
    \caption{Comparison of the error bounds obtained from our approach in red and the one from~\cite{sander2022residualneuralnetworksdiscretize} in magenta}
    \label{fig:error bound comparison}
\end{figure}

\subsection{Experiments on safety verification}
\label{subsect:safety verif}

Using the error bound computed in Section~\ref{subsect:error bound comp}, we can verify safety properties for the neural ODE output set based on the ResNet output set and the error bound set (i.e., $\Omega_{\text{ResNet}}(\mathcal{X}_{in}) + \Omega_{\varepsilon}(\mathcal{X}_{in})$), or vice versa for the ResNet output set based on the neural ODE output set and the negative error bound set (i.e., $\Omega_{\text{neural ODE}}(\mathcal{X}_{in}) + \Omega_{-\varepsilon}(\mathcal{X}_{in})$).

In Figure~\ref{fig:ResNet to nODE}, we compute the over-approximation of the ResNet output set $\textcolor{blue}{\Omega_{\text{ResNet}}}$ using simple bound propagation through the ResNet function with CORA. By adding the error bound  $\Omega_{\varepsilon}$, we obtain a zonotope (shown in \textcolor{red}{red}) that is guaranteed to contain $\mathcal{R}_{\text{neural ODE}}(\mathcal{X}_{in})$. The figure also includes black points representing neural ODE outputs for random initial conditions in $\mathcal{X}_{in}$, with their convex hull (black set) approximating the true reachable set $\mathcal{R}_{\text{neural ODE}}(\mathcal{X}_{in})$. Since the safe set $\textcolor{OliveGreen}{\mathcal{X}_s}$ contains the over-approximation $\textcolor{red}{\Omega_{\text{ResNet}}(\mathcal{X}_{in}) + \Omega_{\varepsilon}(\mathcal{X}_{in})}$, we guarantee that the neural ODE true reachable set is safe, as:
$$\textcolor{OliveGreen}{\mathcal{X}_s}\supseteq\textcolor{red}{\Omega_{\text{ResNet}}(\mathcal{X}_{in}) + \Omega_{\varepsilon}(\mathcal{X}_{in})} \supseteq \mathcal{R}_{\text{neural ODE}}.$$

From Figure~\ref{fig:ResNet to nODE}, we can see that the ResNet and neural ODE reachable sets are very similar due to the ResNet role as a discretization of the neural ODE, but they are not identical. Indeed, some neural ODE outputs (black points) lie outside $\textcolor{blue}{\Omega_{\text{ResNet}}}$, highlighting the necessity of the error bound $\Omega_{\varepsilon}(\mathcal{X}_{in})$ to ensure that the over-approximation captures all possible neural ODE outputs.

\begin{figure}[htb]
    \centering
    \includegraphics[width=\columnwidth]{figures/eps/final/ResNet_to_nODE_comparison_with_Sander_fig.eps}
    \caption{Verification of neural ODE based on ResNet}
    \label{fig:ResNet to nODE}
\end{figure}


Conversely, in Figure~\ref{fig:nODE to ResNet}, we compute the over-approximation of the neural ODE reachable set $\textcolor{black}{\Omega_{\text{neural ODE}}(\mathcal{X}_{in})}$. By adding the negative error bound $\Omega_{-\varepsilon}$, we obtain a zonotope (shown in \textcolor{red}{red}) that encapsulates $\textcolor{blue}{\mathcal{R}_{\text{ResNet}}(\mathcal{X}_{in})}$. Similarly, the figure includes \textcolor{blue}{blue} points representing ResNet outputs for random inputs in $\mathcal{X}_{in}$, with their convex hull (\textcolor{blue}{blue} set) approximating the true reachable set $\textcolor{blue}{\mathcal{R}_{\text{ResNet}}(\mathcal{X}_{in})}$. Since the safe set $\textcolor{OliveGreen}{\mathcal{X}_s}$ is a super set that contains the over-approximation $\textcolor{red}{\Omega_{\text{neural ODE}}(\mathcal{X}_{in}) + \Omega_{-\varepsilon}(\mathcal{X}_{in})}$, we guarantee that the ResNet true reachable set is safe, as:
$$\textcolor{OliveGreen}{\mathcal{X}_s}\supseteq\textcolor{red}{\Omega_{\text{neural ODE}}(\mathcal{X}_{in}) + \Omega_{-\varepsilon}(\mathcal{X}_{in})} \supseteq \textcolor{blue}{\mathcal{R}_{\text{ResNet}}}.$$


\begin{figure}[htb]
    \centering
    \includegraphics[width=\columnwidth]{figures/eps/final/nODE_to_ResNet_comparison_with_Sander_fig.eps}
    \caption{Verification of ResNet based on neural ODE}
    \label{fig:nODE to ResNet}
\end{figure}

We can also remark that the \textcolor{Magenta}{magenta sets} obtained by adding the error bound proposed in~\cite{sander2022residualneuralnetworksdiscretize} to the ResNet and neural ODE reachable sets in Figures~\ref{fig:ResNet to nODE} and~\ref{fig:nODE to ResNet}, extends significantly beyond the green safe set, preventing us from successfully guaranteeing the safety of the models.
