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

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

?? mat_zz_pe.cpp

?? 大數運算類
?? CPP
?? 第 1 頁 / 共 2 頁
字號:

#include <NTL/mat_ZZ_pE.h>

#include <NTL/new.h>

NTL_START_IMPL

NTL_matrix_impl(ZZ_pE,vec_ZZ_pE,vec_vec_ZZ_pE,mat_ZZ_pE)

NTL_io_matrix_impl(ZZ_pE,vec_ZZ_pE,vec_vec_ZZ_pE,mat_ZZ_pE)

NTL_eq_matrix_impl(ZZ_pE,vec_ZZ_pE,vec_vec_ZZ_pE,mat_ZZ_pE)


  
void add(mat_ZZ_pE& X, const mat_ZZ_pE& A, const mat_ZZ_pE& B)  
{  
   long n = A.NumRows();  
   long m = A.NumCols();  
  
   if (B.NumRows() != n || B.NumCols() != m)   
      Error("matrix add: dimension mismatch");  
  
   X.SetDims(n, m);  
  
   long i, j;  
   for (i = 1; i <= n; i++)   
      for (j = 1; j <= m; j++)  
         add(X(i,j), A(i,j), B(i,j));  
}  
  
void sub(mat_ZZ_pE& X, const mat_ZZ_pE& A, const mat_ZZ_pE& B)  
{  
   long n = A.NumRows();  
   long m = A.NumCols();  
  
   if (B.NumRows() != n || B.NumCols() != m)  
      Error("matrix sub: dimension mismatch");  
  
   X.SetDims(n, m);  
  
   long i, j;  
   for (i = 1; i <= n; i++)  
      for (j = 1; j <= m; j++)  
         sub(X(i,j), A(i,j), B(i,j));  
}  

void negate(mat_ZZ_pE& X, const mat_ZZ_pE& A)  
{  
   long n = A.NumRows();  
   long m = A.NumCols();  
  
  
   X.SetDims(n, m);  
  
   long i, j;  
   for (i = 1; i <= n; i++)  
      for (j = 1; j <= m; j++)  
         negate(X(i,j), A(i,j));  
}  
  
void mul_aux(mat_ZZ_pE& X, const mat_ZZ_pE& A, const mat_ZZ_pE& B)  
{  
   long n = A.NumRows();  
   long l = A.NumCols();  
   long m = B.NumCols();  
  
   if (l != B.NumRows())  
      Error("matrix mul: dimension mismatch");  
  
   X.SetDims(n, m);  
  
   long i, j, k;  
   ZZ_pX acc, tmp;  
  
   for (i = 1; i <= n; i++) {  
      for (j = 1; j <= m; j++) {  
         clear(acc);  
         for(k = 1; k <= l; k++) {  
            mul(tmp, rep(A(i,k)), rep(B(k,j)));  
            add(acc, acc, tmp);  
         }  
         conv(X(i,j), acc);  
      }  
   }  
}  
  
  
void mul(mat_ZZ_pE& X, const mat_ZZ_pE& A, const mat_ZZ_pE& B)  
{  
   if (&X == &A || &X == &B) {  
      mat_ZZ_pE tmp;  
      mul_aux(tmp, A, B);  
      X = tmp;  
   }  
   else  
      mul_aux(X, A, B);  
}  
  
  
static
void mul_aux(vec_ZZ_pE& x, const mat_ZZ_pE& A, const vec_ZZ_pE& b)  
{  
   long n = A.NumRows();  
   long l = A.NumCols();  
  
   if (l != b.length())  
      Error("matrix mul: dimension mismatch");  
  
   x.SetLength(n);  
  
   long i, k;  
   ZZ_pX acc, tmp;  
  
   for (i = 1; i <= n; i++) {  
      clear(acc);  
      for (k = 1; k <= l; k++) {  
         mul(tmp, rep(A(i,k)), rep(b(k)));  
         add(acc, acc, tmp);  
      }  
      conv(x(i), acc);  
   }  
}  
  
  
void mul(vec_ZZ_pE& x, const mat_ZZ_pE& A, const vec_ZZ_pE& b)  
{  
   if (&b == &x || A.position1(x) != -1) {
      vec_ZZ_pE tmp;
      mul_aux(tmp, A, b);
      x = tmp;
   }
   else
      mul_aux(x, A, b);
}  

static
void mul_aux(vec_ZZ_pE& x, const vec_ZZ_pE& a, const mat_ZZ_pE& B)  
{  
   long n = B.NumRows();  
   long l = B.NumCols();  
  
   if (n != a.length())  
      Error("matrix mul: dimension mismatch");  
  
   x.SetLength(l);  
  
   long i, k;  
   ZZ_pX acc, tmp;  
  
   for (i = 1; i <= l; i++) {  
      clear(acc);  
      for (k = 1; k <= n; k++) {  
         mul(tmp, rep(a(k)), rep(B(k,i)));
         add(acc, acc, tmp);  
      }  
      conv(x(i), acc);  
   }  
}  

