用Matlab写脚本求解线性方程组,让大家拥有一个线性方程组计算器

用Matlab写脚本求解线性方程组,让大家拥有一个线性方程组计算器

有句话说的好:一个合格的程序员,不会写出“摧毁地球”的方法。他会写一个方法叫“摧毁行星”,然后把地球作为参数传进去。

所以我们来求解线性方程组也不能L仅仅满足把它求出来就行了,我们还要让用户即使不会编程也能轻松利用我们的程序求解线性方程组。

比如这样:
在这里插入图片描述

在这里插入图片描述

下面我们来详细看看怎么实现吧!

齐次线性方程组

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传PD9vK(img-anmXWBOG-1637468700828)(D:\Typora\images\image-20211121121425499.png)(D:\Typora\images\image-20211121121425499.png)]

接下来就看看我们的代码吧~

% 把系数矩阵给写了
A=[1 1 -1 -1;
   2 2  0  1;
   1 1  1  2]
% A=[1,1;2,3;3,4]
% A=[1 2 1 -1;3 6 -1 -3]
% 把系数矩阵的秩求出来
Rank_A=rank(A)
[m,n]=size(A)
if(Rank_A<n)
%   秩小于未知量的个数,方程组有无穷解
%   计算基础解系
   disp("方程组的基础解系为:")
   z=null(A,'r')
elseif(Rank_A==n)
    disp("方程组只有零解")
    z=repmat(0,n,1)
end

这是结果,还是很直观的呢[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-CFvsPEKj-1637468700834)(D:\Typora\images\image-20211121121821529.png)]

非齐次线性方程组

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-o3J7KcBv-1637468700838)(D:\Typora\images\image-20211121121618840.png)]

看看我们的代码吧

% 系数矩阵和增广矩阵
A=[1  2  3;
   2 -1 -1;
   1 -2 -2]
b=[2;1;-1];
Ab=[A,b]
[m,n]=size(A)
Rank_A=rank(A)
Rank_Ab=rank(Ab)
if(Rank_A==Rank_Ab)
    if(Rank_A==n)
        disp("方程组有唯一解")
        x=A\b
    elseif(Rank_A<n)
        disp("方程组有无穷多解")
%         求基础解系
        disp("基础解系为:")
        z=null(A,'r')
%         求一个特解 
        disp("一个特解为:")
        X=pinv(A)*b
    end
else
    disp("此方程组无解")
end
%演算一下下,如果为0,就是对的
AX_b=A*X-b

这个结果也很直观[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-n901G3kb-1637468700842)(D:\Typora\images\image-20211121121931693.png)]

接下来就要让不会变成的小白也拥有一个求解线性方程组的程序了~

上代码

clear;clc
flag=input("亲想算齐次的还是非齐次的呀( ̄︶ ̄)↗ (齐次扣'1',非齐次扣'2'),请输入:");
if(flag==1)
    A=input("请亲输入系数矩阵:");
    Rank_A=rank(A);
    [m,n]=size(A);
   if(Rank_A<n)
%   秩小于未知量的个数,方程组有无穷解
%   计算基础解系
       disp("方程组的基础解系为:")
       z=null(A,'r')
    elseif(Rank_A==n)
       disp("方程组只有零解")
       z=repmat(0,n,1)
   end
elseif(flag==2)
    A=input("请亲输入系数矩阵:");
    b=input("请亲输入常数项列向量:");
    Ab=[A,b];
    [m,n]=size(A);
    Rank_A=rank(A);
    Rank_Ab=rank(Ab);
    if(Rank_A==Rank_Ab)
        if(Rank_A==n)
            disp("方程组有唯一解")
            x=A\b
        elseif(Rank_A<n)
            disp("方程组有无穷多解")
%             求基础解系
            disp("基础解系为:")
            z=null(A,'r')
%             求一个特解 
            disp("一个特解为:")
            X=pinv(A)*b
        end
    else
        disp("此方程组无解")
    end
else
    disp("亲,你怎么输错了!╰(‵□′)╯")
end

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-yyhRBC7X-1637468700845)(D:\Typora\images\image-20211121122128948.png)]

谢谢大家的观看~

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
模糊数学在工程技术、管理科学、金融工程等领域应用中的很多问题都可以用模糊方程和模糊线性系统来描述。 但是,实现模糊方程和模糊线性系统的求解十分困难,对求解方法的研究一直以来都是重点,也是难点。 无论从理论研究还是从实际应用的角度来说,对模糊方程和模糊线性系统的求解研究都具有重要意义。 本文针对传统方法求解模糊方程和模糊线性系统在模糊数运算、隶属函数解析表示、模糊解判定等方面存在的困难,借助模糊结构元理论,相应地提出了一套模糊方程和模糊线性系统的求解方法。首先,利用两个单调函数的自反单调变换构造了等式限定算子,推广了等式限定运算,处理了存在负模糊情况下关于乘法运算的不可逆问题。 并将等式限定运算思想应用到求解模糊线性方程中,给出了模糊解的结构元表示方法和解存在的充要条件。同时,推广了模糊线性方程,研究了更一般的双重模糊线性方程。此外,还研究了关于矩形复模糊数和圆楔形复模糊数线性方程求解问题。 其次,定义了幂模糊数和幂模糊数方程,基于结构元方法研究了幂模糊数运算和幂模糊数方程的求解。同时,实现了一元二次模糊方程的求解,利用区间[-1,1]上的单调函数将一元二次模糊方程的求解问题转化为二元二次参数方程组的求解问题,给出了二次模糊方程解存在的充要条件,并辅以数值例子。 最后,利用结构元技术提出了模糊线性系统的求解方法,给出了模糊解存在的充要条件,并辅以实例计算。由于该求解方法是借助[-1,1]上关于y轴对称的单调函数实现的,结果表明在解存在的判定上优于Embedding法。 同时,管理毕业论文www.yifanglunwen.com [-1,1]还研究了一类由模糊结构元线性生成的模糊线性系统,其求解特点是可转为经典线性系统,避免了参数的讨论。本文提出的模糊方程和模糊线性系统的结构元求解方法,极大地简化了模糊数运算的困难,实现了模糊解的判定和解析表达,为模糊数学基础理论问题的研究以及实际问题中的应用与推广奠定了基础。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值