基于塞尔维斯特准则的二次型标量函数的正定性判断解析.docVIP

基于塞尔维斯特准则的二次型标量函数的正定性判断解析.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
窗体顶端 窗体顶端 窗体底端 Leverrier-Faddeeva递推算法的程序设计范例,编写程序实现基于塞尔维斯特准则的二次型标量函数的正定性判断。要求:编写程序设计报告,含:任务需求分析、程序流程、实现方法、测试验收、源代码等, 根据赛尔维斯特(Sylvester),可以通过判断对称矩阵P的定号性来确定二次型函数的定号性。 则 矩阵P正定的充要条件是所有的顺子主子式都是正的,即; 矩阵P负定的充要条件是 (三)程序设计流程图: (四) 程序设计实现 输入:矩阵A,n阶方阵 输出:二次型标量函数V(x)是正定的、负定的、既不是正定的也不是负定的 结果 程序验证与测试 包含三个cpp文件 Mat.cpp包含类Mat的各成员函数、 Base.cpp实现矩阵的一些基本操作 包括:求行列式的值、 矩阵的余子式、 判断正定性 Mat.cpp #include Mat.h /********类Mat成员函数************/ void Mat::CreateMat(int r,int c,int type,double *A) { int i; this-rows=r; this-cols=c; this-type=type; data = new double[r*c]; //为矩阵申请(r*c)大小的内存空间。 if(A!=NULL)switch(type) { case INT: for(i=0; ir*c; i++)//循环赋值 data[i] = (int)A[i]; break; case DOUBLE: for(i=0; ir*c; i++) data[i] = (double)A[i]; break; default: data = NULL; break; } else { for(i=0; ir*c; i++)//循环赋值 data[i] = 0; } } void Mat::PrintMat() { int j; if(data==NULL)coutendl还没给该矩阵赋值endl; else { for(int i=0;irows;i++) { switch(type) { case INT: case DOUBLE: for(j=0;jcols;j++)cout”\t”data[i*cols+j]; default:break; } printf(\n); } } } double Mat::Read(int i,int j) { return this-data[i*cols+j]; } (2)Main.cpp #include base.h void main() { Mat A; int n; double* a; cout请输入方阵的维数:; cinn; a=new double[n*n]; cout请输入方阵:endl; for(int i=0;in*n;i++) cina[i]; A.CreateMat(n,n,DOUBLE,a); //创建矩阵 A 并赋值 cout原矩阵:endl; A.PrintMat(); //输出原矩阵 coutendl; Judge(A); //判断是否为实对数矩阵、正定性 // system(pause); } (3)Base.cpp #include base.h #include mat.h //============用递归法求行列式的值(并返回)================= double Fun( int n, double *a ) { if(1==n)return a[0]; double* b; double sum = 0; //i,j为行与列,sum为行列式的值 int x=0,num=0; //用x判断(-1)^(i+j)的正负 b=new double[(n-1)*(n-1)]; //数组用来存放代数余子式 for(int c=0;cn;c++) { for(int i=1;in;i++) //实现将余子式存入数组b中 { for(int j=0;jn;j++) { if(j==c)continue; b[num++]

文档评论(0)

1192212 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档