用部分旋转实现高斯消元法

时间:2015-03-08 14:32:08

标签: matlab gaussian

我正在编写一个程序,在MATLAB中使用部分旋转实现高斯消元法。我创建了一个整数数组来存储行的交换,而不是直接交换行。

然而,我无法获得正确的结果,我无法弄清楚问题。我应该如何修改我的代码以获得正确的答案?

A=[1, -2, 1; 2, 1, -3; 4, -7, 1];
b=[0, 5, 1];
b=b';

function x = GE(A,b)

[m,n]= size(A); 
if m ~= n
  disp('Not a square');
end

for p=1:n
   array(p)=p;
endfor

A = [A,b];      

%elimination
for i = 1:n-1
    pivot = i;
    %select pivot
    for j = i+1:n
        if  abs(A(array(i),i)) < abs(A(array(i),i)) %row interchange
            temp = array(i);
            array(i) = array(j);
            array(j) = temp;
        end
    end

    while (pivot <= n && A(pivot,i)== 0)
        pivot = pivot+1;
    end
    if pivot > n
        disp('No unique solution');
        break
    else
        if pivot > i
            tem = array(i);
            array(i) = pivot
            pivot= tem;
        end
    end

    for j = i+1:n
        m = -A(array(j),i)/A(array(i),i);
        for k = i+1:n+1 
            A(array(j),k) = A(array(j),k) + m*A(array(i),k);
        end
    end
end

if A(n,n) == 0
    disp('No unique solution');
    return
end

%backward substitution
x(n) = A(array(n),n+1)/A(array(n),n);
for i = n - 1:-1:1
    sum = 0;
    for j = i+1:n
        sum = sum + A(array(i),j)*x(j);
    end
    x(i) = (A(array(i),n+1) - sum)/A(array(i),i);
end

endfunction

1 个答案:

答案 0 :(得分:0)

您的错误非常简单。您没有正确转动 - 特别是在if声明中:

for j = i+1:n
    if  abs(A(array(i),i)) < abs(A(array(i),i)) %row interchange <-------
        temp = array(i);
        array(i) = array(j);
        array(j) = temp;

    end
end

您检查要转动哪个系数是不正确的,因为当您需要使用i时,您使用索引j检查列。因此,只需更改布尔条件的另一侧,使其使用j

for j = i+1:n
    if  abs(A(array(i),i)) < abs(A(array(j),j)) %// CHANGE HERE
        temp = array(i);
        array(i) = array(j);
        array(j) = temp;

    end
end

使用您的示例Ab,我得到的答案是x = [2 1 0],它与MATLAB的ldivide操作一致:x = A \ b