Level FHE 的高效实现 兼容 Level FHE 的高级算法

news2025/1/2 5:14:26

参考文献:

  1. [CS05] Choi Y, Swartzlander E E. Parallel prefix adder design with matrix representation[C]//17th IEEE Symposium on Computer Arithmetic (ARITH’05). IEEE, 2005: 90-98.
  2. [SV11] Smart N P, Vercauteren F. Fully homomorphic SIMD operations[J]. Designs, codes and cryptography, 2014, 71: 57-81.
  3. [GHS12] Gentry C, Halevi S, Smart N P. Fully homomorphic encryption with polylog overhead[C]//Annual International Conference on the Theory and Applications of Cryptographic Techniques. Berlin, Heidelberg: Springer Berlin Heidelberg, 2012: 465-482.
  4. [GHS12] Gentry C, Halevi S, Smart N P. Homomorphic evaluation of the AES circuit[C]//Annual Cryptology Conference. Berlin, Heidelberg: Springer Berlin Heidelberg, 2012: 850-867.
  5. [HS13] Halevi S, Shoup V. Design and implementation of a homomorphic-encryption library[J]. IBM Research (Manuscript), 2013, 6(12-15): 8-36.
  6. [ZQH+20] Zhang N, Qin Q, Hou Z, et al. Efficient comparison and addition for FHE with weighted computational complexity model[J]. IEEE Transactions on Computer-Aided Design of Integrated Circuits and Systems, 2020, 40(9): 1896-1908.

文章目录

  • Carry-Lookahead Adder
    • Ripple-Carry Adder
    • Carry-Lookahead Adder
    • Parallel-Prefix Adder
  • HE library
    • Double-CRT
    • New Key Switching in CRT
    • Modulus Switching in CRT
  • WCC
    • WCC Analysis
    • Dot Multiplication

Carry-Lookahead Adder

给定两个整数 A = a n − 1 ⋯ a 1 a 0 A=a_{n-1}\cdots a_1 a_0 A=an1a1a0 B = b n − 1 ⋯ b 1 b 0 B=b_{n-1}\cdots b_1 b_0 B=bn1b1b0,为了计算它们的加和,有多种加法器可以选择。我们使用以下逻辑符号:与门 ⋅ \cdot ,或门 + + +,异或门 ⊕ \oplus ,其中 ⋅ \cdot 的优先级最高。

全加器(Full Adder, FA)的输入 a , b , c i n ∈ { 0 , 1 } a,b,cin \in \{0,1\} a,b,cin{0,1},输出 s o u t , c o u t ∈ { 0 , 1 } sout,cout \in \{0,1\} sout,cout{0,1},逻辑表达式为:
s o u t = a ⊕ b ⊕ c i n c o u t = a ⋅ b + a ⋅ c i n + b ⋅ c i n \begin{aligned} sout &= a \oplus b \oplus cin\\ cout &= a \cdot b+a \cdot cin + b \cdot cin \end{aligned} soutcout=abcin=ab+acin+bcin

定义信号 g = a ⋅ b g=a \cdot b g=ab(generate), k = a + b k=a+b k=a+b(kill), p = a ⊕ b p=a \oplus b p=ab(propagate),那么
s o u t = p ⊕ c i n c o u t = g + k ⋅ c i n \begin{aligned} sout &= p \oplus cin\\ cout &= g+k \cdot cin \end{aligned} soutcout=pcin=g+kcin

Ripple-Carry Adder

行波进位加法器 (RCA):将 n n n 个全加器串联起来,输入 A , B , c 0 A,B,c_0 A,B,c0,迭代计算,
g i = a i ⋅ b i k i = a i + b i p i = a i ⊕ b i s i = p i ⊕ c i c i + 1 = g i + k i ⋅ c i \begin{aligned} g_i &= a_i \cdot b_i\\ k_i &= a_i + b_i\\ p_i &= a_i \oplus b_i\\\\ s_i &= p_i \oplus c_i\\ c_{i+1} &= g_i+k_i \cdot c_i \end{aligned} gikipisici+1=aibi=ai+bi=aibi=pici=gi+kici

关键路径的长度就是进位链 c 1 , ⋯   , c n − 1 , c n c_1,\cdots,c_{n-1},c_n c1,,cn1,cn 的迭代轮数 O ( n ) O(n) O(n)

Carry-Lookahead Adder

超前进位加法器(CLA):将 RCA 的进位链不断展开,得到
c i + 1 = g i + k i ⋅ ( g i − 1 + k i − 1 ⋅ ( g i − 2 + ⋯   ) ) = g i + ∑ j = 0 i − 1 ( ∏ l = j + 1 i k l ) g j + c 0 ∏ l = 0 i k l \begin{aligned} c_{i+1} &= g_i+k_i \cdot (g_{i-1}+k_{i-1} \cdot (g_{i-2} + \cdots))\\ &= g_i + \sum_{j=0}^{i-1} \left(\prod_{l=j+1}^i k_l\right)g_j + c_0\prod_{l=0}^i k_l \end{aligned} ci+1=gi+ki(gi1+ki1(gi2+))=gi+j=0i1 l=j+1ikl gj+c0l=0ikl

