最近在网上找了下,没有找到我想要的C语言版本,找到的也是错误的。故自己写了一个,并进行了相关测试,贴出来分享。

具体的LU分解算法就不细说了,随便找本书就知道了,关键是分解的处理流程,细节特别容易出错,一切都在代码里面。

#include <stdio.h>
#include <memory.h>
#include <stdlib.h> #define N 4
#define DEBUG 1 //debug label,0即不打印相关结果,非0打印相关输出结果 void matrix_inverse_LU(float a[][N])
{
float l[N][N], u[N][N];
float l_inverse[N][N], u_inverse[N][N];
float a_inverse[N][N];
int i, j, k;
float s, t; memset(l, 0, sizeof(l));
memset(u, 0, sizeof(u));
memset(l_inverse, 0, sizeof(l_inverse));
memset(u_inverse, 0, sizeof(u_inverse));
memset(a_inverse, 0, sizeof(u_inverse)); for (i = 0; i < N;i++) //计算l矩阵对角线
{
l[i][i] = 1;
} for (i = 0;i < N;i++)
{
for (j = i;j < N;j++)
{
s = 0;
for (k = 0;k < i;k++)
{
s += l[i][k] * u[k][j];
}
u[i][j] = a[i][j] - s; //按行计算u值
} for (j = i + 1;j < N;j++)
{
s = 0;
for (k = 0; k < i; k++)
{
s += l[j][k] * u[k][i];
}
l[j][i] = (a[j][i] - s) / u[i][i]; //按列计算l值
}
} for (i = 0;i < N;i++) //按行序,行内从高到低,计算l的逆矩阵
{
l_inverse[i][i] = 1;
}
for (i= 1;i < N;i++)
{
for (j = 0;j < i;j++)
{
s = 0;
for (k = 0;k < i;k++)
{
s += l[i][k] * l_inverse[k][j];
}
l_inverse[i][j] = -s;
}
} #if DEBUG
printf("test l_inverse:\n");
for (i = 0; i < N; i++)
{
for (j = 0; j < N; j++)
{
s = 0;
for (k = 0; k < N; k++)
{
s += l[i][k] * l_inverse[k][j];
} printf("%f ", s);
}
putchar('\n');
}
#endif for (i = 0;i < N;i++) //按列序,列内按照从下到上,计算u的逆矩阵
{
u_inverse[i][i] = 1 / u[i][i];
}
for (i = 1;i < N;i++)
{
for (j = i - 1;j >=0;j--)
{
s = 0;
for (k = j + 1;k <= i;k++)
{
s += u[j][k] * u_inverse[k][i];
}
u_inverse[j][i] = -s / u[j][j];
}
} #if DEBUG
printf("test u_inverse:\n");
for (i = 0;i < N;i++)
{
for (j = 0;j < N;j++)
{
s = 0;
for (k = 0;k < N;k++)
{
s += u[i][k] * u_inverse[k][j];
} printf("%f ",s);
}
putchar('\n');
}
#endif for (i = 0;i < N;i++) //计算矩阵a的逆矩阵
{
for (j = 0;j < N;j++)
{
for (k = 0;k < N;k++)
{
a_inverse[i][j] += u_inverse[i][k] * l_inverse[k][j];
}
}
} #if DEBUG
printf("test a:\n");
for (i = 0; i < N; i++)
{
for (j = 0; j < N; j++)
{
s = 0;
for (k = 0; k < N; k++)
{
s += a[i][k] * a_inverse[k][j];
} printf("%f ", s);
}
putchar('\n');
}
#endif
} void main()
{
int i, j, k;
float a[N][N]; for (i = 0;i < N;i++)
{
for (j = 0;j < N;j++)
{
a[i][j] = rand() % 10;
}
} matrix_inverse_LU(a);
}

  提醒一下,打印出来的验证结果,可能跟单位矩阵E有稍许不同,如下图所示:

主要是因为相关浮点数计算误差所致,系统原因,不是算法问题。

解决这个问题的方法,就是用更精确的double类型或者改用各适合进行科学计算的工具/语言。

