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

CANN/ops-math 3D反射填充算子

aclnnReflectionPad3d【免费下载链接】ops-math本项目是CANN提供的数学类基础计算算子库实现网络在NPU上加速计算。项目地址: https://gitcode.com/cann/ops-math 查看源码产品支持情况产品是否支持Ascend 950PR/Ascend 950DT√Atlas A3 训练系列产品/Atlas A3 推理系列产品√Atlas A2 训练系列产品/Atlas A2 推理系列产品√Atlas 200I/500 A2 推理产品×Atlas 推理系列产品×Atlas 训练系列产品√功能说明接口功能3D反射填充。示例输入tensor([[[[[0,1], [2,3]], [[4,5], [6,7]]]]]) padding([1,1,1,1,1,1]) 输出为 ([[[[[7,6,7,6], [5,4,5,4], [7,6,7,6], [5,4,5,4]], [[3,2,3,2], [1,0,1,0], [3,2,3,2], [1,0,1,0]], [[7,6,7,6], [5,4,5,4], [7,6,7,6], [5,4,5,4]], [[3,2,3,2], [1,0,1,0], [3,2,3,2], [1,0,1,0]]]]])函数原型每个算子分为两段式接口必须先调用“aclnnReflectionPad3dGetWorkspaceSize”接口获取计算所需workspace大小以及包含了算子计算流程的执行器再调用“aclnnReflectionPad3d”接口执行计算。aclnnStatus aclnnReflectionPad3dGetWorkspaceSize( const aclTensor *self, const aclIntArray *padding, aclTensor *out, uint64_t *workspaceSize, aclOpExecutor **executor)aclnnStatus aclnnReflectionPad3d( void *workspace, uint64_t workspaceSize, aclOpExecutor *executor, aclrtStream stream)aclnnReflectionPad3dGetWorkspaceSize参数说明参数名输入/输出描述使用说明数据类型数据格式维度(shape)非连续TensorselfaclTensor*输入待填充的原输入数据。维度支持四维或五维在最后三维做pad。BOOL、INT8、UINT8、INT16、UINT16、FLOAT16、BFLOAT16、INT32、UINT32、FLOAT32、INT64、UINT64、DOUBLE、COMPLEX64、COMPLEX128、HIFLOAT8、FLOAT8_E5M2、FLOAT8_E4M3FN、FLOAT8_E8M0ND4-5√paddingaclIntArray*输入输入中需要填充的大小。长度为6数值依次代表左右上下前后需要填充的值。padding前两个数值需小于self最后一维度的数值中间两个数值需小于self倒数第二维度的数值后两个数值需小于self倒数第三维度的数值。INT64ND-√outaclTensor*输出填充后的输出结果。维度与self一致out倒数第三维度的数值等于self倒数第三维度的数值加padding后两个值out倒数第二维度的数值等于self倒数第二维度的数值加padding中间两个值out最后一维度的数值等于self最后一维度的数值加padding前两个值。BOOL、INT8、UINT8、INT16、UINT16、FLOAT16、BFLOAT16、INT32、UINT32、FLOAT32、INT64、UINT64、DOUBLE、COMPLEX64、COMPLEX128、HIFLOAT8、FLOAT8_E5M2、FLOAT8_E4M3FN、FLOAT8_E8M0ND4-5√workspaceSizeuint64_t*输出返回需要在Device侧申请的workspace大小。-----executoraclOpExecutor**输出返回op执行器包含了算子计算流程。-----Atlas A3 训练系列产品/Atlas A3 推理系列产品 、 Atlas A2 训练系列产品/Atlas A2 推理系列产品 数据类型不支持 UINT16、UINT32、UINT64、HIFLOAT8、FLOAT8_E5M2、FLOAT8_E4M3FN、FLOAT8_E8M0。Atlas 推理系列产品 、 Atlas 训练系列产品 数据类型不支持 BFLOAT16、UINT16、UINT32、UINT64、COMPLEX64、COMPLEX128、HIFLOAT8、FLOAT8_E5M2、FLOAT8_E4M3FN、FLOAT8_E8M0。返回值aclnnStatus返回状态码具体参见aclnn返回码。第一段接口完成入参校验出现以下场景时报错返回值错误码描述ACLNN_ERR_PARAM_NULLPTR161001Tensor为空指针。ACLNN_ERR_PARAM_INVALID161002self、padding和out的数据类型或数据格式不在支持的范围之内。self、padding和out的输入shape在支持范围之外。五维self为空tensor且存在非batch size维度的大小为0。四维self不支持为空tensor。padding的数值大于等于self对应维度的值。out后三维度的值不等于self后三维度的值加对应padding。out的shape与实际输出shape不匹配。aclnnReflectionPad3d参数说明参数名输入/输出描述workspace输入在Device侧申请的workspace内存地址。workspaceSize输入在Device侧申请的workspace大小由第一段接口aclnnReflectionPad3dGetWorkspaceSize获取。executor输入op执行器包含了算子计算流程。stream输入指定执行任务的Stream。返回值aclnnStatus返回状态码具体参见aclnn返回码。约束说明确定性计算aclnnReflectionPad3d默认确定性实现。如果计算量过大可能会导致算子执行超时aicore error类型报错errorStr为:timeout or trap error场景为最后2轴合轴小于16前面的轴合轴超大。五维self为空tensor且存在非batch size维度的大小为0。四维self不支持为空tensor。调用示例示例代码如下仅供参考具体编译和执行过程请参考编译与运行样例。#include acl/acl.h #include aclnnop/aclnn_reflection_pad3d.h #include iostream #include vector #define CHECK_RET(cond, return_expr) \ do { \ if (!(cond)) { \ return_expr; \ } \ } while (0) #define LOG_PRINT(message, ...) \ do { \ printf(message, ##__VA_ARGS__); \ } while (0) int64_t GetShapeSize(const std::vectorint64_t shape) { int64_t shape_size 1; for (auto i : shape) { shape_size * i; } return shape_size; } int Init(int32_t deviceId, aclrtStream* stream) { // 固定写法资源初始化 auto ret aclInit(nullptr); CHECK_RET(ret ACL_SUCCESS, LOG_PRINT(aclInit failed. ERROR: %d\n, ret); return ret); ret aclrtSetDevice(deviceId); CHECK_RET(ret ACL_SUCCESS, LOG_PRINT(aclrtSetDevice failed. ERROR: %d\n, ret); return ret); ret aclrtCreateStream(stream); CHECK_RET(ret ACL_SUCCESS, LOG_PRINT(aclrtCreateStream failed. ERROR: %d\n, ret); return ret); return 0; } template typename T int CreateAclTensor(const std::vectorT hostData, const std::vectorint64_t shape, void** deviceAddr, aclDataType dataType, aclTensor** tensor) { auto size GetShapeSize(shape) * sizeof(T); // 调用aclrtMalloc申请device侧内存 auto ret aclrtMalloc(deviceAddr, size, ACL_MEM_MALLOC_HUGE_FIRST); CHECK_RET(ret ACL_SUCCESS, LOG_PRINT(aclrtMalloc failed. ERROR: %d\n, ret); return ret); // 调用aclrtMemcpy将host侧数据拷贝到device侧内存上 ret aclrtMemcpy(*deviceAddr, size, hostData.data(), size, ACL_MEMCPY_HOST_TO_DEVICE); CHECK_RET(ret ACL_SUCCESS, LOG_PRINT(aclrtMemcpy failed. ERROR: %d\n, ret); return ret); // 计算连续tensor的strides std::vectorint64_t strides(shape.size(), 1); for (int64_t i shape.size() - 2; i 0; i--) { strides[i] shape[i 1] * strides[i 1]; } // 调用aclCreateTensor接口创建aclTensor *tensor aclCreateTensor(shape.data(), shape.size(), dataType, strides.data(), 0, aclFormat::ACL_FORMAT_ND, shape.data(), shape.size(), *deviceAddr); return 0; } int main() { // 1. 固定写法device/stream初始化, 参考acl API手册 // 根据自己的实际device填写deviceId int32_t deviceId 0; aclrtStream stream; auto ret Init(deviceId, stream); // check根据自己的需要处理 CHECK_RET(ret 0, LOG_PRINT(Init acl failed. ERROR: %d\n, ret); return ret); // 2. 构造输入与输出需要根据API的接口定义构造 std::vectorint64_t selfShape {1, 1, 2, 2, 2}; std::vectorint64_t outShape {1, 1, 4, 4, 4}; void* selfDeviceAddr nullptr; void* outDeviceAddr nullptr; aclTensor* self nullptr; aclIntArray* padding nullptr; aclTensor* out nullptr; std::vectorfloat selfHostData {0, 1, 2, 3, 4, 5, 6, 7}; std::vectorint64_t paddingData {1, 1, 1, 1, 1, 1}; std::vectorfloat outHostData(GetShapeSize(outShape), 0); // 创建self aclTensor ret CreateAclTensor(selfHostData, selfShape, selfDeviceAddr, aclDataType::ACL_FLOAT, self); CHECK_RET(ret ACL_SUCCESS, return ret); // 创建padding aclIntArray padding aclCreateIntArray(paddingData.data(), 6); CHECK_RET(padding ! nullptr, return ret); // 创建out aclTensor ret CreateAclTensor(outHostData, outShape, outDeviceAddr, aclDataType::ACL_FLOAT, out); CHECK_RET(ret ACL_SUCCESS, return ret); // 3. 调用CANN算子库API需要修改为具体的API uint64_t workspaceSize 0; aclOpExecutor* executor; // 调用aclnnReflectionPad3d第一段接口 ret aclnnReflectionPad3dGetWorkspaceSize(self, padding, out, workspaceSize, executor); CHECK_RET(ret ACL_SUCCESS, LOG_PRINT(aclnnReflectionPad3dGetWorkspaceSize failed. ERROR: %d\n, ret); return ret); // 根据第一段接口计算出的workspaceSize申请device内存 void* workspaceAddr nullptr; if (workspaceSize 0) { ret aclrtMalloc(workspaceAddr, workspaceSize, ACL_MEM_MALLOC_HUGE_FIRST); CHECK_RET(ret ACL_SUCCESS, LOG_PRINT(allocate workspace failed. ERROR: %d\n, ret); return ret;); } // 调用aclnnReflectionPad3d第二段接口 ret aclnnReflectionPad3d(workspaceAddr, workspaceSize, executor, stream); CHECK_RET(ret ACL_SUCCESS, LOG_PRINT(aclnnReflectionPad3d failed. ERROR: %d\n, ret); return ret); // 4. 固定写法同步等待任务执行结束 ret aclrtSynchronizeStream(stream); CHECK_RET(ret ACL_SUCCESS, LOG_PRINT(aclrtSynchronizeStream failed. ERROR: %d\n, ret); return ret); // 5. 获取输出的值将device侧内存上的结果拷贝至host侧需要根据具体API的接口定义修改 auto size GetShapeSize(outShape); std::vectorfloat resultData(size, 0); ret aclrtMemcpy(resultData.data(), resultData.size() * sizeof(resultData[0]), outDeviceAddr, size * sizeof(float), ACL_MEMCPY_DEVICE_TO_HOST); CHECK_RET(ret ACL_SUCCESS, LOG_PRINT(copy result from device to host failed. ERROR: %d\n, ret); return ret); for (int64_t i 0; i size; i) { LOG_PRINT(result[%ld] is: %f\n, i, resultData[i]); } // 6. 释放aclTensor和aclScalar需要根据具体API的接口定义修改 aclDestroyTensor(self); aclDestroyIntArray(padding); aclDestroyTensor(out); // 7. 释放device资源需要根据具体API的接口定义修改 aclrtFree(selfDeviceAddr); aclrtFree(outDeviceAddr); if (workspaceSize 0) { aclrtFree(workspaceAddr); } aclrtDestroyStream(stream); aclrtResetDevice(deviceId); aclFinalize(); return 0; }【免费下载链接】ops-math本项目是CANN提供的数学类基础计算算子库实现网络在NPU上加速计算。项目地址: https://gitcode.com/cann/ops-math创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考

