• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            eryar

            PipeCAD - Plant Piping Design Software.
            RvmTranslator - Translate AVEVA RVM to OBJ, glTF, etc.
            posts - 603, comments - 590, trackbacks - 0, articles - 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ù)中的一些問題,如振動(dòng)問題和穩(wěn)定性問題,常可歸結(jié)為求一個(gè)方陣的特征值和特征向量的問題。數(shù)學(xué)中諸如方陣的對(duì)角化及解常微分方程等問題,也都有要用到特征值的理論。

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

            推論:若n階矩陣A與對(duì)角陣

            wps_clip_image-30710

            相似,則λ1,λ2,...,λn即是A的n個(gè)特征值。

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

            推論:如果n階矩陣A的n個(gè)特征值互不相等,則A與對(duì)角陣相似。

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

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

            wps_clip_image-2186

            其中∧是以A的n個(gè)特征值為對(duì)角元的對(duì)角陣。

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

            2. Code Example

            結(jié)合同濟(jì)第四版《線性代數(shù)》中的例子,來驗(yàn)證Jacobi方法計(jì)算的結(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ù)》同濟(jì) 第四版
            *                  
            */

            #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(12120.0);

                A1(
            11= 3.0;  A1(12= -1.0;
                A1(
            21= -1.0; A1(22= 3.0;

                EvalEigenvalue(A1);

                
            // 2. P120 Example 6:
                math_Matrix A2(13130.0);

                A2(
            11= -1.0; A2(12= 1.0; A2(13= 0.0;
                A2(
            21= -4.0; A2(22= 3.0; A2(23= 0.0;
                A2(
            31= 1.0;  A2(32= 0.0; A2(33= 2.0;

                EvalEigenvalue(A2);

                
            // 3. P120 Example 7:
                math_Matrix A3(13130.0);

                A3(
            11= -2.0; A3(12= 1.0; A3(13= 1.0;
                A3(
            21= 0.0;  A3(22= 2.0; A3(23= 0.0;
                A3(
            31= -4.0; A3(32= 1.0; A3(33= 3.0;

                EvalEigenvalue(A3);

                
            // 4. P127 Example 12:
                math_Matrix A4(13130.0);

                A4(
            11= 0.0;  A4(12= -1.0; A4(13= 1.0;
                A4(
            21= -1.0; A4(22= 0.0;  A4(23= 1.0;
                A4(
            31= 1.0;  A4(32= 1.0;  A4(33= 0.0;

                EvalEigenvalue(A4);

                
            // 5. P138 Execise 5(3);
                math_Matrix A5(13130.0);

                A5(
            11= 1.0; A5(12= 2.0; A5(13= 3.0;
                A5(
            21= 2.0; A5(22= 1.0; A5(23= 3.0;
                A5(
            31= 3.0; A5(32= 3.0; A5(33= 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;
            }

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

            wps_clip_image-8177

            Figure 2.1 Jacobi method Result


            3. Conclusion

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

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

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

            4. References

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

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

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

            Feedback

            # re: OpenCascade Eigenvalues and Eigenvectors of Square Matrix  回復(fù)  更多評(píng)論   

            2014-06-22 20:43 by 旗袍女裝
            。對(duì)計(jì)算特征值和特征向量的數(shù)值方法感興趣的讀者,可以參考《計(jì)算方法》或《數(shù)值分析》等相關(guān)書籍。旗袍女裝 www.ssnz88.net

            久久精品国产亚洲av影院| 国产精品免费久久久久久久久| 亚洲精品视频久久久| 久久人人爽人人爽人人av东京热 | 亚洲一本综合久久| 久久久久久毛片免费看| 久久天堂AV综合合色蜜桃网 | 国产巨作麻豆欧美亚洲综合久久| 国产激情久久久久影院老熟女| 色播久久人人爽人人爽人人片aV| 波多野结衣AV无码久久一区| 91精品国产91久久久久久青草| 国内精品伊人久久久影院| 99久久精品国产一区二区| 国内精品久久久久久久久电影网 | 久久久久久免费视频| 狠狠色丁香婷婷久久综合不卡| 久久WWW免费人成一看片| 国产精品无码久久四虎| 99精品久久精品| 熟妇人妻久久中文字幕| 亚洲v国产v天堂a无码久久| 狠狠色丁香久久综合五月| 无码AV波多野结衣久久| 欧美成人免费观看久久| 久久久WWW免费人成精品| 久久777国产线看观看精品| 日本人妻丰满熟妇久久久久久 | 久久精品www人人爽人人| 亚洲AV无码1区2区久久| 久久人人青草97香蕉| 久久久久亚洲国产| 久久久久久精品免费免费自慰| 亚洲午夜精品久久久久久app| 欧美无乱码久久久免费午夜一区二区三区中文字幕 | 久久亚洲精品成人AV| 久久99国产综合精品女同| 久久亚洲日韩精品一区二区三区| 亚洲精品国产字幕久久不卡| 狠狠色丁香久久婷婷综合| 久久综合精品国产二区无码|