[发明专利]一种基于模型转换的状态机模型时序性质验证方法有效

专利信息
申请号: 201910606311.5 申请日: 2019-07-05
公开(公告)号: CN110532167B 公开(公告)日: 2021-05-04
发明(设计)人: 黄滟鸿;史建琦;张继;郭欣;施健 申请(专利权)人: 华东师范大学;上海丰蕾信息科技有限公司
主分类号: G06F11/36 分类号: G06F11/36
代理公司: 北京辰权知识产权代理有限公司 11619 代理人: 刘广达
地址: 200062 上*** 国省代码: 上海;31
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 一种 基于 模型 转换 状态机 时序 性质 验证 方法
【权利要求书】:

1.一种基于模型转换的状态机模型时序性质验证方法,其特征在于,包括:

模型解析步骤,解析高安全性的应用程序开发环境SCADE文本模型,得到语法树实例;所述模型解析步骤的实现过程包括:根据SCADE文本模型的语法语义声明,使用另一个语言识别工具ANTLR格式,将SCADE语法语义声明写成对应的ANTLR文件,所述ANTLR文件描述SCADE语言的语法语义声明;根据ANTLR文件中的声明,使用对应的Java监听器,对SCADE文本模型进行监听,得到语法树信息;根据语法树信息生成语法树实例;

符号表容器步骤,装载语法树实例,得到符号表实例;

模型转换步骤,根据模型转换规则将符号表实例转换为符号模型验证器NuSMV模型;所述模型转换规则引入两个布尔类型的触发器参数active和default;

模型检查步骤,根据线性时序逻辑LTL公式及计算树逻辑CTL公式验证NuSMV模型的时序性质,其中,

模型转换规则基于两类机制,分别是层次化状态机结构转换机制和变量监控机制;层次化状态机结构转换机制通过要引入触发器参数规则来帮助转换过程,最终在NuSMV目标模型中构建出SCADE状态机的层次结构,同时还定义状态转移转换规则,从而使得每一个子状态机都能够用NuSMV模型中的一个模块来表示,并且模块中还声明了子状态机的关系;变量监控机制用于控制模型状态中的行为事件,SCADE状态中拥有具体事件操作,这些操作对应现实系统中的功能,改变着模型中的变量值;变量监控机制使用监控参数来确定这些操作是否执行,从而来间接操纵这些变量的变化。

2.如权利要求1所述的方法,其特征在于,所述符号表容器步骤的实现过程包括:

定义层次化结构符号表和子状态机结构符号表;

根据层次化结构符号表和子状态机结构符号表,对语法树实例进行装载,得到符号表实例。

3.如权利要求1所述的方法,其特征在于,所述模型检查步骤的实现过程包括:

根据LTL公式及CTL公式验证NuSMV模型的时序性质;

若当前所验证的时序性质得到满足,则进行下一个时序性质的验证;

若当前所验证的时序性质未得到满足,则输出反例信息,停止时序性质的验证。

4.如权利要求3所述的方法,其特征在于,停止时序性质的验证之后,还包括:

模型调试步骤,根据所述反例信息修改SCADE系统开发环境,生成新的SCADE文本模型,验证时序性质。

5.如权利要求1所述的方法,其特征在于,所述LTL公式根据SCADE文本模型的自然语言描述的时序安全需求确定。

6.如权利要求1所述的方法,其特征在于,所述CTL公式根据SCADE文本模型的自然语言描述的时序安全需求确定。

7.如权利要求1所述的方法,其特征在于,所述语法语义声明包括:程序语义、声明语义、类型声明、常量声明语义、自定义操作符节点声明语义、等式及表达式声明和SCADE状态机语义。

下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于华东师范大学;上海丰蕾信息科技有限公司,未经华东师范大学;上海丰蕾信息科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

本文链接:http://www.vipzhuanli.com/pat/books/201910606311.5/1.html,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

1、专利原文基于中国国家知识产权局专利说明书;

2、支持发明专利 、实用新型专利、外观设计专利(升级中);

3、专利数据每周两次同步更新,支持Adobe PDF格式;

4、内容包括专利技术的结构示意图流程工艺图技术构造图

5、已全新升级为极速版,下载速度显著提升!欢迎使用!

请您登陆后,进行下载,点击【登陆】 【注册】

关于我们 寻求报道 投稿须知 广告合作 版权声明 网站地图 友情链接 企业标识 联系我们

钻瓜专利网在线咨询

周一至周五 9:00-18:00

咨询在线客服咨询在线客服
tel code back_top