当前位置: 首页 > article >正文

Verus:基于 Rust 验证代码正确性,指南助你掌握验证概念与技术!

键盘快捷键按 ← 或 → 可在各章节间导航按 S 或 / 能在本书中搜索按 ? 可显示此帮助信息按 Esc 则可隐藏此帮助信息。模式选项包括自动明亮模式Rust 模式煤炭模式海军蓝模式Ayu 模式Verus 教程与参考手册Verus 概述Verus 是用于验证用 Rust 编写的代码正确性的工具。其主要目标是基于现有验证框架如 Dafny、Boogie、F*、VCC、Prusti、Creusot、Aeneas、Cogent、Rocq 和 Isabelle/HOL的理念验证底层系统代码的完整功能正确性。验证是静态的Verus 不会添加运行时检查而是使用计算机辅助定理证明来静态验证可执行的 Rust 代码在所有可能的执行情况下都能满足用户提供的某些规范。更详细地说Verus 的目标如下提供一种纯数学语言来表达规范类似于 Dafny、Creusot、F*、Coq、Isabelle/HOL。提供一种基于经典逻辑类似于 Dafny的数学语言来表达证明类似于 Dafny、F*、Coq、Isabelle/HOL。提供一种基于 Rust类似于 Prusti、Creusot 和 Aeneas的底层命令式语言来表达可执行代码类似于 VCC。基于以下原则生成小型、简单的验证条件以便像 Z3 这样的 SMT 求解器能够高效求解使数学规范语言与 SMT 求解器的数学语言相近类似于 Boogie。使用轻量级线性类型检查而非 SMT 求解来推理内存和别名问题类似于 Cogent、Creusot、Aeneas 和 线性 Dafny。我们认为 Rust 是实现这些目标的理想语言。Rust 将底层数据操作包括手动内存管理与先进的高级安全类型系统相结合。该类型系统包含了高级验证语言中常见的特性如代数数据类型支持模式匹配、类型类和一等函数。这使得以自然的方式表达规范和证明变得容易。更重要的是Rust 的类型系统对线性类型和借用提供了复杂的支持这处理了大部分关于内存和别名的推理。因此剩余的推理可以忽略大多数内存和别名问题将 Rust 代码视为纯函数式语言编写的代码从而使验证更加容易。目前我们不打算支持所有 Rust 特性和库相反我们将专注于支持用户所需的高价值特性和库。验证验证器本身。验证 Rust/LLVM 编译器。本指南本指南假设你已经对 Rust 编程的基础知识有一定了解。如果你还不了解我们建议你花几个小时浏览 学习 Rust 页面。熟悉 Rust 对使用 Verus 很有帮助因为 Verus 基于 Rust 的语法和类型系统来表达规范、证明和可执行代码。实际上并没有单独的规范和证明语言规范和证明都是用 Rust 语法编写并使用 Rust 的类型检查器进行类型检查。因此如果你已经掌握了 Rust那么开始使用 Verus 会更容易。然而验证 Rust 代码的正确性需要一些超出编写普通可执行 Rust 代码的概念和技术。例如Verus 通过宏扩展了 Rust 的语法引入了用于编写规范和证明的新概念如 forall、exists、requires 和 ensures还引入了新的类型如数学整数类型 int 和 nat。证明一个 Rust 函数满足其后置条件ensures 子句或一个函数调用满足其前置条件requires 子句可能具有挑战性。因此本指南的教程将带你逐步了解各种概念和技术从相对简单的概念关于整数的基本证明开始过渡到中等难度的挑战关于数据结构的归纳证明然后再到更高级的主题如使用 forall 和 exists 对数组进行证明以及对并发代码进行证明。所有这些证明都借助了自动定理证明器具体来说是 Z3一个可满足性模理论求解器简称 “SMT 求解器”。SMT 求解器通常能够在无需程序员额外帮助的情况下证明简单的属性如布尔值或整数算术的基本属性。然而更复杂的证明通常需要程序员和 SMT 求解器共同努力。因此本指南还将帮助你了解 SMT 求解的优势和局限性并提供如何填补 SMT 求解器无法自动处理的证明部分的建议。例如SMT 求解器通常无法自动进行归纳证明但你可以通过编写一个递归的 Rust 函数其 ensures 子句表达归纳假设来编写归纳证明。

