【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;在计算机上安装大学生科创项目在…

【论文阅读】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套》 欢迎点赞 收藏 ⭐留…

(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;提防包装…

掘根宝典之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;展示了不同…

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…

stm32的EXTI的初始化-学习笔记

简介&#xff1a; 最近在学习stm32外设的过程中&#xff0c;学到EXTI这个外设的时候&#xff0c;感觉有点复杂&#xff0c;虽然是hal库开发&#xff0c;但是不明白所以&#xff0c;所以跟着也野火的教程&#xff0c;一遍看寄存器&#xff0c;一边看hal库的例子&#xff0c;写一…

Echarts+Vue 首页大屏静态示例Demo 第四版 支持自适应

效果: 源码: <template><ScaleScreenclass="scale-wrap":selfAdaption="true":autoScale="true":class="{ fullscreen-container: isFullScreen }"><div class="bg"><dv-loading v-if="loading&…

LeetCode - 和为K的子数组

LCR 010. 和为 K 的子数组 看到这道题的时候&#xff0c;感觉还挺简单的&#xff0c;找到数组中和为k的连续子数组的个数&#xff0c;无非就是一个区间减去另一个区间的和等于k&#xff0c;然后想到了用前缀和来解决这道问题。再算连续子数组出现的个数的时候&#xff0c;可以使…

DJI RONIN 4D变0字节恢复案例

RONIN 4D这个产品听起来比较陌生&#xff0c;还是DJI大疆出品。没错&#xff0c;这是大疆进军影视级的重点明星机型。前阵子刚处理过大疆RONIN 4D的修复案例&#xff0c;下边这个案例是和exfat有关的老问题:文件长度变成0字节。 故障存储:希捷18T /MS Exfat文件系统。 故障现…

如何借助CRM系统获得直观的业务洞察?CRM系统图表视图解析!

Zoho CRM管理系统在优化客户体验方面持续发力&#xff0c;新年新UI&#xff0c;一波新功能正在赶来的路上。今天要介绍的新UI功能在正式推出之前&#xff0c;已经通过早鸟申请的方式给部分国际版用户尝过鲜了。Zoho CRM即将推出图表视图&#xff0c;将原始数据转换为直观的图表…

低代码开发平台-企业级可视化快速开发工具

一、你们是否也遇到了以下问题 &#xff08;1&#xff09;作为传统型的软件公司&#xff0c;你们是否也遇到以下困扰&#xff1a; &#xff08;2&#xff09;作为大型企业软件开发部&#xff0c;你们是否也遇到以下困扰&#xff1a; 二、低代码平台介绍 MSPF快速开发平台是一…