所以进位信号 c i + 1 c_{i+1} ci+1 可以直接根据 ( g i , k i ) (g_i,k_i) (gi,ki) 信号计算出来,不必等待 c i c_{i} ci 信号。关键路径长度仅为 O ( log ⁡ n ) O(\log n) O(logn),但是扇入扇出系数极高。为了平衡计算延迟和电路复杂度,可以使用[分块/分级的超前进位](【硬件算术设计】硬件加法器原理|第2章:超前进位加法器,分块、分级超前进位加法器 - 知乎 (zhihu.com))。

Parallel-Prefix Adder

并行前缀加法器(PPA):为了更好的理解 CLA,可以用代数语言描述 ( g i , k i ) (g_i,k_i) (gi,ki) 信号的合并过程。我们定义有序对 ( g , k ) (g,k) (g,k) 上的二元运算 ∘ \circ 如下:
( g j ,    k j ) ∘ ( g i ,    k i ) : = ( g j + k j g i ,    k i k j ) (g_j,\,\, k_j) \circ (g_i,\,\, k_i) := (g_j+k_jg_i,\,\, k_ik_j) (gj,kj)(gi,ki):=(gj+kjgi,kikj)

容易验证,它是:结合的、幂等的、不交换的。

那么 CLA 的逻辑表达式可以重写为:
( c i + 1 ,    k 0 k 1 ⋯ k i ) = ( g i + k i ⋅ ( g i − 1 + k i − 1 ⋅ ( g i − 2 + ⋯   ) ) ,    k i ⋯ k 1 k 0 ) = ( g i , k i ) ∘ ( g i − 1 , k i − 1 ) ∘ ⋯ ∘ ( g 0 , k 0 ) ∘ ( c 0 , 1 ) \begin{aligned} (c_{i+1},\,\, k_0k_1\cdots k_i) &= (g_i+k_i \cdot (g_{i-1}+k_{i-1} \cdot (g_{i-2} + \cdots)),\,\, k_i\cdots k_1 k_0)\\ &= (g_i,k_i) \circ (g_{i-1},k_{i-1}) \circ \cdots \circ (g_0,k_0) \circ (c_0,1) \end{aligned} (ci+1,k0k1ki)=(gi+ki(gi1+ki1(gi2+)),kik1k0)=(gi,ki)(gi1,ki1)(g0,k0)(c0,1)

其中的每个信号 ( g i , k i ) (g_i,k_i) (gi,ki) ( c 0 , 1 ) (c_0,1) (c0,1) 都是立即的。根据二元运算的结合律,可以设计出一族 ( g , k ) (g,k) (g,k) 信号的并行合并网络。Knowles 提出了一类深度最优的并行前缀加法器,电路的构造为:

在这里插入图片描述

Knowles Adder 以两种著名的 PPA 为极限:Kogge-Stone Adder, Ladner-Fischer Adder。其中 LF 结构需要无限扇出(适合 FHE 运算),而 KS 结构需要无限并行(乘法数量)。Brent-Kung Adder 通过提升 level 层数(乘法深度)来平衡扇出系数和运算单元数量,还有一些 Hybrid Schemes 混合了 KS, LF, BK 结构。

我们用 Parallel-Prefix Graghs 来简化表示 PPA,每个黑点表示二元运算 ∘ \circ 运算(两次乘法,一次加法),运算方向从下往上。不同扇出的 Knowles Adder:

在这里插入图片描述

最适合 FHE 运算的 PPA 就是 Ladner-Fischer Adder:我们的软实现不关心扇出系数,重点关注的是乘法深度和乘法数量。

HE library

Double-CRT

[HS13] 基于 C++ NTL 设计了 RLWE-BGV 的代码实现库 HElib,使用了 [SV11] 的 SIMD 技术,以及 [GHS12] 的 Permuting/Routing 技术。

为了进一步加速,[HS13] 将环 Z q [ x ] / ϕ m ( x ) \mathbb Z_q[x]/\phi_m(x) Zq[x]/ϕm(x) 中的多项式,表示为了 double-CRT 形式。在 BGV 中使用了 chain of moduli, q l = ∏ i = 0 l p i q_l = \prod_{i=0}^l p_i ql=i=0lpi,其中 p i p_i pi 是大小近似的素数,并且满足 m ∣ p i − 1 m|p_i-1 mpi1 使得 Z p i \mathbb Z_{p_i} Zpi 中存在 m m m 次本原单位根 ζ i \zeta_i ζi,于是 ϕ m ( x ) = ∏ j ∈ Z m ∗ ( x − ζ i j ) ( m o d p i ) \phi_m(x)=\prod_{j \in \mathbb Z_m^*}(x-\zeta_i^j) \pmod{p_i} ϕm(x)=jZm(xζij)(modpi)

