news 2026/5/12 5:37:54

union_type using

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
union_type using


一、vivado hls中union说明
1.vivado hls中union联合体和标准的c/c++联合体的union使用规则类似
2.vivado hls中需要对内存和数据类型进行比较准确的推断,从而来生成硬件
3.联合体中所有的成员共享一块内存,同一时刻只能使用其中的一个成员
4.在 HLS 中使用联合体时,需要注意数据类型的位宽和对齐,因为这会直接影响生成的硬件
5.在vivado hls中,联合体的综合是有条件的,需要避免使用指针和动态内存分配
6.联合体中使用数组和结构体是被允许的
7.联合体在vivado hls使用,比较常见的用途,是用于事项数据类型的转换

二、内存共享机制
// 案例1: 基本union使用
union DataUnion {
uint32_t word; // 32位
uint8_t bytes[4]; // 4个8位字节
struct {
uint8_t b0, b1, b2, b3;
} byte_struct;
};

void union_example1(ap_uint<32> input, ap_uint<8>& byte0) {
#pragma HLS INTERFACE ap_ctrl_none port=return
#pragma HLS INTERFACE ap_none port=input
#pragma HLS INTERFACE ap_none port=byte0

DataUnion data;
data.word = input; // 写入32位字

// 四个字节共享同一内存位置
byte0 = data.bytes[0]; // 读取低8位
// data.bytes[1], [2], [3] 对应高8位
}

三、数据位宽匹配设计
// 案例2: 位宽精确匹配
union FixedUnion {
ap_uint<12> data_12bit; // 12位
ap_uint<4> nibbles[3]; // 3×4=12位,正确匹配
// ap_uint<8> bytes[2]; // 错误:2×8=16位,不匹配!

// 可以使用struct进行位域控制
struct {
ap_uint<4> low : 4;
ap_uint<4> mid : 4;
ap_uint<4> high : 4;
} bits;
};

void union_example2(ap_uint<12> in_data,
ap_uint<4>& out_nibble) {
#pragma HLS PIPELINE II=1

FixedUnion fu;
fu.data_12bit = in_data;

// 通过不同方式访问相同数据
out_nibble = fu.nibbles[1]; // 中间4位
// 等效于:out_nibble = fu.bits.mid;
}

四、使用限制
// 案例3: HLS可综合的union用法
union HLS_Compatible {
// 只包含POD(普通旧数据类型)
float fval;
int ival;
ap_fixed<16,8> fixed_val; // HLS定点数类型

// 以下不可在union中使用:
// 1. 非POD类型(如std::string)
// 2. 动态内存分配
// 3. 虚函数
};

void type_conversion(float float_in, int& int_out) {
#pragma HLS INLINE
union {
float f;
int i;
} converter;

converter.f = float_in;
int_out = converter.i; // 浮点位模式解释为整数
}

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/12 5:37:53

docker 容器参数LinkLocalIPv6Address 和 LinkLocalIPv6PrefixLen

文章目录一、什么是 IPv6 链路本地地址&#xff08;Link-Local Address&#xff09;&#xff1f;二、Docker 中的 LinkLocalIPv6Address 和 LinkLocalIPv6PrefixLen2.1、 LinkLocalIPv6Address2.2、 LinkLocalIPv6PrefixLen三、如何查看这两个字段&#xff1f;3.1、docker insp…

作者头像 李华
网站建设 2026/5/12 5:37:53

SPDIFRX接口:数字音频接收全解析

目录 一、SPDIFRX 接口核心原理 1. 物理层&#xff1a;信号传输的 “物理载体” 2. 协议层&#xff1a;数据解析的 “规则” 3. SPDIFRX 核心工作流程 二、SPDIFRX 典型应用场景 1. 消费电子&#xff08;最主流&#xff09; 2. 汽车电子 3. 嵌入式 / 工业设备 4. 专业…

作者头像 李华
网站建设 2026/5/9 10:05:36

mfc40loc.dll文件在系统内缺少 无法运行问题 免费下载

在使用电脑系统时经常会出现丢失找不到某些文件的情况&#xff0c;由于很多常用软件都是采用 Microsoft Visual Studio 编写的&#xff0c;所以这类软件的运行需要依赖微软Visual C运行库&#xff0c;比如像 QQ、迅雷、Adobe 软件等等&#xff0c;如果没有安装VC运行库或者安装…

作者头像 李华
网站建设 2026/5/10 0:18:39

龙伯格观测器的C语言实现及其在FOC电机控制中的应用

1. 龙伯格观测器的C语言实现 1.1 基本数据结构定义 #ifndef LUENBERGER_OBSERVER_H #define LUENBERGER_OBSERVER_H#include <stdint.h>// 矩阵结构体(以2x2系统为例,可扩展) typedef struct {float data[2][2]; // 系统矩阵数据 } Matrix2x2;// 向量结构体 typede…

作者头像 李华
网站建设 2026/5/9 7:52:23

学霸同款2026 TOP8 AI论文写作软件:自考毕业论文全攻略

学霸同款2026 TOP8 AI论文写作软件&#xff1a;自考毕业论文全攻略 2026年自考论文写作工具测评&#xff1a;为何需要一份精准榜单 随着人工智能技术的不断进步&#xff0c;AI写作工具正逐渐成为学术研究和论文撰写的重要辅助手段。对于自考学生而言&#xff0c;如何在有限的…

作者头像 李华
网站建设 2026/5/10 2:18:45

d3dx10_39.dll官方版本 免费下载文件方法分享

在使用电脑系统时经常会出现丢失找不到某些文件的情况&#xff0c;由于很多常用软件都是采用 Microsoft Visual Studio 编写的&#xff0c;所以这类软件的运行需要依赖微软Visual C运行库&#xff0c;比如像 QQ、迅雷、Adobe 软件等等&#xff0c;如果没有安装VC运行库或者安装…

作者头像 李华