aclmdlLoadFromMem

函数功能

从内存加载离线模型数据,由系统内部管理模型运行的内存,同步接口。

系统完成模型加载后,返回的模型ID,作为后续操作时用于识别模型的标志。

约束说明

模型加载、模型执行、模型卸载的操作必须在同一个Context下(关于Context的创建请参见aclrtCreateContext)。在加载前,请先根据模型文件的大小评估内存空间是否足够,内存空间不足,会导致应用程序异常。

函数原型

aclError aclmdlLoadFromMem(const void* model, size_t modelSize, uint32_t* modelId)

参数说明

参数名

输入/输出

说明

model

输入

存放模型数据的内存地址指针。

应用运行在Host时,此处需申请Host上的内存;应用运行在Device时,此处需申请Device上的内存。内存申请接口请参见内存管理

modelSize

输入

内存中的模型数据长度,单位Byte。

modelId

输出

模型ID的指针。

系统成功加载模型后会返回的模型ID。

返回值说明

返回0表示成功,返回其它值表示失败。

相关接口

当前AscendCL还提供了aclmdlSetConfigOpt接口、aclmdlLoadWithConfig接口来实现模型加载,通过配置对象中的属性来区分,在加载模型时是从文件加载,还是从内存加载,以及内存是由系统内部管理,还是由用户管理。

参考资源

接口调用流程,参见模型加载