中文
注册
我要评分
文档获取效率
文档正确性
内容完整性
文档易理解
在线提单
论坛求助
鲲鹏小智

scalbn

计算x * 2^y的值。

接口定义

C interface:

float scalbnf(float x, int y);

double scalbn(double x, int y);

long double scalbnl(long double x, int y);

参数

参数名

类型

描述

输入/输出

x

  • 在scalbnf中,x是单精度浮点类型。
  • 在scalbn中,x是双精度浮点类型。
  • 在scalbnl中,x是长双精度浮点类型。

表示输入数据的浮点值。

输入

y

  • 在scalbnf中,y是整数类型。
  • 在scalbn中,y是整数类型。
  • 在scalbnl中,y是整数类型。

表示输入数据的整数值。

输入

返回值

  • 返回x * 2^y的值,发生溢出时,返回±∞(符号与x保持一致)。

依赖

C: "km_l9.h"

示例

C interface:
    // typical usage
    double x1 = 0.0, x2 = -0.0, x3 = 2.0;
    long int y1 = 2, y2 = 3, y3 = 4, y4 = 5, y5 = 1100;
    // special handing
    double a = INFINITY, b = -INFINITY, c = NAN;
    printf("scalbn(0.0, 2) = %.15f\n", scalbn(x1, y1));
    printf("scalbn(-0.0, 3) = %.15f\n", scalbn(x2, y2));
    printf("scalbn(2.0, 4) = %.15f\n", scalbn(x3, y3));
    printf("scalbn(2.0, 5) = %.15f\n", scalbn(x3, y4));
    printf("scalbn(2.0, 1100) = %.15f\n", scalbn(x3, y5));
    printf("scalbn(INFINITY, 2) = %.15f\n", scalbn(a, y1));
    printf("scalbn(-INFINITY, 2) = %.15f\n", scalbn(b, y1));
    printf("scalbn(NAN, 2) = %.15f\n", scalbn(c, y1));
    /* 
     * scalbn(0.0, 2) = 0.000000000000000
     * scalbn(-0.0, 3) = -0.000000000000000
     * scalbn(2.0, 4) = 32.000000000000000
     * scalbn(2.0, 5) = 64.000000000000000
     * scalbn(2.0, 1100) = inf
     * scalbn(INFINITY, 2) = inf
     * scalbn(-INFINITY, 2) = -inf
     * scalbn(NAN, 2) = nan
     */