\section{Experiments}

\subsection{Hyperparameters Used}
\label{sec:hyperparams}

The hyperparameters for the conventional XGBoost models are detailed in Table \ref{tab:hyperparams},
obtained from the grid-search conducted in the tabular data benchmark 
\citep{dt-better-than-nn}. The hyperparameters for the robust XGBoost models 
were further tuned using these as a starting point.

\begin{table}[!ht]
    \centering
    \caption{Details of the hyperparameters used in the experiments, obtained from the hyperparameter tuning conducted in the tabular data benchmark presented in \cite{dt-better-than-nn}. The number of trees was restricted to 100 for all experiments due to computational constraints of the MILP based solver used to compute the robust metrics.}
    \label{tab:hyperparams}
    {\fontsize{9}{10}\selectfont
    \begin{tabular}{@{}cccccccc@{}}
    \toprule
    dataset                   & No. of Trees & Max Depth & $\gamma$  & Learning Rate & Minimum samples per Leaf & $\lambda$ \\ \midrule
cpu\_act                  & 100           & 9          & 0.0011 & 0.0272         & 5                  & 2.978       \\
pol                       & 100           & 11         & 0.0000 & 0.0272         & 4                  & 2.525       \\
elevators                 & 100           & 7          & 0.0000 & 0.0407         & 18                 & 1.297       \\
wine\_quality             & 100           & 11         & 0.0000 & 0.0118         & 2                  & 1.417       \\
Ailerons                  & 100           & 7          & 0.0000 & 0.0219         & 77                 & 1.515       \\
houses                    & 100           & 10         & 0.0001 & 0.0319         & 2                  & 3.303       \\
house\_16H                & 100           & 11         & 0.0002 & 0.0044         & 3                  & 3.183       \\
diamonds                  & 100           & 5          & 0.0003 & 0.0635         & 4                  & 2.056       \\
Brazilian\_houses         & 100           & 4          & 0.0000 & 0.0722         & 1                  & 3.204       \\
Bike\_Sharing\_Demand     & 100           & 9          & 0.0000 & 0.0143         & 3                  & 1.660       \\
nyc-taxi-green-dec-2016   & 100           & 3          & 0.1054 & 0.2163         & 2                  & 2.335       \\
house\_sales              & 100           & 11         & 0.2247 & 0.0222         & 1                  & 2.168       \\
sulfur                    & 100           & 6          & 0.0000 & 0.1523         & 2                  & 1.469       \\
medical\_charges          & 100           & 4          & 0.0236 & 0.0289         & 14                 & 1.516       \\
MiamiHousing2016          & 100           & 9          & 0.0310 & 0.0314         & 2                  & 3.226       \\
superconduct              & 100           & 10         & 0.0066 & 0.0173         & 15                 & 1.497       \\
yprop\_4\_1               & 100           & 11         & 0.0007 & 0.0119         & 1                  & 1.224       \\
abalone                   & 100           & 10         & 0.0000 & 0.0062         & 29                 & 1.415       \\
delays\_zurich\_transport & 100           & 10         & 0.0130 & 0.0061         & 24                 & 3.043       \\ \bottomrule
    \end{tabular}
    }
    \end{table}

\pagebreak
\subsection{Additional Results}
\label{sec:additional-results}

This section outlines the detailed results of the experiments described in Section \ref{sec:evaluation} for the $L_{\infty}$ adversarial attacks of radii $\epsilon = 0.005$, $\epsilon = 0.01$ and $\epsilon = 0.1$. 


