fpga系列 HDL:Relu激活函数实现与仿真

  • 代码实现对OUTPUT_NODES个32位浮点数进行RELU操作。
  • 32位浮点数的二进制表示遵循 IEEE 754 标准,通常称为单精度浮点数。这个标准定义了浮点数的表示方法,具体分为三个部分:
    • 符号位 (1 bit): 用于表示浮点数的正负。( 0 表示正数,1 表示负数)
    • 指数位 (8 bits): 用于表示指数部分,并采用偏移量 (bias) 编码。
    • 尾数 (或称为有效数字, 23 bits): 用于表示浮点数的有效数字部分。

Module

// https://github.com/omarelhedaby/CNN-FPGA/blob/master/Final%20Code%20Files/Part%205-%20Integration/activationFunction.v
module activationFunction(clk, reset, en, input_fc, output_fc);// 模块定义,名称为 activationFunction// 输入信号:// - clk: 时钟信号// - reset: 复位信号// - en: 使能信号// - input_fc: 输入数据,宽度为 DATA_WIDTH*OUTPUT_NODES// 输出信号:// - output_fc: 输出数据,宽度为 DATA_WIDTH*OUTPUT_NODES// 参数定义parameter DATA_WIDTH = 32;       // 数据宽度,默认为 32 位parameter OUTPUT_NODES = 32;     // 输出节点数,默认为 32 个// 输入信号定义input clk, reset, en;                        // 时钟信号、复位信号和使能信号input [DATA_WIDTH*OUTPUT_NODES-1:0] input_fc; // 输入数据,总宽度为 DATA_WIDTH*OUTPUT_NODESoutput reg [DATA_WIDTH*OUTPUT_NODES-1:0] output_fc; // 输出数据,总宽度同样为 DATA_WIDTH*OUTPUT_NODES// 内部变量声明integer i;  // 循环变量 i// 在时钟负边沿或复位信号正边沿触发的过程块always @ (negedge clk or posedge reset) begin// 检查复位信号if (reset == 1'b1) begin// 如果复位信号为高电平(1),则将输出数据清零output_fc = 0;end else begin// 如果不是复位状态,则检查使能信号if (en == 1'b1) begin// 如果使能信号为高电平(1),则处理输入数据for (i = 0; i < OUTPUT_NODES; i = i + 1) begin// 对每一个输出节点执行以下操作// 检查输入数据中对应数据位的符号位(最高位)if (input_fc[DATA_WIDTH*i + DATA_WIDTH - 1] == 1'b1) begin// 如果符号位为 1,表示该数据为负数或需要置为 0// 对应的输出数据设置为 0output_fc[DATA_WIDTH*i +: DATA_WIDTH] = 0;end else begin// 否则,将输入数据直接赋值给输出数据output_fc[DATA_WIDTH*i +: DATA_WIDTH] = input_fc[DATA_WIDTH*i +: DATA_WIDTH];endendendendendendmodule

TestBench