我们先对模数 q l q_l ql 做 CRT 分解,简记 R = Z [ x ] / ϕ m ( x ) R = \mathbb Z[x]/\phi_m(x) R=Z[x]/ϕm(x) R p = R / ( p R ) R_{p}=R/(pR) Rp=R/(pR)
Z q l [ x ] / ϕ m ( x ) ≅ R / ( q l R ) ≅ R / ( p 0 R ) × R / ( p 1 R ) × ⋯ × R / ( p l R ) Z_{q_l}[x]/\phi_m(x) \cong R/(q_lR) \cong R/(p_0R) \times R/(p_1R) \times \cdots \times R/(p_lR) Zql[x]/ϕm(x)R/(qlR)R/(p0R)×R/(p1R)××R/(plR)

然后对于每个小环 R p i ≅ Z p i [ x ] / ϕ m ( x ) R_{p_i} \cong \mathbb Z_{p_i}[x]/\phi_m(x) RpiZpi[x]/ϕm(x) 继续做 CRT 分解,
Z p i [ x ] / ϕ m ( x ) ≅ Z p i [ x ] / ( x − ζ i j 1 ) × ⋯ × Z p i [ x ] / ( x − ζ i j ϕ ( m ) ) , j t ∈ Z m ∗ \mathbb Z_{p_i}[x]/\phi_m(x) \cong \mathbb Z_{p_i}[x]/(x-\zeta_i^{j_1}) \times \cdots \times Z_{p_i}[x]/(x-\zeta_i^{j_{\phi(m)}}), j_t \in \mathbb Z_m^* Zpi[x]/ϕm(x)Zpi[x]/(xζij1)××Zpi[x]/(xζijϕ(m)),jtZm

假设 m = 2 k m=2^k m=2k 使得 ϕ m ( x ) = x m + 1 \phi_m(x)=x^m+1 ϕm(x)=xm+1,那么 Z m ∗ = { 1 , 3 , 5 , ⋯   , m − 1 } \mathbb Z_m^*=\{1,3,5,\cdots,m-1\} Zm={1,3,5,,m1},可以使用 FFT/NTT 来快速计算。对于一般的 m m m(混杂的 radix-X),在 Z m ∗ \mathbb Z_m^* Zm 中的数字分布不规律,系数表示到 Double-CRT 之间的转化较为复杂。

综上,给定模数 q l q_l ql 对应 level 的环元素 a ∈ Z q l [ x ] / ϕ m ( x ) a \in Z_{q_l}[x]/\phi_m(x) aZql[x]/ϕm(x),可以表示为矩阵形式:第 i i i 行是 a ( x ) ( m o d p i ) a(x) \pmod{p_i} a(x)(modpi) 的 NTT 域,第 i i i 行第 j j j 列是元素 a ( ζ i j ) ( m o d p i ) a(\zeta_i^j) \pmod{p_i} a(ζij)(modpi),形状 ( l + 1 ) × ϕ ( m ) (l+1) \times \phi(m) (l+1)×ϕ(m)
D o u b l e C R T l ( a ) = { a ( x ) ( m o d p i ) ( m o d x − ζ i j ) } 0 ≤ i ≤ l ,    j ∈ Z m ∗ = { a ( ζ i j ) ( m o d p i ) } 0 ≤ i ≤ l ,    j ∈ Z m ∗ \begin{aligned} DoubleCRT^l(a) &= \{a(x) \pmod{p_i}\pmod{x-\zeta_i^j}\}_{0\le i\le l,\,\, j\in \mathbb Z_m^*}\\ &= \{a(\zeta_i^j) \pmod{p_i}\}_{0\le i\le l,\,\, j\in \mathbb Z_m^*}\\ \end{aligned} DoubleCRTl(a)={a(x)(modpi)(modxζij)}0il,jZm={a(ζij)(modpi)}0il,jZm

容易验证,环元素的加法/乘法,就是矩阵的 component-wise 加法/乘法
D o u b l e C R T l ( a + b ) = D o u b l e C R T l ( a ) + D o u b l e C R T l ( a ) D o u b l e C R T l ( a ⋅ b ) = D o u b l e C R T l ( a ) ⋅ D o u b l e C R T l ( a ) \begin{aligned} DoubleCRT^l(a+b) &= DoubleCRT^l(a) + DoubleCRT^l(a)\\ DoubleCRT^l(a \cdot b) &= DoubleCRT^l(a) \cdot DoubleCRT^l(a)\\ \end{aligned} DoubleCRTl(a+b)DoubleCRTl(ab)=DoubleCRTl(a)+DoubleCRTl(a)=DoubleCRTl(a)DoubleCRTl(a)

