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

本文深入探讨了SEAL库中BFV和CKKS加密方案的旋转操作实现,包括行旋转和列旋转。通过示例代码详细解释了如何在加密数据上进行这些操作,并强调了旋转操作不消耗噪音预算的重要性。同时,介绍了CKKS方案中的复数向量旋转。

2021SC@SDUSC

2021-12-27

前言

本篇开始我将讨论SEAL中rotation.cpp的代码实现。

简介

BFV方案(使用BatchEncoder)和CKKS方案都支持对加密数字进行native计算。除了slot-wise计算外,还可以循环地旋转加密向量。

代码分析

void example_rotation_bfv()

先是和前文类似的设置一些参数。

    print_example_banner("Example: Rotation / Rotation in BFV");

    EncryptionParameters parms(scheme_type::bfv);

    size_t poly_modulus_degree = 8192;
    parms.set_poly_modulus_degree(poly_modulus_degree);
    parms.set_coeff_modulus(CoeffModulus::BFVDefault(poly_modulus_degree));
    parms.set_plain_modulus(PlainModulus::Batching(poly_modulus_degree, 20));

    SEALContext context(parms);
    print_parameters(context);
    cout << endl;

    KeyGenerator keygen(context);
    SecretKey secret_key = keygen.secret_key();
    PublicKey public_key;
    keygen.create_public_key(public_key);
    RelinKeys relin_keys;
    keygen.create_relin_keys(relin_keys);
    Encryptor encryptor(context, public_key);
    Evaluator evaluator(context);
    Decryptor decryptor(context, secret_key);

    BatchEncoder batch_encoder(context);
    size_t slot_count = batch_encoder.slot_count();
    size_t row_size = slot_count / 2;
    cout << "Plaintext matrix row size: " << row_size << endl;

    vector<uint64_t> pod_matrix(slot_count, 0ULL);
    pod_matrix[0] = 0ULL;
    pod_matrix[1] = 1ULL;
    pod_matrix[2] = 2ULL;
    pod_matrix[3] = 3ULL;
    pod_matrix[row_size] = 4ULL;
    pod_matrix[row_size + 1] = 5ULL;
    pod_matrix[row_size + 2] = 6ULL;
    pod_matrix[row_size + 3] = 7ULL;

    cout << "Input plaintext matrix:" << endl;
    print_matrix(pod_matrix, row_size);

首先,我们使用BatchEncoder将矩阵编码成明文。我们像往常一样加密明文。


                
<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、付费专栏及课程。

余额充值