相关文章:

CANN/ops-math 3D反射填充算子

aclnnReflectionPad3d 【免费下载链接】ops-math 本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。 项目地址: https://gitcode.com/cann/ops-math 📄 查看源码 产品支持情况 产品是否支持Ascend 950PR/Ascend 950DT√Atlas …...

CANN/runtime CMO缓存操作

11-06 CMO 缓存操作 【免费下载链接】runtime 本项目提供CANN运行时组件和维测功能组件。 项目地址: https://gitcode.com/cann/runtime 本章节描述 CMO(Cache Maintenance Operations)缓存操作接口,用于缓存刷新与失效操作。 aclErr…...

Context Harness:本地优先AI知识库引擎,无缝集成Cursor与Claude

1. 项目概述:一个为AI工具打造的本地优先知识库引擎如果你和我一样,日常重度依赖像Cursor、Claude Code这类AI编程助手,那你肯定也遇到过这个痛点:当你想让AI帮你分析一个复杂的私有代码库、查阅公司内部的API文档,或者…...

构建安全多语言代码沙盒:从原理到实践

1. 项目概述:从“Can I Code?”到“Can I Code!”“let-sunny/canicode”这个项目名,初看有点意思。它不像一个传统的工具库或框架,名字里带着一个问句的意味——“我能编码吗?”。这恰恰是很多初学者,甚至是在特定领…...

