Subtração com empréstimo

Fonte: testwiki
Saltar para a navegação Saltar para a pesquisa

Subtração com empréstimo (SWB, sigla em inglês) é um algoritmo de geração de números pseudoaleatórios, fazendo parte de um conjunto de algoritmos projetados para produzir uma longa série de números aparentemente aleatórios com base em uma pequena quantidade de dados iniciais. É um dos tipos de geradores de Fibonacci defasado, introduzido por George Marsaglia e Arif Zaman em 1991.[1] "Fibonacci defasado" refere-se ao fato de que cada número aleatório é uma função de dois dos números precedentes em alguns deslocamentos fixos especificados, ou "atrasos".

Algoritmo

Considerando a sequência de Fibonacci clássica

0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, ....

com cada um dos elementos sendo a soma dos dois elementos prévios. Se aplicarmos o operador mod a todos os elementos desta sequência, teremos um exemplo de sequência de Fibonacci defasada com atraso r=2, s=1 e uma operação binária vw=(v+w)mod10, temos

0, 1, 1, 2, 3, 5, 8, 3, 1, 4, 5, 9, 4, ....

Diferente do que ocorre na geração usando a adição com transporte (AWC) , cada novo elemento na sequência deste gerador é produzido subtraindo-se o dígito com atraso 1 e o bit de empréstimo (inicialmente igual a 0 para o dígito de atraso 1, que é o 1 em negrito na seq. de Fibonacci acima) do dígito com atraso 2 (o 0 em negrito, nessa mesma sequência). Se a diferença resultar em um número positivo, o bit de empréstimo é igualado a zero; se não, soma-se 10 à diferença obtida e o bit de empréstimo recebe o valor 1. Logo, usando 0 e 1 como valores iniciais, com bit de empréstimo igual a 0, geramos a sequência

0,10,91,11,70,41,20,20,00,20,81,31,40,11,20,91,21,60,

Para uma definição mais formal, precisamos gerar um conjunto finito X de vetores x=(x1,x2,c), tendo como componentes x1e x2,resíduos de 10 e c{0,1}. A função f de geração da sequência é então definida como

f(x1,x2,c)={(x2,x1x2c,0),se x1x2c0(x2,x1x2c+10,1),se x1x2c<0

Que pode ser resumido de maneira mais informal como sendo xn=xn2xn1c, sendo o empréstimo atualizado com cn+1=I(xn2xn1cn), com I sendo a função indicadora..

Já que a ordem da subtração importa no caso deste gerador, toda uma nova gama de geradores SWB pode ser criada por meio da transposição dos elementos atrasados na forma xn=xn1xn2c, com o bit de empréstimo definido de acordo cn+1=I(xn1xn2cn). O gerador como é definido inicialmente[1] é chamado de SWB-II, enquanto que a forma modificada é classificada como SWB-I.[2]

Como formulação geral e de modo a serem estabelecidos os períodos respectivos desta classe de geradores, definimos um conjunto finito X de vetores x=(x1,x2,,xr,c), com os valores de x resíduos em relação à uma base qualquer b, e valores de atraso r e s, sendo r>s tendo a função iterativa f definida para SWB-I

f(x1,,xr,c)={(x2,,xr,x1xr+1sc,0),se x1xr+1sc0(x2,,xr,xr+1sx1c+b,1),se x1xr+1sc<0

e a função iterativa do gerador SWB-II

f(x1,,xr,c)={(x2,,xr,xr+1sx1c,0),se xr+1sx1c0(x2,,xr,xr+1sx1c+b,1),se xr+1sx1c<0

Com os valores das variáveis atribuídos, pode-se garantir que será gerada uma sequência periódica, tendo no caso do SWB-I o valor de brbs2; enquanto que para o SWB-II será brbs.[1]

Predefinição:Referências