【软件分析第12讲-学习笔记】可满足性模理论 Satisfiability Modulo Theories
创始人
2024-01-25 03:58:52
0

文章目录

  • 前言
  • 正文
    • 从SAT到SMT
    • SMT历史
    • z3求解器
    • SMT求解
    • 命题逻辑、一阶逻辑和二阶逻辑
  • 小结
  • 参考文献

前言

创作开始时间:2022年11月16日16:18:59

如题,学习一下可满足性模理论 Satisfiability Modulo Theories的相关知识。参考:熊英飞老师2018《软件分析》课件

正文

从SAT到SMT

理论(Theory):

  • 理论用于对这类符号(如大于,小于)赋予含义
  • 理论包含一组公理和这组公理能推导出的结论

SMT可满足性模理论:

  • 给定一组理论,根据给定背景逻辑,求在该组理论解释下公式的可满足性。

SMT历史

  • Eager方法:将SMT编码成SAT问题
  • Lazy方法:黑盒混合SAT求解器和各种理论求解器

z3求解器

参考:z3求解器(SMT)解各类方程各种逻辑题非常简单直观 https://blog.csdn.net/as604049322/article/details/120279521

z3-solver是由Microsoft Research(微软)开发的SMT求解器,它用于检查逻辑表达式的可满足性,可以找到一组约束中的其中一个可行解,缺点是无法找出所有的可行解

这个网页给了很多求解实例(含Python源码)。

SMT求解

参考:

  • 金继伟,马菲菲,张 健.SMT求解技术简述[J].计算机科学与探索,2015,9(7):769-780

SAT(satisfiability)问题指的是命题逻辑公式的
可满足性问题。随着研究的深入,人们发现SAT在 表达能力上有很大的局限性,许多应用用SAT进行 编码并不是很明智的选择,它们需要比SAT更强的 表达方式。
SMT问题是在特定理论下判定一阶逻辑公式可满足性问题。SMT的全称是Satisfiability Modulo Theories,可被翻译为“可满足性模理论”、“多理论下的可满足性 问题”或者“特定(背景)理论下的可满足性问题”,其 判定算法被称为SMT求解器。
简单地说,一个SMT 公式是结合了理论背景的逻辑公式,其中的命题变 量可以代表理论公式。

命题逻辑、一阶逻辑和二阶逻辑

命题是具有真假值的陈述句。

一阶逻辑不同于单纯的“命题逻辑”,因为,一阶逻辑里面使用了任意和存在。举一个一阶逻辑表达式的例子:

谓词:一个含有变量的命题,例如上述math(x)。

二阶逻辑的量词符号竟然作用在谓词符号上∀ P \forall P∀P,之前我们在一阶谓词中只允许量词作用在个体上,例如∀ x P ( x ) \forall x P(x)∀xP(x)。这就是一阶逻辑和二阶逻辑的区别。

参考:

  • 数理逻辑初步:命题逻辑、一阶逻辑和二阶逻辑 https://blog.csdn.net/qq_43391414/article/details/117397388

小结

后续再补充完善。

创作结束时间:2022年11月16日16:55:49

参考文献

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
群晖外网访问终极解决方法:IP... 写在前面的话 受够了群晖的quickconnet的小水管了,急需一个新的解决方法&#x...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
Azure构建流程(Power... 这可能是由于配置错误导致的问题。请检查构建流程任务中的“发布构建制品”步骤,确保正确配置了“Arti...