26 {
32
33#define a0 numa
34#define a1 (numa + n)
35#define a2 (numa + 2 * n)
36#define a3 (numa + 3 * n)
37#define b0 numb
38#define b1 (numb + n)
39#define b2 (numb + 2 * n)
40#define b3 (numb + 3 * n)
41
43
44 n = (na + 3) >> 2;
47
48 s = na - 3 * n;
49 t = nb - 3 * n;
50
54
55
56
57
58#define v0 dst
59#define v1 (dst + 2 * n)
60#define vinf (dst + 6 * n)
61#define v2 scratch
62#define vm2 (scratch + 2 * n + 1)
63#define vh (scratch + 4 * n + 2)
64#define vm1 (scratch + 6 * n + 3)
65#define tp (scratch + 8 * n + 5)
66
67
68#define apx dst
69#define amx (dst + n + 1)
70#define bmx (dst + 2 * n + 2)
71#define bpx (dst + 4 * n + 2)
72
73
74
75
76
78
79
81
84
85
86
89 if (s < n) {
94 } else
96
97
98
99
102 if (t < n) {
107 } else
109
112
114
115
117
118
120
122
124
126 if (s > t)
128 else
130
132
134}
#define lmmp_debug_assert(x)
#define lmmp_param_assert(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_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
#define lmmp_inc_1(p, inc)
大数加指定值宏(预期无进位)
#define SALLOC_TYPE(n, type)
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_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段系数)。