相关文章:

Verus:基于 Rust 验证代码正确性,指南助你掌握验证概念与技术!

键盘快捷键 按 ← 或 → 可在各章节间导航;按 S 或 / 能在本书中搜索;按 ? 可显示此帮助信息;按 Esc 则可隐藏此帮助信息。 模式选项包括: 自动明亮模式Rust 模式煤炭模式海军蓝模式Ayu 模式 Verus 教程与参考手册Verus 概述 Ver…...

如何用雹(Hail)优化Android设备性能:完整指南

如何用雹(Hail)优化Android设备性能:完整指南 【免费下载链接】Hail Disable / Hide / Suspend / Uninstall Android apps without root. 项目地址: https://gitcode.com/gh_mirrors/ha/Hail 雹(Hail)是一款专为…...

第二章Transformer架构解析(下)

第二章 Transformer架构解析(下) 在进入最关键的Attention之前,我们回顾一下上一个章节的内容:学到的概念核心作用Tokenization文字 → TokenEmbeddingToken → 向量Positional Encoding给向量添加位置信息LayerNorm Softmax层归一化缩放 数字变概率分…...

S32K148的FlexCAN FD从零到跑通:基于S32KDS 2.2和SDK 3.0.0的保姆级配置流程

S32K148的FlexCAN FD从零到跑通:基于S32KDS 2.2和SDK 3.0.0的保姆级配置流程 对于刚接触NXP S32K系列微控制器的开发者来说,FlexCAN FD模块的配置往往是一个令人头疼的挑战。本文将带你从零开始,一步步完成S32K148开发板上FlexCAN FD模块的完…...

从国赛到开源:手把手教你用Arduino Mega和麦克纳姆轮复刻一个物料搬运机器人

从零构建物料搬运机器人:Arduino Mega与麦克纳姆轮实战指南 当第一次看到物料搬运机器人在赛场上流畅地横移、抓取、堆码时,大多数人的反应都是"这简直像科幻电影"。但拆解其核心技术后,你会发现实现这样的机器人并不需要深奥的理…...

保姆级教程:用BAPI_GOODSMVT_CREATE搞定SAP生产订单入库(101/262)与移库(411/412)

SAP物料凭证实战指南:BAPI_GOODSMVT_CREATE深度解析 1. 核心功能与应用场景 物料凭证(Material Document)是SAP系统中记录库存变动的核心单据,而BAPI_GOODSMVT_CREATE则是实现这一功能的关键接口。这个BAPI的强大之处在于它能够覆…...

告别ST依赖:手把手教你为华大HC32L130(M0+)搭建纯净KEIL5工程(附源码)

从ST到华大:HC32L130纯净KEIL5工程构建实战指南 第一次接触华大半导体的HC32L130芯片时,我习惯性地按照ST标准库的工程模板开始搭建环境,结果在第一步就遇到了障碍——华大的驱动包里竟然找不到熟悉的CMSIS内核文件。这种"水土不服"…...

基于FPGA的QAM调制解调:详细实验文档

基于FPGA的QAM调制解调,有详细实验文档16QAM 调制解调 FPGA 实现 —— 功能全景解析(面向 Reviewer、维护者及二次开发者)------------------------------------------------一、项目定位------------------------------------------------“…...

三步搞定Windows网络测速:iperf3-win-builds终极指南

三步搞定Windows网络测速:iperf3-win-builds终极指南 【免费下载链接】iperf3-win-builds iperf3 binaries for Windows. Benchmark your network limits. 项目地址: https://gitcode.com/gh_mirrors/ip/iperf3-win-builds 想要精准测量网络带宽却苦于找不到…...

别再死磕谱域了!GraphSAGE和GAT的采样聚合与注意力机制,手把手教你搞定空域图卷积

