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

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

?? vec_lzz_p.cpp

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

#include <NTL/vec_lzz_p.h>

#include <NTL/new.h>

NTL_START_IMPL

NTL_vector_impl(zz_p,vec_zz_p)

NTL_io_vector_impl(zz_p,vec_zz_p)

NTL_eq_vector_impl(zz_p,vec_zz_p)

void conv(vec_zz_p& x, const vec_ZZ& a)
{
   long i, n;

   n = a.length();
   x.SetLength(n);

   zz_p* xp = x.elts();
   const ZZ* ap = a.elts();

   for (i = 0; i < n; i++)
      conv(xp[i], ap[i]);
}

void conv(vec_ZZ& x, const vec_zz_p& a)
{
   long n = a.length();
   x.SetLength(n);
   long i;
   for (i = 0; i < n; i++)
      x[i] = rep(a[i]);
}




void InnerProduct(zz_p& x, const vec_zz_p& a, const vec_zz_p& b)
{
   long n = min(a.length(), b.length());
   long i;
   zz_p accum, t;

   clear(accum);
   for (i = 0; i < n; i++) {
      mul(t, a[i], b[i]);
      add(accum, accum, t);
   }

   x = accum;
}

void InnerProduct(zz_p& x, const vec_zz_p& a, const vec_zz_p& b,
                  long offset)
{
   if (offset < 0) Error("InnerProduct: negative offset");
   if (NTL_OVERFLOW(offset, 1, 0)) Error("InnerProduct: offset too big");

   long n = min(a.length(), b.length()+offset);
   long i;
   zz_p accum, t;

   clear(accum);
   for (i = offset; i < n; i++) {
      mul(t, a[i], b[i-offset]);
      add(accum, accum, t);
   }

   x = accum;
}

long CRT(vec_ZZ& gg, ZZ& a, const vec_zz_p& G)
{
   long n = gg.length();
   if (G.length() != n) Error("CRT: vector length mismatch");

   long p = zz_p::modulus();

   ZZ new_a;
   mul(new_a, a, p);

   long a_inv;
   a_inv = rem(a, p);
   a_inv = InvMod(a_inv, p);

   long p1;
   p1 = p >> 1;

   ZZ a1;
   RightShift(a1, a, 1);

   long p_odd = (p & 1);

   long modified = 0;

   long h;
   ZZ ah;

   ZZ g;
   long i;
   for (i = 0; i < n; i++) {
      if (!CRTInRange(gg[i], a)) {
         modified = 1;
         rem(g, gg[i], a);
         if (g > a1) sub(g, g, a);
      }
      else
         g = gg[i];
   
      h = rem(g, p);
      h = SubMod(rep(G[i]), h, p);
      h = MulMod(h, a_inv, p);
      if (h > p1)
         h = h - p;
   
      if (h != 0) {
         modified = 1;
         mul(ah, a, h);
   
         if (!p_odd && g > 0 && (h == p1))
            sub(g, g, ah);
         else
            add(g, g, ah);
      }

      gg[i] = g;
   }

   a = new_a;

   return modified;
}



void mul(vec_zz_p& x, const vec_zz_p& a, zz_p b)
{
   long n = a.length();
   x.SetLength(n);

   long i;

   if (n <= 1) {

      for (i = 0; i < n; i++)
	 mul(x[i], a[i], b);

   }
   else {
 
      long p = zz_p::modulus();
      double pinv = zz_p::ModulusInverse();
      long bb = rep(b);
      mulmod_precon_t bpinv = PrepMulModPrecon(bb, p, pinv);
      
      
      const zz_p *ap = a.elts();
      zz_p *xp = x.elts();

      for (i = 0; i < n; i++)
         xp[i].LoopHole() = MulModPrecon(rep(ap[i]), bb, p, bpinv);

   }
}

void mul(vec_zz_p& x, const vec_zz_p& a, long b_in)
{
   zz_p b;
   b = b_in;
   mul(x, a, b);
}



void add(vec_zz_p& x, const vec_zz_p& a, const vec_zz_p& b)
{
   long n = a.length();
   if (b.length() != n) Error("vector add: dimension mismatch");

   x.SetLength(n);
   long i;
   for (i = 0; i < n; i++)
      add(x[i], a[i], b[i]);
}