LU分解法求逆矩阵 C语言实现的更多相关文章

  1. Matlab数值计算示例: 牛顿插值法、LU分解法、拉格朗日插值法、牛顿插值法

    本文源于一次课题作业,部分自己写的,部分借用了网上的demo 牛顿迭代法(1) x=1:0.01:2; y=x.^3-x.^2+sin(x)-1; plot(x,y,'linewidth',2);gr ...

  2. Guass列选主元消去法和三角分解法

    最近数值计算学了Guass列主消元法和三角分解法解线性方程组,具体原理如下: 1.Guass列选主元消去法对于AX =B 1).消元过程:将(A|B)进行变换为,其中是上三角矩阵.即: k从1到n-1 ...

  3. 寒假答辩作品——掘地求升C语言版

    寒假答辩—掘地求升(C语言版) 前言 这个是作为寒假答辩作品写的. 之前考虑过用Unity写个游戏,但毕竟不熟悉C#,感觉几乎都是在套模板,而且写着不顺手,有想法却只能 看着C#发呆,很是无奈,所以决 ...

  4. [Architecture] 系统架构正交分解法

    [Architecture] 系统架构正交分解法 前言 随着企业成长,支持企业业务的软件,也会越来越庞大与复杂.当系统复杂到一定程度,开发人员会发现很多系统架构的设计细节,很难有条理.有组织的用一张大 ...

  5. 利用栈实现算术表达式求值(Java语言描述)

    利用栈实现算术表达式求值(Java语言描述) 算术表达式求值是栈的典型应用,自己写栈,实现Java栈算术表达式求值,涉及栈,编译原理方面的知识.声明:部分代码参考自茫茫大海的专栏. 链栈的实现: pa ...

  6. 分治法求一个N个元素数组的逆序数

    背景  逆序数:也就是说,对于n个不同的元素,先规定各元素之间有一个标准次序(例如n个 不同的自然数,可规定从小到大为标准次序),于是在这n个元素的任一排列中,当某两个元素的先后次序与标准次序不同时, ...

  7. 《github一天一道算法题》:分治法求数组最大连续子序列和

    看书.思考.写代码. /*************************************** * copyright@hustyangju * blog: http://blog.csdn. ...

  8. 时间序列分解-STL分解法

    时间序列分解-STL分解法 [转载时请注明来源]:http://www.cnblogs.com/runner-ljt/ Ljt 作为一个初学者,水平有限,欢迎交流指正. STL(’Seasonal a ...

  9. 项目管理——WBS工作分解法

    首先我们要了解什么是WBS工作分解法 工作分解结构(Work Breakdown Structure,简称WBS)跟因数分解是一个原理,就是把一个项目,按一定的原则分解,项目分解成任务,任务再分解成一 ...

随机推荐

  1. Jmeter的操作流程

    1.1 什么是 JMeter Apache JMeter 是 Apache 组织开发的基于 Java 的压力测试工具.用于对软件做压力测试,它最初被设计用于 Web 应用测试,但后来扩展到其他测试领域 ...

  2. 从入门到自闭之python三大器--装饰器进阶

    装饰器的进阶 有参装饰器: # def warpper(func): # def inner(*args,**kwargs): # user = input("user:") # ...

  3. java执行bat代码

    java执行bat代码.txt public static void runbat(String path,String filename) { String cmd = "cmd /c s ...

  4. PB中的DataStore的应用示例

    编程过程中想在窗口中加一个下拉列表(DDLB),原来听同学说过可以动态改变下拉列表的值,数据库中的表改变,前台客户端的下拉列表就会变,记得当时同学说的是用一个叫下拉数据窗口(DDDW)的东西做的,一直 ...

  5. nohup重定向到其它的日志文件

    如果使用nohup命令提交作业,那么在缺省情况下该作业的所有输出都被重定向到一个名为nohup.out的文件中,除非另外指定了输出文件: nohup command > myout.file 2 ...

  6. redis 学习(4)-- 哈希类型

    redis 学习(4)-- 哈希类型 介绍 redis 中哈希键值结构: 可以看出:哈希键值包括 key,field,value 这三部分,即键,属性,值这三部分.可以这样来表示: key, (fie ...

  7. spring boot zuul集成kubernetes等第三方登录

    介绍一下,在单点登录平台集成kubernetes登录,集成其它系统的登录原理是一样的,如grafana, nacos, jenkins等. POM引用: <dependency> < ...

  8. sql--Drop语句

    通过使用 DROP 语句,可以轻松地删除索引.表和数据库. SQL DROP INDEX 语句 我们可以使用 DROP INDEX 命令删除表格中的索引. 用于 Microsoft SQLJet (以 ...

  9. BASH的保护性编程技巧

    BASH的保护性编程技巧   shell常用逻辑判断 -b file 若文件存在且是一个块特殊文件,则为真 -c file 若文件存在且是一个字符特殊文件,则为真 -d file 若文件存在且是一个目 ...

  10. Maven之私服配置

    一.配置从私服下载 从私服下载主要是将 central 库的下载地址从https://repo1.maven.org/maven2/修改为私服地址,比如http://localhost:8081/re ...