Hacker News with Generative AI: Formal Verification

Clean, a formal verification DSL for ZK circuits in Lean4 (zksecurity.xyz)
We are really excited to share our initial steps towards building clean, an embedded DSL and formal verification framework for ZK circuits in Lean4.
HoarePrompt: Structural Reasoning About Program Correctness in Natural Language (github.com/msv-lab)
HoarePrompt structurally reasons about program correctness in natural language using large language models (LLMs). Drawing inspiration from the strongest postcondition calculus, it employs a step-by-step process to generate natural language descriptions of reachable program states at various program points. By aligning formal semantics with informal requirements, HoarePrompt enables LLMs to detect bugs that violate natural language specifications.
Show HN: Formal Verification for Machine Learning Models Using Lean 4 (github.com/fraware)
Welcome to the Formal Verification of Machine Learning Models in Lean project. This repository provides a framework for specifying and proving properties—such as robustness, fairness, and interpretability—of machine learning models using Lean 4.
Locks, leases, fencing tokens, FizzBee (surfingcomplexity.blog)
FizzBee is a new formal specification language, originally announced back in May of last year. FizzBee’s author, Jayaprabhakar (JP) Kadarkarai, reached out to me recently and asked me what I thought of it, so I decided to give it a go.
Coq-of-rust: Formal verification tool for Rust (github.com/formal-land)
Formal verification tool for Rust: check 100% of execution cases of your programs 🦀 to make applications with no bugs! ✈️ 🚀 ⚕️ 🏦
Software Foundations (cis.upenn.edu)
The Software Foundations series is a broad introduction to the mathematical underpinnings of reliable software.
Formal Verification of Zero-Downtime Database Migration in PlusCal (biradarganesh25.github.io)
Formal verification can be used to analyze complex systems to ensure their correctness.
Comparing Two Verilog CPU Implementations Using EBMC (philipzucker.com)
About a year ago my friends and I built a 4bit cpu out of a kit from aliexpress. https://www.philipzucker.com/td4-4bit-cpu/ It’s a lot of fun. I also think the system is so simple that is is kind of a nice target for tinkering around with formal methods.
Five Kinds of Nondeterminism (buttondown.com)
No newsletter next week, I'm teaching a TLA+ workshop.
Comparing Two Verilog CPU Implementations Using EBMC (philipzucker.com)
About a year ago my friends and I built a 4bit cpu out of a kit from aliexpress. https://www.philipzucker.com/td4-4bit-cpu/ It’s a lot of fun. I also think the system is so simple that is is kind of a nice target for tinkering around with formal methods.
Nvidia Security Team: “What if we just stopped using C?” (2022) (adacore.com)
Today I want to share a great story about why many NVIDIA products are now running formally verified SPARK code. This blog post is in part a teaser for the case study that NVIDIA and AdaCore published today.
Preventing conflicts in authoritative DNS config using formal verification (cloudflare.com)
Over the last year, Cloudflare has begun formally verifying the correctness of our internal DNS addressing behavior — the logic that determines which IP address a DNS query receives when it hits our authoritative nameserver.
Compiling C to Safe Rust, Formalized (arxiv.org)
The popularity of the Rust language continues to explode; yet, many critical codebases remain authored in C, and cannot be realistically rewritten by hand. Automatically translating C to Rust is thus an appealing course of action.
The Hoare Cube (wordpress.com)
I wrote earlier this year about my attempt to understand the repercussions of toggling and when giving a semantics to Hoare triples.
Discharging Lean goals into SMT solvers (github.com/ufmg-smite)
This project is inspired by SMTCoq and aims to provide Lean tactics that discharge goals into SMT solvers. It is under active development and is currently in a beta phase. While it is ready for use, it is important to note that there are still some rough edges and ongoing improvements being made.
Modelling the archetype of a message-passing bug with TLA+ (2022) (medium.com)
Two years ago, I tried to describe “the archetype of a message-passing bug”, using both a real-world example in Rust, as well as plain English.
The Future of TLA+ [pdf] (azurewebsites.net)
Streams, Calculational Proofs and Dafny (rdivyanshu.github.io)
Finding Simple Rewrite Rules for the JIT with Z3 (pypy.org)
Nondeterminism in Formal Specification (buttondown.email)
Lessons from Formally Verified Deployed Software Systems (arxiv.org)
Some notes on Rust, mutable aliasing and formal verification (dreamwidth.org)
Translation of Rust's core and alloc crates to Coq for formal verification (formal.land)
New Foundations is consistent – a difficult mathematical proof proved using Lean (leanprover-community.github.io)