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

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

?? mat_zz_p.cpp

?? 一個比較通用的大數運算庫
?? CPP
?? 第 1 頁 / 共 2 頁
字號:

#include <NTL/mat_ZZ_p.h>
#include <NTL/vec_ZZVec.h>
#include <NTL/vec_long.h>

#include <NTL/new.h>

NTL_START_IMPL

NTL_matrix_impl(ZZ_p,vec_ZZ_p,vec_vec_ZZ_p,mat_ZZ_p)
NTL_io_matrix_impl(ZZ_p,vec_ZZ_p,vec_vec_ZZ_p,mat_ZZ_p)
NTL_eq_matrix_impl(ZZ_p,vec_ZZ_p,vec_vec_ZZ_p,mat_ZZ_p)


  
void add(mat_ZZ_p& X, const mat_ZZ_p& A, const mat_ZZ_p& 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_p& X, const mat_ZZ_p& A, const mat_ZZ_p& 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_p& X, const mat_ZZ_p& 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_p& X, const mat_ZZ_p& A, const mat_ZZ_p& 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 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_p& X, const mat_ZZ_p& A, const mat_ZZ_p& B)  
{  
   if (&X == &A || &X == &B) {  
      mat_ZZ_p tmp;  
      mul_aux(tmp, A, B);  
      X = tmp;  
   }  
   else  
      mul_aux(X, A, B);  
}  
  
  
static
void mul_aux(vec_ZZ_p& x, const mat_ZZ_p& A, const vec_ZZ_p& 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 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_p& x, const mat_ZZ_p& A, const vec_ZZ_p& b)  
{  
   if (&b == &x || A.position1(x) != -1) {
      vec_ZZ_p tmp;
      mul_aux(tmp, A, b);
      x = tmp;
   }
   else
      mul_aux(x, A, b);
}  

static
void mul_aux(vec_ZZ_p& x, const vec_ZZ_p& a, const mat_ZZ_p& 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 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_p& x, const vec_ZZ_p& a, const mat_ZZ_p& B)
{
   if (&a == &x) {
      vec_ZZ_p tmp;
      mul_aux(tmp, a, B);
      x = tmp;
   }
   else
      mul_aux(x, a, B);
}

     
  
void ident(mat_ZZ_p& 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_p& d, const mat_ZZ_p& M_in)
{
   long k, n;
   long i, j;
   long pos;
   ZZ t1, t2;
   ZZ *x, *y;

   const ZZ& p = ZZ_p::modulus();

   n = M_in.NumRows();

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

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

   vec_ZZVec M;
   sqr(t1, p);
   mul(t1, t1, n);

   M.SetLength(n);
   for (i = 0; i < n; i++) {
      M[i].SetSize(n, t1.size());
      for (j = 0; j < n; j++)
         M[i][j] = rep(M_in[i][j]);
   }

   ZZ 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]);
            NegateMod(det, det, p);
         }

         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);
         NegateMod(t1, t1, p);
         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);
         return;
      }
   }

   conv(d, det);
}

long IsIdent(const mat_ZZ_p& 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_p& X, const mat_ZZ_p& 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_p 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_p& d, vec_ZZ_p& X, 
           const mat_ZZ_p& A, const vec_ZZ_p& 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 t1, t2;
   ZZ *x, *y;

   const ZZ& p = ZZ_p::modulus();

   vec_ZZVec M;
   sqr(t1, p);
   mul(t1, t1, n);

   M.SetLength(n);

   for (i = 0; i < n; i++) {
      M[i].SetSize(n+1, t1.size());
      for (j = 0; j < n; j++) 
         M[i][j] = rep(A[j][i]);
      M[i][n] = rep(b[i]);
   }

   ZZ 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]);
            NegateMod(det, det, p);
         }

         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);
         NegateMod(t1, t1, p);
         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);
         return;
      }
   }

   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);
}