另外 Galois 群 G a l ( Q ( ζ ) / Q ) ≅ Z m ∗ \mathcal{Gal}(\mathbb Q(\zeta)/\mathbb Q) \cong \mathbb Z_m^* Gal(Q(ζ)/Q)Zm 中的自同构映射为
κ k ( a ( x ) ) : = a ( x k ) ( m o d ϕ m ( x ) ) ,    ∀ k ∈ Z m ∗ \kappa_k(a(x)):=a(x^k) \pmod{\phi_m(x)},\,\, \forall k \in \mathbb Z_m^* κk(a(x)):=a(xk)(modϕm(x)),kZm

映射 κ k : ζ ↦ ζ k \kappa_k:\zeta \mapsto \zeta^{k} κk:ζζk 就等价于:把矩阵 D o u b l e C R T l ( a ) DoubleCRT^l(a) DoubleCRTl(a) 的第 j j j 列,移动到第 j k ( m o d m ) jk \pmod m jk(modm) 列。所以在 Double-CRT 表示上 Routing 是容易实现的

New Key Switching in CRT

秘钥切换本质上是关于 E n c ( s ) Enc(s) Enc(s)同态数乘运算 L s ( c ) L_s(c) Ls(c),但是密文作为标量的范数相对于模数 q l q_l ql 过大,导致同态运算后的噪声项破坏了明文。

在 BGV 中,为了控制秘钥切换的噪声项,使用的是二进制分解方案:给定 s ′ s' s 下的密文 c ′ c' c,计算 c ′ = ∑ i 2 i c i ′ c'=\sum_i 2^i c_i' c=i2ici,令
c ∗ = c 0 ′ ∣ c 1 ′ ∣ c 2 ′ ∣ ⋯   ,    s ∗ = s ′ ∣ 2 s ′ ∣ 4 s ′ ∣ ⋯ c^*=c_0'|c_1'|c_2'|\cdots,\,\, s^*=s'|2s'|4s'|\cdots c=c0c1c2,s=s∣2s∣4s

那么计算出矩阵 W = W [ s ∗ → s ] W=W[s^* \to s] W=W[ss],它满足 s ∗ = W ⋅ s s^*=W \cdot s s=Ws,那么计算密文 c = c ∗ ⋅ W c=c^* \cdot W c=cW
⟨ c ′ , s ′ ⟩ = ⟨ c ∗ , s ∗ ⟩ = ⟨ c , s ⟩ \langle c', s' \rangle = \langle c^*, s^* \rangle = \langle c, s \rangle c,s=c,s=c,s

为了计算 c ′ c' c 的二进制分解,首先需要把 Double-CRT 转换回系数表示。接着,再把 log ⁡ q l \log q_l logql 个密文 c i ′ c_i' ci 分别转化到 Double-CRT 下,以执行解密的内积运算。这花费了 O ( l log ⁡ q l ) O(l \log q_l) O(llogql) 个长度为 n = ϕ ( m ) n=\phi(m) n=ϕ(m) 的 FFT/NTT 运算。

[GHS12] 使用了不同的噪声项控制技术:临时提升模数。使用 LSB 编码方案,假设 ⟨ c ′ , s ′ ⟩ = 2 e ′ + a ( m o d q ) \langle c',s' \rangle=2e'+a \pmod q c,s=2e+a(modq),对于任意的奇数 p p p,都有
⟨ c ′ , p s ′ ⟩ = 2 p e ′ + p a = 2 e ′ ′ + a ( m o d p q ) \langle c',ps' \rangle = 2pe'+pa = 2e''+a \pmod{pq} c,ps=2pe+pa=2e′′+a(modpq)

其中 e ′ ′ = p e ′ + a ( p − 1 ) / 2 e'' = pe'+a(p-1)/2 e′′=pe+a(p1)/2 大约是原始噪声 e ′ e' e p p p 倍。只要执行模切换,回到模数 q q q,那么噪声就基本还是 e ′ e' e 的量级。因此,我们选取充分大的奇数 p ≈ q m p \approx q\sqrt m pqm ,使用变换矩阵 W = W [ p s ′ → s ] W=W[ps' \to s] W=W[pss] 的密文作为秘钥切换辅助。

虽然不需要对 c ′ c' c 做二进制分解了,但是依然需要计算 c ′ ( m o d p ) c' \pmod p c(modp) 以组成 Z p q [ x ] / ϕ m ( x ) \mathbb Z_{pq}[x]/\phi_m(x) Zpq[x]/ϕm(x) 的 Double-CRT 表示。不过因为不需要维度扩展 log ⁡ q l \log q_l logql 倍,因此只需要 O ( l ) O(l) O(l) 个 FFT/NTT 运算。

