【SecretFlow——SPU基础】

1.SPU基础

SPU设备在SecretFlow中负责执行MPC计算。
在这里插入图片描述

2.代码解读

2.1 创建设备

import secretflow as sf
# 如果存在secretflow,先关闭已经存在的环境
sf.shutdown()
# 初始化四个参与方
sf.init(['alice', 'bob', 'carol', 'dave'], address='local')
# 寻找未占用的端口来创建一个设置。
aby3_config = sf.utils.testing.cluster_def(parties=['alice', 'bob', 'carol'])
# aby_confg = {'nodes': [{'party': 'alice', 'address': '127.0.0.1:49613'},
# 	 {'party': 'bob', 'address': '127.0.0.1:52053'},
# 	 {'party': 'carol', 'address': '127.0.0.1:25589'}],
# 	'runtime_config': {'protocol': 3, 'field': 3}}
# 建立一个三方的SPU
aby3_config = sf.utils.testing.cluster_def(parties=['alice', 'bob', 'carol'])
# 创建两个PYU设备
alice, dave = sf.PYU('alice'), sf.PYU('dave')

2.2 理解向SPU设备中传值

2.2.1 SPUObject

在讨论利用SPU设备计算之前,我们需要理解如何将一个 Python object / PYUObject 传给一个SPU设备。sf.device.SPUIO 是执行该任务的辅助类。(在一般写代码中不需要我们来直接调用,这里显示只是让大家理解更清楚)
每一个SPUObject包含两个成员:
meta: 原始对象的结构。
shares: 原始对象的秘密分享。

# 基于spu的配置和世界大小(参与方个数),创建spu_io
spu_io = sf.device.SPUIO(spu_device.conf, spu_device.world_size)
# 两条数据,每个数据中有两个字段
bank_account = [{'id': 12345, 'deposit': 1000.25}, {'id': 12345, 'deposit': 100000.25}]
import spu
# 通过spu_io产生可以可以被分享的秘密
meta, io_info, *shares = spu_io.make_shares(bank_account, spu.Visibility.VIS_SECRET)

这里产生的meta和原数据结构还是很类似的,只是值被替换成了SPUValueMeta类型
在这里插入图片描述
shares的分片则完全变成了加密格式

# 通过share,io_info,meta可以对数据进行还原。但需要注意的是,对象类型从float变成了array
bank_account_hat = spu_io.reconstruct(shares, io_info, meta)
bank_account_hat

在这里插入图片描述

2.2.2 如何创建一个SPU设备

  1. 如果你想把一个Python对象或函数传递给SPU设备,你必须先将它传递给一个PYU。
  2. 一个SPU Object 包含了meta 和 shares。
  3. sf.to 和 sf.reveal 调用 sf.device.SPUIO 来在SPU对象和Python对象之间转换数据。
  4. 仅仅转化为SPU Object不会触发从PYU至SPU的数据流动,比如当你将一个PYU Object转化为SPU Object时。SPU object所有内容包括meta和shares仍然位于PYU设备。shares只会在计算发生的时候将会被发送到SPU设备的各方。简单的来说,数据流动是lazy的。
# 方式一:以函数的形式
def debit_amount(x):return 10+x
debit_amount_pyu = alice(debit_amount)(5)
debit_amount_spu = debit_amount_pyu.to(spu_device)
# 方式二:以列表+json的格式(python对象)
bank_account = [{'id': 12345, 'deposit': 1000.25}, {'id': 12345, 'deposit': 100000.25}]
bank_account_spu = sf.to(alice,[{'id': 12345, 'deposit': 1000.25}, {'id': 12345, 'deposit': 100000.25}])
bank_account_spu = debit_amount_pyu.to(spu_device)

3. 使用SPU设备进行计算

使用我们生成的spu_device对SpuObject进行计算

# 从每个人的账户中减去amount的金额
def deduce_from_account(bank_account, amount):new_bank_account = []for account in bank_account:account['deposit'] = account['deposit'] - amountnew_bank_account.append(account)return new_bank_account
# 将计算deduce_from_account放到spu_device中进行,并填入两个SPUObject对象bank_account_spu,debit_amount_spu
new_bank_account_spu = spu_device(deduce_from_account)(bank_account_spu, debit_amount_spu
)
new_bank_account_spu
# 显然我们可以将计算结果传递给第三或者是任何人
new_bank_account_pyu = new_bank_account_spu.to(dave)
new_bank_account_pyu
sf.reveal(new_bank_account_pyu)

