数值分析算法 MATLAB 实践 线性方程组 Gauss消去法

简介: 数值分析算法 MATLAB 实践 线性方程组 Gauss消去法

数值分析算法 MATLAB 实践 线性方程组 Gauss消去法

Gauss消去法

function solution =Gauss(A,b)
%高斯消去法function solution =Gauss(A,b)
% A为方程组的系数矩阵 b为方程组的右端项;
    n = length(b);
    for k=1:n-1
        for i=k+1:n
            mik=A(i,k)/A(k,k);%消元因子
            for j=k+1:n
                A(i,j)=A(i,j)-mik*A(k,j);
            end
         b(i)=b(i)-mik*b(k);
        end
    end
    solution(n)=b(n)/A(n,n);
    for i=n-1:-1:1 
        for j=i+1:n
            solution(i)=solution(i)+A(i,j)*solution(j);
        end
        solution(i)=(b(i)-solution(i))/A(i,i);
    end
end
function solution=GaussFunmethod(gauss, Presion) 
% gauss为用户输入的增广矩阵
 % Precision为用户所输入的精度要求
    if nargin==2
      try
         digits(Precision);
      cath
         disp('你输入的精度有误');
         digits(10);
      end
    else
      digits(10);
    end     

    Ab=vpa(gauss)%显示输入的增广矩阵
    row=size(Ab,1);
    col=size(Ab,2);
    if ndims(Ab)~=2|(col-row)~=1
        disp('矩阵的大小有误');
        return
    end
    if det(gauss(:,1:row))==0
        disp('该方程的系数矩阵行列式为零');
        return
    end
   % 消元法
        for i=1:row
          j=i;
          while Ab(j,i)==0
                  j=j+1;
          end
          temp=Ab(i,:);
          Ab(i,:)=Ab(j,:);
          Ab(j,:)=temp;
          for k=i+1:row
              Ab(k,:)=vpa(Ab(k,:)-Ab(i,:)*Ab(k,i)/Ab(i,i));
          end
        end               
      %% 回代过程
        for i=row:-1:1
           temp=Ab(i,col);
           for k=i+1:row
                temp=vpa(temp-solution(k)*Ab(i,k));
           end
           solution(i)=vpa(temp/Ab(i,i));
        end
end

Gauss主元素消去法

function X=Gauss_Mainmethod(A,b)
%列主元方法 计算线性方程组
%A为方程组的系数矩阵 b为方程组的右端项;
    zengguang=[A b];
    Ab = [A,b]
    n=length(b);
    ra=rank(A);
    rz=rank(zengguang);
    temp1=rz-ra;
    if temp1>0
        disp('方程组无一般意义下的解,系数矩阵与增广矩阵秩不同.')
        return
    end
    if (ra==rz)
        if (ra==n)
            X=zeros(n,1); C=zeros(1,n+1);
        for p= 1:n-1
            [Y,j]=max(abs(zengguang(p:n,p))); C=zengguang(p,:);
            zengguang(p,:)= zengguang(j+p-1,:); zengguang(j+p-1,:)=C;
            for k=p+1:n
                m= zengguang(k,p)/ zengguang(p,p);
                zengguang(k,p:n+1)= zengguang(k,p:n+1)-m* zengguang(p,p:n+1);
            end
        end
        b=zengguang(1:n,n+1);A=zengguang(1:n,1:n); X(n)=b(n)/A(n,n);
        for q=n-1:-1:1
                X(q)=(b(q)-sum(A(q,q+1:n)*X(q+1:n)))/A(q,q);
        end
    else
            disp('方程组为欠定方程组')
        end
    X = X';
end
function x=principal_element(A,b)
%列主元方法 计算线性方程组
%A为方程组的系数矩阵 b为方程组的右端项;
[rows,~]=size(A);
aug_mat=[A,b];Ab= [A,b]
for i=1:rows
    temp_list=aug_mat(:,i);
    temp_list(1:max(1,i-1))=0;
    [~,exchange_pos]=max(abs(temp_list));
    aug_mat([i,exchange_pos],:)=aug_mat([exchange_pos,i],:);
    coefficient=aug_mat(:,i);
    coefficient=-coefficient./coefficient(i);
    coefficient(i)=0;
    aug_mat=coefficient*aug_mat(i,:)+aug_mat;
end
divisor=aug_mat((1:rows)+(0:rows:(rows*(rows-1))))';
aug_mat=aug_mat./divisor;
x=aug_mat(:,rows+1:end);
x =x';
end

Gauss-Jordan消去法

function x = GaussJordan(A, b)
%function x = GaussJordan(A, b)
%GaussJordan消去法
%A为方程组的系数矩阵 b为方程组的右端项;
n = length(b);
if size(A, 1) ~= n || size(A, 2) ~= n
    error('Matrix-vector size mismatch.');
end
Ab = [A, b]
% Perform Gauss-Jordan elimination
% augmented matrix
A = [A, b];
for k = 1 : n
    A(k, :) = A(k, :) / A(k, k);
    for i = k + 1 : n
        m = A(i, k) / A(k, k);
        A(i, :) = A(i, :) - m * A(k, :);
    end
