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

CANN/asc-devkit向量最大值函数文档

asc_max

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

产品支持情况

产品是否支持
Atlas A3 训练系列产品/Atlas A3 推理系列产品
Atlas A2 训练系列产品/Atlas A2 推理系列产品

功能说明

执行逐元素取最大值运算,计算公式如下:

$$ dst_i = max(src0_i, src1_i) $$

函数原型

  • 前n个数据计算
__aicore__ inline void asc_max(__ubuf__ int16_t* dst, __ubuf__ int16_t* src0, __ubuf__ int16_t* src1, uint32_t count) __aicore__ inline void asc_max(__ubuf__ half* dst, __ubuf__ half* src0, __ubuf__ half* src1, uint32_t count) __aicore__ inline void asc_max(__ubuf__ int32_t* dst, __ubuf__ int32_t* src0, __ubuf__ int32_t* src1, uint32_t count) __aicore__ inline void asc_max(__ubuf__ float* dst, __ubuf__ float* src0, __ubuf__ float* src1, uint32_t count)
  • 高维切分计算
__aicore__ inline void asc_max(__ubuf__ int16_t* dst, __ubuf__ int16_t* src0, __ubuf__ int16_t* src1, uint8_t repeat, uint8_t dst_block_stride, uint8_t src0_block_stride, uint8_t src1_block_stride, uint8_t dst_repeat_stride, uint8_t src0_repeat_stride, uint8_t src1_repeat_stride) __aicore__ inline void asc_max(__ubuf__ half* dst, __ubuf__ half* src0, __ubuf__ half* src1, uint8_t repeat, uint8_t dst_block_stride, uint8_t src0_block_stride, uint8_t src1_block_stride, uint8_t dst_repeat_stride, uint8_t src0_repeat_stride, uint8_t src1_repeat_stride) __aicore__ inline void asc_max(__ubuf__ int32_t* dst, __ubuf__ int32_t* src0, __ubuf__ int32_t* src1, uint8_t repeat, uint8_t dst_block_stride, uint8_t src0_block_stride, uint8_t src1_block_stride, uint8_t dst_repeat_stride, uint8_t src0_repeat_stride, uint8_t src1_repeat_stride) __aicore__ inline void asc_max(__ubuf__ float* dst, __ubuf__ float* src0, __ubuf__ float* src1, uint8_t repeat, uint8_t dst_block_stride, uint8_t src0_block_stride, uint8_t src1_block_stride, uint8_t dst_repeat_stride, uint8_t src0_repeat_stride, uint8_t src1_repeat_stride)
  • 同步计算
__aicore__ inline void asc_max_sync(__ubuf__ int16_t* dst, __ubuf__ int16_t* src0, __ubuf__ int16_t* src1, uint32_t count) __aicore__ inline void asc_max_sync(__ubuf__ half* dst, __ubuf__ half* src0, __ubuf__ half* src1, uint32_t count) __aicore__ inline void asc_max_sync(__ubuf__ int32_t* dst, __ubuf__ int32_t* src0, __ubuf__ int32_t* src1, uint32_t count) __aicore__ inline void asc_max_sync(__ubuf__ float* dst, __ubuf__ float* src0, __ubuf__ float* src1, uint32_t count)

参数说明

参数名输入/输出描述
dst输出目的操作数(矢量)的起始地址。
src0、src1输入源操作数(矢量)的起始地址。
repeat输入迭代次数。
dst_block_stride输入目的操作数单次迭代内不同DataBlock间地址步长。
src0_block_stride输入源操作数0单次迭代内不同DataBlock间地址步长。
src1_block_stride输入源操作数1单次迭代内不同DataBlock间地址步长。
dst_repeat_stride输入目的操作数相邻迭代间相同DataBlock的地址步长。
src0_repeat_stride输入源操作数0相邻迭代间相同DataBlock的地址步长。
src1_repeat_stride输入源操作数1相邻迭代间相同DataBlock的地址步长。
count输入参与计算的元素个数。

返回值说明

流水类型

PIPE_V

约束说明

  • dst、src的起始地址需要32字节对齐
  • 操作数地址重叠约束请参考通用地址重叠约束。

调用示例

//total_length指参与计算的数据总长度 constexpr uint64_t total_length = 64; __ubuf__ half src0[total_length]; __ubuf__ half src1[total_length]; __ubuf__ half dst[total_length]; asc_max(dst, src0, src1, total_length);

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

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

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

相关文章:

  • 华为CANN HCOMM CCU LoopGroup
  • 2026苏州冰箱维修实测:不制冷、结霜、噪音大故障排查+价格参考 - 一步到家
  • Insomnia API客户端:2024年最全面的开源跨平台API测试工具终极指南 [特殊字符]
  • 如何快速上手Ghidra:面向新手的完整软件逆向工程框架指南
  • 通达信缠论插件完整指南:让复杂技术分析变得简单直观
  • 5分钟上手reveal.js-plugins:初学者必备的快速入门指南
  • 3步掌握Media Downloader:一站式媒体下载工具的终极解决方案
  • 公认的谢氏来源
  • Trip.js主题定制指南:5种内置主题与自定义方法
  • 幻兽帕鲁Mod整合包下载安装实用mod整合与功能指南
  • 深度探索Crawl4AI:实战异步网页爬取与智能内容提取指南
  • 2026南京GEO优化公司选型避坑指南:从“本地服务”到“全意图资产”的升维对决 - GEO优化
  • 2026昆明防水补漏维修团队实测盘点TOP4:昆明业主房屋渗漏修缮靠谱选择 - 宅安选房屋修缮
  • WebHaptics:为移动端网页添加触觉反馈的终极解决方案
  • GRU4Rec训练速度优化:如何在GPU上实现每秒1500个mini-batch
  • 巧用脚本守护:解决macOS iNode安全检查失败与自动断连的自动化方案
  • 宁波汽车音响改装新选择:宁波乾音汽车音响旗舰店,3大核心优势揭秘,宝马原厂音响升级/路虎音响改装,音响改装品牌哪家好 - 音响改装门店分享
  • 终极指南:ieBetter.js与Sizzle选择器引擎如何在IE6-IE8下实现现代CSS选择器
  • MC9S08SG32定时器/PWM引擎(TPMV3)深度解析与实战避坑指南
  • 深入解析UART:从波特率计算到寄存器配置与高级应用
  • 2026宁波机械设备GEO获客优化服务商体验实录 - 起跑123
  • 3步实现Minecraft极致光影:Iris与Sodium完美搭配指南
  • LiveScan3D研究背景:从学术论文到开源项目的演进历程
  • ComfyUI TTP Toolset:突破8K图像处理瓶颈的分块处理革命
  • CANN/asc-devkit SIMD矢量解包API
  • 告别jQuery!轻量级ieBetter.js让IE6-IE8支持querySelector和事件绑定
  • 美格信解读:从公式到听感,THD与THD+N的实战辨析
  • 图片压缩到200KB以内 手机小程序精确压缩方法 - 图片处理研究员
  • 从入门到精通:Catcher异常过滤器与参数排除高级用法终极指南
  • 2026郑州空调维修避坑:高温天气不制冷、漏水、异响故障诊断+维修平台对比 - 一步到家