Вычесть с переносом - Subtract with carry

Вычесть с переносом это генератор псевдослучайных чисел из запаздывающий Фибоначчи тип введен Джордж Марсалья и Ариф Заман в 1991 году.[1]

Алгоритм

Последовательность, генерируемая механизмом вычитания с переносом, может быть описана отношение повторения:

куда .

Константы S и р известны как короткие и длинные задержки соответственно.[2]Следовательно, выражения и соответствуют S-й и р-й предыдущий член последовательности.S и р удовлетворять условию .Модуль M имеет ценность , куда W - размер слова в битах последовательности состояний и .

Двигатель вычитания с переносом - один из семейства генераторов, которое также включает надстройка с переносом и вычесть с займом двигатели.[1]

Это один из трех двигателей генератора случайных чисел, включенных в стандартную комплектацию. C ++ 11 библиотека.[3]

Рекомендации

  1. ^ а б Новый класс генераторов случайных чисел, Джордж Марсалья и Ариф Заман, Анналы прикладной теории вероятностей, Vol. 1, № 3, 1991 г.
  2. ^ subtract_with_carry_engine Класс, Microsoft Visual Studio 2015
  3. ^ std :: subtract_with_carry_engine, cppreference.com