AI赋能宠物纪念册:Gemini3.1Pro的情感文案术

在 2026 年,AI 的应用场景已经从“写文案、做海报、生成代码”扩展到更细分、更情绪化也更需要边界感的领域。比如宠物殡葬、生命纪念、情感告别、个性化内容定制等场景,过去往往依赖人工经验和手工整理,现在则可以借助 Gemini 3.1 Pro 先完成…...

深度解析next-routes:Next.js早期动态路由解决方案的设计与实现

1. 项目概述:一个被时代铭记的Next.js路由解决方案如果你在2017年到2020年间使用Next.js开发过项目,那么你大概率听说过甚至用过next-routes这个库。在那个Next.js官方路由系统还相对“简陋”的年代,next-routes凭借其Express风格的动态路由定…...

AMCT KV Cache量化配置

KV Cache量化简易配置文件 【免费下载链接】amct AMCT是CANN提供的昇腾AI处理器亲和的模型压缩工具仓。 项目地址: https://gitcode.com/cann/amct quant_calibration_config_pytorch.proto文件参数说明如下表所示,该文件所在目录为:AMCT安装目录…...

网络安全技术岗怎么选,不止渗透...

网络安全技术岗怎么选,不止渗透… 你真知道网络安全有哪些技术岗吗?不是所有人都去打漏洞,也不是所有人都进红队。 把网络安全行业里常见的技术岗岗位分类职责技术要求面试考点薪资段位都梳理清楚了👇 学习资源 如果你也是零基础…...