空域图卷积实战:从GraphSAGE的邻居采样到GAT的注意力加权 当你在处理社交网络中的用户关系图时,传统的谱域方法可能让你束手无策——新用户不断加入,关系动态变化,而谱域卷积要求固定的图结构。这就是为什么越来越多的开发者开始转…...

当Python遇上易经:教你用Pandas分析生辰八字的五行平衡(可视化版)

当Python遇上易经:用数据科学解码生辰八字的五行平衡 在数据驱动的时代,传统文化与现代技术的碰撞总能擦出令人惊喜的火花。作为一名常年与数据打交道的分析师,你是否想过用熟悉的Pandas和Matplotlib来解读古老的易经智慧?本文将带…...

从仿真到实战:如何用VPI+Matlab复现一篇光通信顶会论文的DSP算法?

从仿真到实战:如何用VPIMatlab复现光通信顶会论文的DSP算法? 在光通信领域,学术论文中提出的数字信号处理(DSP)算法往往需要经过严格的仿真验证才能应用于实际工程。本文将带你深入探索如何利用VPI和Matlab联合仿真环境…...

RTX 4090显卡深度学习环境配置:从Anaconda到PyTorch的完整流程(Win11+CUDA11.7.0)

RTX 4090深度学习环境配置实战:从零搭建高效开发环境 引言 对于深度学习研究者和开发者来说,一台配置得当的工作站是高效工作的基础。RTX 4090作为NVIDIA最新一代消费级显卡,凭借其强大的计算能力和24GB显存,已经成为许多深度学…...

基于MMC储能的分布式储能系统Simulink仿真及SOC均衡控制:模型预测控制在DC-DC升...

mmc储能 分布式储能simulink仿真 soc均衡控制 采用模型预测控制 dcdc升降压储能模块最近在搞MMC储能的仿真项目,发现这玩意儿真是电网调频的宝藏工具。特别是当分布式储能单元遇上模块化多电平换流器,SOC均衡控制就成了最烧脑的环节。今天咱们就撸起袖…...

戴尔笔记本智能散热管理:DellFanManagement开源解决方案深度解析

戴尔笔记本智能散热管理:DellFanManagement开源解决方案深度解析 【免费下载链接】DellFanManagement A suite of tools for managing the fans in many Dell laptops. 项目地址: https://gitcode.com/gh_mirrors/de/DellFanManagement DellFanManagement是一…...

别再只会用Burp Suite了!手把手教你用Python写一个简单的Web Fuzzer(附完整代码)

从零构建Python Web Fuzzer:超越工具使用者的实战指南 当你已经熟练使用Burp Suite等现成工具进行Web安全测试时,是否曾好奇这些工具背后的工作原理?本文将带你深入Fuzz测试的核心机制,通过Python亲手构建一个功能完整的Web参数F…...

中小企业财税合规实战:一家区域财税服务商的体系拆解

关键词:财税合规 代理记账 中小企业 税务筹划 本地化服务在创业与中小企业经营中,财税问题往往是最容易踩坑却又最容易被忽视的环节。账务混乱、报税逾期、政策误读,轻则罚款,重则影响企业信用甚至经营存续。本文以一家扎根江…...

CCHP经济优化运行与多能源系统优化的MATLAB程序

冷热电联供系统CCHP经济优化运行多能源系统优化MATLAB程序 (1)该程序为冷热电联供系统CCHP经济优化运行,多能源系统优化,硕士学位论文源程序,配有该论文。(2)通过该程序可得到冷热电联供系统的经…...

别再折腾环境变量了!手把手教你用VS2019自带的Python环境一键安装pandas

VS2019内置Python环境极简指南:零配置玩转数据分析 作为.NET或C开发者,当你第一次尝试在Visual Studio 2019中使用Python时,是否曾被环境变量配置、包安装失败等问题困扰?其实,VS2019早已内置了完整的Python开发工具链…...

5个实用技巧:用Marp打造专业级移动端演示文稿

5个实用技巧:用Marp打造专业级移动端演示文稿 【免费下载链接】marp The entrance repository of Markdown presentation ecosystem 项目地址: https://gitcode.com/gh_mirrors/mar/marp Marp是一个基于Markdown的演示文稿生态系统,让开发者能够用…...

