こんにちは、Habr! ZCashのブログ記事の翻訳を紹介します。この記事では、ZCash暗号通貨で使用されるゼロ開示証拠システムSNARKの動作メカニズムについて説明しています(これだけではありません)。
出所前の記事:
パート1:
SNARKの説明。 準同型隠蔽とブラインド多項式計算(翻訳)パート2:
SNARKの説明。 採用された係数の知識と信頼できる多項式のブラインド計算(翻訳)パート3:
SNARKの説明。 計算から多項式、Pinocchioプロトコルおよび楕円曲線のペアリング(翻訳)前の記事で、zk-SNARKのPinocchioプロトコルが検討されました。 検証に必要な加算と乗算の両方をサポートする準同型隠蔽(HS)、および対話型プロトコルから非対話型証拠システムへの移行をサポートする2つのことを分析します。
この記事では、楕円曲線を使用することで、乗算をサポートするHSの形式を、目的の目的には十分であるが取得できることを示します。 この限定された形式のHSは、プロトコルを必要な非対話型システムに変換するのにも十分であることを以下に示します。
まず、楕円曲線に導入し、必要なHSの形状を取得する方法を説明します。
楕円曲線とそのペアリング
pが3より大きい素数であり、
そのような
。 方程式を考えてください:
楕円曲線
Cは点の集合です
この方程式を満たします。 これらの曲線は、グループを構築する興味深い方法を提供します。 グループの要素はポイントになります。
曲線上にある、つまり、技術的な理由で必要であり、「無限遠点」と呼ばれることもあり、同一性の要素、つまりグループのゼロとして機能する特別な点
Oとともに方程式を満たします。
あなたは、「何に関するポイントのセット?」と尋ねるかもしれません。 代数的閉包の座標を持つ点の集合を意味します 。 さらに、曲線にはアフィン射影バージョンがあります。 射影バージョンを参照する場合、曲線の要素として「無限遠点」 Oも含めます。
ここでの問題は、2つのポイントを追加する方法です
サードを取得するには? 加算規則は
、曲線
除数クラスのグループと呼ばれる抽象的なオブジェクトから取得され
ます 。 私たちの目的のために、この除数クラスのグループについて知っておく必要があるのは、加算演算の定義に次の制限を課すことだけです:任意のライン上のポイントの合計はゼロでなければなりません。
O.この制限からどの追加規則が続くかを見てみましょう。 次の形式の方程式で定義される垂直線を見てください
。 この線が点で曲線と交差すると仮定します
。 曲線の方程式の形式は
もし
曲線上にある場合、ポイントがあります
。 さらに、これは垂直線であり、2次曲線の方程式は
Yであるため、これらが線と曲線が交差する唯一の点であることを確認できます。
方程式があります
つまり
このように
とは逆です
グループで。
ここで、最初の座標が一致しないポイント$ inlineP $ inlineおよび$ inlineQ $ inlineを分析しましょう。
、それらを積み重ねる方法を参照してください。
Pと
Qを通る線を引きます
。曲線は3次の
Xの多項式で定義され、すでにこの(垂直ではない)線と2点で交差しているため、3番目の点で線と交差することが保証されます。
、および他のポイントでラインを横断しません。
したがって、取得します
つまり
。 私たちはすでにそれを知っています
から得られた
2番目の座標を
で
。
したがって、グループの追加規則は次のとおりです。選択されたポイント
Pおよび
Qについて、それらを通る線を引き、線の3番目の交点の「鏡」点を取る必要があります。 これは加算の結果です。
P自体を追加する場合は考慮しませんでした。 これは、ポイントPで曲線に接する線を使用し、この線と曲線の2番目の交点としてRを取得することによって行われます。
このグループは通常と呼ばれます
座標が$ inlineC $ inline曲線上の点で構成されているため、
。 しかし、さらにそれを
。 便宜上、要素の数は
p以外の素数
rです。 これは、Zcashが使用する曲線など、多くのソリューションで使用されます。 この場合、任意のアイテム
Oとは異なります
。
rが除算する最小の整数
k 曲線
のネスト度と呼ばれます。
kが十分に大きい場合、たとえば少なくとも6である場合、離散対数問題は
、つまり 発見
そして
から
かなり複雑です。 (現在Zcashで使用されて
いるBNカーブでは、
)
乗法群
で示される次数
rのサブグループを含む
。 座標で曲線の点を見ることができます
だけでなく
。 同じ追加規則に従って、これらの点は
Oと一緒にグループを形成します。
。 に注意してください
明示的に含む
。 ほかに
追加のサブグループが含まれます
順序
r (実際、
順序
rの追加のサブグループ)。
ジェネレーターを修正します
。 Tate還元ペアリングと呼ばれる効果的なマップがあり、それが要素のペアを
そして
から要素へ
そのような
- ジェネレータξから
- 与えられた要素のペアに対して 行った
Tateの定義は、これらの記事の範囲をわずかに超えており、代数幾何学の概念、より多くの因子に依存しています。
実際、ZcashのペアリングではOptimal Ateペアリングが使用されます。これは、簡略化されたTateペアリングに基づいており、 Tateよりも効率的に計算できます。
のために
多項式
度でゼロの値を取ります
ポイント
aで、他のどこにもありません。 ポイントについて
、除数により、関数が存在することを証明できます
曲線から
、これは特定の正確な意味で
Pの次数
rがゼロで、他のどこにもありません。
次に定義される
。
この定義が示されたプロパティにどのように関連するかは完全には理解されていない場合があります。 実際には、
Tateがこれらのプロパティに関連付けられているという証拠は非常に複雑です。
定義する
$インライン$ E_1(x):= x⋅g、E_2(x):= x⋅h、E(x):= x⋅ξ$ inline $ 加算と乗算の両方をサポートするHSの弱いバージョンを取得します。
追加をサポートし、非表示を知るHS
計算できます
。 つまり、
xと
yの「正しい」非表示があれば、
xyの (他の)非表示を取得できます。 しかし、たとえば、
私たちは非表示にすることはできません
。
次に、非インタラクティブな証拠システムについて説明します。 「非インタラクティブ」の意味を説明することから始めましょう。
汎用リンクモデルの非インタラクティブな証拠
非対話型証拠の最も強力で最も直感的な定義は、おそらく次のとおりです。特定のステートメントを証明するために、証明者は事前のメッセージングなしですべての関係者に利用可能な単一のメッセージを送信し、このメッセージを読んだ人はステートメントの真実を確信します。 ほとんどの場合、これは実装できない可能性があります。
計算の複雑性の理論に関しては、 BPP複雑性クラスの言語のみが、非開示の非対話型証明を完全に実装していることを示すことができます。 Zcashトランザクションで証明する必要があるステートメントのタイプ、たとえば、「この行のハッシュのオリジナルを知っています」は、 NP複雑度クラスに対応し、これはBPPよりもはるかに大きいことがわかっています。
一般的な参照文字列-OSS(英語
CRSから)の概念を導入するために、非インタラクティブな証拠の定義を弱めます。 OSSモデルでは、証拠が構築される前に、特定のランダムプロセスに従って文字列が作成され、すべての関係者に送信されるインストールフェーズがあります。 この行はOSSと呼ばれ、証拠の作成と検証に使用されます。 OSSを作成するために使用されるランダムデータは、これらのデータの知識が誤った証拠の構築を可能にするため、どちらの側にも不明であると想定されます。
OSSモデルで
、信頼できるブラインド計算のプロトコルを非インタラクティブな証拠システムに変換する方法を見てみましょう。 このプロトコルはいくつかの同様のサブプロトコルで構成されているため、同様の方法で非対話型の証拠システムに変えることができます。
非インタラクティブな計算プロトコル
計算プロトコルの非インタラクティブバージョンは、最初に、ボブの最初のメッセージをOSSとして公開することにあります。 プロトコルの目的は準同型の非表示を取得することであることを思い出してください
多項式アリスの
ランダムに選択された
。
インストール :ランダムに選択
OSSによって公開されました。
。
証明 。 アリス計算
そして
OSSの要素を使用して、
そして
線形結合をサポートします。
チェック :受け入れています
のために
そして
ボブ計算
そして
、およびそれらの同等性をチェックします。 (それらが等しい場合、これはつまり
)
前のパートで示したように、アリスはそのようなもののみを作成できます
それがテストされます
隠れている
多項式の
彼女に知られている順序
d 。 ここでの主な違いは、ボブが知る必要がないことです
検証のために、ペアリング関数を使用して計算できるため
からのみ
そして
。 したがって、彼は最初のメッセージを自分で作成して送信する必要はなく、このメッセージはOSSで簡単に修正できます。
使用されている画像はこの記事から取られたものであり、Creative Commonsライセンスの下で使用されています。