注意,因为模数 p q ≥ q 2 pq \ge q^2 pqq2,使得 ratio of modulus/noise 变得很大,因此需要将格的维度 n = ϕ ( m ) n=\phi(m) n=ϕ(m) 扩大接近两倍,以维持安全强度。但是 FFT/NTT 的复杂度为 O ( n log ⁡ n ) O(n \log n) O(nlogn),因此计算效率依旧提升了大约 log ⁡ q l / 2 \log q_l/2 logql/2 因子,同时公钥的存储开销也更低。

也可以混合使用进制分解和提升模数:把密文 c ′ c' c 分解为 ∑ i D i c i ′ \sum_i D^ic_i' iDici,其中 D D D 是很大的 radix 使得 c i ′ c_i' ci 的个数很少;接着,对于每个 c i ′ c_i' ci 采取临时提升模数的方案。

Modulus Switching in CRT

我们希望除了某些必要的系数表示,将密文和秘钥始终保持在 Double-CRT 表示下,方便快速计算。从模数 q l = ∏ j = 0 l p j q_l=\prod_{j=0}^l p_j ql=j=0lpj 下的密文 c c c 切换到模数 q l − 1 = ∏ j = 0 l − 1 p j q_{l-1}=\prod_{j=0}^{l-1} p_j ql1=j=0l1pj 下的密文 c ′ c' c 时,保持 c ′ ≡ c ( m o d 2 ) c' \equiv c \pmod 2 cc(mod2),同时要求 “rounding error” τ = c ′ − c / p t \tau=c'-c/p_t τ=cc/pt 的范数很小。

因为 p l p_l pl 是奇素数,这只需计算出 c † = p l ⋅ c ′ c^\dagger = p_l \cdot c' c=plc,使得: p l ∣ c † p_l|c^\dagger plc c † ≡ c ( m o d 2 ) c^\dagger \equiv c \pmod 2 cc(mod2),并且 c † − c c^\dagger-c cc 的范数很小。然后输出 c ′ = c † / p l c'=c^\dagger/p_l c=c/pl 即可。在 Double-CRT 下的模切换算法为:

  1. 从 Double CRT 的最后一行中,计算出 c ˉ = c ( m o d p l ) \bar c=c \pmod{p_l} cˉ=c(modpl) 的系数表示,取值范围 [ − p l / 2 , p l / 2 ) [-p_l/2,p_l/2) [pl/2,pl/2),但是注意 c ˉ \bar c cˉ 属于 R q l R_{q_l} Rql
  2. c ˉ \bar c cˉ 的那些是奇数的系数,通过加减 p l p_l pl 变成偶数,取值范围 [ − p l , p l ) [-p_l,p_l) [pl,pl),得到小多项式 δ \delta δ,满足 δ ≡ c ( m o d p l ) \delta \equiv c \pmod{p_l} δc(modpl) 以及 δ ≡ 0 ( m o d 2 ) \delta \equiv 0 \pmod{2} δ0(mod2)
  3. 计算 δ \delta δ 的 Double CRT 表示,然后计算出 c † = c − δ ( m o d q l ) c^\dagger = c-\delta \pmod{q_l} c=cδ(modql),它满足 p l ∣ c † p_l|c^\dagger plc
  4. 对每个 c † ( m o d p j ) , j < l c^\dagger \pmod{p_j}, j<l c(modpj),j<l,通过计算 p l − 1 ⋅ c † ( m o d p j ) p_l^{-1} \cdot c^\dagger \pmod{p_j} pl1c(modpj),获得 c ′ = c † / p l c'=c^\dagger/p_l c=c/pl 的 Double-CRT 表示

上述过程中,step 1 花费了 1 1 1 个 INTT,step 3 花费了 l l l 个 NTT,共计 O ( l ) O(l) O(l) 个长度为 n = ϕ ( m ) n=\phi(m) n=ϕ(m) 的 FFT/NTT 运算。

WCC

在 Level FHE 的高层应用中,可以使用乘法数量、乘法深度来衡量算法的效率。然而许多工作中,人们往往只关注某一方面,而非综合考量,因此设计出的高级算法并不一定适合在 level FHE 上做计算。

[ZQH+20] 提出了 Weighted Computational Complexity(WCC)计算模型,复杂度定义为
W C C = ∑ l = 0 L W l ⋅ N l WCC = \sum_{l=0}^L W_l \cdot N_l WCC=l=0LWlNl

其中 N l N_l Nl 是第 l l l 层的乘法数量, W l W_l Wl 是第 l l l 层的乘法开销(若 W l = 1 , ∀ l W_l=1,\forall l Wl=1,l 则只关注乘法数量,若 W l = 0 , l < L W_l=0,l<L Wl=0,l<L 则只关注乘法深度)。根据 [GHS12] 的 Double-CRT 下的秘钥切换、模切换,开销为 O ( l ) O(l) O(l) 个长度 n = ϕ ( m ) n=\phi(m) n=ϕ(m) 的 NTT/FFT 运算。因此,忽略繁复的细节,粗略地选取权重为 W l = l + 1 , l ≥ 0 W_l = l+1, l\ge 0 Wl=l+1,l0,这是合适的,且足够指导我们设计更加适合 level FHE 的高级算法。

