/
ROM.go
59 lines (47 loc) · 4.3 KB
/
ROM.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
/*
* Copyright (c) 2012-2020 MIRACL UK Ltd.
*
* This file is part of MIRACL Core
* (see https://github.com/miracl/core).
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/* Fixed Data in ROM - Field and Curve parameters */
package BLS12383
// Base Bits= 58
var Modulus = [...]Chunk{0x2371D6485AAB0AB, 0x30FCA6299214AF6, 0x3801696124F47A8, 0xB3CD969446B0C6, 0x1FEA9284A0AD46, 0x12ADBAD681B6B71, 0x556556956}
var ROI = [...]Chunk{0x2371D6485AAB0AA, 0x30FCA6299214AF6, 0x3801696124F47A8, 0xB3CD969446B0C6, 0x1FEA9284A0AD46, 0x12ADBAD681B6B71, 0x556556956}
var R2modp = [...]Chunk{0x80B6E0116907F4, 0xCF53CF9752AC11, 0x35D47189941C581, 0x19D0835CB1E4D22, 0x16963E90A0FC49B, 0x367FB9DB3852312, 0x4DFECE397}
var SQRTm3 = [...]Chunk{0x34FB13BD7AAD4A8, 0x3EB766ED6919E77, 0x2693005C218EFDB, 0xF31154F6A061CA, 0x3EDE7FE641FFB44, 0x12ADBACE8076A30, 0x556556956}
const MConst Chunk = 0x1BC0571073435FD
var Fra = [...]Chunk{0x52D72D3311DAC1, 0x24D203F99DCF806, 0x344AE550D8C8A36, 0x348FEE86A1A0959, 0x2C11B52F10E4C6C, 0x9FDA2F0CE2E7F0, 0x22ACD5BF0}
var Frb = [...]Chunk{0x1E446375298D5EA, 0xC2AA22FF4452F0, 0x3B684104C2BD72, 0x16ACEAE2A2CA76D, 0x15ECF3F939260D9, 0x8B017E5B388380, 0x32B880D66}
const CURVE_Cof_I int = 0
var CURVE_Cof = [...]Chunk{0x80000010011FF, 0x40, 0x0, 0x0, 0x0, 0x0, 0x0}
//var CURVE_Cof = [...]Chunk{0x150556155169EAB, 0x2AAB0002AAEFFED, 0x555, 0x0, 0x0, 0x0, 0x0}
const CURVE_B_I int = 15
var CURVE_B = [...]Chunk{0xF, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}
var CURVE_Order = [...]Chunk{0x32099EBFEBC0001, 0x17C25684834E5CE, 0x1C81698B381DE0, 0x2003002E0270110, 0x1002001, 0x0, 0x0}
var CURVE_Gx = [...]Chunk{0xC4773908734573, 0x176FC20FD1DC11E, 0x3AD84AF1E3445C5, 0x1DAC207D0B0BE1E, 0x52DDB050F31D9F, 0x25E7B3938E0D7D0, 0x41FCBA55B}
var CURVE_Gy = [...]Chunk{0x12D165E8003F224, 0x1F527B21FE63F48, 0xA94ADEB4D2DDE5, 0x319AED912441D4C, 0x1C31C46D99D0DAD, 0x133ECC00092BA73, 0x68F16727}
var CURVE_HTPC = [...]Chunk{0x1, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}
var CURVE_Bnx = [...]Chunk{0x8000001001200, 0x40, 0x0, 0x0, 0x0, 0x0, 0x0}
var CRu = [...]Chunk{0xC367502EAAC2A9, 0x17DA068B7D974B7, 0x2F4A34DEA341BC2, 0xD36F75C5738948, 0x6E94874605445, 0x12ADBAD28116AD1, 0x556556956}
var CURVE_Pxa = [...]Chunk{0x3CB3B62D7F2D86, 0x3F6AD9E57474F85, 0x1C90F562572EE81, 0x3214B55C96F51FC, 0x27CB1E746432501, 0x1FB00FA301E6425, 0x634D2240}
var CURVE_Pxb = [...]Chunk{0x3D9E41EC452DE15, 0x12ACA355FF9837B, 0xBA88E92D5D75B5, 0x3B6741732277F66, 0x3288361DD24F498, 0x592EBCDE9DC5, 0x300D78006}
var CURVE_Pya = [...]Chunk{0x68F0BB9408CB41, 0x27B793C83586597, 0x3ACA913A2E75B4, 0x359CF266CF9A25E, 0x33FE6347B6E990E, 0x34894D1F2527615, 0x33792CF93}
var CURVE_Pyb = [...]Chunk{0x2D846437F479093, 0x10F2C379889218E, 0x32F449F7BC98B01, 0x111ACFBEA3DEBC2, 0x3D15A7AE001CE0D, 0xB3631AC93B9EE9, 0x20E5247DD}
//var CURVE_W = [2][7]Chunk{{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, {0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}}
//var CURVE_SB = [2][2][7]Chunk{{{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, {0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}}, {{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, {0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}}}
//var CURVE_WB = [4][7]Chunk{{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, {0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, {0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, {0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}}
//var CURVE_BB = [4][4][7]Chunk{{{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, {0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, {0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, {0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}}, {{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, {0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, {0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, {0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}}, {{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, {0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, {0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, {0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}}, {{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, {0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, {0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}, {0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}}}