\begin{table}[!ht]
    \caption{Comparisons of standard and robust regression metrics for an $L_{\infty}$ adversarial attack of radius $\epsilon = 0.005$. }
    \label{tab:summary_results_eps_0_005}
    {\fontsize{7.8}{10}\selectfont
    \begin{tabular}{@{}c|ccc|ccc|ccc|c|cc@{}}
    \toprule
    \multirow{2}{*}{Dataset} & \multicolumn{3}{c|}{ours} & \multicolumn{3}{c|}{RGBDT} & \multicolumn{3}{c|}{xgboost} & \multirow{2}{*}{$y_{\text{range}}$} & \multicolumn{2}{c}{$\text{MAD}_{\text{ratio}}$} \\
                             & $R^2$      & $R^2_{\text{rob}}$  & $\text{MAD}$ & $R^2$       & $R^2_{\text{rob}}$   & $\text{MAD}$   & $R^2$         & $R^2_{\text{rob}}$      & $\text{MAD}$      &                           & RGBDT             &        XGBoost       \\ \midrule
    Ailerons                  & 0.800    & 0.791         & 0.000          & 0.786        & 0.779             & 0.000              & 0.758                & 0.751                     & 0.000                      & 0.003    &         -              &    -                  \\
Bike\_Sharing\_Demand     & 0.706    & 0.697         & 1.122          & 0.710        & 0.707             & 0.414              & 0.613                & 0.608                     & 0.557                      & 410.200  & 0.369                 & 0.496                \\
Brazilian\_houses         & 0.935    & 0.876         & 0.154          & 0.944        & 0.668             & 0.396              & 0.986                & -0.997                    & 1.052                      & 4.776    & 2.571                 & 6.831                \\
MiamiHousing2016          & 0.876    & 0.827         & 0.067          & 0.878        & 0.805             & 0.089              & 0.865                & 0.771                     & 0.100                      & 3.533    & 1.328                 & 1.493                \\
abalone                   & 0.482    & 0.405         & 0.369          & 0.496        & 0.399             & 0.437              & 0.364                & 0.198                     & 0.597                      & 22.400   & 1.184                 & 1.618                \\
cpu\_act                  & 0.986    & 0.978         & 0.934          & 0.981        & 0.971             & 1.152              & 0.975                & 0.951                     & 1.801                      & 99.000   & 1.233                 & 1.928                \\
delays\_zurich\_transport & 0.137    & 0.133         & 0.011          & 0.134        & 0.077             & 0.171              & 0.101                & -0.047                    & 0.388                      & 10.272   & 15.545                & 35.273               \\
diamonds                  & 0.962    & 0.960         & 0.005          & 0.965        & 0.949             & 0.035              & 0.966                & 0.907                     & 0.108                      & 2.264    & 7.000                 & 21.600               \\
elevators                 & 0.866    & 0.842         & 0.000          & 0.869        & 0.825             & 0.001              & 0.822                & 0.781                     & 0.001                      & 0.057    & inf                   & inf                  \\
house\_16H                & 0.382    & 0.283         & 0.105          & 0.401        & 0.248             & 0.128              & 0.295                & -0.985                    & 0.682                      & 11.112   & 1.219                 & 6.495                \\
house\_sales              & 0.848    & 0.821         & 0.035          & 0.853        & 0.806             & 0.056              & 0.836                & 0.749                     & 0.087                      & 3.745    & 1.600                 & 2.486                \\
houses                    & 0.810    & 0.757         & 0.059          & 0.838        & 0.570             & 0.188              & 0.853                & 0.435                     & 0.237                      & 2.671    & 3.186                 & 4.017                \\
medical\_charges          & 0.813    & 0.729         & 0.067          & 0.906        & 0.649             & 0.139              & 0.908                & 0.625                     & 0.121                      & 1.852    & 2.075                 & 1.806                \\
nyc-taxi-green-dec-2016   & 0.304    & 0.127         & 0.124          & 0.357        & -0.174            & 0.265              & 0.440                & -0.592                    & 0.435                      & 3.270    & 2.137                 & 3.508                \\
pol                       & 0.986    & 0.974         & 1.784          & 0.985        & 0.961             & 2.786              & 0.976                & 0.945                     & 2.968                      & 100.000  & 1.562                 & 1.664                \\
sulfur                    & 0.897    & 0.830         & 0.008          & 0.909        & 0.813             & 0.012              & 0.909                & 0.546                     & 0.014                      & 0.861    & 1.500                 & 1.750                \\
superconduct              & 0.815    & 0.682         & 5.573          & 0.817        & 0.542             & 9.779              & 0.784                & -0.876                    & 30.349                     & 129.840  & 1.755                 & 5.446                \\
wine\_quality             & 0.429    & 0.319         & 0.105          & 0.432        & 0.230             & 0.176              & 0.390                & 0.136                     & 0.194                      & 5.400    & 1.676                 & 1.848                \\
yprop\_4\_1               & 0.067    & 0.050         & 0.000          & 0.062        & 0.038             & 0.001              & 0.049                & -0.719                    & 0.015                      & 0.149    & inf                   & inf                   \\ \bottomrule
    \end{tabular}
    }
    \end{table}

    \vspace{6em}