void sub(vec_zz_p& x, const vec_zz_p& a, const vec_zz_p& b)
{
   long n = a.length();
   if (b.length() != n) Error("vector sub: dimension mismatch");
   x.SetLength(n);
   long i;
   for (i = 0; i < n; i++)
      sub(x[i], a[i], b[i]);
}

void clear(vec_zz_p& x)
{
   long n = x.length();
   long i;
   for (i = 0; i < n; i++)
      clear(x[i]);
}

void negate(vec_zz_p& x, const vec_zz_p& a)
{
   long n = a.length();
   x.SetLength(n);
   long i;
   for (i = 0; i < n; i++)
      negate(x[i], a[i]);
}


long IsZero(const vec_zz_p& a)
{
   long n = a.length();
   long i;

   for (i = 0; i < n; i++)
      if (!IsZero(a[i]))
         return 0;

   return 1;
}

vec_zz_p operator+(const vec_zz_p& a, const vec_zz_p& b)
{
   vec_zz_p res;
   add(res, a, b);
   NTL_OPT_RETURN(vec_zz_p, res);
}

vec_zz_p operator-(const vec_zz_p& a, const vec_zz_p& b)
{
   vec_zz_p res;
   sub(res, a, b);
   NTL_OPT_RETURN(vec_zz_p, res);
}


vec_zz_p operator-(const vec_zz_p& a)
{
   vec_zz_p res;
   negate(res, a);
   NTL_OPT_RETURN(vec_zz_p, res);
}


zz_p operator*(const vec_zz_p& a, const vec_zz_p& b)
{
   zz_p res;
   InnerProduct(res, a, b);
   return res;
}


void VectorCopy(vec_zz_p& x, const vec_zz_p& a, long n)
{
   if (n < 0) Error("VectorCopy: negative length");
   if (NTL_OVERFLOW(n, 1, 0)) Error("overflow in VectorCopy");

   long m = min(n, a.length());

   x.SetLength(n);
  
   long i;

   for (i = 0; i < m; i++)
      x[i] = a[i];

   for (i = m; i < n; i++)
      clear(x[i]);
}

