博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
功能覆盖率
阅读量:6005 次
发布时间:2019-06-20

本文共 760 字,大约阅读时间需要 2 分钟。

随着各种设计变得越来越复杂,采用受约束的随机测试方法(CRT)是对它们进行全面验证的唯一有效途径。无论是随机的还是定向的激励,都要使用覆盖率来度量测试进行的程度。

覆盖率的类型

覆盖率是衡量设计验证完成程度的一个通用词。随着测试逐步覆盖各种合理的组合,仿真过程会慢慢勾画出你的设计情况,覆盖率工具会在仿真过程中收集信息,然后进行后续处理并得倒覆盖率报告。通过覆盖率报告找出覆盖率盲区,然后修改现有测试或者创建新测试来填补这些盲区。这个过程一直迭代进行,直到你对覆盖率满意为止。

代码覆盖率

衡量验证进展的最简易的方式是使用代码覆盖率。这种方式衡量的是多少行代码已经被执行过。代码覆盖率衡量的是测试对于设计规范的“实现”究竟测试得有多彻底,而非针对验证计划。

功能覆盖率

验证的目的就是确保设计在实际环境中的行为正确。设计规范里详细说明了设备应该如何运行,而验证计划里则列出了相应的功能应该如何激励、验证和测量。

功能覆盖率是和设计意图紧密相连的,有时也称为”规范覆盖率“,而代码覆盖率则是衡量设计的实现情况。

漏洞率

衡量覆盖率的一个间接的方式是查看新漏洞出现的比率。

断言覆盖率

断言是用于一次性地或一段时间内核对两个设计信号之间关系的声明性代码。它可以跟随设计和测试平台一起仿真。

 

功能覆盖率策略

在动手写测试代码之前,你需要预先弄清楚相关设计的关键特性、边界情形和可能故障模型。这其实就是验证计划的内容。

(1) 收集信息而非数据

(2) 只测量你将会使用到的内容

(3) 测量的完备性

 

参考文献:

[1] Chris Spear. SystemVerilog验证测试平台编写指南. 科学出版社. 2009,09.

转载于:https://www.cnblogs.com/dpc525/p/5401504.html

你可能感兴趣的文章
Java生成-zipf分布的数据集(自定义倾斜度,用作spark data skew测试)
查看>>
修复CefSharp浏览器组件中文输入Bug
查看>>
正则与sed,grep,awk三剑客
查看>>
诊断一句SQL不走索引的原因
查看>>
iOS开发拓展篇—UIDynamic(简单介绍)
查看>>
Linux pipe函数
查看>>
图片标注工具LabelImg使用教程
查看>>
(原創) 如何設計一個數位相框? (SOC) (Quartus II) (SOPC Builder) (Nios II) (TRDB-LTM) (DE2-70)...
查看>>
/etc/profile文件内容
查看>>
量词 匹配优先与忽略优先
查看>>
一页纸IT项目管理:大道至简的实用管理沟通工具
查看>>
汽车知识:车内异味的清除方法
查看>>
IE6 7下绝对定位引发浮动元素神秘消失
查看>>
android - ADT本地配置、sdk配置
查看>>
I.MX6 dhcpcd 需要指定网卡
查看>>
js递归原理之return
查看>>
浏览器的回流和重绘及其优化方式
查看>>
gulp+browser-sync实现前端自动化刷新
查看>>
python学习笔记 --- 来看看 random_state 这个参数
查看>>
基于angular2实现用户登录并信息持久化的一些理解(三)
查看>>