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

CANN/asc-devkit AdjustSoftMaxRes API

AdjustSoftMaxRes【免费下载链接】asc-devkit本项目是CANN 推出的昇腾AI处理器专用的算子程序开发语言原生支持C和C标准规范主要由类库和语言扩展层构成提供多层级API满足多维场景算子开发诉求。项目地址: https://gitcode.com/cann/asc-devkit产品支持情况产品是否支持Ascend 950PR/Ascend 950DT√Atlas A3 训练系列产品 / Atlas A3 推理系列产品√Atlas A2 训练系列产品 / Atlas A2 推理系列产品√Kirin X90√Kirin 9030√功能说明本接口用于调整SoftMax的计算结果为指定的值。主要用于对SoftMax相关计算结果做后处理。当输入的max中存在指定的值的时候会调整对应的softmaxres中的结果为输入的自定义的值。以上调整方式为按行进行即当max某一行的值为某个值时调整当前softmaxres对应一行的值都为输入的值。为方便理解通过Python脚本实现的方式表达其计算公式如下其中res是输入也是输出max\from\to\res_shape都为输入。def adjust_softmax_res(res, max, from, to, res_shape): for i in res_shape[0]: if max[i] from: for j in res_shape[1]: res[i][j] to return函数原型template typename T1, typename T2, bool isDataFormatNZ false, uint8_t stepSizeMode 0 __aicore__ inline bool AdjustSoftMaxRes(const LocalTensorT1 softMaxRes, const LocalTensorT2 maxTensor, const uint32_t from, const T1 to, const SoftMaxShapeInfo softmaxShapeInfo)参数说明表 1模板参数说明参数名描述T1softMaxRes的数据类型。Ascend 950PR/Ascend 950DT支持的数据类型为half、float。Atlas A3 训练系列产品 / Atlas A3 推理系列产品支持的数据类型为half、float。Atlas A2 训练系列产品 / Atlas A2 推理系列产品支持的数据类型为half、float。Kirin X90支持的数据类型为half、float。Kirin 9030支持的数据类型为half、float。T2maxTensor的数据类型。Ascend 950PR/Ascend 950DT支持的数据类型为half、float。Atlas A3 训练系列产品 / Atlas A3 推理系列产品支持的数据类型为half、float。Atlas A2 训练系列产品 / Atlas A2 推理系列产品支持的数据类型为half、float。Kirin X90支持的数据类型为half、float。Kirin 9030支持的数据类型为half、float。isDataFormatNZ当前输入输出的数据格式是否为NZ格式默认数据格式为ND即默认取值为false。stepSizeModemaxTensor取元素的步进长度的模式。参数取值如下0默认值每个BlockSize32字节内取第一个元素的数值与输入from的数值作对比。即maxTensor的数据类型为float时按照输入shape为(m, 8)的格式每8个数取一个数maxTensor的数据类型为half时按照输入shape为(m, 16)的格式每16个数取一个数。非0取maxTensor每个元素的数值与输入from的数值作对比。即按照输入shape为(m, 1)的格式每次取一个元素的数值与输入from的数值作对比。该参数取值非0时仅支持maxTensor为ND格式。表 2接口参数说明参数名输入/输出描述softMaxRes输入/输出既是源操作数也是目的操作数。类型为LocalTensor支持的TPosition为VECIN/VECCALC/VECOUT。LocalTensor数据结构的定义请参考LocalTensorlast轴长度需要32Byte对齐。一般为softmax计算的输出结果。maxTensor输入源操作数。类型为LocalTensor支持的TPosition为VECIN/VECCALC/VECOUT。softmax计算过程中reducemax的结果。maxTensor的last轴长度固定为32Byte即一个datablock长度。该datablock中的所有数据为同一个值。比如half数据类型下该datablock中的16个数均为相同的reducemax的值。非last轴的长度与softMaxRes保持一致。from输入源操作数类型为uint32_t。需要判断的maxTensor中的值。需要注意的是由于maxTensor中的值均为浮点数类型因此此处需要填入的值为浮点数类型对应十六进制的值。比如当需要判断maxTensor是否有1.0这个值时from值需要填入1.0对应的十六进制值0x3f800000。to输入源操作数类型和softMaxRes的数据类型保持一致。需要往softMaxRes中填充的值。softmaxShapeInfo输入softMaxRes的shape信息结构定义如下struct SoftMaxShapeInfo { uint32_t srcM; // 非尾轴乘积长度 uint32_t srcK; // 尾轴长度必须32Byte对齐 uint32_t oriSrcM; // 原始非尾轴乘积长度 uint32_t oriSrcK; // 原始尾轴长度 };需要注意目前仅支持ND输入。返回值说明bool类型当返回true时表示maxTensor中存在需要判断的值若返回false则表示maxTensor中不存在需要判断的值。约束说明操作数地址对齐要求请参见通用地址对齐约束。当参数softmaxShapeInfo中srcM ! oriSrcM 或者 srcK ! oriSrcK时开发者需要对GM上的原始输入(oriSrcM, oriSrcK)在M或K方向补齐数据到(srcM, srcK)补齐的数据会参与部分运算在输入输出复用的场景下API的计算结果会覆盖srcTensor中补齐的原始数据在输入输出不复用的场景下API的计算结果会覆盖dstTensor中对应srcTensor补齐位置的数据。调用示例本样例中需要对SoftMax计算结果做后处理判断maxTensor中是否存在0xFF7FFFFF如果存在刷新对应结果为0。本样例中实现的是固定shape为输入x[32, 32]输出y[32, 32]的AdjustSoftMaxResCustom算子。输入softMaxRes的shape大小为[32,32]maxTensor的shape大小为[32,8]数据类型均为float。AscendC::LocalTensorfloat srcLocal inQueueSrc.DeQuefloat(); AscendC::LocalTensorfloat maxLocal inQueueMax.DeQuefloat(); AscendC::LocalTensorfloat dstLocal outQueueDst.AllocTensorfloat(); AscendC::LocalTensorfloat tmpTensor calcBuf.Getfloat(); AscendC::SoftMaxShapeInfo srcShape {height, width, height, width}; AscendC::AdjustSoftMaxResfloat, float(srcLocal, maxLocal, FROM, TO, srcShape); AscendC::DataCopy(tmpTensor, srcLocal, height * width); AscendC::DataCopy(dstLocal, tmpTensor, height * width);【免费下载链接】asc-devkit本项目是CANN 推出的昇腾AI处理器专用的算子程序开发语言原生支持C和C标准规范主要由类库和语言扩展层构成提供多层级API满足多维场景算子开发诉求。项目地址: https://gitcode.com/cann/asc-devkit创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考

