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

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

?? eigen.pas

?? Delphi 的數學控件
?? PAS
?? 第 1 頁 / 共 3 頁
字號:
      end;

    { Double QR step involving rows L to En and columns M to En }
    for K := M to Na do
      begin
        NotLas := (K <> Na);
        if (K = M) then goto 170;
        P := H[K,K - 1];
        Q := H[K + 1,K - 1];
        R := 0.0;
        if NotLas then R := H[K + 2,K - 1];
        X := Abs(P) + Abs(Q) + Abs(R);
        if X = 0.0 then goto 260;
        P := P / X;
        Q := Q / X;
        R := R / X;
170:    S := DSgn(Sqrt(P * P + Q * Q + R * R), P);
        if K <> M then
          H[K,K - 1] := - S * X
        else if L <> M then
          H[K,K - 1] := - H[K,K - 1];
        P := P + S;
        X := P / S;
        Y := Q / S;
        Zz := R / S;
        Q := Q / P;
        R := R / P;
        if NotLas then goto 225;

        { Row modification }
        for J := K to Ubound do
          begin
            P := H[K,J] + Q * H[K + 1,J];
            H[K,J] := H[K,J] - P * X;
            H[K + 1,J] := H[K + 1,J] - P * Y;
          end;

        J := Min(En, K + 3);

        { Column modification }
        for I := Lbound to J do
          begin
            P := X * H[I,K] + Y * H[I,K + 1];
            H[I,K] := H[I,K] - P;
            H[I,K + 1] := H[I,K + 1] - P * Q;
          end;

        { Accumulate transformations }
        for I := I_low to I_igh do
          begin
            P := X * Z[I,K] + Y * Z[I,K + 1];
            Z[I,K] := Z[I,K] - P;
            Z[I,K + 1] := Z[I,K + 1] - P * Q;
          end;
        goto 260;

225:
        { Row modification }
        for J := K to Ubound do
          begin
            P := H[K,J] + Q * H[K + 1,J] + R * H[K + 2,J];
            H[K,J] := H[K,J] - P * X;
            H[K + 1,J] := H[K + 1,J] - P * Y;
            H[K + 2,J] := H[K + 2,J] - P * Zz;
          end;

        J := Min(En, K + 3);

        { Column modification }
        for I := Lbound to J do
          begin
            P := X * H[I,K] + Y * H[I,K + 1] + Zz * H[I,K + 2];
            H[I,K] := H[I,K] - P;
            H[I,K + 1] := H[I,K + 1] - P * Q;
            H[I,K + 2] := H[I,K + 2] - P * R;
          end;

        { Accumulate transformations }
        for I := I_low to I_igh do
          begin
            P := X * Z[I,K] + Y * Z[I,K + 1] + Zz * Z[I,K + 2];
            Z[I,K] := Z[I,K] - P;
            Z[I,K + 1] := Z[I,K + 1] - P * Q;
            Z[I,K + 2] := Z[I,K + 2] - P * R;
          end;

260:  end;

    goto 70;

270: { One root found }
    H[En,En] := X + T;
    Wr[En] := H[En,En];
    Wi[En] := 0.0;
    En := Na;
    goto 60;

280: { Two roots found }
    P := 0.5 * (Y - X);
    Q := P * P + W;
    Zz := Sqrt(Abs(Q));
    H[En,En] := X + T;
    X := H[En,En];
    H[Na,Na] := Y + T;
    if Q < 0.0 then goto 320;

    { Real pair }
    Zz := P + DSgn(Zz, P);
    Wr[Na] := X + Zz;
    Wr[En] := Wr[Na];
    if Zz <> 0.0 then Wr[En] := X - W / Zz;
    Wi[Na] := 0.0;
    Wi[En] := 0.0;
    X := H[En,Na];
    S := Abs(X) + Abs(Zz);
    P := X / S;
    Q := Zz / S;
    R := Sqrt(P * P + Q * Q);
    P := P / R;
    Q := Q / R;

    { Row modification }
    for J := Na to Ubound do
      begin
        Zz := H[Na,J];
        H[Na,J] := Q * Zz + P * H[En,J];
        H[En,J] := Q * H[En,J] - P * Zz;
      end;

    { Column modification }
    for I := Lbound to En do
      begin
        Zz := H[I,Na];
        H[I,Na] := Q * Zz + P * H[I,En];
        H[I,En] := Q * H[I,En] - P * Zz;
      end;

    { Accumulate transformations }
    for I := I_low to I_igh do
      begin
        Zz := Z[I,Na];
        Z[I,Na] := Q * Zz + P * Z[I,En];
        Z[I,En] := Q * Z[I,En] - P * Zz;
      end;

    goto 330;

