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 •Lik ik j .Li aij ai 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 4L 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 •Lik ik j .Li aij aik 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 aik 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 1L2 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 1L 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 An1 . 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 4L3 •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 1L1 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 ( m1)1 1 am1 x1 ... a1n xn ... a2n xn ... a( m1) n xn ... am nxn b1 a11 a12 a1n x1 b1 a b2 a2n x2 b2 21 a22 bm1 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.