相关文章:

CANN/asc-devkit AdjustSoftMaxRes API

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

通过Taotoken CLI工具一键配置多开发环境的大模型接入信息

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 通过Taotoken CLI工具一键配置多开发环境的大模型接入信息 在接入多个大模型服务时,开发者常常需要为不同的开发工具&a…...

5分钟解锁QQ音乐加密格式:qmc-decoder终极指南

5分钟解锁QQ音乐加密格式:qmc-decoder终极指南 【免费下载链接】qmc-decoder Fastest & best convert qmc 2 mp3 | flac tools 项目地址: https://gitcode.com/gh_mirrors/qm/qmc-decoder 你是否曾经在QQ音乐下载了心爱的歌曲,却发现它们被加…...

LFM2.5-VL-1.6B赋能运维:自动化生成服务器监控图表分析报告

LFM2.5-VL-1.6B赋能运维:自动化生成服务器监控图表分析报告 1. 运维人员的日常痛点 每天早上打开电脑,第一件事就是查看服务器监控数据,这可能是很多运维工程师的日常。面对Grafana上密密麻麻的CPU、内存、网络流量曲线,需要花大…...

如何免费解锁原神60帧限制?2025完整教程与安全指南

如何免费解锁原神60帧限制?2025完整教程与安全指南 【免费下载链接】genshin-fps-unlock unlocks the 60 fps cap 项目地址: https://gitcode.com/gh_mirrors/ge/genshin-fps-unlock 想让你的《原神》游戏体验更上一层楼吗?你是否厌倦了默认的60帧…...

从零构建自主可控AI智能体:NanoFleet Agent部署与实战指南

1. 项目概述:构建一个自主可控的AI智能体运行时 如果你和我一样,对当前市面上那些要么绑定特定云服务、要么功能封闭的AI Agent框架感到厌倦,那么NanoFleet Agent的出现,就像在满是套件的工具箱里发现了一把瑞士军刀。它不是一个…...