void mul(vec_ZZ_pE& x, const vec_ZZ_pE& a, const mat_ZZ_pE& B)
{
   if (&a == &x) {
      vec_ZZ_pE tmp;
      mul_aux(tmp, a, B);
      x = tmp;
   }
   else
      mul_aux(x, a, B);

}

     
  
void ident(mat_ZZ_pE& X, long n)  
{  
   X.SetDims(n, n);  
   long i, j;  
  
   for (i = 1; i <= n; i++)  
      for (j = 1; j <= n; j++)  
         if (i == j)  
            set(X(i, j));  
         else  
            clear(X(i, j));  
} 


void determinant(ZZ_pE& d, const mat_ZZ_pE& M_in)
{
   long k, n;
   long i, j;
   long pos;
   ZZ_pX t1, t2;
   ZZ_pX *x, *y;

   const ZZ_pXModulus& p = ZZ_pE::modulus();

   n = M_in.NumRows();

   if (M_in.NumCols() != n)
      Error("determinant: nonsquare matrix");

   if (n == 0) {
      set(d);
      return;
   }

   vec_ZZ_pX *M = NTL_NEW_OP vec_ZZ_pX[n];

   for (i = 0; i < n; i++) {
      M[i].SetLength(n);
      for (j = 0; j < n; j++) {
         M[i][j].rep.SetMaxLength(2*deg(p)-1);
         M[i][j] = rep(M_in[i][j]);
      }
   }

   ZZ_pX det;
   set(det);

   for (k = 0; k < n; k++) {
      pos = -1;
      for (i = k; i < n; i++) {
         rem(t1, M[i][k], p);
         M[i][k] = t1;
         if (pos == -1 && !IsZero(t1))
            pos = i;
      }

      if (pos != -1) {
         if (k != pos) {
            swap(M[pos], M[k]);
            negate(det, det);
         }

         MulMod(det, det, M[k][k], p);

         // make M[k, k] == -1 mod p, and make row k reduced

         InvMod(t1, M[k][k], p);
         negate(t1, t1);
         for (j = k+1; j < n; j++) {
            rem(t2, M[k][j], p);
            MulMod(M[k][j], t2, t1, p);
         }

         for (i = k+1; i < n; i++) {
            // M[i] = M[i] + M[k]*M[i,k]

            t1 = M[i][k];   // this is already reduced

            x = M[i].elts() + (k+1);
            y = M[k].elts() + (k+1);

            for (j = k+1; j < n; j++, x++, y++) {
               // *x = *x + (*y)*t1

               mul(t2, *y, t1);
               add(*x, *x, t2);
            }
         }
      }
      else {
         clear(d);
         goto done;
      }
   }

   conv(d, det);

done:
   delete[] M;
}

long IsIdent(const mat_ZZ_pE& A, long n)
{
   if (A.NumRows() != n || A.NumCols() != n)
      return 0;

   long i, j;

   for (i = 1; i <= n; i++)
      for (j = 1; j <= n; j++)
         if (i != j) {
            if (!IsZero(A(i, j))) return 0;
         }
         else {
            if (!IsOne(A(i, j))) return 0;
         }

   return 1;
}
            

void transpose(mat_ZZ_pE& X, const mat_ZZ_pE& A)
{
   long n = A.NumRows();
   long m = A.NumCols();

   long i, j;

   if (&X == & A) {
      if (n == m)
         for (i = 1; i <= n; i++)
            for (j = i+1; j <= n; j++)
               swap(X(i, j), X(j, i));
      else {
         mat_ZZ_pE tmp;
         tmp.SetDims(m, n);
         for (i = 1; i <= n; i++)
            for (j = 1; j <= m; j++)
               tmp(j, i) = A(i, j);
         X.kill();
         X = tmp;
      }
   }
   else {
      X.SetDims(m, n);
      for (i = 1; i <= n; i++)
         for (j = 1; j <= m; j++)
            X(j, i) = A(i, j);
   }
}
   

void solve(ZZ_pE& d, vec_ZZ_pE& X, 
           const mat_ZZ_pE& A, const vec_ZZ_pE& b)

