生活知识
生活常识
科技数码
教育知识
汽车知识
游戏知识
办公方法
装修知识
旅游知识
搜索

生活常识分类 日常知识 生活知识 餐饮知识 宠物知识 运动知识 更多知识 中文舞曲 英文舞曲 车载音乐 车载视频

矩阵求逆matlab 矩阵求逆例题

日期:2023-02-27 08:56:41人气:19

导读:大家好,小帝来为大家解答以上问题。矩阵求逆matlab,矩阵求逆这个很多人还不知道,现在让我们一起来看看吧!1、下面是实现Gauss-Jordan法实...

大家好,小帝来为大家解答以上问题。矩阵求逆matlab,矩阵求逆这个很多人还不知道,现在让我们一起来看看吧!

1、下面是实现Gauss-Jordan法实矩阵求逆。

2、 #include #include #include int brinv(double a[], int n) { int *is,*js,i,j,k,l,u,v; double d,p; is=malloc(n*sizeof(int)); js=malloc(n*sizeof(int)); for (k=0; k<=n-1; k++) { d=0.0; for (i=k; i<=n-1; i++) for (j=k; j<=n-1; j++) { l=i*n+j; p=fabs(a[l]); if (p>d) { d=p; is[k]=i; js[k]=j;} } if (d+0==0) { free(is); free(js); printf("err**not inv"); return(0); } if (is[k]!=k) for (j=0; j<=n-1; j++) { u=k*n+j; v=is[k]*n+j; p=a[u]; a[u]=a[v]; a[v]=p; } if (js[k]!=k) for (i=0; i<=n-1; i++) { u=i*n+k; v=i*n+js[k]; p=a[u]; a[u]=a[v]; a[v]=p; } l=k*n+k; a[l]=0/a[l]; for (j=0; j<=n-1; j++) if (j!=k) { u=k*n+j; a[u]=a[u]*a[l];} for (i=0; i<=n-1; i++) if (i!=k) for (j=0; j<=n-1; j++) if (j!=k) { u=i*n+j; a[u]=a[u]-a[i*n+k]*a[k*n+j]; } for (i=0; i<=n-1; i++) if (i!=k) { u=i*n+k; a[u]=-a[u]*a[l];} } for (k=n-1; k>=0; k--) { if (js[k]!=k) for (j=0; j<=n-1; j++) { u=k*n+j; v=js[k]*n+j; p=a[u]; a[u]=a[v]; a[v]=p; } if (is[k]!=k) for (i=0; i<=n-1; i++) { u=i*n+k; v=i*n+is[k]; p=a[u]; a[u]=a[v]; a[v]=p; } } free(is); free(js); return(1); } void brmul(double a[], double b[],int m,int n,int k,double c[]) { int i,j,l,u; for (i=0; i<=m-1; i++) for (j=0; j<=k-1; j++) { u=i*k+j; c[u]=0.0; for (l=0; l<=n-1; l++) c[u]=c[u]+a[i*n+l]*b[l*k+j]; } return; } int main() { int i,j; static double a[4][4]={ {0.2368,0.2471,0.2568,2671}, {1161,0.1254,0.1397,0.1490}, {0.1582,1675,0.1768,0.1871}, {0.1968,0.2071,2168,0.2271}}; static double b[4][4],c[4][4]; for (i=0; i<=3; i++) for (j=0; j<=3; j++) b[i][j]=a[i][j]; i=brinv(a,4); if (i!=0) { printf("MAT A IS:"); for (i=0; i<=3; i++) { for (j=0; j<=3; j++) printf("%17e ",b[i][j]); printf(""); } printf(""); printf("MAT A- IS:"); for (i=0; i<=3; i++) { for (j=0; j<=3; j++) printf("%17e ",a[i][j]); printf(""); } printf(""); printf("MAT AA- IS:"); brmul(b,a,4,4,4,c); for (i=0; i<=3; i++) { for (j=0; j<=3; j++) printf("%17e ",c[i][j]); printf(""); } } }

以上就是【矩阵求逆matlab,矩阵求逆】相关内容。

声明: 本站所有文章来自互联网搜索结果, 如果侵犯到你的权益 请提供版权证明来信告知,我们会在3个工作日之内删除 本站为非赢利性网站 不接受任何赞助和广告

Copyright 2005-2022 baike.pingguodj.com 酷帝达百科 客服邮箱:s2s2s2-s@outlook.com