7#include "../../include/lammp/impl/toom_interp.h"
41#define a2 (numa + 2 * n)
42#define a3 (numa + 3 * n)
43#define a4 (numa + 4 * n)
44#define a5 (numa + 5 * n)
48 n = 1 + (na >= 3 * nb ? (na - 1) / (
mp_size_t)6 : (nb - 1) >> 1);
88 ash[n] = 2 * cy +
lmmp_shl_(ash + s, ash + s, n - s, 1);
156#define v1 (dst + 2 * n)
157#define vinf (dst + 6 * n)
159#define vm2 (scratch + 2 * n + 1)
160#define vh (scratch + 4 * n + 2)
161#define vm1 (scratch + 6 * n + 3)
162#define scratch_out (scratch + 8 * n + 4)
176 }
else if (
asm1[n] == 2) {
185 }
else if (
as1[n] == 2) {
187 }
else if (
as1[n] != 0) {
230#define a2 (numa + 2 * n)
231#define a3 (numa + 3 * n)
232#define a4 (numa + 4 * n)
233#define a5 (numa + 5 * n)
261 ash[n] = 2 * cy +
lmmp_shl_(ash + s, ash + s, n - s, 1);
329#define v1 (dst + 2 * n)
330#define vinf (dst + 6 * n)
332#define vm2 (scratch + 2 * n + 1)
333#define vh (scratch + 4 * n + 2)
334#define vm1 (scratch + 6 * n + 3)
335#define scratch_out (scratch + 8 * n + 4)
349 }
else if (
asm1[n] == 2) {
358 }
else if (
as1[n] == 2) {
360 }
else if (
as1[n] != 0) {
403#define a2 (numa + 2 * n)
404#define a3 (numa + 3 * n)
405#define a4 (numa + 4 * n)
406#define a5 (numa + 5 * n)
433 ash[n] = 2 * cy +
lmmp_shl_(ash + s, ash + s, n - s, 1);
445#define v1 (dst + 2 * n)
446#define vinf (dst + 6 * n)
448#define vm2 (scratch + 2 * n + 1)
449#define vh (scratch + 4 * n + 2)
450#define vm1 (scratch + 6 * n + 3)
451#define scratch_out (scratch + 8 * n + 4)
465 }
else if (
asm1[n] == 2) {
474 }
else if (
as1[n] == 2) {
476 }
else if (
as1[n] != 0) {
509 bs1 = tmp + 5 * n + 5;
514 enum toom7_flags bflags =
lmmp_mul_toom62_cache_init_(dst, numa, numb, n, s, t,
scratch, tmp,
bs1,
bsm1,
bs2,
bsm2, bsh);
519 while (na >= 5 * nb) {
520 lmmp_mul_toom62_cache_(dst, numa, numb, n, s, t,
scratch, tmp,
bs1,
bsm1,
bs2,
bsm2, bsh, bflags);
#define lmmp_copy(dst, src, n)
#define lmmp_zero(dst, n)
#define lmmp_debug_assert(x)
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)
大数比较函数(内联)
#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_shl_(mp_ptr dst, mp_srcptr numa, mp_size_t na, mp_size_t shl)
大数左移操作 [dst,na] = [numa,na]<<shl,dst的低shl位填充0
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_addmul_1_(mp_ptr numa, mp_srcptr numb, mp_size_t n, mp_limb_t b)
大数乘以单limb并累加操作 [numa,n] += [numb,n] * b
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]
#define lmmp_inc_1(p, inc)
大数加指定值宏(预期无进位)
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)
大数判零函数(内联)
void lmmp_mul_toom62_(mp_ptr restrict dst, mp_srcptr restrict numa, mp_size_t na, mp_srcptr restrict numb, mp_size_t nb)
static void lmmp_mul_toom62_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_ptr restrict scratch, mp_ptr restrict tmp, mp_srcptr restrict bs1, mp_srcptr restrict bsm1, mp_srcptr restrict bs2, mp_srcptr restrict bsm2, mp_srcptr restrict bsh, enum toom7_flags bflags)
static enum toom7_flags lmmp_mul_toom62_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 scratch, mp_ptr restrict tmp, mp_ptr restrict bs1, mp_ptr restrict bsm1, mp_ptr restrict bs2, mp_ptr restrict bsm2, mp_ptr restrict bsh)
void lmmp_mul_toom62_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)
#define BALLOC_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 处求值