-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathGaussJordan.m
91 lines (76 loc) · 3.07 KB
/
GaussJordan.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
function x = GaussJordan(A,B)
%Autor: Rolando Valdez Guzmán
%Alias: Tutoingeniero
%Canal de Youtube: https://www.youtube.com/channel/UCU1pdvVscOdtLpRQBp-TbWg
%Versión: 2.1
%Actualizado: 18/may/2022
% ESTA FUNCION PIDE LOS SIGUIENTES DATOS DE ENTRADA:
% A = matriz cuadrada de coeficientes del sistema de ecuaciones.
% B = Vector columna de resultados de cada ecuación.
% VARIABLES DE SALIDA:
% x = vector con los valore para todas las variables del sistema de
% ecuaciones.
%~~~~~~~~~~~~~~~Protección contra errores en las entradas~~~~~~~~~~~~~~~~~%
if nargin ~= 2
error('Se debe ingresar una matriz cuadrada A y un vector columna B');
%Si se ingresan todos los datos de entrada, elegir un método de solución
else
if size(A,1) ~= size(A,2)
error('Se necesita que la matriz A sea cuadrada')
elseif size(B,2) ~= 1
error('B debe ser un vector columna');
elseif size(A,1) ~= size(B,1)
error('El número de filas de A no coincide con el de B. Sistema inconsistente');
end
end
if det(A) == 0
error('El determinante de la matriz A es cero, no se puede resolver');
end
%~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~Setup~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~%
n = size(A,1); t = ' | '; T = repmat(t,length(A(:,1)),1);
%%unión de los datos en una solo matriz
a = num2str(A); b = num2str(B); c = [a T b];
disp('Sistema original'); disp(c); disp(newline);
%~~~~~~~~~~~~~~~~~~~~~~~~~~~~~Pivoteo parcial~~~~~~~~~~~~~~~~~~~~~~~~~~~~~%
disp('Paso 0: Reordenar ecuaciones');
for k = 1:n
if A(k,k) ~= max(abs(A(:,k)))
[filapivote,~] = find(abs(A) == max(abs(A(:,k))));
A([k,filapivote(1)],:) = A([filapivote(1),k],:);
B([k,filapivote(1)]) = B([filapivote(1),k]);
end
end
c = [num2str(A), T, num2str(B)]; %%unión de los datos en una solo matriz
disp(c); disp(newline);
%~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~Gauss-Jordan~~~~~~~~~~~~~~~~~~~~~~~~~~~~~%
j = 1;
for k = 1:n
if A(k,k) ~= 1 %%si el elemento i,i de la diagonal es diferente de 1
B(k) = B(k)/A(k,k);
A(k,:) = A(k,:)./A(k,k);
c = [num2str(A), T, num2str(B)]; %%unión de los datos en una solo matriz
disp(['Paso ',num2str(j),': Normalizar la ecuación ',num2str(k)]);
disp(c); disp(newline);
j = j+1;
end
for i = 1:n
if i ~= k
if A(i,k) ~= 0 %Si no hay un cero en este elemento, hacer eliminación
factor = A(i,k)/A(k,k);
A(i,:) = A(i,:) - factor*A(k,:);
B(i) = B(i) - factor*B(k);
c = [num2str(A), T, num2str(B)]; %%unión de los datos en una solo matriz
disp(['Paso ',num2str(j)]); disp(c); disp(newline);
j = j+1;
else
continue %Si hay un cero, saltarse al siguiente elemento
end
end
end
x = B;
end
%~~~~~~~~~~~~~~~~~~~~~~~~~Impresión de resultados~~~~~~~~~~~~~~~~~~~~~~~~~%
for i = 1:n
fprintf('x%d = %f',i,x(i));
fprintf('\n');
end