news 2026/7/1 20:33:06

vivado hls设计总结(二十)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
vivado hls设计总结(二十)

一、硬件高效型C语言代码之C++类和模板
1.vivado hls支持C++ class类的综合
2.vivado hls只是支持对顶层函数进行综合
3.vivado hls不支持对顶层的class类进行综合
4.如果要对类成员函数进行综合,需要将类本身例化为函数
5.不支持对位于顶层的类进行综合
6.不支持对位于顶层的类成员函数进行综合

二、顶层函数

三、类的实现

#include <fstream>
#include <iostream>
#include <iomanip>
#include <cstdlib>
using namespace std;
#define N 85
typedef int coef_t;
typedef int data_t;
typedef int acc_t;
// Class CFir definition
template<class coef_T, class data_T, class acc_T>
class CFir {
protected:
static const coef_T c[N];
data_T shift_reg[N-1];
private:
public:
data_T operator()(data_T x);
template<class coef_TT, class data_TT, class acc_TT>
friend ostream&
operator<<(ostream& o, const CFir<coef_TT, data_TT, acc_TT> &f);
};
// Load FIR coefficients
template<class coef_T, class data_T, class acc_T>
const coef_T CFir<coef_T, data_T, acc_T>::c[N] = {
#include "cpp_FIR.h"
};
// FIR main algorithm
template<class coef_T, class data_T, class acc_T>
data_T CFir<coef_T, data_T, acc_T>::operator()(data_T x) {
int i;
acc_t acc = 0;
data_t m;
loop: for (i = N-1; i >= 0; i--) {
if (i == 0) {
m = x;
shift_reg[0] = x;
} else {
m = shift_reg[i-1];
if (i != (N-1))
shift_reg[i] = shift_reg[i - 1];
}
acc += m * c[i];
}
return acc;
}
// Operator for displaying results
template<class coef_T, class data_T, class acc_T>
ostream& operator<<(ostream& o, const CFir<coef_T, data_T, acc_T> &f) {
for (int i = 0; i < (sizeof(f.shift_reg)/sizeof(data_T)); i++) {
o << shift_reg[ << i << ]= << f.shift_reg[i] << endl;
}

o << ______________ << endl;
return o;
}
data_t cpp_FIR(data_t x);

四、测试激励的编写

五、可以使用类模板来实现递归算法

//Tail recursive call
template<data_t N> struct fibon_s {
template<typename T>
static T fibon_f(T a, T b) {
return fibon_s<N-1>::fibon_f(b, (a+b));
}
};
// Termination condition
template<> struct fibon_s<1> {
template<typename T>
static T fibon_f(T a, T b) {
return b;
}
};
void cpp_template(data_t a, data_t b, data_t &dout){
dout = fibon_s<FIB_N>::fibon_f(a,b);
}

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

XGBoost完整安装配置指南:从入门到精通

XGBoost完整安装配置指南&#xff1a;从入门到精通 【免费下载链接】xgboost dmlc/xgboost: 是一个高效的的机器学习算法库&#xff0c;基于 C 开发&#xff0c;提供用于提升分类、回归、排序等任务的性能。 项目地址: https://gitcode.com/gh_mirrors/xg/xgboost XGBoo…

作者头像 李华
网站建设 2026/6/28 23:08:30

OBS面部追踪插件终极指南:打造专业直播画面的5个关键步骤

OBS面部追踪插件终极指南&#xff1a;打造专业直播画面的5个关键步骤 【免费下载链接】obs-face-tracker Face tracking plugin for OBS Studio 项目地址: https://gitcode.com/gh_mirrors/ob/obs-face-tracker OBS面部追踪插件是专为OBS Studio设计的实时面部检测工具&…

作者头像 李华
网站建设 2026/6/29 8:59:50

无线数据通信技术【1.5】

2.5.2 多普勒频移与多普勒衰落当运动的物体达到一定的速度时&#xff08;如急速行使的汽车、 超音速飞机、 人造卫星在发射等&#xff09;&#xff0c;固定点接收到的从运动体发来的载波频率将随物体运动速度的不同产生不同的频移&#xff0c;导致信号频率扩展&#xff0c;通常…

作者头像 李华
网站建设 2026/6/26 15:52:28

Infinigen完全攻略:从零构建程序化世界的7个关键步骤

Infinigen完全攻略&#xff1a;从零构建程序化世界的7个关键步骤 【免费下载链接】infinigen Infinite Photorealistic Worlds using Procedural Generation 项目地址: https://gitcode.com/gh_mirrors/in/infinigen Infinigen是一款革命性的开源程序化世界生成工具&…

作者头像 李华
网站建设 2026/6/29 18:43:17

告别串口噩梦:打造工业现场的 Modbus 智能通信中枢

摘要&#xff1a;在工业物联网&#xff08;IIoT&#xff09;的升级改造中&#xff0c;工程师们常面临一个棘手的“时空错位”&#xff1a;一边是支持高并发、云原生的现代化 SCADA/MES 系统&#xff0c;另一边是躺在控制柜里主要靠串口通信的“古董”设备。如何让 TCP/IP 网络与…

作者头像 李华