\begin{table}[!ht]
    \caption{Comparisons of standard and robust regression metrics for an $L_{\infty}$ adversarial attack of radius $\epsilon = 0.01$. }
    \label{tab:summary_results_eps_0_01}
    {\fontsize{7.8}{10}\selectfont
    \begin{tabular}{@{}c|ccc|ccc|ccc|c|cc@{}}
    \toprule
    \multirow{2}{*}{Dataset} & \multicolumn{3}{c|}{ours} & \multicolumn{3}{c|}{RGBDT} & \multicolumn{3}{c|}{xgboost} & \multirow{2}{*}{$y_{\text{range}}$} & \multicolumn{2}{c}{$\text{MAD}_{\text{ratio}}$} \\
                             & $R^2$      & $R^2_{\text{rob}}$  & $\text{MAD}$ & $R^2$       & $R^2_{\text{rob}}$   & $\text{MAD}$   & $R^2$         & $R^2_{\text{rob}}$      & $\text{MAD}$      &                           & RGBDT             &        XGBoost       \\ \midrule
    Ailerons                  & 0.800    & 0.753         & 0.000          & 0.785        & 0.723             & 0.000              & 0.758                & 0.703                     & 0.000                      & 0.003    &         -              &    -                  \\
Bike\_Sharing\_Demand     & 0.714    & 0.704         & 1.053          & 0.714        & 0.699             & 1.882              & 0.613                & 0.591                     & 2.460                      & 410.200  & 1.787                 & 2.336                \\
Brazilian\_houses         & 0.906    & 0.843         & 0.174          & 0.936        & 0.711             & 0.323              & 0.986                & -2.579                    & 1.459                      & 4.776    & 1.856                 & 8.385                \\
MiamiHousing2016          & 0.865    & 0.758         & 0.120          & 0.878        & 0.716             & 0.161              & 0.865                & 0.648                     & 0.186                      & 3.533    & 1.342                 & 1.550                \\
abalone                   & 0.470    & 0.355         & 0.477          & 0.493        & 0.304             & 0.730              & 0.364                & 0.053                     & 0.999                      & 22.400   & 1.530                 & 2.094                \\
cpu\_act                  & 0.985    & 0.974         & 1.195          & 0.981        & 0.961             & 1.875              & 0.975                & -1.275                    & 12.555                     & 99.000   & 1.569                 & 10.506               \\
delays\_zurich\_transport & 0.129    & 0.125         & 0.013          & 0.133        & 0.070             & 0.176              & 0.101                & -0.094                    & 0.501                      & 10.272   & 13.538                & 38.538               \\
diamonds                  & 0.960    & 0.941         & 0.016          & 0.965        & 0.922             & 0.068              & 0.966                & 0.843                     & 0.156                      & 2.264    & 4.250                 & 9.750                \\
elevators                 & 0.858    & 0.814         & 0.001          & 0.871        & 0.817             & 0.001              & 0.822                & 0.765                     & 0.001                      & 0.057    & 1.000                 & 1.000                \\
house\_16H                & 0.335    & 0.204         & 0.119          & 0.392        & 0.196             & 0.182              & 0.295                & -1.161                    & 0.738                      & 11.112   & 1.529                 & 6.202                \\
house\_sales              & 0.838    & 0.795         & 0.053          & 0.854        & 0.764             & 0.094              & 0.836                & 0.657                     & 0.145                      & 3.745    & 1.774                 & 2.736                \\
houses                    & 0.802    & 0.701         & 0.099          & 0.827        & 0.375             & 0.270              & 0.853                & 0.058                     & 0.370                      & 2.671    & 2.727                 & 3.737                \\
medical\_charges          & 0.682    & 0.547         & 0.088          & 0.899        & 0.257             & 0.226              & 0.908                & 0.204                     & 0.215                      & 1.852    & 2.568                 & 2.443                \\
nyc-taxi-green-dec-2016   & 0.241    & 0.044         & 0.130          & 0.354        & -1.261            & 0.620              & 0.440                & -1.396                    & 0.639                      & 3.270    & 4.769                 & 4.915                \\
pol                       & 0.983    & 0.949         & 3.782          & 0.984        & 0.942             & 4.080              & 0.976                & 0.923                     & 4.340                      & 100.000  & 1.079                 & 1.148                \\
sulfur                    & 0.888    & 0.724         & 0.012          & 0.876        & 0.589             & 0.019              & 0.909                & 0.099                     & 0.026                      & 0.861    & 1.583                 & 2.167                \\
superconduct              & 0.783    & 0.592         & 7.229          & 0.804        & 0.208             & 16.294             & 0.784                & -1.458                    & 37.067                     & 129.840  & 2.254                 & 5.128                \\
wine\_quality             & 0.395    & 0.187         & 0.175          & 0.426        & -0.017            & 0.322              & 0.390                & -0.164                    & 0.356                      & 5.400    & 1.840                 & 2.034                \\
yprop\_4\_1               & 0.070    & 0.042         & 0.001          & 0.071        & 0.018             & 0.001              & 0.049                & -0.951                    & 0.018                      & 0.149    & 1.000                 & 18.000                 \\ \bottomrule
    \end{tabular}
    }
