[发明专利]一种结构化文本程序的自动化验证方法在审
申请号: | 201810167496.X | 申请日: | 2018-02-28 |
公开(公告)号: | CN108446121A | 公开(公告)日: | 2018-08-24 |
发明(设计)人: | 史建琦;黄滟鸿;卜祥兴;熊家文;佘庆 | 申请(专利权)人: | 华东师范大学;上海华元创信软件有限公司 |
主分类号: | G06F8/41 | 分类号: | G06F8/41 |
代理公司: | 北京辰权知识产权代理有限公司 11619 | 代理人: | 刘广达 |
地址: | 200062 上*** | 国省代码: | 上海;31 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 结构化文本 验证 图形化 工业控制系统 抽象语法树 变量信息 迁移系统 时态逻辑 自动化 形式化验证 静态分析 人力成本 构建 解析 文本 | ||
本发明公开了一种结构化文本程序的自动化验证方法,属于工业控制系统形式化验证领域。所述方法包括:分别解析结构化文本程序及规范说明文本中的规范要求,得到对应的抽象语法树和线性时态逻辑公式;根据抽象语法树生成结构化文本程序的图形化中间描述,并在图形化中间描述上进行静态分析得到结构化文本程序中的变量信息;根据图形化中间描述和变量信息构建循环迁移系统模型;验证循环迁移系统模型是否满足线性时态逻辑公式。本发明中,采用自动化验证技术对结构化文本程序进行验证,不仅提高了验证效率,降低了人力成本,而且有效的提高了结构化文本程序对应的工业控制系统的安全性和可靠性。
技术领域
本发明涉及工业控制系统形式化验证技术领域,尤其涉及一种结构化文本程序的自动化验证方法。
背景技术
随着科技技术的不断发展与进步,智能化越来越广泛的走进各个领域。近年来,德国提出了“工业4.0”计划,旨在提升制造业的智能化水平,建立具有适应性、资源效率及基因工程学的智慧工厂,其他国家也相继提出类似的工业发展计划,可见提高制造业自动化水平已成为未来工业发展的趋势之一。可想而知的,将会有越来越多的工业控制系统在未来应用于不同的行业中;其中,在一些关键性行业,如轨道交通、航空航天等,工业控制系统的安全性和可靠性极其重要,任何微小的错误都可能引发重大的经济损失,甚至是人员伤亡。因而对工业控制系统进行有效验证及其重要,而且意义重大。
发明内容
为解决现有技术的不足,本发明提供一种结构化文本程序的自动化验证方法。
第一方面,本发明提供一种结构化文本程序的自动化验证方法,包括:
分别解析结构化文本程序及规范说明文本中的规范要求,得到对应的抽象语法树和线性时态逻辑公式;
根据所述抽象语法树生成所述结构化文本程序的图形化中间描述,并在所述图形化中间描述上进行静态分析得到所述结构化文本程序中的变量信息;
根据所述图形化中间描述和所述变量信息构建循环迁移系统模型;
验证所述循环迁移系统模型是否满足所述线性时态逻辑公式。
可选地,所述分别解析结构化文本程序及规范说明文本中的规范要求,得到对应的抽象语法树和线性时态逻辑公式,具体包括:
解析结构化文本程序得到抽象语法树;
解析规范说明文本中的规范要求得到对应的程序所具备的性质,根据得到的程序所具备的性质生成对应的线性时态逻辑公式。
可选地,所述根据所述抽象语法树生成所述结构化文本程序的图形化中间描述,并在所述图形化中间描述上进行静态分析得到所述结构化文本程序中的变量信息,具体为:
解析所述抽象语法树并生成所述结构化文本程序的图形化中间描述,在所述图形化中间描述上进行依赖分析得到所述结构化文本程序中输出变量的依赖集合,并对所述输出变量进行值集分析得到输出变量的值集。
可选地,所述根据所述图形化中间描述和所述变量信息构建循环迁移系统模型,具体为:根据所述图形化中间描述、所述输出变量的依赖集合和输出变量的值集,构建循环迁移系统模型。
可选地,所述验证所述循环迁移系统模型是否满足所述线性时态逻辑公式,具体为:遍历所述循环迁移系统模型的状态空间,验证所述状态空间中的各状态是否满足所述线性时态逻辑公式。
可选地,当验证所述循环迁移系统模型不满足所述线性时态逻辑公式时,还包括:输出不满足原因。
第二方面,本发明提供一种结构化文本程序的自动化验证设备,包括:
一个或多个处理器,存储一个或多个程序的存储装置;
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于华东师范大学;上海华元创信软件有限公司,未经华东师范大学;上海华元创信软件有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201810167496.X/2.html,转载请声明来源钻瓜专利网。