WCC Analysis

[ZQH+20] 分析了整数比较、整数加法的 WCC 复杂度。

三种比较算法,

  1. Linear Comparison (LinC),线性比较
    c o m i = ( a i ⊕ 1 ) ⋅ b i ⊕ ( a i ⊕ b i ⊕ 1 ) ⋅ c o m i − 1 com_i=(a_i\oplus 1) \cdot b_i \oplus (a_i\oplus b_i\oplus 1) \cdot com_{i-1} comi=(ai1)bi(aibi1)comi1

    最终输出 C O M ( A , B ) = c o m n − 1 COM(A,B)=com_{n-1} COM(A,B)=comn1,可计算出 W C C = O ( n 2 ) WCC=O(n^2) WCC=O(n2)

  2. Iteration Comparison (IterC),分治算法
    t i , 1 = ( a i ⊕ 1 ) ⋅ b i ,    z i , 1 = a i ⊕ b i ⊕ 1 t i j = t i + h , j − h + z i + h , j − h ⋅ t i , h ,    j > 1 ,    h = ⌈ j / 2 ⌉ t_{i,1} = (a_i \oplus 1)\cdot b_i,\,\, z_{i,1}=a_i\oplus b_i \oplus 1\\ t_{ij}=t_{i+h,j-h}+z_{i+h,j-h} \cdot t_{i,h},\,\, j>1,\,\, h=\lceil j/2 \rceil ti,1=(ai1)bi,zi,1=aibi1tij=ti+h,jh+zi+h,jhti,h,j>1,h=j/2

    最终输出 C O M ( A , B ) = t 0 , n COM(A,B)=t_{0,n} COM(A,B)=t0,n,它的 WCC 通项公式较为复杂难以写出

  3. Logarithm Comparison (LogC),将线性比较完全展开
    d i = ( a i ⊕ 1 ) ⋅ b i ,    z i = a i ⊕ b i ⊕ 1 c i = d i ⋅ ∏ j = i + 1 n − 1 z j d_i=(a_i \oplus 1) \cdot b_i,\,\, z_i=a_i \oplus b_i \oplus 1\\ c_i = d_i \cdot \prod_{j=i+1}^{n-1} z_j di=(ai1)bi,zi=aibi1ci=dij=i+1n1zj

    最终输出 C O M ( A , B ) = ∑ i = 0 n − 1 c i COM(A,B) = \sum_{i=0}^{n-1}c_i COM(A,B)=i=0n1ci,使用二叉树计算 ∏ j = 1 n − 1 z j \prod_{j=1}^{n-1} z_j j=1n1zj,其他的 ∏ j = i + 1 n − 1 z j \prod_{j=i+1}^{n-1} z_j j=i+1n1zj 是这个二叉树的某些中间结果的乘积(总的乘法数量为 O ( n log ⁡ n ) O(n \log n) O(nlogn) 而非 O ( n ) O(n) O(n))。它的 W C C = O ( n log ⁡ 2 n ) WCC=O(n \log^2 n) WCC=O(nlog2n)

两种整数加法,

  1. Ripple-Carry Adder,可计算出 W C C = O ( n 2 ) WCC=O(n^2) WCC=O(n2),隐藏的常数比 LinC 更大
  2. Parallel-Prefix Adder,可计算出 W C C = O ( n log ⁡ 2 n ) WCC=O(n \log^2 n) WCC=O(nlog2n),隐藏的常数比 LogC 更大

Dot Multiplication

类似于 PPA 的二元运算,[ZQH+20] 定义了 DotMC,
( P 1 ,    G 1 ) ∘ ( P 0 ,    G 0 ) = ( P 1 + G 1 ⋅ P 0 ,    G 1 ⋅ G 0 ) (P_1,\,\,G_1) \circ (P_0,\,\,G_0) = (P_1+G_1 \cdot P_0,\,\, G_1 \cdot G_0) (P1,G1)(P0,G0)=(P1+G1P0,G1G0)