告别Manjaro软件安装失败:从换源、yay到手动下载构建文件的完整自救手册

Manjaro软件安装全攻略:从基础配置到高阶排错实战 最近在Manjaro社区论坛上看到一个高频问题:"为什么我的软件安装总是失败?"这背后其实涉及Linux发行版特有的包管理机制。作为一款基于Arch的滚动发行版,Manjaro在提供最…...

国产175℃随钻伽马探测器的产业生态与趋势展望

近年来,国内随钻测井装备的自主化进程明显加速,其中耐温175℃探测器的成熟供应是产业链升级的关键一环。青岛智腾ZT系列伽马探测器的推出,不仅丰富了高温LWD核心部件的选择,也折射出国产井下仪器产业生态的若干趋势。 核心元器件自…...

用Python的SymPy库手把手验证sinx和cosx的泰勒展开式(附代码)

用Python的SymPy库手把手验证sinx和cosx的泰勒展开式(附代码) 泰勒展开式是高等数学中一个极其重要的概念,它将复杂的函数表示为无限多项式的和。对于理工科学生和开发者来说,理解泰勒展开不仅有助于深入掌握微积分,还…...

Win11下Pytorch GPU环境搭建:从驱动匹配到IDE集成的完整指南

1. 硬件准备与驱动检查 刚接触深度学习的同学可能对GPU加速充满期待,但首先要确认你的设备是否支持。我遇到过不少朋友兴冲冲开始安装,结果发现显卡根本不兼容,白白浪费半天时间。Win11系统对NVIDIA显卡的支持相当友好,不过还是需…...

避坑指南:STM32 HAL库与标准库下CAN通信配置的10个常见错误(基于STM32F405实测)

STM32 CAN通信实战避坑指南:HAL库与标准库配置差异全解析 在工业控制和汽车电子领域,CAN总线因其高可靠性和实时性成为首选通信方案。STM32系列MCU内置的bxCAN控制器为开发者提供了便捷的实现路径,但不同库函数(HAL与标准库&#…...

GESP2023年6月认证C++三级( 第一部分选择题(1-8))

🏰 第一题:程序变身魔法1、🧙‍♂️老师说:你写了一段程序,就像写了一张“魔法咒语纸”。但是电脑看不懂人类语言,它只懂“机器语言”。2、❓问题:要让程序真正跑起来,需要哪一步&am…...

为什么定义常量要用 static final 修饰,final 表示不可修改,static 表示全局唯一,和在一起表示全局常量

final 表示不可修改,static 表示全局唯一,和在一起表示全局常量。static 修饰的成员变量随着类的加载而创建,可以直接使用类调用,也可以使用类的实例对象调用,多个实例对象共享同一个 static 修饰的静态变量。我的理解…...

别再只盯着通道注意力了!用HAN的层注意力模块(LAM)给你的超分模型提提神

突破超分辨率瓶颈:层注意力机制(LAM)的深度实践指南 当你在深夜调试超分辨率模型时,是否遇到过这样的困境——明明已经堆叠了足够深的网络层数,尝试了各种通道注意力模块,甚至加入了密集连接,但…...

星穹铁道跃迁记录导出工具:终极免费数据分析指南 [特殊字符]

星穹铁道跃迁记录导出工具:终极免费数据分析指南 🚀 【免费下载链接】star-rail-warp-export Honkai: Star Rail Warp History Exporter 项目地址: https://gitcode.com/gh_mirrors/st/star-rail-warp-export 你是否想知道自己在《崩坏&#xff1…...

3步搭建专业光猫配置解析平台:ZET解码器深度指南

3步搭建专业光猫配置解析平台:ZET解码器深度指南 【免费下载链接】ZET-Optical-Network-Terminal-Decoder 项目地址: https://gitcode.com/gh_mirrors/ze/ZET-Optical-Network-Terminal-Decoder ZET-Optical-Network-Terminal-Decoder是一款专为网络工程师和…...