|
Генератор псевдослучайных чисел (ГПСЧ), Получение ПСЧ по seed-у и индексу внутри последовательности |
|
|
|
Jan 28 2014, 07:30
|
Участник

Группа: Участник
Сообщений: 40
Регистрация: 19-07-12
Пользователь №: 72 832

|
Цитата(Rst7 @ Jan 28 2014, 10:10)  Не видал, но есть простой метод решения. Берете какой-нибудь алгоритм шифрования (например DES), и шифруете ключем seed открытый текст index. На выходе получаете случайные числа. Либо берете хэш-функцию (например, MD5) от композиции seed и index. Отличный вариант! Если не найду нужный ГПСЧ, то так и сделаю. Спасибо! ))
|
|
|
|
Guest_TSerg_*
|
Jan 28 2014, 07:41
|
Guests

|
Что мешает заполнить таблицу нужного размера от ГСЧ, а затем по индексу извлекать?
|
|
|
|
|
Jan 28 2014, 09:39
|
Участник

Группа: Участник
Сообщений: 40
Регистрация: 19-07-12
Пользователь №: 72 832

|
Цитата(TSerg @ Jan 28 2014, 10:41)  Что мешает заполнить таблицу нужного размера от ГСЧ, а затем по индексу извлекать?  Даже если всю память контроллера займу таблицей, периодичность повторения ПСП будет для меня очень маленькой (
|
|
|
|
Guest_TSerg_*
|
Jan 28 2014, 09:50
|
Guests

|
Ну, хорошо. А открытый текст где держать? На большом брате и передавать по Wi-Fi?  Вы задачу поточнее изложите, а то фантазий много возникает.
|
|
|
|
|
Jan 28 2014, 11:34
|
Участник

Группа: Участник
Сообщений: 40
Регистрация: 19-07-12
Пользователь №: 72 832

|
Цитата(TSerg @ Jan 28 2014, 12:50)  Ну, хорошо. А открытый текст где держать? На большом брате и передавать по Wi-Fi?  Вы задачу поточнее изложите, а то фантазий много возникает. Время (индекс значения в последовательности) и ключ/полином, по условиям задачи, синхронизируются один раз в "безопасной среде". Одинаковые значения должны синхронно формироваться на обоих устройствах для поддержания связи между собой. Задача получения n-го значения последовательности выплывает из-за необходимости периодического восстановления синхронизма. Это если вкратце.
|
|
|
|
Guest_TSerg_*
|
Jan 28 2014, 14:05
|
Guests

|
Цитата(Tarbal @ Jan 28 2014, 16:37)  Аналоговый генератор шума + АЦП. Хотя дополнительное железо мне не нравится, но для полноты картины... В этом случае никакой синхронизации не будет в принципе, а она ТС нужна. P.S. Если возникает рассинхронизация, то использовать передачу slave-девайсу нового значения seed и начинать синхронную генерацию ПСП (reset с новым seed).
|
|
|
|
|
Jan 28 2014, 17:35
|
Участник

Группа: Участник
Сообщений: 40
Регистрация: 19-07-12
Пользователь №: 72 832

|
Вопрос, может уже не в эту тему... Последовал совету вычислять md5 от комбинации времени и индекса. Время вычисления md5 на целевом камне - 15.17 мкс. Зато алгоритм хэша "MurmurHash2" - 0.59 мкс. Предел 1 мкс. Кто-нибудь слышал про MurmurHash2? И есть ли альтернативная и быстрая хэш функция?
|
|
|
|
|
Jan 28 2014, 18:24
|
ʕʘ̅͜ʘ̅ʔ
    
Группа: Свой
Сообщений: 1 008
Регистрация: 3-05-05
Пользователь №: 4 691

|
Альтернативная обязательно есть: любая функция с выходом фиксированной разрядности, зависящим от входа. А мурмур-то почему не подходит? xxhash посмотрите, но не думаю, что там кардинальные отличия по части быстродействия Цитата(fsergey @ Jan 28 2014, 18:35)  И есть ли альтернативная и быстрая хэш функция?
|
|
|
|
|
Jan 28 2014, 18:54
|
Участник

Группа: Участник
Сообщений: 40
Регистрация: 19-07-12
Пользователь №: 72 832

|
Цитата(Fat Robot @ Jan 28 2014, 22:24)  Альтернативная обязательно есть: любая функция с выходом фиксированной разрядности, зависящим от входа.
А мурмур-то почему не подходит?
xxhash посмотрите, но не думаю, что там кардинальные отличия по части быстродействия мурмур как раз подходит! Тест на равномерность распределения, применительно к задаче, дал отличный результат. За совет спасибо, xxhash тоже думаю потестировать.
|
|
|
|
|
Jan 28 2014, 19:15
|
ʕʘ̅͜ʘ̅ʔ
    
Группа: Свой
Сообщений: 1 008
Регистрация: 3-05-05
Пользователь №: 4 691

|
Тест на равномерность распределения не стоит и ломаного сентаво.
пример: rng = 0,1,2,3, 0,1,2,3, 0,1,2,3, ... имеет равномерное распределение в диапазоне [0; 3]
Я писал вам, чем проверяются RNG.
С другой стороны, если у вас все хорошо, то пусть так и будет. равномерно хорошо.
|
|
|
|
|
Jan 28 2014, 20:04
|
Участник

Группа: Участник
Сообщений: 40
Регистрация: 19-07-12
Пользователь №: 72 832

|
Цитата(Fat Robot @ Jan 28 2014, 23:15)  Тест на равномерность распределения не стоит и ломаного сентаво.
пример: rng = 0,1,2,3, 0,1,2,3, 0,1,2,3, ... имеет равномерное распределение в диапазоне [0; 3]
Я писал вам, чем проверяются RNG.
С другой стороны, если у вас все хорошо, то пусть так и будет. равномерно хорошо. Тест последовательностей по дайхарду (Runs Test): 49.76 - 49.82-% восходящих последовательностей для разных сидов. Покатит. Тест Birthday Spacings ещё кажется интересным. Идею понял. Благодарю!
|
|
|
|
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|