nextafterf
产品支持情况
产品 |
是否支持 |
|---|---|
Atlas 350 加速卡 |
√ |
x |
|
x |
|
x |
|
x |
|
x |
|
x |
功能说明
对于两个数据x、y:
如果y大于x,返回比x大的下一个可表示的浮点值。
如果y小于x,返回比x小的下一个可表示的浮点值。
如果y等于x,返回x。
函数原型
1 | inline float nextafterf(float x, float y) |
参数说明
参数名 |
输入/输出 |
描述 |
|---|---|---|
x |
输入 |
源操作数。 |
y |
输入 |
源操作数。 |
返回值说明
- x不等于y时,返回y方向上x之后下一个可表示的浮点值。
- x等于y时,返回x。
- 若x、y任意一个为nan,返回nan。
- 若x=+inf,y不为nan,返回3.4028235e+38。
- 若x=-inf,y不为nan,返回-3.4028235e+38。
约束说明
SIMT编程场景当前不支持使用该接口。
需要包含的头文件
使用该接口需要包含"simt_api/math_functions.h"头文件。
1 | #include "simt_api/math_functions.h" |
调用示例
SIMD与SIMT混合编程场景:
1 2 3 4 5 6 | __simt_vf__ __launch_bounds__(1024) inline void KernelNextAfter(__gm__ float* dst, __gm__ float* x, __gm__ float* y) { int idx = threadIdx.x + blockIdx.x * blockDim.x; dst[idx] = nextafterf(x[idx], y[idx]); printf("x[%d] = %f, y[%d] = %f, dst[%d] = %f, 输入x的16进制表示为: 0x%x, 输出dst的16进制表示为: 0x%x\n", idx, x[idx], idx, y[idx], idx, dst[idx], x[idx], dst[idx]); } |
程序输入为:
1 2 | x:[10.0f 10.0f -10.0f -10.0f ...] y:[20.0f -20.0f 20.0f -20.0f ...] |
程序前4个线程的运行时打印效果如下:
1 2 3 4 | x[0] = 10.000000, y[0] = 20.000000, dst[0] = 10.000001, 输入x的16进制表示为: 0x41200000, 输出dst的16进制表示为: 0x41200001 x[1] = 10.000000, y[1] = -20.000000, dst[1] = 9.999999, 输入x的16进制表示为: 0x41200000, 输出dst的16进制表示为: 0x411fffff x[2] = -10.000000, y[2] = 20.000000, dst[2] = -9.999999, 输入x的16进制表示为: 0xc1200000, 输出dst的16进制表示为: 0xc11fffff x[3] = -10.000000, y[3] = -20.000000, dst[3] = -10.000001, 输入x的16进制表示为: 0xc1200000, 输出dst的16进制表示为: 0xc1200001 |
父主题: 数学函数