0

私はCUSPで次のことをしようとしています:

A=[
    1,1,0,0;
    2,2,2,0;
    0,3,3,3;
    0,0,4,4];
B=[1,1,1,1]';
disp(mldivide(A,B));

これは

X=[0.9167,0.0833,-0.5000,0.7500]

一方、CUSP からは奇妙な回答が返ってきます。

#include <cusp/dia_matrix.h>
#include <cusp/krylov/cg.h>
#include <cusp/print.h>
int main()
{
    cusp::dia_matrix<int,float,cusp::host_memory> A(4,4,10,3);
    A.diagonal_offsets[0] = -1;
    A.diagonal_offsets[1] =  0;
    A.diagonal_offsets[2] =  1;
    for (int i = 0;i <3;i++)
    {
        for (int q = 0 ;q < A.num_cols;q++)
        {
            A.values(q,i)=q+1;
        }
    }
    //copy
    cusp::dia_matrix<int,float,cusp::device_memory> AA = A;
    cusp::array1d<float,cusp::device_memory> BB(A.num_rows,1);
    cusp::array1d<float,cusp::device_memory> XX(A.num_rows,0);
    cusp::print(AA);
    cusp::print(XX);
    cusp::print(BB);
    cusp::krylov::cg(AA,XX,BB);\
    cusp::print(XX);
    return 0;
}

結果は次のようになります

sparse matrix <4, 4> with 10 entries
              0              0              1
              0              1              1
              1              0              2
              1              1              2
              1              2              2
              2              1              3
              2              2              3
              2              3              3
              3              2              4
              3              3              4
array1d <4>
             0
             0
             0
             0
array1d <4>
             1
             1
             1
             1
array1d <4>
      -39.9938
       -53.436
       87.9025
      -30.1429

最後のものはあまり正しくないようです。私が間違っていることを知っている人はいますか?コードの使い方が間違っているのでしょうか、それとも非常に優れた推測ソリューションと前提条件を使用する必要があるのでしょうか?

4

1 に答える 1

2

共役勾配法は、対称正定行列での使用に対してのみ有効です。あなたの行列は対称ではありません。これが、有効なソリューションを生成しない (そして生成できない) 理由です。適切で条件の整った SPD 行列を使用するか、別の数値法を使用してください。

于 2014-05-12T05:50:12.873 に答える