【IC验证】数组

一、非组合型数组

1.声明

logic [31:0] array [1024];
或者logic [31:0] array [1023:0];
或者logic array [31:0] [1023:0];

理解成一维数组就表示array 数组中有1024个数据,每个数据32bit。

也可以理解为二维数组。

int [1:0][2:0]a1[3:0][4:0]

这是一个4×5×2×3维(高维-低维)的数组。要先看数组名右边的,再看数组名左边的,其中每一边都是从左到右

2.特点

声明时数组元素个数在数组名右边,各数据是独立的,非连续存储。且左边是高位,右边是低位

3.数组的赋值

int array1 [7:0] [31:0];
int array2 [7:0] [31:0];
array2[3] = array1 [0];

表示将array1数组的所有32个元素的第一位赋值给array2对应的32个元素的第4位。

所以其实array2[3]是一种简写,完整写法为array2[3][31:0]

注意非组合型数组不能使用向量来进行赋值。如a = 8'h5。因为向量是连续的而非组合型数组是非连续的。

4.数组的初始化

非组合型(unpacked)数组初始化时,则需要通过’{}来对数组的每一个维度进行赋值

int d [0:1][0:3] = ’{ ’{7,3,0,5}, ’{2,0,1,6} };
// d[0][0] = 7
// d[0][1] = 3
// d[0][2] = 0
// d[0][3] = 5
// d[1][0] = 2
// d[1][1] = 0
// d[1][2] = 1
// d[1][3] = 6

5.拷贝

  • 对于组合型数组,由于数组会被视为向量,因此当赋值左右两侧操作数的大小和维度不相同时,也可以做赋值。
  • 如果当尺寸不相同时,则会通过截取或者扩展右侧操作数的方式来对左侧操作数赋值。
B = A

当A的位宽小于B的位宽时,要对B的高位进行填充,如果都是有符号数则填充符号位,无符号数填充0; 当A的位宽大于B的位宽时,截掉A的高位

二、组合型数组

1.声明

logic [3:0][7:0] array;

表示有4个8bit数据

2.特点

维度声明在数组名的左边;各数据连续存放。高维在最左边

3.赋值

logic [1:0][1:0][7:0] a; // 3-D packed array
a[1][1][0] = 1’b0; // assign to one bit
a = 32’hF1A3C5E7; // assign to full array
a[1][0][3:0] = 4’hF; // assign to a part select
a[0] = 16’hFACE; // assign to a slice
a = {16’bz, 16’b0}; // assign concatenation

可以使用向量进行整体赋值

4.初始化

组合型数组的初始化与向量的初始化一致.

logic [3:0][7:0] a = 32’h0; // vector assignment
logic [3:0][7:0] b = {16’hz,16’h0}; // concatenate operator
logic [3:0][7:0] c = {16{2’b01}}; // replicate operator

5.拷贝

对于非组合型数组,在发生数组间拷贝时,则要求做左右两侧操作数的维度和大小必须严格一致

logic [31:0] a [2:0][9:0];
logic [0:31] b [1:3][1:10];
a = b; // assign unpacked array to unpacked array

非组合型数组无法直接赋值给组合型数组,同样地,组合型数组也无法直接赋值给非组合型数组

三、 组合型声明数组

组合型(packed)除了可以用来声明数组,也可以用到结构体里面去。

typedef struct packed {
logic [ 7:0] crc;
logic [63:0] data;
} data_word;
data_word [7:0] darray; // 1-D packed array of
// packed structures

如果未添加packed,则默认他是非组合型。添加了则是组合型,结构体内各变量连续存放,节省空间,方便赋值

四、数组的索引

  • SV添加foreach循环来对一维或者多维数组进行循环索引,而不需要指定该数组的维度大小。
  • foreach循环结构中的变量无需声明。
  • foreach循环结构中的变量是只读的,其作用域只在此循环结构中。
int sum [1:8] [1:3];
foreach ( sum[i,j] )
sum[i][j] = i + j; // initialize array

五、关于数组的一些系统函数

  • $dimensions(array_name)用来返回数组的维度。
  • $left(array_name, dimension)返回指定维度的最左索引值(msb)。
logic [1:2][7:0] word [0:3][4:1];
$left(word,1) will return 0
$left(word,2) will return 4
$left(word,3) will return 1
$left(word,4) will return 7
  • 与$left()类似的,还有${right, low, high}(array_name, dimension)。
  • $size(array_name, dimension)可以返回指定维度的尺寸大小。
  • $increment(array_name, dimension),如果指定维度的最左索引值大于或等于最右索引值,那么返回1,否则返回-1。
  • $bits(expression)可以用来返回数组存储的比特数目。