NTL_END_IMPL

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品久久久久久综合日本欧美| 久久久久久9999| 精品欧美一区二区在线观看| 国产精品三级久久久久三级| 亚洲va欧美va天堂v国产综合| 国产在线视频一区二区| 91极品视觉盛宴| 2017欧美狠狠色| 日韩黄色免费电影| 色综合天天综合网天天狠天天| 91精品国产一区二区| 国产精品久久久久久久久果冻传媒| 三级久久三级久久| 色av成人天堂桃色av| 国产欧美1区2区3区| 91香蕉视频在线| 精品国产免费人成在线观看| 亚洲二区视频在线| 97精品久久久午夜一区二区三区| 久久亚洲精华国产精华液 | www.在线欧美| 国产一区二区三区四区在线观看| 国产一区日韩二区欧美三区| 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲乱码精品一二三四区日韩在线| 91精品国产色综合久久不卡电影| 国产精品综合av一区二区国产馆| 亚洲精品一区二区三区香蕉| 51精品秘密在线观看| 久久久99精品久久| 视频一区免费在线观看| 欧美日韩国产bt| 一区二区三区欧美在线观看| 91免费看视频| 亚洲猫色日本管| 欧美一区二区三区影视| 亚洲激情图片一区| 不卡高清视频专区| 国产精品久久久久一区| av动漫一区二区| 国产精品久久久久久久久快鸭| 国产一区二区福利| 欧美激情一区不卡| 色婷婷综合久久久久中文一区二区| 一区在线中文字幕| 在线亚洲+欧美+日本专区| 亚洲裸体在线观看| 欧美亚洲禁片免费| 日本少妇一区二区| 精品对白一区国产伦| 国产高清成人在线| 亚洲同性gay激情无套| 色婷婷av一区二区| 日韩黄色免费电影| 国产欧美精品国产国产专区| 91色综合久久久久婷婷| 亚洲午夜激情网页| 精品三级在线看| 不卡的电视剧免费网站有什么| 一区二区三区在线影院| 8x福利精品第一导航| 国产麻豆成人精品| 一区二区欧美在线观看| 欧美一区二区三区在线看| 国产成人小视频| 亚洲青青青在线视频| 欧美一区二区三区婷婷月色 | 成人午夜av影视| 亚洲精品国产第一综合99久久| 88在线观看91蜜桃国自产| 国产一区二区精品在线观看| 一区二区三区视频在线观看| 911精品产国品一二三产区| 粉嫩av一区二区三区| 亚洲日本免费电影| 欧美变态tickling挠脚心| 97久久精品人人澡人人爽| 日韩黄色在线观看| 亚洲免费观看在线观看| 2020国产精品久久精品美国| 日本道免费精品一区二区三区| 久久99久久99精品免视看婷婷 | 国产天堂亚洲国产碰碰| 欧美视频中文字幕| 成人福利视频在线| 美女视频一区在线观看| 天天亚洲美女在线视频| 日本一区二区在线不卡| 91精品国产91久久久久久一区二区| 不卡欧美aaaaa| 激情成人午夜视频| 天堂va蜜桃一区二区三区| 国产精品嫩草99a| 久久综合色8888| 91精品国产一区二区三区蜜臀| 色综合网色综合| 大桥未久av一区二区三区中文| 日韩电影在线观看网站| 亚洲一二三区在线观看| 国产精品伦一区| 久久蜜桃av一区精品变态类天堂 | 精品久久五月天| 欧美色网一区二区| 一本大道综合伊人精品热热| 懂色av一区二区夜夜嗨| 韩国女主播一区二区三区| 日韩电影在线观看电影| 午夜视频在线观看一区| 亚洲一区二区在线视频| 亚洲色图制服诱惑| 成人欧美一区二区三区视频网页| 久久综合色8888| 国产无一区二区| 国产亚洲一区二区在线观看| 欧美一区二区久久久| 欧美妇女性影城| 欧美美女直播网站| 欧美精品一卡二卡| 日韩欧美精品在线视频| 日韩一区二区三区电影在线观看| 51久久夜色精品国产麻豆| 日韩免费看网站| 亚洲精品一线二线三线| 久久精品亚洲麻豆av一区二区 | 欧美一区二区三区免费| 欧美一区三区二区| 精品国产一区二区三区久久久蜜月| 91精品蜜臀在线一区尤物| 欧美tk—视频vk| 国产偷v国产偷v亚洲高清| 国产精品日产欧美久久久久| 中文字幕一区二区三区不卡在线 | av亚洲精华国产精华| 99精品视频在线观看| 欧美性videosxxxxx| 91精品久久久久久久99蜜桃| 欧美mv日韩mv国产网站| 国产精品三级在线观看| 亚洲成在人线免费| 日韩av电影一区| 大陆成人av片| 欧美日韩国产区一| wwww国产精品欧美| 亚洲综合色视频| 国产老妇另类xxxxx| 91小视频免费观看| 欧美大片在线观看一区二区| 国产日本欧美一区二区| 一区二区三区欧美| 久99久精品视频免费观看| 成人av资源在线观看| 欧美精品一卡二卡| 中国色在线观看另类| 视频一区二区三区中文字幕| 国产一区在线不卡| 在线影视一区二区三区| 欧美tickling网站挠脚心| 亚洲精品乱码久久久久| 精品一区二区免费视频| 91美女在线看| 欧美v国产在线一区二区三区| 亚洲美女在线国产| 国产精品性做久久久久久| 欧美少妇bbb| 自拍偷拍亚洲综合| 激情伊人五月天久久综合| 欧美综合天天夜夜久久| 久久久国产综合精品女国产盗摄| 亚洲一区二区在线观看视频| 国产一区二区伦理片| 91麻豆精品国产91| 亚洲一区国产视频| av爱爱亚洲一区| 久久久高清一区二区三区| 日日摸夜夜添夜夜添亚洲女人| www.色精品| 国产无一区二区| 激情文学综合插| 日韩手机在线导航| 日韩精品五月天| 欧美又粗又大又爽| 亚洲人快播电影网| 大桥未久av一区二区三区中文| 精品毛片乱码1区2区3区| 日韩中文字幕麻豆| 欧美视频在线一区二区三区 | 中文欧美字幕免费| 国产成人精品一区二| 精品国产乱码久久久久久图片| 日韩精品成人一区二区三区| 91官网在线观看| 亚洲精品成人精品456| 92国产精品观看| 日韩一区中文字幕| 色又黄又爽网站www久久| 国产精品国产精品国产专区不片| 国产成人午夜精品5599| 久久久久久久久久看片| 国产成人午夜电影网| 中文字幕久久午夜不卡|