[发明专利]一种基于多图多标记学习的软件Bug检测方法在审
申请号: | 202111514505.6 | 申请日: | 2021-12-13 |
公开(公告)号: | CN114168478A | 公开(公告)日: | 2022-03-11 |
发明(设计)人: | 印莹;赵宇海;任晨凤 | 申请(专利权)人: | 东北大学 |
主分类号: | G06F11/36 | 分类号: | G06F11/36;G06F16/901;G06F40/242;G06K9/62;G06N3/08 |
代理公司: | 沈阳东大知识产权代理有限公司 21109 | 代理人: | 梁焱 |
地址: | 110819 辽宁*** | 国省代码: | 辽宁;21 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 基于 多图多 标记 学习 软件 bug 检测 方法 | ||
1.一种基于多图多标记学习的软件Bug检测方法,其特征在于,该方法包括以下步骤:
步骤1:基于程序源代码对应的Bug报告获得所述程序源代码的Bug多标记,从而生成程序源代码的多标记数据;
步骤2:生成程序源代码的多图数据MG,从而获得与程序源代码相对应的多图多标记数据;
步骤3:从步骤2获得的多图数据MG中挖掘频繁子图,获得频繁子图集frequencyG;
步骤4:从步骤3获得的频繁子图集frequencyG中筛选出能够区分不同标记的子图,将这些子图命名为区分子图,所有区分子图构成区分子图集featureG;
步骤5:基于步骤4获得的区分子图集featureG实现多图的向量化,将每个程序源代码文件对应的多图多标记数据转化成多示例多标记数据;
步骤6:将步骤5获得的多示例多标记数据退化为单示例多标记数据;
步骤7:利用步骤6获得的单示例多标记数据对神经元网络学习模型进行学习训练;
步骤8:将待检测的程序源代码输入到训练后的神经元网络学习模型中执行软件Bug检测,模型返回结果即为Bug检测结果。
2.根据权利要求1所述的基于多图多标记学习的软件Bug检测方法,其特征在于,所述步骤1进一步包括如下步骤:
步骤1-1:获取原始的程序源代码和对应的Bug报告,给定停用词表ST和标记个数L;
步骤1-2:初始化文本列表T1为空,初始化向量列表T2为空;
步骤1-3:根据停用词表ST将Bug报告中的停用词删除,将删除后剩下的词存入文本列表T1中,作为语料库;
步骤1-4:将T1中的单词构建成词典Dic并计算文本向量,且将文本向量存入向量列表T2中;
步骤1-5:计算T1中每个单词的TF-IDF值;
步骤1-6:根据每个单词的TF-IDF值、给定的标记个数L以及所述词典Dic和步骤1-4得到的向量列表T2,获得每个Bug报告对应的关键词信息,并以这些关键词作为对应程序源代码的Bug多标签,生成多标记数据D1。
3.根据权利要求1所述的基于多图多标记学习的软件Bug检测方法,其特征在于,所述生成程序源代码的多图数据MG的方法为:针对每一个程序源代码文件P,以方法为粒度,将每个方法均转换成对应的程序依赖图PDG,且由于一个方法对应一个程序依赖图,而一个源代码文件中包括很多方法,因此,一个程序源代码文件P对应一个图包Bag,从而获得该程序源代码文件P对应的多图数据MG。
4.根据权利要求1所述的基于多图多标记学习的软件Bug检测方法,其特征在于,使用gspan算法从步骤2获得的多图数据MG中挖掘频繁子图。
5.根据权利要求3所述的基于多图多标记学习的软件Bug检测方法,其特征在于,所述步骤4进一步包括如下步骤:
步骤4-1:输入步骤3得到的频繁子图集frequencyG和预期的区分子图个数k,k由用户指定;
步骤4-2:初始化区分子图集featureG为空,区分度阈值τ为0;
步骤4-3:遍历频繁子图集frequencyG,对于其中的每一个子图,若已选择的子图个数小于k或者该子图的区分度大于当前的区分度阈值τ,则将该频繁子图添加到区分子图集featureG中;若区分子图集featureG中的区分子图个数大于k,则剔除区分子图集featureG中区分度最小的子图,并将区分度阈值τ更新为当前区分子图集featureG中具有最小区分度的子图的区分度;
所述区分度阈值τ按照下式进行更新:
其中gi表示区分子图集featureG中的第i个子图;Ds表示区分度;
步骤4-4:返回区分子图集featureG。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于东北大学,未经东北大学许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202111514505.6/1.html,转载请声明来源钻瓜专利网。