layout | title |
---|---|
default |
Certified Programs and Proofs (CPP) |
Certified Programs and Proofs (CPP) is an international conference on practical and theoretical topics in all areas that consider formal verification and certification as an essential paradigm for their work. CPP spans areas of computer science, mathematics, logic, and education. CPP is sponsored by ACM SIGPLAN, usually in cooperation with ACM SIGLOG.
Steering Committee
- Cătălin Hriţcu (SC Chair), MPI-SP, Germany
- Sandrine Blazy, University of Rennes, France
- Adam Chlipala, MIT, USA
- Georges Gonthier, Inria, France
- Gerwin Klein, Proofcraft and UNSW Sydney, Australia
- Robbert Krebbers, Radboud University Nijmegen, Netherlands
- Dale Miller, Inria Saclay and LIX/Institut Polytechnique de Paris, France
- Tobias Nipkow, Technische Universität München, Germany
- Brigitte Pientka, McGill University, Canada
- Zhong Shao, Yale University, USA
- Kathrin Stark, Heriot-Watt University, UK
- Nicolas Tabareau, Inria, Nantes, France
- Amin Timany, Aarhus University, Denmark
- Dmitriy Traytel, University of Copenhagen, Denmark
- Steve Zdancewic, University of Pennsylvania, USA
Former SC members
- Andrei Popescu, University of Sheffield, United Kingdom
- Lennart Beringer, Princeton University, USA
- Jasmin Blanchette, Ludwig-Maximilians-Universität München, Germany
- Assia Mahboubi, Inria, France and Vrije Universiteit Amsterdam, Netherlands
- Magnus O. Myreen, Chalmers University of Technology, Sweden
- June Andronick, Proofcraft and UNSW Sydney, Australia
- Amy Felty, University of Ottawa, Canada
- Yves Bertot, Inria, France
- Viktor Vafeiadis, MPI-SWS, Germany
- Jeremy Avigad, Carnegie Mellon University, USA
- Xavier Leroy, Collège de France, PSL University, France
- Alwen Tiu, Australian National University, Australia
- Michael Norrish, Australian National University, Australia
- Chris Hawblitzel, Microsoft Research, USA
- Jean-Pierre Jouannaud, Université de Paris-Saclay, France
- Andrew Appel, Princeton University, USA
- Nikolaj Bjorner, Microsoft Research, USA
- John Harrison, Amazon Web Services, USA
- CPP 2026
- PC Chairs: Nicolas Tabareau and Nikhil Swamy
- Conference Chairs: Kathrin Stark and Yannick Zakowski
- CPP 2025, Denver, Colorado, USA, January 20-21, 2025 (co-located with POPL’25)
- PC Chairs: Sandrine Blazy and Nicolas Tabareau
- Conference Chairs: Amin Timany and Kathrin Stark
- CPP 2024, London, UK, January 15-16, 2024 (co-located with POPL’24)
- PC Chairs: Brigitte Pientka and Sandrine Blazy
- Conference Chairs: Dmitriy Traytel and Amin Timany
- CPP 2023, Boston, USA, January 16-17, 2023 (co-located with POPL’23)
- PC Chairs: Steve Zdancewic and Brigitte Pientka
- Conference Chairs: Robbert Krebbers and Dmitriy Traytel
- CPP 2022, Philadelphia, USA, January 17-18, 2022 (co-located with POPL’22)
- PC Chairs: Andrei Popescu and Steve Zdancewic
- Conference Chairs: Lennart Beringer and Robbert Krebbers
- CPP 2021, Online, January 17-19, 2021 (co-located with POPL’21)
- PC Chairs: Cătălin Hriţcu and Andrei Popescu
- Conference Chairs: Cătălin Hriţcu and Lennart Beringer
- CPP 2020, New Orleans, USA, January 20-21, 2020 (co-located with POPL’20)
- PC Chairs: Jasmin Blanchette and Cătălin Hriţcu
- CPP 2019, Cascais/Lisbon, Portugal, January 14-15, 2019 (co-located with POPL’19)
- PC Chairs: Assia Mahboubi and Magnus O. Myreen
- CPP 2018, Los Angeles, USA, January 8-9, 2018 (co-located with POPL’18)
- PC Chairs: June Andronick and Amy Felty
- CPP 2017, Paris, France, January 16-17, 2017 (co-located with POPL’17)
- PC Chairs: Yves Bertot and Viktor Vafeiadis
- CPP 2016, Saint Petersburg, Florida, USA, January 18-19, 2016 (co-located with POPL’16)
- PC Chairs: Jeremy Avigad and Adam Chlipala
- CPP 2015, Mumbai, India, January 13-14, 2015 (co-located with POPL’15)
- PC Chairs: Xavier Leroy and Alwen Tiu
- CPP 2013, Melbourne, Australia, December 11-13, 2013 (co-located with APLAS’13)
- PC Chairs: Georges Gonthier Michael Norrish
- CPP 2012, Kyoto, Japan, December 13-15, 2012 (collocation with APLAS’12)
- PC Chairs: Chris Hawblitzel and Dale Miller
- CPP 2011, Kenting, Taiwan, December 7-9, 2011 (co-located with APLAS’11)
- PC Chairs: Jean-Pierre Jouannaud and Zhong Shao
The official CPP proceedings since 2015 are publicly available via SIGPLAN OpenTOC. A list of CPP PC members is available here.
Given Distinguished Paper Awards
- CPP 2024: Formal Probabilistic Methods for Combinatorial Structures using the Lovász Local Lemma. Chelsea Edmonds and Lawrence Paulson.
- CPP 2024: Martin-Löf à la Coq. Arthur Adjedj, Meven Lennon-Bertrand, Kenji Maillard, Pierre-Marie Pédrot, and Loïc Pujet.
- CPP 2024: Rooting for Efficiency: Mechanised Reasoning about Array-Based Trees in Separation Logic. Qiyuan Zhao, George Pîrlea, Zhendong Ang, Umang Mathur, and Ilya Sergey.
- CPP 2023: A Formalization of the Development Closedness Criterion for Left-Linear Term Rewrite Systems. Christina Kohl and Aart Middeldorp.
- CPP 2023: Computing Cohomology Rings in Cubical Agda. Thomas Lamiaux, Axel Ljungström, and Anders Mörtberg.
- CPP 2023: Aesop: White-Box Best-First Proof Search for Lean. Jannis Limperg, Asta Halkjær From.
- CPP 2022: Specification and Verification of a Transient Stack. Alexandre Moine, Arthur Charguéraud, and François Pottier.
- CPP 2022: CertiStr: A Certified String Solver. Shuanglong Kan, Anthony Widjaja Lin, Philipp Ruemmer, and Micha Schrader.
- CPP 2022: Semantic cut elimination for the logic of bunched implications, formalized in Coq. Dan Frumin.
- CPP 2021: A Minimalistic Verified Bootstrapped Compiler (Proof Pearl). Magnus O. Myreen.
- CPP 2021: Formalizing the Ring of Witt Vectors. Johan Commelin and Robert Y. Lewis.
- CPP 2021: Machine-Checked Semantic Session Typing. Jonas Kastberg Hinrichsen, Daniël Louwrink, Robbert Krebbers, and Jesper Bengtson.
Given Amazing Reviewer Awards
- CPP 2024: Théo Winterhalter, Inria, France
- CPP 2023: Anja Petković Komel, TU Wien, Austria
- CPP 2022: Armaël Guéneau, Inria, France
- CPP 2021: Kathrin Stark, Heriot-Watt University, UK
The CPP Manifesto (from 2011)
In this manifesto, we advocate for the creation of a new international conference in the area of formal methods and programming languages, called Certified Programs and Proofs (CPP). Certification here means formal, mechanized verification of some sort, preferably with the production of independently checkable certificates. CPP would target any research promoting formal development of certified software and proofs, that is:
The development of certified or certifying programs The development of certified mathematical theories The development of new languages and tools for certified programming New program logics, type systems, and semantics for certified code New automated or interactive tools and provers for certification Results assessed by an original open source formal development Original teaching material based on a proof assistant Software today is still developed without precise specification. A developer often starts the programming task with a rather informal specification. After careful engineering, the developer delivers a program that may not fully satisfy the specification. Extensive testing and debugging may shrink the gap between the two, but there is no assurance that the program accurately follows the specification. Such inaccuracy may not always be significant, but when a developer links a large number of such modules together, these “noises” may multiply, leading to a system that nobody can understand and manage. System software built this way often contains hard-to-find “zero-day vulnerabilities” that become easy targets for Stuxnet-like attacks. CPP aims to promote the development of new languages and tools for building certified programs and for making programming precise.
Certified software consists of an executable program plus a formal proof that the software is free of bugs with respect to a particular dependability claim. With certified software, the dependability of a software system is measured by the actual formal claim that it is able to certify. Because the claim comes with a mechanized proof, the dependability can be checked independently and automatically in an extremely reliable way. The formal dependability claim can range from making almost no guarantee, to simple type safety property, or all the way to deep liveness, security, and correctness properties. It provides a great metric for comparing different techniques and making steady progress in constructing dependable software.
The conventional wisdom is that certified software will never be practical because any real software must also rely on the underlying runtime system which is too low-level and complex to be verifiable. In recent years, however, there have been many advances in the theory and engineering of mechanized proof systems applied to verification of low-level code, including proof-carrying code, certified assembly programming, local reasoning and separation logic, certified linking of heterogeneous components, certified protocols, certified garbage collectors, certified or certifying compilation, and certified OS-kernels. CPP intends to be a driving force that would facilitate the rapid development of this exciting new area, and be a natural international forum for such work.
The recent development in several areas of modern mathematics requires mathematical proofs containing enormous computation that cannot be verified by mathematicians in an entire lifetime. Such development has puzzled the mathematical community and prompted some of our colleagues in mathematics and computer science to start developing a new paradigm, formal mathematics, which requires proofs to be verified by a reliable theorem prover. As particular examples, such an effort has been made for the four-color theorem and has started for the sphere packing problem and the classification of finite groups. We believe that this emerging paradigm is the beginning of a new era. No essential existing theorem in computer science has yet been considered worth a similar effort, but it could well happen in the very near future. For example, existing results in security would often benefit from a formal development allowing us to exhibit the essential hypotheses under which the result really holds. CPP would again be a natural international forum for this kind of work, either in mathematics or in computer science, and would participate strongly in the emergence of this paradigm.
On the other hand, there is a recent trend in computer science to formally prove new results in highly technical subjects such as computational logic, at least in part. In whichever scientific area, formal proofs have three major advantages: no assumption can be missing, as is sometimes the case; the result cannot be disputed by a wrong counterexample, as sometimes happens; and more importantly, a formal development often results in a better understanding of the proof or program, and hence results in easier and better implementation. This new trend is becoming strong in computer science work, but is not recognized yet as it should be by traditional conferences. CPP would be a natural forum promoting this trend.
There are not many proof assistants around. There should be more, because progress benefits from competition. On the other hand, there is much theoretical work that could be implemented in the form of a proof assistant, but this does not really happen. One reason is that it is hard to publish a development work, especially when this requires a long-term effort as is the case for a proof assistant. It is even harder to publish work about libraries which, we all know, are fundamental for the success of a proof assistant. CPP would pay particular attention in publishing, publicizing, and promoting this kind of work.
Finally, CPP also aims to be a publication arena for innovative teaching experiences, in computer science or mathematics, using proof assistants in an essential way. These experiences could be submitted in an innovative format to be defined.