Proposta de Implementação do Algoritmo de Gauss-Jordan em Linguagem C
para Auxiliar o Aprendizado de Tópicos de Álgebra Linear
Diogo Chadud Milagres, Evandro L. Souza Falleiros
IFMS – Instituto Federal de Educação, Ciência e Tecnologia
de Mato Grosso do Sul
Nova Andradina – MS
[email protected], [email protected]
RESUMO
O objetivo deste trabalho é apresentar o Algoritmo de Gauss-Jordan para inversão
de Matrizes Quadradas de qualquer ordem e, a partir dele, extrair resultados úteis
para a Álgebra Linear além da obtenção da Matriz Inversa, como a resolução de
Sistemas Lineares e obtenção do determinante de uma Matriz por triangulação.
Tem-se, como objetivo propor algoritmos para as três aplicações supracitadas,
visando futura implementação destes em uma linguagem de programação. Nesse
sentido, pretende-se viabilizar uma ferramenta computacional para a aplicação da
Álgebra Linear em matrizes de ordens quaisquer e, particularmente, em matrizes de
ordens maiores que 3, onde as técnicas manuais de resolução demandam muito
tempo.
Palavras-chave: Eliminação de Gauss, Gauss-Jordan, Álgebra Linear, Sistemas
Lineares, Determinantes.
Introdução
Sistemas lineares aparecem com frequência na resolução de problemas tanto
do Ensino Médio quanto em cursos superiores, na disciplina de Álgebra Linear. Há
vários métodos de solucionar um sistema linear, dentre eles o método de
substituição e eliminação [LIPSCHUTZ, 2004]. No entanto, para sistemas com mais
de três incógnitas, esses métodos tornam-se trabalhosos [BOLDRINI, 1980].
Nesse aspecto, é importante lançar mão de algoritmos que utilizem Álgebra
das Matrizes [LIPSCHUTZ, 2004]. O Algoritmo de Eliminação de Gauss (AEG)
[BOLDRINI, 1980; LIPSCHUTZ, 2004; PATRÍCIO, 2006], também chamado de
escalonamento, resolve o problema parcialmente, pois ainda depende do método da
substituição, caso o sistema seja SPD. O Algoritmo de Gauss-Jordan retorna como
resultado a matriz hermitiana equivalente, cujas propriedades levam à matriz
inversa, caso a parte incompleta da hermitiana seja igual a In (Matriz identidade de
ordem n), ou à indicação de que a matriz não é invertível, se a característica da
hermitiana H seja menor que a característica da matriz original submetida ao
algoritmo.
Considerando a aplicação em Sistemas Lineares, é possível adaptar o
algoritmo de Gauss-Jordan para encontrar imediatamente a solução de um Sistema
Linear SPD (Sistema Possível Determinado), ou indicar se o sistema é SPI (Sistema
Possível Indeterminado), caso a característica da matriz incompleta após o
procedimento seja menor que a característica da matriz original, o mesmo
acontecendo com a matriz completa, ou SI (Sistema Indeterminado), caso as
característica da matriz incompleta seja menor após o procedimento do que a matriz
original, mas as características da matriz completa antes e após a aplicação do
algoritmo sejam iguais.
O algoritmo de Gauss-Jordan torna-se mais fácil de entender pela prontidão
com que fornece as respostas desejadas, ou seja, torna-se mais didático de se
apresentar que o AEG. No entanto, Gauss-Jordan é menos eficiente em termos
computacionais que o escalonamento. A preocupação, no entanto, não é com a
complexidade computacional, mas com a aplicação do algoritmo e suas variantes na
solução de sistemas lineares, determinantes e inversão de matrizes.
O trabalho será apresentado da seguinte forma: um capítulo sucinto para
apresentar os conceitos de álgebra das matrizes que serão úteis para se aplicar o
algoritmo de Gauss-Jordan. Em seguida, os capítulos referentes a cada problema
que se deseja resolver: inversão de matrizes, resolução de sistemas lineares e
cálculo do determinante por triangulação da matriz, todos com suas respectivas
propostas de pseudocódigo para futuras implementações. Consolidando a
interdisciplinaridade da Matemática com a Computação, teremos um capítulo sobre
resultados preliminares, focando a apresentação de exemplos. Finalmente, o
capítulo referente à conclusão pessoal dos autores sobre as impressões do que o
trabalho se propôs a mostrar e suas respectivas ideias para implementações e
criação de ferramentas didáticas aplicadas ao ensino de Álgebra Linear, tanto no
Ensino Superior quanto no Ensino Médio.
Álgebra das Matrizes
O objetivo é entender que arranjos lineares (chamados de vetores), se
tiverem o mesmo tamanho, podem ser representados em uma só notação,
denominada matriz. A partir da representação matricial, podem ser aplicadas
diversas propriedades de álgebra linear, como somas e trocas entre linhas. Antes de
aplicarmos os resultados dessas operações lineares, vamos estabelecer uma
sucinta base teórica da álgebra das matrizes e enunciar alguns algoritmos que
permitem que as operações lineares sejam aplicadas.
Uma matriz é um arranjo de valores (escalares), que agrupados linearmente
denominam-se vetores, todos os vetores do mesmo tamanho:
Se a matriz for representada por uma letra maiúscula, no caso A, seus
escalares (ou elementos) são representados pela letra minúscula correspondente e
são acompanhados de um índice com duas indicações. A primeira é a linha em que
ele se encontra, e a segunda é a coluna. No caso, aij representa o elemento da linha
i e da coluna j.
Uma matriz cujo número de linha e o de colunas é o mesmo é chamada de
matriz quadrada. Ela é particularmente útil para a resolução de sistemas lineares,
considerando o método de Crammer. O conceito associado à matriz quadrada que
auxilia a resolução de sistemas lineares é o determinante, que será explorado em
outra seção.
Na matriz quadrada, os elementos a ij onde i = j formam a diagonal principal.
Na figura abaixo, a diagonal principal forma o vetor [2 3 – 4].
A matriz identidade de ordem n, ou I n, denota uma matriz quadrada com n
linhas e n colunas com a seguinte característica:
O valor δij é chamado de delta de Kronecker [LIPSCHUTZ, 2004]. Por
exemplo, I3 é dado por:
Uma matriz é escalonada, ou está na forma de Echelon, quando obedece às
seguintes condições [LIPSCHUTZ, 2004]:
1) Todas as linhas nulas, caso existam, terminam nas últimas posições
(considerando uma ordenação de cima para baixo).
2) Cada primeiro valor não nulo de uma linha está à direita do primeiro valor
não nulo da linha acima.
Esses primeiros valores não nulos são chamados de pivôs. Eles são muito
importantes para determinar uma matriz equivalente na forma de Echelon relativa a
uma matriz qualquer.
A matriz acima está escalonada. Os valores circulados são os pivôs. A
quantidade de pivôs de uma matriz dá a característica da mesma. No caso car(A) =
4. Como car(A) < linhas(A), se fosse um sistema linear, o mesmo seria SPI (isto já
aconteceria porque, se cada coluna fosse representar uma variável, claramente
haveria mais variáveis que equações, esse exemplo foi dado somente como
ilustração). Demonstrações desse tipo não serão abordadas aqui, nem técnicas de
resolução de sistemas SPI ou SI.
Uma matriz está na forma canônica de Hermite quando obedece às seguintes
condições [PATRÍCIO, 2006]:
1) Todas as linhas nulas, caso existam, terminam nas últimas posições
(considerando uma ordenação de cima para baixo).
2) Cada primeiro valor não nulo de uma linha (pivô) está à direita do primeiro
valor não nulo da linha acima.
3) Todos os pivôs são iguais a 1.
4) Todos os outros elementos da coluna do pivô são nulos.
É importante notar que, se a matriz A for quadrada, e se car(A) = linhas(A),
ela é equivalente à matriz identidade.
Algoritmo de Gauss-Jordan e a inversão de Matrizes
Conforme consta em [PATRÍCIO, 2006], o Algoritmo de Gauss-Jordan resolve
completamente o problema de encontrar as soluções de um sistema linear SPD. O
resultado da aplicação do AGJ e uma matriz qualquer é a forma canônica.
Sua descrição, passo-a-passo, é a seguinte [LIPSCHUTZ, 2004]:
Seja a matriz A dada por
1) Ida: Consiste em encontrar a matriz equivalente a A, só que escalonada.
Passo 1: Organiza-se as linhas de forma que, quanto mais acima, o pivô de
cada linha esteja na mesma coluna ou mais à esquerda que o pivô da linha de baixo.
Passo 2: Seja aij o primeiro pivô. Para “zerar” o próximo elemento não nulo
desta j-ésima coluna (seja a(i + k)j), faz-se a seguinte operação linear:
a

