0

0

日常记录(16)SystemVerilog

雪夜

雪夜

发布时间:2025-06-25 12:04:01

|

799人浏览过

|

来源于php中文网

原创

巴科斯-诺尔范式(bnf)是一种元语言,用于描述和定义编程语言的语法规则。以下是对bnf及其在systemverilog中的应用的详细说明:

巴科斯-诺尔范式(BNF)概述

BNF是一种元语言,用于描述语言的语法结构。它由一系列规则或“产生式”组成,每个产生式定义了语言中的一个结构。

  • 产生式(Production):由一个或多个项目组成,项目可以是终端或非终端。
  • 终端(Terminal):语法中不可再分解的基本元素。
  • 非终端(Nonterminal):语法中需要进一步分解的元素。
  • 产生式列表(Production List):多个项目按顺序排列,使用 | 符号表示选择。

BNF在SystemVerilog中的应用

在SystemVerilog中,BNF用于定义randsequence语法,这是一种用于生成随机序列的语法结构。

  • randsequence语法:由一个或多个产生式组成,每个产生式包含一个名称和一个产生式项目列表。
  • 产生式项目:分为终端和非终端。非终端由终端和其他非终端定义,最终分解为终端。
  • 终端:不可分割的项目,定义在其相关代码块中。
  • 产生式列表:一系列按顺序排列的项目,使用 | 符号表示选择,生成器会随机选择其中一个。

示例

例如,一个名为main的产生式可以定义为:

main ::= first second done
first ::= add | dec
second ::= pop | push
  • 当选择main时,生成的序列为firstseconddone
  • first产生式在adddec之间随机选择。
  • second产生式在poppush之间随机选择。
  • 其他产生式如adddecpoppushdone都是终端,由其代码块定义。

执行和结果

当执行randsequence语句时,生成器根据语法规则生成随机序列。每个产生式的执行会产生相应的代码块副作用,从而生成所需的刺激。

额外功能

ghiblitattoo
ghiblitattoo

用AI创造独特的吉卜力纹身

下载

SystemVerilog中的序列生成器还支持随机权重、交错和其他控制机制。递归产生式可以导致循环。

参考资料

  • IEEE Std 1800-2017 SystemVerilog标准,第545-546页
  • 克里斯,SystemVerilog验证测试平台编写指南,第169页

其他相关概念

  • 函数(function):在SystemVerilog中,函数不消耗仿真时间,不能有时间延迟、阻塞语句、事件或调用task。
  • 任务(task):可以消耗仿真时间。
  • unique和priority关键字:用于if、case、casez、casex语句前,确保条件唯一性或优先级。
  • rand和randc:用于随机数生成,其中randc确保每个值只生成一次。

代码示例

以下是使用randc的代码示例:

module test;
    parameter N = 10;
    rand bit[N-1:0] randc_var;
    bit[N-1:0] gen_done[$];

    function automatic bit[N-1:0] get_randc();
        bit succ = 0;
        while(!succ) begin
            succ = std::randomize(randc_var) with { unique {randc_var,gen_done};};
        end
        gen_done.push_back(randc_var);
        if(gen_done.size() == 2**N) begin
            gen_done.delete();
        end
        return randc_var;
    endfunction

    initial begin
        for (int i=0; i<100; i++) begin
            $display("Randc value: %0d", get_randc());
        end
    end
endmodule

日常记录(16)SystemVerilog日常记录(16)SystemVerilog

通过上述详细说明,读者可以更好地理解BNF在SystemVerilog中的应用及其相关概念。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

731

2023.08.22

function是什么
function是什么

function是函数的意思,是一段具有特定功能的可重复使用的代码块,是程序的基本组成单元之一,可以接受输入参数,执行特定的操作,并返回结果。本专题为大家提供function是什么的相关的文章、下载、课程内容,供大家免费下载体验。

473

2023.08.04

js函数function用法
js函数function用法

js函数function用法有:1、声明函数;2、调用函数;3、函数参数;4、函数返回值;5、匿名函数;6、函数作为参数;7、函数作用域;8、递归函数。本专题提供js函数function用法的相关文章内容,大家可以免费阅读。

163

2023.10.07

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

97

2026.01.09

c++框架学习教程汇总
c++框架学习教程汇总

本专题整合了c++框架学习教程汇总,阅读专题下面的文章了解更多详细内容。

51

2026.01.09

学python好用的网站推荐
学python好用的网站推荐

本专题整合了python学习教程汇总,阅读专题下面的文章了解更多详细内容。

139

2026.01.09

学python网站汇总
学python网站汇总

本专题整合了学python网站汇总,阅读专题下面的文章了解更多详细内容。

12

2026.01.09

python学习网站
python学习网站

本专题整合了python学习相关推荐汇总,阅读专题下面的文章了解更多详细内容。

19

2026.01.09

俄罗斯手机浏览器地址汇总
俄罗斯手机浏览器地址汇总

汇总俄罗斯Yandex手机浏览器官方网址入口,涵盖国际版与俄语版,适配移动端访问,一键直达搜索、地图、新闻等核心服务。

83

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
CSS3 教程
CSS3 教程

共18课时 | 4.4万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 6.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号