📄 householdertransform.cpp
字号:
// HouseholderTransform.cpp
//约化对称阵为对称三对角阵的豪斯荷尔德变换法
#include <iostream> //输入输出流头文件
#include "Matrix.h" //矩阵类及相关函数头文件
#include "EigenvalueVector.h" //特征值及特征向量头文件
using namespace std; //名字空间
void main() //定义控制台应用程序的入口点
{
double a[5][5] =
{
{10.0, 1.0, 2.0, 3.0, 4.0},
{ 1.0, 9.0, -1.0, 2.0, -3.0},
{ 2.0, -1.0, 7.0, 3.0, -5.0},
{ 3.0, 2.0, 3.0, 12.0, -1.0},
{ 4.0, -3.0, -5.0, -1.0, 15.0}
};
valarray<double> b(5), c(5);
matrix<double> q(5,5), da(&a[0][0],5,5);
cout.setf(ios::fixed); //输出数据为定点法
cout.precision(6); //精度6位
if(HouseholderTransform(da,q,b,c) > 0)
{
cout << "MATRIX A IS: " << endl;
MatrixLinePrint(da);
cout << endl;
cout << "MATRIX Q IS: " << endl;
MatrixLinePrint(q);
cout << endl;
cout << "MATRIX B IS: " << endl;
ValarrayPrint(b);
cout << endl;
cout << "MATRIX C IS: " << endl;
ValarrayPrint(c);
cout << endl;
}
else
cout << "Matrix A is not symmetry." << endl;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -