使用HElib进行比较
Getting comparisons using HElib?
我正在尝试对密文进行比较。给定两个值为p1=p2 = 1
的密文c1
和c2
,指令c1 == c2
或c1.equalsTo(c2)
总是给出false
。我怎么解决这个问题?
是否有可能在两个密文上以(c1 < c2)
的形式进行大于比较?
假设我有两个密文c1
和c2
分别用于纯文本p1
, p2
,我如何使用HElib比较它们,任何一个为我提供源代码或工作逻辑?
不可以,在HElib中不能直接比较两个密文。
这是由于在HElib中使用的加密系统。然而,即使没有详细说明这一点,也可以说没有公钥密码系统(HElib是公钥)可以支持像c1 < c2
这样返回未加密布尔值的操作,因为这将使攻击者能够轻松地通过加密新值和比较来找到任何密文的明文。
如果你想在HElib中进行比较,你需要将整个程序表示为具有单独加密位的二进制电路。然后你可以实现条件分支作为多路复用。这不仅是繁琐的,而且通常太慢(HElib不是一个快速的加密系统)对于任何'真正的'程序。
相关文章:
- 比较并显示使用最小值(a,b)和最大值(a、b)升序排列的4个数字
- 为什么比较运算符如此快速
- 我可以使用 g++ 进行三种比较 (<=>) 吗?
- 比较字符数组
- 将模板化的类型与C++中的某些类/类型进行比较
- C++自定义比较函数
- 如何比较自定义类的std::变体
- 多个If语句与使用逻辑运算符计算条件的单个语句的比较
- std::设置自定义比较器
- 布尔比较运算符是如何在C++中工作的
- C++将目录中的所有文件与::filesystem进行比较
- shell排序中的交换和比较
- 如何在C++中比较两个char数组
- catch框架有没有办法比较流或文件
- 从文件中读取多个字节,并将它们存储在C++中进行比较
- 智能指针作为无序映射键,并通过引用进行比较
- 比较if语句中的数组值和int值
- 对于循环变体比较
- 使用自定义比较函数使用std::sort()对矢量字符串进行排序时出现问题
- 使用HElib进行比较