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

CANN向量步幅切片约束

Vec Stride and Slicing Constraints【免费下载链接】cannbot-skillsCANNBot 是面向 CANN 开发的用于提升开发效率的系列智能体本仓库为其提供可复用的 Skills 模块。项目地址: https://gitcode.com/cann/cannbot-skillsRead this file when a vec operation needs to access part of a wider buffer, or when a narrow source (e.g. row-max buffer) must align with a wide destination row by row.GoalDecide correctly when a vec operation can run continuously over a full buffer versus when it requires sliced views or explicit stride configuration.1. The alignment problemVec operations inferrepeatfrom the destination tensor and strides from each tensorsspan/shape. When a wide buffer (e.g.[M, 128]) is paired with a narrow buffer (e.g.[M, 8]), the repeat counts may not align row-by-row.For float (C08):[M, 128]→span1128does not match8*C064orC08→ default strides (blk1, rep8)Each row takes2 repeats(128 / 64 2)[M, 8]→span18 C0→blk0, rep1Each row takes1 repeatfrom the narrow bufferIfsub(wide[M,128], wide[M,128], narrow[M,8])is called directly:repeat M * 128 / 64 2M(from dst)narrow advances 1 per repeat → after repeat 0 (row 0 first half), narrow moves to row 1row 0s second half gets row 1s value→ misaligned!2. Fix: slice the wide buffer to 64-column viewsSlicing to[M, 64]creates a view wherespan164 8*C0:blk1, repshape[1]//C0(e.g.128//816for a 128-wide parent)Each row takes1 repeat→ aligns with the narrow buffersrep1# Correct: sliced views ensure 1 repeat per row sub(ub[0:M, 0:64], ub[0:M, 0:64], max_buf) # first half sub(ub[0:M, 64:128], ub[0:M, 64:128], max_buf) # second halfThe slice syntax creates a Tensor view with updatedspanandoffsetwhile keeping the originalshape. The stride auto-inference usesspanfor stride selection andshapeforrep_stridecalculation, which correctly skips the full row width between repeats.3. When slicing is NOT neededPurely element-wise operations (no narrow source) can run continuously over the full buffer:OperationNeeds slicing?Reasonmuls(wide, wide, scalar)NoScalar broadcasts uniformlyexp(wide, wide)NoSame-shape in-place, no alignment issuecast(half_out, float_in)NoSame-shape element-wise conversionsub(wide, wide, narrow)YesNarrow source advances 1 row/repeatvmax(dst64, wide_half1, wide_half2)YesNeed column views of a wider bufferbrcb(wide, narrow)Explicit stridesSee brcb sectionRule: if all source and destination tensors have the samespanand are operated element-wise, no slicing is needed. If any operand has a different width (narrower), slice the wider operands to match the narrow operands per-row repeat cadence.4. Stride auto-inference rulesFromvecutils.infer_strides(tensor)for float (C08):span[1]Matchesblk_striderep_stride64( 8×C0)Yes1shape[1] // C08( C0)Yes0shape[1] // C0otherNo1 (default)8 (default)For half (C016):span[1]Matchesblk_striderep_stride128( 8×C0)Yes1shape[1] // C016( C0)Yes0shape[1] // C0otherNo1 (default)8 (default)Whenspan[0] 1and a match occurred,rep_strideis overridden to0.infer_repeat(tensor)always uses:span[0] * span[1] / (256 // dtype.size)5. Column slicing via Tensor viewsDSL tensor slicing (tensor[row_start:row_end, col_start:col_end]) creates a view with:offsetadjusted to the slice startspanset to the slice extentshapeinherited from the parent (full allocation width)This meansrep_stride shape[1] // C0correctly accounts for the full row width, whilerepeat span[0] * span[1] // (256 // dtype_size)only covers the sliced region.Example forub_data[0:64, 64:128]whereub_dataisTensor(float, [64, 128]):span [64, 64],shape [64, 128],offset [0, 64]blk1, rep128//816(skips full 128-wide row)repeat 64*64/64 64(one repeat per row)Files to studyeasyasc/stub_functions/vec/vecutils.py— stride inference logiceasyasc/utils/Tensor.py— slice/view creationagent/example/kernels/a2/flash_attn_score.py— practical use of sliced sub continuous exp/cast【免费下载链接】cannbot-skillsCANNBot 是面向 CANN 开发的用于提升开发效率的系列智能体本仓库为其提供可复用的 Skills 模块。项目地址: https://gitcode.com/cann/cannbot-skills创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考

相关文章:

CANN向量步幅切片约束

Vec Stride and Slicing Constraints 【免费下载链接】cannbot-skills CANNBot 是面向 CANN 开发的用于提升开发效率的系列智能体,本仓库为其提供可复用的 Skills 模块。 项目地址: https://gitcode.com/cann/cannbot-skills Read this file when a vec oper…...

