在softfolat中双精度浮点、单精度浮点对异常值的处理,代码是什么

时间: 2024-02-23 22:59:59 浏览: 19
在softfloat中,双精度浮点数和单精度浮点数对异常值的处理方式是一致的,都是根据IEEE 754标准中定义的规则进行处理的。以下是softfloat中处理浮点异常值的部分代码示例: ```c /*---------------------------------------------------------------------------- | Handle invalid operation exception. *----------------------------------------------------------------------------*/ void softfloat_raiseFlags( int32_t flags ) { float_exception_flags |= flags; } /*---------------------------------------------------------------------------- | Raise the invalid operation exception for a NaN operand. *----------------------------------------------------------------------------*/ void softfloat_raiseNaNFlags( uint_fast64_t uiA ) { if ( softfloat_isSigNaNF64UI( uiA ) || softfloat_isSigNaNF32UI( uiA ) ) { softfloat_raiseFlags( float_flag_invalid ); } } /*---------------------------------------------------------------------------- | Determine whether the result of a float addition is NaN. *----------------------------------------------------------------------------*/ bool softfloat_isNaNF32UI( uint_fast32_t uiA ) { return ( ( uiA & 0x7F800000 ) == 0x7F800000 ) && ( uiA & 0x007FFFFF ); } /*---------------------------------------------------------------------------- | Perform a float-to-int conversion, rounding to nearest, with double rounding | to even in the presence of a tie. *----------------------------------------------------------------------------*/ int32_t softfloat_roundPackToF32( bool sign, int_fast16_t exp, uint_fast32_t sig ) { int_fast8_t roundingMode; bool roundNearEven; int32_t absZ; roundingMode = float_rounding_mode; roundNearEven = ( roundingMode == float_round_nearest_even ); if ( 0x96 <= (uint16_t) exp ) { if ( ( exp < 0 ) || ( sig | (uint32_t) ( exp << 13 ) ) ) { softfloat_raiseFlags( float_flag_invalid ); return sign ? (int32_t) ui32_to_i64( 0x80000000 ) : 0x7FFFFFFF; } return sign ? (int32_t) ui32_to_i64( 0x80000000 ) : 0x7FFFFFFF; } if ( exp <= -0x6F ) { if ( exp < -0x96 ) { softfloat_roundPackFloatToExtF80M( sign, exp + 0x7F, sig | 0x00800000, 0, &absZ ); return absZ; } return 0; } return softfloat_roundPackMToF32( sign, 0x7F + exp, sig | 0x00800000, roundingMode, roundNearEven ); } ``` 这里只是部分代码示例,softfloat中对不同类型浮点数的异常值处理代码比较复杂,需要对整个库进行详细的分析和理解。

相关推荐

最新推荐

recommend-type

C语言菜鸟基础教程之单精度浮点数与双精度浮点数

在C语言中,单精度浮点数(float)和双精度浮点数(double)类型都是用来储存实数的,双精度是用记忆较多,有效数字较多,数值范围较大。
recommend-type

32位单精度浮点乘法器的FPGA实现

32位单精度浮点乘法器的FPGA实现32位单精度浮点乘法器的FPGA实现
recommend-type

对S7-200PLC双精度浮点数转单精度浮点数例程的一点补充

对S7-200PLC双精度浮点数转单精度浮点数例程的一点补充,远程抄表相关技术的交流
recommend-type

PCB技术中的贴装精度

贴装精度(即贴装偏差),也称定位精度,描述一个元器件放置在PCB上预定位置上的准确程度。贴片机精度的是指所放元器件实际位置与预定位置的最大偏差,反映了实际位置与预定位置之间的一致程度,从数据分析的角度说...
recommend-type

基础电子中的基于AD5933的高精度生物阻抗测量方案

显然,这些研究和设计工作均在某一方面对生物阻抗测量系统的精度提高做出了贡献,但是单一的方法对精度的提高有限,本文采用ADI公司的高度集成的阻抗测量芯片AD5933设计了一种精度高的阻抗测量方法,利用比例测量,...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB柱状图在信号处理中的应用:可视化信号特征和频谱分析

![matlab画柱状图](https://img-blog.csdnimg.cn/3f32348f1c9c4481a6f5931993732f97.png) # 1. MATLAB柱状图概述** MATLAB柱状图是一种图形化工具,用于可视化数据中不同类别或组的分布情况。它通过绘制垂直条形来表示每个类别或组中的数据值。柱状图在信号处理中广泛用于可视化信号特征和进行频谱分析。 柱状图的优点在于其简单易懂,能够直观地展示数据分布。在信号处理中,柱状图可以帮助工程师识别信号中的模式、趋势和异常情况,从而为信号分析和处理提供有价值的见解。 # 2. 柱状图在信号处理中的应用 柱状图在信号处理
recommend-type

帮我设计一个基于Android平台的便签APP的代码

很抱歉,我是一个语言模型AI,无法提供完整的Android APP代码。但是,我可以给您一些设计便签APP的建议和思路。 1. 界面设计 首先考虑APP的界面设计,便签APP通常需要一个主界面用于显示所有的便签,以及一个编辑界面用于编辑单个便签。主界面可以采用列表的形式,列出所有的便签,每个便签可以显示标题和摘要内容。在编辑界面中,用户可以输入标题和正文内容,并且可以设置提醒时间、标签、优先级等。 2. 数据存储 便签APP需要一个数据存储的方案,可以考虑使用SQLite数据库来存储便签数据。每个便签可以存储标题、正文内容、提醒时间、标签、优先级等信息。 3. 便签操作 便签APP
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。