简记 A d d [ ( P , G ) ] = P + G Add[(P,G)]=P+G Add[(P,G)]=P+G 是最终信号的合并操作。定义初始信号 p i = ( a i ⊕ 1 ) ⋅ b i , 0 ≤ i ≤ n − 1 p_i=(a_i \oplus 1) \cdot b_i, 0 \le i \le n-1 pi=(ai1)bi,0in1,以及 g i = a i ⊕ b i ⊕ 1 , 1 ≤ i ≤ n − 1 g_i=a_i \oplus b_i \oplus 1,1\le i \le n-1 gi=aibi1,1in1 g 0 = 0 g_0=0 g0=0,那么有:
C O M ( A , B ) = ( a n − 1 ⊕ 1 ) ⋅ b n − 1 ⊕ ( a n − 1 ⊕ b n − 1 ⊕ 1 ) ⋅ c o m n − 2 = A d d [ ( p n − 1 , g n − 1 ) ∘ ( p n − 2 , g n − 2 ) ∘ ⋯ ∘ ( p 0 , g 0 ) ] \begin{aligned} COM(A,B) &= (a_{n-1}\oplus 1) \cdot b_{n-1} \oplus (a_{n-1}\oplus b_{n-1}\oplus 1) \cdot com_{n-2}\\ &= Add\left[(p_{n-1},g_{n-1}) \circ (p_{n-2},g_{n-2}) \circ \cdots \circ (p_0,g_0)\right] \end{aligned} COM(A,B)=(an11)bn1(an1bn11)comn2=Add[(pn1,gn1)(pn2,gn2)(p0,g0)]

因为 DotMC 运算是结合的,因此可以使用二叉树方式,并行地合并信号

在这里插入图片描述

可以计算出 W C C = O ( n log ⁡ n ) WCC=O(n \log n) WCC=O(nlogn),乘法数量 O ( n ) O(n) O(n),乘法深度 O ( log ⁡ n ) O(\log n) O(logn)。对比下 LogC 的乘法数量为 O ( n log ⁡ n ) O(n \log n) O(nlogn),计算复杂度为 W C C = O ( n log ⁡ 2 n ) WCC=O(n \log^2 n) WCC=O(nlog2n)

而 CLA 本身就是使用了 DotMC,不过它的某一些 DotMC 可以延迟计算,平移到更低的 level 上计算,使得 W l W_l Wl 更小。

原始的 CLA 电路为:

在这里插入图片描述

把一些 DotMC 移动(绿色的那些点),

在这里插入图片描述

论文指出当 n > 16 n>16 n>16 时,DotMC 的比较和 OptCLA 更加高效,并且随着 n n n 增大效果更好。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1039936.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于微信小程序的校园商铺系统设计与实现(源码+lw+部署文档+讲解等)

文章目录 前言学生端微信端&#xff0c;主要功能有&#xff1a;商家的主要功能有&#xff1a;管理员的主要功能有&#xff1a;具体实现截图论文参考详细视频演示为什么选择我自己的网站自己的小程序&#xff08;小蔡coding&#xff09;有保障的售后福利 代码参考源码获取 前言 …

商家收款2000手续费多少

目前不管是微信商户或者支付宝商户最低费率可以达到0.2%费率&#xff1b;市面上普通个体商户或者企业商家的收款费率一般在0.6左右&#xff0c;一些使用第三方聚合支付平台的也有使用0.38的&#xff0c;总体也就是10000块钱的费率是38-60块钱&#xff0c;对于一些流水比较大的商…

微调大模型工具-LoRA

介绍 微调 在机器学习领域&#xff0c;大型模型已成为解决各种问题的首选解决方案。从自然语言处理到计算机视觉&#xff0c;这些计算能力的庞然大物都表现出了无与伦比的性能。然而&#xff0c;这种性能实际上是有代价的。微调这些大型模型以适应特定任务或领域是一个资源密…

GE IS220PVIBH1A 336A4940CSP16 电源模块

GE IS220PVIBH1A 336A4940CSP16 电源模块是通用电气&#xff08;GE&#xff09;的一种电源模块&#xff0c;用于工业控制和电力系统中&#xff0c;提供电源供应和保护功能。以下是这种类型电源模块的一般特点和功能&#xff1a; 电源供应&#xff1a;GE IS220PVIBH1A 336A4940C…

编写基于冒泡排序算法的qsort函数

目录 1.简单认识冒泡排序 2.进入正文分析如何实现函数 3.1比较两个相邻元素的大小 3.2比较两个相邻元素大小后要换函数 4.my_qsort函数&#xff1a; 5.总结&#xff1a; 1.简单认识冒泡排序 冒泡排序的步骤如下&#xff1a; 比较相邻的两个元素&#xff0c;如果第一个元素比…

TS编译选项——不允许使用隐式any类型、不明确类型的this、严格检查空值、编译后文件自动设置严格模式

