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

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

?? dynlinalg.cpp

?? C++ Math Lib. C++ Builder must use.
?? CPP
字號:
//---------------------------------------------------------------------------
// N.V.Shokhirev
// created: 20040809
// modified: 20050809
//---------------------------------------------------------------------------
#pragma hdrstop

#include "DynLinAlg.h"
#include "MatUtils.h"
#include "dynarrutils.h"

//---------------------------------------------------------------------------

#pragma package(smart_init)

/*  scalar tridiagonal solver (Thomas algorithm)

        | d(1)  a(1)   0             | |u(1)|     |c(1)|
        | b(2)  d(2)  a(2)           | |u(2)|     |c(2)|
        |  0     -     -    -        | | .  |  =  | .  |
        |              -    -    -   | | .  |     | .  |
        |  0               b(n)  d(n)| |u(n)|     |c(n)|
INPUT:
       a - sup-diag,  a is NOT destroyed
       d - diagonal,  b is NOT destroyed
       b - sub-diag
       c(i) - r.h.s.
OUTPUT:
      solution vector, u(i) is returned to the calling program in the c(i) array
*/
void strid(FArr1D& b, FArr1D& d, FArr1D& a, FArr1D& c)
{
  int h = d.H1();
  int l = d.L1();
  double r;
//  Establish upper triangular matrix
  for (int j = l+1; j <= h; j++)
  {
    r    = b(j) / d(j-1);
    d(j) = d(j) - r*a(j-1);
    c(j) = c(j) - r*c(j-1);
  };

//  Back substitution
  c(h) = c(h) / d(h);
  for (int j = h-1; j >= l; j--)
  {
    c(j) = ( c(j) - a(j) * c(j+1) ) / d(j);
  };
} // strid <-----------------------------------------------------------------


/* Tri-diagonal 2D matrix

   | m11 m12  0   -   |   | d(1) a(1)   0              |
   | m21 m22 m23  -   |   | b(2) d(2)  a(2)            |
   |  0  m32 m33  -   | = |  0    -     -     -        |
   |  -   -   -   -   |   |             -     -     -  |
   |  0   0   0   -   |   |  0               b(n)  d(n)|
INPUT:
       a - sup-diag
       d - diagonal
       b - sub-diag
OUTPUT:
       m - tri-dialonal matrix    */
void TridTo2D(FArr1D& b, FArr1D& d, FArr1D& a, FArr2D& m)
{
  int h = d.H1();
  int l = d.L1();
  assert( a.L1() == l && a.H1() == h &&  b.L1() == l && b.H1() == h );
  assert( m.L1() == l && m.H1() == h &&  m.L2() == l && m.H2() == h );
  m.fill(0.0);
  m(l, l ) = d(l);
  for (int j = l+1; j <= h; j++)
  {
    m(j,j-1) = b(j);
    m(j, j ) = d(j);
    m(j-1,j) = a(j-1);
  };
} // TridTo2D <--------------------------------------------------------------


/*  Gauss substitution with diagonal pivots

        | M(1,1) M(1,2) M(1,3) .  M(1,N)| |x(1)|     |b(1)|
        | M(2,1) M(2,2) M(2,3) .  M(2,N)| |x(2)|     |b(2)|
        | M(3,1) M(3,2) M(3,3) .  M(3,N)| |x(3)|     |b(3)|
        |   .      .      .    .    .   | | .  |  =  | .  |
        | M(N,1) M(N,2) M(N,3) .  M(N,N)| |x(N)|     |b(N)|

INPUT:
   M is N x (N+K) array  K > 0
   N x N contains the matrix itself
   the last K columns contain b - r.h.s.
OUTPUT:
   solution vector(s), x is(are) returned the last column(s) of M */
bool GaussD(FArr2D& M)
{
  int h1 = M.H1();
  int l1 = M.L1();
  int h2 = M.H2();
  double t;

  assert( l1 == M.L2() );

  for (int i = l1; i <= h1; i++)
  {
    t = M(i,i);
    if(abs(t) < SafeMinReal) return false;
    for (int j = i; j <= h2; j++) M(i,j) = M(i,j)/t;

    for (int k = l1; k <= h1; k++)
      if (k != i)
      {
        t = M(k,i);
        if(abs(t)>SafeMinReal)
          for (int j = i; j <= h2; j++) M(k,j) = M(k,j)-M(i,j)*t;
      };
  };
  return true;
} // GaussD <----------------------------------------------------------------


