%\documentclass{uai2025} % for initial submission
\documentclass[accepted]{uai2025} % 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]{uai2025} % ptmx math instead of Computer
                                         % Modern (has noticeable issues)
% \documentclass[mathfont=newtx]{uai2025} % 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{xcolor}
\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
\usepackage{algorithm}
\usepackage[noend]{algorithmic}
%% 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

\input{header}

\title{Root Cause Analysis of Failures from Partial Causal Structures}
\usepackage{footmisc}  % Add this in your preamble if not already there

% Then in the author section:
\author[1]{\href{mailto:<mikram@purdue.edu>?Subject=Your UAI 2025 paper}{Azam Ikram\textsuperscript{\dag}}}
\author[1]{\href{mailto:<lee4094@purdue.edu>?Subject=Your UAI 2025 paper}{Kenneth Lee\textsuperscript{\dag}}}
\author[2]{Shubham Agarwal}
\author[2]{Shiv Kumar Saini}
\author[1]{Saurabh Bagchi}
\author[1]{Murat Kocaoglu}

% Add affiliations
\affil[1]{%
    Elmore Family School of Electrical and Computer Engineering,
    Purdue University,
    West Lafayette, IN,
    USA
}
\affil[2]{%
    Adobe Research, India
}

% Add this manually after \maketitle or at the bottom of your preamble


% \author[1]{\href{mailto:<mikram@purdue.edu>?Subject=Your UAI 2025 paper}{Azam Ikram\textsuperscript{\dag}}}
% \author[1]{\href{mailto:<lee4094@purdue.edu>?Subject=Your UAI 2025 paper}{Kenneth Lee\textsuperscript{\dag}}}
% \author[2]{Shubham Agarwal}
% \author[2]{Shiv Kumar Saini}
% \author[1]{Saurabh Bagchi}
% \author[1]{Murat Kocaoglu}
% Add affiliations after the authors
% \affil[1]{%
%     Elmore Family School of Electrical and Computer Engineering, Purdue University, West Lafayette, IN, USA
% }
% \affil[2]{%
%     Adobe Research, India
% }



% The standard author block has changed for UAI 2025 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]{\href{mailto:<jj@example.edu>?Subject=Your UAI 2025 paper}{Jane~J.~von~O'L\'opez}{}}
% \author[1]{Harry~Q.~Bovik}
% \author[1,2]{Further~Coauthor}
% \author[3]{Further~Coauthor}
% \author[1]{Further~Coauthor}
% \author[3]{Further~Coauthor}
% \author[3,1]{Further~Coauthor}
% % Add affiliations after the authors
% \affil[1]{%
%     Computer Science Dept.\\
%     Cranberry University\\
%     Pittsburgh, Pennsylvania, USA
% }
% \affil[2]{%
%     Second Affiliation\\
%     Address\\
%     …
% }
% \affil[3]{%
%     Another Affiliation\\
%     Address\\
%     …
%   }
  
\begin{document}
\maketitle
\begingroup
\renewcommand\thefootnote{\dag}
\footnotetext{Equal contribution}
\endgroup

\begin{abstract}
Finding the root cause of failures is a prominent problem in many complex networks. Causal inference provides us with tools to address this problem algorithmically to automate this process and solve it efficiently. The existing methods either use a known causal structure to identify root cause by backtracking the changes, or ignore the causal structure but relies on invariance tests to identify the changing causal mechanisms after the failure. Assuming a single, unknown root cause, we first establish a novel connection between root cause analysis and the \textit{Interactive Graph Search (IGS)} problem. This mapping highlights the importance of causal knowledge: we demonstrate that any algorithm relying solely on marginal invariance tests to identify the root cause must perform at least $\Omega(\log_{2}(n) + d\log_{1+d}n)$ many tests, where $n$ represents the number of components and $d$ denotes the maximum out-degree of the graph. We then present an optimal algorithm that achieves this bound by reducing the root cause identification problem as an instance of IGS. Beyond the single root cause scenario, we propose a practical extension for settings with multiple root causes and partial causal knowledge. More specifically, we show that even if the causal graph is partially known, we can identify the root-causes with a linear number of invariance tests. This is the first known result on incorporating a partial causal structure for root cause analysis. Our experiments on a production-level application demonstrate that, even in the absence of complete causal information, our approach accurately identifies the root causes of failures. Our source code is available online at \href{https://github.com/azamikram/rcg}{github.com/azamikram/rcg}.
\end{abstract}

\input{sections/introduction}

\input{sections/background}
\input{sections/problem}
\input{sections/known-graph}
\input{sections/unknown-graph}
\input{sections/experiments}
\input{sections/case-study}

\section{Conclusion}
Identifying the root cause of system failures is a critical
challenge in software systems. We argue that leveraging a
system’s partial causal structure can provide valuable insights for diagnosing failures. First, we demonstrate the
value of the causal graph by showing that it can significantly
reduce the number of invariance tests required. We establish
a lower bound on the number of marginal CI tests necessary
to identify the root cause, given the correct causal graph, for
any algorithm that relies solely on marginal invariance tests. Then,
we argue that a system’s normal operational time can
be leveraged to learn a partial causal graph. Based on this,
we introduce an algorithm that systematically utilizes the
partial causal graph to identify the root cause using a linear
number of invariance tests. Our proposed algorithm \name can incorporate a wide range of causal discovery algorithms and its performance will improve alongside with the advancement of causal discovery from observational data. Empirical results show that our
approach outperforms state-of-the-art methods, improving
fault detectability. We believe \name shows promise for RCA under latent confounding by integrating causal discovery algorithms capable of learning from observational data with unobserved confounders. An interesting future direction is to explore how to effectively leverage multiple unknown interventional distributions for RCA within the framework of modeling the failure as a soft intervention. As mutual information performs well in our experiments, it is also worthwhile to explore the conditions under which mutual information will be most efficient in terms of both sample and time complexity for RCA.



% Identifying root causes of system failures is a key challenge in software systems. We show that leveraging a partial causal graph, learned during normal operation, can reduce the number of required invariance tests. We establish a lower bound on marginal CI tests needed with the true causal graph and propose an algorithm that uses the partial graph to identify root causes with a linear number of tests. Empirically, our method outperforms existing approaches in RCA.
\begin{acknowledgements} % will be removed in pdf for initial submission,
% 						 % (without ‘accepted’ option in \documentclass)
%                          % so you can already fill it to test with the
%                          % ‘accepted’ class option
%     Briefly acknowledge people and organizations here.

%     \emph{All} acknowledgements go in this section.
This research has been supported in part by NSF CAREER 2239375, IIS 2348717, Amazon Research Award and Adobe Research.
This material is based in part upon work supported by the National Science Foundation under Grant Number CNS-2333487, Army Research Lab under Contract number W911NF-20-2-0026, and gift funding from Adobe Research. Any opinions, findings, and conclusions or recommendations expressed in this material are those of the authors and do not necessarily reflect the views of the sponsors.
\end{acknowledgements}

% References
\bibliography{refs}



\onecolumn

\title{Root Cause Analysis of Failure with Observational Causal Discovery\\(Supplementary Material)}
\maketitle

\appendix

\input{sections/appendix}

\end{document}
