type A1使用

本文介绍了type A1和type A曲线的区别,重点在于type A1的G1、G2、GT阶为合数N,由多个素数乘积构成。合数阶群存在一系列素数阶子群,这些子群之间正交,且双线性映射特性保持不变。同时,讨论了type A1在实际使用中的场景。
摘要由CSDN通过智能技术生成

区别

我们常使用type A,type A1两种曲线。type A是素数阶的,type A1与其很类似,但其 G 1 , G 2 , G T G_1,G_2,G_T G1,G2,GT的阶是合数 N N N. N N N是一系列素数的乘积 N = p 1 p 2 . . . p n N=p_1 p_2...p_n N=p1p2...pn.对双线性映射 e : G 1 × G 2 → G T e:G_1 \times G_2 \rightarrow G_T e:G1×G2GT同样满足双线性的性质。
合数阶群与素数阶群的区别在于,他有一系列子群:阶为 p i p_i pi的子群 G p i ( i ∈ { 1 , 2 , . . . , n } ) G_{p_i} (i \in \{1,2,...,n\}) Gpi(i{1,2,...,n}).对于不同的子群之间是正交的. e ( h i , g j ) = 1 ( h i ∈ G P i , g i ∈ G p j ) e(h_i,g_j)=1 (h_i \in G_{P_i} ,g_i \in G_{p_j}) e(hi,gj)=1(hiGPi,giGpj)

使用

	public static void main(String[] args) {
		// TODO Auto-generated method stub	
		int num=3;
		TypeA1CurveGenerator pg = new TypeA1CurveGenerator(num, 517);
		PairingParameters s=pg.generate();
		Pairing pairing=PairingFactory.getPairing(s);
		
		Field Zn=pairing.getZr();
		Field Gt=pairing.getGT();
		Element zn1=Zn.newRandomElement().getImmutable();
		Element gt1=Gt.newRandomElement().getImmutable();
		System.out.println("zn1:"+zn1.toString());
		System.out.println("gt:"+gt1.toString());
		Element generator=pairing.getG1().newRandomElement().getImmutable();
		//使用生成阶为pi的子群,生成随机元素 :
		Element Gp1=ElementUtils.getGenerator(pairing, generator, s, 0, num).getImmutable();
		System.out.println("Gp1:"+Gp1.toString());
		}
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

密码猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值