【发布时间】:2014-11-01 12:53:35
【问题描述】:
我正在从事一个密码学项目。我们需要使用 NTL big num 库,特别是使用库的 CRT 函数来生成公钥。该库的CRT函数没有使用标准的中文剩余定理算法;这是一个修改版本,我无法准确理解它是如何工作的。
CRT(a,b,c,d)
据我所知,如果 a%b == c%d,CRT 会返回 1,但并非总是如此,因为我设置 b = 5、d = 6 和 a=c 是随机的以下结果1-6 之间的整数:
a%b: 3 c%d: 3 CRT: 1
a%b: 0 c%d: 5 CRT: 1
a%b: 2 c%d: 2 CRT: 0
a%b: 1 c%d: 1 CRT: 0
a%b: 4 c%d: 4 CRT: 1
a%b: 1 c%d: 0 CRT: 1
以下是库中 CRT 函数的代码。 ZZ 是用于表示大数的库特定类型。
long CRT(ZZ& gg, ZZ& a, const ZZ& G, const ZZ& p){
long modified = 0;
ZZ g;
if (!CRTInRange(gg, a)) {
modified = 1;
ZZ a1;
rem(g, gg, a); // g = gg%a
RightShift(a1, a, 1); // a1 = (a >> 1)
if (g > a1) sub(g, g, a);
}
else
g = gg;
ZZ p1;
RightShift(p1, p, 1);
ZZ a_inv;
rem(a_inv, a, p);
InvMod(a_inv, a_inv, p); // a_inv = a_inv^{-1} mod p, 0 <= a_inv < p
ZZ h;
rem(h, g, p);
SubMod(h, G, h, p); // return h = (G-h)%p
MulMod(h, h, a_inv, p); // return h = (h*a_inv)%p
if (h > p1)
sub(h, h, p);
if (h != 0) {
modified = 1;
ZZ ah;
mul(ah, a, h);
if (!IsOdd(p) && g > 0 && (h == p1))
sub(g, g, ah);
else
add(g, g, ah);
}
mul(a, a, p);
gg = g;
return modified;
}
以下是图书馆提供的唯一信息。我对离散数学不是很熟练。谁能通俗地解释一下这个函数的作用?
中文剩余。
这个版本是 v3.7 的新版本,并且显着 比以前的版本更简单、更快。
此函数将 g, a, G, p, 使得 a > 0, 0
正常使用下,输入值g满足-a/2
另外,在正常使用情况下,a 和 p 都是奇数;然而,常规 即使不是这样,它仍然可以工作。
该例程基于以下简单事实。
令 -a/2 0,则设置 g' := g - a h; 否则,设置 g' := g + a h。 那么这样定义的g'满足上述要求。 很容易看出 g 满足同余条件。 唯一的事情是检查“平衡”条件 -a'/2
【问题讨论】:
-
我真的很讨厌缩写:Cathode Ray Tube (terminal) (CRT), C Run Time library。
-
我写在第一段:中国剩余定理
标签: c++ cryptography