范式革新:时序媒体智能解析引擎与结构化知识蒸馏技术

范式革新:时序媒体智能解析引擎与结构化知识蒸馏技术 【免费下载链接】extract-video-ppt extract the ppt in the video 项目地址: https://gitcode.com/gh_mirrors/ex/extract-video-ppt 在数字内容爆炸式增长的今天,视频已成为知识传递的主要载…...

生成式AI应用场景深度拆解(2026奇点大会闭门报告首次公开)

更多请点击: https://intelliparadigm.com 第一章:生成式AI应用场景:2026奇点智能大会 2026奇点智能大会首次设立“生成式AI产业落地全景沙盘”,聚焦大模型从实验室走向千行百业的关键跃迁。大会现场部署了12个实时交互式AI应用展…...

CANN/hccl:自定义通信算子 - 点对点通信

自定义通信算子 - 点对点通信 【免费下载链接】hccl 集合通信库(Huawei Collective Communication Library,简称HCCL)是基于昇腾AI处理器的高性能集合通信库,为计算集群提供高性能、高可靠的通信方案 项目地址: https://gitcode…...

深度剖析Go语言,一文告诉你为什么大厂开始增加Go的招聘量

最近这两年大厂青睐Go,不是因为Go比Java"更好",而是因为Go比Java"更适合云原生时代"。我在G7汇通天下做后端架构时,亲历了从Java全面转向Go的过程。今天用一篇文章,说清Go语言的核心竞争力,以及你…...

利用 Taotoken 模型广场为学术研究项目筛选性价比最高的模型

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 利用 Taotoken 模型广场为学术研究项目筛选性价比最高的模型 为学术研究项目选择合适的大语言模型,常常需要在模型能力…...

ARM SIMD浮点与定点转换指令VCVT详解

1. ARM SIMD浮点与定点转换指令概述在ARM架构的SIMD(单指令多数据)指令集中,VCVT系列指令承担着浮点数与定点数之间相互转换的关键任务。这类指令通过单条指令同时处理多个数据元素,实现了数值格式转换的并行化处理。作为ARM NEON技术的重要组成部分&…...

嵌入式ROM代码启动机制与优化实践

1. 嵌入式ROM代码启动机制解析在嵌入式系统开发领域,ROM代码是处理器上电后最先执行的固件,它如同系统的"基因代码"决定了硬件初始化的基本行为。以TI OMAP系列处理器为例,其ROM代码存储在芯片内部掩膜ROM中,主要完成三…...

集成电路PVT角点分析的零调优智能方法

1. 多元角点分析的技术挑战与突破在集成电路设计领域,工艺-电压-温度(PVT)角点分析是确保芯片可靠性的关键环节。随着工艺节点不断缩小,晶体管级变异效应日益显著,传统的单角点验证方法已无法满足现代芯片设计的严苛要…...

cann-bench TopK算子API描述

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

三步解锁QQ音乐加密文件:qmc-decoder让你的音乐真正自由播放

三步解锁QQ音乐加密文件:qmc-decoder让你的音乐真正自由播放 【免费下载链接】qmc-decoder Fastest & best convert qmc 2 mp3 | flac tools 项目地址: https://gitcode.com/gh_mirrors/qm/qmc-decoder 你是否曾经在QQ音乐下载了心爱的歌曲,却…...

CANN/catccos计算通信融合算子模板库

CATCCOS 【免费下载链接】catccos CATCCOS昇腾计算-通信融合算子模板库,是一个聚焦于提供高性能计算通信融合类算子基础模板的代码库。 项目地址: https://gitcode.com/cann/catccos 📌 简介 CATCCOS(CANN Templates for Compute-Communication …...

CANN设备运行时事实

Device and Runtime Facts 【免费下载链接】cannbot-skills CANNBot 是面向 CANN 开发的用于提升开发效率的系列智能体,本仓库为其提供可复用的 Skills 模块。 项目地址: https://gitcode.com/cann/cannbot-skills Use this file for device caps, pipe mapp…...

RAP中的派生变量%说明

1. %msg是 BDEF 派生类型(Derived Types)的一个组件。它被用作 REPORTED 响应参数的一个组成部分。%msg 提供了一个消息接口 IF_ABAP_BEHV_MESSAGE 的实例。如果不需要对该接口进行自定义实现,可以使用继承而来的 new_message( ) 或 new_mess…...

CANN/tensorflow AOE调优配置

AOE 【免费下载链接】tensorflow Ascend TensorFlow Adapter 项目地址: https://gitcode.com/cann/tensorflow [!NOTE]说明 AOE调优特性仅支持如下产品的训练场景: Atlas A3 训练系列产品/Atlas A3 推理系列产品Atlas A2 训练系列产品/Atlas A2 推理系列产品A…...

长期使用Taotoken服务在API延迟与稳定性方面的实际感受分享

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 长期使用Taotoken服务在API延迟与稳定性方面的实际感受分享 在持续数月的项目开发中,我们团队将多个AI应用的后端服务统…...

