[发明专利]一种单路径线性约束的循环程序终止性判断方法有效
申请号: | 201910051138.7 | 申请日: | 2019-01-11 |
公开(公告)号: | CN109901993B | 公开(公告)日: | 2022-01-28 |
发明(设计)人: | 李轶;杨文强;冯勇 | 申请(专利权)人: | 中国科学院重庆绿色智能技术研究院 |
主分类号: | G06F11/36 | 分类号: | G06F11/36 |
代理公司: | 暂无信息 | 代理人: | 暂无信息 |
地址: | 400714 重庆市北*** | 国省代码: | 重庆;50 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 路径 线性 约束 循环 程序 终止 判断 方法 | ||
本发明涉及一种单路径线性约束的循环程序终止性判断方法,包含以下步骤:步骤一、提取出单路径线性约束的循环程序;步骤二、将单路径线性约束的循环程序所转化成的线性不等式系统并求解,无解则该循环程序终止,有解则暂时无法判断其终止性;步骤三、判断线性不等式系统的解中是否存在不动点,存在则该循环程序不终止;如果不存在不动点且状态变量有界,则该循环程序终止,否则无法判断其终止性;步骤四、判断线性不等式系统的解空间的投影是否与循环条件相同,相同则该循环程序不终止,否则无法判断其终止性。该方法通过构造秩函数,采用单量词消去方法,能够在多项式时间内分析出程序的循环终止性,提高了计算效率。
技术领域
本发明涉及一种单路径线性约束的循环程序终止性判断方法,属于计算机技术领域。
背景技术
随着信息技术的迅猛发展,嵌入式系统在人类生活中发挥着越来越重的作用,而嵌入式程序系统运行中的可达性、终止性、不变式尤为重要,而程序的终止性分析是确保程序完全正确性的必要基础。技术人员在编写程序过程中总是希望能判断出程序是否终止,虽然一般的程序的终止性问题早已被证明是不可判定的,但是特殊的某些类程序还是可以分析出其终止性的,这也表明了对程序中终止性的研究是很有理论意义和实际应用意义的。当前,国际上主要通过合成秩函数来进行循环终止性分析,目前主要用来分析线性循环程序,通常基于G.E.Collins提出的柱形代数分解方法,但其采用混合量词消去方法,这样做会引入更多的变元,计算复杂度高。
近来,计算机代数和实代数理论也逐渐被应用于程序自动验证,针对一些线性和非线性循环程序进行了终止性判定。本发明针对单路径线性约束的循环程序提出了终止性问题分析方法,该方法被证明能准确的分析出该类循环的终止性问题。
发明内容
有鉴于此,本发明提供一种单路径线性约束的循环程序终止性判断方法,摒弃基于Farkas定理的方法,以达到减小计算复杂度,提高计算效率的目的。
为达到上述目的,本发明提供如下技术方案:
一种单路径线性约束的循环程序终止性判断方法,包括如下步骤:
步骤一、遍历程序,查找程序中的循环程序,提取出单路径线性约束的循环程序;
步骤二、依次对步骤一所述的单路径线性约束的循环程序所转化成的线性不等式系统并进行求解,如果无解,则该单路径线性约束的循环程序终止,有解则暂时无法判断其终止性;
步骤三、依次判断步骤二所述的有解的线性不等式系统的解中是否存在不动点,如果是,则该单路径线性约束的循环程序不终止;进一步,如果不存在不动点且状态变量有界,则该单路径线性约束的循环程序终止,否则无法判断其终止性;
步骤四、依次判断步骤三所述的无法判断的单路径线性约束的循环程序的线性不等式系统的解空间的投影是否与循环条件相同,如果相同,则该单路径线性约束的循环程序不终止。
进一步,所述步骤一所述的单路径线性约束的循环程序可以表述为:while{B·x0≤d}do{M1·xk+M2·xk+1≤c}end while;其中,分别为有理数矩阵,分别为有理数列向量,n、p、q分别为正整数,和分别对应第k次循环和第k+1次循环的实数列向量状态变量,特别地,k=0为初始时刻,该时刻对应的状态变量x0、x1可直接用来分析程序循环终止性。
进一步,所述步骤二所述的依次对步骤一所述的单路径线性约束的循环程序转化成的线性不等式系统形式为:其中,为有理数矩阵,和为待求解变量;然后利用量词消去方法对其解进行判定,如果无解,则该单路径线性约束的循环程序终止,有解则暂时无法判断其终止性。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于中国科学院重庆绿色智能技术研究院,未经中国科学院重庆绿色智能技术研究院许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201910051138.7/2.html,转载请声明来源钻瓜专利网。