亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

OpenCascade Eigenvalues and Eigenvectors of

系統(tǒng) 1791 0

OpenCascade Eigenvalues and Eigenvectors of Square Matrix

eryar@163.com

Abstract. OpenCascade use the Jacobi method to find the eigenvalues and the eigenvectors of a real symmetric square matrix. Use class math_Jacobi to computes all eigenvalues and eigenvectors by using Jacobi method. The exception NotSquare is raised if the matrix is not square. No verification that the matrix is really symmetric is done.?

Key words. Eigenvalues, Eigenvectors, OpenCascade, Matrix, Jacobi method,

?

1. Introduction

工程技術(shù)中的一些問題,如振動問題和穩(wěn)定性問題,常可歸結(jié)為求一個方陣的特征值和特征向量的問題。數(shù)學(xué)中諸如方陣的對角化及解常微分方程等問題,也都有要用到特征值的理論。?

定義:設(shè)A是n階矩陣,如果數(shù)λ和n維非零列向量x使關(guān)系式 Ax = λx成立,那么這樣的數(shù)λ稱為方陣A的特征值,非零向量x稱為A對應(yīng)于特征值λ的特征向量。?

推論:若n階矩陣A與對角陣?

wps_clip_image-30710

相似,則λ1,λ2,...,λn即是A的n個特征值。?

定理:n階矩陣A與對角陣相似(即A能對角化)的充分必要條件是A有n個線性無關(guān)的特征向量。?

推論:如果n階矩陣A的n個特征值互不相等,則A與對角陣相似。?

當(dāng)A的特征方程有重根時,就不一定有n個線性無關(guān)的的特征向量,從而不一定能對角化。一個n階矩陣具備什么條件才能對角化呢?這是一個較復(fù)雜的問題。?

定理:設(shè)A為n階對稱陣,則有正交陣P,使?

wps_clip_image-2186

其中∧是以A的n個特征值為對角元的對角陣。?

OpenCascacde中使用了Jacobi方法來計算對稱方陣的特征值和特征向量。本文對math_Jacobi的使用進行詳細說明。

?

2. Code Example

結(jié)合同濟第四版《線性代數(shù)》中的例子,來驗證Jacobi方法計算的結(jié)果。示例程序如下所示:

      
        /*
      
      
        

*    Copyright (c) 2014 eryar All Rights Reserved.

*

*        File    : Main.cpp

*        Author  : eryar@163.com

*        Date    : 2014-06-22 21:46

*        Version : 1.0v

*

*    Description : Demonstrate how to find the eigenvalues and

*                  eigenvectors for a symmetric square Matrix.

*                  題目來自《線性代數(shù)》同濟 第四版

*                  


      
      
        */
      
      
        #define
      
       WNT
      
        



#include 
      
      <math_Jacobi.hxx>




      
        #pragma
      
       comment(lib, "TKernel.lib")


      
        #pragma
      
       comment(lib, "TKMath.lib")




      
        /*
      
      
        *

* OpenCascade use Jacobi method to find the eigenvalues and 

* the eigenvectors of a real symmetric square matrix.


      
      
        */
      
      
        void
      
       EvalEigenvalue(
      
        const
      
       math_Matrix &
      
        A)

{

    math_Jacobi J(A);



    std::cout 
      
      << A <<
      
         std::endl;



    
      
      
        if
      
      
         (J.IsDone())

    {

        std::cout 
      
      << 
      
        "
      
      
        Jacobi: \n
      
      
        "
      
       << J <<
      
         std::endl;

        
      
      
        //
      
      
        std::cout << "Eigenvalues: \n" << J.Values() << std::endl;

        
      
      
        //
      
      
        std::cout << "Eigenvectors: \n" << J.Vectors() << std::endl;
      
      
        for
      
       (Standard_Integer i = A.LowerRow(); i <= A.UpperRow(); ++
      
        i)

        {

            math_Vector V(
      
      
        1
      
      
        , A.RowNumber());

            

            J.Vector(i, V);



            std::cout 
      
      << 
      
        "
      
      
        Eigenvalue: 
      
      
        "
      
       << J.Value(i) <<
      
         std::endl;

            std::cout 
      
      << 
      
        "
      
      
        Eigenvector: 
      
      
        "
      
       << V <<
      
         std::endl;

        }

    }

}




      
      
        void
      
       TestJacobi(
      
        void
      
      
        )