\end{table}





\begin{table}[!ht]
        \caption{Comparisons of standard and robust regression metrics for an $L_{\infty}$ adversarial attack of radius $\epsilon = 0.1$. }
        \label{tab:summary_results_eps_0_1}
        {\fontsize{7.8}{10}\selectfont
        \begin{tabular}{@{}c|ccc|ccc|ccc|c|cc@{}}
        \toprule
        \multirow{2}{*}{Dataset} & \multicolumn{3}{c|}{ours} & \multicolumn{3}{c|}{RGBDT} & \multicolumn{3}{c|}{xgboost} & \multirow{2}{*}{$y_{\text{range}}$} & \multicolumn{2}{c}{$\text{MAD}_{\text{ratio}}$} \\
                                 & $R^2$      & $R^2_{\text{rob}}$  & $\text{MAD}$ & $R^2$       & $R^2_{\text{rob}}$   & $\text{MAD}$   & $R^2$         & $R^2_{\text{rob}}$      & $\text{MAD}$      &                           & RGBDT             &        XGBoost       \\ \midrule
    Ailerons                  & 0.562    & 0.025         & 0.000          & 0.726        & -0.399            & 0.000              & 0.758                & -0.431                    & 0.000                      & 0.003    &       -                &     -                 \\
Bike\_Sharing\_Demand     & 0.274    & -0.664        & 46.494         & 0.578        & -1.781            & 86.108             & 0.613                & -1.726                    & 78.848                     & 410.200  & 1.852                 & 1.696                \\
Brazilian\_houses         & 0.615    & 0.307         & 0.375          & 0.718        & -1.457            & 1.184              & 0.986                & -20.624                   & 3.674                      & 4.776    & 3.157                 & 9.797                \\
MiamiHousing2016          & 0.283    & -0.162        & 0.251          & 0.816        & -3.269            & 1.202              & 0.865                & -3.275                    & 1.191                      & 3.533    & 4.789                 & 4.745                \\
abalone                   & 0.111    & 0.042         & 0.299          & 0.331        & -0.241            & 1.555              & 0.364                & -1.346                    & 3.532                      & 22.400   & 5.201                 & 11.813               \\
cpu\_act                  & 0.964    & 0.862         & 5.382          & 0.981        & 0.746             & 8.559              & 0.975                & -16.530                   & 79.775                     & 99.000   & 1.590                 & 14.823               \\
delays\_zurich\_transport & -0.004   & -0.004        & 0.001          & 0.072        & -0.145            & 0.487              & 0.101                & -0.649                    & 1.315                      & 10.272   & 487.000               & 1315.000             \\
diamonds                  & 0.002    & -0.019        & 0.099          & 0.928        & -7.332            & 1.628              & 0.966                & -9.919                    & 1.857                      & 2.264    & 16.444                & 18.758               \\
elevators                 & 0.313    & -0.222        & 0.003          & 0.800        & -16.935           & 0.029              & 0.822                & -16.461                   & 0.028                      & 0.057    & 9.667                 & 9.333                \\
house\_16H                & 0.165    & -0.036        & 0.101          & 0.271        & -0.683            & 0.526              & 0.295                & -3.748                    & 1.371                      & 11.112   & 5.208                 & 13.574               \\
house\_sales              & 0.476    & 0.201         & 0.216          & 0.805        & -1.201            & 0.705              & 0.836                & -1.797                    & 0.775                      & 3.745    & 3.264                 & 3.588                \\
houses                    & 0.614    & 0.153         & 0.303          & 0.789        & -1.222            & 0.726              & 0.853                & -3.219                    & 1.039                      & 2.671    & 2.396                 & 3.429                \\
medical\_charges          & -0.290   & -0.297        & 0.021          & -0.115       & -13.729           & 0.942              & 0.908                & -13.566                   & 1.135                      & 1.852    & 44.857                & 54.048               \\
nyc-taxi-green-dec-2016   & 0.007    & -0.056        & 0.055          & 0.155        & -1.003            & 0.474              & 0.440                & -13.888                   & 2.193                      & 3.270    & 8.618                 & 39.873               \\
pol                       & 0.850    & -0.164        & 29.583         & 0.946        & -0.982            & 46.064             & 0.976                & -1.444                    & 54.829                     & 100.000  & 1.557                 & 1.853                \\
sulfur                    & 0.452    & -0.904        & 0.038          & 0.878        & -29.388           & 0.310              & 0.909                & -16.217                   & 0.219                      & 0.861    & 8.158                 & 5.763                \\
superconduct              & 0.206    & 0.033         & 5.157          & 0.640        & -2.533            & 43.676             & 0.784                & -4.386                    & 60.570                     & 129.840  & 8.469                 & 11.745               \\
wine\_quality             & 0.121    & -0.027        & 0.140          & 0.361        & -2.104            & 1.054              & 0.390                & -3.173                    & 1.288                      & 5.400    & 7.529                 & 9.200                \\
yprop\_4\_1               & 0.000    & -0.003        & 0.000          & 0.060        & -0.703            & 0.014              & 0.049                & -4.222                    & 0.047                      & 0.149    & inf                   & inf                    \\ \bottomrule
    \end{tabular}
    }
