SlideShare una empresa de Scribd logo
1 de 76
Descargar para leer sin conexión
Mental Jinroを支える暗号技術
Tsukuba.pm #3
吉村 優
https://twitter.com/_yyu_
http://qiita.com/yyu
https://github.com/y-yu
May 14, 2016
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 1 / 21
自己紹介
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 2 / 21
自己紹介
筑波大学 情報科学類 学士
(COINS11)
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 2 / 21
自己紹介
筑波大学 情報科学類 学士
(COINS11)
WORD 編集部 OB
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 2 / 21
自己紹介
筑波大学 情報科学類 学士
(COINS11)
WORD 編集部 OB
プログラム論理研究室 OB
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 2 / 21
自己紹介
筑波大学 情報科学類 学士
(COINS11)
WORD 編集部 OB
プログラム論理研究室 OB
現在は Scala を書く仕事に従事
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 2 / 21
Mental Jinroとは?
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 3 / 21
Mental Jinroとは?
“
Mental Jinro は人狼からゲームマスターを排除したゲー
ムである
”
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 3 / 21
Mental Jinroとは?
“
Mental Jinro は人狼からゲームマスターを排除したゲー
ムである
”ゲームマスターとは何か?
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 3 / 21
Mental Jinroとは?
“
Mental Jinro は人狼からゲームマスターを排除したゲー
ムである
”ゲームマスターとは何か?
そもそも人狼とは何か?
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 3 / 21
人狼とは?
人狼 ∗
“
Wikipedia —— 汝は人狼なりや?
”∗人狼には様々なルールがあるが、このスライドではこのルールを用いる
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 4 / 21
人狼とは?
人狼 ∗
“ プレイヤーはそれぞれが村人と村人に化けた人狼と
なり、自分自身の正体がばれないように他のプレイ
ヤーと交渉して正体を探る
Wikipedia —— 汝は人狼なりや?
”∗人狼には様々なルールがあるが、このスライドではこのルールを用いる
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 4 / 21
人狼とは?
人狼 ∗
“ プレイヤーはそれぞれが村人と村人に化けた人狼と
なり、自分自身の正体がばれないように他のプレイ
ヤーと交渉して正体を探る
ゲームは半日単位で進行し、昼には全プレイヤーの
投票により決まった人狼容疑者の処刑が、夜には人
狼による村人の襲撃が行われる
Wikipedia —— 汝は人狼なりや?
”∗人狼には様々なルールがあるが、このスライドではこのルールを用いる
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 4 / 21
人狼とは?
人狼 ∗
“ プレイヤーはそれぞれが村人と村人に化けた人狼と
なり、自分自身の正体がばれないように他のプレイ
ヤーと交渉して正体を探る
ゲームは半日単位で進行し、昼には全プレイヤーの
投票により決まった人狼容疑者の処刑が、夜には人
狼による村人の襲撃が行われる
全ての人狼を処刑することができれば村人チームの
勝ち
Wikipedia —— 汝は人狼なりや?
”∗人狼には様々なルールがあるが、このスライドではこのルールを用いる
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 4 / 21
人狼とは?
人狼 ∗
“ プレイヤーはそれぞれが村人と村人に化けた人狼と
なり、自分自身の正体がばれないように他のプレイ
ヤーと交渉して正体を探る
ゲームは半日単位で進行し、昼には全プレイヤーの
投票により決まった人狼容疑者の処刑が、夜には人
狼による村人の襲撃が行われる
全ての人狼を処刑することができれば村人チームの
勝ち
人狼と同じ数まで村人を減らすことができれば人狼
チームの勝ち
Wikipedia —— 汝は人狼なりや?
”∗人狼には様々なルールがあるが、このスライドではこのルールを用いる
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 4 / 21
人狼の役職
人狼に必要な役職
参加者を次の役職に分ける必要がある
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 5 / 21
人狼の役職
人狼に必要な役職
参加者を次の役職に分ける必要がある
村人
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 5 / 21
人狼の役職
人狼に必要な役職
参加者を次の役職に分ける必要がある
村人
人狼
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 5 / 21
人狼の役職
人狼に必要な役職
参加者を次の役職に分ける必要がある
村人
人狼
ゲームマスター
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 5 / 21
人狼の役職
人狼に必要な役職
参加者を次の役職に分ける必要がある
村人
人狼
ゲームマスター
ゲームマスターとは何か?
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 5 / 21
ゲームマスターと公平性
ゲームマスターの役割
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 6 / 21
ゲームマスターと公平性
ゲームマスターの役割
人狼と村人のチーム分けをする
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 6 / 21
ゲームマスターと公平性
ゲームマスターの役割
人狼と村人のチーム分けをする
人狼に襲撃された村人を村人チームに宣告する
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 6 / 21
ゲームマスターと公平性
ゲームマスターの役割
人狼と村人のチーム分けをする
人狼に襲撃された村人を村人チームに宣告する
人狼と村人の数を管理し、どちらかのチームが勝利した時そ
れを宣言する
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 6 / 21
ゲームマスターと公平性
ゲームマスターの役割
人狼と村人のチーム分けをする
人狼に襲撃された村人を村人チームに宣告する
人狼と村人の数を管理し、どちらかのチームが勝利した時そ
れを宣言する
ゲームマスターとは審判
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 6 / 21
ゲームマスターと公平性
ゲームマスターの役割
人狼と村人のチーム分けをする
人狼に襲撃された村人を村人チームに宣告する
人狼と村人の数を管理し、どちらかのチームが勝利した時そ
れを宣言する
ゲームマスターとは審判
ゲームマスターが不公平だったら?
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 6 / 21
ゲームマスターと公平性
ゲームマスターの役割
人狼と村人のチーム分けをする
人狼に襲撃された村人を村人チームに宣告する
人狼と村人の数を管理し、どちらかのチームが勝利した時そ
れを宣言する
ゲームマスターとは審判
ゲームマスターが不公平だったら?
大問題!
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 6 / 21
Mental Jinro
ゲームマスターを消そう!
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 7 / 21
Mental Jinro
ゲームマスターを消そう!
ゲームマスターが消えると……
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 7 / 21
Mental Jinro
ゲームマスターを消そう!
ゲームマスターが消えると……
チーム分けはどうする?
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 7 / 21
Mental Jinro
ゲームマスターを消そう!
ゲームマスターが消えると……
チーム分けはどうする?
襲撃された村人の情報をどう伝える?
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 7 / 21
Mental Jinro
ゲームマスターを消そう!
ゲームマスターが消えると……
チーム分けはどうする?
襲撃された村人の情報をどう伝える?
勝敗は誰が判断する?
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 7 / 21
Mental Jinroを支える暗号技術
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 8 / 21
Mental Jinroを支える暗号技術
コミットメント
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 8 / 21
コイントスゲーム
アリスとボブの二人がいるとする
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 9 / 21
コイントスゲーム
アリスとボブの二人がいるとする
1 アリスがコインの “表” または “裏” を紙に書き、紙を封筒に
入れる
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 9 / 21
コイントスゲーム
アリスとボブの二人がいるとする
1 アリスがコインの “表” または “裏” を紙に書き、紙を封筒に
入れる
2 ボブはコインを投げる
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 9 / 21
コイントスゲーム
アリスとボブの二人がいるとする
1 アリスがコインの “表” または “裏” を紙に書き、紙を封筒に
入れる
2 ボブはコインを投げる
3 封筒から紙を取り出し、
アリスの予想とコインの結果が同じなら、アリスの勝利
アリスの予想とコインの結果が違えば、ボブの勝利
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 9 / 21
コイントスゲーム
アリスとボブの二人がいるとする
1 アリスがコインの “表” または “裏” を紙に書き、紙を封筒に
入れる
2 ボブはコインを投げる
3 封筒から紙を取り出し、
アリスの予想とコインの結果が同じなら、アリスの勝利
アリスの予想とコインの結果が違えば、ボブの勝利
4 このゲームは電話上で行う
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 9 / 21
コイントスゲーム
アリスとボブの二人がいるとする
1 アリスがコインの “表” または “裏” を紙に書き、紙を封筒に
入れる
2 ボブはコインを投げる
3 封筒から紙を取り出し、
アリスの予想とコインの結果が同じなら、アリスの勝利
アリスの予想とコインの結果が違えば、ボブの勝利
4 このゲームは電話上で行う
アリスが予想を反故にする?
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 9 / 21
コイントスゲーム
アリスとボブの二人がいるとする
1 アリスがコインの “表” または “裏” を紙に書き、紙を封筒に
入れる
2 ボブはコインを投げる
3 封筒から紙を取り出し、
アリスの予想とコインの結果が同じなら、アリスの勝利
アリスの予想とコインの結果が違えば、ボブの勝利
4 このゲームは電話上で行う
アリスが予想を反故にする?
封筒をどうやって実現する?
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 9 / 21
コイントスゲーム
プロトコル
†整数 x mod p かつ xy ≡ 1 (mod p) となる逆元 y が存在する x の集合で
ある
‡後述する
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 10 / 21
コイントスゲーム
プロトコル
1 ボブは p = 2q + 1 となる大きな素数 p, q をランダムに生成し
て、Z∗
p
† の位数 q の部分群 G から生成元 ‡g, v をランダムに選
択して p, q, g, v をアリスへ送信する
†整数 x mod p かつ xy ≡ 1 (mod p) となる逆元 y が存在する x の集合で
ある
‡後述する
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 10 / 21
コイントスゲーム
プロトコル
1 ボブは p = 2q + 1 となる大きな素数 p, q をランダムに生成し
て、Z∗
p
† の位数 q の部分群 G から生成元 ‡g, v をランダムに選
択して p, q, g, v をアリスへ送信する
2 アリスは p, q, g, v を検証し、表と予想するなら m := 1 を選択
し、裏と予想するなら m := q − 1 を選択し、乱数
r ∈ {1, . . . , q − 1} を用いて c := grvm mod p 計算し c をボブ
へ送信する
†整数 x mod p かつ xy ≡ 1 (mod p) となる逆元 y が存在する x の集合で
ある
‡後述する
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 10 / 21
コイントスゲーム
プロトコル
1 ボブは p = 2q + 1 となる大きな素数 p, q をランダムに生成し
て、Z∗
p
† の位数 q の部分群 G から生成元 ‡g, v をランダムに選
択して p, q, g, v をアリスへ送信する
2 アリスは p, q, g, v を検証し、表と予想するなら m := 1 を選択
し、裏と予想するなら m := q − 1 を選択し、乱数
r ∈ {1, . . . , q − 1} を用いて c := grvm mod p 計算し c をボブ
へ送信する
3 ボブはコイントスをして、結果をアリスへ送信する
†整数 x mod p かつ xy ≡ 1 (mod p) となる逆元 y が存在する x の集合で
ある
‡後述する
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 10 / 21
コイントスゲーム
プロトコル
1 ボブは p = 2q + 1 となる大きな素数 p, q をランダムに生成し
て、Z∗
p
† の位数 q の部分群 G から生成元 ‡g, v をランダムに選
択して p, q, g, v をアリスへ送信する
2 アリスは p, q, g, v を検証し、表と予想するなら m := 1 を選択
し、裏と予想するなら m := q − 1 を選択し、乱数
r ∈ {1, . . . , q − 1} を用いて c := grvm mod p 計算し c をボブ
へ送信する
3 ボブはコイントスをして、結果をアリスへ送信する
4 アリスは r, m を公開する
†整数 x mod p かつ xy ≡ 1 (mod p) となる逆元 y が存在する x の集合で
ある
‡後述する
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 10 / 21
コイントスゲーム
プロトコル
1 ボブは p = 2q + 1 となる大きな素数 p, q をランダムに生成し
て、Z∗
p
† の位数 q の部分群 G から生成元 ‡g, v をランダムに選
択して p, q, g, v をアリスへ送信する
2 アリスは p, q, g, v を検証し、表と予想するなら m := 1 を選択
し、裏と予想するなら m := q − 1 を選択し、乱数
r ∈ {1, . . . , q − 1} を用いて c := grvm mod p 計算し c をボブ
へ送信する
3 ボブはコイントスをして、結果をアリスへ送信する
4 アリスは r, m を公開する
5 ボブは c ≡ grvm (mod p) を検証する
†整数 x mod p かつ xy ≡ 1 (mod p) となる逆元 y が存在する x の集合で
ある
‡後述する
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 10 / 21
コイントスゲームの検証
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 11 / 21
コイントスゲームの検証
アリスが予想を反故にする?
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 11 / 21
コイントスゲームの検証
アリスが予想を反故にする?
アリスは m をコミットした後で、m (m = m) と偽れる
⇓ならば
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 11 / 21
コイントスゲームの検証
アリスが予想を反故にする?
アリスは m をコミットした後で、m (m = m) と偽れる
⇓ならば
アリスは grvm = gr vm となる r を計算できる
⇓ならば
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 11 / 21
コイントスゲームの検証
アリスが予想を反故にする?
アリスは m をコミットした後で、m (m = m) と偽れる
⇓ならば
アリスは grvm = gr vm となる r を計算できる
⇓ならば
アリスは g を何乗したら v となるかという離散対数が求められる
gr
vm
≡ gr
vm
(mod p)
vm−m
≡ gr −r
(mod p)
logg (vm−m
) ≡ r − r (mod q)
logg v ≡ (r − r)/(m − m ) (mod q)
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 11 / 21
離散対数問題
離散対数問題
“
次の条件を満す g, p, y(y = gx mod p) が与えられたとき、
x を求める問題のことである
クラウドを支えるこれからの暗号技術 [2]
”
§このような g のことを生成元と言い、生成元は全ての i = 1, . . . , q − 1 と
j = 1, . . . , q − 1 について、i = j ならば gi ≡ gj (mod p) となる
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 12 / 21
離散対数問題
離散対数問題
“
次の条件を満す g, p, y(y = gx mod p) が与えられたとき、
x を求める問題のことである
クラウドを支えるこれからの暗号技術 [2]
”g, p が次を満すとき、離散対数問題を解くことは困難
§このような g のことを生成元と言い、生成元は全ての i = 1, . . . , q − 1 と
j = 1, . . . , q − 1 について、i = j ならば gi ≡ gj (mod p) となる
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 12 / 21
離散対数問題
離散対数問題
“
次の条件を満す g, p, y(y = gx mod p) が与えられたとき、
x を求める問題のことである
クラウドを支えるこれからの暗号技術 [2]
”g, p が次を満すとき、離散対数問題を解くことは困難
p は巨大な素数
§このような g のことを生成元と言い、生成元は全ての i = 1, . . . , q − 1 と
j = 1, . . . , q − 1 について、i = j ならば gi ≡ gj (mod p) となる
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 12 / 21
離散対数問題
離散対数問題
“
次の条件を満す g, p, y(y = gx mod p) が与えられたとき、
x を求める問題のことである
クラウドを支えるこれからの暗号技術 [2]
”g, p が次を満すとき、離散対数問題を解くことは困難
p は巨大な素数
p − 1 の約数の中に、巨大な素数 q が含まれている
§このような g のことを生成元と言い、生成元は全ての i = 1, . . . , q − 1 と
j = 1, . . . , q − 1 について、i = j ならば gi ≡ gj (mod p) となる
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 12 / 21
離散対数問題
離散対数問題
“
次の条件を満す g, p, y(y = gx mod p) が与えられたとき、
x を求める問題のことである
クラウドを支えるこれからの暗号技術 [2]
”g, p が次を満すとき、離散対数問題を解くことは困難
p は巨大な素数
p − 1 の約数の中に、巨大な素数 q が含まれている
g は全ての i = 1, . . . , q − 1 について、gi ≡ 1 (mod p) となる §
§このような g のことを生成元と言い、生成元は全ての i = 1, . . . , q − 1 と
j = 1, . . . , q − 1 について、i = j ならば gi ≡ gj (mod p) となる
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 12 / 21
コイントスゲーム
プロトコル
1 ボブは p = 2q + 1 となる大きな素数 p, q をランダムに生成し
て、Z∗
p
† の位数 q の部分群 G から生成元 ‡g, v をランダムに選
択して p, q, g, v をアリスへ送信する
2 アリスは p, q, g, v を検証し、表と予想するなら m := 1 を選択
し、裏と予想するなら m := q − 1 を選択し、乱数
r ∈ {1, . . . , q − 1} を用いて c := grvm mod p 計算し c をボブ
へ送信する
3 ボブはコイントスをして、結果をアリスへ送信する
4 アリスは r, m を公開する
5 ボブは c ≡ grvm (mod p) を検証する
†整数 x mod p かつ xy ≡ 1 (mod p) となる逆元 y が存在する x の集合で
ある
‡後述する
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 13 / 21
コイントスゲームの検証
アリスが予想を反故にする?
アリスは m をコミットした後で、m (m = m) と偽れる
⇓ならば
アリスは grvm = gr vm となる r を計算できる
⇓ならば
アリスは g を何乗したら v となるかという離散対数が求められる
gr
vm
≡ gr
vm
(mod p)
vm−m
≡ gr −r
(mod p)
logg (vm−m
) ≡ r − r (mod q)
logg v ≡ (r − r)/(m − m ) (mod q)
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 14 / 21
コイントスゲームの検証
アリスは m をコミットした後で、m (m = m) と偽れる
⇓ならば
アリスは g を何乗したら v となるかという離散対数が求められる
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 15 / 21
コイントスゲームの検証
アリスは m をコミットした後で、m (m = m) と偽れる
⇓ならば
アリスは g を何乗したら v となるかという離散対数が求められる
離散対数問題を解くことは困難であるということに矛盾する
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 15 / 21
コイントスゲームの検証
アリスは m をコミットした後で、m (m = m) と偽れる
⇓ならば
アリスは g を何乗したら v となるかという離散対数が求められる
離散対数問題を解くことは困難であるということに矛盾する
アリスは m をコミットした後で m と偽ることは困難である
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 15 / 21
コイントスゲームの検証
封筒をどうやって実現する?
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 16 / 21
コイントスゲームの検証
封筒をどうやって実現する?
ボブは grvm から m を特定できる
↓しかし
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 16 / 21
コイントスゲームの検証
封筒をどうやって実現する?
ボブは grvm から m を特定できる
↓しかし
g, v は生成元である
⇓従って
gr mod p は 1, . . . , p − 1 の全ての値を取る
⇓つまり
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 16 / 21
コイントスゲームの検証
封筒をどうやって実現する?
ボブは grvm から m を特定できる
↓しかし
g, v は生成元である
⇓従って
gr mod p は 1, . . . , p − 1 の全ての値を取る
⇓つまり
全ての m には grvm = gr vm となる r が存在する
⇓つまり
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 16 / 21
コイントスゲームの検証
封筒をどうやって実現する?
ボブは grvm から m を特定できる
↓しかし
g, v は生成元である
⇓従って
gr mod p は 1, . . . , p − 1 の全ての値を取る
⇓つまり
全ての m には grvm = gr vm となる r が存在する
⇓つまり
ボブは正しい m を区別することができない
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 16 / 21
まとめ
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 17 / 21
まとめ
Mental Jinro はゲームマスターを排除した人狼である
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 17 / 21
まとめ
Mental Jinro はゲームマスターを排除した人狼である
コミットメントを利用することで、コミットした情報を反故
にしたり、コミットメントからコミットした情報を特定され
ることを防げる
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 17 / 21
まとめ
Mental Jinro はゲームマスターを排除した人狼である
コミットメントを利用することで、コミットした情報を反故
にしたり、コミットメントからコミットした情報を特定され
ることを防げる
Mental Jinro はこのコミットメントによって成り立っている
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 17 / 21
まとめ
Mental Jinro はゲームマスターを排除した人狼である
コミットメントを利用することで、コミットした情報を反故
にしたり、コミットメントからコミットした情報を特定され
ることを防げる
Mental Jinro はこのコミットメントによって成り立っている
Mental Jinro の詳細は Qiita の記事を参照のこと
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 17 / 21
目次
1 自己紹介
2 Mental Jinro とは?
人狼とは?
人狼の役職
ゲームマスターと公平性
Mental Jinro
3 コミットメント
コイントスゲーム
コイントスゲームの検証
離散対数問題
4 まとめ
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 18 / 21
参考文献
H. デルフス, H. クネーブル.
暗号と確率的アルゴリズム入門 — 数学理論と応用.
シュプリンガーフェアラーク東京, 12 2003.
光成滋生.
クラウドを支えるこれからの暗号技術.
秀和システム, 6 2015.
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 19 / 21
余談
このスライドは LuaLATEX と Beamer により作成され、Travis CI
による自動コンパイルが行われている
ソースコード
https://github.com/y-yu/mental-jinro-slide
PDF(アニメーションあり)
https://y-yu.github.io/mental-jinro-slide/
mental_jinro.pdf
PDF(アニメーションなし)
https://y-yu.github.io/mental-jinro-slide/
mental_jinro_without_animation.pdf
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 20 / 21
Thank you for listening!
Any question?
吉村 優 (https://twitter.com/_yyu_) Mental Jinro を支える暗号技術 May 14, 2016 21 / 21

Más contenido relacionado

Último

Último (12)

LoRaWANスマート距離検出センサー DS20L カタログ LiDARデバイス
LoRaWANスマート距離検出センサー  DS20L  カタログ  LiDARデバイスLoRaWANスマート距離検出センサー  DS20L  カタログ  LiDARデバイス
LoRaWANスマート距離検出センサー DS20L カタログ LiDARデバイス
 
論文紹介:Selective Structured State-Spaces for Long-Form Video Understanding
論文紹介:Selective Structured State-Spaces for Long-Form Video Understanding論文紹介:Selective Structured State-Spaces for Long-Form Video Understanding
論文紹介:Selective Structured State-Spaces for Long-Form Video Understanding
 
知識ゼロの営業マンでもできた!超速で初心者を脱する、悪魔的学習ステップ3選.pptx
知識ゼロの営業マンでもできた!超速で初心者を脱する、悪魔的学習ステップ3選.pptx知識ゼロの営業マンでもできた!超速で初心者を脱する、悪魔的学習ステップ3選.pptx
知識ゼロの営業マンでもできた!超速で初心者を脱する、悪魔的学習ステップ3選.pptx
 
論文紹介: The Surprising Effectiveness of PPO in Cooperative Multi-Agent Games
論文紹介: The Surprising Effectiveness of PPO in Cooperative Multi-Agent Games論文紹介: The Surprising Effectiveness of PPO in Cooperative Multi-Agent Games
論文紹介: The Surprising Effectiveness of PPO in Cooperative Multi-Agent Games
 
Amazon SES を勉強してみる その32024/04/26の勉強会で発表されたものです。
Amazon SES を勉強してみる その32024/04/26の勉強会で発表されたものです。Amazon SES を勉強してみる その32024/04/26の勉強会で発表されたものです。
Amazon SES を勉強してみる その32024/04/26の勉強会で発表されたものです。
 
LoRaWAN スマート距離検出デバイスDS20L日本語マニュアル
LoRaWAN スマート距離検出デバイスDS20L日本語マニュアルLoRaWAN スマート距離検出デバイスDS20L日本語マニュアル
LoRaWAN スマート距離検出デバイスDS20L日本語マニュアル
 
論文紹介:Video-GroundingDINO: Towards Open-Vocabulary Spatio-Temporal Video Groun...
論文紹介:Video-GroundingDINO: Towards Open-Vocabulary Spatio-Temporal Video Groun...論文紹介:Video-GroundingDINO: Towards Open-Vocabulary Spatio-Temporal Video Groun...
論文紹介:Video-GroundingDINO: Towards Open-Vocabulary Spatio-Temporal Video Groun...
 
NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)
NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)
NewSQLの可用性構成パターン(OCHaCafe Season 8 #4 発表資料)
 
新人研修 後半 2024/04/26の勉強会で発表されたものです。
新人研修 後半        2024/04/26の勉強会で発表されたものです。新人研修 後半        2024/04/26の勉強会で発表されたものです。
新人研修 後半 2024/04/26の勉強会で発表されたものです。
 
Utilizing Ballerina for Cloud Native Integrations
Utilizing Ballerina for Cloud Native IntegrationsUtilizing Ballerina for Cloud Native Integrations
Utilizing Ballerina for Cloud Native Integrations
 
Observabilityは従来型の監視と何が違うのか(キンドリルジャパン社内勉強会:2022年10月27日発表)
Observabilityは従来型の監視と何が違うのか(キンドリルジャパン社内勉強会:2022年10月27日発表)Observabilityは従来型の監視と何が違うのか(キンドリルジャパン社内勉強会:2022年10月27日発表)
Observabilityは従来型の監視と何が違うのか(キンドリルジャパン社内勉強会:2022年10月27日発表)
 
Amazon SES を勉強してみる その22024/04/26の勉強会で発表されたものです。
Amazon SES を勉強してみる その22024/04/26の勉強会で発表されたものです。Amazon SES を勉強してみる その22024/04/26の勉強会で発表されたものです。
Amazon SES を勉強してみる その22024/04/26の勉強会で発表されたものです。
 

Destacado

How Race, Age and Gender Shape Attitudes Towards Mental Health
How Race, Age and Gender Shape Attitudes Towards Mental HealthHow Race, Age and Gender Shape Attitudes Towards Mental Health
How Race, Age and Gender Shape Attitudes Towards Mental Health
ThinkNow
 
Social Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie InsightsSocial Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie Insights
Kurio // The Social Media Age(ncy)
 

Destacado (20)

2024 State of Marketing Report – by Hubspot
2024 State of Marketing Report – by Hubspot2024 State of Marketing Report – by Hubspot
2024 State of Marketing Report – by Hubspot
 
Everything You Need To Know About ChatGPT
Everything You Need To Know About ChatGPTEverything You Need To Know About ChatGPT
Everything You Need To Know About ChatGPT
 
Product Design Trends in 2024 | Teenage Engineerings
Product Design Trends in 2024 | Teenage EngineeringsProduct Design Trends in 2024 | Teenage Engineerings
Product Design Trends in 2024 | Teenage Engineerings
 
How Race, Age and Gender Shape Attitudes Towards Mental Health
How Race, Age and Gender Shape Attitudes Towards Mental HealthHow Race, Age and Gender Shape Attitudes Towards Mental Health
How Race, Age and Gender Shape Attitudes Towards Mental Health
 
AI Trends in Creative Operations 2024 by Artwork Flow.pdf
AI Trends in Creative Operations 2024 by Artwork Flow.pdfAI Trends in Creative Operations 2024 by Artwork Flow.pdf
AI Trends in Creative Operations 2024 by Artwork Flow.pdf
 
Skeleton Culture Code
Skeleton Culture CodeSkeleton Culture Code
Skeleton Culture Code
 
PEPSICO Presentation to CAGNY Conference Feb 2024
PEPSICO Presentation to CAGNY Conference Feb 2024PEPSICO Presentation to CAGNY Conference Feb 2024
PEPSICO Presentation to CAGNY Conference Feb 2024
 
Content Methodology: A Best Practices Report (Webinar)
Content Methodology: A Best Practices Report (Webinar)Content Methodology: A Best Practices Report (Webinar)
Content Methodology: A Best Practices Report (Webinar)
 
How to Prepare For a Successful Job Search for 2024
How to Prepare For a Successful Job Search for 2024How to Prepare For a Successful Job Search for 2024
How to Prepare For a Successful Job Search for 2024
 
Social Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie InsightsSocial Media Marketing Trends 2024 // The Global Indie Insights
Social Media Marketing Trends 2024 // The Global Indie Insights
 
Trends In Paid Search: Navigating The Digital Landscape In 2024
Trends In Paid Search: Navigating The Digital Landscape In 2024Trends In Paid Search: Navigating The Digital Landscape In 2024
Trends In Paid Search: Navigating The Digital Landscape In 2024
 
5 Public speaking tips from TED - Visualized summary
5 Public speaking tips from TED - Visualized summary5 Public speaking tips from TED - Visualized summary
5 Public speaking tips from TED - Visualized summary
 
ChatGPT and the Future of Work - Clark Boyd
ChatGPT and the Future of Work - Clark Boyd ChatGPT and the Future of Work - Clark Boyd
ChatGPT and the Future of Work - Clark Boyd
 
Getting into the tech field. what next
Getting into the tech field. what next Getting into the tech field. what next
Getting into the tech field. what next
 
Google's Just Not That Into You: Understanding Core Updates & Search Intent
Google's Just Not That Into You: Understanding Core Updates & Search IntentGoogle's Just Not That Into You: Understanding Core Updates & Search Intent
Google's Just Not That Into You: Understanding Core Updates & Search Intent
 
How to have difficult conversations
How to have difficult conversations How to have difficult conversations
How to have difficult conversations
 
Introduction to Data Science
Introduction to Data ScienceIntroduction to Data Science
Introduction to Data Science
 
Time Management & Productivity - Best Practices
Time Management & Productivity -  Best PracticesTime Management & Productivity -  Best Practices
Time Management & Productivity - Best Practices
 
The six step guide to practical project management
The six step guide to practical project managementThe six step guide to practical project management
The six step guide to practical project management
 
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
Beginners Guide to TikTok for Search - Rachel Pearson - We are Tilt __ Bright...
 

Mental Jinroを支える暗号技術