Li + k •Lik   ik  j .Li
 aij 
 ai k  j 

 aij  serve para tornar o elemento a(i + k)j nulo. Vamos chama-lo


O termo  
de fator.
Passo 3: Repete-se os passos 1 e 2 até que todos os elementos abaixo do
pivô da primeira coluna que contém um pivô sejam nulos.
Passo 4: Para a próxima coluna, repita os passos 1 a 3. O pivô deve estar
pleo menos uma linha abaixo do pivô anterior. Observe que, para cada nova coluna,
o algoritmo da ida será aplicado em uma submatriz de dimensões menores que a
aplicação na coluna anterior.
Ao final desse processo, obteremos a matriz na forma de Echelon equivalente
à matriz dada.
Vamos aplicar o algoritmo da ida em um exemplo.
Seja a matriz A dada por
2 4 3 
A  1  2 4 
3 1  1
Aplicando a parte da ida do AGJ na coluna do primeiro pivô, temos:

1
3 
2 4 3 
L2 •L2   .L1 2 4

1  2 4    pivô  a  2
 2   0  4 5 

11
2 



 3

L

L

.
L


3 1  1
0  5  112 
 3 • 3  2  1
Observe que agora o novo pivô é a22 = - 4. O AGJ deverá ser aplicado na
 4 52 
