当前位置: 首页 > news >正文

CANN/asc-devkit SIMT bfloat16x2乘法函数

__hmulx2

【免费下载链接】asc-devkit本项目是CANN 推出的昇腾AI处理器专用的算子程序开发语言,原生支持C和C++标准规范,主要由类库和语言扩展层构成,提供多层级API,满足多维场景算子开发诉求。项目地址: https://gitcode.com/cann/asc-devkit

产品支持情况

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

功能说明

计算两个bfloat16x2_t类型数据各分量的相乘结果,并遵循CAST_RINT模式对结果进行舍入。

函数原型

bfloat16x2_t __hmulx2(const bfloat16x2_t x, const bfloat16x2_t y)

参数说明

表 1参数说明

参数名输入/输出描述
x输入源操作数。
y输入源操作数。

返回值说明

输入数据各分量相乘的结果。相乘的分量x和y满足:

  • 当输入和结果都不为nan时,x*y的符号为x和y符号的异或。
  • x为非0值,y为±inf时,返回值符号由x和y的符号异或决定,值为inf。
  • x为±0,y为±inf时,返回值为nan。
  • x为±0,y为有限值时,返回值符号由x和y的符号异或决定,值为0。
  • x,y任意一个为nan时,返回值为nan。

约束说明

需要包含的头文件

使用该接口需要包含"simt_api/asc_bf16.h"头文件。

#include "simt_api/asc_bf16.h"

调用示例

  • SIMT编程场景:

    // 使用短向量可提升数据搬运效率 __global__ __launch_bounds__(1024) void simt_hmulx2(bfloat16_t* x, bfloat16_t* y, bfloat16_t* dst, uint32_t input_total_length) { uint32_t idx = blockIdx.x * blockDim.x + threadIdx.x; // 每个线程处理1个bfloat16x2_t类型的数据,即2个bfloat16_t类型的数据,因此idx >= input_total_length / 2的线程不处理数据 if (idx >= input_total_length / 2) { return; } bfloat16x2_t* input1 = (bfloat16x2_t*)x; bfloat16x2_t* input2 = (bfloat16x2_t*)y; bfloat16x2_t* out = (bfloat16x2_t*)dst; out[idx] = __hmulx2(input1[idx], input2[idx]); }
  • SIMD与SIMT混合编程场景:

    // 使用短向量可提升数据搬运效率 __simt_vf__ __launch_bounds__(1024) inline void simt_hmulx2(__gm__ bfloat16x2_t* x, __gm__ bfloat16x2_t* y, __gm__ bfloat16x2_t* dst, uint32_t input_total_length) { uint32_t idx = blockIdx.x * blockDim.x + threadIdx.x; // 每个线程处理1个bfloat16x2_t类型的数据,即2个bfloat16_t类型的数据,因此idx >= input_total_length / 2的线程不处理数据 if (idx >= input_total_length / 2) { return; } dst[idx] = __hmulx2(x[idx], y[idx]); } __global__ __vector__ void compute_kernel(__gm__ bfloat16_t* x, __gm__ bfloat16_t* y, __gm__ bfloat16_t* dst, uint32_t input_total_length) { asc_vf_call<simt_hmulx2>(dim3(1024), (__gm__ bfloat16x2_t*)x, (__gm__ bfloat16x2_t*)y, (__gm__ bfloat16x2_t*)dst, input_total_length); }

【免费下载链接】asc-devkit本项目是CANN 推出的昇腾AI处理器专用的算子程序开发语言,原生支持C和C++标准规范,主要由类库和语言扩展层构成,提供多层级API,满足多维场景算子开发诉求。项目地址: https://gitcode.com/cann/asc-devkit

创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考

http://www.jsqmd.com/news/855727/

相关文章:

  • gh_mirrors/ex/expected性能优化:7个提升效率的关键技巧
  • mpv.net多语言指南:如何快速设置中文界面和10+语言支持
  • 离子交换柱生产厂家哪家靠谱?水喷式真空泵厂家推荐:丰亿环保领衔,2026年国内优质水喷式真空泵与离子交换柱生产厂家盘点 - 栗子测评
  • WZLBadge与Swift混编:在现代iOS项目中的完美应用指南
  • Augmentoolkit事实数据生成管道:打造精准问答AI的终极方法
  • applera1n:免费绕过iOS 15-16激活锁的终极指南
  • NeRF的“分治”艺术:拆解Mega-NeRF如何用几何聚类搞定超大场景建模
  • 混合搅拌机厂家哪家好?干法制粒机生产厂家哪家好?2026年国内靠谱厂家实力盘点与推荐:科洛伊机械领衔 - 栗子测评
  • 2026紧固件与地基构件行业发展现状:预埋钢板槽塑翼螺母灌注桩螺旋地桩厂家及晨翔紧固件产品矩阵优势分析 - 栗子测评
  • LeetCode 每日一题笔记 日期:2026.05.20 题目:2657. 找到前缀公共数组
  • CacheTool OPcache管理:如何优化PHP字节码缓存性能的终极指南
  • CausalImpact最佳实践:避免因果推断中的7个常见陷阱
  • Redis分布式锁进阶第八十一篇
  • CDCS项目医疗AI竞赛专题:肺部结节智能诊断与医药化学优化
  • 2026年热镀锌地脚双头U型不锈钢螺栓正规生产厂家货源与产品优势 - 栗子测评
  • 2026年知名的智能装备拖链电缆/工业机器人拖链电缆稳定供货厂家推荐 - 品牌宣传支持者
  • RobotStudio 6.08里找不到DeviceNet Device?手把手教你配置DSQC652信号板(附709-1选项详解)
  • DreamTalk与3DMM参数:如何提取和利用面部表情风格特征
  • parse库错误处理与异常管理:构建可靠的字符串解析应用
  • 程序员人生规划:平衡编程工作与生活的指南
  • 《Sysinternals实战指南》进程和诊断工具学习笔记(8.15):实战案例|内存狂涨 / 句柄泄漏怎么查?用 VMMap + Handle + ListDLLs 三步定位
  • 泉州html+css 5页
  • 3D混合先验技术驱动音频生成说话头:VividTalk的创新实践与生态价值
  • 深入解析PyTorch-FCN架构:FCN32s、FCN16s、FCN8s模型对比分析
  • ops-cv 图像预处理加速:YOLO 推理前的最后一公里
  • 老板出幻觉了!过度相信 AI,迟早要暴雷…
  • 《Sysinternals实战指南》进程和诊断工具学习笔记(8.16):LiveKd 入门——在线内核调试,不重启不蓝屏
  • 杭州学书法艺考去哪家?2026杭州书法艺考机构推荐:杭州书法统考通过率高的机构+杭州师资力量强的书法培训机构 - 栗子测评
  • LicenseFinder扩展开发指南:如何为新的包管理器添加支持
  • Tunasync调度器工作原理:智能任务分配与并发控制完全指南