/*  Jacobi iterative method for M * x = b

        | M(1,1) M(1,2) M(1,3) .  M(1,N)| |x(1)|     |b(1)|
        | M(2,1) M(2,2) M(2,3) .  M(2,N)| |x(2)|     |b(2)|
        | M(3,1) M(3,2) M(3,3) .  M(3,N)| |x(3)|     |b(3)|
        |   .      .      .    .    .   | | .  |  =  | .  |
        | M(N,1) M(N,2) M(N,3) .  M(N,N)| |x(N)|     |b(N)|
INPUT:
   M is N x N array of coefficients
   b is the vector of r.h.s.
   x - initial approximation
   eps - accuracy
   itermax - iteration limit
OUTPUT:
   solution vector x */
bool JacobiIter(FArr2D& M, FArr1D& x, FArr1D& b, real eps, int itermax)
{
  int h = M.H1();
  int l = M.L1();
  int iter = 0;
  double delta, sum;
  FArr1D y(l,h);

  assert( (l == M.L2()) && (h == M.H2()) );
  do
  {
    iter++;
    delta = 0.0;
    for (int i = l; i <= h; i++)
    {
      sum = 0.0;
      y = x;
      for (int j = l; j <= h; j++)
        if (j != i) sum += M(i,j)*x(j);
      x(i) = (b(i)-sum)/M(i,i);
      delta = max1(delta, abs(x(i)-y(i)));
    };  
  } while ( (delta > eps) && (iter < itermax) );
  return (iter < itermax);
} // JacobiIter <------------------------------------------------------------


/*  Gauss elimination with partial pivoting

        | M(1,1) M(1,2) M(1,3) .  M(1,N)| |x(1)|     |b(1)|
        | M(2,1) M(2,2) M(2,3) .  M(2,N)| |x(2)|     |b(2)|
        | M(3,1) M(3,2) M(3,3) .  M(3,N)| |x(3)|     |b(3)|
        |   .      .      .    .    .   | | .  |  =  | .  |
        | M(N,1) M(N,2) M(N,3) .  M(N,N)| |x(N)|     |b(N)|
INPUT:
   M is N x (N+K) array  K > 0
   N x N contains the matrix itself
   the last K columns contain b - r.h.s.
OUTPUT:
   solution vector(s), x is(are) returned the last column(s) of M */
bool GaussP(FArr2D& M)
{
  int h1 = M.H1();
  int l1 = M.L1();
  int h2 = M.H2();
  int ii;
  double t;

  assert( l1 == M.L2() );

  for (int i = l1; i <= h1; i++)
  {
    // search for the largest element
    t = 0.0;  ii = i;
    for (int j = i; j <= h1; j++) if(abs(M(j,i)) > t){ t = abs(M(j,i)); ii = j;}

    if(t < SafeMinReal) return false;
    if(ii > i) M.swap1(ii,i);

    t = M(i,i);
    for (int j = i; j <= h2; j++) M(i,j) = M(i,j)/t;

    for (int k = l1; k <= h1; k++)
      if (k != i)
      {
        t = M(k,i);
        if(abs(t)>SafeMinReal)
          for (int j = i; j <= h2; j++) M(k,j) = M(k,j)-M(i,j)*t;
      };
  };
  return true;
} // GaussP <----------------------------------------------------------------

/*  Conjugate Gradients solution of A*x = b

        | A(1,1) A(1,2) A(1,3) .  A(1,N)| |x(1)|     |b(1)|
        | A(2,1) A(2,2) A(2,3) .  A(2,N)| |x(2)|     |b(2)|
        | A(3,1) A(3,2) A(3,3) .  A(3,N)| |x(3)|     |b(3)|
        |   .      .      .    .    .   | | .  |  =  | .  |
        | A(N,1) A(N,2) A(N,3) .  A(N,N)| |x(N)|     |b(N)|
INPUT:
   A is N x N array
   x - initial guess for solution vector
   b - r.h.s.
OUTPUT:
   x - solution vector          */
bool ConjGrad(FArr2D& A, FArr1D& b, FArr1D& x, real eps, int itermax)
{
  double Pold, Pnew, beta, gamma;
  int h1 = A.H1();
  int l1 = A.L1();
  int iter = 0;
  int k = sqrt(A.D2());
  //  Temp Arrays d, r, y
  FArr1D y(l1,h1);
  FArr1D d(l1,h1);
  FArr1D r(l1,h1);

  assert( l1 == A.L2() && h1 == A.H2() );

  r = b - A*x;
  Pold = Norm2(r);  //  Pold = r*r;
  d = r;

  while ((Pold > eps) && (iter <= itermax))
  {
    y = A*d;
    beta = Pold/(d*y);
    x = x + beta*d;
    if (iter % k == 0) r = b - A*x;
    else r = r - beta*y;
    Pnew = Norm2(r);  // Pnew = r*r;
    gamma = Pnew/Pold;
    d = r + gamma*d;
    Pold = Pnew;
    iter++;
  };

  return (iter < itermax);
} // ConjGrad <--------------------------------------------------------------