Qwen3.5-9B-GGUF惊艳效果展示:通义千问3.5量化版长文本生成作品集

Qwen3.5-9B-GGUF惊艳效果展示:通义千问3.5量化版长文本生成作品集 1. 模型介绍与核心能力 1.1 技术背景 Qwen3.5-9B-GGUF是阿里云开源的Qwen3.5-9B模型的量化版本,采用GGUF格式进行优化。这个90亿参数的稠密模型基于创新的Gated Delta Networks架构&a…...

ZAP+GPT:智能安全测试自动化,让漏洞报告秒变修复指南

1. 项目概述:当ZAP遇上GPT,自动化安全测试的智能进化 在应用安全测试领域,Zed Attack Proxy(ZAP)早已是渗透测试人员和开发者的老朋友。作为一个开源的、功能强大的Web应用安全扫描器,ZAP能通过主动和被动…...

lvgl_v8之arc代码示例

{lv_obj_clean(lv_scr_act());lv_obj_t* arc = lv_arc_create(lv_scr_act());...

终极Sunshine游戏串流服务器搭建指南:10分钟实现跨设备游戏串流

终极Sunshine游戏串流服务器搭建指南:10分钟实现跨设备游戏串流 【免费下载链接】Sunshine Self-hosted game stream host for Moonlight. 项目地址: https://gitcode.com/GitHub_Trending/su/Sunshine Sunshine是一款开源的自托管游戏串流服务器&#xff0c…...

Qianfan-OCR效果展示:看AI如何精准识别复杂表格与多栏文档,结果超乎想象

Qianfan-OCR效果展示:看AI如何精准识别复杂表格与多栏文档,结果超乎想象 1. 引言:当传统OCR遇到现代文档的挑战 在日常工作中,我们经常需要处理各种文档——从简单的合同到复杂的财务报表,从整齐的发票到混乱的网页截…...

基于AWS Serverless构建企业级OpenAI代理网关:安全、可控、低成本集成AI服务

1. 项目概述与核心价值最近在折腾一个很有意思的项目,叫aws-openai,来自 GitHub 上的FullStackWithLawrence仓库。乍一看名字,你可能会觉得这又是一个简单的“把 OpenAI API 套个 AWS 壳”的玩具。但实际深入进去,你会发现它的设计…...

IC Compiler布图规划保姆级教程:从TDF文件到电源环,新手避坑指南

IC Compiler布图规划实战手册:从TDF解析到电源环构建的21个关键操作节点 刚拿到综合后网表的芯片设计新手,面对布图规划这个"后端设计第一关"时,往往会在TDF文件解析、电源环连接等环节遭遇各种"暗坑"。本文将以真实项目…...

CANN/HCOMM AI CPU通信算子编译部署

编译部署 【免费下载链接】hcomm HCOMM(Huawei Communication)是HCCL的通信基础库,提供通信域以及通信资源的管理能力。 项目地址: https://gitcode.com/cann/hcomm 开发者完成通信算子开发之后,需部署到运行环境上进行功能…...

体验 Taotoken 官方价折扣活动对个人项目开发成本的影响

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 体验 Taotoken 官方价折扣活动对个人项目开发成本的影响 对于个人开发者和小型团队而言,大模型 API 的调用成本是项目开…...

CANN/cann-samples关键特性详解

Features 【免费下载链接】cann-samples 算子领域高性能实战演进样例与体系化调优知识库 项目地址: https://gitcode.com/cann/cann-samples 关键特性,解耦大模型核心算子底层能力。 访存优化方法 full_load:演示在 MTE2 带宽受限的场景下&…...

KoalaClient:开源AI对话客户端部署与高效工作流集成指南

1. 项目概述:为什么我们需要一个更好的AI对话客户端 如果你和我一样,每天的工作流里已经离不开像ChatGPT、Claude这类大语言模型,那你肯定对官方网页版或者一些通用客户端的体验深有感触。官方界面功能单一,切换模型麻烦&#xf…...

cann-bench稀疏注意力算子API

SparseFlashAttention 算子 API 描述 【免费下载链接】cann-bench 评测AI在处理CANN领域代码任务的能力,涵盖算子生成、算子优化等领域,支撑模型选型、训练效果评估,统一量化评估标准,识别Agent能力短板,构建CANN领域评…...

社交媒体图像生成评估:ECHO框架解析与应用

1. 项目背景与核心价值社交媒体平台每天产生数以亿计的图像数据,这些用户生成内容(UGC)蕴含着丰富的视觉表达模式和创意元素。传统图像生成基准数据集往往基于静态、人工标注的图片库,难以反映真实场景中动态变化的视觉趋势。ECHO框架的提出,…...

AI如何成为创意催化剂:从技术工具到内省伙伴的实践指南

1. 项目概述:当画笔遇见算法作为一名在数字艺术与创意科技交叉领域摸索了十多年的创作者,我亲历了从传统手绘板到生成式AI的整个技术浪潮。最初,我和许多同行一样,对“AI艺术”抱有复杂的情绪——它究竟是解放创造力的神兵利器&am…...

AI结构性风险:超越事故与滥用,解码技术与社会系统的复杂互动

1. 项目概述:当AI不再是“工具”我们谈论AI风险时,脑子里最先蹦出来的,往往是那些极具戏剧性的画面:自动驾驶汽车失控撞向人群,或是某个心怀叵测的黑客利用AI生成病毒,发动大规模网络攻击。这类风险&#x…...

MongoDB索引优化实战:让查询飞起来

写在前面:索引是数据库查询性能的关键,MongoDB提供了丰富的索引类型来满足不同场景的需求。本篇将详细介绍MongoDB索引的创建、使用、管理和优化技巧,帮助您打造高效的MongoDB查询。 文章目录一、索引基础概念1.1 什么是索引?1.2 …...

CANN Qwen Dense推理优化

基于Atlas A2/A3的Qwen Dense模型推理性能优化实践 【免费下载链接】cann-recipes-infer 本项目针对LLM与多模态模型推理业务中的典型模型、加速算法,提供基于CANN平台的优化样例 项目地址: https://gitcode.com/cann/cann-recipes-infer 概述 本文主要介绍…...

ExGRPO框架:强化学习中的动态经验重放优化

1. ExGRPO框架解析:平衡探索与经验重放的强化学习新范式在强化学习领域,样本效率一直是制约算法性能的关键瓶颈。特别是在大语言模型(LLM)的强化学习微调(RLHF)场景中,每个样本的获取成本可能高…...

在Taotoken控制台中管理API密钥并设置访问控制策略

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 在Taotoken控制台中管理API密钥并设置访问控制策略 对于团队管理员或项目负责人而言,统一、安全地管理大模型API访问权…...

FFmpeg视频批量裁剪:从原理到Python自动化实现

1. 项目概述与核心价值最近在整理一批视频素材时,遇到了一个挺典型的场景:我需要把一段16:9的横屏视频,快速裁剪成9:16的竖屏版本,用于短视频平台发布。手动用桌面软件打开、设置裁剪区域、导出,一两个视频还行&#x…...

CANN/opbase快速入门指南

快速入门 【免费下载链接】opbase 本项目是CANN算子库的基础框架库,为算子提供公共依赖文件和基础调度能力。 项目地址: https://gitcode.com/cann/opbase 快速体验项目前,请参考本项目README完成环境准备和源码下载,此处不再赘述。 …...

通过Taotoken CLI工具一键配置团队开发环境中的大模型接入点

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 通过Taotoken CLI工具一键配置团队开发环境中的大模型接入点 当团队开始将大模型能力集成到开发流程中时,一个常见的挑…...

R语言决策树非线性回归建模与优化实战

1. 决策树在R语言中的非线性回归实战作为一名长期使用R语言进行数据建模的分析师,我发现在处理复杂非线性关系时,决策树往往能提供传统线性方法无法比拟的灵活性。今天就来分享如何用R中的决策树算法实现非线性回归任务,以及我在实际项目中积…...

XUnity.AutoTranslator终极教程:如何为Unity游戏实现实时自动翻译

XUnity.AutoTranslator终极教程:如何为Unity游戏实现实时自动翻译 【免费下载链接】XUnity.AutoTranslator 项目地址: https://gitcode.com/gh_mirrors/xu/XUnity.AutoTranslator 你是否曾经因为语言障碍而无法畅玩心爱的日系RPG或欧美独立游戏?…...