Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
乱数を作る
Search
Satoshi SAKAO
September 05, 2018
Science
0
180
乱数を作る
社内のLTイベント「えるLT Vol3」で発表した資料です
Satoshi SAKAO
September 05, 2018
Tweet
Share
More Decks by Satoshi SAKAO
See All by Satoshi SAKAO
Testcontainers/2024-11-20-llt32
ottijp
0
83
Pkl/2024-04-17-llt31
ottijp
0
110
JavaScriptのデバッグ/2023-09-04-llt30
ottijp
0
180
CDK for TerraformでAzureリソースをデプロイする/2023-05-15-llt29
ottijp
1
310
TWELITEへの誘い/2022-12-27-llt28
ottijp
0
180
ビルドツールBazelを触ってみた/2022-09-28-llt27
ottijp
0
200
HashiCorp Vaultを使ったシークレットのセキュアな一元管理 〜Ansibleを添えて〜/2022-07-12-llt26
ottijp
0
170
AWSインフラのデプロイをCDKでカイゼンする/2022-03-23-llt25
ottijp
0
120
Amazon Timestreamでデータ補間/2021-12-27-llt24
ottijp
0
120
Other Decks in Science
See All in Science
データマイニング - グラフデータと経路
trycycle
PRO
2
490
Text-to-SQLの既存の評価指標を問い直す
gotalab555
1
190
シャボン玉の虹から原子も地震も重力も見える! 〜 物理の目「干渉縞」のすごい力 〜
syotasasaki593876
1
110
データマイニング - ノードの中心性
trycycle
PRO
0
360
Celebrate UTIG: Staff and Student Awards 2025
utig
0
1.3k
コミュニティサイエンスの実践@日本認知科学会2025
hayataka88
0
150
先端因果推論特別研究チームの研究構想と 人間とAIが協働する自律因果探索の展望
sshimizu2006
3
830
Amusing Abliteration
ianozsvald
0
140
(2025) Balade en cyclotomie
mansuy
0
530
Lean4による汎化誤差評価の形式化
milano0017
1
460
A Guide to Academic Writing Using Generative AI - A Workshop
ks91
PRO
0
250
主成分分析に基づく教師なし特徴抽出法を用いたコラーゲン-グリコサミノグリカンメッシュの遺伝子発現への影響
tagtag
PRO
0
220
Featured
See All Featured
Designing Experiences People Love
moore
143
24k
Introduction to Domain-Driven Design and Collaborative software design
baasie
1
690
The agentic SEO stack - context over prompts
schlessera
0
720
Optimising Largest Contentful Paint
csswizardry
37
3.6k
Abbi's Birthday
coloredviolet
2
6k
The Language of Interfaces
destraynor
162
26k
StorybookのUI Testing Handbookを読んだ
zakiyama
31
6.6k
Skip the Path - Find Your Career Trail
mkilby
1
93
Have SEOs Ruined the Internet? - User Awareness of SEO in 2025
akashhashmi
0
300
Facilitating Awesome Meetings
lara
57
6.8k
JAMstack: Web Apps at Ludicrous Speed - All Things Open 2022
reverentgeek
1
400
The MySQL Ecosystem @ GitHub 2015
samlambert
251
13k
Transcript
乱数を作る えるLT Vol.3 2018/09/05 (Wed) @インフォコム Satoshi SAKAO K1
話すひと K2 インフォコム株式会社 オープンイノベーションセンター " アプリケーションエンジニア JS(ES6) / Node.js /
GCP / IoT / iOS (Swift) シュタゲ / ASMR Satoshi SAKAO @ottijp
免責 K3 • 実はよくわかってません • 数学不得意です • Newtonに感化された だけなんです
ランダムな点群はどっち? K4 A B クラスター錯覚
ランダムな数(乱数)をどう作るか? • プログラミングにおける rand() • 計算式(アルゴリズム)によって次の乱数を決める • 規則がいっさい存在しない •
ノイズ,熱雑音などによって次の乱数を決める K5 疑似乱数 真の乱数
疑似乱数 弱い乱数 • 計算は簡単(早い) • 収束,周期性がある (乱数として質が悪い) 強い乱数 • 計算は比較的遅い
• 乱数としての質が良い K6 • 平方採中法 • 線形合同法 • clangのrand() • Javaのjava.util.Random • XOR Shift • JavaScriptのMath.random() • メルセンヌ・ツイスタ • さいきょう
疑似乱数の比較 K7 線形合同法(弱い乱数) メルセンヌ・ツイスタ(強い乱数) ※ [0:255]の範囲で整数乱数を生成し,(x,y,z)点を1000点作成
ランダムな数(乱数)をどう作るか? • プログラミングにおける rand() • 計算(アルゴリズム)によって次の乱数を決める • 規則がいっさい存在しない •
ノイズ,熱雑音などによって次の乱数を決める K8 疑似乱数 真の乱数
真の乱数 • サイコロ • /dev/random デバイスドライバなどから集めた環境ノイズを利用 • HW乱数生成装置 K9 統計数理研究所の乱数生成装置
真の乱数 K10 /dev/random(真の乱数) ※ [0:255]の範囲で整数乱数を生成し,(x,y,z)点を1000点作成
K11 真の乱数生成装置を作る
真の乱数生成装置を作る • Arduinoを利用 • analogRead()で開放端子から電圧を入力 • 一定間隔で計測した電圧デジタル値の1bitを合成 K12 開放 (繋がない)
真の乱数生成装置を作る K13 0x10000010 •2.34V 479 0x11011111 •2.28V 466 0x11010010 •2.21V
452 0x11000100 •2.09V 428 0x10101100 •1.95V 400 0x10010000 •1.82V 372 0x01110100 •1.68V 345 0x01011001 •1.56V 320 0x01000000 by Morn https://commons.wikimedia.org/wiki/User:Morn
Arduino電圧乱数 K14 メルセンヌ・ツイスタ(強い疑似乱数) /dev/random(真の乱数) Arduino電圧乱数
Arduino電圧乱数 • 精度が悪い理由(予想) • 電圧の振幅が小さい • ランダム性の無いノイズの可能性 • 生成スピードが遅い(125B/s) •
電圧計測間隔が短いと似通った値になった • それっぽい値になるように1msに1bit計測 K15
乱数の精度検定 • 検定内容 • 等確率性 • 無規則性 • 検定用のツールがある •
dieharderなど • https://webhome.phy.duke.edu/~rgb/General/ dieharder.php • なんかうまく検定評価できず挫折 orz K16
まとめ • 乱数の種類 • 疑似乱数と真の乱数 • よりよい精度には強い乱数 (メルセンヌ・ツイスタなど)を使おう • 真の乱数を手軽に使うには/dev/randomを使おう
• 精度は悪いが自作もできる K17
$ exit K18
K19 Appendix
Arduinoのコード K20