3.1 SPU背后计算的步骤

步骤1:将Python(Jax)代码编译为SPU可执行文件

Python 函数(在我们的例子中是 deduce_from_account)和所有输入的元数据(bank_account_spu 和 debit_amount_spu)将被发送到 SPU 设备。然后使用 SPU 编译器将它们编译为 SPU Executable。
在这里插入图片描述

步骤2:将SPU可执行文件和秘密分享分配给SPU参与方

步骤3:运行SPU可执行文件并组装SPU对象

然后 SPU 设备的每一方将执行 SPU Executation。
最后,SPU 设备的每一方都将拥有一个输出 SPU Object的一份share和一个meta。
然后 SecretFlow 框架将使用它们来组装 SPU Object。

参考文献

隐语官方文档链接
secretnote运行环境

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/776386.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【YOLOV5 入门】——detect.py简单解析模型检测基于torch.hub的检测方法

声明:笔记是毕设时根据B站博主视频学习时自己编写,请勿随意转载! 一、打开detect.py(文件解析) 打开上节桌面创建的yolov5-7.0文件夹里的detect.py文件(up主使用的是VScode,我这里使用pycharm…

NLP深入学习:结合源码详解 BERT 模型(三)

文章目录 1. 前言2. 预训练2.1 modeling.BertModel2.1.1 embedding_lookup2.1.2 embedding_postprocessor2.1.3 transformer_model 2.2 get_masked_lm_output2.3 get_next_sentence_output2.4 训练 3. 参考 1. 前言 前情提要: 《NLP深入学习:结合源码详…

PyQt5开发——QCheckBox 复选框用法与代码示例

1. 复选框 QCheckBox 是 Qt 框架中的一个控件,用于在界面中表示一个可以被选中或取消选中的复选框。它通常用于允许用户在多个选项之间进行选择。在 Python 中使用 PyQt 或 PySide 开发 GUI 应用程序时,可以使用 QCheckBox 控件来实现复选框。 2.基本用…

[ Linux ] git工具的基本使用(仓库的构建,提交)

1.安装git yum install -y git 2.打开Gitee,创建你的远程仓库,根据提示初始化本地仓库(这里以我的仓库为例) 新建好仓库之后跟着网页的提示初始化便可以了 3.add、commit、push三板斧 git add . //add仓库新增(变…

企业数字化转型:聊聊数据思维!

笔者曾在《深入聊一聊企业数字化转型这个事儿》 一文中给出了数字化转型的定义,即:通过应用数字化技术来重塑企业的信息化环境和业务过程。本质上来讲,企业数字化转型,不仅是技术方面的升级,更是企业文化、思维方式的转…

【计算机考研】408到底有多难?

你真以为大家是学不会408吗? 不是!单纯是因为时间不够!!! 再准确一些就是不会分配时间 408的知识其实并不难,要说想上130那确实有难度,但是100在时间充裕的情况下还是可以做到的 我本人是双…

非wpf应用程序项目【类库、用户控件库】中使用HandyControl

文章速览 前言参考文章实现方法1、添加HandyControl包;2、添加资源字典3、修改资源字典内容坚持记录实属不易,希望友善多金的码友能够随手点一个赞。 共同创建氛围更加良好的开发者社区! 谢谢~ 前言 wpf应用程序中,在入口项目中存在App.xaml文件,在这个文件中加上对各个…

Linux之进程控制进程终止进程等待进程的程序替换替换函数实现简易shell

文章目录 一、进程创建1.1 fork的使用 二、进程终止2.1 终止是在做什么?2.2 终止的3种情况&&退出码的理解2.3 进程常见退出方法 三、进程等待3.1 为什么要进行进程等待?3.2 取子进程退出信息status3.3 宏WIFEXITED和WEXITSTATUS(获取…

全球首位AI程序员Devin诞生,以此谈谈AI对程序员的影响

一、简介 全球首位 AI 程序员 Devin 是由初创公司 Cognition AI 创造的。这家公司成立仅四个月,却已经引起了广泛关注。 Devin作为人工智能的代表,将展示出人工智能在编程领域的潜力和能力,激发程序员探索和应用人工智能技术的兴趣。这将可…

NanoMQ的安装与部署

本文使用docker进行安装,因此安装之前需要已经安装了docker 拉取镜像 docker pull emqx/nanomq:latest 相关配置及密码认证 创建目录/usr/local/nanomq/conf以及配置文件nanomq.conf、pwd.conf # # # # MQTT Broker # # mqtt {property_size 32max_packet_siz…

6、ChatGLM3-6B 部署实践

一、ChatGLM3-6B介绍与快速入门 ChatGLM3 是智谱AI和清华大学 KEG 实验室在2023年10月27日联合发布的新一代对话预训练模型。ChatGLM3-6B 是 ChatGLM3 系列中的开源模型,免费下载,免费的商业化使用。 该模型在保留了前两代模型对话流畅、部署门槛低等众多…

官网怎么发布新文章,怎么在官方网站上发布新内容

随着企业和组织越来越重视官方网站的建设和更新,发布新内容成为了官方网站管理的重要一环。本文将探讨在官方网站上发布新内容的步骤和方法,以及如何确保发布的内容质量和效果。 1. 确定发布内容 在发布新内容之前,首先需要确定发布的内容。…

精品凉拌菜系列热卤系列课程

这一系列课程涵盖精美凉拌菜和美味热卤菜的制作技巧。学员将学习如何选材、调味和烹饪,打造口感丰富、色香俱佳的菜肴。通过实践训练,掌握独特的烹饪技能,为家庭聚餐或职业厨艺提升增添亮点。 课程大小:6.6G 课程下载&#xff1…

windows安装R4.3.3

官网地址The Comprehensive R Archive Network 下载后得到exe安装,默认安装到了C:\Program Files\R, 因为之前已经安装了4.2.3,所以新建了文件夹为4.3.3,两者互不干扰 安装完毕后,打开rstudio,设置 然后重…

基于springboot+vue+Mysql的酒店管理系统

开发语言:Java框架:springbootJDK版本:JDK1.8服务器:tomcat7数据库:mysql 5.7(一定要5.7版本)数据库工具:Navicat11开发软件:eclipse/myeclipse/ideaMaven包:…

C++入门:类和对象(上)

类和对象重点解析 1.类的定义1.类的访问限定符及封装1.C实现封装的方式2.访问限定符注意 3.封装 2.类对象模型2.1类对象存储方式2.2类对象的大小2.2.1结构体内存对齐原则2.2.2为什么要内存对齐 3.this指针3.1this指针的引出3.2this指针的特性3.3this指针的存储3.4this指针可以为…

如何安全地添加液氮到液氮罐中

液氮是一种极低温的液体,它在许多领域广泛应用,但在处理液氮时需谨慎小心。添加液氮到液氮罐中是一个常见的操作,需要遵循一些安全准则以确保操作人员的安全和设备的完整性。 选择合适的液氮容器 选用专业设计用于存储液氮的容器至关重要。…

UEDITOR WORD图片转存交互

1.下载示例: Word一键粘贴控件-示例-泽优软件 2.复制WordPaster插件目录 3.引入插件文件 注意:不要重复引入jquery,如果您的项目已经引入了jq,则不用再引入jq-1.4 4.在工具栏中增加插件按钮 6.初始化控件 注意: 1.如…

专业文件翻译,笔译翻译公司推荐!

在全球化的大潮中,文件翻译已然成为了商业、法律、科技、文化等诸多领域的核心纽带。特别是在商业交往、合同签订、技术交流等方面,一份高质量的译文往往关乎着合作的成败。而在这其中,专业的文件翻译公司更是扮演着至关重要的角色。它们不仅…

C语言例4-33:求调和级数中第多少项的值大于10

代码如下&#xff1a; //求调和级数中第多少项的值大于10 //调和级数的第n项为11/21/3...1/n #include<stdio.h> #define LIMIT 10 int main(void) {int n1;float sum0.0;for(;;) //死循环&#xff0c;或者while&#xff08;1&#xff09;{sumsum1.0/n;if(sum&g…