昇腾GE动态维度设置API
aclmdlSetInputDynamicDims【免费下载链接】geGEGraph Engine是面向昇腾的图编译器和执行器提供了计算图优化、多流并行、内存复用和模型下沉等技术手段加速模型执行效率减少模型内存占用。 GE 提供对 PyTorch、TensorFlow 前端的友好接入能力并同时支持 onnx、pb 等主流模型格式的解析与编译。项目地址: https://gitcode.com/cann/ge产品支持情况产品是否支持Atlas A3 训练系列产品 / Atlas A3 推理系列产品√Atlas A2 训练系列产品 / Atlas A2 推理系列产品√功能说明如果模型输入的Shape是动态的、输入数据Format为ND格式ND表示支持任意格式在模型执行前调用本接口设置模型推理时具体维度的值。函数原型aclError aclmdlSetInputDynamicDims(uint32_t modelId, aclmdlDataset *dataset, size_t index, const aclmdlIODims *dims)参数说明参数名输入/输出说明modelId输入模型ID。调用aclmdlLoadFromFile接口/aclmdlLoadFromMem接口/aclmdlLoadFromFileWithMem接口/aclmdlLoadFromMemWithMem接口加载模型成功后会返回模型ID。dataset输入输出模型推理的输入数据的指针。使用aclmdlDataset类型的数据描述模型推理时的输入数据输入的内存地址、内存大小用aclDataBuffer类型的数据来描述。index输入标识动态维度的输入index。需调用aclmdlGetInputIndexByName接口获取输入名称固定为ACL_DYNAMIC_TENSOR_NAME。dims输入具体某一档上的所有维度信息的指针。此处设置的动态维度的值只能是模型构建时设置的档位中的某一档。例如使用ATC工具进行模型转换时input_shapedata:1,1,40,-1;label:1,-1;mask:-1,-1 dynamic_dims20,20,1,1; 40,40,2,2; 80,60,4,4若输入数据的真实维度为1,1,40,20,1,20,1,1则dims结构体信息的填充示例如下name暂不使用dims.dimCount 8dims.dims[0] 1dims.dims[1] 1dims.dims[2] 40dims.dims[3] 20dims.dims[4] 1dims.dims[5] 20dims.dims[6] 1dims.dims[7] 1如果不清楚模型构建时的动态维度档位也可以调用aclmdlGetInputDynamicDims接口获取指定模型支持的动态维度档位数以及每一档中的值。返回值说明返回0表示成功返回其他值表示失败请参见aclError。【免费下载链接】geGEGraph Engine是面向昇腾的图编译器和执行器提供了计算图优化、多流并行、内存复用和模型下沉等技术手段加速模型执行效率减少模型内存占用。 GE 提供对 PyTorch、TensorFlow 前端的友好接入能力并同时支持 onnx、pb 等主流模型格式的解析与编译。项目地址: https://gitcode.com/cann/ge创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考