记录学习LTL2BA和SPIN实现LTL satisfiability checking

2023-12-10 19:40

本文主要是介绍记录学习LTL2BA和SPIN实现LTL satisfiability checking,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这里记录一下学习LTL2BA和SPIN实现LTL satisfiability checking

1. LTL satisfiability checking关注这样一类问题:对于一个系统,给定一个由线性时序逻辑(LTL)描述的性质,判断系统是否具有该性质,解决该问题的理论方法之一简单理解是将LTL性质转换为等价的Buchi自动机,再列举系统所有的运行轨迹,检验这些运行轨迹能否使得Buchi自动机最终停留在“接受”的状态。

2. 实现LTL satisfiability checking的方法/工具有很多,读者可以参考下面这篇文章做出的总结:

Rozier, K. Y., & Vardi, M. Y. (2007, July). LTL satisfiability checking. In International SPIN Workshop on Model Checking of Software (pp. 149-167). Springer, Berlin, Heidelberg.

3. 本文主要介绍一下以SPIN为工具的LTL satisfiability checking,

  • 输入:Promela(PROcess MEta LAnguage,一种用于建模并行程序的语言),一个用于LTL satisfiability checking的Promela(.pml)文件包含两部分,分别是对于待验证系统的描述,和对于待验证性质的描述
  • 输出:系统是否满足给定的性质,如果不满足则会连带输出一条系统不满足该性质的运行轨迹
  • 对于性质的定义,SPIN可以接受LTL性质(其会将输入的LTL性质转换为Buchi自动机),也可以直接接受Buchi自动机(以“never claims”的形式进行定义);另外一种输入方法是先使用特定工具将LTL性质转换为Buchi自动机,再将转换结果输入SPIN,这些工具包括LTL2AUT,LTL2BA,LTL2Buchi(JavaPathFinder)等。

本文学习使用的是LTL2BA+SPIN的组合

4. LTL2BA

官网为http://www.lsv.fr/~gastin/ltl2ba/index.php,其提供了一个在线的demo,LTL2BA的理论文章以及LTL2BA的下载。

  • demo的应用示例:输入LTL公式“[] ( s ->  ( X e ) )”(意为系统当前状态如果使得命题s成立,则下一个状态需使得命题e成立),以下是输出的Buchi自动机表达式和图像
never { /* G ( c ->  ( X s ) ) */
accept_init :    /* init */if:: (!c) -> goto accept_init:: (1) -> goto accept_S2fi;
accept_S2 :    /* 1 */if:: (!c && s) -> goto accept_init:: (s) -> goto accept_S2fi;
}

 

  • LTL2BA的下载和安装:官网上有下载连接,下载解压后需要编译c文件,作者运行系统是WIN10,采用的具体方法是下载cygwin→安装过程中勾选gcc-core和make包→将cygwin的bin目录添加至环境变量PATH→命令行在LTL2BA根目录下执行命令make -f Makefile
  • 编译完成后即可命令行使用ltl2ba命令,使用方法可参见根目录下的README文档,一般使用的命令是ltl2ba -f 'formula'和ltl2ba -F xxx.txt,前者直接在命令行中输入LTL公式,后者则是将LTL公式保存在.txt文件中再运行命令
  • 其它运行Makefile文件的方法可参见stackoverflow上的这个帖子How to run a makefile in Windows

这篇关于记录学习LTL2BA和SPIN实现LTL satisfiability checking的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/478155

相关文章

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

SpringBoot3实现Gzip压缩优化的技术指南

《SpringBoot3实现Gzip压缩优化的技术指南》随着Web应用的用户量和数据量增加,网络带宽和页面加载速度逐渐成为瓶颈,为了减少数据传输量,提高用户体验,我们可以使用Gzip压缩HTTP响应,... 目录1、简述2、配置2.1 添加依赖2.2 配置 Gzip 压缩3、服务端应用4、前端应用4.1 N

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

Java枚举类实现Key-Value映射的多种实现方式

《Java枚举类实现Key-Value映射的多种实现方式》在Java开发中,枚举(Enum)是一种特殊的类,本文将详细介绍Java枚举类实现key-value映射的多种方式,有需要的小伙伴可以根据需要... 目录前言一、基础实现方式1.1 为枚举添加属性和构造方法二、http://www.cppcns.co

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

MySQL双主搭建+keepalived高可用的实现

《MySQL双主搭建+keepalived高可用的实现》本文主要介绍了MySQL双主搭建+keepalived高可用的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、测试环境准备二、主从搭建1.创建复制用户2.创建复制关系3.开启复制,确认复制是否成功4.同

Java实现文件图片的预览和下载功能

《Java实现文件图片的预览和下载功能》这篇文章主要为大家详细介绍了如何使用Java实现文件图片的预览和下载功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... Java实现文件(图片)的预览和下载 @ApiOperation("访问文件") @GetMapping("

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

使用Sentinel自定义返回和实现区分来源方式

《使用Sentinel自定义返回和实现区分来源方式》:本文主要介绍使用Sentinel自定义返回和实现区分来源方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Sentinel自定义返回和实现区分来源1. 自定义错误返回2. 实现区分来源总结Sentinel自定