\end{table}


\clearpage
\subsection{Robustness Profile}


This section outlines the complete results of the comparison between 
the robustness profiles of the proposed method, to the exact robust
splitting criterion, and the heuristic presented in \cite{chen2019training}.

\begin{figure}[!htbp]
    \centering
    \includegraphics[width=\linewidth]{figures/exact_vs_lb_vs_heuristic.pdf}
    \caption{Comparison of the robustness profile of the models obtained 
    by our method, the heuristic from \cite{chen2019training}, 
    the same heuristic set with a relaxed perturbation radius, and an exact 
    solution to the robust splitting score from Equation \ref
    {eq:robust-splitting-criterion-exact}.}
    \label{fig:robustness-profile-full}
\end{figure}

\clearpage
\section{Analytical Solution to the Linear Relaxation of Robust Splitting Criterion}
\label{sec:appendix-analytical-solution}
We need to compute the robust splitting criterion:

\begin{equation}
    \label{eq:appendix-robust-splitting-criterion}
    \begin{split}
        \mathcal{S}_{\text{rob}}(\mathcal{I}_L^0, \mathcal{I}_R^0, \Delta \mathcal{I}) &\geq \mathcal{S}_{\text{rob}}^{\text{lb}} = \min_{p,q} \frac{1}{2}\Biggl[  \frac{\left(\sum_{i \in \mathcal{I}_L^0} g_i + p \right)^2}{\sum_{i \in \mathcal{I}_L^0} h_i + q + \lambda} \\[1ex]
        + & \frac{\left(\sum_{i \in \mathcal{I}_R^0} g_i + \sum_{i \in \Delta\mathcal{I}} g_i - p \right)^2}{\sum_{i \in \mathcal{I}_R^0} h_i + \sum_{i \in \Delta\mathcal{I}} h_i + \lambda} \\[1ex]
        - & \frac{\left(\sum_{i \in I} g_i\right)^2}{\sum_{i
    \in I} h_i + \lambda} \Biggr] - \gamma,
    \end{split}
\end{equation}

subject to the constraints:

\begin{equation}
    \label{eq:appendix-rob_constraints}
    \setlength{\jot}{10pt}
    \begin{gathered}
        p \in \left[\sum_{i \in
    \Delta \mathcal{I} } \min(0, g_i), \sum_{i \in \Delta
    \mathcal{I} } \max(0, g_i) \right], \\
    q \in \left[0,
            \sum_{i \in \Delta \mathcal{I} } h_i \right], \\
        p \leq q \cdot c_1, \\
        p \geq q \cdot c_2, \\
        p \geq G^{(\Delta \mathcal{I})} - c_1(H^{(\Delta \mathcal{I})} - q), \\
        p \leq G^{(\Delta \mathcal{I})} - c_2(H^{(\Delta
        \mathcal{I})} - q),\\
    \end{gathered}
