% \documentclass{uai2023} % for initial submission
\documentclass[accepted]{uai2023} % after acceptance, for a revised
                                    % version; also before submission to
                                    % see how the non-anonymous paper
                                    % would look like

%% There is a class option to choose the math font
% \documentclass[mathfont=ptmx]{uai2023} % ptmx math instead of Computer
% Modern (has noticable issues)
% \documentclass[mathfont=newtx]{uai2023} % newtx fonts (improves upon
 % ptmx; less tested, no support)
% NOTE: Only keep *one* line above as appropriate, as it will be replaced
%       automatically for papers to be published. Do not make any other
%       change above this note for an accepted version.

%% Choose your variant of English; be consistent
\usepackage[american]{babel}
% \usepackage[british]{babel}

%% Some suggested packages, as needed:
\usepackage{natbib} % has a nice set of citation styles and commands
    \bibliographystyle{plainnat}
    \renewcommand{\bibsection}{\subsubsection*{References}}
\usepackage{mathtools} % amsmath with fixes and additions
% \usepackage{siunitx} % for proper typesetting of numbers and units
\usepackage{booktabs} % commands to create good-looking tables
\usepackage{tikz} % nice language for creating drawings and diagrams

% for cross referencing the main text
% PLEASE ONLY USE xr IN THE SUPPLEMENTARY MATERIAL. 
% In the main paper, hard code any cross-reference to the supplementary material. 
\usepackage{xr} 
\externaldocument{uai2023-template}

%% Provided macros
% \smaller: Because the class footnote size is essentially LaTeX's \small,
%           redefining \footnotesize, we provide the original \footnotesize
%           using this macro.
%           (Use only sparingly, e.g., in drawings, as it is quite small.)

