CAREER: SHF: Compositional Analysis of Randomized Algorithms CAREER: SHF: Compositional Analysis of Randomized Algorithms
Synopsis
Randomized algorithms play a central role in important applications, including
machine learning, data privacy, and cryptography. Like all software,
probabilistic programs are susceptible to bugs. Furthermore, correctness
properties rest on mathematical proof; missteps in these arguments can render
algorithms incorrect before they are even implemented. Regardless of their
source, errors may go unnoticed for years, posing increasing risks as
probabilistic programs see broader adoption. This proposal seeks to advance the
theory and practice of verification for probabilistic programs, developing
technology to increase our confidence that these programs are correct.
This project develops a software system to formally verify randomized
algorithms, by leveraging three complementary ideas: (1) Employ higher-level
properties that allows formal proofs to cover more ground with each step; (2)
Strive for compositional reasoning which can allow complex systems to be
verified by analyzing each component separately; and (3) Formalize human proof
techniques which should inform verification methods. In the near term, results
will enable verification for new algorithms. In the long term, this proposal
works towards a world where all randomized programs can be computer-checked for
correctness prior to deployment.
Personnel
Collaborators
- Aws Albarghouthi (University of Wisconsin)
- Gilles Barthe (MPI S&P)
- Simon Docherty (Droit)
- Azadeh Farzan (University of Toronto)
- Marco Gaboardi (Boston University)
- Tao Gu (University College London)
- Benjamin Kaminski (University College London)
- Ariel Kellison (Sandia National Laboratories)
- Joost-Pieter Katoen (RWTH Aachen)
- Emanuele D'Osualdo (University of Konstanz)
- Subhajit Roy (IIT Kanpur)
- Alexandra Silva (Cornell University)
- Joseph Tassarotti (Boston College)
- Mingsheng Ying (University of Technology Sydney)
- Nengkun Yu (University of Technology Sydney)
- Fabio Zanasi (University College London)
Publications
- Jialu Bao, Simon Docherty, Justin Hsu, and Alexandra Silva. A Bunched Logic for Conditional Independence. LICS 2021. [paper]
- Li Zhou, Gilles Barthe, Justin Hsu, Mingsheng Ying, and Nengkun Yu. A Quantum Interpretation of Bunched Logic & Quantum Separation Logic. LICS 2021. [paper]
- Subhajit Roy, Justin Hsu, and Aws Albarghouthi. Learning Differentially Private Mechanisms. IEEE S&P 2021. [paper]
- Alejandro Aguirre, Gilles Barthe, Justin Hsu, Benjamin Lucien Kaminski, Joost-Pieter Katoen, and Christoph Matheja. A Pre-Expectation Calculus for Probabilistic Sensitivity. POPL 2021. Distinguished Paper Award. [paper] [blog]
- Gilles Barthe, Justin Hsu, and Kevin Liao. A Probabilistic Separation Logic. POPL 2020. [paper]
- Jialu Bao, Marco Gaboardi, Justin Hsu, and Joseph Tassarotti. A Separation
Logic for Negative Dependence. POPL 2022. [paper]
- Karuna Grewal, Loris D’Antoni, and Justin Hsu. P4BID: Information Flow
Control in P4. PLDI 2022. [paper]
- Jialu Bao, Nitesh Trivedi, Drashti Pathak, Justin Hsu, and Subhajit Roy.
Data-Driven Invariant Learning for Probabilistic Programs. CAV 2022.
Distinguished Paper Award. [paper]
- Zachary Susag, Sumit Lahiri, Justin Hsu, and Subhajit Roy. Symbolic Execution
for Randomized Programs. OOPSLA 2022. [paper]
- Tao Gu, Jialu Bao, Justin Hsu, Alexandra Silva, and Fabio Zanasi. A
Categorical Approach to DIBI Models. FSCD 2024. [paper]
- Jialu Bao, Nitesh Trivedi, Drashti Pathak, Justin Hsu, and Subhajit Roy.
Data-Driven Invariant Learning for Probabilistic Programs. Formal Methods in
System Design (previously appeared at CAV 2022).
[paper]
- Ariel E. Kellison and Justin Hsu. Numerical Fuzz: A Type System for Rounding
Error Analysis. PLDI 2024. [paper]
- Jialu Bao, Emanuele D'Osualdo, and Azadeh Farzan. Bluebell: An Alliance of
Relational Lifting and Independence For Probabilistic Reasoning. POPL 2025.
[paper]
Code
- Exist: Data-Driven Invariant Learning for Probabilistic Programs. Code for CAV 2022 paper. code
- Plinko: Symbolic Execution for Randomized Programs. Code for OOPSLA 2022 paper. code
- Numerical Fuzz: A Type System for Rounding Error Analysis. Code for PLDI 2024 paper. code
Education
- CS 538: Introduction to the Theory and Design of Programming Languages (University of Wisconsin) [materials] [blog]
- CS 763: Security and Privacy in Data Science (University of Wisconsin) [materials]
- Invited course: Reasoning about Probabilistic Programs (OPLSS 2021) [slides] [recordings]
- CS 6182: Foundations of Probabilistic Programming (Cornell University) [materials]
- CS 6117: Category Theory for Computer Scientists (Cornell University) [materials] [blog]
Outreach
- Programming Languages Mentoring Workshop@POPL 2021 (Organizer) [site] [blog]
- Programming Languages Mentoring Workshop 2021-2023 (Steering Committee)
- Conference on Mathematical Foundations of Programming Semantics (MFPS) 2022 (Co-Chair)
- Cornell Bowers CIS Undergraduate Research Experience 2023 (Director) [site]