{

    
      
      
        //
      
      
         1. P120 Example 5:
      
      

    math_Matrix A1(
      
        1
      
      , 
      
        2
      
      , 
      
        1
      
      , 
      
        2
      
      , 
      
        0.0
      
      
        );



    A1(
      
      
        1
      
      , 
      
        1
      
      ) = 
      
        3.0
      
      ;  A1(
      
        1
      
      , 
      
        2
      
      ) = -
      
        1.0
      
      
        ;

    A1(
      
      
        2
      
      , 
      
        1
      
      ) = -
      
        1.0
      
      ; A1(
      
        2
      
      , 
      
        2
      
      ) = 
      
        3.0
      
      
        ;



    EvalEigenvalue(A1);



    
      
      
        //
      
      
         2. P120 Example 6:
      
      

    math_Matrix A2(
      
        1
      
      , 
      
        3
      
      , 
      
        1
      
      , 
      
        3
      
      , 
      
        0.0
      
      
        );



    A2(
      
      
        1
      
      , 
      
        1
      
      ) = -
      
        1.0
      
      ; A2(
      
        1
      
      , 
      
        2
      
      ) = 
      
        1.0
      
      ; A2(
      
        1
      
      , 
      
        3
      
      ) = 
      
        0.0
      
      
        ;

    A2(
      
      
        2
      
      , 
      
        1
      
      ) = -
      
        4.0
      
      ; A2(
      
        2
      
      , 
      
        2
      
      ) = 
      
        3.0
      
      ; A2(
      
        2
      
      , 
      
        3
      
      ) = 
      
        0.0
      
      
        ;

    A2(
      
      
        3
      
      , 
      
        1
      
      ) = 
      
        1.0
      
      ;  A2(
      
        3
      
      , 
      
        2
      
      ) = 
      
        0.0
      
      ; A2(
      
        3
      
      , 
      
        3
      
      ) = 
      
        2.0
      
      
        ;



    EvalEigenvalue(A2);



    
      
      
        //
      
      
         3. P120 Example 7:
      
      

    math_Matrix A3(
      
        1
      
      , 
      
        3
      
      , 
      
        1
      
      , 
      
        3
      
      , 
      
        0.0
      
      
        );



    A3(
      
      
        1
      
      , 
      
        1
      
      ) = -
      
        2.0
      
      ; A3(
      
        1
      
      , 
      
        2
      
      ) = 
      
        1.0
      
      ; A3(
      
        1
      
      , 
      
        3
      
      ) = 
      
        1.0
      
      
        ;

    A3(
      
      
        2
      
      , 
      
        1
      
      ) = 
      
        0.0
      
      ;  A3(
      
        2
      
      , 
      
        2
      
      ) = 
      
        2.0
      
      ; A3(
      
        2
      
      , 
      
        3
      
      ) = 
      
        0.0
      
      
        ;

    A3(
      
      
        3
      
      , 
      
        1
      
      ) = -
      
        4.0
      
      ; A3(
      
        3
      
      , 
      
        2
      
      ) = 
      
        1.0
      
      ; A3(
      
        3
      
      , 
      
        3
      
      ) = 
      
        3.0
      
      
        ;



    EvalEigenvalue(A3);



    
      
      
        //
      
      
         4. P127 Example 12:
      
      

    math_Matrix A4(
      
        1
      
      , 
      
        3
      
      , 
      
        1
      
      , 
      
        3
      
      , 
      
        0.0
      
      
        );



    A4(
      
      
        1
      
      , 
      
        1
      
      ) = 
      
        0.0
      
      ;  A4(
      
        1
      
      , 
      
        2
      
      ) = -
      
        1.0
      
      ; A4(
      
        1
      
      , 
      
        3
      
      ) = 
      
        1.0
      
      
        ;

    A4(
      
      
        2
      
      , 
      
        1
      
      ) = -
      
        1.0
      
      ; A4(
      
        2
      
      , 
      
        2
      
      ) = 
      
        0.0
      
      ;  A4(
      
        2
      
      , 
      
        3
      
      ) = 
      
        1.0
      
      
        ;

    A4(
      
      
        3
      
      , 
      
        1
      
      ) = 
      
        1.0
      
      ;  A4(
      
        3
      
      , 
      
        2
      
      ) = 
      
        1.0
      
      ;  A4(
      
        3
      
      , 
      
        3
      
      ) = 
      
        0.0
      
      
        ;



    EvalEigenvalue(A4);



    
      
      
        //
      
      
         5. P138 Execise 5(3);
      
      

    math_Matrix A5(
      
        1
      
      , 
      
        3
      
      , 
      
        1
      
      , 
      
        3
      
      , 
      
        0.0
      
      
        );



    A5(
      
      
        1
      
      , 
      
        1
      
      ) = 
      
        1.0
      
      ; A5(
      
        1
      
      , 
      
        2
      
      ) = 
      
        2.0
      
      ; A5(
      
        1
      
      , 
      
        3
      
      ) = 
      
        3.0
      
      
        ;

    A5(
      
      
        2
      
      , 
      
        1
      
      ) = 
      
        2.0
      
      ; A5(
      
        2
      
      , 
      
        2
      
      ) = 
      
        1.0
      
      ; A5(
      
        2
      
      , 
      
        3
      
      ) = 
      
        3.0
      
      
        ;

    A5(
      
      
        3
      
      , 
      
        1
      
      ) = 
      
        3.0
      
      ; A5(
      
        3
      
      , 
      
        2
      
      ) = 
      
        3.0
      
      ; A5(
      
        3
      
      , 
      
        3
      
      ) = 
      
        6.0
      
      
        ;



    EvalEigenvalue(A5);

}




      
      
        int
      
       main(
      
        int
      
       argc, 
      
        char
      
      *
      
         argv[])