CANN/metadef自定义逻辑流分配函数

CustomAllocateStreamPassFn 【免费下载链接】metadef Ascend Metadata Definition 项目地址: https://gitcode.com/cann/metadef AI处理器支持情况 AI处理器类型 是否支持 Ascend 910C√ Ascend 910B√ 功能说明 注册自定义的逻辑流分配Pass执行函数。 函数原型 P…...

CANN/AMCT大模型FlatQuant量化

AMCT大模型对于LLAMA2/Qwen3的FlatQuant量化 【免费下载链接】amct AMCT是CANN提供的昇腾AI处理器亲和的模型压缩工具仓。 项目地址: https://gitcode.com/cann/amct 1 量化前提 1.1 安装依赖 本sample依赖包可参考requirements.txt 需要注意的是torch_npu包版本需要…...

基于Kuramoto模型与CNN的脑电信号同步特征提取与分类方法

1. 项目概述与核心思路最近在做一个挺有意思的交叉项目,核心是把物理学里的Kuramoto模型和深度学习里的卷积神经网络(CNN)结合起来,去处理脑电信号。听起来有点绕,但说白了,就是想用更“物理”一点的方式&a…...

元宇宙边缘计算AI架构:从资源调度到个性化体验塑造

1. 项目概述:为什么元宇宙需要一种全新的边缘计算AI架构?如果你最近关注过科技新闻,大概率会被“元宇宙”这个词刷屏。它描绘了一个物理与虚拟世界深度融合的未来图景,人们通过扩展现实设备在其中工作、社交、娱乐。然而&#xff…...

