URN Logo
UNIX Resources » Linux » China Linux Forum » CPU 与 编译器 » 5 » 浮点模拟
announcement 声明: 本页内容为中国Linux论坛的内容镜像,文章的版权以及其他所有的相关权利属于中国Linux论坛和相应文章的作者,如果转载,请注明文章来源及相关版权信息。
Resources
China Linux Forum(finished)
Linux Forum(finished)
FreeBSD China(finished)
linuxforum.net
  业界新闻与评论
  自由软件杂谈
  IT 人生
  Linux软件快递
  翻译作坊
  Linux图书与评论
  GNU Emacs/XEmacs
  Linux 中文环境和中文化
  Linux桌面与办公软件
  Linux 多媒体与娱乐版
  自由之窗Mozilla
  笔记本电脑上的Linux
  Gentoo
  Debian 一族
  网络管理技术
  Linux 安装与入门
  WEB服务器和FTP服务器
  域名服务器和邮件服务器
  Linux防火墙和代理服务器应用
  文件及打印服务器
  技术培训与认证
  Linux内核技术
  Linux 嵌入技术
  Linux设备驱动程序
  Linux 集群技术
  LINUX平台数据库
  系统和网络安全
  CPU 与 编译器
  系统计算研究所专栏
  Linux下的GUI软件开发
  C/C++编程版
  PHP 技 术
  Java&jsp技术
  Shell编程技术
  Perl 编 程
  Python 编 程
  XML/Web Service 技术
  永远的Unix
  FreeBSD世界
   
浮点模拟
浮点模拟 - EricFisher [2006-01-20 15:08 | 243 byte(s)]
 
Re: 浮点模拟 - EricFisher [2006-01-23 09:29 | 1,316 byte(s)]
 
Subject: 浮点模拟
Author: EricFisher    Posted: 2006-01-20 15:08    Length: 243 byte(s)
[Original] [Print] [Top]
1、有谁知道gcc的浮点模拟代码fp-bit.c中,NGARDS,IMPLICIT_1这两个宏什么意思?

2、unpack_d函数最后的代码,dst->fraction.ll = (fraction << NGARDS) | IMPLICIT_1;什么意思?

谢谢!
[Original] [Print] [Top]
Subject: Re: 浮点模拟
Author: EricFisher    Posted: 2006-01-23 09:29    Length: 1,316 byte(s)
[Original] [Print] [Top]
> I guess that the macro NGARDS is relevant to the guard digit. But I
> still failed to have a clear conception about what it means. Others
> are easy to know by IEEE 754 and "What Every Computer Scientist Should
> Know about Floating-Point Arithmetic". Except,
>
> define NGARDS 8L
> define GARDROUND 0x7f
> define GARDMASK 0xff
> define GARDMSB 0x80
>
> what do these mean? :-)

NGARDS is the number of guard bits--as I recall you need at least two
guard bits, and beyond that fp-bit just fills out to the next byte
boundary. GARDROUND is a mask for the bits - 1, GARDMASK is a mask
for the bits, GARDMSB is the most significant guard bit.

> Especially when unpack a signal floating point, the fraction takes
> such an operation at last, that make me much confused.
> dst->fraction.ll = (fraction << NGARDS) | IMPLICIT_1;

The left shift makes room for the guard bits. The IMPLICIT_1 is the
implicit 1 found in the IEEE-754 floating point mantissa.

Ian
[Original] [Print] [Top]
« Previous thread
【急】相同的算法、输入,不同的CPU,操作系统,结果不一样?
CPU 与 编译器
5
Next thread »
请教版主mips TLB refill异常的问题
     

Copyright © 2007 UNIX Resources Network, All Rights Reserved.      About URN | Privacy & Legal | Help | Contact us
备案序号: 京ICP备05006143    webmaster: webmaster@unixresources.net
This page created on 2008-07-17 03:47:18, cost 0.055654048919678 ms.