FPGA浮点数定点数的处理
http://blog.chinaaet.com/justlxy/p/5100053166大佬博客,讲的非常有条理的
1,基础知识
(1)定点数的基础认知:
首先例如一个16位的数表示的定点数的范围是:(MAX:16‘d32767 MIN: -32767#2^15-1#’)最高位符号位,三位整数位,其余的12位是小数位的话,那么
它的精度有小数部分决定:1/4096=0.0244140625
可表示数的范围为:(0.0244140625*4095)=0.999755859375,然后加上整数的最大表示值7,即极限最大值为7.999755859375。
(2)浮点数的认知
浮点数就是指整数和小数位数不确定的数字的表达,实际上采用的就是咱们常用的科学计数法。如1.23*10^2采用的是基数(10),指数(2),尾数(1.23)以及一个符号位来表示。这里实际上是采用指数方法实现了小数点的浮动。
在 IEEE 标准中,浮点数是将特定长度的连续字节的所有二进制位分割为特定宽度的符号域,指数域和尾数域三个域,其中保存的值分别用于表示给定二进制浮点数中的符号,指数和尾数。这样,通过尾数和可以调节的指数(所以称为"浮点")就可以表达给定的数值了。具体的格式参见下面的图例:


上图中可以看出S表示符号位,EXponent表示指数位,也就是“浮动”的指数位,指数的范围在32位的系统中(0-2^8 -1)/2 也就是0-127,在double型位2^11位浮动指数。
2.FPGA浮点数的定点化
首先明确输入的浮点数是什么格式的:其次明白要输出的定点数又是怎样的,最后两者之间的转换也就明了了:
输入的浮点数是::f[31:0]表示一个单精度32位浮点数,f[31]是符号位,其为‘0’表示正数、为‘1’表示负数;f[30:23]这8位为指数位,为了能表示负指数,将在实际指数的基础上加上127得到的结果存入f[30:23];f[22:0]表示小数位(尾数),类似科学计数法,不过采用了省略整数位(2进制的科学计数法整数位必定是1)1。那么这个浮点数要转换成定点数,就需要先判断指数位与127的关系,小于127,则说明该指数位是正数,那么转化成定点数的话就需要将{8'd1,float_in[22:0]}右移127-float_in[30:23]位,否则左移float_in[30:23]-127位。
代码稍微贴一下
module float2fixed_pipeline
(
input [:] float_in,
input enable,
input clk,
input rst,
output reg [:] fixed_out,
output reg valid
); reg [:] M_copy;
reg [:] shift_value;
reg shift_direction; //0, shift left; 1, shift right
reg sign; //符号位
reg valid_count; // Pipeline level 1
always @ (posedge clk or posedge rst) begin //synchronous enable and asynchronous reset
if(rst) begin
shift_value <= 'd0;
shift_direction <= 'b0;
sign <= 'b0;
M_copy <= 'd0;
end
else if(enable) begin
sign <= float_in[];
M_copy <= {'d1,float_in[22:0]}; if(float_in[:] <= 'd127) begin //E <= 127,shfit {1'b1,M} right to get I(指数) and F(小数)
shift_direction <= 'b1;
shift_value <= 'd127 - float_in[30:23];
end
else begin //E > 127,shfit {1'b1,M} left to get I and F
shift_direction <= 'b0;
shift_value <= float_in[:] - 'd127;//2^7-1
end
end
else begin //enable = 0, Maintain the previous value
shift_value <= shift_value;
shift_direction <= shift_direction;
sign <= sign;
M_copy <= M_copy;
end
end // Output logic
always @ (posedge clk or posedge rst) begin //synchronous enable and asynchronous reset
if(rst) begin
fixed_out <= 'd0;
end
else if(enable) begin
if(shift_direction) begin //E <= 127,shfit {1'b1,M} right to get I and F
fixed_out <= {sign,M_copy >> shift_value};
end
else begin //E > 127,shfit {1'b1,M} left to get I and F
fixed_out <= {sign,M_copy << shift_value};
end
end
else begin //enable = 0, Maintain the previous value
fixed_out <= fixed_out;
end
end // The valid output logic
always @ (posedge clk or posedge rst) begin //asynchronous reset
if(rst) begin
valid <= 'b0;
valid_count <= 'd0;
end
else if(enable) begin
if(valid_count == 'd1) begin //Maintain valid as ture unless reset
valid <= 'b1;
valid_count <= valid_count;
end
else begin
valid_count <= 'b1;
valid <= 'b0;
end
end
else begin //enable = 0, Maintain the previous value
valid <= valid;
valid_count <= valid_count;
end
end endmodule
3.FPGA定点数的浮点化
也是想明白输入的定点数格式为最高位是符号位,然后紧接着8位整数位,最后是23位小数位。我们需要注意的是转换后的输出的浮点数最高位符号位,然后是8位的指数位,最后是23位小数位,其表达的浮点数的大小为

,将小数位从高到低依次存入f[22:0]的从高到低的位数,不足23位则在末尾补0,例如小数位只有“10011001”则f[22:0]="10011001000000000000000",这样就可以用23位存储空间表示24位的数据,变相增加了精度。另外还有一些特殊编码,如无穷大、0、NAN和非正规数,这里没有考虑,待以后用到再细究吧。
手算整理思路:
首先是浮点数的指数位的确定:看定点数整数部分的最高非零位的位置N,那么exp=N-1,
然后是浮点数的小数位的确定:这里用到了127这个所谓的偏置数以及流水线的设计方法:
// Output logic
always @ (posedge clk or posedge rst) begin //synchronous enable and asynchronous reset
if(rst) begin
float_out <= 'd0;
end
else if(enable) begin
if(fixed_shift_reg3[] == 'b1) begin
float_out <= {fixed_shift_reg3[],8'd127 - shift_count3 - 8'd1 + ((shift_direction3) ? 'd8 : 8'd0),fixed_shift_reg3[:],'d0};
end
else if(fixed_shift_reg3[] == 'b1) begin
float_out <= {fixed_shift_reg3[],8'd127 - shift_count3 - 8'd2 + ((shift_direction3) ? 'd8 : 8'd0),fixed_shift_reg3[:],'d0};
end
else if(fixed_shift_reg3[] == 'b1) begin
float_out <= {fixed_shift_reg3[],8'd127 - shift_count3 - 8'd3 + ((shift_direction3) ? 'd8 : 8'd0),fixed_shift_reg3[:],'d0};
end
else begin //The fixed-point input is zero, -0 will be cast to 0 too.
float_out <= {'b0,8'd127,'d0};
end
end
else begin //enable = 0, Maintain the previous value
float_out <= float_out;
end
end
小数位的移动在三级流水线中分别根据的是fixed_in[22:11],fixed_shift_reg1[22:17],fixed_shift_reg1[22:20].不等于0的时候不移位,直接拼接,等于0的时候分别移位12,6,3位,将每级流水线中的移位次数记录下来为shift_count3.。。。。。。
关于流水线的verilog基础还是不扎实,所以下一篇接上流水线的解剖~
FPGA浮点数定点数的处理的更多相关文章
- FPGA浮点数定点化
因为在普通的fpga芯片里面,寄存器只可以表示无符号型,不可以表示小数,所以在计算比较精确的数值时,就需要做一些处理,不过在altera在Arria 10 中增加了硬核浮点DSP模块,这样更加适合硬件 ...
- FPGA 浮点定点数的处理
大纲: 1浮点数的格式指定 2浮点数的运算(加法) 3浮点数加减法器的实现(难于乘除法器的实现) 1. 在FPGA的设计中,浮点数的概念不同于C语言中的定义,这里的浮点数指的是小数点位置会发生变化的 ...
- FPGA大疆考试准备内容
1.寄存器与锁存器 锁存器:电平触发的存储单元,在有效电平时间里可以多次改变数据. 优点: 占触发器资源少,缺点是容易产生毛刺.(附上去毛刺的方法:格雷码计数器(*https://blog.cs ...
- IP核引发的关于定,浮点数的认识
上面是一段关于CORDIC_IP测试文件,用于计算给定角度的sin值和cos值,关于数值表示规则在此不再重复,仅仅说明以下3点: 1 数采用原码,反码,补码,本身并没有正确与否之分(这一点很重要,我 ...
- MySQL用户管理及SQL语句详解
1.1 MySQL用户管理 1.1.1 用户的定义 用户名+主机域 mysql> select user,host,password from mysql.user; +--------+--- ...
- 【重学计算机】计组D2章:数据表示
1.基本概念 真值:+0101,-0100:机器数: [x]原=0101 2.几种机器数 原码:x = -0101,[x]原 = 1101 反码:x = -0101,[x]反 = 1010 补码:x ...
- MySQL数据类型1
1.float.double.decimal类型用法详解 三者的区别介绍 float:浮点型,含字节数为4,32bit,数值范围为-3.4E38~3.4E38(7个有效位) double:双精度实型, ...
- 【转】MySQL用户管理及SQL语句详解
[转]MySQL用户管理及SQL语句详解 1.1 MySQL用户管理 1.1.1 用户的定义 用户名+主机域 mysql> select user,host,password from mysq ...
- NOIP2018 No regrets youth
NOIP2018在即,20181009总结一些易错的知识点和解题方法 ——by ljc20020730 HGOI NOIP2018 No regrets youth ! NOIP2018 No reg ...
随机推荐
- [极客大挑战 2019]PHP
0x00知识点 1:直接扫描目录得到网站源码. 2:public.protected与private在序列化时的区别 protected 声明的字段为保护字段,在所声明的类和该类的子类中可见,但在该类 ...
- Codeforces Round #568 (Div. 2)网卡&垫底记
这场和div3差不多嘛(后来发现就是div3),就是网太卡10min交一发就不错了,简直自闭. A 签到. B 记录每一段的字母数,满足条件即:段数相同+字母相同+字母数下>=上. #inclu ...
- 剑指offer【08】- 二叉树的深度(java)
题目:二叉树的深度 考点:知识迁移能力 题目描述:输入一棵二叉树,求该树的深度.从根结点到叶结点依次经过的结点(含根.叶结点)形成树的一条路径,最长路径的长度为树的深度. 牛客网上的剑指offer题, ...
- 关于linux下安装mysqlclient报 Failed building wheel for mysqlclient问题
导入下列依赖包,搞定 sudo apt-get install python3 python-dev python3-dev build-essential libssl-dev libffi-dev ...
- 吴裕雄--天生自然 PHP开发学习:MySQL 读取数据
<?php $servername = "localhost"; $username = "root"; $password = "admin& ...
- 01 语言基础+高级:1-6 集合_day02【Collection、泛型】
day02[Collection.泛型] 主要内容 Collection集合 迭代器 增强for 泛型 教学目标 能够说出集合与数组的区别 说出Collection集合的常用功能 能够使用迭代器对集合 ...
- 优秀的github java项目
转载:https://www.zhihu.com/question/24834285/answer/251369977 biezhi/blade:先推荐下自己的哈哈,一款轻量级.高性能.简洁优雅的MV ...
- Mysql存储过程案例集合
注:使用的工具为SQLyog 壹.while简单使用(替换字符串中的字符,和REPLACE效果一样) 注: 这里没有使用REPLACE函数 1.创建存储过程 DROP PROCEDURE IF EXI ...
- 2.windows-oracle实战第二课 -用户管理
创建用户:在oracle中创建一个用户有create user语句,一般是具有dba(数据库管理员)的权限才能使用.用户创建在所在的实例数据库中. 给用户修改密码:passw 给别人修改密码需要dba ...
- 分辨率单位及换算,LW / PH、LP / mm、L / mm、Cycles / mm、Cycles / pixel、LP / PH
对于测试数字成像设备非常重要的参数是分辨率.但有不同的方式来表达数码相机的分辨率,有时令人困惑.下面介绍的是是最常见的单位. 百万像素 “这台相机有1000万像素的分辨率”是我们经常在广告上看到的数据 ...