\end{equation}\
where the parameters \(c_1\) and \(c_2\) are defined as follows:
\begin{equation}
    c_1 =
    \begin{cases}
    \tfrac{g_{\max}^{(\Delta\mathcal{I})}}{h_{\min}^{(\Delta\mathcal{I})}}, & g_{\max}^{(\Delta\mathcal{I})} \ge 0, \\[2ex]
    \tfrac{g_{\max}^{(\Delta\mathcal{I})}}{h_{\max}^{(\Delta\mathcal{I})}}, & g_{\max}^{(\Delta\mathcal{I})} < 0,
    \end{cases}
    \quad
    c_2 =
    \begin{cases}
    \tfrac{g_{\min}^{(\Delta\mathcal{I})}}{h_{\max}^{(\Delta\mathcal{I})}}, & g_{\min}^{(\Delta\mathcal{I})} \ge 0, \\[2ex]
    \tfrac{g_{\min}^{(\Delta\mathcal{I})}}{h_{\min}^{(\Delta\mathcal{I})}}, & g_{\min}^{(\Delta\mathcal{I})} < 0.
    \end{cases}
\end{equation}

The minimisation problem in Eq. \ref{eq:appendix-robust-splitting-criterion} can be
simplified, by only considering the contributions of the left and right child nodes 
to determine optimal values of $p$ and $q$, as the contribution of the parent 
node is constant and does not depend on the split.

\begin{equation}
  \label{eq:simplified-objective}
  f(p,q)=\frac{(A+p)^{2}}{C+q}+\frac{(B+T-p)^{2}}{D+Q-q}
\end{equation}

where we consider the following simplified notation for the sums 
of the first and second derivatives:
\begin{align*}
A &= \sum_{i\in \mathcal{I}_{L}^0} g_{i}, & C &= \sum_{i\in \mathcal{I}_{L}^0} h_{i},\\
B &= \sum_{i\in \mathcal{I}_{R}^0} g_{i}, & D &= \sum_{i\in \mathcal{I}_{R}^0} h_{i},\\
T &= \sum_{i\in \Delta \mathcal{I}} g_{i}, & Q &= \sum_{i\in \Delta \mathcal{I}} h_{i},
\end{align*}

Taking partial derivatives of Eq. \ref{eq:simplified-objective} with 
respect to $p$ and $q$ gives us the following equations:
\begin{align}
  \frac{\partial f}{\partial p}&=\frac{2(A+p)}{C+q}-\frac{2(B+T-q)}{D+Q-q}=0,\label{eq:dLdp}\\[4pt]
  \frac{\partial f}{\partial q}&=-\frac{(A+p)^{2}}{(C+q)^{2}}+\frac{(B+T-p)^{2}}{(D+Q-q)^{2}}=0\label{eq:dfdq}
\end{align}
Both equations reduce to the same proportionality condition
\begin{equation}
  \label{eq:lambda_cond}
  \frac{A+p}{C+q}=\frac{B+T-p}{D+Q-q}=\mu
\end{equation}
Adding the two numerators and denominators shows
\begin{equation}
  \mu = \frac{A+B+T}{C+D+Q}
\end{equation}
Hence every stationary point must lie on the \emph{central line}
\begin{equation}
  \label{eq:central_line}
  p = \mu(C+q)-A.
\end{equation}
Substituting Eq. \ref{eq:central_line} back into the objective function 
Eq. \ref{eq:simplified-objective} yields a constant minimum for $f$:

\begin{equation}
    \label{eq:constant_minimum}
    f(p,q) = \frac{A^2 + B^2 + T^2 + 2(AB + AT + BT)}{C+D+Q}.
\end{equation}

If any point on the line segment (Eq. \ref{eq:central_line}) satisfies the 
constraints in Eq. \ref{eq:appendix-rob_constraints}, then it is a global 
minimum of the objective function.  If not, the minimum must be attained at 
one of the extreme points of the feasible polygon defined by the constraints.
This involves minimising the analytical value of $f$ for each of the 8 
constraint edges, as well as at their corners. We now enumerate the 
possible minimisation cases. 

