【2023 · CANN训练营第一季】应用开发深入讲解——第二章 模型推理
【摘要】 学习目标在这里插入图片描述学习资源内存管理在线课程 文档模型推理文档第1节 AscendCL运行资源管理运行资源管理概述在这里插入图片描述申请运行管理资源时,需按顺序依次申请: Device 、 Context 、 Stream ,然后根据实际需求调用 aclrtGetRunMode 接口获取软件栈的运行模型(当同一个应用既支持在 Host 运行,也支持在 Device 运行时,在编程时需...
学习目标
data:image/s3,"s3://crabby-images/199df/199df10e46f7b25ef7554395ebb29c952624c6b1" alt=""
在这里插入图片描述
学习资源
内存管理
模型推理
第1节 AscendCL运行资源管理
运行资源管理概述
data:image/s3,"s3://crabby-images/f885c/f885c545df2390d49a50898daa029fa57552540b" alt=""
在这里插入图片描述
申请运行管理资源时,需按顺序依次申请: Device 、 Context 、 Stream ,然后根据实际需求调用 aclrtGetRunMode 接口获取软件栈的运行模型(当同一个应用既支持在 Host 运行,也支持在 Device 运行时,在编程时需要就需要根据运行模式来判断后续的接口调用逻辑,这时需要提前获取运行模式。)。 ·调用 aclrtSetDevice 接口显式指定用于运算的 Device 。
指定用于计算的 Device aclrtSetDevice ■调用 aclrtCreateContext 接口显式创建 Context ,调用 aclrtCreateStream 接口显式创建 Stream 。 .不显式创建 Context 和 Stream ,系统会使用默认 Context 、默认 Stream ,该默认 Context 、默认 Stream 是在调用 aclrtSetDevice 接口时隐式创建的。默认 Context 、默认 Stream 作为接口入参时,直接传 NULL 。
是否显式创建 Context 和 Stream ? 创建 Context 和 Stream acirtCreateContext aclrtCreateStream .不显式指定用于运算的 Device 。 调用 aclrtCreateContext 接口显式创建 Context ,调用 aclrtCreateStream 接口显式创建 Stream 。系统在显式创建 Context 时,系统内部会调用 aclrtSetDevice 接口指定运行的 Device , Device ID 通过 aclrtCreateContext 接口传入。
data:image/s3,"s3://crabby-images/bf535/bf535158c504f0c34553126932bf695a33886a00" alt=""
在这里插入图片描述
接口命名规则
data:image/s3,"s3://crabby-images/024c3/024c32e3f658087c568146854b8a8415d1ab3b71" alt=""
在这里插入图片描述
Device 管理
- 获取当前设备数量
data:image/s3,"s3://crabby-images/16167/16167c67627095e833ac85000c3164bf805de39c" alt=""
在这里插入图片描述
data:image/s3,"s3://crabby-images/b7d98/b7d9837137d3bb96d30ae9abac2ee7a7be64dc7a" alt=""
在这里插入图片描述
data:image/s3,"s3://crabby-images/30b8b/30b8b98a8e52b70bc79157616a9cc58a23f28e79" alt=""
在这里插入图片描述
释放device资源,要注意释放顺序
data:image/s3,"s3://crabby-images/b8a62/b8a628f7a32f0753a488ddceef4bcc3999cde90e" alt=""
在这里插入图片描述
data:image/s3,"s3://crabby-images/c61a0/c61a09004f3788ec32422523cf438707aa8853db" alt=""
在这里插入图片描述
Context 管理
data:image/s3,"s3://crabby-images/e97ef/e97ef2eb0e82a0e4c71468aa8337b71064cb9915" alt=""
在这里插入图片描述
data:image/s3,"s3://crabby-images/ce199/ce1990ea154762f4fba10123db6d50e945c5d66b" alt=""
在这里插入图片描述
Stream管理
·原理介绍: >在 ACL 中, Stream 是一个任务队列,应用程序通过 Stream 来管理任务的并行,一个 Stream 内部的任务保序执行,即 Stream 根据发送过来的任务依次执行;不同 Stream 中的任务并行执行。一个默认 Context 下会挂一个默认 Stream ,如果不显式创建 Stream ,可使用默认 Stream 。
创建
data:image/s3,"s3://crabby-images/fa22e/fa22e0f353237d0ab974835ff6aee41ba5875cc5" alt=""
在这里插入图片描述
data:image/s3,"s3://crabby-images/b8188/b81885bc16feb2588770b7cd389d4b693b9524fd" alt=""
在这里插入图片描述
第2节 AscendCL 内存管理&数据传输
. ACL 是有一套自己的内存管理逻辑的,任何用于参与 ACL 运算的内存( Device 侧)都不能是 C / C ++原生内存管理接口( Malloc 、 new )申请的内存,而是调用 ACL 提供的内存管理专用接口 .回忆一下: ACL 在设备的管理上,是要区分 Host 和 Device 的(还记得 aclrtGetRunMode 接口吗?),所有的加速计算最终都是要在 Device 上执行的,也就是说所有的数据(数据集、模型等)最终都会在 Device 侧参与计算,这里分两种场景:
Host & Device 分设,如Atlas300场景(虽然在同一台机器上,但是是通过 PCle 接口交互的,本质上是两个设备),此时数据、模型都在 host 侧加载,然后将这些数据传输到 device 侧进行计算,计算完毕后将结果回传至 host 侧进行使用 Host & Device 合设,如Atlas200Dk场景,此时不区分 Host 与 Device ,只有 Device ,数据、模型都在 device 上直接加载、计算、使用 ·本模块就是要跟大家分享如何在 Host 侧和 Device 侧分别申请内存,并将数据在两端进行传输(复制)。
Host侧内存的申请&释放
data:image/s3,"s3://crabby-images/2cf13/2cf135fe06faf4f5a02db5054f79b79469d0fbc7" alt=""
在这里插入图片描述
Device侧内存的申请及释放
data:image/s3,"s3://crabby-images/6b5f6/6b5f6e9b34eb345bcca48a4687bd23f606e5f5d1" alt=""
在这里插入图片描述
data:image/s3,"s3://crabby-images/e09aa/e09aa96457a3c0ec40ce0874042225a5e786b7b4" alt=""
在这里插入图片描述
异步内存初始化
data:image/s3,"s3://crabby-images/fbff0/fbff01cb2266d62584b260f92e6bd4f3fbb01ac3" alt=""
在这里插入图片描述
AscendCL 模型加载与执行
模型推理三大流程
data:image/s3,"s3://crabby-images/ef1c5/ef1c589204bd1200689db8c4c5c069c8e4990c31" alt=""
在这里插入图片描述
模型推理整体流程
data:image/s3,"s3://crabby-images/8ec2a/8ec2a64bfe37c7233313c84bc93ad84f0f1f7ac7" alt=""
在这里插入图片描述
准备推理输入、输出数据
data:image/s3,"s3://crabby-images/74dde/74dde4c2bb6fbd35c099ab85980befe54a7d076b" alt=""
在这里插入图片描述
自动管理内存场景
data:image/s3,"s3://crabby-images/f0d0b/f0d0beea0dcfe776e2e4e6e04963671d02eaadf9" alt=""
在这里插入图片描述
手动管理内存场景
data:image/s3,"s3://crabby-images/05556/05556061b8447156a7aaa3ea2d53fa275cdaa77d" alt=""
在这里插入图片描述
data:image/s3,"s3://crabby-images/b4b44/b4b44295a5ababde0986686792a0c60af385d2ae" alt=""
在这里插入图片描述
模型卸载
data:image/s3,"s3://crabby-images/88bee/88beec70ed09f1a3def3ae6b0e9f1b10df62b2ff" alt=""
在这里插入图片描述
获取模型描述信息
data:image/s3,"s3://crabby-images/a7b11/a7b111a391deb722d0e563f2561ac4d0b2131804" alt=""
在这里插入图片描述
data:image/s3,"s3://crabby-images/9776f/9776fb055a27bcc53992892822fa65cc96fc2bc7" alt=""
在这里插入图片描述
data:image/s3,"s3://crabby-images/e50a8/e50a855588ebb5659ad000c0998f07e68432f4da" alt=""
在这里插入图片描述
模型推理执行接口——同步
data:image/s3,"s3://crabby-images/2b9e6/2b9e601e6f41aae9429361633422cf813b7a35e9" alt=""
在这里插入图片描述
模型推理执行接口——异步
data:image/s3,"s3://crabby-images/57169/571692c36b23c7c2dbf446f4c927395bec6c17c2" alt=""
在这里插入图片描述
案例演示
data:image/s3,"s3://crabby-images/667a2/667a2c104a22a9455e8ed898d6ca98b57abe72de" alt=""
【声明】本内容来自华为云开发者社区博主,不代表华为云及华为云开发者社区的观点和立场。转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息,否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
作者其他文章
评论(0)