Método de JacobiO método de Jacobi é um algoritmo para resolver sistemas de equações lineares. Trata-se de uma versão simplificada do algoritmo de valores próprios de Jacobi. O método tem o nome do matemático Alemão Carl Gustav Jakob Jacobi. O método iterativo de Jacobi é um método clássico que data do final do século XVIII. Técnicas iterativas são raramente utilizadas para solucionar sistemas lineares de pequenas dimensões, já que o tempo requerido para obter um mínimo de precisão ultrapassa o requerido pelas técnicas diretas como a eliminação gaussiana. Contudo, para sistemas grandes, com grande porcentagem de entradas de zero (sistemas esparsos), essas técnicas aparecem como alternativas mais eficientes. Sistemas esparsos de grande porte frequentemente surgem na análise de circuitos, na solução numérica de problemas de valor de limite e equações diferenciais parciais.[1] DescriçãoDada uma matriz quadrada de equações lineares: em que: Então A pode ser decomposto num componente diagonal D e o resto R: O sistema de equações lineares pode ser reescrito como: O método de Jacobi é um método iterativo que resolve o membro esquerdo da expressão em ordem a x ao usar o método resultante da iteração anterior no membro direito. Analiticamente, isto pode ser escrito como: Ou, equivalentemente: Nota-se que a computação de é feita com base em todos os valores obtidos em iterações anteriores. Ao contrário do método de Gauss-Seidel, não se pode reescrever com , pois esse valor é necessário durante a continuação da computação. Esta é a diferença mais significativa entre o método de Jacobi e o método de Gauss-Seidel e é o motivo que o torna um algoritmo paralelo. AlgoritmoMATLAB / FreeMatX = input('Insira o vetor chute inicial ');
A = input('Insira a matriz dos coeficientes do sistema ');
b = input('Insira o vetor com os termos constantes ');
m = input('Insira o número máximo de iterações');
E = input('Insira a tolerância ');
n = input('Insira o número de equações ');
parar = 1;
ni = 0;
while (parar == 1 && ni < m)
for i=1:n
soma = 0;
for j=1:n
if(j~=i)
soma = soma + A(i,j)*X(j)/A(i,i);
end
end
x(i) = (b(i)/A(i,i)) - soma;
end
if (abs(norm(x) - norm(X))< E)
parar = 0;
else
X=x;
end
ni = ni + 1;
end
disp('Resposta do sistema');
disp(X');
disp('Número de iterações utilizadas: ');
disp(ni);
ScilabNa sequência, apresentamos um código Scilab que implementa uma versão simples do método de Jacobi. Os dados de entrada são: A matriz dos coeficientes, b vetor dos termos constantes, x0 vetor aproximação inicial, TOL tolerância, N número máximo de iterações. A saída é a calculada aproximação da solução de Ax = b. function [x] = jacobi(A,b,x0,TOL,N)
//preliminar
nlin = size(A,1); //num. de linhas
x = zeros(nlin,1); //cria x
//iterações
k = 1;
while (k <= N)
//iteração de Jacobi
for i = 1:nlin
x(i) = 0;
for j = [1:i-1,i+1:nlin]
x(i) = x(i) - A(i,j)*x0(j);
end
x(i) = (x(i) + b(i))/A(i,i);
end
//critério de parada
if (norm(x-x0,'inf') < TOL) then
return x;
end
//prepara nova iteração
k = k+1;
x0 = x;
end
//num. de iter. excedido
disp('Método falhou.')
endfunction
JavaScriptAbaixo é apresentado a resolução utilizando a linguagem JavaScript. function norm(Matrix) {
//Requer implementação ou inclusão de biblitecas de terceiros
}
/*
* A = Matriz
* b = Resultado da matriz
*/
function gaussJacobi(A, b) {
var X = new Array();
var x = new Array();
for (var k = 0; k < b.length; k++)
{
X[k] = 0; //Math.floor((Math.random() * 10000) + 1);
}
var E = 0.00001;//Precisão
var m = 1000;//Numero máximo de iterações
var ni = 0;//Contador de iterações
var continuar = true;
while (continuar && ni < m) {
for (var i=0; i < b.length; i++) {
soma = 0;
for (var j = 0; j < b.length; j++) {
if (j != i) {
soma = soma + A[i][j]*X[j]/A[i][i];
}
x[i] = (b[i]/A[i][i]) - soma;
}
}
if (Math.abs(norm(x) - norm(X)) < E) {
continuar = false;
} else {
X=x.slice(0);
}
ni = ni + 1;
}
return X;
}
JavaA seguir apresenta-se o algoritmo na linguagem Java com o vetor padrão de aproximação inicial zero. Parâmetros: matriz → a matriz; b → o vetor dos resultados; e → a precisão; numIter → o número máximo de iterações. Esta função retorna um vetor onde cada posição corresponde a uma variável. Ex.: resultado[0] = x, resultado[1] = y, resultado[2] = z... public static double[] jacobi(double[][] matriz, double[] b, double e, int numIter) {
double[] x0 = new double[matriz.length]; //vetor dos resultados anteriores
double[] x = x0.clone(); //vetor dos resultados atuais
double erro = 100, soma;
int k = 0; //A quantidade de iterações feitas
//Zera o vetor x0
for (int i = 0; i < x0.length; i++) {
x0[i] = 0;
}
while (erro >= e && k <= numIter) {
for (int i = 0; i < matriz.length; i++) {
soma = 0;
for (int j = 0; j < matriz[0].length; j++) {
if (i != j) {
soma += (matriz[i][j] * x0[j]) / matriz[i][i];
}
x[i] = (b[i] / matriz[i][i]) - soma;
}
}
erro = calcErro(x, x0);
x0 = x.clone();
k++;
}
return x;
}
//Faz o cálculo do erro
private static double calcErro(double[] a, double[] b) {
double result[] = new double[a.length];
for (int i = 0; i < a.length; i++) {
result[i] = Math.abs(a[i] - b[i]);
}
int cont = 0; //um contador
double maior = 0; //o maior número contido no vetor
while (cont < a.length) {
maior = Math.max(maior, result[cont]);
cont++;
}
return maior;
}
ConvergênciaA iteração de Jacobi tem a forma:
onde, e . Pode-se mostrar que, independentemente da aproximação inicial , a sequência gerada converge para a solução de se, e somente se, o raio espectral da matriz iteração for menor que .[2] Ou seja, as iterações de Jacobi convergem para a solução do sistema se, e somente se, o raio espectral de for menor que , i.e.:
Consequentemente, o método de Jacobi é convergente sempre que a matriz seja estrita ou irredutivelmente uma matriz estritamente diagonal dominante. Recentemente, uma técnica de duplo ciclo foi introduzida para forçar a convergência para a solução correta do algoritmo de Jacobi mesmo quando as condições suficientes para convergência não são verificadas. A técnica de duplo ciclo funciona para matrizes positivas definidas ou dependentes de colunas.[3] Exemplos1. Um sistema linear é dado por
Pretende-se usar a equação . Agora é necessário encontrar a matriz inversa dos valores da diagonal A através duma decomposição
Para se encontrar T recorre-se à equação . Agora, encontrado T, torna-se necessário obter C recorrendo à expressão . Assim, agora teremos . E agora podemos encontrar . Agora que se está na posse de X matrizes é possível avaliar a convergência para aproximar as soluções. 2. Efetuando os cálculos com três casas decimais, determine a solução do sistema de equações lineares por meio do método de Jacobi, onde : Nesse caso tem-se:
, E os resultados de aplicação do método de Jacobi são mostrados na tabela:
Notemos que a partir da 5 interação o método se estabiliza, com um erro de aproximadamente 0,04%. Critério de convergência (critério das linhas)Seja o sistema linear e seja: α =. Se α= máx α<1, sendo 1≤k≤n, então o método de Jacobi gera uma sequência {} convergente para a solução do sistema dado, independente da escolha da aproximação inicial, . Exemplo: Analisando a matriz A do sistema linear:
Temos: α = = = 0.3 < 1; α = =0.4 < 1; α = = 0.5 < 1 E então máx α = 0.5 < 1, sendo 1≤k≤3 donde, pelo critério das linhas, temos garantia de convergência para o método de Jacobi. Sempre que o critério de linhas não for satisfeito, devemos tentar uma permutação de linhas e/ou colunas de forma a obtermos uma disposição para a qual a matriz dos coeficientes satisfaça o critério das linhas.[4] Referências
Ver tambémLigações externas
|
Portal di Ensiklopedia Dunia