[发明专利]一种基于LLVM中间表示程序切片的度量模型有效

专利信息
申请号: 201710089449.3 申请日: 2017-02-20
公开(公告)号: CN106933572B 公开(公告)日: 2020-05-19
发明(设计)人: 张迎周;闫丽;徐晨晨;吴寄语 申请(专利权)人: 南京邮电大学
主分类号: G06F8/35 分类号: G06F8/35;G06F8/40
代理公司: 南京经纬专利商标代理有限公司 32200 代理人: 许方
地址: 210003 江苏*** 国省代码: 江苏;32
权利要求书: 查看更多 说明书: 查看更多
摘要: 发明公开了一种基于LLVM中间表示程序切片的度量模型,包括:将源程序通过LLVM命令行转换成对应的LLVM IR语言;构建程序系统依赖图,对程序LLVM IR语句切片;根据程序切片的结果和源程序转换得到的LLVM IR语句得到程序中各模块的模块大小,输出变量的个数,根据各度量模块所有输出变量的切片集中最大的切片集大小和最小的切片集的大小,和所有变量的公共切片集;将上步所得值带入度量函数中,完成对函数的LLVM IR度量,然后计算程序的Halstead度量;将程序所有度量结果先去除具有相同作用的度量值,再构建复杂性度量函数Complexity,并对程序的各个模块的Complexity进行计算并根据其大小进行排序,软件开发或测试可根据各模块的复杂度大小合理分配开发资源,并进行错误检测。本发明有效提高了程序切片的通用性和度量精度。
搜索关键词: 一种 基于 llvm 中间 表示 程序 切片 度量 模型
【主权项】:
一种基于LLVM中间表示程序切片的度量模型,其特征在于,包括以下步骤:步骤(1)将源程序通过LLVM的命令行转换成对应的LLVM IR语言;步骤(2)将LLVM IR构建系统依赖图,得到对应的程序切片;步骤(3)得到源程序的输出变量对应的指令及指令集、程序操作符和操作数的信息,即:根据程序切片的结果和源程序转换得到的LLVM IR语句得到程序中每个模块的模块大小,输出变量的个数,根据每个度量模块所有输出变量的切片集中最大的切片集大小和最小的切片集的大小,和所有变量的公共切片集;步骤(4)根据LLVM IR的切片结果和各种度量公式计算函数模块的各度量值,即:将步骤(3)中得到的值带入到度量函数中,完成对函数的LLVM IR度量,然后计算程序的Halstead度量;步骤(5)根据各度量值计算评估,即:将程序所有的度量结果先去除具有相同作用的度量值,再将剩余的度量值根据对程序的可靠性,稳定性的影响情况进行排序,在软件测试阶段可根据模块排序将开发资源合理安排对模块进行检查。
下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

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

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

×

专利文献下载

说明:

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

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

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

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

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

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

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

钻瓜专利网在线咨询

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

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