[发明专利]一种基于概率模型的程序错误检测方法及系统有效

专利信息
申请号: 201510982321.0 申请日: 2015-12-22
公开(公告)号: CN105608006B 公开(公告)日: 2018-06-08
发明(设计)人: 陈灯;魏巍;张彦铎;李晓林;李迅;于宝成;鲁统伟;闵峰;周华兵;朱锐;卢涛;彭丽 申请(专利权)人: 武汉工程大学
主分类号: G06F11/36 分类号: G06F11/36
代理公司: 湖北武汉永嘉专利代理有限公司 42102 代理人: 许美红
地址: 430074 湖北*** 国省代码: 湖北;42
权利要求书: 查看更多 说明书: 查看更多
摘要: 发明公开了一种基于概率模型的程序错误检测方法及系统,该方法包括以下步骤:S1、获取概率模型和待检测程序,从待检测程序中提取待检测的函数调用序列集合;S2、获取单个待检测的函数调用序列,求解最相似的函数调用序列集合,并计算联合概率;S3、根据相似集合对该待检测序列进行检测并生成修复方案;S4、完成该待检测序列的检测和修复后,记录检测到的各个错误信息及修复方案;S5、对待检测集合中的所有待检测序列检测完毕后,输出程序错误报告。本发明无需处理概率模型转换到确定性模型时的阈值选择问题,能够快速的检测程序中的错误,且检测准确率高。
搜索关键词: 检测 概率模型 函数调用序列 待检测序列 集合 待检测程序 错误检测 修复 计算联合概率 错误报告 错误信息 记录检测 输出程序 阈值选择 准确率 求解 确定性 转换
【主权项】:
一种基于概率模型的程序错误检测方法,其特征在于,包括以下步骤:S1、获取概率模型和待检测程序,从待检测程序中提取待检测的函数调用序列集合,记作待检测集合;概率模型为API使用协议库,该概率模型由人为给出,或采用自动化方法从程序中获得;S2、从待检测集合中获取单个待检测的函数调用序列,记作待检测序列,求解概率模型中与该待检测序列最相似的函数调用序列集合,记作相似集合;并计算相似集合中各函数调用序列在概率模型中的联合概率;根据概率模型A验证单个待检测的函数调用序列q的正确性,其具体方法为:根据概率模型A和待检测序列q求解函数调用序列集合P,使得任意的函数调用序列p∈P,满足下列条件:a、设A*为去掉概率模型A中的概率后获得的确定性模型;b、函数调用序列p能够由A*产生;c、设p'为由A*产生的任一函数调用序列,则有δ(p,q)≤δ(p′,q),其中δ(p,q)表示函数调用序列p和q之间的距离;计算联合概率的方法具体为:对于任意的函数调用序列p∈函数调用序列集合P,根据概率模型计算p的联合概率,联合概率为函数调用序列在概率模型中所对应路径上的概率的乘积;根据该联合概率对P中所有的函数调用序列按照从大到小进行排序;S3、根据相似集合对该待检测序列进行检测并生成修复方案,相似集合中每一条函数调用序列对应一个错误报告,所有错误报告构成一个错误报告组,组内错误报告按照函数调用序列的联合概率降序排列;对待检测序列进行检测和修复的具体方法为:按照联合概率从大到小依次获取函数调用序列集合P中函数调用序列p,比较函数调用序列p和待检测序列q,若二者相同,则q为正确的函数调用序列;否则,其中包含有错误;以最少的编辑操作将q转换为p,实施操作的位置和方法即为错误产生点和修复方案;S4、完成该待检测序列的检测和修复后,记录检测到的各个错误信息及修复方案,包括:错误的函数调用名称、错误产生的位置;S5、对待检测集合中的所有待检测序列检测完毕后,输出程序错误报告。
下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于武汉工程大学,未经武汉工程大学许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

本文链接:http://www.vipzhuanli.com/patent/201510982321.0/,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

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

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

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

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

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

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

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

钻瓜专利网在线咨询

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

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