开发者
资源
[object Object][object Object][object Object]undefined
[object Object]
  • 接口功能:完成PMCC模型混淆引擎的资源初始化和释放。

    • 资源初始化:与PMCC混淆引擎CA建立socket连接、对CA、TA进行初始化,并返回socket连接符。
    • 资源释放:与PMCC混淆引擎CA断开socket连接。
  • 背景:PMCC(Privacy&Model Confidential Computing)模型混淆特性利用CPU核中的TrustZone可信执行环境隔离存储混淆因子、派生混淆掩码、执行动态掩码添加。PMCC基于NPU TrustZone构建了模型混淆引擎CA(普通OS中的Client Application)与模型混淆引擎TA(TEE OS中的Trusted Application)。为了使模型在推理执行过程中能够访问模型混淆引擎TA,通过AICPU算子机制及NPU卡内localhost socket进行中转。

[object Object]

每个算子分为,必须先调用 “aclnnObfuscationSetupGetWorkspaceSize”接口获取计算所需workspace大小以及包含了算子计算流程的执行器,再调用“aclnnObfuscationSetup”接口执行计算。

[object Object]
[object Object]
[object Object]
  • 参数说明

    [object Object]
  • 返回值

    aclnnStatus:返回状态码,具体参见

    第一段接口完成入参校验,出现以下场景时报错:

    [object Object]
[object Object]
  • 参数说明

    [object Object]
  • 返回值

    返回aclnnStatus状态码,具体参见

[object Object]
  • 确定性计算:

    • aclnnObfuscationSetup默认确定性实现。
  • 该接口与配套使用,完成PMCC模型混淆功能,使用方式如下:

    • 首先调用aclnnObfuscationSetup进行资源初始化,可重复调用,以最后一次初始化为准
    • 再多次调用aclnnObfuscationCalculate进行张量混淆处理
    • 最后调用aclnnObfuscationSetup进行资源释放,只能调用一次;也可不显式进行资源释放,而是通过终止程序进程的方式达到资源释放的目的
[object Object]

示例代码如下,仅供参考,具体编译和执行过程请参考

[object Object]