V0 第11节 验证环境组件

2023-12-10 19:39
文章标签 组件 环境 验证 v0

本文主要是介绍V0 第11节 验证环境组件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 激励发生器

  • Simulator (激励发生器)是验证环境的重要部件,在一些场合中,它被称为driver(驱动器)、BFM(bus function model,总线功能模型),behavioral(行为模型) 或者 generator(发生器)
  • Simulator的主要职责是模拟与DUT相邻设计的接口协议,只需要关注如何模拟接口信号,使其能够以真实的接口协议来发送激励给DUT
  • Simulator 不应该违反协议,但不拘束于真实的硬件行为,还可以给出丰富的只要协议允许的激励场景
  • 比真实硬件行为更丰富的激励,会使得在模块级的验证更加充分,因为它不但可以验证硬件普通的接口时序,还模拟出更多复杂的、在更高系统级别无法产生出来的激励场景
  • Simulator的接口主要是同DUT连接,此外,也有时钟和复位信号的输入,确保生成的数据同DUT的接口一侧是同步的关系
  • Simulator还可以有其它的配置接口用来控制接口数据的生成
  • Simulator也可以有存储接口数据生成历史功能,这可以用来在仿真运行时或者结束后查看接口数据,方便统计或者调试

1.1 激励器组件结构框图

在这里插入图片描述

1.2 Channel Initiator 组件

  • 从simulator同DUT的连接关系来看,我们可以将其进一步分为两种:initiator(发起器)和responder(响应器)
  • 由于channel 从端接口协议上有握手信号,我们需要遵照接口时序,确保chx_ready为低时,保证chx_data和chx_valid保持不变
  • 相邻数据之间没有数据包的限制,所以相邻数据之间的关系较弱,但也应该考虑数据之间是否有空闲周期,以及整体数据的传输速率设定
  • 由于每一个数据从端都有对应的FIFO缓存数据,所以也需要考虑如何使得FIFO的状态可遍历,例如,典型的FIFO状态可以分为empty,full以及中间状态即有数据存储但未写满,要使得FIFO可以触发这些状态,我们就应该控制channel initiator的传输速率

2.监测器

  • Monitor (监测器)的主要功能是用来观察DUT的边界或者内部信号,并且级过打包整理传送给其它验证平台的组件例如checker 比较器
  • 从监测信号的层次来划分monitor的功能,它们可以分为观察DUT边界信号和观察DUT内部信号

2.1 监测器组件结构框图

在这里插入图片描述

  • 如果没有特殊的需要,我们应采取灰盒验证的策略(非白盒)
  • 观察的内部信号应当尽量少,且应当是表示状态的信号,不建议采集中间变量信号的原因在于,这些信号的时序,逻辑甚留存性都不稳定, 这种不稳定对于验证环境的收敛是有害的

3. 比较器

  • 无论是从实现难度,还是从维护人力上来讲,checker(比较器)都应当是最需要时间投入的验证组件
  • checker肩负了模拟设计行为和功能检查的任务
  • 缓存从各个monitor收集到的数据
  • 将DUT输入接口侧的数据汇集给内置的reference model(参考模型)reference model 在这里扮演了模拟硬件功能的角色,也是需要较多精力维护的部分,因为验证者需要在熟悉硬件功能的情况下实现该模型,而又不应参考真实硬件的逻辑
  • 通过数据比较的方法,检查实际收集到的DUT输出端接口数据是否同reference model产生的期望数据一致
  • 对于设计内部的关键功能模块,也有相对应的线程进行独立的检查
  • 在检查过程中,可以将检查成功的信息统一纳入到检查报告中,便于仿真后的查询,如果检查失败,也可以采取暂停仿真同时报告错误信息的方式,进行在线调试
  • 线上比较 online check:在仿真时收集数据和在线比较,并且实时报告
  • 线下比较 offline check: 将仿真时收集到的数据记录在文件中,在仿真结束后,通过脚本进行数据比较
    在这里插入图片描述

3.1 比较器组件结构框图

在这里插入图片描述

3.2 比较器实现建议

  • 对于复杂的系统验证,我们倾向于集中管理simulator和checker,因为它们两都都需要主动给出激励或者判断结果,也需要较多的协调处理
  • simulator和monitor是一一对应的,我们通常将它们进一步封装在agent单元组件中,而checker则最终集群搁置在中收化的位置

这篇关于V0 第11节 验证环境组件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/478148

相关文章

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推

如何在页面调用utility bar并传递参数至lwc组件

1.在app的utility item中添加lwc组件: 2.调用utility bar api的方式有两种: 方法一,通过lwc调用: import {LightningElement,api ,wire } from 'lwc';import { publish, MessageContext } from 'lightning/messageService';import Ca

安装nodejs环境

本文介绍了如何通过nvm(NodeVersionManager)安装和管理Node.js及npm的不同版本,包括下载安装脚本、检查版本并安装特定版本的方法。 1、安装nvm curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.0/install.sh | bash 2、查看nvm版本 nvm --version 3、安装

【IPV6从入门到起飞】5-1 IPV6+Home Assistant(搭建基本环境)

【IPV6从入门到起飞】5-1 IPV6+Home Assistant #搭建基本环境 1 背景2 docker下载 hass3 创建容器4 浏览器访问 hass5 手机APP远程访问hass6 更多玩法 1 背景 既然电脑可以IPV6入站,手机流量可以访问IPV6网络的服务,为什么不在电脑搭建Home Assistant(hass),来控制你的设备呢?@智能家居 @万物互联

高并发环境中保持幂等性

在高并发环境中保持幂等性是一项重要的挑战。幂等性指的是无论操作执行多少次,其效果都是相同的。确保操作的幂等性可以避免重复执行带来的副作用。以下是一些保持幂等性的常用方法: 唯一标识符: 请求唯一标识:在每次请求中引入唯一标识符(如 UUID 或者生成的唯一 ID),在处理请求时,系统可以检查这个标识符是否已经处理过,如果是,则忽略重复请求。幂等键(Idempotency Key):客户端在每次

v0.dev快速开发

探索v0.dev:次世代开发者之利器 今之技艺日新月异,开发者之工具亦随之进步不辍。v0.dev者,新兴之开发者利器也,迅速引起众多开发者之瞩目。本文将引汝探究v0.dev之基本功能与优势,助汝速速上手,提升开发之效率。 何谓v0.dev? v0.dev者,现代化之开发者工具也,旨在简化并加速软件开发之过程。其集多种功能于一体,助开发者高效编写、测试及部署代码。无论汝为前端开发者、后端开发者

pico2 开发环境搭建-基于ubuntu

pico2 开发环境搭建-基于ubuntu 安装编译工具链下载sdk 和example编译example 安装编译工具链 sudo apt install cmake gcc-arm-none-eabi libnewlib-arm-none-eabi libstdc++-arm-none-eabi-newlib 注意cmake的版本,需要在3.17 以上 下载sdk 和ex

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip