一. 对于双线性对的hash函数:
对于群的hash函数:
二. 做运算的时候要注意一下几点:
- Java的运算结果都是产生一个新的Element来存储,所以我们需要把运算结果赋值给一个新的Element;
- Java在进行相关运算时,参与运算的Element值可能会改变。所以,如果需要在运算过程中保留参与运算的Element值,在存储的时候一定要调用getImmutable(),具体方法见代码中的初始化相关参数部分。
- 其实为了保险起见,防止Element在运算的过程中修改了Element原本的数值,可以使用Element.duplicate()方法。这个方法将返回一个与Element数值完全一样的Element,但是是个新的Element对象。举例来说,如果做G1×G1的运算,可以写成:
Element G_1_m_G_1 = G_1.duplicate().mul(G_1_p.duplicate());
4.G和G其实也是可以进行幂指数运算的,即GG,调用的函数为Element e1.pow(Element e2)。特别注意,我们再写G群的Z次方运算时,用的函数为powZn(),而不是pow(),这个调用错误很容易使得程序