SEAL全同态加密开源库(十三) CKKS-源码浅析

本文详细解析了使用SEAL库进行CKKS全同态加密时,涉及的多项式计算过程,包括平方、乘法、重线性化和模切换等操作。在处理不同比例和加密参数的密文时,通过调整比例、模切换和加密参数以实现加法运算。最终,成功计算并解密了给定输入的PI*x^3+0.4*x+1的表达式,验证了CKKS加密下复杂数学运算的正确性。

2021SC@SDUSC
2021-12-26

前言

这是SEAL全同态加密开源库分析报告的第13篇,我们继续上一篇的CKKS源码分析。

代码分析

现在x3_encryption与x1_encryption处于不同的级别,这阻止我们将它们相乘来计算x3
我们可以简单地将x1_encrypted切换到模数转换链中的下一个参数。然而,由于我们仍然需要将x3,乘以PI(plain_coeff3),所以我们先计算PI*x,然后将它与x2相乘,得到PI *x3。最后,我们计算PI *x 并将其从280缩放到接近2^40的值。

    print_line(__LINE__);
    cout << "Compute and rescale PI*x." << endl;
    Ciphertext x1_encrypted_coeff3;
    evaluator.multiply_plain(x1_encrypted, plain_coeff3, x1_encrypted_coeff3);
    cout << "    + Scale of PI*x before rescale: " << log2(x1_encrypted_coeff3.scale())
        << " bits" << endl;
    evaluator.rescale_to_next_inplace(x1_encrypted_coeff3);
    cout << "    + Scale of PI*x after rescale: " << log2(x1_encrypted_coeff3.scale())
        << " bits" << endl;

因为x3_encrypted和x1_encrypted_coeff3具有相同的scale和使用相同的加密参数,所以我们可以将它们相乘。我们将结果写入x3_encrypted,relinearize和rescale。再次注意scale是接近2^40,但不完全是2的40次方due to yet another scaling by a prime。我们已经到了模切换链的最后一个level。

    print_line(__LINE__);
    cout << "Compute, relinearize, and rescale (PI*x)*x^2." << endl;
    evaluator.multiply_inplace(x3_encrypted, x1_encrypted_coeff3);
    evaluator.relinearize_inplace(x3_encrypted, relin_keys);
    cout << "    + Scale of PI*x^3 before rescale: " << log2(x3_encrypted.scale())
        << " bits" << endl;
    evaluator.rescale_to_next_inplace(x3_encrypted);
    cout << "    + Scale of PI*x^3 after rescale: " << log2(x3_encrypted.scale())
        << " bits" << endl;

接下来计算1次项。所有这些都需要一个带有plain_coeff1的multiply_plain。我们使用结果覆盖x1_encryption。

print_line(__LINE__);
cout << "Compute and rescale 0.4*x." << endl;
evaluator.multiply_plain_inplace(x1_encrypted, plain_coeff1);
cout << "    + Scale of 0.4*x before rescale: " << log2(x1_encrypted.scale())
    << " bits" << endl;