/*  Conjugate Gradients solution of C*x = b

        | C(1,1) C(1,2) .  C(1,N)| |x(1)|     |b(1)|
        | C(2,1) C(2,2) .  C(2,N)| |x(2)|     |b(2)|
        | C(3,1) C(3,2) .  C(3,N)| | .  |  =  |b(3)|
        |   .      .    .    .   | |x(N)|     | .  |
        | C(M,1) C(M,2) .  C(M,N)|            |b(M)|
INPUT:
   C(M,N) array    M >= N
   x(N) - initial guess for solution vector
   b(M) - r.h.s.
OUTPUT:
   x(N) - solution vector     */
bool ConjGradLS(FArr2D& C, FArr1D& b, FArr1D& x, real eps, int itermax)
{
  double Pold, Pnew, beta, gamma;
  int h1 = C.H1();
  int l1 = C.L1();
  int h2 = C.H2();
  int l2 = C.L2();
  int iter = 0;
  int k = sqrt(C.D2());
  // Temp Arrays  g(N), d(N), r(M), y(M)
  FArr1D y(l1,h1);
  FArr1D d(l2,h2);
  FArr1D r(l1,h1);
  FArr1D g(l2,h2);

  r = b - C*x;
  g = r*C;
  Pold = Norm2(g);  //  Pold = g*g;
  d = g;

  while ((Pold > eps) && (iter <= itermax))
  {
    y = C*d;
    beta = Pold/Norm2(y);  //  beta = Pold/(y*y);
    x = x + beta*d;
    if (iter % k == 0) r = b - C*x;
    else r = r - beta*y;
    g = r*C;
    Pnew = Norm2(g);  //  Pnew = g*g;
    gamma = Pnew/Pold;
    d = g + gamma*d;
    Pold = Pnew;
    iter++;
  };
  return (iter < itermax);
} // ConjGradLS <------------------------------------------------------------


int index321(int i1, int i2, int i3, int l1, int l2, int l3, int n1, int n2, int n3)
{
  return (i1-l1 + n1*(i2-l2 + n2*(i3-l3)));
}

void i3i2i1(int i, int& i1, int& i2, int& i3, int l1, int l2, int l3, int n1, int n2, int n3)
{
  int n1n2 = n1*n2;
  i3 = i/n1n2+l3;  i %= n1n2;
  i2 = i/n1+l2;
  i1 = i % n1 + l1;
}

int index123(int i1, int i2, int i3, int l1, int l2, int l3, int n1, int n2, int n3)
{
  return (i3-l3 + n3*(i2-l2 + n2*(i1-l1)));
}

