SNARKの説明。 採用された係数の知識と信頼できる多項式のブラインド計算(翻訳)

こんにちは、Habr! ZCashのブログ記事の翻訳を紹介します。この記事では、ZCash暗号通貨で使用されるゼロ開示証拠システムSNARKの動作メカニズムについて説明しています(これだけではありません)。

前の記事: SNARKの説明。 準同型隠蔽とブラインド多項式計算(翻訳)

この記事では、検証可能な多項式の受け入れられた係数とブラインド計算のテストを調べます。 行こう...

前の記事で、アリスが盲目的に皮を見つけ出す方法を見ました EPsその多項式Pは、ボブに属する点sで d次です。 アリスは計算中に値sを取得しないため、この「ブラインド」計算と呼びました。

ただし、このプロトコルには何かが欠けています。 アリスが計算できるという事実 EPs彼女が本当に送信することを保証しません EPsボブ、他の意味ではない。

したがって、プロトコルを正しく追跡するためにアリスを「取得」する方法が必要です。 この記事では、これを実現する方法について詳しく説明します。 まず、これに必要なメインツールの動作原理を検討して説明しましょう。 これを係数の知識(KC)テストと呼びます。

前と同様に、順序GのグループGの生成元をgで示します |G|=pここで、離散対数は困難なタスクです。 便宜上、この場所から始めて、乗法ではなく加法的にグループで作業します。 つまり、 $インライン$α∈F_p、α⋅g$インライン$ はαgのコピーを掛けたものを示します。

係数知識テスト


のために αFp、要素のペアを呼び出します abGαカップル ab0そして b=αa
Fp非ゼロ要素を示します Fp。 これはと同じです Zp前の記事で説明されています

