Épsilon de máquina

Em aritmética de ponto flutuante, denomina-se épsilon da máquina o menor número que somado a 1 produza resultado diferente de 1, ou seja, que não é arredondado. O épsilon de máquina representa a exatidão relativa da aritmética do computador, e a sua existência é uma consequência direta da precisão finita da aritmética de ponto flutuante. O valor também é chamado de unidade de arredondamento ou menor número representável, e é simbolizado pela letra grega épsilon .[1][2]

Gráfico de ((1+x)-1)/x calculado em sistema de numeração do tipo 'double'. Idealmente o resultado seria 1, o gráfico mostra o efeito da perda de significância na operação (1+x) quando x é pequeno. Quando x se torna menor que o épsilon de máquina, a expressão se torna nula.

Definição formal

Arredondamento é o processo de escolha da representação de um número real em um sistema numérico de ponto flutuante. Para um determinado sistema numérico e um procedimento de arredondamento, o épsilon de máquina é o máximo erro relativo do procedimento escolhido.

Algumas explicações são necessárias para se determinar o valor dessa definição. Um sistema numérico de ponto flutuante é caracterizado por uma base , e por uma precisão , por exemplo, o número de dígitos na base da mantissa (incluindo qualquer bit implícito). Todos os números com o mesmo expoente têm o espaçamento . O espaçamento muda nos números que são potências perfeitas de ; o espaçamento no lado de maior magnitude é vezes maior que o espaçamento no lado de menor magnitude.

Uma vez que o épsilon de máquina é o limite do erro relativo, é suficiente considerar números com expoente . Também é suficiente para considerar números positivos. Para o método de arredondamento do valor mais próximo, o erro absoluto de arredondamento é no máximo metade do espaçamento, ou . Este valor é o maior numerador possível para o erro relativo. O denominador no erro relativo é o número sendo arredondado, que deve ser o menor possível para tornar o erro maior. O maior erro relativo, portanto, acontece quando o arredondamento é aplicado a números na forma onde está entre e . Todos esses números arredondam para com erro relativo . O máximo ocorre quando está no limite superior do intervalo. O no denominador tem pouca importância, sendo deixado de fora por conveniência, e apenas é tomado com o épsilon de máquina. Como foi mostrado aqui, o erro relativo é maior para números que são arredondados para , então o épsilon de máquina também é chamado de unidade de arredondamento, significando simplesmente "o máximo erro que pode ocorrer quando se arredonda para o valor unitário".

Assim, o máximo espaçamento entre um número normalizado em ponto flutuante , e um número normalizado adjacente é x .[3]

Modelo aritmético

A análise numérica usa o épsilon de máquina para estudar os efeitos dos erros de arredondamento. Os reais erros da aritmética computacional são complexos demais para serem diretamente estudados, então, em vez disso, o seguinte modelo simplificado é utilizado. O padrão aritmético da IEEE define que todas as operações de ponto flutuante são feitas como se fosse possível executá-las com precisão infinita, e então o resultado é arredondado para um número de ponto flutuante. Suponha que (1) e são números de ponto flutuante, que (2) é uma operação aritmética em ponto flutuante como adição ou multiplicação, e que (3) é a operação de precisão infinita. De acordo com o padrão, o computador calcula:

Pela definição, o erro relativo do arredondamento é máximo quando igual ao épsilon da máquina, então:

onde em grandeza absoluta é no máximo .

Como determinar o épsilon de máquina

Os valores de épsilon de máquina a seguir se aplicam a formatos padronizados de ponto flutuante:

IEEE 754 - 2008Nome usualTipo de dado em C++Base Precisão Épsilon de máquina[a] Épsilon de máquina[b]
binary16meia precisãoindisponível211 (um bit implícito)2 -11 = 4.88e-042 -10 = 9.77e-04
binary32precisão singularfloat224 (um bit implícito)2 -24 = 5.96e-082 -23 = 1.19e-07
binary64precisão dupladouble253 (um bit implícito)2 -53 = 1.11e-162 -52 = 2.22e-16
binary80precisão estendida_float80[4]2642 -64 = 5.42e-202 -63 = 1.08e-19
binary128precisão quádrupla_float128[4]2113 (um bit implícito)2 -113 = 9.63e-352 -112 = 1.93e-34
decimal32precisão singular decimal_Decimal32[5]1075 × 10 -710−6
decimal64precisão dupla decimal_Decimal64[5]10165 × 10 -1610−15
decimal128precisão quádrupla decimal_Decimal128[5]10345 × 10 -3410−33

a de acordo com Prof. Demmel, LAPACK, Scilab b de acordo com Prof. Higham; Padrão ISO C; constantes de linguagem C, C++ e Python; Mathematica, MATLAB e Octave


O épsilon de máquina de um sistema pode ser aproximado (a um fator de 2) pelo seguinte algoritmo em pseudocódigo: [6]

eps=1

while (eps+1) > 1
   eps=eps/2
end

eps=eps*2

Cancelamento catastrófico

Ver artigo principal: Cancelamento catastrófico

O cancelamento catastrófico é um efeito que ocorre quando excedemos o limite de precisão do sistema de numeração, sendo caracterizado por um aumento substancial do erro relativo dos resultados. O exemplo característico desse tipo de erro é quando o resultado da subtração de dois números se aproxima do valor do épsilon de máquina.[7]

Veja também

Referências

  1. Bortoli, Álvaro L.; Cardoso, Carolina; Fachin, Maria P. G.; Cunha, Rudnei D (2003). Introdução a Cálculo Numérico (PDF). [S.l.: s.n.] p. 15[ligação inativa]
  2. Sanches, Carlos A. A (2012). Matemática Computacional: Erros de Arredondamento (PDF). [S.l.: s.n.]
  3. Higham, Nicholas (2002). Accuracy and Stability of Numerical Algorithms (2 ed). [S.l.]: SIAM. 37 páginas
  4. Floating Types - Using the GNU Compiler Collection (GCC)
  5. Decimal Float - Using the GNU Compiler Collection (GCC)
  6. E. Elliott Ward Cheney, David Ronald Kincaid (2012). Numerical mathematics and computing. [S.l.]: Cengage Learning
  7. L.A.Sphaier, L.S.B.Alves. Representação de Números, Erros Numéricos e Aritmética Computacional. Disponível em www.sphaier.com
This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.