从零构建高性能云原生抓取平台:架构、部署与实战指南

1. 项目概述:从零到一构建一个高性能云原生抓取平台最近在折腾一个很有意思的开源项目,叫openperf/openclaw-cloud。乍一看这个名字,可能有点摸不着头脑,但如果你拆解一下,就能发现它的野心不小。“OpenPerf”暗示了其…...

OpenClaw:基于零信任与深度防御的安全AI代理网关架构与实践

1. 项目概述与核心安全理念最近在折腾一个挺有意思的项目,叫 OpenClaw。简单来说,这是一个为 AI 智能体(AI Agent)设计的、带有 SSH 桥接功能的运行平台。它的核心设计理念非常激进,甚至可以说有点“偏执”&#xff1a…...

Spring Boot项目初始化模板:开箱即用的企业级开发脚手架

1. 项目概述与核心价值最近在社区里看到不少朋友在讨论如何快速启动一个Spring Boot项目,特别是对于刚接触这个框架或者需要频繁创建新项目的团队来说,每次从零开始搭建脚手架、配置依赖、设计包结构,都是一件既耗时又容易出错的事情。我自己…...

如何快速搭建高效本地图片搜索引擎:ImageSearch完整实战指南

如何快速搭建高效本地图片搜索引擎:ImageSearch完整实战指南 【免费下载链接】ImageSearch 基于.NET10的本地硬盘千万级图库以图搜图案例Demo和图片exif信息移除小工具分享 项目地址: https://gitcode.com/gh_mirrors/im/ImageSearch ImageSearch是一个基于.…...

基于SocialDAO与隐私计算构建性勒索预防援助系统

1. 项目概述与核心问题拆解最近几年,一个令人不安的词汇在数字世界的阴暗角落频繁出现——“性勒索”。它不再是电影里的情节,而是真实发生在普通人身上的数字噩梦。简单来说,性勒索就是利用受害者的私密影像或信息,以公开、传播为…...

AI驱动湍流研究新范式:扩散模型与Transformer在流体力学中的应用

1. 项目概述:当湍流研究遇上AI,一场范式转移正在发生如果你在流体力学、航空航天或者气象预报领域工作过,一定会对“湍流”这两个字又爱又恨。爱的是,它无处不在,从飞机机翼的绕流到大气环流,再到血管内的血…...

CANN/sip Nrm2向量范数算子

Nrm2 【免费下载链接】sip 本项目是CANN提供的一款高效、可靠的高性能信号处理算子加速库,基于华为Ascend AI处理器,专门为信号处理领域而设计。 项目地址: https://gitcode.com/cann/sip 产品支持情况 产品是否支持Atlas 200I/500 A2 推理产品A…...

AI智能体技能研究:如何高效利用Awesome-Skills-Paper构建个人知识库

