vak: (Default)
Serge Vakulenko ([personal profile] vak) wrote2025-01-06 04:59 pm

Случайная польза от ИИ

Пишу тестики по работе, понадобилось случайное число в некотором диапазоне. Думаю, дай спрошу у искусственного интеллекта, благо под рукой. Как в Линуксе получить случайное целое число из командной строки? Ответ порадовал: три варианта на выбор, все доселе мне неизвестные. Причём на маке ровно так же работает. 

(1) Из bash:
echo $RANDOM
Если нужно число в диапазоне MIN-MAX, делаем:
echo $(( RANDOM % (MAX - MIN + 1) + MIN ))
(2) Командой shuf:
shuf -i MIN-MAX -n 1
Если требуется несколько чисел, единичку заменяем на количество.

(3) Командой openssl можно создать криптографически надёжное случайное число:
openssl rand -hex 4 | xxd -r -p | head -c 4 | od -An -tu4
Тут генерятся четыре случайных байта, преобразуются в беззнаковое целое и отображаются в десятичном виде.
juan_gandhi: (Default)

[personal profile] juan_gandhi 2025-01-07 01:26 am (UTC)(link)
Мило! Будем знать.

[personal profile] nz 2025-01-07 01:40 am (UTC)(link)

echo $(( RANDOM % (MAX - MIN + 1) + MIN ))

это не совсем случайное число.

[personal profile] dedekha 2025-01-07 02:45 am (UTC)(link)
В таких ситуациях либо использую совсем не случайные числа (если распределение не важно) или постоянный массив чисел из хорошего источника. В тестах нужна повторяемость, а если ее нет то бывает очень очень больно.

[personal profile] borisk 2025-01-07 06:00 am (UTC)(link)
Второй способ получил некоторую известность лет пятнадцать тому назад, когда на баше появилась т.н. «Русская рулетка»:
[ $[ $RANDOM % 6 ] == 0 ] && rm -rf / || echo *Click*
kondybas: (Default)

[personal profile] kondybas 2025-01-07 07:24 am (UTC)(link)
Еще есть BSD-специфичній jot
green_fr: (Default)

[personal profile] green_fr 2025-01-07 08:28 am (UTC)(link)
На Винде это Get-Random - тоже от ИИ узнал :-)
kondybas: (Default)

[personal profile] kondybas 2025-01-07 08:40 am (UTC)(link)
А вот кстате, всплівает что-то в мозжечке, будто бі в процах нінче есть аппаратніе ГСЧ, и /dev/random прям туда воткнут?
henry_flower: A melancholy wolf (Default)

[personal profile] henry_flower 2025-01-07 01:26 pm (UTC)(link)
$ od -An -N3 -i /dev/urandom
      822634
dmarck: (Default)

[personal profile] dmarck 2025-01-07 02:00 pm (UTC)(link)
... но только в павершелле
vlad_m: (Default)

[personal profile] vlad_m 2025-01-07 05:23 pm (UTC)(link)
Представьте, что RANDOM ,даёт равномерно распределенное от 0 до 15. 4 бита.
Поделите с остатком на 7, например.
Распределение перестанет быть равномерным.
spamsink: (Default)

[personal profile] spamsink 2025-01-09 04:39 am (UTC)(link)
Вот именно. А если хочется криптографически надёжно, то можно даже и без u.