wire [3:0][7:0] a [0:15]; // $bits(a) 返回512
struct packed {byte tag; logic [31:0] addr;} b; $bits(b) 返回40

六、动态数组

以上的组合数组与非组合数组都是叫做定常数组,即位宽大小都是确定的,下面介绍动态数组。

1.声明

  • 动态数组在声明时需要使用[],这表示不会在编译时为其指定尺寸,而是在仿真运行时来确定。
  • 动态数组一开始为空,而需要使用new[]来为其分配空间。

2.系统函数

  • new[]
dynamic_array_new ::= new[expression] [(expression)]

[expression]:

数组中元素的数目。必须是一个非负的 integral 表达式

(expression):

可选的。用一个已知的数组来初始化新的数组。如果没有指定,那么最新分配的数组元素被初始化成它们的缺省值。数组标识符必须与左侧的数组具有相同的数据类型,但不必具有相同的尺寸。如果这个数组的尺寸小于新数组的尺寸,那么多余 的元素会被初始化成它们的缺省值。如果这个数组的尺寸大于新数组的尺寸,那么多余的元素会被忽略。 例如:

integer addr[]; // 声明动态数组
addr = new[100]; // 产生具有 100 个元素的数组 ...
addr = new[200](addr);// 加倍数组的尺寸,但保留以前的值。
  • size()
int j = addr.size(); 
addr = new[j] (addr); // 将 addr 数组的尺寸扩大为 4 倍

size()方法返回动态数组的当前尺寸,如果数组还没有产生,则返回 0。

  • delete()
int ab [] = new[N]; // 产生一个尺寸为 N 的临时数组
ab.delete(); // 删除数据内容
$display("%d", ab.size); // 打印 0

delete()方法清空数组,产生一个 0 尺寸的数组。

不可以像队列一样使用delete(i)删除第i个元素

同样也可以使用new[0]来进行清空

七、队列(queue)

  1. 定义

队列类似于一个一维的非压缩数组,它可以自动地增长和缩减。0 代表第一个 元素,$代表最后一个元素

  1. 赋值

byte q1[$]; // 一个字节队列
string names[$] = {"Bob"}; // 具有一个元素的字符串队列
integer Q[$] = {3, 2, 7}; // 一个被初始化成三个元素的整数队列
bit q2[$:255]; // 一个最大尺寸为 256 的位队列
  1. 队列操作符

int q[$] = {2, 4, 8};
int p[$];
int e, pos; 
e = q[0]; // 读取第一个(最左边)条目。
e = q[$]; // 读取最后一个(最右边)条目。
q[0] = e; // 写第一个元素 
p = q; // 读和写整个队列(拷贝) 
q = {q, 6}; // 在队列的尾部插入'6' 
q = {e, q}; // 在队列的头部插入'e' 
q = q[1:$]; // 删除第一个(最左边)元素
q = {}; // 清除队列(删除所有的元素) 
q = {q[0:pos-1], e, q[pos:$]}; // 在位置'pos'处插入'e' 
q = {q[0:pos], e, q[pos+1:$]}; // 在位置'pos'之后插入'e'

Tips:

如果 a>b,那么 Q[a:b]产生一个空队列{}。

Q[n:n]产生具有一个元素的队列,这个元素位于位置 n。因此,Q[n:n]==={Q[n]}。

如果 n 位于 Q(n < 0 或 n > $)的范围之外,那么 Q[n:n]产生一个空队列{}。

无论是 a 还是 b 是一个包含 X 或 Z 的四态表达式,都产生一个空队列{}。

Q[a:b]中如果 a < 0,那么它与 Q[0:b]相同。

Q[a:b]中如果 b > $,那么它与 Q[a:$]相同。

  1. 队列方法

  • size()

size()方法返回队列中元素的数目。如果队列是空的,它返回 0。

for (int j=0; j<q.size; j++) $display(q[j]);
  • insert()

insert()方法在指定的索引位置插入指定的元素。

q[$]={1,2,3};
q.insert(1,3);//在第二个位置插入元素3.

不过insert只能插入元素,不能插入一个队列,下面的操作是错误的

int q1[$]={1,2,3};
int q2[$]={1};
q1.insert(1,q2);//这种做法是错误的
  • delete()

delete()方法删除指定索引位置的元素。

q[$]={1,2,3};
q.delete(1);//删除第二个元素
q.delete();//删除所有元素
  • push_front(); push_back()
q[$]={1,2,3};
q.push_front(1);//在第一个位置插入元素1
q.push_back(1);//在最后位置插入元素1.
  • push_front(); push_back()
