7#include "../../include/lammp/lmmpn.h"
8#include "../../include/lammp/impl/toom_interp.h"
30 mp_size_t n = na >= 2 * nb ? (na + 3) >> 2 : (nb + 1) >> 1, s = na - 3 * n, t = nb - n;
37#define a2 (numa + 2 * n)
38#define a3 (numa + 3 * n)
43#define v1 (dst + 2 * n)
44#define vinf (dst + 4 * n)
46#define v2 (tp + 2 * n + 2)
51#define bp1 (tp + n + 1)
157 int vm1_neg, flag = 0;
162#define a2 (numa + 2 * n)
163#define a3 (numa + 3 * n)
168#define v1 (dst + 2 * n)
169#define vinf (dst + 4 * n)
171#define v2 (tp + 2 * n + 2)
178#define bp2 (tp + n + 1)
179#define a13 (tp + n + 1)
289#define a2 (numa + 2 * n)
290#define a3 (numa + 3 * n)
295#define v1 (dst + 2 * n)
296#define vinf (dst + 4 * n)
298#define v2 (tp + 2 * n + 2)
305#define bp2 (tp + n + 1)
306#define a13 (tp + n + 1)
366 mp_size_t n = (2 * nb + 3) >> 2, s = 2 * nb - 3 * n, t = nb - n;
369 mp_ptr restrict _bm1 = _bp1 + n + 1;
375 while (2 * na >= 5 * nb) {
#define lmmp_copy(dst, src, n)
#define lmmp_zero(dst, n)
const mp_limb_t * mp_srcptr
#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
#define lmmp_inc(p)
大数加1宏(预期无进位)
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])
static mp_limb_t lmmp_sub_1_(mp_ptr dst, mp_srcptr numa, mp_size_t na, mp_limb_t x)
大数减单精度数静态内联函数 [dst,na]=[numa,na]-x
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]
static int lmmp_zero_q_(mp_srcptr p, mp_size_t n)
大数判零函数(内联)
static void lmmp_mul_toom42_cache_(mp_ptr restrict dst, mp_srcptr restrict numa, mp_srcptr restrict numb, mp_size_t n, mp_size_t s, mp_size_t t, mp_srcptr restrict _bp1, mp_srcptr restrict _bm1, mp_ptr restrict tp, int flag)
void lmmp_mul_toom42_(mp_ptr restrict dst, mp_srcptr restrict numa, mp_size_t na, mp_srcptr restrict numb, mp_size_t nb)
static int lmmp_mul_toom42_cache_init_(mp_ptr restrict dst, mp_srcptr restrict numa, mp_srcptr restrict numb, mp_size_t n, mp_size_t s, mp_size_t t, mp_ptr restrict _bp1, mp_ptr restrict _bm1, mp_ptr restrict tp)
void lmmp_mul_toom42_unbalance_(mp_ptr restrict dst, mp_srcptr restrict numa, mp_size_t na, mp_srcptr restrict numb, mp_size_t nb)
#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乘法算法