320: { Complex pair }
    Wr[Na] := X + P;
    Wr[En] := Wr[Na];
    Wi[Na] := Zz;
    Wi[En] := - Zz;

330:
    En := Enm2;
    goto 60;

340:
    if Norm = 0.0 then Exit;

    { All roots found. Backsubstitute to find
      vectors of upper triangular form }
    for En := Ubound downto Lbound do
      begin
        P := Wr[En];
        Q := Wi[En];
        Na := En - 1;
        if Q < 0.0 then
          goto 710
        else if Q = 0.0 then
          goto 600
        else
          goto 800;

600:    { Real vector }
        M := En;
        H[En,En] := 1.0;
        if Na < Lbound then goto 800;

        for I := Na downto Lbound do
          begin
            W := H[I,I] - P;
            R := 0.0;

            for J := M to En do
              R := R + H[I,J] * H[J,En];

            if Wi[I] >= 0.0 then goto 630;
            Zz := W;
            S := R;
            goto 700;
630:        M := I;
            if Wi[I] <> 0.0 then goto 640;
            T := W;
            if T <> 0.0 then goto 635;
            Tst1 := Norm;
            T := Tst1;
            repeat
              T := 0.01 * T;
              Tst2 := Norm + T;
            until Tst2 <= Tst1;
635:        H[I,En] := - R / T;
            goto 680;

640:        { Solve real equations }
            X := H[I,I + 1];
            Y := H[I + 1,I];
            Q := (Wr[I] - P) * (Wr[I] - P) + Wi[I] * Wi[I];
            T := (X * S - Zz * R) / Q;
            H[I,En] := T;
            if Abs(X) > Abs(Zz) then
              H[I + 1,En] := (- R - W * T) / X
            else
              H[I + 1,En] := (- S - Y * T) / Zz;

680:        { Overflow control }
            T := Abs(H[I,En]);
            if T = 0.0 then goto 700;
            Tst1 := T;
            Tst2 := Tst1 + 1.0 / Tst1;
            if Tst2 > Tst1 then goto 700;
            for J := I to En do
              H[J,En] := H[J,En] / T;
700:      end;
        { End real vector }
        goto 800;

        { Complex vector }
710:    M := Na;

        { Last vector component chosen imaginary so that
          eigenvector matrix is triangular }
        if Abs(H[En,Na]) > Abs(H[Na,En]) then
          begin
            H[Na,Na] := Q / H[En,Na];
            H[Na,En] := - (H[En,En] - P) / H[En,Na];
          end
        else
          Cdiv(0.0, - H[Na,En], H[Na,Na] - P, Q, H[Na,Na], H[Na,En]);

        H[En,Na] := 0.0;
        H[En,En] := 1.0;
        Enm2 := Na - 1;
        if Enm2 < Lbound then goto 800;

        for I := Enm2 downto Lbound do
          begin
            W := H[I,I] - P;
            Ra := 0.0;
            Sa := 0.0;

            for J := M to En do
              begin
                Ra := Ra + H[I,J] * H[J,Na];
                Sa := Sa + H[I,J] * H[J,En];
              end;

            if Wi[I] >= 0.0 then goto 770;
            Zz := W;
            R := Ra;
            S := Sa;
            goto 795;
770:        M := I;
            if Wi[I] <> 0.0 then goto 780;
            Cdiv(- Ra, - Sa, W, Q, H[I,Na], H[I,En]);
            goto 790;

            { Solve complex equations }
780:        X := H[I,I + 1];
            Y := H[I + 1,I];
            Vr := (Wr[I] - P) * (Wr[I] - P) + Wi[I] * Wi[I] - Q * Q;
            Vi := (Wr[I] - P) * 2.0 * Q;
            if (Vr = 0.0) and (Vi = 0.0) then
              begin
                Tst1 := Norm * (Abs(W) + Abs(Q) + Abs(X) + Abs(Y) + Abs(Zz));
                Vr := Tst1;
                repeat
                  Vr := 0.01 * Vr;
                  Tst2 := Tst1 + Vr;
                until Tst2 <= Tst1;
              end;
            Cdiv(X * R - Zz * Ra + Q * Sa, X * S - Zz * Sa - Q * Ra, Vr, Vi, H[I,Na], H[I,En]);
            if Abs(X) > Abs(Zz) + Abs(Q) then
              begin
                H[I + 1,Na] := (- Ra - W * H[I,Na] + Q * H[I,En]) / X;
                H[I + 1,En] := (- Sa - W * H[I,En] - Q * H[I,Na]) / X;
              end
            else
              Cdiv(- R - Y * H[I,Na], - S - Y * H[I,En], Zz, Q, H[I + 1,Na], H[I + 1,En]);

