CKKS 精度测试(openFHE和Tenseal库)

OpenFHE 库

  • OpenFHE 库的 CKKS 算法参数涉及三种(缩放因子(scaleModSize)、乘法深度(Multiplicative depth)、插槽数(batchSize))
    在这里插入图片描述

  • 测试一次密文乘法的精度和 x 18 + x 9 + 1 x^{18}+x^{9}+1 x18+x9+1五次密文的精度
    在这里插入图片描述

乘法深度 6 缩放因子 20(精度 13bit)

在这里插入图片描述
在这里插入图片描述

乘法深度 6 缩放因子 30(精度 23bit)

在这里插入图片描述
在这里插入图片描述

乘法深度 6 缩放因子 40(精度 32bit)

在这里插入图片描述
在这里插入图片描述

乘法深度 6 缩放因子 50(精度 42bit)

在这里插入图片描述
在这里插入图片描述

乘法深度 6 缩放因子 59(精度 51bit)

在这里插入图片描述
在这里插入图片描述

TenSEAL 库

  • SEAL 库的 CKKS 算法参数涉及三种(系数模(coeff_modulus)、多项式模度(poly_modulus_degree)、缩放因子(scale))
    在这里插入图片描述
    在这里插入图片描述

参数介绍

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-oJOLWKbv-1666709801530)(static/boxcnXOBO6EFMsIYRv4gEdnhJsf.png)]

Scaling factor

CKKS 方案的第一步是将一个实数向量编码为一个明文多项式。缩放系数定义了数字的二进制表示法的编码精度。直观地说,我们谈论的是二进制精度,如下图所示。
在这里插入图片描述

The polynomial modulus degree

多项式模数直接影响到,明文多项式中的系数个数,密文元素的大小,方案的计算性能(越大越差),安全级别(越大越好)。多项式模数的次数必须是 2 的幂(例如 1024、2048、4096、8192、16384 或 32768)。

The coefficient modulus sizes

该方案需要的最后一个参数是一个二进制大小的列表。利用这个列表,SEAL 将生成这些二进制大小的素数列表,称为系数模数(图中为 q)。系数模直接影响到。密码文本元素的大小,列表的长度表示方案的级别(或支持的加密乘法的数量)。安全级别(越大越差)。

  • 系数模的和不能超过 polynomial modulusr 定义的最大比特长度

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-9dziEzcV-1666709801530)(static/boxcnQnMtFI2wegOfHoSqoTrlJb.png)]

Benchmark

单次密文乘法

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

五次密文乘法 x 18 + x 9 + 1 x^{18}+x^{9}+1 x18+x9+1

在这里插入图片描述
在这里插入图片描述

  • 2
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
ckks(Ciphertext-Key Homomorphic Encryption over the Integers)是一种混淆加密方案,用于保护机密数据的隐私。它的运行时间分析主要涉及以下几个方面。 首先,ckks方案的运行时间与数据大小和计算操作的复杂度有关。当数据大小增加时,计算密钥切换和加密操作的时间会增加。相对于其他同类方案,ckks具有较高的计算复杂度,主要体现在同态操作和加密过程中。 其次,ckks方案的加密过程中,生成加密密钥、密钥切换和加密操作都需要时间。生成加密密钥是ckks方案的初始化过程,需要一定的计算时间。密钥切换操作用于支持不同的同态计算,它需要将密钥更新成特定的结构,该过程也需要时间。加密操作主要是将明文转化为密文,这一过程涉及到数学运算和数据转换,所以时间较长。 最后,ckks方案中的同态操作是实现加法和乘法的关键步骤。同态加法和同态乘法的运行时间与数据的大小和复杂度有关。在ckks方案中,同态乘法的运算时间较长,主要是由于乘法的复杂性决定的。对于乘法操作,可能需要多次迭代计算,因此运行时间相对较长。 综上所述,ckks方案的运行时间分析与数据大小、计算复杂度以及同态操作有关。尽管ckks方案的计算复杂度较高,但它提供了更高级的同态操作,可以实现更复杂的计算,从而保护隐私数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值