Publication Type
Journal Article
Version
publishedVersion
Publication Date
8-2025
Abstract
We consider the problems of statically refuting equivalence and similarity of output distributions defined by a pair of probabilistic programs. Equivalence and similarity are two fundamental relational properties of probabilistic programs that are essential for their correctness both in implementation and in compilation. In this work, we present a new method for static equivalence and similarity refutation. Our method refutes equivalence and similarity by computing a function over program outputs whose expected value with respect to the output distributions of two programs is different. The function is computed simultaneously with an upper expectation supermartingale and a lower expectation submartingale for the two programs, which we show to together provide a formal certificate for refuting equivalence and similarity. To the best of our knowledge, our method is the first approach to relational program analysis to offer the combination of the following desirable features: (1) it is fully automated, (2) it is applicable to infinite-state probabilistic programs, and (3) it provides formal guarantees on the correctness of its results. We implement a prototype of our method and our experiments demonstrate the effectiveness of our method to refute equivalence and similarity for a number of examples collected from the literature.
Keywords
Probabilistic programming, Static program analysis, Probability distribution equivalence, Kantorovich distance, Martingales
Discipline
Programming Languages and Compilers
Research Areas
Intelligent Systems and Optimization
Areas of Excellence
Digital transformation
Publication
Proceedings of the ACM on Programming Languages
First Page
2098
Last Page
2122
Identifier
10.1145/3656462
Publisher
Association for Computing Machinery (ACM)
Citation
CHATTERJEE, Krishnendu; GOHARSHADY, Ehsan Kafshdar; NOVOTNÝ, Petr; and ZIKELIC, Dorde.
Equivalence and similarity refutation for probabilistic programs. (2025). Proceedings of the ACM on Programming Languages. 2098-2122.
Available at: https://ink.library.smu.edu.sg/sis_research/9063
Copyright Owner and License
Authors
Creative Commons License
This work is licensed under a Creative Commons Attribution-NonCommercial-No Derivative Works 4.0 International License.
Additional URL
https://doi.org/10.1145/3656462