%% Self-defined macros
\newcommand{\swap}[3][-]{#3#1#2} % just an example

\def\projname{BeliefPPG}
\def\preAttmodule{SpecrAtt}

% Vectors --> mathbf
\newcommand{\bz}{\bm{z}}
\newcommand{\bM}{\bm{M}}
%\newcommand{\bm}{\mathbf{m}}
\newcommand{\bw}{\bm{w}}
\newcommand{\bx}{\bm{x}}
\newcommand{\by}{\bm{y}}


% curly math symbols
\newcommand{\calA}{\mathcal{A}}
\newcommand{\calB}{\mathcal{B}}
\newcommand{\calC}{\mathcal{C}}
\newcommand{\calD}{\mathcal{D}}
\newcommand{\calE}{\mathcal{E}}
\newcommand{\calF}{\mathcal{F}}
\newcommand{\calG}{\mathcal{G}}
\newcommand{\calH}{\mathcal{H}}
\newcommand{\calJ}{\mathcal{J}}
\newcommand{\calK}{\mathcal{K}}
\newcommand{\calL}{\mathcal{L}}
\newcommand{\calM}{\mathcal{M}}
\newcommand{\calN}{\mathcal{N}}
\newcommand{\calO}{\mathcal{O}}
\newcommand{\calP}{\mathcal{P}}
\newcommand{\calQ}{\mathcal{Q}}
\newcommand{\calR}{\mathcal{R}}
\newcommand{\calS}{\mathcal{S}}
\newcommand{\calT}{\mathcal{T}}
\newcommand{\calU}{\mathcal{U}}

\newcommand{\calX}{\mathcal{X}}
\newcommand{\calY}{\mathcal{Y}}
\newcommand{\calZ}{\mathcal{Z}}

%Added by Scott
\newcommand{\indep}{\perp \!\!\! \perp}

% Added by Paul
\DeclareMathOperator{\ReLU}{ReLU}
\DeclareMathOperator*{\argmin}{arg\,min}
\DeclareMathOperator*{\argmax}{arg\,max}



\newcommand{\oarr}[1]{\overrightarrow{#1}}


% Added by Lenart
\usepackage{xifthen}
\DeclareMathOperator{\trace}{Tr}
\newcommand{\norm}[1]{\left\lVert#1\right\rVert}
\newcommand{\abs}[1]{\left\lvert#1\right\rvert}
\newcommand{\normal}[3][]{%
    \ifthenelse{\isempty{#1}}
        {\mathcal{N}\left(#2, #3\right)}
        {\mathcal{N}\left(#1|#2, #3\right)}%
}
\DeclareMathOperator{\cov}{cov}
\DeclareMathOperator*{\E}{\mathbb{E}}
\DeclareMathOperator{\rank}{rank}
\DeclareMathOperator{\image}{Im}
\DeclareMathOperator{\var}{var}





\newcommand\givenbase[1][]{\:#1\lvert\:}
\let\given\givenbase
\newcommand\sgiven{\givenbase[\delimsize]}
\DeclarePairedDelimiterX\Basics[1](){\let\given\sgiven #1}

\title{BeliefPPG: Uncertainty-aware Heart Rate Estimation from PPG signals via Belief Propagation\\(Supplementary Material)}

% The standard author block has changed for UAI 2023 to provide
% more space for long author lists and allow for complex affiliations
%
% All author information is authomatically removed by the class for the
% anonymous submission version of your paper, so you can already add your
% information below.
%
% Add authors
\author[1]{Valentin~Bieri$^*$}
\author[1]{Paul~Streli$^*$}
\author[1]{Berken~Utku~Demirel}
\author[1]{Christian~Holz}
% \author[3]{Further~Coauthor}
% \author[3,1]{Further~Coauthor}
% Add affiliations after the authors
\affil[1]{%
    Department of Computer Science\\
    % Cranberry University\\
    ETH Zürich, Switzerland
}
  
  \begin{document}
  
% \onecolumn %% Turn this off if single column is desired for the supplement
\maketitle

\def\thefootnote{*}\footnotetext{These authors contributed equally to this work}\def\thefootnote{\arabic{footnote}}


\appendix
\section{Transition function selection}
\label{sec:transition_fn}
While we experimented with alternative distributions for the transition function, including LaPlacian, Gaussian, and Levy distributions of the absolute difference and relative difference in HR between two beat-to-beat intervals, we observed that our transition function using a discretized Gaussian prior fit on the logarithmic change $\log{\frac{y_{t}}{y_{t-1}}}$ led to the best results while offering a reasonable fit to the observed histogram of heart range changes (see~\autoref{fig:logdiffs}).

\begin{figure}[ht!]
    \centering
    \includegraphics[width=0.7\columnwidth]{prior_on_logdiffs_bu.pdf}
    \caption{Logarithmic change of HR values in the IEEE dataset.}
    \label{fig:logdiffs}
\end{figure}


\section{Selection of $\sigma_{y}$}
\label{sec:suppl_ablation}
We represent the ground-truth HR $y_{t}$ as a discretized normal distribution with density $\normal{y_{t}}{\sigma_{y}^{2}}$. The selection of the hyperparameter $\sigma_y^2$ is based on an ablation study, and the results, as demonstrated in Table~\ref{fig:label_std_table}, indicate minimal sensitivity to variations in $y_t$.


\begin{table}[h!]
\centering
\caption{Ablations of \projname{} with different $\sigma_y$ under LoSo-CV on BAMI-1. We report MAE, its standard deviation across subjects (STD) and the log-likelihood on the test set.}
\label{fig:label_std_table}
\resizebox{\columnwidth}{!}{
    \begin{tabular}{lccccccccc} \toprule
        $\sigma_y$ & 0.25 & 0.5 & 0.75 & 1.0 & 1.5 & 2.0 & 2.5 & 3.0 & 4.0  \\ \midrule
        MAE & 2.15 & 2.30 & 2.34 & 2.18 & \textbf{2.00} & 2.45 & 2.29 & 2.45 & 2.35 \\
        STD MAE & 0.90 & 1.30 & 1.70 & 1.00 & \textbf{1.00} & 1.80 & 1.50 & 1.50 & 1.40 \\
        \textbf{Log Lik.} & -4.13 & -4.2 & -4.22 & -4.13 & \textbf{-4.12} & -4.28 & -4.23 & -4.3 & -4.33 \\ \bottomrule
    \end{tabular}
}
\end{table}




\section{MAPE across activities}

\begin{figure}[h!]
    \centering
    \includegraphics[width=1.0\columnwidth]{mape_by_activit_bu_version.pdf}
    \caption{Mean absolute percentage errors (MAPEs) visualized by activity for LoSo on DaLiA. Boxes correspond to interquartile ranges and whiskers to 10th and 90th percentiles over subjects. The blue lines indicate the median, and the orange line marks the acceptable error of 10\%.}
    \label{fig:by_activity}
\end{figure}
Figure \ref{fig:by_activity} presents the Mean Absolute Percentage Errors (MAPE) across activities compared to the AAMI standard \citep{AAMI} for the DaLiA dataset.
The AAMI standard sets the acceptable limits for HR monitoring within ±10\%, which is implemented using the MAPE statistic as defined by the Consumer Technology Association \citep{Consumer-technology-assoc}.

The results demonstrate that the median MAPE for all activities is significantly below this limit. Notably, none of the 15 peak detectors benchmarked by Charlton et al. \citep{CharltonBenchmark} achieved this level of accuracy. 





\section{Architecture details}
\label{sec:nn_config}
Table \ref{fig:architecture_table} provides architecture and training details. We implemented our network using TensorFlow 2.8.0.

\begin{table*}[t!]
\centering
\caption{Details about \projname{}'s heart rate network architecture and training configuration}
\label{fig:architecture_table}

\resizebox{\textwidth}{!}{
    \begin{tabular}{llllllllllll}
        \textbf{} & \textbf{} & \textbf{} &   \\ \hline
        \multicolumn{3}{l}{\textbf{Heart rate network architecture}} ~ & ~ & ~ & ~ & ~ & ~& ~ \\ 
        \textbf{} & Up-/Downspl. fac. & Comment & Kernel Size & Padding & Filters / Inner Dim & Activation & Dropout & Output shape & ~ & ~ & ~ \\ 
        
        \midrule
        
        \multicolumn{3}{l}{\textbf{Time-Frequency Branch} \textit{ // input shape: $(W_s,N_s,2) = (7, 64, 2)$}}  ~ & ~ & ~ & ~  \\ 
         {2x Conv2D} & - & - & 3x3 & same & 32 & leaky\_relu & 0.1 & (7,64,32) \\ 
         {embedding 4x} & - & - & - & - & 32 & - & - & 4 x (7,64,32) \\ 
         {2x attention + reduce mean}  & - & reduces $1^{st}$ axis & - & - & - & - & - & (64, 32) \\ 
         {3x downsampling block (1D)} & 4 & stride=poolsize=4 & 3x1 & same & 12, 24, 48 & relu & 0.2 & (1, 48)  \\ 
         {bottleneck attention} & - & - & 2x1 & - & 48 & tanh, relu & 0.2 & (1, 48)\\ 
         {3x upsampling block} & 4 & upspl. size=4 & 3x1 & same & 48, 24, 12 & relu & 0.2 & (64, 12) \\ 
         {Conv1D} & - & - & 1x1 & same & 1 & softmax & - & (64,) \\ 
         {} & ~ & ~ & ~ & ~ & ~ & ~ \\ 
         \multicolumn{3}{l}{\textbf{Time Branch} \textit{ // input shape: $(L_x, 1) = (1280, 1)$}} & ~ & ~ & ~  \\ 
        {Conv1D + bn + MaxPool} & 4 & dilation\_rate=2 & 10 & causal & 16 & leaky\_relu & 0.1 & (320, 16)  \\ 
        {Conv1D + bn + MaxPool} & 4 & dilation\_rate=2 & 10 & causal & 16 & leaky\_relu & 0.1 & (80, 16)  \\ 
        {LSTM} & - & - & - & - & 64 & tanh & 0.1 & (80, 64)\\ 
        {LSTM} & - & - & - & - & 64 & tanh & 0.1 &  (64,) \\ 
        {Dense 2x} & - & - & - & - & 48 & leaky\_relu & - & 2x (1, 48) \\ 
        \textbf{} & ~ & ~ & ~ & ~ & ~ & ~ & ~  \\ 
        \multicolumn{3}{l}{\textbf{Training Parameters}} ~ & ~ & ~ & ~ & ~  \\ 
        {Batch Size} & 128 & ~ & ~ & ~ & ~ & ~ & ~ & ~\\ 
        {Optimizer} & \multicolumn{5}{l}{Adam(lr=0.00025)} ~ & ~ & ~ & ~ \\ 
        {LR Scheduler} & \multicolumn{6}{l}{ReduceLROnPlateau(factor=0.5, min\_lr=1e-10 monitor="loss", patience=3)} ~ & ~ & ~ \\ 
        {Stopping criterion} & \multicolumn{5}{l}{EarlyStopping(patience=40 restore\_best\_weights=True, monitor="val\_loss")} ~ & ~ & ~  \\ 
        {TTA: gaussian noise std} & 0.25 & ~ & ~ & ~ & ~ & ~ & ~ & ~ \\ 
        {TTA: max stretching factor} & 25\% & ~ & ~ & ~ & ~ & ~ & ~ \\  
        {$\sigma_y$: label standard deviation} & 1.5 & ~ & ~ & ~ & ~ & ~ & ~ \\  \hline
    \end{tabular}
}
\end{table*}

\bibliography{bieri_741}

\end{document}