{
   long n = A.NumRows();
   if (A.NumCols() != n)
      Error("solve: nonsquare matrix");

   if (b.length() != n)
      Error("solve: dimension mismatch");

   if (n == 0) {
      set(d);
      X.SetLength(0);
      return;
   }

   long i, j, k, pos;
   ZZ_pX t1, t2;
   ZZ_pX *x, *y;

   const ZZ_pXModulus& p = ZZ_pE::modulus();

   vec_ZZ_pX *M = NTL_NEW_OP vec_ZZ_pX[n];

   for (i = 0; i < n; i++) {
      M[i].SetLength(n+1);
      for (j = 0; j < n; j++) {
         M[i][j].rep.SetMaxLength(2*deg(p)-1);
         M[i][j] = rep(A[j][i]);
      }
      M[i][n].rep.SetMaxLength(2*deg(p)-1);
      M[i][n] = rep(b[i]);
   }

   ZZ_pX det;
   set(det);

   for (k = 0; k < n; k++) {
      pos = -1;
      for (i = k; i < n; i++) {
         rem(t1, M[i][k], p);
         M[i][k] = t1;
         if (pos == -1 && !IsZero(t1)) {
            pos = i;
         }
      }

      if (pos != -1) {
         if (k != pos) {
            swap(M[pos], M[k]);
            negate(det, det);
         }

         MulMod(det, det, M[k][k], p);

         // make M[k, k] == -1 mod p, and make row k reduced

         InvMod(t1, M[k][k], p);
         negate(t1, t1);
         for (j = k+1; j <= n; j++) {
            rem(t2, M[k][j], p);
            MulMod(M[k][j], t2, t1, p);
         }

         for (i = k+1; i < n; i++) {
            // M[i] = M[i] + M[k]*M[i,k]

            t1 = M[i][k];   // this is already reduced

            x = M[i].elts() + (k+1);
            y = M[k].elts() + (k+1);

            for (j = k+1; j <= n; j++, x++, y++) {
               // *x = *x + (*y)*t1

               mul(t2, *y, t1);
               add(*x, *x, t2);
            }
         }
      }
      else {
         clear(d);
         goto done;
      }
   }

   X.SetLength(n);
   for (i = n-1; i >= 0; i--) {
      clear(t1);
      for (j = i+1; j < n; j++) {
         mul(t2, rep(X[j]), M[i][j]);
         add(t1, t1, t2);
      }
      sub(t1, t1, M[i][n]);
      conv(X[i], t1);
   }

   conv(d, det);

done:
   delete[] M;
}

