Adição com transporte

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

Adição com transporte (AWC, 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, ....

Para uma definição mais formal e estabelecermos o período dessa sequência, precisamos gerar um conjunto finito X de vetores x=(x1,x2), tendo como componentes os resíduos de 10 e função iterativa f definida por f(x1,x2)=(x2,x1+x2modm). Como f tem uma inversa, para qualquer vetor inicial xX a sequência x,f(x),f2(x),f3(x), é estritamente periódica.[1]

O gerador pseudo-aleatório usando adição com transporte se baseia na sequência periódica acima. Temos como valores iniciais x_0 e x_1 iguais a 0 e 1, respectivamente, mais um bit de transporte inicial de 0. Cada novo dígito da sequência é igual à soma dos dois dígitos anteriores (como na Fibonacci) mais o bit de transporte. Ao resultado é aplicado mod10 e o bit de transporte do novo dígito da sequência pode ser 1 ou 0, dependendo se o resultado é maior ou menor que 10. Usando sobrescritos para indicar o bit de transporte, os digito da sequência gerada são

0,10,10,20,30,50,80,31,21,60,80,41,31,80,11,01,20,

Diferente da sequência-base mostrada acima, x,f(x),f2(x),f3(x),, nossos x provém do conjunto de vetores X de ordem 1×3, com x=(x1,x2,c). A função de iteração f é, portanto

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

Nos casos em que os vetores iniciais x=(x1,x2,0), com x1<x2 ou x=(x1,x2,1), com x1>x2, a sequência é periódica com um período igual a 108. O mesmo período também ocorre no caso no caso de vetores iniciais diferentes dos tipos anteriores, e diferentes de (0,0,0) ou (9,9,9), só que o vetor que deu origem à sequência pode não aparecer novamente dentro dela.[1]

Como se baseia nas sequências de Fibonacci defasadas, toda uma nova classe de geradores pode ser criada a partir da escolha de valores específicos dos atrasos r e s; assim como do vetor gerador x=(x1,x2,,xr,c) com resíduos gerados em relação a b, obtendo-se assim, uma sequência x,f(x),f2(x),f3(x), com

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

O período da sequência gerada será, então, de br+bs2.[1] Ou seja, devido a sua característica exponencial, estes geradores podem apresentar períodos bastante longos. Por exemplo, ao se escolher b tem ordem de 232 e r em torno de 20, o período da sequência é de 2640, com um custo computacional baixo, já que usará somente r locações de memória e a operação será realizada aproveitando-se a aritmética que já vem embutida na CPU.

Versão complementar

O gerador AWC tem uma versão chamada AWC complementar (AWC-c, sigla em inglês).[2] As regras para formação do elemento xn e o transporte c são

xn=(2b1xnrxnscn)modb=(xnrxnscn1)modb,cn+1=I(xnr+xns+cnb)

com I sendo a função indicadora, cujo valor é 1 se seu argumento é verdadeiro, e 0 se falso.

No AWC-c, xne c são criados como no AWC, mas toma-se o dígito complementar b1xn em vez de xn. Com essa alteração, o período das sequências geradas por meio do AWC-c será de br+bs.

Predefinição:Referências