C++中常用的复合数据类型在Vivado Hls中的应用方法

在c++中常用的复合数据类型,一种是结构体,另一种就是枚举类型。
struct
对于struct来说,如果出现在顶层函数,并作为顶层函数参数的时候,struct里的scalar变量就会被映射scalar类型的端口,数组就会被映射为相应的memory端口。在实际使用中,建议预先把结构体在头文件里声明。对于结构体中的元素,vivado hls里提供相应的data pack优化方式,这种优化方式分为两种,即field_level 和struct_level。
两者区别
结构体里field_level所有元素的位宽必须以8 bits为边界,比如说,一个变量为6 bits就必须扩展到8 bits,如果一个struct有五个元素,每个元素6 bits,每个元素扩展到8 bits,此时总位宽就会被扩展为40 bits。而struct_level不改变每个元素的实际位宽,但是对于封装后的总位宽要以8 bits为边界,比如说,上面的·总位宽就会被扩展到32 bits。
注意:比较这两种类型的data pack优化方式,会发现两者的clock,latency和interval,以及资源利用率都是一致的。data pack可以降低latency和interval,提高数据的吞吐率,这是因为这里data pack对for循环进行展开。
enum
enumerated type是将一个数值定义为一个符号常量,需要用到关键字enum。枚举类型的元素会被自动的分配到一个整数,其中起始值为0,后面依次加1。这样是为了提高代码的可读性。
总结
vivado hls既支持结构体,也支持枚举类型,这两种类型都可以作为接口出现在顶层函数。如果结构体出现在顶层函数,可以通过field_level 和struct_level进行封装,如果枚举类型作为接口出现在顶层函数,它实际上是整数,vivado会自动推断相应mode的数据位宽。

电源设计之DC/DC工作原理及芯片详解
技术融合创新推动5G发展,高科技要渗透传统领域
比特币主网VeriBlock是如何工作的
【蓝桥杯嵌入式】第七章 串口发送数据
DC/DC转换厂商:陕西亚成微电子有限公司简介
C++中常用的复合数据类型在Vivado Hls中的应用方法
基于AT73C500/501专用芯片组的电参量测量模块
stm32怎么用
【安全算法之SHA1】SHA1摘要运算的C语言源码实现
一直进展缓慢的“携号转网”最近终于有了眉目
网络可编程性有哪一些办法实现
基于AD8302的RF信号精确增益/相位测量
一种可选的PLC编程方法,支持机械工程的模块化
浅谈大语言模型在医疗领域的应用
尘埃落定后中兴通讯股价攀新高 中兴通讯8月28日举行2018年第二次临时股东大会
如何将DHT11温度和湿度传感器与树莓派连接
Linear推出4通道电压输出16位和12 位DAC系列
自制电源和电话滤波器
人工智能大时代即将到来,为何存储器需求越来越高?
三大运营商为什么同时砍掉多款4G套餐?