ldexp.c

来自「开发平台ccs5000 tms320vc5416的fft程序」· C语言 代码 · 共 29 行

C
29
字号
/****************************************************************************/
/*  LDEXP  v3.70                                                           */
/*  Copyright (c) 1993-2001 Texas Instruments Incorporated                  */
/****************************************************************************/
#include <math.h>
#include <errno.h>

double ldexp(double x, int exp)
{
     int *ptr = (int *)&x;
     long texp = (long) exp + ((ptr[0] >> 7) & 0xFF);

     /***********************************************************************/
     /* IF RESULT UNDERFLOWS, RETURN 0.0.  IF RESULT OVERFLOWS, RETURN      */
     /* +- INFINITY.                                                        */
     /***********************************************************************/
     if      (texp < 1)      
       x = 0.0; 
     else if (texp > 0xFE) 
     { 
       errno = ERANGE;
       x = (x < 0) ? -HUGE_VAL : HUGE_VAL;
     }
     else                   
       ptr[0] = (ptr[0] & 0x807F) | ((int)texp << 7);
   
     return x;
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?