void inv(ZZ_pE& d, mat_ZZ_pE& X, const mat_ZZ_pE& A)
{
   long n = A.NumRows();
   if (A.NumCols() != n)
      Error("inv: nonsquare matrix");

   if (n == 0) {
      set(d);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久久久久久久久久久夜| 另类小说视频一区二区| 国产欧美日韩另类视频免费观看 | 欧美一区二区在线观看| 欧美日韩免费观看一区二区三区| 日本韩国欧美在线| 色婷婷亚洲综合| 欧美性猛交xxxxxxxx| 欧美色国产精品| 91麻豆精品国产91久久久久| 91精品黄色片免费大全| 日韩情涩欧美日韩视频| 精品久久国产97色综合| 国产视频不卡一区| 中文字幕一区二区在线观看| 椎名由奈av一区二区三区| 亚洲欧美二区三区| 亚洲123区在线观看| 日韩av成人高清| 国产一区二区精品久久91| 国产精品一区二区在线播放 | 91免费国产视频网站| 91女人视频在线观看| 欧美日韩免费不卡视频一区二区三区| 欧美日韩一本到| 日韩精品中文字幕在线不卡尤物| 精品国产乱码久久久久久久久 | 毛片一区二区三区| 国产精品亚洲专一区二区三区 | 国产精品久久久久影院色老大| 成人欧美一区二区三区在线播放| 亚洲自拍偷拍欧美| 蜜桃久久久久久| 成人精品鲁一区一区二区| 91色九色蝌蚪| 欧美电视剧在线观看完整版| 国产精品护士白丝一区av| 亚洲一区二区三区在线看| 美腿丝袜亚洲三区| 成人av电影在线播放| 欧美日韩精品福利| 国产日产欧美精品一区二区三区| 一区二区三区四区av| 美国一区二区三区在线播放| 成人18视频在线播放| 欧美精品一级二级三级| 国产亚洲精品福利| 香蕉加勒比综合久久| 国产精品自在在线| 欧美日韩精品欧美日韩精品一 | 中文字幕电影一区| 亚洲成人自拍偷拍| 成人妖精视频yjsp地址| 欧美丰满少妇xxxxx高潮对白| 久久精品视频一区二区三区| 亚洲国产综合色| 国产精品一线二线三线| 欧美精品久久一区| 国产精品久久久久9999吃药| 免费人成在线不卡| 色婷婷综合久久久| 国产人久久人人人人爽| 日韩主播视频在线| 一本一道久久a久久精品 | 亚洲欧洲综合另类在线| 久久国产福利国产秒拍| 欧美中文字幕一二三区视频| 国产精品美女www爽爽爽| 美女被吸乳得到大胸91| 欧美人动与zoxxxx乱| 国产精品欧美一区喷水| 国产又黄又大久久| 日韩一区和二区| 亚洲国产成人高清精品| 99九九99九九九视频精品| 久久一夜天堂av一区二区三区| 午夜精品视频在线观看| 91亚洲精品久久久蜜桃| 国产三级欧美三级日产三级99 | 99精品国产99久久久久久白柏| 日韩视频国产视频| 午夜a成v人精品| 在线精品视频小说1| 国产精品国产精品国产专区不蜜 | 欧美电影在线免费观看| 亚洲精品视频在线| av不卡一区二区三区| 久久亚洲综合av| 激情综合色综合久久| 91精品国产综合久久香蕉的特点| 亚洲一级在线观看| 色婷婷亚洲综合| 亚洲精品国产成人久久av盗摄| 丁香激情综合国产| 亚洲国产精品av| 丰满白嫩尤物一区二区| 久久久午夜电影| 国产精品一区专区| 国产日韩三级在线| www.日本不卡| 国产精品全国免费观看高清| 高清beeg欧美| 国产精品美女久久久久aⅴ国产馆| 成人午夜私人影院| 日韩美女视频19| 色婷婷精品大视频在线蜜桃视频| 亚洲色图20p| 色婷婷久久久亚洲一区二区三区| 亚洲精品免费在线观看| 91久久精品一区二区三区| 一级精品视频在线观看宜春院| 91精品办公室少妇高潮对白| 亚洲综合在线免费观看| 欧美三级电影在线观看| 天涯成人国产亚洲精品一区av| 欧美一区二区视频在线观看2022| 日本不卡一二三区黄网| 日韩区在线观看| 国产91精品露脸国语对白| 国产精品美女久久久久久久| 色婷婷精品久久二区二区蜜臂av | 青青青爽久久午夜综合久久午夜| 日韩欧美成人激情| 丰满放荡岳乱妇91ww| 亚洲日本青草视频在线怡红院| 色婷婷久久久综合中文字幕| 日韩国产在线观看| 精品久久久久久久久久久院品网| 懂色av一区二区三区免费看| 亚洲色图.com| 欧美精品日韩一本| 国产麻豆成人传媒免费观看| 亚洲桃色在线一区| 678五月天丁香亚洲综合网| 久久精品国产久精国产| 亚洲国产精品t66y| 欧美男生操女生| 国产大陆亚洲精品国产| 亚洲欧美国产三级| 欧美一区日韩一区| 成人精品视频一区| 天天色综合天天| 久久精品夜色噜噜亚洲aⅴ| 在线精品视频免费播放| 九九久久精品视频| 亚洲摸摸操操av| 欧美成人三级电影在线| 色综合久久综合网| 六月婷婷色综合| 亚洲免费观看高清完整版在线观看熊 | 国产精品亚洲а∨天堂免在线| 专区另类欧美日韩| 亚洲精品一区二区三区在线观看| 91免费小视频| 国产一区福利在线| 亚洲国产人成综合网站| 国产三级三级三级精品8ⅰ区| 精品视频资源站| 国产成人亚洲综合色影视| 亚洲bt欧美bt精品777| 国产性色一区二区| 欧美日本一区二区三区| 成人avav影音| 激情图片小说一区| 婷婷综合另类小说色区| 一区在线中文字幕| 26uuu亚洲| 欧美日韩日日骚| av在线不卡免费看| 精品制服美女久久| 午夜精品久久久久久久久久| 国产精品午夜免费| 欧美xxxxxxxxx| 欧美日韩aaaaaa| 91啪在线观看| 成人免费va视频| 激情综合亚洲精品| 青青青爽久久午夜综合久久午夜| 一区av在线播放| 亚洲色图一区二区| 国产精品麻豆久久久| 国产三级久久久| 久久亚洲精精品中文字幕早川悠里| 欧美精品99久久久**| 日本伦理一区二区| 99精品桃花视频在线观看| 国产99久久久国产精品潘金网站| 久久精品国产99国产精品| 午夜视频在线观看一区二区| 亚洲欧美另类在线| 日韩一区中文字幕| 亚洲欧洲美洲综合色网| 中文字幕久久午夜不卡| 久久综合狠狠综合久久激情| 日韩一区二区精品在线观看| 538在线一区二区精品国产| 欧美色爱综合网| 欧美艳星brazzers| 在线观看日韩国产| 色爱区综合激月婷婷|