submatriz 2 x 2 
:
11
 5  2 
3 
3 
2 4
2 4
0  4 5    pivô  a  4L  L    5 .L  0  4 5 
 3 • 3   2
22
2 
2 


4


69
11

0  5  2 
0 0  8 
Eis a matriz escalonada equivalente à matriz original.
2) volta: Consiste em encontrar a (hermitiana) canônica de A, a partir da sua
forma escalonada.
O algoritmo da volta é bastante similar ao da ida, invertendo-se o sentido do
escalonamento. Além do que, o passo 1 não precisaria mais ser feito, uma vez que a
matriz escalona já est[a organizada para anulação dos elementos acima do pivô. No
lugar disso, o passo 1 irá transformar os pivôs no número 1. Ou seja, vamos de
baixo para cima. Pequenas adaptações precisarão ser feitas:
Passo 1: Cada pivô passará a valer 1, multiplicando-se sua linha equivalente
pelo inverso do referido pivô.
Passo 2: Seja aij o primeiro pivô. Para “zerar” o próximo elemento não nulo
desta j-ésima coluna (seja a(i - k)j), faz-se a seguinte operação linear:
a

Li - k •Lik   ik  j .Li
 aij 
 aik  j 
 serve para tornar o elemento a(i - k)j nulo. Vamos chama-lo
O termo  
 aij 


de fator. Nota: como o pivô passará a valer 1, o fator é simplificado para  aik  j .
Passo 3: Repete-se os passos 1 e 2 até que todos os elementos acima do
pivô da última coluna à direita que contém um pivô sejam nulos.
Passo 4: Para a próxima coluna à esquerda, repita os passos 1 a 3. O pivô
deve estar pelo menos uma linha acima do pivô anterior. Observe que, para cada
nova coluna, o algoritmo da ida será aplicado em uma submatriz de dimensões
menores que a aplicação na coluna anterior.
Ao final desse processo, obteremos a matriz na forma canônica equivalente à
matriz dada.
Continuando com o exemplo:
3   L1   12 .L1
2 4
1 2 32 

0  4 5   L   1 .L  0 1  5 
 2
2
2 
4
8


0 0  698  L3   698 .L3
0 0 1 
1 2 32 
1 2 0
5
0 1  5    pivô  a  1L2  L2   8 .L3  0 1 0

33
8
3



 L1  L1   2 .L3
0 0 1 
0 0 1
1 2 0
1 0 0
0 1 0   pivô  a  1L  L  2.L  0 1 0  I
22
1
1
2



 3
0 0 1
0 0 1
O exemplo ainda mostra que, para uma matriz quadrada, sendo A’ a forma de
Echelon de A, se car(A’) = linhas(A), então a forma canônica [e a matriz identidade
de ordem equivalente a A.
Para obtenção da matriz inversa A-1 da matriz A (desde que seja invertível),
aplica-se o AGJ da seguinte forma [PATRÍCIO, 2006]:
Constrói-se a matriz n x 2n, concatenando lado a lado a matriz quadrada A
com a matriz identidade equivalente: An I n . Aplicando AGJ, caso car(A’) = linhas(A),




sendo A’ a forma de Echelon de A, teremos ao final o sistema equivalente I n An1 .
Aplicando ao exemplo anterior:

1
2 4
2 4 3 1 0 0
3 1 0 0
L2 •L2   .L1






2


 0  4 52  12 1 0
1  2 4 0 1 0   pivô  a11  2
L3 •L3   3 .L1
0  5  112  32 0 1
3 1 1 0 0 1

 2
2 4
2 4 3 1 0 0
3 1 0 0


5






5
5
1
1
0  4 2  2 1 0   pivô  a22  4L3 •L3    4 .L 2  0  4 2  2 1 0

0 0  698  78  54 1
0  5  112  32 0 1




2 4
1 2 32
3 1
0 0  L1   12 .L1




5
5
1
1
0  4 2  2 1 0   L2   4 .L2  0 1  8
8
0 0  698  78  54 1 
0 0 1

 L3   69 .L3

1 2 32

5
0 1  8
0 0 1

1
2
1
8
7
69
0
 14
10
69
1
2
1
8
7
69
0
 14
10
69
0 

0 
 698 
5
24
4 
1 2 0 69
0 
 23
23
5


L

L


.
L




2
3
8
0    pivô  a33  1 2
 0 1 0 13
 11
 695 
69
69
3
 L1  L1   2 .L3
10
0 0 1 697
 698 
 698 
69

5
7
24
4 
22 
1 2 0 69
1 0 0  692
 23
23
69
69


13
5
13
5
11
11
0 1 0 69  69  69    pivô  a22  1L1  L1  2.L2  0 1 0 69  69  69 
10
10
0 0 1 697
0 0 1 697
 698 
 698 
69
69


O resultado ode ser comprovado com a ajuda de softwares, como
Mathematica, Octave, Matlab e outros similares.
Solução de Sistemas de Equações Lineares
Uma equação linear é a que envolve n variáveis x1, x2, ..., xn em uma equação
de grau 1, ou seja, uma equação da reta no espaço n-dimensional:
Um Sistema de equações lineares é um conjunto de equações lineares com
incógnitas em comum e que devem ser resolvidas em conjunto.
Os sistemas lineares podem ser do tipo SPD (Sistema Possível Determinado),
quando há uma única n-upla (r1, r2, ..., rn) como solução, SPI (Sistema Possível
Indeterminado), quando há uma infinidade de n-uplas k(r1, r2, ..., rn), k  R , como
solução do sistema e SI (Sistema Indeterminado) quando o sistema não tem
solução.
Podemos representar um sistema linear de forma matricial. Notando que
 a11x1
 a x
 21 1
 
a
x
 ( m1)1 1
 am1 x1
 ...  a1n xn
 ...  a2n xn


 ...  a( m1) n xn
 ...  am nxn
 b1
 a11 a12   a1n   x1   b1 
a
 b2
a2n   x2  b2 
 21 a22
   

       

    
 bm1
    
 
am1 am2   am n  xm  bm 
 bm
há várias técnicas de cálculo da solução do sistema, e diagnosticar se é SPD,
SPI, ou SI.
Uma delas é a regra de Crammer. Esse método considera o cálculo de
determinantes para discutir ou calcular um Sistema Linear. Em resumo, seja a matriz
formada apenas pelos coeficientes a ij das equações lineares. D1 o determinante da
mesma matriz de coeficientes, substituindo-se a coluna 1 (das variáveis x1 e
coeficientes a11 até am1) pelos termos independentes b 1 até bn. D2 até Dn seguem o
mesmo modelo. Observem que para calcular determinantes, essas matrizes devem
ser quadradas, então o número m de equações tem que ser igual ao número n de
variáveis.
Uma proposta de algoritmo para esse método é o seguinte:
Passo 1: se m = n, prossiga para o passo 2; se m > n, elimine as últimas m –
n equações até que m = n; se m < n, complete as n – m linhas restantes com zeros
no lugar dos coeficientes e termos independentes respectivos.
Passo 2: Calcule o determinante D. Se D for igual a zero, o sistema não tem
uma solução única, ou não tem solução nenhuma. Assim, ele é candidato a SPI ou
SI. Prossiga para o passo 3; Caso D seja diferente de zero, o sistema é SPD.
Prossiga para o passo 3.
Passo 3: Caso D seja igual a zero e todos os determinantes Di, i = 1, ..., n,
sejam todos iguais a zero, o sistema é SPI; Se D for igual a zero e pelo menos um
determinante i = 1, ..., n, for diferente de zero, o sistema é SI; se D for diferente de
zero, os resultados das variáveis são xi = Di / D.
Um problema com esse método é que sua complexidade computacional é
muito alta, se comparado ao AGJ. Assim, a proposta é, a partir da implementação do
AGJ, utilizá-lo concatenando, à direita da matriz de coeficientes a ij, a coluna de
termos independentes bi:
 a11 a12   a1n b1 


a2n b2 
 a21 a22
 

 


  
 
am1 am2   am n bm 


Assim, quando se encontrar a forma canônica de Hermite em relação à matriz
de coeficientes aij, desde que seja quadrada, temos que as transformações feitas em
bi, i = 1, ..., n, levam aos respectivos valores de xi, i = 1, ..., n, caso o sistema seja
SPD.
A proposta inicial de implementação consiste em misturar as ideias do
escalonamento completo do AGJ, mas a discussão sobre se o sistema é SPD ou
não seria feita pelo cálculo do determinante principal D de Crammer. No entanto,
para matrizes quadradas de ordem maior que 3, o cálculo do determinante por
pivotagem e Laplace [LIPSCHUTZ, 2004] pode se tornar cansativo e complexo,
mesmo na forma de implementar. Assim, a ideia é encontrar a matriz escalonada na
forma de Echelon, e aplicar o cálculo do determinante da matriz triangular.
Cálculo de Determinantes por triangulação
Em [LIPSCHUTS, 2004], o teorema 8.2 (iii) afirma que, se A é uma matriz
n
triangular, então seu determinante é dado por
a
i 1
ii
, se a matriz for de ordem n.
Além disso, das propriedades de manipulação de uma matriz e os efeitos no cálculo
do seu determinante, temos que (teorema 8.3):
(i)
(ii)
(iii)
Se duas linhas (colunas) forem trocadas de posição entre si, trocase o sinal do determinante;
Se um alinha (coluna) for multiplicada por um escalar k, também o
determinante será multiplicado por k;
Se houver uma soma de um linha por um múltiplo de outra (tal como
o algoritmo de eliminação gaussiana), o determinante não será
afetado.
Assim, pode-se calcular o determinante de uma matriz quadrada de qualquer
ordem, aplicando a fórmula do determinante da matriz triangular e, mesmo que a
matriz não seja triangular, pode-se encontrar a triangular equivalente pelo AEG.
A implementação desse cálculo, além de fornecer um programa que calcule
determinantes de matrizes quadradas de qualquer ordem, auxilia na implementação
de um código que resolva sistemas lineares tanto pelo AGJ como por Crammer.
Também, pode fornecer uma resposta intermediária, caso uma matriz não seja
invertível (se det(A) = 0, então não existe A –1) [LIPSCHUTZ, 2004], antes de
proceder com o cálculo.
Resultados preliminares
Alguns protótipos foram testados, ainda de forma incompleta, mas que
resolve problemas mais simples como matrizes que são invertíveis e sistemas
lineares com número de variáveis igual ao número de equações. Vejamos alguns
exemplos de aplicação:
 1 2 3
a) Determinar a matriz inversa de A   0 1 2 :
 2 0 1
Digite a ordem da matriz: 3
[-2
0
1
0
0
1
]
Pressione qualquer tecla para continuar...
Digite a_11: 1
Digite a_12: 2
Coluna 1 operando com os fatores:
Digite a_13: 3
[1
2
3
1
0
0
]
[0
1
2
0
1
0
]
[0
4
7
2
0
1
]
Digite a_21: 0
Digite a_22: 1
Digite a_23: 2
Pressione qualquer tecla para continuar...
Digite a_31: -2
Digite a_32: 0
Pivo: 1
Digite a_33: 1
Matriz A:
L2 <-> L2
[1
2
3
]
[1
2
3
1
0
0
]
[0
1
2
]
[0
1
2
0
1
0
]
[-2
0
1
]
[0
4
7
2
0
1
]
Pressione qualquer tecla para continuar...
Matriz Identidade:
[1
0
0
]
Coluna 2 operando com os fatores:
[0
1
0
]
[1
2
3
1
0
0
]
[0
0
1
]
[0
1
2
0
1
0
]
[0
0
-1
2
-4
1
]
Matrizes Concatenadas:
Pressione qualquer tecla para continuar...
[1
2
3
1
0
0
]
[0
1
2
0
1
0
]
[-2
0
1
0
0
1
]
Pivo: 1
L3 <-> L3
[1
2
3
1
0
0
]
[0
1
2
0
1
0
]
[0
0
-1
2
-4
1
]
Pressione qualquer tecla para continuar...
L1 <-> L1
[1
2
3
1
0
0
]
[0
1
2
0
1
0
]
Coluna 3 operando com os fatores:
[1
2
0
7
-12
3
]
[0
1
0
4
-7
2
]
[0
0
-1
2
-4
1
]
Pressione qualquer tecla para continuar...
Pressione qualquer tecla para continuar...
Matrizes Concatenadas depois do algoritmo:
[1
0
0
-1
2
-1
]
[0
1
0
4
-7
2
]
[0
0
1
-2
4
-1
]
L2 <-> L2
[1
2
0
7
-12
3
]
[0
1
0
4
-7
2
]
[0
0
-1
2
-4
1
]
Pressione qualquer tecla para continuar...
Pressione qualquer tecla para continuar...
Matriz inversa:
[-1
2
-1
]
[4
-7
2
]
[-2
4
-1
]
Coluna 2 operando com os fatores:
[1
0
0
-1
2
-1
]
[0
1
0
4
-7
2
]
[0
0
-1
2
-4
1
]
Pressione qualquer tecla para finalizar...
O programa concluiu corretamente que a matriz inversa é dada por
 1 2 3
A   0 1 2 .
 2 0 1
1
b) Resolver o seguinte sistema linear extraído de [BOLDRINI, 1980]:
 x1  4x2  3x3  1

