25 {
31
32#define a0 numa
33#define a1 (numa + n)
34#define a2 (numa + 2 * n)
35#define a3 (numa + 3 * n)
36#define b0 numb
37#define b1 (numb + n)
38#define b2 (numb + 2 * n)
39
40 n = 1 + (3 * na >= 4 * nb ? (na - 1) >> 2 : (nb - 1) / (
mp_size_t)3);
43
44 s = na - 3 * n;
45 t = nb - 2 * n;
46
49
50
51
52
54
55#define v0 dst
56#define vm1 (scratch)
57#define v1 (dst + 2 * n)
58#define vm2 (scratch + 2 * n + 1)
59#define v2 (scratch + 4 * n + 2)
60#define vinf (dst + 5 * n)
61#define bs1 dst
62#define bsm1 (scratch + 2 * n + 2)
63#define asm1 (scratch + 3 * n + 3)
64#define asm2 (scratch + 4 * n + 4)
65#define bsm2 (dst + n + 1)
66#define bs2 (dst + 2 * n + 2)
67#define as2 (dst + 3 * n + 3)
68#define as1 (dst + 4 * n + 4)
69
70
71
72
73#define a0a2 scratch
74#define b0b2 scratch
75#define a1a3 asm1
76#define b1d bsm1
77
78
80
81
85 if (t != n)
88
92 } else {
94 }
95
96
97
99
100
106 } else {
110 }
111
120
121
123
124
126
127
129
130
132
133
134 if (s > t)
136 else
138
139
141
143
145#undef v0
146#undef vm1
147#undef v1
148#undef vm2
149#undef v2
150#undef vinf
151#undef bs1
152#undef bs2
153#undef bsm1
154#undef bsm2
155#undef asm1
156#undef asm2
157#undef as1
158#undef as2
159#undef a0a2
160#undef b0b2
161#undef a1a3
162#undef b1d
163#undef a0
164#undef a1
165#undef a2
166#undef a3
167#undef b0
168#undef b1
169#undef b2
170}
#define lmmp_debug_assert(x)
#define lmmp_param_assert(x)
static mp_limb_t lmmp_add_(mp_ptr dst, mp_srcptr numa, mp_size_t na, mp_srcptr numb, mp_size_t nb)
大数加法静态内联函数 [dst,na]=[numa,na]+[numb,nb]
static int lmmp_cmp_(mp_srcptr numa, mp_srcptr numb, mp_size_t n)
大数比较函数(内联)
static mp_limb_t lmmp_add_1_(mp_ptr dst, mp_srcptr numa, mp_size_t na, mp_limb_t x)
大数加单精度数静态内联函数 [dst,na]=[numa,na]+x
void lmmp_mul_(mp_ptr dst, mp_srcptr numa, mp_size_t na, mp_srcptr numb, mp_size_t nb)
不等长大数乘法操作 [dst,na+nb] = [numa,na] * [numb,nb]
void lmmp_mul_n_(mp_ptr dst, mp_srcptr numa, mp_srcptr numb, mp_size_t n)
等长大数乘法操作 [dst,2*n] = [numa,n] * [numb,n]
mp_limb_t lmmp_shl_(mp_ptr dst, mp_srcptr numa, mp_size_t na, mp_size_t shl)
大数左移操作 [dst,na] = [numa,na]<<shl,dst的低shl位填充0
mp_limb_t lmmp_add_n_sub_n_(mp_ptr dsta, mp_ptr dstb, mp_srcptr numa, mp_srcptr numb, mp_size_t n)
同时执行n位加法和减法 ([dsta,n],[dstb,n]) = ([numa,n]+[numb,n],[numa,n]-[numb,n])
mp_limb_t lmmp_add_n_(mp_ptr dst, mp_srcptr numa, mp_srcptr numb, mp_size_t n)
无进位的n位加法 [dst,n] = [numa,n] + [numb,n]
#define SALLOC_TYPE(n, type)
void lmmp_toom_interp6_(mp_ptr dst, mp_size_t n, enum toom6_flags flags, mp_ptr w4, mp_ptr w2, mp_ptr w1, mp_size_t w0n)
Toom插值计算(6点插值):用于Toom-43和Toom-52 乘法算法
int lmmp_toom_eval_dgr3_pm2_(mp_ptr xp2, mp_ptr xm2, mp_srcptr xp, mp_size_t n, mp_size_t x3n, mp_ptr tp)
Toom-3 专用:3次多项式在 x = +2 和 x = -2 处求值 计算 P(+2) 和 P(-2),其中 P(x) 是一个3次多项式(4段系数)。
int lmmp_toom_eval_dgr3_pm1_(mp_ptr xp1, mp_ptr xm1, mp_srcptr xp, mp_size_t n, mp_size_t x3n, mp_ptr tp)
Toom-3 专用:3次多项式在 x = +1 和 x = -1 处求值 计算 P(+1) 和 P(-1),其中 P(x) 是一个3次多项式(4段系数)。