企业内如何通过Taotoken实现AI模型调用的统一审计与风控

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 企业内如何通过Taotoken实现AI模型调用的统一审计与风控 对于有合规与安全要求的企业而言,直接让各部门或应用分别对接…...

我给 MariaDB 装了个“副驾驶”:DBLens for MariaDB

有时候我觉得,数据库不是难用,是太会藏东西了。 你问它:“订单状态在哪?” 它沉默。 你问:“这个字段谁在用?” 它继续沉默。 你打开表列表,看着一串似曾相识但又不敢乱点的名字,心里…...

马斯克投1200亿建芯片工厂,微美全息加速量子算力集群进入全球“AI军备竞赛”

据报道,埃隆马斯克的太空探索技术公司准备斥资1200亿美元建造一家人工智能(AI)芯片工厂,这将是世界上最大的人工智能芯片工厂。AI芯片工厂重构算力马斯克在社交媒体平台X上写道:“这是为建设全球最大、最先进芯片制造设…...

CANN/runtime算子信息订阅API

# 19-03 订阅算子信息 【免费下载链接】runtime 本项目提供CANN运行时组件和维测功能组件。 项目地址: https://gitcode.com/cann/runtime 本章节描述算子信息订阅接口,用于订阅模型中算子的执行信息(类型、名称、耗时等)…...

CANN/runtime多Stream同步示例

2_multi_stream 【免费下载链接】runtime 本项目提供CANN运行时组件和维测功能组件。 项目地址: https://gitcode.com/cann/runtime 描述 本样例展示了多个Stream之间流间任务同步功能。 产品支持情况 本样例支持以下产品: 产品是否支持Atlas A3 训练系列…...

AI时代知识工作者的创造力重塑:从复用、随机性到形式与内容的边界

1. 项目概述:当知识工作遇上AI,创造力如何被重新定义?最近和不少做内容、做产品、做策略的朋友聊天,大家都有一个共同的感受:自从ChatGPT、Midjourney这些AI工具普及后,工作流程确实快了不少,但…...

CANN/ops-nn Gelu梯度算子

GeluGrad 【免费下载链接】ops-nn 本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。 项目地址: https://gitcode.com/cann/ops-nn 产品支持情况 产品是否支持Ascend 950PR/Ascend 950DT√Atlas A3 训练系列产品/Atlas A3 推理系列产品√A…...

科学拉丁文献翻译评测:ChatGPT与Google Translate的深度对比

1. 项目缘起与核心价值作为一名长期在生物、医药和古典文献领域打交道的从业者,我几乎每天都要和拉丁文打交道。无论是解读一份18世纪的植物志手稿,还是理解一篇现代药理学论文中引用的经典术语,拉丁语都是横亘在面前的一道坎。过去&#xff…...

通过 Taotoken 管理控制台精细化设置 API Key 的访问权限与审计日志

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 通过 Taotoken 管理控制台精细化设置 API Key 的访问权限与审计日志 在团队协作或项目开发中,统一管理大模型 API 的调…...

CANN/opbase获取Tensor格式

aclGetFormat 【免费下载链接】opbase 本项目是CANN算子库的基础框架库,为算子提供公共依赖文件和基础调度能力。 项目地址: https://gitcode.com/cann/opbase 功能说明 获取aclTensor的format,aclTensor由aclCreateTensor接口创建。 函数原型 …...

ATVC AddWithBroadcast算子样例

【免费下载链接】atvc ATVC(Ascend C Templates for Vector Compute),是为基于Ascend C开发的典型Vector算子封装的一系列模板头文件的集合,可帮助用户快速开发典型Vector算子。 项目地址: https://gitcode.com/cann/atvc …...

泰山派3M-RK3576-系统功能-Debian12-MIPI屏幕显示

Debian12系统MIPI屏幕显示 下载对应镜像 使用 网盘🚀 在 系统镜像/Debian12/ 这个目录中下载我们提供的 .img 镜像文件。 本文档使用的镜像有两个(需要根据屏幕的型号选择): 【1】. TaishanPi-3M-RK3576_Debian12-Xfce_dsiC41…...

Graph-autofusion super_kernel极简示例

super_kernel极简sample 【免费下载链接】graph-autofusion Graph-autofusion 是一个面向昇腾(Ascend)芯片的轻量级、解耦式组件集合,旨在通过自动融合技术加速模型执行。 目前已开源 SuperKernel 组件,未来将持续开放更多自动融合…...

02.基础语法

第 2 章 C++ 基础语法 目录介绍 2.1 C++快速介绍 2.1.1 C++语言介绍 2.1.2 C++的特点 2.1.3 C++标准库 2.1.4 C++应用领域 2.1.5 C++的版本 2.1.6 综合案例与思考 2.2 C++编译器...