English

Certifying Zero-Knowledge Circuits with Refinement Types

Cryptography and Security 2023-04-19 v2

Abstract

Zero-knowledge (ZK) proof systems have emerged as a promising solution for building security-sensitive applications. However, bugs in ZK applications are extremely difficult to detect and can allow a malicious party to silently exploit the system without leaving any observable trace. This paper presents Coda, a novel statically-typed language for building zero-knowledge applications. Critically, Coda makes it possible to formally specify and statically check properties of a ZK application through a rich refinement type system. One of the key challenges in formally verifying ZK applications is that they require reasoning about polynomial equations over large prime fields that go beyond the capabilities of automated theorem provers. Coda mitigates this challenge by generating a set of Coq lemmas that can be proven in an interactive manner with the help of a tactic library. We have used Coda to re-implement 79 arithmetic circuits from widely-used Circom libraries and applications. Our evaluation shows that Coda makes it possible to specify important and formally verify correctness properties of these circuits. Our evaluation also revealed 6 previously-unknown vulnerabilities in the original Circom projects.

Keywords

Cite

@article{arxiv.2304.07648,
  title  = {Certifying Zero-Knowledge Circuits with Refinement Types},
  author = {Junrui Liu and Ian Kretz and Hanzhi Liu and Bryan Tan and Jonathan Wang and Yi Sun and Luke Pearson and Anders Miltner and Işıl Dillig and Yu Feng},
  journal= {arXiv preprint arXiv:2304.07648},
  year   = {2023}
}

Comments

This paper was incorrectly submitted, and should be submitted to Cryptology ePrint Archive instead

R2 v1 2026-06-28T10:07:12.069Z