29 {
34
35#define a0 numa
36#define a1 (numa + n)
37#define a2 (numa + 2 * n)
38#define a3 (numa + 3 * n)
39#define a4 (numa + 4 * n)
40#define b0 numb
41#define b1 (numb + n)
42
43 n = 1 + (2 * na >= 5 * nb ? (na - 1) / (
mp_size_t)5 : (nb - 1) >> 1);
46
47 s = na - 4 * n;
48 t = nb - n;
49
52
53
54
55
57
58#define v0 dst
59#define vm1 (scratch)
60#define v1 (dst + 2 * n)
61#define vm2 (scratch + 2 * n + 1)
62#define v2 (scratch + 4 * n + 2)
63#define vinf (dst + 5 * n)
64#define bs1 dst
65#define bsm1 (scratch + 2 * n + 2)
66#define asm1 (scratch + 3 * n + 3)
67#define asm2 (scratch + 4 * n + 4)
68#define bsm2 (dst + n + 1)
69#define bs2 (dst + 2 * n + 2)
70#define as2 (dst + 3 * n + 3)
71#define as1 (dst + 4 * n + 4)
72
73
74#define a0a2 scratch
75#define a1a3 asm1
76
77
79
80
81 if (t == n) {
86 } else {
88 }
90 } else {
96 } else {
98 }
99 }
100
101
106 } else {
108 if (t == n) {
112 } else {
114 }
115 } else {
120 } else {
122 }
123 }
124 }
125
126
128
132
137
138
140
141
143
144
146
147
149
150
151 if (s > t)
153 else
155
156
158
161#undef v0
162#undef vm1
163#undef v1
164#undef vm2
165#undef v2
166#undef vinf
167#undef bs1
168#undef bs2
169#undef bsm1
170#undef bsm2
171#undef asm1
172#undef asm2
173#undef as1
174#undef as2
175#undef a0a2
176#undef b0b2
177#undef a1a3
178#undef a0
179#undef a1
180#undef a2
181#undef a3
182#undef b0
183#undef b1
184#undef b2
185}
#define lmmp_zero(dst, n)
#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]
static mp_limb_t lmmp_sub_(mp_ptr dst, mp_srcptr numa, mp_size_t na, mp_srcptr numb, mp_size_t nb)
大数减法静态内联函数 [dst,na]=[numa,na]-[numb,nb]
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_sub_n_(mp_ptr dst, mp_srcptr numa, mp_srcptr numb, mp_size_t n)
无借位的n位减法 [dst,n] = [numa,n] - [numb,n]
static int lmmp_zero_q_(mp_srcptr p, mp_size_t n)
大数判零函数(内联)
#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_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_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 处求值