25 {
30 mp_size_t n = (na + 2) / 3, s = na - 2 * n, t = nb - 2 * n;
31 int vm1_neg;
34
35#define a0 numa
36#define a1 (numa + n)
37#define a2 (numa + 2 * n)
38#define b0 numb
39#define b1 (numb + n)
40#define b2 (numb + 2 * n)
41
42#define v0 dst
43#define v1 (dst + 2 * n)
44#define vinf (dst + 4 * n)
45#define vm1 tp
46#define v2 (tp + 2 * n + 2)
47
48#define bm1 dst
49#define am1 (dst + n)
50#define ap1 tp
51#define bp1 (tp + n + 1)
52#define ap2 ap1
53#define bp2 bp1
54
55
60 am1h = 0;
61 vm1_neg = 1;
62 } else {
64 ap1[n] = cy + (cy2 >> 1);
65 am1h = cy - (cy2 & 1);
66 vm1_neg = 0;
67 }
68
69
74 bm1h = 0;
75 vm1_neg ^= 1;
76 } else {
78 bp1[n] = cy + (cy2 >> 1);
79 bm1h = cy - (cy2 & 1);
80 }
81
82
83 if (s > t)
85 else
89
90
93
94
96 if (s != n)
100
101
103 if (t != n)
107
108
110
111
113 cy = 0;
114 if (am1h)
116 if (bm1h)
119
120
122
125}
#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_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_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_interp5_(mp_ptr dst, mp_ptr v2, mp_ptr vm1, mp_size_t n, mp_size_t spt, int vm1_neg, mp_limb_t vinf0)
Toom插值计算(5点插值),用于Toom-33和Toom-42乘法算法