790:        { Overflow control }
            T := Max(Abs(H[I,Na]), Abs(H[I,En]));
            if T = 0.0 then goto 795;
            Tst1 := T;
            Tst2 := Tst1 + 1.0 / Tst1;
            if Tst2 > Tst1 then goto 795;
            for J := I to En do
              begin
                H[J,Na] := H[J,Na] / T;
                H[J,En] := H[J,En] / T;
              end;

795:      end;
      { End complex vector }
800:  end;

    { End back substitution.
      Vectors of isolated roots }
    for I := Lbound to Ubound do
      if (I < I_low) or (I > I_igh) then
        for J := I to Ubound do
          Z[I,J] := H[I,J];

    { Multiply by transformation matrix to give
      vectors of original full matrix. }
    for J := Ubound downto I_low do
      begin
        M := Min(J, I_igh);
        for I := I_low to I_igh do
          begin
            Zz := 0.0;
            for K := I_low to M do
              Zz := Zz + Z[I,K] * H[K,J];
            Z[I,J] := Zz;
          end;
      end;

    Hqr2 := 0;
  end;

  procedure BalBak(Z : TMatrix; Lbound, Ubound, I_low, I_igh : Integer;
                   Scale : TVector; M : Integer);
{ ----------------------------------------------------------------------
  This procedure is a translation of the EISPACK subroutine Balbak

  This procedure forms the eigenvectors of a real general matrix
  by back transforming those of the corresponding balanced matrix
  determined by Balance.

  On input:

    Z contains the real and imaginary parts of the eigenvectors
    to be back transformed.

    Lbound, Ubound are the lowest and highest indices
    of the elements of Z

    I_low and I_igh are integers determined by Balance.

    Scale contains information determining the permutations
    and scaling factors used by Balance.

    M is the index of the latest column of Z to be back transformed.

  On output:

    Z contains the real and imaginary parts of the transformed
    eigenvectors in its columns Lbound..M
  ---------------------------------------------------------------------- }
  var
    I, J, K : Integer;
    S : Float;
  begin
    if M < Lbound then Exit;

    if I_igh <> I_low then
      for I := I_low to I_igh do
        begin
          S := Scale[I];
          { Left hand eigenvectors are back transformed if the
            foregoing statement is replaced by S := 1.0 / Scale[I] }
          for J := Lbound to M do
            Z[I,J] := Z[I,J] * S;
        end;

    for I := (I_low - 1) downto Lbound do
      begin
        K := Round(Scale[I]);
        if K <> I then
          for J := Lbound to M do
            Swap(Z[I,J], Z[K,J]);
      end;

    for I := (I_igh + 1) to Ubound do
      begin
        K := Round(Scale[I]);
        if K <> I then
          for J := Lbound to M do
            Swap(Z[I,J], Z[K,J]);
      end;
  end;

  function EigenVals(A : TMatrix; Lbound, Ubound : Integer;
                     Lambda_Re, Lambda_Im : TVector) : Integer;
  var
    I_low, I_igh : Integer;
    Scale : TVector;
    I_int : TIntVector;
  begin
    DimVector(Scale, Ubound);
    DimVector(I_Int, Ubound);

    Balance(A, Lbound, Ubound, I_low, I_igh, Scale);
    ElmHes(A, Lbound, Ubound, I_low, I_igh, I_int);
    EigenVals := Hqr(A, Lbound, Ubound, I_low, I_igh, Lambda_Re, Lambda_Im);
  end;

  function EigenVect(A : TMatrix; Lbound, Ubound : Integer;
                     Lambda_Re, Lambda_Im : TVector; V : TMatrix) : Integer;
  var
    I_low, I_igh, ErrCode : Integer;
    Scale : TVector;
    I_Int : TIntVector;
  begin
    DimVector(Scale, Ubound);
    DimVector(I_Int, Ubound);

    Balance(A, Lbound, Ubound, I_low, I_igh, Scale);
    ElmHes(A, Lbound, Ubound, I_low, I_igh, I_int);
    Eltran(A, Lbound, Ubound, I_low, I_igh, I_int, V);
    ErrCode := Hqr2(A, Lbound, Ubound, I_low, I_igh, Lambda_Re, Lambda_Im, V);
    if ErrCode = 0 then BalBak(V, Lbound, Ubound, I_low, I_igh, Scale, Ubound);

    EigenVect := ErrCode;
  end;

  procedure DivLargest(V : TVector; Lbound, Ubound : Integer;
                       var Largest : Float);
  var
    I : Integer;
  begin
    Largest := V[Lbound];
    for I := Succ(Lbound) to Ubound do
      if Abs(V[I]) > Abs(Largest) then
        Largest := V[I];
    for I := Lbound to Ubound do
      V[I] := V[I] / Largest;
  end;

  function RootPol(Coef : TVector; Deg : Integer;
                   Xr, Xi : TVector) : Integer;
  var
    A            : TMatrix;  { Companion matrix }
    N            : Integer;  { Size of matrix }
    I_low, I_igh : Integer;  { Used by Balance }
    Scale        : TVector;  { Used by Balance }
    Nr           : Integer;  { Number of real roots }
    I, J         : Integer;  { Loop variables }
    ErrCode      : Integer;  { Error code }
  begin
    N := Pred(Deg);
    DimMatrix(A, N, N);
    DimVector(Scale, N);

    { Set up the companion matrix (to save space, begin at index 0) }
    for J := 0 to N do
      A[0,J] := - Coef[Deg - J - 1] / Coef[Deg];
    for J := 0 to Pred(N) do
      A[J + 1,J] := 1.0;

    { The roots of the polynomial are the eigenvalues of the companion matrix }
    Balance(A, 0, N, I_low, I_igh, Scale);
    ErrCode := Hqr(A, 0, N, I_low, I_igh, Xr, Xi);

    if ErrCode <> 0 then
      begin
        RootPol := ErrCode;
        Exit;
      end;

    { Count real roots }
    Nr := 0;
    for I := 0 to N do
      if Xi[I] = 0.0 then
        Inc(Nr);

    { Transfer roots from 0..(Deg - 1) to 1..Deg }
    for I := N downto 0 do
      begin
        J := I + 1;
        Xr[J] := Xr[I];
        Xi[J] := Xi[I];
      end;

    RootPol := Nr;
  end;

