version 1.1, 2018/09/19 05:45:07 |
version 1.3, 2019/03/03 05:21:17 |
|
|
* DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE, |
* DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE, |
* PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE. |
* PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE. |
* |
* |
* $OpenXM$ |
* $OpenXM: OpenXM_contrib2/asir2018/engine/up_lm.c,v 1.2 2018/09/28 08:20:28 noro Exp $ |
*/ |
*/ |
#include "ca.h" |
#include "ca.h" |
#include <math.h> |
#include <math.h> |
Line 58 extern int current_ff; |
|
Line 58 extern int current_ff; |
|
void fft_mulup_lm(UP n1,UP n2,UP *nr) |
void fft_mulup_lm(UP n1,UP n2,UP *nr) |
{ |
{ |
ModNum *f1,*f2,*w,*fr; |
ModNum *f1,*f2,*w,*fr; |
ModNum *frarray[1024]; |
ModNum *frarray[NPrimes]; |
int modarray[1024]; |
int modarray[NPrimes]; |
int frarray_index = 0; |
int frarray_index = 0; |
Z m,m1,m2,lm_mod; |
Z m,m1,m2,lm_mod; |
int d1,d2,dmin,i,mod,root,d,cond,bound; |
int d1,d2,dmin,i,mod,root,d,cond,bound; |
Line 92 void fft_mulup_lm(UP n1,UP n2,UP *nr) |
|
Line 92 void fft_mulup_lm(UP n1,UP n2,UP *nr) |
|
cond = FFT_pol_product(d1,f1,d2,f2,fr,i,w); |
cond = FFT_pol_product(d1,f1,d2,f2,fr,i,w); |
if ( cond ) |
if ( cond ) |
error("fft_mulup : error in FFT_pol_product"); |
error("fft_mulup : error in FFT_pol_product"); |
STOQ(mod,m1); mulz(m,m1,&m2); m = m2; |
STOZ(mod,m1); mulz(m,m1,&m2); m = m2; |
if ( z_bits((Q)m) > bound ) { |
if ( z_bits((Q)m) > bound ) { |
crup_lm(frarray,d1+d2,modarray,frarray_index,m,lm_mod,&r); |
crup_lm(frarray,d1+d2,modarray,frarray_index,m,lm_mod,&r); |
uptolmup(r,nr); |
uptolmup(r,nr); |
Line 105 void fft_mulup_lm(UP n1,UP n2,UP *nr) |
|
Line 105 void fft_mulup_lm(UP n1,UP n2,UP *nr) |
|
void fft_squareup_lm(UP n1,UP *nr) |
void fft_squareup_lm(UP n1,UP *nr) |
{ |
{ |
ModNum *f1,*w,*fr; |
ModNum *f1,*w,*fr; |
ModNum *frarray[1024]; |
ModNum *frarray[NPrimes]; |
int modarray[1024]; |
int modarray[NPrimes]; |
int frarray_index = 0; |
int frarray_index = 0; |
Z m,m1,m2,lm_mod; |
Z m,m1,m2,lm_mod; |
int d1,dmin,i,mod,root,d,cond,bound; |
int d1,dmin,i,mod,root,d,cond,bound; |
Line 137 void fft_squareup_lm(UP n1,UP *nr) |
|
Line 137 void fft_squareup_lm(UP n1,UP *nr) |
|
cond = FFT_pol_square(d1,f1,fr,i,w); |
cond = FFT_pol_square(d1,f1,fr,i,w); |
if ( cond ) |
if ( cond ) |
error("fft_mulup : error in FFT_pol_product"); |
error("fft_mulup : error in FFT_pol_product"); |
STOQ(mod,m1); mulz(m,m1,&m2); m = m2; |
STOZ(mod,m1); mulz(m,m1,&m2); m = m2; |
if ( z_bits((Q)m) > bound ) { |
if ( z_bits((Q)m) > bound ) { |
crup_lm(frarray,2*d1,modarray,frarray_index,m,lm_mod,&r); |
crup_lm(frarray,2*d1,modarray,frarray_index,m,lm_mod,&r); |
uptolmup(r,nr); |
uptolmup(r,nr); |
Line 150 void fft_squareup_lm(UP n1,UP *nr) |
|
Line 150 void fft_squareup_lm(UP n1,UP *nr) |
|
void trunc_fft_mulup_lm(UP n1,UP n2,int dbd,UP *nr) |
void trunc_fft_mulup_lm(UP n1,UP n2,int dbd,UP *nr) |
{ |
{ |
ModNum *f1,*f2,*fr,*w; |
ModNum *f1,*f2,*fr,*w; |
ModNum *frarray[1024]; |
ModNum *frarray[NPrimes]; |
int modarray[1024]; |
int modarray[NPrimes]; |
int frarray_index = 0; |
int frarray_index = 0; |
Z m,m1,m2,lm_mod; |
Z m,m1,m2,lm_mod; |
int d1,d2,dmin,i,mod,root,d,cond,bound; |
int d1,d2,dmin,i,mod,root,d,cond,bound; |
Line 185 void trunc_fft_mulup_lm(UP n1,UP n2,int dbd,UP *nr) |
|
Line 185 void trunc_fft_mulup_lm(UP n1,UP n2,int dbd,UP *nr) |
|
cond = FFT_pol_product(d1,f1,d2,f2,fr,i,w); |
cond = FFT_pol_product(d1,f1,d2,f2,fr,i,w); |
if ( cond ) |
if ( cond ) |
error("fft_mulup : error in FFT_pol_product"); |
error("fft_mulup : error in FFT_pol_product"); |
STOQ(mod,m1); mulz(m,m1,&m2); m = m2; |
STOZ(mod,m1); mulz(m,m1,&m2); m = m2; |
if ( z_bits((Q)m) > bound ) { |
if ( z_bits((Q)m) > bound ) { |
crup_lm(frarray,MIN(dbd-1,d1+d2),modarray,frarray_index,m,lm_mod,&r); |
crup_lm(frarray,MIN(dbd-1,d1+d2),modarray,frarray_index,m,lm_mod,&r); |
uptolmup(r,nr); |
uptolmup(r,nr); |
Line 205 void crup_lm(ModNum **f,int d,int *mod,int index,Z m,Z |
|
Line 205 void crup_lm(ModNum **f,int d,int *mod,int index,Z m,Z |
|
for ( i = 0; i <= d; i++ ) { |
for ( i = 0; i <= d; i++ ) { |
remz((Z)w->c[i],lm_mod,&t); w->c[i] = (Num)t; |
remz((Z)w->c[i],lm_mod,&t); w->c[i] = (Num)t; |
} |
} |
for ( i = d; (i >= 0) && (w->c[i] != 0); i-- ); |
for ( i = d; (i >= 0) && (w->c[i] == 0); i-- ); |
if ( i < 0 ) *r = 0; |
if ( i < 0 ) *r = 0; |
else { |
else { |
w->d = i; |
w->d = i; |
Line 275 void save_up(UP obj,char *name) |
|
Line 275 void save_up(UP obj,char *name) |
|
void hybrid_powermodup(UP f,UP *xp) |
void hybrid_powermodup(UP f,UP *xp) |
{ |
{ |
Z n; |
Z n; |
UP x,y,t,invf,s; |
UP x,y,t,invf,s,s1; |
int k; |
int k; |
LM lm; |
LM lm; |
|
|