26 {
37
38#define a0 numa
39#define a1 (numa + n)
40#define a2 (numa + 2 * n)
41#define a3 (numa + 3 * n)
42#define a4 (numa + 4 * n)
43#define b0 numb
44#define b1 (numb + n)
45#define b2 (numb + 2 * n)
46
49 s = na - 4 * n;
50 t = nb - 2 * n;
51
54 tmp += n + 1;
56 tmp += n + 1;
58 tmp += n + 1;
60 tmp += n + 1;
61 ash = tmp;
62 tmp += n + 1;
64 tmp += n + 1;
66 tmp += n + 1;
68 tmp += n + 1;
70 tmp += n + 1;
71 bsh = tmp;
72 tmp += n + 1;
73
74 gp = dst;
75
76
78
79
81
82
83
87 if (s < n) {
90 ash[n] = 2 * cy +
lmmp_shl_(ash + s, ash + s, n - s, 1);
92 } else
94
95
96
102 } else {
106 }
107
108
109
113
115
119 } else {
121 }
122
123
124
126 if (t < n) {
129 bsh[n] = 2 * cy +
lmmp_shl_(bsh + t, bsh + t, n - t, 1);
131 } else
133
144
145#define v0 dst
146#define v1 (dst + 2 * n)
147#define vinf (dst + 6 * n)
148#define v2 scratch
149#define vm2 (scratch + 2 * n + 1)
150#define vh (scratch + 4 * n + 2)
151#define vm1 (scratch + 6 * n + 3)
152#define scratch_out (scratch + 8 * n + 4)
153
154
155
156
160
161
164
165
166
169
170
172
173
174 if (s > t)
176 else
178
180
182}
#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)
大数比较函数(内联)
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_addshl1_n_(mp_ptr dst, mp_srcptr numa, mp_srcptr numb, mp_size_t n)
加法结合左移1位操作 [dst,n] = [numa,n] + ([numb,n] << 1)
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])
#define lmmp_inc_1(p, inc)
大数加指定值宏(预期无进位)
#define SALLOC_TYPE(n, type)
int lmmp_toom_eval_pm2_(mp_ptr xp2, mp_ptr xm2, unsigned k, mp_srcptr xp, mp_size_t n, mp_size_t hn, mp_ptr tp)
通用高阶 Toom 求值:k次多项式在 x = +2 和 x = -2 处求值
void lmmp_toom_interp7_(mp_ptr dst, mp_size_t n, enum toom7_flags flags, mp_ptr w1, mp_ptr w3, mp_ptr w4, mp_ptr w5, mp_size_t w6n, mp_ptr tp)
Toom插值计算(7点插值):用于Toom-44、Toom-53、Toom-62 乘法算法
int lmmp_toom_eval_pm1_(mp_ptr xp1, mp_ptr xm1, unsigned k, mp_srcptr xp, mp_size_t n, mp_size_t hn, mp_ptr tp)
通用高阶 Toom 求值:k次多项式在 x = +1 和 x = -1 处求值