2x1  5x2  4x3  4
 x  3x  2x  5
2
3
 1
Digite coeficiente da variavel x_2 da
equacao 3: -3
Digite a quantidade de variaveis: 3
Digite coeficiente da variavel x_1 da
equacao 1: 1
Digite coeficiente da variavel x_2 da
equacao 1: 4
Digite coeficiente da variavel x_3 da
equacao 3: -2
Digite resultado da equacao 1: 1
Digite resultado da equacao 2: 4
Digite resultado da equacao 3: 5
Digite coeficiente da variavel x_3 da
equacao 1: 3
Sistema em forma de Matriz Completa:
Digite coeficiente da variavel x_1 da
equacao 2: 2
Digite coeficiente da variavel x_2 da
equacao 2: 5
[1
4
3
1
]
[2
5
4
4
]
[1
-3
-2
5
]
Digite coeficiente da variavel x_3 da
equacao 2: 4
Pivo: 1
Digite coeficiente da variavel x_1 da
equacao 3: 1
Pressione qualquer tecla para continuar...
[0
[1
4
3
]
[0
-3
-2
]
[0
-7
-5
]
0
-0.333
-0.667
]
Pressione qualquer tecla para continuar...
L3 <-> L3
Pressione qualquer tecla para continuar...
[1
4
3
1
]
[0
-3
-2
2
]
[0
0
-0.333
-0.667
]
Pivo: -3
Pressione qualquer tecla para continuar...
Pressione qualquer tecla para continuar...
[1
4
3
]
[0
-3
-2
]
[0
0
-0.333
]
Coluna 3 operando com os fatores:
[1
4
0
-5
]
[0
-3
0
6
]
[0
0
-0.333
-0.667
]
Pressione qualquer tecla para continuar...
Pivo: 1
L1 <-> L1
Pressione qualquer tecla para continuar...
[1
4
3
1
]
[2
5
4
4
]
[1
-3
-2
5
]
L2 <-> L2
[1
4
0
-5
]
[0
-3
0
6
]
[0
0
-0.333
-0.667
]
Pressione qualquer tecla para continuar...
Coluna 1 operando com os fatores:
[1
4
3
1
]
[0
-3
-2
2
]
[0
-7
-5
4
]
Pressione qualquer tecla para continuar...
Coluna 2 operando com os fatores:
[1
0
0
3
]
[0
-3
0
6
]
[0
0
-0.333
-0.667
]
Pressione qualquer tecla para continuar...
Pivo: -3
Pressione qualquer tecla para continuar...
L2 <-> L2
Sistema resolvido:
[1
4
3
1
]
[0
-3
-2
2
]
[0
-7
-5
4
]
[1
0
0
3
]
[0
1
0
-2
]
[0
0
1
2
]
Pressione qualquer tecla para continuar...
x_1 = 3
Coluna 2 operando com os fatores:
x_2 = -2
[1
4
3
1
]
[0
-3
-2
2
]
x_3 = 2
Pressione qualquer tecla para finalizar...
1 3 4
2
2
1
0
3  2 1 