// Code your testbench here
// or browse Examples
`timescale 1ns / 1psmodule tb_activationFunction;// 参数定义parameter DATA_WIDTH = 32;parameter OUTPUT_NODES = 32;// 测试平台中的信号reg clk;reg reset;reg en;reg [DATA_WIDTH*OUTPUT_NODES-1:0] input_fc;wire [DATA_WIDTH*OUTPUT_NODES-1:0] output_fc;// 实例化被测试模块activationFunction #(.DATA_WIDTH(DATA_WIDTH),.OUTPUT_NODES(OUTPUT_NODES)) uut (.clk(clk),.reset(reset),.en(en),.input_fc(input_fc),.output_fc(output_fc));// 时钟生成initial beginclk = 0;forever #5 clk = ~clk; // 每 5 时间单位切换一次时钟状态end// 测试过程initial begin// 初始化信号reset = 1;en = 0;input_fc = 0;// 复位过程#10;reset = 0;// 测试 1: 输入数据处理#10;en = 1;input_fc = {32'h00000001, 32'h00000002, 32'h00000003, 32'h00000004,32'h00000005, 32'h00000006, 32'h00000007, 32'h00000008,32'h00000009, 32'h0000000A, 32'h0000000B, 32'h0000000C,32'h0000000D, 32'h0000000E, 32'h0000000F, 32'h00000010,32'h00000011, 32'h00000012, 32'h00000013, 32'h00000014,32'h00000015, 32'h00000016, 32'h00000017, 32'h00000018,32'h00000019, 32'h0000001A, 32'h0000001B, 32'h0000001C,32'h0000001D, 32'h0000001E, 32'h0000001F, 32'h00000020};// 等待处理完成#10;// 测试 2: 改变输入数据,测试负数的处理input_fc = {32'h80000001, 32'h80000002, 32'h80000003, 32'h80000004,32'h80000005, 32'h80000006, 32'h80000007, 32'h80000008,32'h80000009, 32'h8000000A, 32'h8000000B, 32'h8000000C,32'h8000000D, 32'h8000000E, 32'h8000000F, 32'h80000010,32'h80000011, 32'h80000012, 32'h80000013, 32'h80000014,32'h80000015, 32'h80000016, 32'h80000017, 32'h80000018,32'h80000019, 32'h8000001A, 32'h8000001B, 32'h8000001C,32'h8000001D, 32'h8000001E, 32'h8000001F, 32'h80000020};// 等待处理完成#10;// 禁用模块en = 0;// 等待一段时间以观察状态#10;// 启用模块并测试复位reset = 1;#10;reset = 0;en = 1;// 等待一段时间#10;// 结束仿真$finish;end// 观察输出信号变化//initial begin//    $monitor("Time: %0t, Output: %h", $time, output_fc);//end// edaplayground仿真https://blog.csdn.net/ResumeProject/article/details/139300170  initial begin$dumpfile("dump.vcd"); $dumpvars;endendmodule

仿真

edaplayground

在这里插入图片描述

  • 第一个时钟周期:rest为1,输出为0

  • 第二个时钟周期:rest为0,输入为空,输出为0
    在这里插入图片描述

  • 第三个时钟周期:rest为0,输入为20,输出为20
    在这里插入图片描述

  • 第四个时钟周期:rest为0,输入为负数,输出为0

  • 在这里插入图片描述

digitaljs

在这里插入图片描述

在这里插入图片描述

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

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

相关文章

全国糖酒会,就这5个字。“会天下美味”

“全国糖酒会&#xff0c;会天下美味”&#xff0c;是全国糖酒会的品牌口号。这个品牌口号来的非常偶然。 两年前&#xff0c;全国糖酒会准备更新标志之时&#xff0c;也设计了一个品牌口号。新标志发布前几天&#xff0c;临时作了调整&#xff0c;最终变成了“全国糖酒会&…

linux下oracle启动及关于pfile和spfile启动参数文件的配置

在现代企业环境中&#xff0c;Oracle数据库作为关键的业务支撑平台&#xff0c;承载着大量的数据处理和事务管理任务。 无论是对于DBA&#xff08;数据库管理员&#xff09;还是开发人员来说&#xff0c;掌握Oracle数据库的基本操作和配置技巧都是至关重要的。本文提供了一份全…

Flutter基本组件Text使用

Text是一个文本显示控件&#xff0c;用于在应用程序界面中显示单行或多行文本内容。 Text简单Demo import package:flutter/material.dart;class MyTextDemo extends StatelessWidget {const MyTextDemo({super.key});overrideWidget build(BuildContext context) {return Sca…

Protobuf库的使用

文章目录 Protobuf是什么Protobuf使⽤流程介绍ProtoBuf的使用创建.proto⽂件指定proto3语法package声明符定义消息&#xff08;message&#xff09;编译contacts.proto⽂件命令如下&#xff1a;序列化与反序列化的使⽤ Protobuf是什么 ProtoBuf&#xff08;全称ProtocolBuffer…

【Python基础】Python函数

本文收录于 《Python编程入门》专栏&#xff0c;从零基础开始&#xff0c;分享一些Python编程基础知识&#xff0c;欢迎关注&#xff0c;谢谢&#xff01; 文章目录 一、前言二、函数的定义与调用三、函数参数3.1 位置参数3.2 默认参数3.3 可变数量参数&#xff08;或不定长参数…

若依框架登录鉴权详解(动态路由)

若依框架登录鉴权&#xff1a;1.获取token&#xff08;过期在响应拦截器中实现&#xff09;,2.基于RBAC模型获取用户、角色和权限信息&#xff08;在路由前置守卫&#xff09;&#xff0c;3.根据用户权限动态生成&#xff08;从字符串->组件&#xff0c;根据permission添加动…

【C++进阶】hash表的封装

文章目录 hash表哈希表的关键组成部分哈希表的优缺点优点&#xff1a;缺点&#xff1a; 常见应用场景 开放定址法实现hash表负载因子 (Load Factor)负载因子的意义负载因子的影响再散列 (Rehashing)示例 整体框架insertFinderasehash桶封装框架insertfinderase~HashTable() 总结…

银行结算业务

1.1 银行本票 银行本票是由银行签发的,承诺自己在见票时无条件支付票款给收款人或持票人的业务。银行本票按票面划分为定额本票和不定额本票,按币种划分为人民币银行本票和外币银行本票。人民币银行本票仅在同一交换区域内使用,资金清算利用当地人民银行组织的资金清算形式…

多个vue项目部署到nginx服务器

文章目录 需求一、项目打包1.vue.config.js2.request.js文件3.打包 二、nginx配置 需求 同一个域名安装多个vue项目。 比如&#xff1a;域名为 https://domain.com 后缀。那么通过不同的后缀就能去访问不同的项目地址。 https://domain.com&#xff0c;不加任何后缀&#x…

【第0006页 · 数组】寻找重复数

【前言】本文以及之后的一些题解都会陆续整理到目录中&#xff0c;若想了解全部题解整理&#xff0c;请看这里&#xff1a; 第0006页 寻找重复数 今天想讨论的一道题在 LeetCode 上评论也是颇为“不错”。有一说一&#xff0c;是道好题&#xff0c;不过我们还是得先理解了它才…

微信小程序中如何监听元素进入目标元素

Page({onLoad: function(){// 如果目标节点&#xff08;用选择器 .target-class 指定&#xff09;进入显示区域以下 100px 时&#xff0c;就会触发回调函数。wx.createIntersectionObserver().relativeToViewport({bottom: 100}).observe(.target-class, (res) > {res.inter…

合宙4G模组Air780EX——产品规格书

Air780EX 是合宙通信推出的LTE Cat.1 bis通信模块&#xff1b; Air780EX采用移芯EC618平台&#xff0c;支持LTE 3GPP Rel.13 技术&#xff1b; Air780EX 是4G全网通模块&#xff0c;可适应不同的运营商和产品&#xff0c;确保产品设计的最大灵活性。 其主要特点和优势可以总…

maven配置文件常用模板

注释很详细&#xff0c;直接上代码 项目结构 内容 父项目 pom.xml <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi…

高德地图SDK Android版开发 10 InfoWindow

高德地图SDK Android版开发 10 InfoWindow 前言相关类和方法默认样式Marker类AMap类AMap.OnInfoWindowClickListener 接口 自定义样式(视图)AMap 类AMap.ImageInfoWindowAdapter 接口 自定义样式(Image)AMap.ImageInfoWindowAdapter 接口 示例界面布局MapInfoWindow类常量成员变…

【数学建模国赛思路预约】2024全国大学生数学建模竞赛助攻思路、代码、论文

2024年全国大学生数学建模大赛马上就要开始了&#xff0c;大家有没有准备好呢&#xff0c;今年将会和之前一样&#xff0c;将会在比赛赛中时期为大家提供比赛各题的相关解题思路、可运行代码参考以及成品论文。 一、分享计划表如下所示 1、 赛中分享内容包括&#xff08;2023国…

高并发内存池(二):​整体框架的介绍与ThreadCache的实现

目录 整体框架介绍 ThreadCache的主体框架 自由链表-FreeList 内存对齐-RoundUp 计算桶位置-Index 基础版 进阶版 线程局部存储 __declspec(thread) 关键字 实现线程无锁 申请内存-Allocate 释放内存-Deallocate 从中心缓存中申请内存 整体框架介绍 高并发内存池…

机器学习引领未来:赋能精准高效的图像识别技术革新

图像识别技术近年来取得了显著进展,深刻地改变了各行各业。机器学习,特别是深度学习的突破,推动了这一领域的技术革新。本文将深入探讨机器学习如何赋能图像识别技术,从基础理论到前沿进展,再到实际应用与挑战展望,为您全面呈现这一领域的最新动态和未来趋势。 1. 引言 …

kubernetes集群部署Confluence 7.2.0+mysql 5.7(自测有效)

背景介绍&#xff1a; Confluence是一个专业的企业知识管理与协同软件。使用简单&#xff0c;但它强大的编辑和站点管理特征能够帮助团队成员之间共享信息、文档协作、集体讨论&#xff0c;信息推送。 这里介绍的使用的是Confluence 7.2.0版本的。 一、在kubernetes集群部署 1…

本地零阶提示优化

本文探讨了如何优化大型语言模型&#xff08;LLM&#xff09;中的提示&#xff08;prompt&#xff09;&#xff0c;以更有效地利用这些黑盒模型的能力。传统的优化方法倾向于寻找全局最优解&#xff0c;但在某些情况下这种做法可能表现不佳。通过对提示优化进行深入的研究&…

01 Docker概念和部署

目录 1.1 Docker 概述 1.1.1 Docker 的优势 1.1.2 镜像 1.1.3 容器 1.1.4 仓库 1.2 安装 Docker 1.2.1 配置和安装依赖环境 1.3镜像操作 1.3.1 搜索镜像 1.3.2 获取镜像 1.3.3 查看镜像 1.3.4 给镜像重命名 1.3.5 存储&#xff0c;载入镜像和删除镜像 1.4 Doecker…