q[$]={1,2,3};
j=q.pop_front();//队列q删除第一个元素,并返回第一个元素1给j
j=q.pop_back();//队列q删除最后一个元素,并返回最后一个元素3给j
  • 拼接符
q1[$]={1,2,3};
q2[$]={4,5,6};
q={q1[0:1],7,q2[1:$]};//q表示{1,2,7,5,6}

八、关联数组(hash)

  1. 定义

对于处理成员数目会动态改变的连续变量集合而言,动态数组非常有用。然而,当集合的尺寸是未知的或者数据存储空间比较有限的时候,联合数组则是更好的选择。联合数组在使用之前不会分配任何存储空间,并且索引表达式不再被限制成 integral 表达式,而是可以具有任何数据类型。在对一个非常大的地址空间进行寻址时,SV只为实际写入的元素分配空间

  1. 声明

data_type array_id [index_type];

index_type 是用作索引的数据类型, 或者使用*。如果是*,那么数组可以使用任意尺寸的 integral 表达式来索引。采用数据类型作为索引的联合数组将索引表达式限制成一个特定的数据类型。

integer i_array[*]; // 整数联合数组(未指定索引)
bit [20:0] array_b[string]; // 21 位向量的联合数组,使用字符串类型作为索引
event ev_array[myClass]; // 事件类型的联合数组,使用类 myClass 索引

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/740904.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

springboot267大学生科创项目在线管理系统的设计与实现

# 大学生科创项目在线管理系统设计与实现 摘 要 传统办法管理信息首先需要花费的时间比较多&#xff0c;其次数据出错率比较高&#xff0c;而且对错误的数据进行更改也比较困难&#xff0c;最后&#xff0c;检索数据费事费力。因此&#xff0c;在计算机上安装大学生科创项目在…

Java面试题:设计一个线程安全的单例模式,解释Java内存模型(JMM)以及如何在多线程环境下保证可见性,使用Java并发工具包,实现一个有界线程池

在Java技术领域&#xff0c;面试官经常会考察候选人对多线程并发、设计模式以及内存管理等方面的综合运用能力。这三个领域不仅涵盖了Java编程的核心知识&#xff0c;也是面试中的高频考点。本文将为您解析三个综合性的面试题&#xff0c;帮助您从问题的核心内容、考察重点、原…

【论文阅读】ACM MM 2023 PatchBackdoor:不修改模型的深度神经网络后门攻击

文章目录 一.论文信息二.论文内容1.摘要2.引言3.作者贡献4.主要图表5.结论 一.论文信息 论文题目&#xff1a; PatchBackdoor: Backdoor Attack against Deep Neural Networks without Model Modification&#xff08;PatchBackdoor:不修改模型的深度神经网络后门攻击&#xf…

数据结构从入门到精通——树和二叉树

树和二叉树 前言一、树概念及结构1.1树的概念1.2 树的相关概念&#xff08;重要&#xff09;1.3 树的表示1.4 树在实际中的运用&#xff08;表示文件系统的目录树结构&#xff09; 二、二叉树概念及结构2.1二叉树概念2.2现实中的二叉树2.3 特殊的二叉树2.4 二叉树的性质2.5 二叉…

基于Java+SpringBoot+vue+element疫情药品采购出入库系统设计实现

基于JavaSpringBootvueelement疫情药品采购出入库系统设计实现 博主介绍&#xff1a;多年java开发经验&#xff0c;专注Java开发、定制、远程、文档编写指导等,csdn特邀作者、专注于Java技术领域 作者主页 央顺技术团队 Java毕设项目精品实战案例《1000套》 欢迎点赞 收藏 ⭐留…

中间件MQ面试题之Kafka

MQ相关面试题 Kafka面试题 (1)rockermq和kafka 的区别在哪里? 使用场景有什么不一样? 不同点: 数据可靠性 不同: RocketMQ:支持异步实时刷盘、同步刷盘、同步复制、异步复制;kafka:使用异步刷盘方式,异步复制/同步复制。性能对比:kafka单机写入TPS比较高单机支持…

(2)(2.12) Robsense SwarmLink

文章目录 前言 1 规格&#xff08;根据制造商提供&#xff09; 2 EasySwarm 3 参数说明 前言 Robsense SwarmLink 遥测无线电可将多架无人机连接到一个地面站&#xff0c;而无需在地面站一侧安装多个无线电&#xff08;即创建一个网状网络&#xff09;。此外&#xff0c;还…

在项目管理中,如何更好地协同团队成员,提高团队合作效率?