{

    
      
      
        //
      
      
         The Jacobi method to find the eigenvalues and

    
      
      
        //
      
      
         eigenvectors of a real symmetric square matrx.

    
      
      
        //
      
      
         The exception NotSquare is raised if the matrix is not square.

    
      
      
        //
      
      
         No verification that the matrix is really symmetric is done.
      
      
            TestJacobi();



    
      
      
        return
      
      
        0
      
      
        ;

}
      
    

計算結(jié)果部分如下圖所示:?

wps_clip_image-8177

Figure 2.1 Jacobi method Result

?

3. Conclusion

矩陣的特征值和特征向量的理論能用來求解微分方程組的問題。振動分析、現(xiàn)代控制理論中的數(shù)學(xué)模型都可歸結(jié)為對微分方程組的求解。因此,對特征值和特征向量的數(shù)值計算有重要的意義。?

OpenCascade中提供了使用Jacobi方法來計算特征值和特征向量的類math_Jacobi。從計算結(jié)果可以看出,math_Jacobi只對對稱方陣的計算結(jié)果準(zhǔn)確,若不是對稱陣,則計算結(jié)果是不準(zhǔn)確的。?

會使用OpenCascade中現(xiàn)成的算法是一回事,能實現(xiàn)這些算法又是另外一回事。對計算特征值和特征向量的數(shù)值方法感興趣的讀者,可以參考《計算方法》或《數(shù)值分析》等相關(guān)書籍。


4. References

1. 同濟大學(xué)應(yīng)用數(shù)學(xué)系. 線性代數(shù). 高等教育出版社. 2003?

2. 易大義, 沈云寶, 李有法. 計算方法. 浙江大學(xué)出版社. 2002?

3. 楊明, 李先忠. 矩陣論. 華中科技大學(xué)出版社. 2005

?

OpenCascade Eigenvalues and Eigenvectors of Square Matrix


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 国产视频999| 一区二区三区四区产品乱码伦 | 色综合久久中文色婷婷 | 亚洲精品一区二区三区 | 久久久久久人精品免费费看 | 精品久久一区二区三区 | 亚洲欧美日韩国产综合专区 | 乱人伦视频69 | 亚洲精品日韩中文字幕久久久 | 日韩黄a级成人毛片 | 精品哟啊呦v视频在线观看 精品哟哟国产在线观看 | 久热在线| 亚洲成人网在线 | 成人欧美在线视频 | 亚洲男人的天堂久久香蕉 | 欧美最大成人毛片视频网站 | 成人在线免费观看 | 亚洲一区精品中文字幕 | 国产精品夜色视频一区二区 | 国产精品色 | 天天躁夜夜躁很很躁麻豆 | 久久精品无码一区二区三区 | 天海翼一区二区三区高清视频 | 中文字幕美日韩在线高清 | 91精品国产福利在线观看性色 | 国产精品白丝喷水在线观看 | 精品视频 九九九 | 欧美三级中文字幕 | 四虎在线视频观看大全影视 | 天天插天天干天天射 | 亚洲另类图片专区 | 91尤物在线播放 | 久久天天躁狠狠躁夜夜 | 青青久久国产 | 欧美精品blacked中文字幕 | 久久中文字幕网 | 国产成人综合网 | se01国产短视频在线观看 | 一区二区成人国产精品 | 免费一级毛片无毒不卡 | 欧美精品亚洲精品日韩专区va |