如何使用掩码操作API

Mask用于控制矢量计算中参与计算的元素个数,支持以下工作模式及配置方式:

表1 Mask工作模式

工作模式

说明

Normal模式

默认模式,支持单次迭代内的Mask能力,需要开发者配置迭代次数,额外进行尾块的计算。

Normal模式下,Mask用来控制单次迭代内参与计算的元素个数。

通过调用SetMaskNorm设置Normal模式。

Counter模式

简化模式,直接传入计算数据量,自动推断迭代次数,不需要开发者去感知迭代次数、处理非对齐尾块的操作;但是不具备单次迭代内的Mask能力。

Counter模式下,Mask表示整个矢量计算参与计算的元素个数。

通过调用SetMaskCount设置Counter模式。

表2 Mask配置方式

配置方式

说明

接口传参(默认)

通过矢量计算API的入参直接传递Mask值。矢量计算API的模板参数isSetMask(仅部分API支持)用于控制接口传参还是外部API配置,默认值为true,表示接口传参。Mask对应于高维切分计算API中的mask/mask[]参数或者tensor前n个数据计算API中的calCount参数。

外部API配置

调用SetVectorMask接口设置Mask值,矢量计算API的模板参数isSetMask设置为false,接口入参中的Mask参数(对应于高维切分计算API中的mask/mask[]参数或者tensor前n个数据计算API中的calCount参数)不生效。适用于Mask参数相同,多次重复使用的场景,无需在矢量计算API内部反复设置,会有一定的性能优势。

Mask操作的使用方式如下:

表3 Mask操作的使用方式

配置方式

工作模式

前n个数据计算API

高维切分计算API

接口传参

Normal模式

不涉及。

isSetMask模板参数设置为true,通过接口入参传入Mask,根据使用场景配置dataBlockStriderepeatStriderepeatTimes参数。

Counter模式

isSetMask模板参数设置为true,通过接口入参传入Mask。

  • isSetMask模板参数设置为true,通过接口入参传入Mask。
  • 根据使用场景配置dataBlockStriderepeatStride参数。repeatTimes传入固定值即可,建议统一设置为1,该值不生效。

外部API配置

Normal模式

不涉及。

调用SetVectorMask设置Mask,之后调用高维切分计算API。
  • isSetMask模板参数设置为false,接口入参中的mask值设置为占位符MASK_PLACEHOLDER,用于占位,无实际含义。
  • 根据使用场景配置repeatTimesdataBlockStriderepeatStride参数。

Counter模式

调用SetVectorMask设置Mask,之后调用前n个数据计算API,isSetMask模板参数设置为false;接口入参中的calCount建议设置成1。

调用SetVectorMask设置Mask,之后调用高维切分计算API。
  • isSetMask模板参数设置为false;接口入参中的mask值设置为MASK_PLACEHOLDER,用于占位,无实际含义。
  • 根据使用场景配置dataBlockStriderepeatStride参数。repeatTimes传入固定值即可,建议统一设置为1,该值不生效。

典型场景的使用示例如下:

  • 前n个数据计算API接口内部会设置工作模式为Counter模式,所以如果前n个数据计算API配合Counter模式使用时,无需手动调用SetMaskCount设置Counter模式。
  • 所有手动使用Counter模式的场景,使用完毕后,需要调用SetMaskNorm恢复工作模式。
  • 调用SetVectorMask设置Mask,使用完毕后,需要调用ResetMask恢复Mask值为默认值。
  • 使用高维切分计算API配套Counter模式使用时,比前n个数据计算API增加了可间隔的计算,支持dataBlockStride、repeatStride参数。