返回介绍

12.11 范围变量的随机化 — std::randomize()

发布于 2020-09-09 22:55:51 字数 1404 浏览 1937 评论 0 收藏 0

内建的类随机化方法对类成员变量执行专有的操作。使用类来对需要随机化的数据建模是一种强大的机制,它使得我们能够产生通用、可复用的包含随机变量的对象,并能够产生可以在以后扩展、继承、约束、过载、使能、关闭、以及从其它对象合并或分离的约束。类及与其关联的随机变量和约束在处理上的方便性使得类非常适合描述和处理随机数据和约束。然而,某些要求较少的问题并不需要类的这些完整的灵活性,它可以使用一个较为简单的机制来随机化不属于一个类的数据。范围随机函数(std::randomize())使得用户能够随机化当前范围内的数据,而无需定义一个类或实例化一个类对象。

范围随机化函数的语法如下:

scope_randomize ::=               // 没有包含在附录A中
    [std::]randomize([variable_identifier_list]) [with constraint_block]

语法12-10 — 范围随机化函数语法(没有包含在附录A中)

范围随机化函数与类的随机化方法的作用相同,只是它操作于当前范围内的变量而不是类成员变量。函数的参数指定了那些需要赋值为随机值的变量,也就是随机变量。

例如:

module stim;
    bit [15:0] addr;
    bit [31:0] data;

    function bit gen_stim();
        bit success, rd_wr;
        success = randomize(addr, data, rd_wr);  // 调用std::randomize
        return rd_wr;
    endfunction

    ...
endmodule

函数gen_stim调用std::randomize()函数并带有三个变量作为参数:addr、data、和rd_wrstd::randomize()将新的随机变量赋值到那些在gen_stim函数范围内可见的变量。注意,addr和data具有模块级的作用范围,而rd_wr具有函数内的本地作用范围。我们也可以使用类来编写上面的例子:

class stimc;
    rand bit [15:0] addr;
    rand bit [31:0] data;
    rand bit rd_wr;
endclass

function bit gen_stim(stimc p);
    bit success;
    success = p.randomize();
    addr = p.addr;
    data = p.data;
    return p.rd_wr;
endfunction

然而,对于这个简单的应用,范围随机化函数能够产生一个更直接的实现。

如果范围随机化函数成功地为所有的随机变量设置了有效值,那么它返回1;否则它返回0。如果调用范围随机化函数的时候没有指定参数,那么它作为一个检查器使用,并简单地返回状态。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文