fpga实现浮点数乘法以及sin运算

本文详细介绍了在FPGA中如何表示和操作浮点数,包括自定义浮点数格式和IEEE浮点数表示,并通过实例展示了浮点数乘法的计算过程。此外,还探讨了FPGA中调用sin IP核进行浮点数sin运算,并解释了如何将自定义浮点数转换为IEEE格式进行计算。提供了相关工具的下载链接及FPGA工程源码。
摘要由CSDN通过智能技术生成

一、FPGA表示浮点数的方法
FPGA表示浮点数的方法主要由两个
1 自己定义的 比如最高位位符号位,中间n位为整数部分,最后m位为小数部分

举个例子
3.14 转换位2进制 11.00100011
我们可以表示为这样 0_00000011_00100011
最高位为符号位 中间八位为整数部分,后八位为小数部分
这种定义的方式只有程序员自己知道 在写程序的时候可以随意的定义

2 IEEE浮点数表示方式

对于单精度(float)的数字来说 主要包括 最高位位符号位,中间8位阶码位,最后23位为尾数
还是拿3.14来举例 转换位2进制 11.00100011…
首先必须先将数据转换为1.x * 2^m次的格式 即 1.100100011 * 2^1格式
8位阶码位的大小位 127+1 127为固定的 1为2的指数
尾数就是小数点后面的所有数据 100100011后面补充0 到23位
所以最终表示为 0_10000000_10010001100000000000000 即 十六进制:4048C000(H)
通过计算机计算 发现4048C000对应的小数为3.136719 该误差是由于在计算3.14转换位2进制的时候只取了小数点后的8位,从而精度有了偏差
为了验证该表示方法的正确性 我们将3.14的二进制多取几位
3.14 = 11.001000111101011100001…
同理转换为科学技术法 3.14 = 11.001000111101011100001 = 1.1001000111101011100001 * 2^1
阶码位127+1 = 128
最终表示结果 0_10000000_10010001111010111000010 = 4048F5C2 (H)
经过计算器验证 4048F5C2 (H)对应的小数结果位3.140000 该表示方式正确

二、FPGA浮点乘法运算
我一般采用的浮点运算方式为自定义方式 即自己定义小数点的位置
比如计算 30 * pi/180
30 对应的二进制 00011110
规定A [23:0] [符号位] [22:15]整数位 [14:0] 小数位
则30表示为 24’b0_00011110_000000000000000

pi/180 = 0.0174444444444444对应的二进制 0.000001000111011
照规则B [16:0] [符号位] 15整数位 [14:0] 小数位
则 pi/180表示位17’b0_0_000001000111011

计算过程 30*pi/180 = 24’b0_00011110_000000000000000 * 16’b0_000001000111011
最终结果位24+17bit 即41bit
最关键的一点就是41bit中有多少是整数部分 多少位是小数部分
小数部分的位数是两个数小数部分位数之和 第一个数的小数部分15位 第二个数的小数部分15位
所以最终结果 小数部分共30位

所以最终的表示 [40:0] 40:符号位 [39:30]整数部分 [29:0]小数部分
计算过程

assign result =
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阳光非宅男

你的鼓励是我最大的肯定

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值