在项目管理中&#xff0c;协同团队成员并提高团队合作效率是确保项目成功实施的关键。以下是一些建议&#xff0c;有助于更好地协同团队成员&#xff0c;提高团队合作效率&#xff1a; 一、明确角色与责任 为每个团队成员分配明确的角色和职责&#xff0c;通过制定详细的任务…

用chatgpt写论文重复率高吗?如何降低重复率?

ChatGPT写的论文重复率很低 ChatGPT写作是基于已有的语料库和文献进行训练的&#xff0c;因此在写作过程中会不可避免地引用或借鉴已有的研究成果和观点。同时&#xff0c;由于ChatGPT的表述方式和写作风格与人类存在一定的差异&#xff0c;也可能会导致论文与其他文章相似度高…

程序人生——Java中基本类型使用建议

目录 引出Java中基本类型使用建议建议21&#xff1a;用偶判断&#xff0c;不用奇判断建议22&#xff1a;用整数类型处理货币建议23&#xff1a;不要让类型默默转换建议24&#xff1a;边界、边界、还是边界建议25&#xff1a;不要让四舍五入亏了一方 建议26&#xff1a;提防包装…

Kotlin OKHTTP3和拦截器的使用

注意&#xff1a;在android6.0以后网络请求还需如下配置&#xff1a; android:usesCleartextTraffic"true" <applicationandroid:allowBackup"true"android:icon"mipmap/ic_launcher"android:label"string/app_name"android:round…

掘根宝典之C++迭代器简介

在C中&#xff0c;容器是一种用于存储和管理数据的数据结构。C标准库提供了多种容器&#xff0c;每种容器都有其独特的特点和适用场景。 我们知道啊&#xff0c;我们可以通过下标运算符来对容器内的元素进行访问&#xff0c;但是只有少数几种容器才同时支持下标运算符&#xf…

闲聊电脑(7)常见故障排查

闲聊电脑&#xff08;7&#xff09;常见故障排查 夜深人静&#xff0c;万籁俱寂&#xff0c;老郭趴在电脑桌上打盹&#xff0c;桌子上的小黄鸭和桌子旁的冰箱又开始窃窃私语…… 小黄鸭&#xff1a;冰箱大哥&#xff0c;平时遇到电脑故障该咋处理呢&#xff1f; 冰箱&#xf…

k8s中calico网络组件部署时一个节点一直处于Pending状态

k8s中calico网络组件部署时一个节点一直处于Pending状态 故障截图 故障排查思路&#xff0c;通过describe查看具体原因 ~]# kubectl describe pod calico-node-pzlfv -n kube-system通过describe查看得知报错 Warning FailedScheduling 58s (x23 over 23m) default-sche…

基于YOLOv8/YOLOv7/YOLOv6/YOLOv5的扑克牌识别软件(Python+PySide6界面+训练代码)

摘要&#xff1a;开发扑克牌识别软件对于智能辅助决策工具的建立具有关键作用。本篇博客详细介绍了如何运用深度学习构建一个扑克牌识别软件&#xff0c;并提供了完整的实现代码。该系统基于强大的YOLOv8算法&#xff0c;并对比了YOLOv7、YOLOv6、YOLOv5&#xff0c;展示了不同…

mysql报错Deadlock found when trying to get lock; try restarting transaction处理

参考&#xff1a; https://blog.csdn.net/a1k2l45k/article/details/128220585 http://www.04007.cn/article/347.html https://www.jb51.net/python/296131kjw.htm show engine innodb status 查看日志&#xff0c;改代码。

tomcat配置好了,进不去这两个路径要一样

tomcat配置好了&#xff0c;进不去这两个路径要一样

原生JavaScript,根据后端返回扁平JSON动态【动态列头、动态数据】生成表格数据

前期准备&#xff1a; JQ下载地址&#xff1a; https://jquery.com/ <!DOCTYPE html> <html><head><meta charset"utf-8"><title>JSON动态生成表格数据,动态列头拼接</title><style>table {width: 800px;text-align: cen…

【RepVGG网络】

RepVGG网络 RepVGG网络是2021年由清华大学、旷视科技与香港科技大学等机构的研究者提出的一种深度学习模型结构&#xff0c;其核心特点是通过“结构重参数化”&#xff08;re-parameterization&#xff09;技术&#xff0c;在训练阶段采用复杂的多分支结构以优化网络的训练过程…

中间件MQ面试题之Rabbitmq

Rabbitmq 面试题 (1)RabbitMQ 如何确保消息不丢失? 消息持久化,当然前提是队列必须持久化 RabbitMQ确保持久性消息能从服务器重启中恢复的方式是,将它们写入磁盘上的 —个持久化日志文件,当发布一条持久性消息到持久交换器上时,RabbitMQ会在消 息提交到日志文件后才发…