news 2026/5/21 4:17:05

昇腾C SIMT复数乘加函数

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
昇腾C SIMT复数乘加函数

__hcmadd

【免费下载链接】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输入视为复数,第一个分量为实部,第二个分量为虚部,执行复数乘加运算x*y+z。

函数原型

bfloat16x2_t __hcmadd(const bfloat16x2_t x, const bfloat16x2_t y, const bfloat16x2_t z)

参数说明

表 1参数说明

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

返回值说明

输入数据视为复数,执行复数乘加运算的结果。对于输入a、b、c:

  • 实部的结果为:__hfma(-a.y, b.y, __hfma(a.x, b.x, c.x))。
  • 虚部的结果为:__hfma( a.y, b.x, __hfma(a.x, b.y, c.y))。

约束说明

需要包含的头文件

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

#include "simt_api/asc_bf16.h"

调用示例

  • SIMT编程场景:

    // 使用短向量可提升数据搬运效率 __global__ __launch_bounds__(1024) void simt_hcmadd(bfloat16_t* x, bfloat16_t* y, bfloat16_t* z, 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* input3 = (bfloat16x2_t*)z; bfloat16x2_t* out = (bfloat16x2_t*)dst; out[idx] = __hcmadd(input1[idx], input2[idx], input3[idx]); }
  • SIMD与SIMT混合编程场景:

    // 使用短向量可提升数据搬运效率 __simt_vf__ __launch_bounds__(1024) inline void simt_hcmadd(__gm__ bfloat16x2_t* x, __gm__ bfloat16x2_t* y, __gm__ bfloat16x2_t* z, __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] = __hcmadd(x[idx], y[idx], z[idx]); } __global__ __vector__ void compute_kernel(__gm__ bfloat16_t* x, __gm__ bfloat16_t* y, __gm__ bfloat16_t* z, __gm__ bfloat16_t* dst, uint32_t input_total_length) { asc_vf_call<simt_hcmadd>(dim3(1024), (__gm__ bfloat16x2_t*)x, (__gm__ bfloat16x2_t*)y, (__gm__ bfloat16x2_t*)z, (__gm__ bfloat16x2_t*)dst, input_total_length); }

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

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

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/21 4:16:04

CacheTool配置指南:如何通过YAML文件简化操作流程

CacheTool配置指南&#xff1a;如何通过YAML文件简化操作流程 【免费下载链接】cachetool CLI App and library to manage apc & opcache. 项目地址: https://gitcode.com/gh_mirrors/ca/cachetool CacheTool是一款强大的PHP缓存管理工具&#xff0c;能够通过命令行…

作者头像 李华
网站建设 2026/5/21 4:15:18

UI.Vision RPA的AI视觉功能:革命性的图像识别自动化方案

UI.Vision RPA的AI视觉功能&#xff1a;革命性的图像识别自动化方案 【免费下载链接】RPA Ui.Vision Open-Source RPA Software with Computer Vision, OCR, Anthropic Computer Use/LLM. Selenium IDE import/export. 项目地址: https://gitcode.com/gh_mirrors/rp/RPA …

作者头像 李华
网站建设 2026/5/21 4:09:25

HTML会代替Markdown吗?为什么?

不会替代&#xff0c;举个很简单的例子&#xff0c;Claude发布SKILL功能&#xff0c;用的标准文档格式是Markdown&#xff0c;而非HTML&#xff0c;原因在于SKILL既要方便广大用户编写&#xff0c;又要方便大模型读取。 skill-name/ # 目录名name字段&#xff…

作者头像 李华
网站建设 2026/5/21 4:08:11

Kiba ETL入门指南:如何在10分钟内构建你的第一个数据管道

Kiba ETL入门指南&#xff1a;如何在10分钟内构建你的第一个数据管道 【免费下载链接】kiba Data processing & ETL framework for Ruby 项目地址: https://gitcode.com/gh_mirrors/ki/kiba Kiba是一款专为Ruby开发者设计的轻量级数据处理与ETL框架&#xff0c;它提…

作者头像 李华
网站建设 2026/5/21 4:05:14

smassh核心组件剖析:Tracker、StatsTracker和Generator的实现原理

smassh核心组件剖析&#xff1a;Tracker、StatsTracker和Generator的实现原理 【免费下载链接】termtyper Smassh your Keyboard, TUI Edition 项目地址: https://gitcode.com/gh_mirrors/te/termtyper smassh是一款基于终端的打字练习工具&#xff08;TUI Edition&…

作者头像 李华
网站建设 2026/5/21 4:04:13

swagger-jsdoc 事件驱动架构:AsyncAPI 配置与使用

swagger-jsdoc 事件驱动架构&#xff1a;AsyncAPI 配置与使用 【免费下载链接】swagger-jsdoc Generates swagger/openapi specification based on jsDoc comments and YAML files. 项目地址: https://gitcode.com/gh_mirrors/sw/swagger-jsdoc swagger-jsdoc 是一款强大…

作者头像 李华