end
for k = n : -1 : 1
    for i = k - 1 : -1 : 1
        m = A(i, k) / A(k, k);
        A(i, :) = A(i, :) - m * A(k, :);
    end
end
    x = A(:, n + 1);
    x =x';
end
目录
相关文章
|
6天前
|
算法
基于模糊控制算法的倒立摆控制系统matlab仿真
本项目构建了一个基于模糊控制算法的倒立摆控制系统,利用MATLAB 2022a实现了从不稳定到稳定状态的转变,并输出了相应的动画和收敛过程。模糊控制器通过对小车位置与摆的角度误差及其变化量进行模糊化处理,依据预设的模糊规则库进行模糊推理并最终去模糊化为精确的控制量,成功地使倒立摆维持在直立位置。该方法无需精确数学模型,适用于处理系统的非线性和不确定性。
基于模糊控制算法的倒立摆控制系统matlab仿真
|
2天前
|
机器学习/深度学习 人工智能 算法
【人工智能】传统语音识别算法概述,应用场景,项目实践及案例分析,附带代码示例
传统语音识别算法是将语音信号转化为文本形式的技术,它主要基于模式识别理论和数学统计学方法。以下是传统语音识别算法的基本概述
9 2
|
5天前
|
机器学习/深度学习 算法 定位技术
MATLAB - 遗传算法(GA)求解旅行商问题(TSP)
MATLAB - 遗传算法(GA)求解旅行商问题(TSP)
12 3
|
7天前
|
算法
基于多路径路由的全局感知网络流量分配优化算法matlab仿真
本文提出一种全局感知网络流量分配优化算法,针对现代网络中多路径路由的需求,旨在均衡分配流量、减轻拥塞并提升吞吐量。算法基于网络模型G(N, M),包含N节点与M连接,并考虑K种不同优先级的流量。通过迭代调整每种流量在各路径上的分配比例,依据带宽利用率um=Σ(xm,k * dk) / cm来优化网络性能,确保高优先级流量的有效传输同时最大化利用网络资源。算法设定收敛条件以避免陷入局部最优解。
|
9天前
|
机器学习/深度学习 数据采集 人工智能
理解并应用机器学习算法:从技术基础到实践应用
【8月更文挑战第10天】机器学习算法的应用已经深入到我们生活的方方面面,理解和掌握机器学习算法对于数据科学家、工程师乃至普通从业者来说都至关重要。通过本文的介绍,希望大家能够对机器学习有一个基本的认识,并学会如何将其应用于实际问题中。当然,机器学习是一个不断发展和演变的领域,只有不断学习和实践,才能跟上时代的步伐。
|
15天前
|
存储 算法 调度
基于和声搜索算法(Harmony Search,HS)的机器设备工作最优调度方案求解matlab仿真
通过和声搜索算法(HS)实现多机器并行工作调度,以最小化任务完成时间。在MATLAB2022a环境下,不仅输出了工作调度甘特图,还展示了算法适应度值的收敛曲线。HS算法模拟音乐家即兴创作过程,随机生成初始解(和声库),并通过选择、微调生成新解,不断迭代直至获得最优调度方案。参数包括和声库大小、记忆考虑率、音调微调率及带宽。编码策略将任务与设备分配映射为和声,目标是最小化完成时间,同时确保满足各种约束条件。
|
6天前
|
算法
基于EM期望最大化算法的GMM模型参数估计matlab仿真
此程序在MATLAB 2022a中实现了基于EM算法的GMM参数估计,用于分析由多个高斯分布组成的混合数据。程序通过迭代优化各高斯组件的权重、均值与协方差,直至收敛,并输出迭代过程的收敛曲线及最终参数估计结果。GMM假设数据由K个高斯分布混合而成,EM算法通过E步计算样本归属概率,M步更新参数,循环迭代直至收敛。
|
6天前
|
机器学习/深度学习 移动开发 算法
MATLAB 状态空间设计 —— LQG/LQR 和极点配置算法
MATLAB 状态空间设计 —— LQG/LQR 和极点配置算法
18 0
|
12天前
|
安全
【2023高教社杯】D题 圈养湖羊的空间利用率 问题分析、数学模型及MATLAB代码
本文介绍了2023年高教社杯数学建模竞赛D题的圈养湖羊空间利用率问题,包括问题分析、数学模型建立和MATLAB代码实现,旨在优化养殖场的生产计划和空间利用效率。
31 6
【2023高教社杯】D题 圈养湖羊的空间利用率 问题分析、数学模型及MATLAB代码
|
13天前
|
存储 算法 搜索推荐
【2022年华为杯数学建模】B题 方形件组批优化问题 方案及MATLAB代码实现
本文提供了2022年华为杯数学建模竞赛B题的详细方案和MATLAB代码实现,包括方形件组批优化问题和排样优化问题,以及相关数学模型的建立和求解方法。
39 3
【2022年华为杯数学建模】B题 方形件组批优化问题 方案及MATLAB代码实现

热门文章

最新文章