CountBitsCntSameAsSignBit

产品支持情况

产品 是否支持
Ascend 950PR/Ascend 950DT
Atlas A3 训练系列产品/Atlas A3 推理系列产品
Atlas A2 训练系列产品/Atlas A2 推理系列产品
Atlas 200I/500 A2 推理产品 x
Atlas 推理系列产品AI Core
Atlas 推理系列产品Vector Core x
Atlas 训练系列产品 x
Kirin X90
Kirin 9030

功能说明

头文件路径为:"basic_api/kernel_operator_scalar_intf.h"

统计int64_t类型数值的二进制表示中,从最高数值位开始与符号位相同的连续比特位的个数。

以如下CountBitsCntSameAsSignBit调用为例:

int64_t valueOut = AscendC::CountBitsCntSameAsSignBit(0x0100000000000020ULL); // 返回6

其计算结果如下图所示:

图 1 CountBitsCntSameAsSignBit计算示意图

CountBitsCntSameAsSignBit计算示意图

函数原型

__aicore__ inline int64_t CountBitsCntSameAsSignBit(int64_t valueIn)

参数说明

表 1 参数说明

参数名称 输入/输出 描述
valueIn 输入 被统计的二进制数字。

返回值说明

返回从最高数值位开始与符号位相同的连续比特位的个数。

约束说明

当输入是-1(比特位全1)或者0(比特位全0)时,返回-1。

调用示例

int64_t valueOut;
int64_t valueIn = 0;                                    // 二进制表示全为0
valueOut = AscendC::CountBitsCntSameAsSignBit(valueIn); // 返回-1

valueIn = 0xFFFFFFFFFFFFFFFFLL;                         // -1, 二进制表示全为1
valueOut = AscendC::CountBitsCntSameAsSignBit(valueIn); // 返回-1

valueIn = 0x7FFFFFFFFFFFFFFFLL;                         // 正数最大值
valueOut = AscendC::CountBitsCntSameAsSignBit(valueIn); // 返回0

valueIn = 0x8000000000000000LL;                         // 负数最小值
valueOut = AscendC::CountBitsCntSameAsSignBit(valueIn); // 返回0

valueIn = 1;
valueOut = AscendC::CountBitsCntSameAsSignBit(valueIn); // 返回62

valueIn = 0x00F0000000000000LL;
valueOut = AscendC::CountBitsCntSameAsSignBit(valueIn); // 返回7