void inv(ZZ_p& d, mat_ZZ_p& X, const mat_ZZ_p& A)
{

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区午夜精品| 欧美日韩一区二区在线视频| 三级在线观看一区二区| 亚洲精品综合在线| 一区二区三区资源| 亚洲国产精品久久久久秋霞影院| 亚洲最大色网站| 亚洲成av人片在线观看| 日日骚欧美日韩| 美女性感视频久久| 国产电影一区二区三区| 97久久精品人人做人人爽50路| 福利一区二区在线| 色综合色综合色综合色综合色综合| 91亚洲国产成人精品一区二区三| 色婷婷综合久久久久中文一区二区| 欧美专区日韩专区| 日韩一区二区三区在线| 国产视频一区在线观看| 国产精品乱人伦| 亚洲一区二区三区精品在线| 日韩高清国产一区在线| 国产精品一区二区男女羞羞无遮挡| 成人黄色国产精品网站大全在线免费观看| 91麻豆国产自产在线观看| 欧美精品高清视频| 国产欧美精品一区二区三区四区| 亚洲欧美aⅴ...| 狠狠色丁香婷婷综合| 色综合亚洲欧洲| 日韩欧美区一区二| 亚洲乱码一区二区三区在线观看| 久久精品国产免费看久久精品| 成人午夜激情视频| 91精品国产入口| 亚洲视频一区二区在线| 另类人妖一区二区av| 色婷婷综合在线| 久久久久综合网| 无码av免费一区二区三区试看| 国产成人一级电影| 欧美一区二区在线看| 亚洲欧美在线高清| 国产精品一区在线观看乱码| 精品视频一区二区三区免费| 国产午夜精品福利| 蜜臀av一级做a爰片久久| 91浏览器在线视频| 欧美国产国产综合| 激情图区综合网| 精品视频免费在线| 日韩一区有码在线| 成人免费视频视频在线观看免费 | 91视视频在线观看入口直接观看www | 欧美一二三四区在线| 亚洲免费成人av| 东方aⅴ免费观看久久av| 日韩一区二区三区视频在线| 亚洲黄色av一区| 91免费版pro下载短视频| 久久综合九色综合久久久精品综合| 亚洲第一激情av| 欧美无人高清视频在线观看| 一区在线播放视频| 北条麻妃一区二区三区| 国产午夜精品久久| 国产成人午夜精品影院观看视频| 欧美xxxx在线观看| 免费高清在线一区| 日韩精品一区二| 精品中文字幕一区二区小辣椒| 欧美日韩三级一区| 视频在线观看一区二区三区| 欧美偷拍一区二区| 日日骚欧美日韩| 日韩欧美亚洲国产另类| 精品一区二区影视| 2020日本不卡一区二区视频| 韩国在线一区二区| 国产欧美精品一区二区色综合| 粉嫩绯色av一区二区在线观看| 亚洲国产高清在线| 色婷婷亚洲综合| 日韩国产欧美在线视频| 日韩欧美国产系列| 夫妻av一区二区| 亚洲丝袜美腿综合| 欧美亚洲国产一卡| 免费观看在线综合| 国产午夜亚洲精品理论片色戒| 国产成人免费在线视频| 中文字幕亚洲视频| 欧美日韩亚洲综合一区| 欧美bbbbb| 国产精品国产自产拍高清av王其 | 成人免费毛片片v| 一区二区三区日韩精品视频| 欧美精品亚洲二区| 国产一区999| 亚洲精品综合在线| 欧美电影免费观看高清完整版在| 国产成人亚洲综合色影视| 一区二区三区蜜桃| wwwwxxxxx欧美| 欧洲色大大久久| 国产一区二区看久久| 亚洲激情在线播放| 久久久久久久久99精品| 欧美性极品少妇| 国产ts人妖一区二区| 亚洲高清免费在线| 国产精品三级视频| 6080亚洲精品一区二区| 成人av在线影院| 另类专区欧美蜜桃臀第一页| 亚洲人123区| 久久精品亚洲精品国产欧美kt∨| 在线亚洲人成电影网站色www| 精品一区二区成人精品| 曰韩精品一区二区| 国产人久久人人人人爽| 91精品国产入口| 在线观看日韩国产| 大尺度一区二区| 美女免费视频一区二区| 一级特黄大欧美久久久| 国产精品人妖ts系列视频| 欧美大片免费久久精品三p| 在线免费不卡电影| 不卡的电视剧免费网站有什么| 另类小说色综合网站| 亚洲一二三区视频在线观看| 国产精品久线在线观看| 久久久久久久久99精品| 日韩一二三区不卡| 制服丝袜av成人在线看| 欧美人与禽zozo性伦| 91福利精品视频| 91官网在线免费观看| 色综合视频在线观看| aa级大片欧美| 99久久精品国产观看| 99视频精品全部免费在线| 风间由美一区二区av101| 国产一区二区视频在线| 麻豆91在线播放免费| 麻豆极品一区二区三区| 日本91福利区| 久久99精品国产麻豆不卡| 美日韩黄色大片| 国产综合久久久久久久久久久久| 麻豆精品久久精品色综合| 久久精品国产一区二区| 精品一区免费av| 国产精品自拍av| www.亚洲在线| 色婷婷综合激情| 在线成人高清不卡| 日韩欧美在线123| 日韩免费电影一区| 国产欧美日韩三级| 亚洲美女在线一区| 亚洲电影一区二区三区| 亚洲国产另类av| 久久99九九99精品| 成人小视频在线观看| 色婷婷精品久久二区二区蜜臀av| 欧美无砖专区一中文字| 欧美成人性战久久| 国产精品美女久久久久久久久| 中文字幕在线观看不卡视频| 一区二区日韩av| 久久av中文字幕片| av亚洲精华国产精华精华| 日本乱码高清不卡字幕| 欧美肥胖老妇做爰| 久久精品一区二区| 亚洲精品国产视频| 久久成人av少妇免费| 成人丝袜18视频在线观看| 欧美色视频一区| 久久久久久久久岛国免费| 亚洲日本在线看| 国内精品嫩模私拍在线| 91麻豆免费观看| 日韩欧美一级特黄在线播放| 国产精品国产自产拍在线| 天天影视色香欲综合网老头| 国产福利精品导航| 欧美三级中文字| 国产精品人成在线观看免费| 日韩电影在线观看电影| av一本久道久久综合久久鬼色| 欧美一区二区播放| 亚洲激情男女视频| 成人免费精品视频| 精品福利二区三区| 亚洲线精品一区二区三区| 成人中文字幕合集| 久久综合久久99|