一、不允许使用隐式any类型 在tsconfig.js文件中配置noImplicitAny属性 {"compilerOptions": {// 不允许使用隐式any类型"noImplicitAny": true} } 开启后即可禁止使用隐式的any类型 注意&#xff1a;显式的any类型并不会被禁止 二、不允许使用不明确类…

亚马逊儿童自行车,滑板车等电动移动设备合规标准UL报告如何办理?UL 2272、UL 2849

加拿大 儿童自行车 儿童自行车适用于 14 岁以下儿童。儿童自行车的车轮由两个轮子组成&#xff0c;一个在另一个后面&#xff0c;通过踩踏推动&#xff0c;用连接在前轮上的车把操纵。其中一些可能配备有训练轮&#xff0c;这是一对平行于后轮的额外的车轮&#xff0c;可防止自…

ShapeableImageView 不只是圆形ImageView

偶然间看到了这位老哥的 https://juejin.cn/post/6869376452040196109#comment 文章&#xff0c;发现了ShapeableImageView–一个多形状的ImageView &#xff0c;虽然似乎发布了很久了&#xff0c;现在学习不晚。 效果图 布局文件 <com.google.android.material.imageview.S…

yyyy/MM/dd与yyyy-MM-dd使用new Date().getTime()时间转换不相等?!!

起源 该问题发现于日期组件增加国家法定假节假日的禁用&#xff0c;通过pickerOptions属性定义disabledDate方法实现 export default {data () {return {holidayList: [2023-01-01,2023-01-02,2023-01-21,2023-01-22,2023-01-23,2023-01-24,2023-01-25,2023-01-26,2023-01-27…

SQL注入——预编译CASE注入

文章目录 预编译 CASE 注入1. SQL注入漏洞防御2. WEBGOAT SQL注入2.1 WebGoat 8.02.2 Order by 注入2.2.1 构造 when 的条件2.2.2 代码审计 预编译 CASE 注入 预编译 CASE&#xff08;Prepared CASE&#xff09;是一种数据库查询语言&#xff08;如SQL&#xff09;中的控制语句…

Android Studio 的android.jar文件在哪儿

一般在&#xff1a;C:\Users\admin\AppData\Local\Android\Sdk\platforms\android-33下&#xff08;不一定是33&#xff0c;这个得看你Android Studio->app->builde.gradle的targetSdk是多少&#xff09; 怎么找&#xff1a; 1.打开Android Studio 粘贴地址后&#xff0…

【C++】stack queue

stack & queue 一、容器适配器二、deque&#xff08;了解&#xff09;三、stack1. stack 的介绍2. 模拟实现 stack 四、queue1. queue 的使用2. 模拟实现 queue3. priority_queue&#xff08;1&#xff09;priority_queue 的介绍&#xff08;2&#xff09;priority_queue 的…

数字IC笔试千题解--单选题篇(二)

前言 出笔试题汇总&#xff0c;是为了总结秋招可能遇到的问题&#xff0c;做题不是目的&#xff0c;在做题的过程中发现自己的漏洞&#xff0c;巩固基础才是目的。 所有题目结果和解释由笔者给出&#xff0c;答案主观性较强&#xff0c;若有错误欢迎评论区指出&#xff0c;资料…

如何通过Python实现接口自动化的参数关联?

前言 通常在接口自动化中&#xff0c;经常会参数关联的问题&#xff0c;那么什么是参数关联&#xff1f; 参数关联就是上一个接口的返回值会被下一个接口当做参数运用&#xff0c;其中Python中可以实现参数关联的方法有很多种&#xff0c;今天小编给大家介绍下&#xff0c;如…

IC验证| Verilog语法详解之条件语句

Verilog 是一种用于数字逻辑电路设计的硬件描述语言&#xff0c;可以用来进行数字电路的仿真验证、时序分析、逻辑综合。 既是一种行为级&#xff08;可用于电路的功能描述&#xff09;描述语言又是一种结构性&#xff08;可用于元器件及其之间的连接&#xff09;描述语言。 …

RedisTemplate出现\xac\xed\x00\x05t\x00\x0f前缀解决

问题描叙 出现这种乱码前缀的原因是没有进行序列化&#xff0c;因此导致在传输过程出现乱码问题&#xff0c;存到数据库&#xff0c;发现 key,hash key/value 都有 \xAC\xED\x00\x05t\x00 前缀。RedisTemplate类中默认是没有设置序列化的。 解决方法 设置RedisTemplate的序列…

如何快速建立一个专业、高效的宠物医院小程序?

随着社会的发展和科技的进步&#xff0c;人们对于宠物的关注度越来越高&#xff0c;养宠物已经成为了许多人的生活方式。然而&#xff0c;宠物的健康问题也随之而来&#xff0c;宠物医院成为了不可或缺的存在。为了更好地服务于宠物主人&#xff0c;打造一个专属的宠物医院线上…

IntelliJ IDEA 左侧Commit栏不见了

1.点击File->Settings->Version Control->Commit 2.勾选Use non-modal commit interface

关于ElementUI之首页导航与左侧菜单实现

目录 一.Mock 1.1.什么是Mock.js 1.2.特点 1.3.安装与配置 1.3.1. 安装mock.js 1.3.2.引入mock.js 1.4.mockjs使用 1.4.1.定义测试数据文件 1.4.2.mock拦截Ajax请求 1.4.3.界面代码优化 二.总线 2.1.是什么 2.2.前期准备 2.3.配置组件与路由关系 2.3.1. 配置组件 …