RunGraphWithStreamAsync
产品支持情况
头文件/库文件
- 头文件:#include <ge/ge_api.h>
- 库文件:libge_runner.so
功能说明
异步运行指定ID对应的Graph图,输出运行结果。该接口包括了编译,加载和运行Graph的操作。
此函数与RunGraph均为运行指定ID对应的图,并输出结果,区别于RunGraph的是,该接口:
-
异步运行。
-
inputs和outputs均为Device上的内存空间,且需要在运行前由用户分配内存大小。
如下两种情况用户可以不分配输出内存:
- 用户通过RegisterExternalAllocator设置了外置allocator,如果没有分配输出内存,由GE调用外置allocator的接口分配内存,用户需要在外置allocator析构前释放这块内存。
- 用户没有设置外置allocator,动态图场景,如果没有分配输出内存,GE使用内置allocator分配内存,内存的生命周期与图的生命周期保持一致,用户需要在图卸载前(Session析构前、GEFinalize前)主动释放此内存。
函数原型
Status RunGraphWithStreamAsync(uint32_t graph_id, void *stream, const std::vector<Tensor> &inputs,std::vector<Tensor> &outputs)
参数说明
|
如果通过options指定了ge.exec.hostInputIndexes参数,对应索引的Tensor可以为Host上的内存空间。 |
||
返回值说明
约束说明
-
调用该接口前,请先分配好Tensor需要使用的内存。
-
调用该接口前,需要通过acl提供的aclrtCreateStream接口创建Stream,且只支持Stream为默认Context的场景。
-
得到输出运行结果前,需要通过aclrtSynchronizeStream接口保证Stream上的任务已经执行完。
接口详细说明请参见《应用开发指南 (C&C++)》。