テストは次のとおりです。

  1. ボブは乱数を選ぶ αFpと数 aG。 彼は計算する b=αa
  2. 彼はアリスにペアで「リクエスト」を送信します ab。 に注意してください abαペアです。
  3. アリスは別のペアでリクエストに応答するはずです ab。 また、αペアです。
  4. ボブは、次の場合にのみアリスの答えを受け入れます。 ab本当にαペアです(αを知っているので、 b=αa

それでは、アリスがいつ電話に出られるかを考えてみましょう。 彼女がαを知っているとします。 この場合、彼女は単にGから任意の 'を選択し、計算することができます b=αaそして、新しいαペアを返します ab

ただし、 αに関する情報のみが式に含まれているため αaまた、グループGには複雑な離散対数問題があり、アリスは見つけることができないと信じています α

それで、 αを知らずにどうやってクエリにうまく答えられるのでしょうか?

これを行う簡単な方法は次のとおりです。アリスはいくつかを選ぶだけです γFpそしてカップルに答えます $インライン$(a '、b')=(γ⋅a、γ⋅b)$インライン$

この場合、次のものがあります。

$ inline $ b '=γ⋅b =γα⋅a =α(γ⋅a)=α⋅a' $ inline $

このようにカップル ab必要に応じて、 αペアです。

アリスがこのオプションを使用して回答した場合、アリスとの比が等しいかどうか、つまりそのような係数を知っていることに注意してください γa=γa

採用された係数の知識(係数仮定の知識(KCA))は、これが常に当てはまると述べています。

ZPK:アリスが正しい答えを返す場合 abボブの要請で abその後、ボブの選択に関係なく、高い確率で a彼女はそのような係数を知っています γa=γa
文献では、伝統的に乗法群に使用されてきたため、これは通常「受け入れられた指数の知識」と呼ばれます

記事の次のパートでは、知識テストと合格率が重要なツールになります。

「アリスは知っている」とはどういう意味ですか?


特定の数式でZPKをどのように定式化できるのか疑問に思われるかもしれません。 特に、「アリスは知っている」という考えをどのように定式化するのでしょうか γ数学的定義では?

これは次のように行われます。Aliceに加えて、Alice Extractorと呼ばれるもう1つの側面があると言います。 アリスの抽出器は、アリスの内部状態にアクセスできます。

これで、ZPKを次のように定式化できます。Aliceが正常に応答するたびに α夫婦 abアリスエクストラクターが戻る γそのような a=γa

PPCの完全な正式な定義は、Extractorを「やや弱い」と定義し、代わりに、出力ではなく、Aliceの成功した応答の可能性を示しています。 γこの場合は重要ではありません

検証可能な多項式のブラインド計算を行う方法


さらに、以前の資料に基づいて、信頼性の高い多項式のブラインド計算のプロトコルを開発します。その定義を以下に示します。 以下のパート(および記事)では、このプロトコルを使用してSNARKを作成する方法を示します。

アリスが次数dの多項式Pを持ち、ボブが点を持っているとします sFp彼が偶然選んだ。 ボブに知らせるプロトコルを作成したい EPs、つまり Psで非表示にし、2つの追加プロパティを追加

  1. 機密性:アリスはsを認識せず、ボブはPを認識しません
  2. 信頼性:アリスが値を送信する可能性 EPsボブはそれを受け入れますが、彼女に知られている次数dの多項式Pについては無視できます。

これは、ブラインド多項式チェックテストと呼ばれます。 前の記事のプロトコルは、最初の段落のみを提供し、2番目の段落は提供しませんでした。 信頼性を得るには、採用された係数(ZPK)に関する知識の拡張バージョンが必要です。

有効性と機密性のプロパティは、アリスにsの値を見ずに使用する多項式Pを決定させるため、一緒に役立ちます。 ある意味では、これにより、アリスは「ポイントクエリ」を参照せずに「多項式で答える」必要があります。 このロジックはさらに明確になります。

完全な形式的証明では、いくつかのことをより微妙に説明しています。 たとえば、アリスは多項式Pを決定する前にsに関する情報を取得します たとえば、彼女は非表示になります s...sd

高度なZPK


上記で定義した形式のZPKは、次のように聞こえます。ボブがアリスに α夫婦 ab=αaそして、アリスは別のものを生成します α夫婦 ab、彼女はcの値を知っているので、 a=ca。 つまり、アリスはa 'aの関係を知ってます。

ここで、ボブが1つではなく、アリスに複数の α夫婦 a1b1...adbd(同じ α) そして今、再びこれらのペアを受け取ったアリスは、他のものを生成するはずです α-ペア ab。 彼女は意味を知らないが、アリスはこれをしなければならないことが重要です α

上記のように、アリスは作成できます α簡単な方法でカップル。 これを行うには、ペアのいずれかを取る aibiボブから取得し、両方の要素にいくつかを掛けます cFp。 もし aibiだった αカップル caicbiまたになります αカップル。 しかし、アリスは生成できます α-より多くの受信のためのペア αペア? そして、新しいを取得することは可能ですか α一度に複数の受信を使用するカップル αペア?

回答:はい。 たとえば、アリスは2つの値を選択できます c1c2Fpペアを計算します $インライン$(a '、b')=(c_1⋅a_1 +c_2⋅a_2、c_1⋅b_1 +c_2⋅b_2)$インライン$ 。 単純な変換は、 aゼロ以外、これも α-ペア:

$ inline $ b '=c_1⋅b_1 +c_2⋅b_2 =c_1α⋅a_1 +c_2α⋅a_2 =α(c_1⋅a_1 +c_2⋅a_2)=α⋅a' $ inline $

より一般的なケースでは、Aliceは結果のdペアの線形結合をとることができます。 これを行うには、いずれかを選択します c1...cdFpそして識別する ab=Σi=1dciaiΣi=1dcibi

アリスがこの戦略を使用して彼女を生成する場合、 α-ペア、彼女はいくつかの線形関係を知っているだろう aそして a1...ad。 つまり、彼女は知っている c1...cdそのような a=Σi=1dciai

拡張されたZPKは、実際、これがアリスが生成できる唯一の方法であると主張しています αカップル。 したがって、正常に生成されると、アリスは aそして a1...ad。 より正式には、 Gがジェネレーターgを持つサイズpのグループであり、記事の冒頭で追加的に説明されているとします。 Gで受け入れられる次数dの係数(d-ZPC)の知識は、次のように記述できます。

d-ZPK:ボブがランダムを選択したとします αFpそして sFp、およびアリスを送信します α-ペア $ inline $(g、α⋅g)、(s⋅g、αs⋅g)、...、(s ^d⋅g、αs^d⋅g)$ inline $ 。 アリスが別の質問に答えるとします α夫婦 ab。 次に、高い確率で、アリスは知っています c0...cdFpそのような Σi=0dcisig=a
D-KCA(d-ZPK)がJens Grott に掲載されました。

ことに注意してください dzpkボブはランダムセットを送信しません α-pair、ただし特定の「多項式構造」を持つセットを送信します。 この利点は、以下のプロトコルで確認できます。

信頼できるブラインド計算プロトコル


HS(準同型隠蔽)がマッピングであると仮定します Ex=xg上記のGからのジェネレータgについて。

簡単にするために、この特定のEのプロトコルを示します。

  1. ボブはランダムに選ぶ αFp、およびアリスに非表示を送信します gsg...sdg(のために 1s...sd)、および非表示 $ inline $α⋅g、αs⋅g、...、αs ^d⋅g $ inline $ (のために ααs...αsd
  2. アリス計算 a=Psgそして b=αPsg最初のステップで送信されたアイテムを使用して、それらをボブに送信します。
  3. ボブはそれをチェックします b=αa、この平等が成り立つ場合にのみ答えを受け入れます。

まず、得られた係数に注意してください PPsg線形結合です gsg...sdgそして αPsg、そして αPsgは線形結合です $ inline $α⋅g、αs⋅g、...、αs ^d⋅g $ inline $ 。 したがって、前の記事のプロトコルと同様に、アリスは、ボブのメッセージから、彼女が知っている多項式Pについてこれらの値を実際に計算できます。

次に、d-ZPCによると、Aliceが送信した場合 abそのような b=αa、ほぼ確実に彼女はそのようなことを知っています c0...cdFpあれ a=Σi=0dcisig。 この場合 a=Psg多項式の PX=Σi=0dciXi有名なアリス。 言い換えれば、ボブがステップ3で答えを受け入れ、アリスがそのような多項式Pを知らない確率は無視できます。

このすべてを要約し、d-ZPCを使用して、多項式の信頼できるブラインド計算のためのプロトコルを開発しました。 今後の記事では、このメカニズムがSNARKコンストラクトでどのように使用されるかについて説明します。

次の記事: SNARKの説明。 計算から多項式、ピノキオプロトコル、楕円曲線の共役(翻訳)まで

Source: https://habr.com/ru/post/J343468/


All Articles