亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? quicktest.cpp

?? NTL is a high-performance, portable C++ library providing data structures and algorithms for manipul
?? CPP
字號:

#include <NTL/ZZ_pX.h>
#include <NTL/lzz_pX.h>

#include <NTL/version.h>

NTL_CLIENT


#define make_string_aux(x) #x
#define make_string(x) make_string_aux(x)

int SmallModulusTest(long p, long n)
{
   zz_pBak bak;

   bak.save();


   zz_p::init(p);

   zz_pX a, b, c, cc;

   random(a, n);
   random(b, n);
   PlainMul(c, a, b);
   FFTMul(cc, a, b);

   int res;
   res = (c != cc);

   bak.restore();

   return res;
}




int main()
{


   cerr << "This is NTL version " << NTL_VERSION << "\n"; 

   cerr << "Basic Configuration Options:\n";


#ifdef NTL_STD_CXX
   cerr << "NTL_STD_CXX\n";
#endif

#ifdef NTL_PSTD_NNS
   cerr << "NTL_PSTD_NNS\n";
#endif

#ifdef NTL_PSTD_NHF
   cerr << "NTL_PSTD_NHF\n";
#endif

#ifdef NTL_PSTD_NTN
   cerr << "NTL_PSTD_NTN\n";
#endif

#ifdef NTL_GMP_LIP
   cerr << "NTL_GMP_LIP\n";
#endif

#ifdef NTL_GMP_HACK
   cerr << "NTL_GMP_HACK\n";
#endif

#ifdef NTL_LONG_LONG_TYPE
   cerr << "NTL_LONG_LONG_TYPE: ";
   cerr << make_string(NTL_LONG_LONG_TYPE) << "\n";
#endif

#ifdef NTL_UNSIGNED_LONG_LONG_TYPE
   cerr << "NTL_UNSIGNED_LONG_LONG_TYPE: ";
   cerr << make_string(NTL_UNSIGNED_LONG_LONG_TYPE) << "\n";
#endif

#ifdef NTL_CXX_ONLY
   cerr << "NTL_CXX_ONLY\n";
#endif


#ifdef NTL_X86_FIX
   cerr << "NTL_X86_FIX\n";
#endif

#ifdef NTL_NO_X86_FIX
   cerr << "NTL_NO_X86_FIX\n";
#endif

#ifdef NTL_NO_INIT_TRANS
   cerr << "NTL_NO_INIT_TRANS\n";
#endif

#ifdef NTL_CLEAN_INT
   cerr << "NTL_CLEAN_INT\n";
#endif

#ifdef NTL_CLEAN_PTR
   cerr << "NTL_CLEAN_PTR\n";
#endif

#ifdef NTL_RANGE_CHECK
   cerr << "NTL_RANGE_CHECK\n";
#endif


cerr << "\n";
cerr << "Resolution of double-word types:\n";
cerr << make_string(NTL_LL_TYPE) << "\n";
cerr << make_string(NTL_ULL_TYPE) << "\n";


cerr << "\n";
cerr << "Performance Options:\n";

#ifdef NTL_LONG_LONG
   cerr << "NTL_LONG_LONG\n";
#endif

#ifdef NTL_AVOID_FLOAT
   cerr << "NTL_AVOID_FLOAT\n";
#endif

#ifdef NTL_SPMM_UL
   cerr << "NTL_SPMM_UL\n";
#endif


#ifdef NTL_SPMM_ULL
   cerr << "NTL_SPMM_ULL\n";
#endif


#ifdef NTL_SPMM_ASM
   cerr << "NTL_SPMM_ASM\n";
#endif




#ifdef NTL_AVOID_BRANCHING
   cerr << "NTL_AVOID_BRANCHING\n";
#endif



#ifdef NTL_TBL_REM
   cerr << "NTL_TBL_REM\n";
#endif


#ifdef NTL_GF2X_ALTCODE
   cerr << "NTL_GF2X_ALTCODE\n";
#endif

#ifdef NTL_GF2X_ALTCODE1
   cerr << "NTL_GF2X_ALTCODE1\n";
#endif


#ifdef NTL_GF2X_NOINLINE
   cerr << "NTL_GF2X_NOINLINE\n";
#endif

   cerr << "\n\n";

   if (_ntl_gmp_hack)
      cerr << "using GMP hack\n";

   long n, k;

   n = 200;
   k = 10*NTL_ZZ_NBITS;

   ZZ p;

   GenPrime(p, k);


   ZZ_p::init(p);         // initialization

   ZZ_pX f, g, h, r1, r2, r3;

   random(g, n);    // g = random polynomial of degree < n
   random(h, n);    // h =             "   "
   random(f, n);    // f =             "   "

   // SetCoeff(f, n);  // Sets coefficient of X^n to 1
   
   ZZ_p lc;

   do {
      random(lc);
   } while (IsZero(lc));

   SetCoeff(f, n, lc);


   // For doing arithmetic mod f quickly, one must pre-compute
   // some information.

   ZZ_pXModulus F;
   build(F, f);

   PlainMul(r1, g, h);  // this uses classical arithmetic
   PlainRem(r1, r1, f);

   MulMod(r2, g, h, F);  // this uses the FFT

   MulMod(r3, g, h, f);  // uses FFT, but slower

   // compare the results...

   if (r1 != r2) {
      cerr << "r1 != r2!!\n";
      return 1;
   }
   else if (r1 != r3) {
      cerr << "r1 != r3!!\n";
      return 1;
   }


   // small prime tests...I've made some changes in v5.3
   // that should be checked on various platforms, so 
   // we might as well check them here.

   if (SmallModulusTest(17, 1000)) {
      cerr << "first SmallModulusTest failed!!\n";
      return 1;
   }

   if (SmallModulusTest((1L << (NTL_SP_NBITS))-1, 1000)) {
      cerr << "second SmallModulusTest failed!!\n";
      return 1;
   }

   cerr << "test is OK\n";

   ZZ x1, x2, x3, x4;
   double t;
   long i;

   RandomLen(x1, 1024);
   RandomBnd(x2, x1);
   RandomBnd(x3, x1);

   mul(x4, x2, x3);

   t = GetTime();
   for (i = 0; i < 100000; i++)
      mul(x4, x2, x3);
   t = GetTime()-t;

   cerr << "time for 1024-bit mul: " << t*10 << "us";

   if (_ntl_gmp_hack) {
      _ntl_gmp_hack = 0;
      mul(x4, x2, x3);

      t = GetTime();
      for (i = 0; i < 100000; i++)
         mul(x4, x2, x3);
      t = GetTime()-t;

      cerr << " (" << (t*10) << "us without GMP)"; 

      _ntl_gmp_hack = 1;
   }

   cerr << "\n";

   rem(x2, x4, x1);

   t = GetTime();
   for (i = 0; i < 100000; i++)
      rem(x2, x4, x1);
   t = GetTime()-t;

   cerr << "time for 2048/1024-bit rem: " << t*10 << "us";

   if (_ntl_gmp_hack) {
      _ntl_gmp_hack = 0;
      rem(x2, x4, x1);
   
      t = GetTime();
      for (i = 0; i < 100000; i++)
         rem(x2, x4, x1);
      t = GetTime()-t;
      cerr << " (" << (t*10) << "us without GMP)"; 

      _ntl_gmp_hack = 1;
   }

   cerr << "\n";
   

   GenPrime(p, 1024);
   RandomBnd(x1, p);
   if (IsZero(x1)) set(x1);

   InvMod(x2, x1, p);

   t = GetTime();
   for (i = 0; i < 1000; i++)
      InvMod(x2, x1, p);
   t = GetTime()-t;

   cerr << "time for 1024-bit modular inverse: " << t*1000 << "us";

   if (_ntl_gmp_hack) {
      _ntl_gmp_hack = 0;
      InvMod(x2, x1, p);
   
      t = GetTime();
      for (i = 0; i < 1000; i++)
         InvMod(x2, x1, p);
      t = GetTime()-t;
         cerr << " (" << (t*1000) << "us without GMP)"; 

      _ntl_gmp_hack = 1;
   }

   cerr << "\n";



   // test modulus switching
   
   n = 1024;
   k = 1024;
   RandomLen(p, k);

   ZZ_p::init(p);
   ZZ_pInfo->check();

   ZZ_pX j1, j2, j3;

   random(j1, n);
   random(j2, n);

   t = GetTime();
   for (i = 0; i < 20; i++) mul(j3, j1, j2);
   t = GetTime()-t;

   cerr << "time to multiply degree 1023 polynomials\n   modulo a 1024-bit number: ";
   cerr << (t/20) << "s";

   if (_ntl_gmp_hack) {
      _ntl_gmp_hack = 0;

      ZZ_p::init(p);
      ZZ_pInfo->check();

      t = GetTime();
      for (i = 0; i < 20; i++) mul(j3, j1, j2);
      t = GetTime()-t;

      cerr << " (" << (t/20) << "s without GMP)";
      _ntl_gmp_hack = 1;
   }

   cerr << "\n";

   return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美电视剧免费全集观看| 国产精品午夜春色av| 丰满亚洲少妇av| 免费在线观看不卡| 一区二区国产盗摄色噜噜| 中日韩av电影| 美国毛片一区二区三区| 麻豆精品视频在线观看| 91影院在线免费观看| 成人av在线资源网站| 成人性视频网站| 91一区在线观看| 精品盗摄一区二区三区| 欧美大度的电影原声| 一区二区三区国产豹纹内裤在线| 久久国产人妖系列| 国产九色精品成人porny| 久久精品国产第一区二区三区| 97se亚洲国产综合自在线不卡| 欧美中文字幕一区二区三区 | 成人黄色片在线观看| 91精品免费观看| 欧美mv和日韩mv的网站| 偷偷要91色婷婷| 秋霞午夜鲁丝一区二区老狼| 欧美性一二三区| 欧美精品一区二区精品网| 精品理论电影在线| 日韩成人一区二区三区在线观看| 久久精品噜噜噜成人av农村| 3751色影院一区二区三区| 亚洲午夜久久久久久久久电影网 | 中文久久乱码一区二区| 国产精品一级二级三级| 久久久久国产免费免费| 亚洲欧洲日韩综合一区二区| 亚洲亚洲精品在线观看| 色婷婷久久久久swag精品| 91精品免费在线观看| 日韩电影免费一区| 欧美一区在线视频| 国产精品情趣视频| jizz一区二区| 久久综合资源网| 高清不卡一二三区| 国产精品久久久久久久久动漫| 水野朝阳av一区二区三区| 成人高清视频在线观看| 日韩一区中文字幕| 色婷婷久久久综合中文字幕| 午夜视频久久久久久| 3751色影院一区二区三区| 久久99精品一区二区三区| 91免费在线播放| 亚洲国产成人精品视频| 91精品国产aⅴ一区二区| 国产在线精品一区二区三区不卡 | 国产精品家庭影院| 色婷婷综合激情| 日韩精品乱码免费| 久久蜜桃香蕉精品一区二区三区| 成人免费av网站| 亚洲一区在线观看免费观看电影高清| 国产剧情一区在线| 亚洲女厕所小便bbb| 成人免费观看男女羞羞视频| 一区二区三区高清不卡| 日韩精品中午字幕| 成人av网站免费| 亚洲成人av一区二区| 日本精品裸体写真集在线观看 | 国产在线精品一区二区三区不卡| 另类欧美日韩国产在线| 日本一区二区成人| 麻豆专区一区二区三区四区五区| 国产三级一区二区三区| 国产精品一区二区无线| 一区二区三区精品久久久| 精品日韩一区二区三区免费视频| 99久久99久久精品免费看蜜桃| 亚洲成a人v欧美综合天堂下载 | 日韩成人免费在线| 国产精品日韩精品欧美在线| 欧美人与性动xxxx| 天天av天天翘天天综合网色鬼国产| 久久久久久久久久电影| 欧美日韩国产一区| 99久久综合色| 国产精品99久久久久| 日本三级亚洲精品| 亚洲福利国产精品| 最新日韩在线视频| 国产欧美日韩视频在线观看| 成人白浆超碰人人人人| 美女性感视频久久| 亚洲一区在线免费观看| 国产精品理论片| 国产人伦精品一区二区| 精品国一区二区三区| 欧美日韩免费观看一区三区| 老司机午夜精品| 亚洲第一激情av| 成人欧美一区二区三区黑人麻豆 | 国产成人a级片| 欧美一区二区三区免费在线看| 成人激情午夜影院| 久久精品国产亚洲高清剧情介绍 | 成人丝袜18视频在线观看| 欧美96一区二区免费视频| 亚洲人成7777| 国产亚洲欧美一级| 91精品国产综合久久久久| 91香蕉视频污| jiyouzz国产精品久久| 99视频一区二区| 国产成人自拍在线| 久久狠狠亚洲综合| 日本视频在线一区| 亚洲成av人在线观看| 久久久99免费| 国产精品久久精品日日| 久久久久亚洲综合| 欧美精品一区二区三区在线播放| 欧美福利一区二区| 欧美日韩在线一区二区| 国产白丝网站精品污在线入口| 亚洲精品中文在线| 欧美老肥妇做.爰bbww| 色av综合在线| 欧美日韩国产免费一区二区| 在线视频国内一区二区| 91色porny在线视频| 99久久国产综合色|国产精品| 成人av网站在线| av电影天堂一区二区在线观看| 国产麻豆成人精品| 久久精品国产久精国产爱| 久久国产欧美日韩精品| 麻豆视频观看网址久久| 国产**成人网毛片九色| 高清免费成人av| 成人18精品视频| 97久久精品人人爽人人爽蜜臀| 91视频观看视频| 91麻豆精品国产综合久久久久久| 7777精品久久久大香线蕉| 欧美精品亚洲一区二区在线播放| 欧美色手机在线观看| 欧美午夜精品久久久久久孕妇| 91精品国产综合久久精品麻豆 | 中文字幕第一区| 亚洲在线一区二区三区| 亚洲一区二区精品久久av| 午夜精品久久久久久久久久| 天天操天天色综合| 国产综合色在线视频区| 日本道精品一区二区三区 | 欧美另类videos死尸| 久久久美女毛片| 亚洲免费观看高清| 亚洲午夜电影在线观看| 欧美aaa在线| 成人国产一区二区三区精品| 91福利国产成人精品照片| 91精品婷婷国产综合久久| 久久精品人人做人人爽人人| 亚洲精品综合在线| 免费观看在线综合色| 国产mv日韩mv欧美| 7799精品视频| 欧美高清在线精品一区| 性感美女久久精品| 国产麻豆精品一区二区| 99这里都是精品| 91精品国产黑色紧身裤美女| 中文子幕无线码一区tr| 五月开心婷婷久久| 成人av在线资源| 日韩一二三四区| 午夜精品成人在线视频| 成人性视频免费网站| 欧美精品成人一区二区三区四区| 国产女主播在线一区二区| 一区二区三区毛片| 成人aa视频在线观看| 欧美成人一区二区三区| 亚洲女人的天堂| 成人综合激情网| 亚洲国产精品黑人久久久| 日日骚欧美日韩| 91日韩精品一区| 久久精品一区二区三区av| 美女诱惑一区二区| 欧美专区亚洲专区| 国产精品国产三级国产有无不卡 | 日韩电影一区二区三区| 欧美日韩一区二区三区免费看| 久久亚洲一级片| 久久精品国产亚洲一区二区三区 | 国模一区二区三区白浆|