2 0 1
2 :
c) Calcular o determinante de C   4


5
 2  4 3 1
 1
0
3
2  4
Digite a ordem da matriz: 5
Digite
Digite
Digite
Digite
Digite
Digite
Digite
Digite
Digite
Digite
Digite
Digite
Digite
Digite
Digite
Digite
Digite
Digite
Digite
Digite
Digite
Digite
Digite
Digite
Digite
a_11:
a_12:
a_13:
a_14:
a_15:
a_21:
a_22:
a_23:
a_24:
a_25:
a_31:
a_32:
a_33:
a_34:
a_35:
a_41:
a_42:
a_43:
a_44:
a_45:
a_51:
a_52:
a_53:
a_54:
a_55:
2
1
-3
4
2
1
0
3
-2
1
4
2
0
1
2
-2
-4
3
1
5
1
0
3
2
-4
[-2
-4
3
1
5
]
[1
0
3
2
-4
]
Pressione qualquer tecla para continuar...
Coluna 1 operando com os fatores:
[2
1
-3
4
2
]
[0
-0.5
4.5
-4
0
]
[0
0
6
-7
-2
]
[0
-3
0
5
7
]
[0
-0.5
4.5
0
-5
]
Pressione qualquer tecla para continuar...
Pivo: -0.5
L2 <-> L2
[2
1
-3
4
2
]
[0
-0.5
4.5
-4
0
]
[0
0
6
-7
-2
]
[0
-3
0
5
7
]
[0
-0.5
4.5
0
-5
]
Matriz A:
[2
1
-3
4
2
]
[1
0
3
-2
1
]
[4
2
0
1
2
]
[-2
-4
3
1
5
]
[1
0
3
2
-4
]
Pressione qualquer tecla para continuar...
Coluna 2 operando com os fatores:
[2
1
-3
4
2
]
[0
-0.5
4.5
-4
0
]
[0
0
6
-7
-2
]
[0
0
-27
29
7
]
[0
0
0
4
-5
]
Pivo: 2
L1 <-> L1
[2
1
-3
4
2
]
[1
0
3
-2
1
]
[4
2
0
1
2
]
Pressione qualquer tecla para continuar...
L4 <-> L4
Pivo: 6
[2
1
-3
4
2
]
[0
-0.5
4.5
-4
0
]
[0
0
6
-7
-2
]
[0
0
0
-2.5
-2
]
[0
0
0
4
-5
]
L3 <-> L3
[2
1
-3
4
2
]
[0
-0.5
4.5
-4
0
]
[0
0
6
-7
-2
]
[0
0
-27
29
7
]
[0
0
0
4
-5
]
Pressione qualquer tecla para continuar...
Coluna 4 operando com os fatores:
Pressione qualquer tecla para continuar...
[2
1
-3
4
2
]
[0
-0.5
4.5
-4
0
]
[0
0
6
-7
-2
]
[0
0
0
-2.5
-2
]
[0
0
0
0
-8.2
]
Coluna 3 operando com os fatores:
[2
1
-3
4
2
]
[0
-0.5
4.5
-4
0
]
[0
0
6
-7
-2
]
[0
0
0
-2.5
-2
]
[0
0
0
4
-5
]
Pressione qualquer tecla para continuar...
det(A) = -122
Pressione qualquer tecla para continuar...
Pressione qualquer tecla para finalizar...
Pivo: -2.5
Ou seja, além calcular det(C), o programa retornou a forma escalonada de
Echelon de C pelo método da eliminação gaussiana (AEG).
Conclusão e Propostas para futuros trabalhos
Em álgebra de matrizes, os algoritmos como Crammer, AEG e AGJ são
possíveis de se implementar, uma vez que a bibliografia sobre o assunto traz
algoritmos de forma descritiva para realizar os cálculos como matriz inversa, valores
das incógnitas em um sistema linear e determinantes.
Utilizando alguns teoremas de álgebra linear e os algoritmos descritos neste
trabalho, foi possível implementar formas mais simples desses algoritmos em C e
obter resultados que foram vistos no capítulo anterior. Para futuros trabalhos,
pretendemos aprimorar o código fonte, levando-se em consideração a complexidade
computacional e os testes de validade. Pretende-se, também, propor uma interface
gráfica agradável ao usuário final. Dessa forma, os resultados das operações
poderão ser melhor visualizadas pelos usuários do sistema. Vale ressaltar que tal
implementação também deverá mostrar a solução implícita no caso do sistema ser
SPI.
Referências
BOLDRINI, J. L. et al. Álgebra Linear. São Paulo: Harper & Hall do Brasil. 3ª
Ed., 1980.
LIPSCHUTZ, S.; LIPSON, M. Schaum’s Outlines of Theory and Problems of
Linear Algebra. McGraw-Hill. 3th Ed., 2004.
PATRÍCIO, P. Notas de Aula de Álgebra Linear em 2006. Disponível em:
<http://w3.math.uminho.pt/~pedro/>. Acesso em: set-2013.
Download

Proposta de Implementação do Algoritmo de Gauss-Jordan