evaluator.rescale_to_next_inplace(x1_encrypted);
cout 
<think>由于用户的问题是关于SEAL库(全同态加密)的安装方法,我将根据提供的引用内容以及一般安装经验来回答。虽然引用[2]提到了安装与配置,但具体步骤并未详细给出,因此需要结合SEAL官方文档的常规安装步骤进行说明。 SEAL库的安装通常包括以下步骤: 1. 安装必要的依赖项 2. 下载SEAL源代码 3. 使用CMake配置构建 4. 编译和安装 以下是详细的安装步骤: ### 步骤1: 安装依赖项 SEAL需要以下依赖: - CMake (版本3.10或更高) - GCC (版本7.4.0或更高) 或 Clang (版本6.0或更高) - 支持C++17的编译器 在Ubuntu系统上,可以使用以下命令安装依赖: ```bash sudo apt update sudo apt install cmake g++ build-essential ``` ### 步骤2: 下载SEAL源代码 可以从GitHub仓库克隆最新的SEAL源代码: ```bash git clone https://github.com/microsoft/SEAL.git cd SEAL ``` ### 步骤3: 使用CMake配置构建 创建一个构建目录并运行CMake: ```bash cmake -S . -B build -DSEAL_THROW_ON_TRANSPARENT_CIPHERTEXT=ON ``` 其中,`-DSEAL_THROW_ON_TRANSPARENT_CIPHERTEXT=ON` 是一个可选的安全选项,建议启用。 ### 步骤4: 编译和安装 ```bash cmake --build build sudo cmake --install build ``` ### 步骤5: 验证安装(可选) 创建一个测试程序,例如: ```cpp #include "seal/seal.h" using namespace seal; int main() { EncryptionParameters parms(scheme_type::bfv); return 0; } ``` 然后编译并运行,确保没有错误。 ### 注意事项 - 如果安装过程中遇到问题,可以参考SEAL的GitHub仓库中的[README](https://github.com/microsoft/SEAL)和[官方文档](https://github.com/microsoft/SEAL#building)- 对于Windows或macOS系统,安装步骤类似,但需要相应平台的编译环境和工具。 以上步骤提供了一个标准的安装流程。由于SEAL库的版本更新,具体细节可能会有变化,建议以官方最新文档为准。 [^1]: [探索SEAL可扩展加密库:同态加密的强大工具](https://example.com) (示例引用链接) [^2]: [SEAL全同态加密开源库() 安装与配置](https://example.com) (示例引用链接) [^3]: [2021SC@SDUSC-SEAL全同态加密库(六)](https://example.com) (示例引用链接) §§相关问题§§ 1. SEAL库支持哪些同态加密方案? 2. 如何验证SEAL库是否安装成功? 3. 在使用SEAL库时遇到编译错误应该如何处理? </think>以下是SEAL库(全同态加密库)的完整安装方法,基于官方文档和社区实践整理: --- ### 一、安装前提条件 1. **系统要求**:支持 Linux/macOS/Windows(推荐 Linux 系统) 2. **必要工具**: - CMake(≥3.10) - Git - C++17 兼容编译器(GCC ≥7.4.0 或 Clang ≥6.0) 3. **依赖库**: - CLT (Command Line Tools) - zlib(Ubuntu 安装:`$ sudo apt install zlib1g-dev`) --- ### 二、安装步骤(以 Ubuntu 为例) #### 步骤1:安装依赖项 ```bash sudo apt update sudo apt install -y cmake g++ build-essential git zlib1g-dev ``` #### 步骤2:克隆 SEAL 仓库 ```bash git clone https://github.com/microsoft/SEAL.git cd SEAL ``` #### 步骤3:编译安装 ```bash # 创建构建目录 cmake -S . -B build -DSEAL_USE_ZLIB=ON # 编译(启用多核加速) cmake --build build --parallel $(nproc) # 安装到系统目录 sudo cmake --install build ``` #### 步骤4:验证安装 创建测试文件 `test_seal.cpp`: ```cpp #include "seal/seal.h" int main() { seal::EncryptionParameters parms(seal::scheme_type::bfv); return 0; } ``` 编译测试: ```bash g++ test_seal.cpp -lseal-4.1 -o test_seal && ./test_seal ``` 无报错即安装成功[^2][^3]。 --- ### 三、Windows/macOS 特殊说明 1. **Windows**: - 需安装 [Visual Studio 2019+](https://visualstudio.microsoft.com/) - 使用 CMake GUI 配置项目时勾选 `SEAL_USE_ZLIB` 2. **macOS**: ```bash brew install cmake gcc zlib export CXX=/usr/local/bin/g++-11 # 指定新版本编译器 ``` --- ### 四、安装注意事项 1. **版本兼容性**:最新稳定版为 v4.1(2023年) 2. **常见错误解决**: - `找不到zlib`:添加 `-DZLIB_ROOT=/usr/lib` 到 CMake 命令 - `C++17 不兼容`:升级编译器或添加 `-DCMAKE_CXX_STANDARD=17` 3. **开发环境集成**: - CMake 项目中添加: ```cmake find_package(SEAL 4.1 REQUIRED) target_link_libraries(your_target PRIVATE SEAL::seal) ``` [^1]: SEAL 库通过加密保护数据同时保留计算能力,适用于云端隐私计算场景 [^2]: 安装需确保 C++17 兼容环境和 zlib 支持 [^3]: 全同态操作(如加法)通过密文直接计算实现隐私保护 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值