aboutsummaryrefslogtreecommitdiff
path: root/files/ja/glossary/rng/index.html
blob: b76c3aa1a5713163e817cb2b3ac335f65d2a409b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
---
title: Random Number Generator (乱数発生器)
slug: Glossary/RNG
tags:
  - CodingScripting
  - Glossary
translation_of: Glossary/RNG
---
<p><strong>PRNG</strong> (擬似乱数発生器) は、複雑で、予測できないように見えるパターンの数字を出力するためのアルゴリズムです。真の乱数 (放射性線源など) はまったく予測できないのに対し、すべてのアルゴリズムは予測可能なので、 PRNG は、開始パラメーターや<em>シード</em>が同じときには同じ数値を返します。</p>

<p>疑似乱数はゲームなど、様々な応用分野で使用されています。</p>

<p>暗号学的に安全な擬似乱数とは、暗号での使用に合うよう追加のプロパティを伴う擬似乱数であり、次のようなものがあります。</p>

<ul>
 <li>(シードを知らずに) 攻撃者が計算によって出力を予測することができないもの</li>
 <li>攻撃者がその現在の状態を解くことができた場合、攻撃者が以前に発行された数を解明することができないもの。</li>
</ul>

<p>多くの疑似乱数、は暗号学的に安全ではありません。</p>

<h2 id="Learn_more" name="Learn_more">関連情報</h2>

<h3 id="一般知識">一般知識</h3>

<ul>
 <li>Wikipedia の{{Interwiki("wikipedia", "Pseudorandom number generator")}}</li>
 <li>JavaScript の組み込み PRNG 関数である {{jsxref("Math.random()")}}。これは暗号学的に安全な PRNG ではありません。</li>
 <li>{{domxref("Crypto.getRandomValues()")}}: 暗号学的に安全な数値を提供するためのものです。</li>
</ul>

<section id="Quick_links">
<ul>
 <li>{{domxref("RandomSource")}}</li>
 <li>{{jsxref("Math.random()")}}</li>
 <li>{{domxref("Crypto.getRandomValues()")}}</li>
</ul>
</section>