找回密码
 注册
关于网站域名变更的通知
查看: 268|回复: 1
打印 上一主题 下一主题

FPGA表示浮点数的方法

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2019-8-20 14:49 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
FPGA表示浮点数的方法( F0 |' [( N. P6 Q4 t
7 T6 R5 n- u# e
FPGA表示浮点数的方法主要由两个! T5 z, e4 F, ]" i# F5 D

/ }6 U3 D: Y2 b- h, X0 N. b1 自己定义的 比如最高位位符号位,中间n位为整数部分,最后m位为小数部分
% w  ?7 I% P% O$ S' v/ U; }) {
, \) e8 K* I7 G. K. `举个例子  ?4 L3 ^) h' C) n$ O
3.14 转换位2进制 11.00100011
' W2 C# u: X' @& e& N, `1 G" y我们可以表示为这样 0_00000011_00100011
5 q' v: W! |) h& I$ @最高位为符号位 中间八位为整数部分,后八位为小数部分
/ ?. b- @/ ~- T  m  D3 c这种定义的方式只有程序员自己知道 在写程序的时候可以随意的定义! `- ]% I8 J5 N- Q' m1 `

& S* g9 H  I) r' Z3 K2 IEEE浮点数表示方式- t4 Y5 [/ D5 a9 L5 X5 `+ y( V
$ R( c6 }5 P+ D9 n- Q
对于单精度(float)的数字来说 主要包括 最高位位符号位,中间8位阶码位,最后23位为尾数
5 H- H) u/ g% u$ Y还是拿3.14来举例 转换位2进制 11.00100011…, Q) @7 H" a/ d& ^
首先必须先将数据转换为1.x * 2^m次的格式 即 1.100100011 * 2^1格式+ F( ^/ Y) c+ N) B' b1 G6 _
8位阶码位的大小位 127+1 127为固定的 1为2的指数$ U3 ]# ], G" V: K8 n- O0 b
尾数就是小数点后面的所有数据 100100011后面补充0 到23位
( Q# m( T; S8 l5 R所以最终表示为 0_10000000_10010001100000000000000 即 十六进制:4048C000(H)' d: I; C' ~+ h6 L1 s
通过计算机计算 发现4048C000对应的小数为3.136719 该误差是由于在计算3.14转换位2进制的时候只取了小数点后的8位,从而精度有了偏差/ j4 v6 o2 x0 q* P/ z$ V
为了验证该表示方法的正确性 我们将3.14的二进制多取几位
/ ]7 m  g8 n( L3.14 = 11.001000111101011100001…
# @1 K* _4 A3 M; p- }8 z5 `同理转换为科学技术法 3.14 = 11.001000111101011100001 = 1.1001000111101011100001 * 2^1
6 d9 i% Q7 c  B& u1 p阶码位127+1 = 128$ K3 b" M0 a# o% C4 h
最终表示结果 0_10000000_10010001111010111000010 = 4048F5C2 (H)* h# O' ], r7 d( h
经过计算器验证 4048F5C2 (H)对应的小数结果位3.140000 该表示方式正确
3 x6 q/ o" o( h  _* i$ C7 r& s0 U1 A6 ~$ U: n
: h( O+ V) q3 g' X' p* U

0 a7 F* F  l- d9 @6 m5 u, S" X0 z, x
, ]; O% ~9 o, g& t4 S
4 G! G9 l0 x4 m- J% I# R/ Q2 L
! A! \, Z0 h, \8 `+ v  W

. C. D- h1 ~) R- l( q  h8 m' w# B+ F: {, j
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

EDA365公众号

关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

GMT+8, 2025-8-20 17:58 , Processed in 0.125000 second(s), 23 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

快速回复 返回顶部 返回列表