end.

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩视频在线一区二区| 国产精品理论片在线观看| 日韩av电影免费观看高清完整版在线观看| 精品视频999| 亚洲一区二区欧美日韩| 欧美经典一区二区三区| 精品国产乱码久久久久久夜甘婷婷| 91黄色小视频| 91蜜桃传媒精品久久久一区二区| 国产精品99久久久久久有的能看 | 97久久久精品综合88久久| 久久99久久精品| 日韩极品在线观看| 亚洲视频在线一区| 日韩欧美中文一区二区| 91麻豆精品国产91久久久久久久久 | 欧美人妖巨大在线| 国产不卡视频一区| 午夜电影网亚洲视频| 成人欧美一区二区三区视频网页| 欧美国产日韩精品免费观看| 国产日韩av一区| 国产色一区二区| 欧美变态口味重另类| 欧美精品aⅴ在线视频| 亚洲国产成人av网| 日本一区二区三区国色天香| 成人av网站免费观看| 99久久99久久精品免费看蜜桃| 国产精品欧美一级免费| 亚洲精品国产精品乱码不99| 在线播放国产精品二区一二区四区| 成人午夜又粗又硬又大| 亚洲中国最大av网站| 亚洲精品一区二区三区福利| 欧美日韩在线免费视频| 91影院在线观看| 91麻豆福利精品推荐| av在线免费不卡| 成人v精品蜜桃久久一区| 国产高清精品久久久久| 粉嫩一区二区三区在线看| 久久电影网站中文字幕| 精品中文字幕一区二区小辣椒| 狠狠久久亚洲欧美| 免费看欧美女人艹b| 激情深爱一区二区| 成人美女在线观看| 91美女片黄在线| 日韩美女啊v在线免费观看| 欧美一区二区三区免费在线看 | 成人短视频下载| 欧美日韩高清在线播放| 日韩高清欧美激情| 麻豆精品一区二区| 欧美在线观看视频在线| 欧美大度的电影原声| 欧美一区二区在线免费播放 | 欧美国产欧美综合| 亚洲成人黄色小说| 成人黄色a**站在线观看| proumb性欧美在线观看| 91色在线porny| 日韩美女一区二区三区四区| 欧美激情中文字幕| 久久综合网色—综合色88| 国产精品久久三| 国产人成一区二区三区影院| 宅男噜噜噜66一区二区66| 亚洲精品在线免费观看视频| 国产揄拍国内精品对白| 成人app网站| 中文字幕 久热精品 视频在线| 久久精品av麻豆的观看方式| 日韩午夜激情电影| 亚洲国产三级在线| 国产成人精品免费在线| 在线免费一区三区| 日本成人超碰在线观看| 91美女视频网站| 午夜国产精品影院在线观看| 粉嫩欧美一区二区三区高清影视| 欧美亚洲另类激情小说| 欧美激情综合五月色丁香| 亚洲精品视频一区二区| 一区二区激情视频| 国产一区二区三区精品视频| 99精品在线免费| 久久久久久久综合| 偷拍一区二区三区| 国产成人av电影在线| 国产欧美一区二区精品忘忧草| 日韩电影在线观看网站| 日韩一区二区三区四区| 国产精品免费网站在线观看| 国产毛片精品一区| 欧美tk—视频vk| 欧美一区二区精美| 欧美日韩免费电影| 另类小说图片综合网| 日韩精品一二区| 国产成人啪免费观看软件| 亚洲精品一区二区三区精华液| 五月激情综合色| 337p亚洲精品色噜噜狠狠| 亚洲成人黄色影院| 欧美午夜精品免费| 综合色中文字幕| 粉嫩久久99精品久久久久久夜| 一区二区在线免费| 色呦呦网站一区| 亚洲线精品一区二区三区八戒| 欧美在线不卡视频| 亚洲午夜精品在线| 9191国产精品| 看片的网站亚洲| 2020国产精品自拍| 国产成人h网站| 国产精品三级视频| 色综合久久综合网| 一区二区三区高清| 欧美综合一区二区三区| 亚洲综合自拍偷拍| 欧美日本在线一区| 久久99久久精品| 中文幕一区二区三区久久蜜桃| 99久久精品情趣| 亚洲国产欧美在线人成| 9191成人精品久久| 国产精品亚洲第一| 国产婷婷色一区二区三区| 成人午夜av影视| 亚洲一区二区三区中文字幕| 51午夜精品国产| 久久国产精品第一页| 国产午夜精品久久久久久免费视| 成人午夜在线视频| 亚洲国产视频一区二区| 日韩免费成人网| 国产成人免费av在线| 一区二区三区在线看| 欧美精品 日韩| 韩国中文字幕2020精品| 国产精品视频看| 日本道精品一区二区三区| 日日摸夜夜添夜夜添亚洲女人| 久久综合国产精品| 91麻豆自制传媒国产之光| 奇米在线7777在线精品| 中文字幕一区二区三区在线观看| 欧美日本在线播放| 风流少妇一区二区| 亚洲福利视频一区| 久久久精品免费网站| 在线观看亚洲a| 国产一区91精品张津瑜| 亚洲一区二区中文在线| 久久久99精品久久| 欧美日韩卡一卡二| 成人午夜视频在线观看| 亚洲1区2区3区4区| 国产精品久久久久久久久免费桃花| 欧美老女人第四色| 成人午夜激情视频| 麻豆91在线看| 亚洲成人一二三| 最好看的中文字幕久久| 亚洲一区二区欧美| 国产精品人人做人人爽人人添| 91精品国产品国语在线不卡| 成人av在线电影| 精品一区二区三区久久| 亚洲成a人片在线不卡一二三区 | 国产美女在线精品| 亚洲电影视频在线| 国产精品久久久久毛片软件| 日韩女优毛片在线| 欧美日韩午夜在线| 99久久精品免费精品国产| 狠狠狠色丁香婷婷综合久久五月| 亚洲v日本v欧美v久久精品| 亚洲欧洲精品一区二区精品久久久| 精品国产欧美一区二区| 国产a级毛片一区| 精品免费99久久| 亚洲免费观看高清在线观看| 免费成人在线视频观看| 日本精品视频一区二区| 欧美国产精品v| 国产东北露脸精品视频| 日韩三级电影网址| 亚洲国产成人av网| 91丨porny丨国产| 国产精品久久久久永久免费观看 | 日韩一区国产二区欧美三区| 欧美国产精品中文字幕| 韩国精品主播一区二区在线观看 | 色婷婷av一区二区三区软件| 国产麻豆精品在线| 国产网站一区二区|