1. 项目概述与核心价值最近在整理智能体(Agent)相关的学习资料时,发现了一个非常实用的开源项目——Awesome-Skills-Paper。这个项目本质上是一个经过精心整理的、关于“智能体技能”的学术论文清单。对于任何正在研究或学习AI智能体&#xf…...

CANN/hcomm梯度切分策略设置

set_split_strategy_by_size 【免费下载链接】hcomm HCOMM(Huawei Communication)是HCCL的通信基础库,提供通信域以及通信资源的管理能力。 项目地址: https://gitcode.com/cann/hcomm 产品支持情况 Ascend 950PR/Ascend 950DT&#…...

CANN Runtime CntNotify管理API

9. CntNotify管理 【免费下载链接】runtime 本项目提供CANN运行时组件和维测功能组件。 项目地址: https://gitcode.com/cann/runtime 本章节描述 CANN Runtime 的 CntNotify(计数型通知)管理接口,用于 CntNotify 的创建、记录、等待及…...

AI重塑高等教育:构建人机协同反馈系统与未来技能培养

1. 项目概述:当AI成为课堂的“第三位教师”最近和几位高校的朋友聊天,话题总绕不开一个词:AI。不是那种遥不可及的实验室技术,而是已经渗透到学生作业、论文、甚至课堂讨论里的生成式AI。一位教授朋友给我看了他学生的课程论文&am…...

终极视频PPT提取指南:3步将视频内容秒变PDF讲义

终极视频PPT提取指南:3步将视频内容秒变PDF讲义 【免费下载链接】extract-video-ppt extract the ppt in the video 项目地址: https://gitcode.com/gh_mirrors/ex/extract-video-ppt 还在为从冗长视频中手动截图PPT而烦恼吗?🤔 今天我…...

KEEBOX LIST™:开发者资源聚合清单的设计、使用与维护实践

1. 项目概述:一个为开发者打造的“工具箱”清单 如果你和我一样,在软件开发的日常里,经常需要为某个特定任务寻找合适的工具、库或者一份靠谱的教程,那你肯定也经历过那种在搜索引擎和无数个浏览器标签页之间反复横跳的“信息过载…...

利用AI与MCP协议高效开发与调试Adaptive Cards

1. 项目概述:用AI简化Adaptive Cards开发如果你在开发Microsoft Teams机器人、Outlook插件,或者在使用Copilot、Cursor这类AI编程助手时,需要快速生成或调试Adaptive Cards,那么手动编写和验证JSON绝对是个耗时又容易出错的活儿。…...

AI驱动分子逆合成:Transformer与扩散模型技术解析与实践

1. 项目概述:从“拆解”分子到“设计”合成在药物研发、新材料探索乃至精细化工领域,合成化学家们常常面临一个核心挑战:如何高效、经济地合成一个目标分子?这个过程,我们称之为“逆合成分析”。传统的逆合成分析高度依…...

对话式AI如何隐秘引导消费决策:行为心理学实验揭示四大机制

1. 项目概述:一次关于“引导”的深度实验最近几年,对话式AI(比如各种智能客服、语音助手、聊天机器人)已经渗透到我们线上消费的每一个环节。表面上看,它们只是在回答问题、处理订单,或者提供一些建议。但作…...

深度强化学习优化量子比特反馈控制:从DQN原理到实验部署

1. 项目概述与核心价值最近在实验室里折腾一个挺有意思的课题,就是怎么用强化学习去优化量子比特的测量和反馈控制。听起来有点跨界,对吧?量子计算和强化学习,一个在微观世界玩叠加和纠缠,一个在宏观世界搞决策和优化&…...

CANN/sip:AscendSiPBoost信号处理加速库

AscendSiPBoost 信号处理加速库 【免费下载链接】sip 本项目是CANN提供的一款高效、可靠的高性能信号处理算子加速库,基于华为Ascend AI处理器,专门为信号处理领域而设计。 项目地址: https://gitcode.com/cann/sip 🔥 [2025/10] Asce…...