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
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值