BN128曲线
创始人
2024-03-27 18:35:54
0

1. 引言

BN系列椭圆曲线E(Fp):y2=x3+b,其中b≠0E(\mathbb{F}_p):y^2=x^3+b,其中b\neq 0E(Fp​):y2=x3+b,其中b​=0,由Paulo S. L. M. Barreto1 和 Michael Naehrig 在2005年论文 Pairing-Friendly Elliptic Curves of Prime Order中首次提出,在该论文中,提出了构建embedding degree为k=12k=12k=12的BN系列椭圆曲线的有效算法:

  • 基域:素数 p=36x4+36x3+24x2+6x+1p=36x^4+36x^3+24x^2+6x+1p=36x4+36x3+24x2+6x+1
  • scalar域:order (即椭圆曲线上的点的个数)n=36x4+36x3+18x2+6x+1n=36x^4+36x^3+18x^2+6x+1n=36x4+36x3+18x2+6x+1
  • trace:t=6x2+1t=6x^2+1t=6x2+1(trace of Frobenius)
  • n=p+1−tn=p+1-tn=p+1−t

以太坊的alt_bn128曲线,取:
x=4965661367192848881x=4965661367192848881x=4965661367192848881

从而有:

  • p=21888242871839275222246405745257275088696311157297823662689037894645226208583p=21888242871839275222246405745257275088696311157297823662689037894645226208583p=21888242871839275222246405745257275088696311157297823662689037894645226208583
  • n=21888242871839275222246405745257275088548364400416034343698204186575808495617n=21888242871839275222246405745257275088548364400416034343698204186575808495617n=21888242871839275222246405745257275088548364400416034343698204186575808495617
  • t=147946756881789318990833708069417712967t=147946756881789318990833708069417712967t=147946756881789318990833708069417712967

根据herumi/ate-pairing可知,相应的extension field为:

  • Fp2=Fp[u]/(u2+1)\mathbb{F}_{p^2}=\mathbb{F}_p[u]/(u^2+1)Fp2​=Fp​[u]/(u2+1),其中u2=1u^2=1u2=1
  • Fp6=Fp2[v]/(v3−ξ)\mathbb{F}_{p^6}=\mathbb{F}_{p^2}[v]/(v^3-\xi)Fp6​=Fp2​[v]/(v3−ξ),其中v3=ξ,ξ=u+9v^3=\xi,\xi=u+9v3=ξ,ξ=u+9
  • Fp12=Fp6[w]/(w2−v)\mathbb{F}_{p^{12}}=\mathbb{F}_{p^6}[w]/(w^2-v)Fp12​=Fp6​[w]/(w2−v),其中w2=vw^2=vw2=v

相应的sage脚本为:

# GF(p) p的質數體,x為generator
sage: P. = PolynomialRing(GF(p))
# 用GF(p) extension 建構Fp2,u為generator
sage: F2. = GF(p).extension(x^2 + 1)# Fp2的Polynomial ring P,t為generator
sage: P. = F2[]
# 用Fp2 extension 建構Fp6,v為generator
sage: F6. = F2.extension(t^3 - u-9)# 若可以則執行下列:
# Fp6的Polynomial Ring P,y為generator
sage: P. = F6[]
# 用Fp6 extension 建構Fp12,w為generator
sage: F12. = F6.extension(y^2 - v)

Pairing-Friendly Elliptic Curves of Prime Order论文中有:
在这里插入图片描述
以太坊黄皮书中与zkSNARK相关的预编译合约使用的是BN128曲线对:

  • 曲线C1(基于Fp\mathbb{F}_pFp​)为:
    在这里插入图片描述
  • 曲线C2(基于Fp2\mathbb{F}_{p^2}Fp2​)为:
    在这里插入图片描述

相应的sage脚本为:

# G1
sage: F1 = GF(21888242871839275222246405745257275088696311157297823662689037894645226208583)
sage: G1 = EllipticCurve(F1,[0,3])sage: P1 = G1(1,2)# G2
sage: F2 = GF(21888242871839275222246405745257275088696311157297823662689037894645226208583^2,"i",modulus=x^2 + 1)
sage: TwistB = 3*F2("9+i")^(-1)
sage: G2 = EllipticCurve(F2,[0,TwistB])sage: P2x = F2("11559732032986387107991004021392285783925812861821192530917403151452391805634*i + 10857046999023057135944570762232829481370756359578518086990519993285655852781")
sage: P2y = F2("4082367875863433681332203403145435568316851327593401208105741076214120093531*i + 8495653923123431417604973247489272438418190587263600148770280649306958101930")
sage: P2 = G2(P2x,P2y)

基于以上BN128曲线对 构建的pairing计算结果对应 Fp12\mathbb{F}_{p^{12}}Fp12​,即有:
在这里插入图片描述
以太坊EIP-197:Precompiled contracts for optimal ate pairing check on the elliptic curve alt_bn128,以太坊的预编译合约采用以上(公式253)来替代(公式254),从而验证pairing运算结果是否一致。

参考资料

[1] BN128曲线
[2] Paulo S. L. M. Barreto1 和 Michael Naehrig 2005年论文 Pairing-Friendly Elliptic Curves of Prime Order
[3] 以太坊黄皮书

相关内容

热门资讯

喜欢穿一身黑的男生性格(喜欢穿... 今天百科达人给各位分享喜欢穿一身黑的男生性格的知识,其中也会对喜欢穿一身黑衣服的男人人好相处吗进行解...
发春是什么意思(思春和发春是什... 本篇文章极速百科给大家谈谈发春是什么意思,以及思春和发春是什么意思对应的知识点,希望对各位有所帮助,...
网络用语zl是什么意思(zl是... 今天给各位分享网络用语zl是什么意思的知识,其中也会对zl是啥意思是什么网络用语进行解释,如果能碰巧...
为什么酷狗音乐自己唱的歌不能下... 本篇文章极速百科小编给大家谈谈为什么酷狗音乐自己唱的歌不能下载到本地?,以及为什么酷狗下载的歌曲不是...
家里可以做假山养金鱼吗(假山能... 今天百科达人给各位分享家里可以做假山养金鱼吗的知识,其中也会对假山能放鱼缸里吗进行解释,如果能碰巧解...
华为下载未安装的文件去哪找(华... 今天百科达人给各位分享华为下载未安装的文件去哪找的知识,其中也会对华为下载未安装的文件去哪找到进行解...
四分五裂是什么生肖什么动物(四... 本篇文章极速百科小编给大家谈谈四分五裂是什么生肖什么动物,以及四分五裂打一生肖是什么对应的知识点,希...
怎么往应用助手里添加应用(应用... 今天百科达人给各位分享怎么往应用助手里添加应用的知识,其中也会对应用助手怎么添加微信进行解释,如果能...
客厅放八骏马摆件可以吗(家里摆... 今天给各位分享客厅放八骏马摆件可以吗的知识,其中也会对家里摆八骏马摆件好吗进行解释,如果能碰巧解决你...
苏州离哪个飞机场近(苏州离哪个... 本篇文章极速百科小编给大家谈谈苏州离哪个飞机场近,以及苏州离哪个飞机场近点对应的知识点,希望对各位有...