• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C语言 > DSP中浮点转定点运算--浮点数的存储格式

DSP中浮点转定点运算--浮点数的存储格式

作者:ganxingming 字体:[增加 减小] 来源:互联网 时间:2017-05-28

ganxingming 通过本文主要向大家介绍了定点dsp和浮点dsp,dsp定点和浮点,dsp浮点运算,浮点dsp,定点dsp等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

二:浮点数的存储格式

2.1 IEEE floating point standard

  上面我们说了,浮点数的小数点是不固定的,如果每个人都按照自己的爱好存储在电脑里,那不就乱套了吗?那么怎么在计算机中存储这种类型的数字呢?象这类古老的问题前人早都为我们做好了相应的规范,无规矩不成方圆吗。我们平时所说的浮点数的存储规范,就是由IEEE指定的,具体的规范文件是:IEEE Standard 754 for Binary Floating-Point Arithmetic。大家可以很容易的从网络上下载到这篇文档。

  在c语言中,单精度(float)数据类型为32bits,具体的如下图所示:

/UpFiles/2017/5/28/2016617102352889.png

整个32bits分三部分,即

  Sign:符号位,1 bit,0为正,1为负;

  Exponent(bias):指数部分,8 bits,存储格式为移码存储(后面还会说明),偏移量为127;

  Mantissa(fraction):尾数部分。

  对应的双精度(double)类型的格式为:

/UpFiles/2017/5/28/2016617102402031.png

同样,64位也被分为了三部分,对照单精度,不用我说就可以理解各个部分的含义了吧?

  是不是有点迷糊了,不要怕,理论这个东西最能忽悠人了,看起来很高深,其实也就是个屁大的事,举个例子就很容易明白了。

举例说明,如3.24x103,则对应的部分为,Sign为0,3为指数部分(注意计算机里面存储的不是3,这里仅仅为了说明),3.24为尾数。我们知道,计算机“笨”的要死,只认识0和1,那么到底一个浮点数值在计算机存储介质中是如何存储的呢?

例如,我们要想偷窥浮点类型的值4.25在计算机硬盘中存储的庐山真面目,请跟我来:首先把4.25转换成二进制的表达方式,即100.01,在详细点,变成1.0001x22,好了,对号入座把。

Sign=0;

Exponent(bias)=2+127=129 (偏移量为127,就是直接加上个127了);

Mantissa=1.0001-1.0=0001(规格化后,小数点前总是整数1,全世界人都知道前面是1不是0,所以省略不写了,即尾数部分不包括整数部分;当别人问你,为什么23 bit的尾数部分可以表示24位的精度,知道怎么回答了吧。 靠,什么,没有看懂,再仔细读两便就知道了)。

 /UpFiles/2017/5/28/2016617102409132.png

对照上面的图示,相信你已经看明白了吧?相信你的智商。为了加深认识,再来一个。如果给定你一个二进制数字串,01000000100010000000000000000000,并告诉你这是一个float类型的值,让你说出它是老几,知道怎么算了吧?如果不知道,看下面的图,我就不废话解释了。

/UpFiles/2017/5/28/2016617102421605.png

2.2深入理解浮点存储格式

为了更深入的理解浮点数的格式。我们使用C语言来做一件事。在C语言的世界里,强制类型转换,大家应该都很熟悉了。例如:

float f=4.6;

int i;

…

i = (int)(f+0.5); // i=5

..</div>

下面我们不使用强制类型转化,我们自己来计算f转换成整形应该等于几?

把主要代码帖出来,如下:

int ival= ((*(int *)(&fval)) & 0x07fffff) | 0x800000;

// 提取指数部分

int exponent = 150 - (((*(int *)(&fval)) >> 23) & 0xff);

if (exponent < 0)

ival = (ival<< -exponent);

else

ival = (ival >> exponent);

// 如果小于0,则将结果取反

if ((*(int *)&fval) & 0x80000000)

ival = -ival;</div>

好好琢磨琢磨吧,看明白了,就说明你基本明白了浮点数的存储格式,如果没有看明白,接着看,知道明白为止。

以上就是本文的全部内容,希望能给大家一个参考,也希望大家多多支持。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • DSP中浮点转定点运算--举例及编程中的心得
  • DSP中浮点转定点运算--定点数模拟浮点数运算及常见的策略
  • DSP中浮点转定点运算--定点数的加减乘除运算
  • DSP中浮点转定点运算--浮点数的存储格式
  • DSP中浮点转定点运算--浮点与定点概述

相关文章

  • 2017-05-28C语言数据结构 栈的基础操作
  • 2017-05-28c++动态内存空间示例(自定义空间类型大小和空间长度)
  • 2017-05-28基于c++中的默认拷贝函数的使用详解
  • 2017-05-28C语言数组入门之数组的声明与二维数组的模拟
  • 2017-05-28C++线程同步实例分析
  • 2017-05-28浅谈C++ 基类指针和子类指针的相互赋值
  • 2017-05-28c语言中位字段与结构联合的组合使用详解
  • 2017-05-28stl容器set,map,vector之erase用法与返回值详细解析
  • 2017-05-28C++基础入门教程(八):函数指针
  • 2017-05-28VC MFC非模态对话框的实现方法

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • linux系统中c++写日志文件功能分享
    • Objective-C的内省(Introspection)用法小结
    • C++ CTreeview的checkbox使用方法
    • C++中用两个标准容器stack,实现一个队列的方法详解
    • C语言中设置用户识别码的相关函数的简单讲解
    • C语言fgets和fputs函数的用法详解(以字符串的形式读写文件)
    • LintCode 堆化详解及实例代码
    • C++设计模式之中介者模式
    • 使用OpenGL实现3D立体显示的程序代码
    • C++中的常对象与常对象成员详解

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有