news 2026/7/5 20:08:32

CANN/asc-devkit Matmul-Tiling类构造函数

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
CANN/asc-devkit Matmul-Tiling类构造函数

Matmul Tiling类构造函数

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

功能说明

用于创建一个Matmul单核Tiling对象,或者多核Tiling对象,或者BatchMatmul Tiling对象。

函数原型

  • 带参构造函数,需要传入硬件平台信息,推荐使用这类构造函数来获得更好的兼容性。

    • 使用PlatformAscendC类传入信息

      explicit MatmulApiTiling(const platform_ascendc::PlatformAscendC& ascendcPlatform)
      explicit MultiCoreMatmulTiling(const platform_ascendc::PlatformAscendC& ascendcPlatform)
      explicit BatchMatmulTiling(const platform_ascendc::PlatformAscendC& ascendcPlatform)
    • 使用PlatformInfo传入信息

      当platform_ascendc::PlatformAscendC无法在Tiling运行时获取时,需要用户自行构造PlatformInfo结构体,透传给MatmulApiTiling构造函数。

      explicit MatmulApiTiling(const PlatformInfo& platform)
      explicit MultiCoreMatmulTiling(const PlatformInfo& platform)
  • 无参构造函数

    MatmulApiTiling()
    MultiCoreMatmulTiling()
    BatchMatmulTiling()

    无参构造函数只支持如下产品型号:

    Atlas A2训练系列产品/Atlas 800I A2推理产品

    Atlas A3 训练系列产品

  • 基类构造函数

    MatmulApiTiling、MultiCoreMatmulTiling和BatchMatmulTiling都继承自基类MatmulApiTilingBase,其构造函数如下:

    MatmulApiTilingBase()
    explicit MatmulApiTilingBase(const platform_ascendc::PlatformAscendC& ascendcPlatform)
    explicit MatmulApiTilingBase(const PlatformInfo& platform)

参数说明

表1参数说明

参数名输入/输出描述
ascendcPlatform输入传入硬件平台的信息,PlatformAscendC定义请参见构造及析构函数。
platform输入传入硬件版本以及AI Core中各个硬件单元提供的内存大小。PlatformInfo构造时通过构造及析构函数获取。

PlatformInfo结构定义如下代码所示,socVersion通过GetSocVersion获取并透传,各类硬件存储空间大小通过GetCoreMemSize获取并透传。

不推荐通过直接填值构造PlatformInfo的方式调用构造函数,例如PlatformInfo(socVersion, 1024, 1024, ..);
struct PlatformInfo { platform_ascendc::SocVersion socVersion; uint64_t l1Size = 0; uint64_t l0CSize = 0; uint64_t ubSize = 0; uint64_t l0ASize = 0; uint64_t l0BSize = 0; };

在实现Host侧的Tiling函数时,platform_ascendc::PlatformAscendC用于获取一些硬件平台的信息,来支撑Tiling的计算,比如获取硬件平台的核数等信息。PlatformAscendC类提供获取这些平台信息的功能。

与platform_ascendc::PlatformAscendC不同的是,PlatformInfo则用于获取芯片版本、AI Core中各个硬件单元提供的内存大小等只针对单个AI Core的信息。

约束说明

使用样例

  • 无参构造函数

    // 单核Tiling matmul_tiling::MatmulApiTiling tiling; tiling.SetAType(matmul_tiling::TPosition::GM, matmul_tiling::CubeFormat::ND, matmul_tiling::DataType::DT_FLOAT16); // 多核Tiling matmul_tiling::MultiCoreMatmulTiling tiling; tiling.SetAType(matmul_tiling::TPosition::GM, matmul_tiling::CubeFormat::ND, matmul_tiling::DataType::DT_FLOAT16); // BatchMatmul Tiling matmul_tiling::BatchMatmulTiling bmmTiling; bmmTiling.SetAType(matmul_tiling::TPosition::GM, matmul_tiling::CubeFormat::ND, matmul_tiling::DataType::DT_FLOAT16);
  • 带参构造函数

    // 单核Tiling auto ascendcPlatform = platform_ascendc::PlatformAscendC(context->GetPlatformInfo()); matmul_tiling::MatmulApiTiling tiling(ascendcPlatform); tiling.SetAType(matmul_tiling::TPosition::GM, matmul_tiling::CubeFormat::ND, matmul_tiling::DataType::DT_FLOAT16); // 多核Tiling auto ascendcPlatform = platform_ascendc::PlatformAscendC(context->GetPlatformInfo()); matmul_tiling::MultiCoreMatmulTiling tiling(ascendcPlatform); tiling.SetAType(matmul_tiling::TPosition::GM, matmul_tiling::CubeFormat::ND, matmul_tiling::DataType::DT_FLOAT16); // BatchMatmul Tiling auto ascendcPlatform = platform_ascendc::PlatformAscendC(context->GetPlatformInfo()); matmul_tiling::BatchMatmulTiling bmmTiling(ascendcPlatform); bmmTiling.SetAType(matmul_tiling::TPosition::GM, matmul_tiling::CubeFormat::ND, matmul_tiling::DataType::DT_FLOAT16);

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

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

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

如何永久珍藏你的数字对话?一款让聊天记录重获新生的本地工具

如何永久珍藏你的数字对话?一款让聊天记录重获新生的本地工具 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/w…

作者头像 李华
网站建设 2026/7/5 20:06:20

如何在3分钟内完成离线文字识别?Umi-OCR终极指南

如何在3分钟内完成离线文字识别?Umi-OCR终极指南 【免费下载链接】Umi-OCR OCR software, free and offline. 开源、免费的离线OCR软件。支持截屏/批量导入图片,PDF文档识别,排除水印/页眉页脚,扫描/生成二维码。内置多国语言库。…

作者头像 李华
网站建设 2026/7/5 20:06:07

GTA5终极修改器YimMenu:如何保护游戏体验并解锁无限可能

GTA5终极修改器YimMenu:如何保护游戏体验并解锁无限可能 【免费下载链接】YimMenu YimMenu, a GTA V menu protecting against a wide ranges of the public crashes and improving the overall experience. 项目地址: https://gitcode.com/GitHub_Trending/yi/Yi…

作者头像 李华
网站建设 2026/7/5 20:05:56

MIC1557与PIC18F4458构建高精度定时系统

1. 项目背景与核心器件选型在工业自动化、医疗设备和智能家居等领域,可靠的时间基准往往决定着整个系统的成败。经过多年项目实践,我发现MIC1557这款低成本定时器芯片与PIC18F4458微控制器的组合,能够构建出误差小于0.5%的定时系统&#xff0…

作者头像 李华