\begin{description}
  \item[Case\,1] $p=k\,q$ ($k\in\{c_{1},c_{2}\}$):
    \begin{equation}
      q^{\star}=\frac{AD+AQ-BC-CT}{A+B-k(C+D+Q)+T},\quad p^{\star}=kq^{\star}.
    \end{equation}
  \item[Case\,2] $p=T-k\,(Q-q)$ ($k\in\{c_{1},c_{2}\}$):
    \begin{equation}
      q^{\star}=\frac{AD+AQ-BC-kQ(C+D+Q)+DT+QT}{A+B-k(C+D+Q)+T},\quad p^{\star}=T-k(Q-q^{\star}).
    \end{equation}
  \item[Case\,3] fixed $p=\bar{p}$ ($\bar{p}\in\{\sum_{i \in
    \Delta \mathcal{I} } \min(0, g_i), \sum_{i \in \Delta
    \mathcal{I} } \max(0, g_i)\}$):
    \begin{equation}
      q^{\star}=\frac{AD+AQ-BC-CT+\bar{p}(C+D+Q)}{A+B+T},\quad p^{\star}=\bar{p}.
    \end{equation}
  \item[Case\,4] fixed $q\in\{0,Q\}$: similar formulas with roles of $p$ and $q$ swapped.
  
  \item[Case\,5] Vertices of the bounding box defined by $p \in \{p_{min}, p_{max}\}$
   and $q \in \{0, Q\}$:
    \begin{equation}
      (p^{\star}, q^{\star}) \in \{ (p_{min}, 0), (p_{min}, Q), (p_{max}, 0), 
      (p_{max}, Q) \}.
    \end{equation}

  \item[Case\,6] Intersection of $p=k_a q$ and $p=T-k_b(Q-q)$, where 
  $k_a, k_b \in \{c_1, c_2\}$ and $k_a \neq k_b$ :
    \begin{equation}
      q^{\star}=\frac{T-k_b Q}{k_a-k_b},\quad p^{\star}=k_a q^{\star}.
    \end{equation}

  \item[Case\,7] Intersection of $p=c_1 q$ with $p=c_2 q$ (if $c_1 \neq c_2$), 
  and intersection of $p=T-c_1(Q-q)$ with $p=T-c_2(Q-q)$ (if $c_1 \neq c_2$):
    \begin{align}
      \text{For } p=c_1 q, p=c_2 q: \quad & p^{\star}=0,\quad q^{\star}=0. \\
      \text{For } p=T-c_1(Q-q), p=T-c_2(Q-q): \quad & q^{\star}=Q,\quad p^{\star}=T.
    \end{align}

  \item[Case\,8] Intersection of $p=kq$ with $q=Q$, where $k \in \{c_1,c_2\}$ 
  and intersection of $p=T-k(Q-q)$ with $q=0$, where $k \in \{c_1,c_2\}$:
    \begin{align}
      \text{For } p=kq \text{ and } q=Q: \quad & p^{\star}=kQ,\quad q^{\star}=Q. \\
      \text{For } p=T-k(Q-q) \text{ and } q=0: \quad & p^{\star}=T-kQ,\quad q^{\star}=0.
    \end{align}

  \item[Case\,9] Intersection of $p=T-k(Q-q)$ with $p=\bar{p}$, where 
  $k \in \{c_1,c_2\}$ and $\bar{p} \in \{p_{min}, p_{max}\}$:
    \begin{equation}
      p^{\star}=\bar{p},\quad q^{\star} = \frac{\bar{p}+kQ-T}{k} 
      \quad (\text{if } k \neq 0).
    \end{equation}

  \item[Case\,10] Specific points $(p^{\star}, q^{\star}) = (\bar{p}, k/\bar{p})$, 
  where $\bar{p} \in \{p_{min}, p_{max}\}$ and $k \in \{c_1,c_2\}$ :
    \begin{equation}
      p^{\star}=\bar{p},\quad q^{\star}=\frac{k}{\bar{p}} 
      \quad (\text{if } \bar{p} \neq 0).
    \end{equation}
\end{description}

Thus, computing the global minimum corresponds to checking the 
feasibility of the unconstrained analytical solution, 8 edges, 
and 24 vertices of the bounding polygon. In practice, several of the intermediate
values are cached, which leads to the minimum being computed efficiently, and in 
constant time. 