void i1i2i3(int i, int& i1, int& i2, int& i3, int l1, int l2, int l3, int n1, int n2, int n3)
{
  int n3n2 = n3*n2;
  i1 = i/n3n2+l1;  i %= n3n2;
  i2 = i/n3+l2;
  i3 = i % n3 + l3;
}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美极品美女视频| 91一区二区三区在线播放| 亚洲乱码中文字幕| 中文av一区二区| 欧美精品一区二| 欧美一级国产精品| 精品久久久久久久人人人人传媒| 欧美午夜电影一区| 欧美色视频一区| 欧美日韩精品一区二区| 在线观看中文字幕不卡| 在线观看不卡一区| 欧美日韩精品是欧美日韩精品| 欧美视频在线观看一区| 欧美日韩一区高清| 日韩欧美亚洲另类制服综合在线 | 日韩va欧美va亚洲va久久| 亚洲成人资源在线| 久久99精品一区二区三区三区| 精品亚洲成a人| 国产福利一区二区三区视频在线| 国产综合色视频| 高清av一区二区| 色婷婷综合五月| 日韩亚洲欧美成人一区| 久久精品在线观看| 亚洲一区二区三区激情| 国产成人在线视频播放| av电影在线观看不卡| 欧美中文字幕一区| 欧美成人a视频| 国产精品网站导航| 午夜精品久久一牛影视| 国产自产v一区二区三区c| 91在线观看免费视频| 欧美精品自拍偷拍| 欧美精品一区二区三区很污很色的 | 色综合久久88色综合天天免费| 色国产精品一区在线观看| 日韩欧美专区在线| 成人免费一区二区三区在线观看| 偷偷要91色婷婷| 成a人片亚洲日本久久| 7777女厕盗摄久久久| 国产日韩欧美精品综合| 午夜视频一区二区三区| 成人激情开心网| 日韩一级成人av| 亚洲欧美激情视频在线观看一区二区三区 | 91官网在线观看| 日韩精品一区二区三区四区| 中文字幕中文在线不卡住| 免费高清在线一区| 色天天综合色天天久久| 久久综合资源网| 日本不卡在线视频| 在线视频一区二区三| 欧美极品xxx| 久久精品二区亚洲w码| 日韩欧美在线网站| 亚洲国产中文字幕| 成人午夜免费av| 久久一日本道色综合| 天堂午夜影视日韩欧美一区二区| 成人av午夜电影| 欧美激情在线看| 国产乱码精品一区二区三区五月婷 | 亚洲天天做日日做天天谢日日欢| 国产中文字幕一区| 日韩欧美国产1| 肉色丝袜一区二区| 欧美日韩国产高清一区二区三区| 国产偷国产偷亚洲高清人白洁 | 日韩精品专区在线影院观看| 亚洲一区国产视频| 欧美色综合网站| 欧美激情在线看| 成人少妇影院yyyy| 中文av一区二区| caoporn国产一区二区| 国产日韩av一区| 国产aⅴ精品一区二区三区色成熟| 欧美电影免费提供在线观看| 久久99国产精品尤物| 欧美大片国产精品| 国产制服丝袜一区| 国产日韩欧美一区二区三区综合| 国产精品18久久久| 亚洲天堂av老司机| 欧美亚洲日本国产| 日本成人中文字幕| 精品国产伦一区二区三区免费 | 中文字幕一区二区三区在线观看| 日本乱人伦一区| 亚洲观看高清完整版在线观看| 欧美三级日韩三级| 一区在线播放视频| 欧美日韩激情一区| 亚洲欧美日韩综合aⅴ视频| 色综合激情五月| 日韩和欧美的一区| 久久综合色播五月| 91麻豆成人久久精品二区三区| 亚洲在线免费播放| 日韩精品一区二区三区在线 | 92国产精品观看| 午夜激情综合网| 久久一二三国产| 在线观看亚洲成人| 免费精品视频在线| 亚洲色图第一区| 精品三级在线看| 紧缚捆绑精品一区二区| 4438成人网| 99久久精品国产精品久久| 亚洲成人午夜电影| 国产午夜精品美女毛片视频| 色狠狠av一区二区三区| 久久国产成人午夜av影院| 久久久亚洲精华液精华液精华液| 色婷婷狠狠综合| 成人免费看视频| 日本不卡视频在线| 亚洲一级不卡视频| 国产精品国产三级国产有无不卡 | 亚洲国产精品久久人人爱蜜臀| 香蕉乱码成人久久天堂爱免费| 久久蜜桃av一区二区天堂 | 亚洲精品在线观看网站| 亚洲成人激情综合网| 欧美系列亚洲系列| 亚洲一区二区三区爽爽爽爽爽| 99久精品国产| 亚洲一级二级三级在线免费观看| 欧美日韩免费一区二区三区 | 国产精品传媒视频| 欧美性猛交一区二区三区精品| 蜜桃视频在线观看一区| 中文字幕精品三区| 欧美中文字幕一二三区视频| 免费成人你懂的| 中文字幕五月欧美| 91精品国产高清一区二区三区蜜臀| 成人app下载| 日韩av中文在线观看| 中文字幕亚洲电影| 亚洲精品一区二区三区四区高清 | 欧美大片国产精品| 国产精品资源网| 一区二区成人在线| 久久久久久久久免费| 欧美视频一区二区| 国产一区欧美二区| 亚洲国产一区二区三区青草影视| 久久久国产一区二区三区四区小说 | 亚洲福利一区二区三区| 日韩亚洲电影在线| 欧美中文字幕一区二区三区亚洲 | 激情都市一区二区| voyeur盗摄精品| 蜜臀久久99精品久久久画质超高清| 国产精品二三区| 欧美精品一区二区三区蜜臀| 日本丶国产丶欧美色综合| 极品少妇xxxx精品少妇| 亚洲永久精品国产| 亚洲三级在线观看| 久久久777精品电影网影网| 在线观看亚洲精品| 国产一区二区三区免费| 亚洲最大的成人av| 日韩午夜小视频| 成人国产精品视频| 精品亚洲国内自在自线福利| 亚洲国产精品t66y| 中文欧美字幕免费| 欧美v日韩v国产v| 欧美日韩二区三区| 99精品视频免费在线观看| 国产呦精品一区二区三区网站| 日本不卡一二三区黄网| 亚洲欧美国产三级| 国产精品欧美精品| 欧美一区二区免费观在线| 91精品一区二区三区在线观看| 色视频一区二区| 成人午夜电影网站| 国产精品系列在线播放| 国产一区二区三区视频在线播放| 美女诱惑一区二区| 免费欧美日韩国产三级电影| 亚洲mv大片欧洲mv大片精品| 亚洲电影你懂得| 亚洲国产综合人成综合网站| 亚洲人成精品久久久久久| 亚洲天堂成人网| 亚洲一区二区欧美激情| 一区二区三区毛片| 国产精品乱码一区二区三区软件| 国产亚洲成av人在线观看导航 |