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
160
乱数を作る
社内の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
52
Pkl/2024-04-17-llt31
ottijp
0
79
JavaScriptのデバッグ/2023-09-04-llt30
ottijp
0
150
CDK for TerraformでAzureリソースをデプロイする/2023-05-15-llt29
ottijp
1
260
TWELITEへの誘い/2022-12-27-llt28
ottijp
0
150
ビルドツールBazelを触ってみた/2022-09-28-llt27
ottijp
0
160
HashiCorp Vaultを使ったシークレットのセキュアな一元管理 〜Ansibleを添えて〜/2022-07-12-llt26
ottijp
0
140
AWSインフラのデプロイをCDKでカイゼンする/2022-03-23-llt25
ottijp
0
84
Amazon Timestreamでデータ補間/2021-12-27-llt24
ottijp
0
100
Other Decks in Science
See All in Science
白金鉱業Meetup Vol.16_【初学者向け発表】 数理最適化のはじめの一歩 〜身近な問題で学ぶ最適化の面白さ〜
brainpadpr
11
2.2k
Introd_Img_Process_2_Frequ
hachama
0
560
How To Buy, Verified Venmo Accounts in 2025 This year
usaallshop68
2
110
04_石井クンツ昌子_お茶の水女子大学理事_副学長_D_I社会実現へ向けて.pdf
sip3ristex
0
490
機械学習 - K近傍法 & 機械学習のお作法
trycycle
PRO
0
1.1k
Online Feedback Optimization
floriandoerfler
0
2.1k
academist Prize 4期生 研究トーク延長戦!「美は世界を救う」っていうけど、どうやって?
jimpe_hitsuwari
0
140
生成検索エンジン最適化に関する研究の紹介
ynakano
2
1k
Quelles valorisations des logiciels vers le monde socio-économique dans un contexte de Science Ouverte ?
bluehats
1
390
Lean4による汎化誤差評価の形式化
milano0017
0
160
CV_5_3dVision
hachama
0
140
データベース02: データベースの概念
trycycle
PRO
2
750
Featured
See All Featured
YesSQL, Process and Tooling at Scale
rocio
173
14k
Performance Is Good for Brains [We Love Speed 2024]
tammyeverts
10
920
A Tale of Four Properties
chriscoyier
160
23k
Making Projects Easy
brettharned
116
6.3k
Fantastic passwords and where to find them - at NoRuKo
philnash
51
3.3k
Optimising Largest Contentful Paint
csswizardry
37
3.3k
Code Review Best Practice
trishagee
68
18k
RailsConf 2023
tenderlove
30
1.1k
JavaScript: Past, Present, and Future - NDC Porto 2020
reverentgeek
48
5.4k
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
53
2.8k
Bootstrapping a Software Product
garrettdimon
PRO
307
110k
Intergalactic Javascript Robots from Outer Space
tanoku
271
27k
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