Skip to main content

Dominator Tree Certification and Divergent Spanning Trees

Author(s): Georgiadis, Loukas; Tarjan, Robert E

Download
To refer to this page use: http://arks.princeton.edu/ark:/88435/pr1k544
Abstract: How does one verify that the output of a complicated program is correct? One can formally prove that the program is correct, but this may be beyond the power of existing methods. Alternatively, one can check that the output produced for a particular input satisfies the desired input--output relation by running a checker on the input--output pair. Then one only needs to prove the correctness of the checker. For some problems, however, even such a checker may be too complicated to formally verify. There is a third alternative: augment the original program to produce not only an output but also a correctness certificate, with the property that a very simple program (whose correctness is easy to prove) can use the certificate to verify that the input--output pair satisfies the desired input--output relation. We consider the following important instance of this general question: How does one verify that the dominator tree of a flow graph is correct? Existing fast algorithms for finding dominators are complicated, and even verifying the correctness of a dominator tree in the absence of additional information seems complicated. We define a correctness certificate for a dominator tree, show how to use it to easily verify the correctness of the tree, and show how to augment fast dominator-finding algorithms so that they produce a correctness certificate. We also relate the dominator certificate problem to the problem of finding divergent spanning trees in a flow graph, and we develop algorithms to find such trees. All our algorithms run in linear time. Previous algorithms apply just to the special case of only trivial dominators, and they take at least quadratic time.
Publication Date: Nov-2015
Citation: Georgiadis, Loukas, and Robert E. Tarjan. "Dominator Tree Certification and Divergent Spanning Trees." ACM Transactions on Algorithms 12, no. 1 (2015): 11:1-11:42. doi:10.1145/2764913
DOI: 10.1145/2764913
ISSN: 1549-6325
EISSN: 1549-6333
Pages: 11:1 - 11:42
Type of Material: Journal Article
Journal/Proceeding Title: ACM Transactions on Algorithms
Version: Author's manuscript



Items in OAR@Princeton are protected by copyright, with all rights reserved, unless otherwise indicated.