{"version":3,"file":"static/chunks/7488.9a6cdaa927cf8eec.js","mappings":"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","sources":["webpack://_N_E/../../node_modules/bn.js/lib/bn.js","webpack://_N_E/../../node_modules/safe-buffer/index.js","webpack://_N_E/../../node_modules/superstruct/dist/index.mjs"],"sourcesContent":["(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert (val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits (ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN (number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n\n BN.BN = BN;\n BN.wordSize = 26;\n\n var Buffer;\n try {\n if (typeof window !== 'undefined' && typeof window.Buffer !== 'undefined') {\n Buffer = window.Buffer;\n } else {\n Buffer = require('buffer').Buffer;\n }\n } catch (e) {\n }\n\n BN.isBN = function isBN (num) {\n if (num instanceof BN) {\n return true;\n }\n\n return num !== null && typeof num === 'object' &&\n num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n };\n\n BN.max = function max (left, right) {\n if (left.cmp(right) > 0) return left;\n return right;\n };\n\n BN.min = function min (left, right) {\n if (left.cmp(right) < 0) return left;\n return right;\n };\n\n BN.prototype._init = function init (number, base, endian) {\n if (typeof number === 'number') {\n return this._initNumber(number, base, endian);\n }\n\n if (typeof number === 'object') {\n return this._initArray(number, base, endian);\n }\n\n if (base === 'hex') {\n base = 16;\n }\n assert(base === (base | 0) && base >= 2 && base <= 36);\n\n number = number.toString().replace(/\\s+/g, '');\n var start = 0;\n if (number[0] === '-') {\n start++;\n this.negative = 1;\n }\n\n if (start < number.length) {\n if (base === 16) {\n this._parseHex(number, start, endian);\n } else {\n this._parseBase(number, base, start);\n if (endian === 'le') {\n this._initArray(this.toArray(), base, endian);\n }\n }\n }\n };\n\n BN.prototype._initNumber = function _initNumber (number, base, endian) {\n if (number < 0) {\n this.negative = 1;\n number = -number;\n }\n if (number < 0x4000000) {\n this.words = [number & 0x3ffffff];\n this.length = 1;\n } else if (number < 0x10000000000000) {\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff\n ];\n this.length = 2;\n } else {\n assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff,\n 1\n ];\n this.length = 3;\n }\n\n if (endian !== 'le') return;\n\n // Reverse the bytes\n this._initArray(this.toArray(), base, endian);\n };\n\n BN.prototype._initArray = function _initArray (number, base, endian) {\n // Perhaps a Uint8Array\n assert(typeof number.length === 'number');\n if (number.length <= 0) {\n this.words = [0];\n this.length = 1;\n return this;\n }\n\n this.length = Math.ceil(number.length / 3);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n var j, w;\n var off = 0;\n if (endian === 'be') {\n for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n w = number[i] | (number[i - 1] << 8) | (number[i - 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n } else if (endian === 'le') {\n for (i = 0, j = 0; i < number.length; i += 3) {\n w = number[i] | (number[i + 1] << 8) | (number[i + 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n }\n return this._strip();\n };\n\n function parseHex4Bits (string, index) {\n var c = string.charCodeAt(index);\n // '0' - '9'\n if (c >= 48 && c <= 57) {\n return c - 48;\n // 'A' - 'F'\n } else if (c >= 65 && c <= 70) {\n return c - 55;\n // 'a' - 'f'\n } else if (c >= 97 && c <= 102) {\n return c - 87;\n } else {\n assert(false, 'Invalid character in ' + string);\n }\n }\n\n function parseHexByte (string, lowerBound, index) {\n var r = parseHex4Bits(string, index);\n if (index - 1 >= lowerBound) {\n r |= parseHex4Bits(string, index - 1) << 4;\n }\n return r;\n }\n\n BN.prototype._parseHex = function _parseHex (number, start, endian) {\n // Create possibly bigger array to ensure that it fits the number\n this.length = Math.ceil((number.length - start) / 6);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n // 24-bits chunks\n var off = 0;\n var j = 0;\n\n var w;\n if (endian === 'be') {\n for (i = number.length - 1; i >= start; i -= 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n } else {\n var parseLength = number.length - start;\n for (i = parseLength % 2 === 0 ? start + 1 : start; i < number.length; i += 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n }\n\n this._strip();\n };\n\n function parseBase (str, start, end, mul) {\n var r = 0;\n var b = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n\n r *= mul;\n\n // 'a'\n if (c >= 49) {\n b = c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n b = c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n b = c;\n }\n assert(c >= 0 && b < mul, 'Invalid character');\n r += b;\n }\n return r;\n }\n\n BN.prototype._parseBase = function _parseBase (number, base, start) {\n // Initialize as zero\n this.words = [0];\n this.length = 1;\n\n // Find length of limb in base\n for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n limbLen++;\n }\n limbLen--;\n limbPow = (limbPow / base) | 0;\n\n var total = number.length - start;\n var mod = total % limbLen;\n var end = Math.min(total, total - mod) + start;\n\n var word = 0;\n for (var i = start; i < end; i += limbLen) {\n word = parseBase(number, i, i + limbLen, base);\n\n this.imuln(limbPow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n if (mod !== 0) {\n var pow = 1;\n word = parseBase(number, i, number.length, base);\n\n for (i = 0; i < mod; i++) {\n pow *= base;\n }\n\n this.imuln(pow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n this._strip();\n };\n\n BN.prototype.copy = function copy (dest) {\n dest.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n dest.words[i] = this.words[i];\n }\n dest.length = this.length;\n dest.negative = this.negative;\n dest.red = this.red;\n };\n\n function move (dest, src) {\n dest.words = src.words;\n dest.length = src.length;\n dest.negative = src.negative;\n dest.red = src.red;\n }\n\n BN.prototype._move = function _move (dest) {\n move(dest, this);\n };\n\n BN.prototype.clone = function clone () {\n var r = new BN(null);\n this.copy(r);\n return r;\n };\n\n BN.prototype._expand = function _expand (size) {\n while (this.length < size) {\n this.words[this.length++] = 0;\n }\n return this;\n };\n\n // Remove leading `0` from `this`\n BN.prototype._strip = function strip () {\n while (this.length > 1 && this.words[this.length - 1] === 0) {\n this.length--;\n }\n return this._normSign();\n };\n\n BN.prototype._normSign = function _normSign () {\n // -0 = 0\n if (this.length === 1 && this.words[0] === 0) {\n this.negative = 0;\n }\n return this;\n };\n\n // Check Symbol.for because not everywhere where Symbol defined\n // See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Symbol#Browser_compatibility\n if (typeof Symbol !== 'undefined' && typeof Symbol.for === 'function') {\n try {\n BN.prototype[Symbol.for('nodejs.util.inspect.custom')] = inspect;\n } catch (e) {\n BN.prototype.inspect = inspect;\n }\n } else {\n BN.prototype.inspect = inspect;\n }\n\n function inspect () {\n return (this.red ? '';\n }\n\n /*\n\n var zeros = [];\n var groupSizes = [];\n var groupBases = [];\n\n var s = '';\n var i = -1;\n while (++i < BN.wordSize) {\n zeros[i] = s;\n s += '0';\n }\n groupSizes[0] = 0;\n groupSizes[1] = 0;\n groupBases[0] = 0;\n groupBases[1] = 0;\n var base = 2 - 1;\n while (++base < 36 + 1) {\n var groupSize = 0;\n var groupBase = 1;\n while (groupBase < (1 << BN.wordSize) / base) {\n groupBase *= base;\n groupSize += 1;\n }\n groupSizes[base] = groupSize;\n groupBases[base] = groupBase;\n }\n\n */\n\n var zeros = [\n '',\n '0',\n '00',\n '000',\n '0000',\n '00000',\n '000000',\n '0000000',\n '00000000',\n '000000000',\n '0000000000',\n '00000000000',\n '000000000000',\n '0000000000000',\n '00000000000000',\n '000000000000000',\n '0000000000000000',\n '00000000000000000',\n '000000000000000000',\n '0000000000000000000',\n '00000000000000000000',\n '000000000000000000000',\n '0000000000000000000000',\n '00000000000000000000000',\n '000000000000000000000000',\n '0000000000000000000000000'\n ];\n\n var groupSizes = [\n 0, 0,\n 25, 16, 12, 11, 10, 9, 8,\n 8, 7, 7, 7, 7, 6, 6,\n 6, 6, 6, 6, 6, 5, 5,\n 5, 5, 5, 5, 5, 5, 5,\n 5, 5, 5, 5, 5, 5, 5\n ];\n\n var groupBases = [\n 0, 0,\n 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216,\n 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625,\n 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632,\n 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149,\n 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176\n ];\n\n BN.prototype.toString = function toString (base, padding) {\n base = base || 10;\n padding = padding | 0 || 1;\n\n var out;\n if (base === 16 || base === 'hex') {\n out = '';\n var off = 0;\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = this.words[i];\n var word = (((w << off) | carry) & 0xffffff).toString(16);\n carry = (w >>> (24 - off)) & 0xffffff;\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\n }\n if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n }\n if (carry !== 0) {\n out = carry.toString(16) + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n if (base === (base | 0) && base >= 2 && base <= 36) {\n // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n var groupSize = groupSizes[base];\n // var groupBase = Math.pow(base, groupSize);\n var groupBase = groupBases[base];\n out = '';\n var c = this.clone();\n c.negative = 0;\n while (!c.isZero()) {\n var r = c.modrn(groupBase).toString(base);\n c = c.idivn(groupBase);\n\n if (!c.isZero()) {\n out = zeros[groupSize - r.length] + r + out;\n } else {\n out = r + out;\n }\n }\n if (this.isZero()) {\n out = '0' + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n assert(false, 'Base should be between 2 and 36');\n };\n\n BN.prototype.toNumber = function toNumber () {\n var ret = this.words[0];\n if (this.length === 2) {\n ret += this.words[1] * 0x4000000;\n } else if (this.length === 3 && this.words[2] === 0x01) {\n // NOTE: at this stage it is known that the top bit is set\n ret += 0x10000000000000 + (this.words[1] * 0x4000000);\n } else if (this.length > 2) {\n assert(false, 'Number can only safely store up to 53 bits');\n }\n return (this.negative !== 0) ? -ret : ret;\n };\n\n BN.prototype.toJSON = function toJSON () {\n return this.toString(16, 2);\n };\n\n if (Buffer) {\n BN.prototype.toBuffer = function toBuffer (endian, length) {\n return this.toArrayLike(Buffer, endian, length);\n };\n }\n\n BN.prototype.toArray = function toArray (endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n\n var allocate = function allocate (ArrayType, size) {\n if (ArrayType.allocUnsafe) {\n return ArrayType.allocUnsafe(size);\n }\n return new ArrayType(size);\n };\n\n BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) {\n this._strip();\n\n var byteLength = this.byteLength();\n var reqLength = length || Math.max(1, byteLength);\n assert(byteLength <= reqLength, 'byte array longer than desired length');\n assert(reqLength > 0, 'Requested array length <= 0');\n\n var res = allocate(ArrayType, reqLength);\n var postfix = endian === 'le' ? 'LE' : 'BE';\n this['_toArrayLike' + postfix](res, byteLength);\n return res;\n };\n\n BN.prototype._toArrayLikeLE = function _toArrayLikeLE (res, byteLength) {\n var position = 0;\n var carry = 0;\n\n for (var i = 0, shift = 0; i < this.length; i++) {\n var word = (this.words[i] << shift) | carry;\n\n res[position++] = word & 0xff;\n if (position < res.length) {\n res[position++] = (word >> 8) & 0xff;\n }\n if (position < res.length) {\n res[position++] = (word >> 16) & 0xff;\n }\n\n if (shift === 6) {\n if (position < res.length) {\n res[position++] = (word >> 24) & 0xff;\n }\n carry = 0;\n shift = 0;\n } else {\n carry = word >>> 24;\n shift += 2;\n }\n }\n\n if (position < res.length) {\n res[position++] = carry;\n\n while (position < res.length) {\n res[position++] = 0;\n }\n }\n };\n\n BN.prototype._toArrayLikeBE = function _toArrayLikeBE (res, byteLength) {\n var position = res.length - 1;\n var carry = 0;\n\n for (var i = 0, shift = 0; i < this.length; i++) {\n var word = (this.words[i] << shift) | carry;\n\n res[position--] = word & 0xff;\n if (position >= 0) {\n res[position--] = (word >> 8) & 0xff;\n }\n if (position >= 0) {\n res[position--] = (word >> 16) & 0xff;\n }\n\n if (shift === 6) {\n if (position >= 0) {\n res[position--] = (word >> 24) & 0xff;\n }\n carry = 0;\n shift = 0;\n } else {\n carry = word >>> 24;\n shift += 2;\n }\n }\n\n if (position >= 0) {\n res[position--] = carry;\n\n while (position >= 0) {\n res[position--] = 0;\n }\n }\n };\n\n if (Math.clz32) {\n BN.prototype._countBits = function _countBits (w) {\n return 32 - Math.clz32(w);\n };\n } else {\n BN.prototype._countBits = function _countBits (w) {\n var t = w;\n var r = 0;\n if (t >= 0x1000) {\n r += 13;\n t >>>= 13;\n }\n if (t >= 0x40) {\n r += 7;\n t >>>= 7;\n }\n if (t >= 0x8) {\n r += 4;\n t >>>= 4;\n }\n if (t >= 0x02) {\n r += 2;\n t >>>= 2;\n }\n return r + t;\n };\n }\n\n BN.prototype._zeroBits = function _zeroBits (w) {\n // Short-cut\n if (w === 0) return 26;\n\n var t = w;\n var r = 0;\n if ((t & 0x1fff) === 0) {\n r += 13;\n t >>>= 13;\n }\n if ((t & 0x7f) === 0) {\n r += 7;\n t >>>= 7;\n }\n if ((t & 0xf) === 0) {\n r += 4;\n t >>>= 4;\n }\n if ((t & 0x3) === 0) {\n r += 2;\n t >>>= 2;\n }\n if ((t & 0x1) === 0) {\n r++;\n }\n return r;\n };\n\n // Return number of used bits in a BN\n BN.prototype.bitLength = function bitLength () {\n var w = this.words[this.length - 1];\n var hi = this._countBits(w);\n return (this.length - 1) * 26 + hi;\n };\n\n function toBitArray (num) {\n var w = new Array(num.bitLength());\n\n for (var bit = 0; bit < w.length; bit++) {\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n w[bit] = (num.words[off] >>> wbit) & 0x01;\n }\n\n return w;\n }\n\n // Number of trailing zero bits\n BN.prototype.zeroBits = function zeroBits () {\n if (this.isZero()) return 0;\n\n var r = 0;\n for (var i = 0; i < this.length; i++) {\n var b = this._zeroBits(this.words[i]);\n r += b;\n if (b !== 26) break;\n }\n return r;\n };\n\n BN.prototype.byteLength = function byteLength () {\n return Math.ceil(this.bitLength() / 8);\n };\n\n BN.prototype.toTwos = function toTwos (width) {\n if (this.negative !== 0) {\n return this.abs().inotn(width).iaddn(1);\n }\n return this.clone();\n };\n\n BN.prototype.fromTwos = function fromTwos (width) {\n if (this.testn(width - 1)) {\n return this.notn(width).iaddn(1).ineg();\n }\n return this.clone();\n };\n\n BN.prototype.isNeg = function isNeg () {\n return this.negative !== 0;\n };\n\n // Return negative clone of `this`\n BN.prototype.neg = function neg () {\n return this.clone().ineg();\n };\n\n BN.prototype.ineg = function ineg () {\n if (!this.isZero()) {\n this.negative ^= 1;\n }\n\n return this;\n };\n\n // Or `num` with `this` in-place\n BN.prototype.iuor = function iuor (num) {\n while (this.length < num.length) {\n this.words[this.length++] = 0;\n }\n\n for (var i = 0; i < num.length; i++) {\n this.words[i] = this.words[i] | num.words[i];\n }\n\n return this._strip();\n };\n\n BN.prototype.ior = function ior (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuor(num);\n };\n\n // Or `num` with `this`\n BN.prototype.or = function or (num) {\n if (this.length > num.length) return this.clone().ior(num);\n return num.clone().ior(this);\n };\n\n BN.prototype.uor = function uor (num) {\n if (this.length > num.length) return this.clone().iuor(num);\n return num.clone().iuor(this);\n };\n\n // And `num` with `this` in-place\n BN.prototype.iuand = function iuand (num) {\n // b = min-length(num, this)\n var b;\n if (this.length > num.length) {\n b = num;\n } else {\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = this.words[i] & num.words[i];\n }\n\n this.length = b.length;\n\n return this._strip();\n };\n\n BN.prototype.iand = function iand (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuand(num);\n };\n\n // And `num` with `this`\n BN.prototype.and = function and (num) {\n if (this.length > num.length) return this.clone().iand(num);\n return num.clone().iand(this);\n };\n\n BN.prototype.uand = function uand (num) {\n if (this.length > num.length) return this.clone().iuand(num);\n return num.clone().iuand(this);\n };\n\n // Xor `num` with `this` in-place\n BN.prototype.iuxor = function iuxor (num) {\n // a.length > b.length\n var a;\n var b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = a.words[i] ^ b.words[i];\n }\n\n if (this !== a) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = a.length;\n\n return this._strip();\n };\n\n BN.prototype.ixor = function ixor (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuxor(num);\n };\n\n // Xor `num` with `this`\n BN.prototype.xor = function xor (num) {\n if (this.length > num.length) return this.clone().ixor(num);\n return num.clone().ixor(this);\n };\n\n BN.prototype.uxor = function uxor (num) {\n if (this.length > num.length) return this.clone().iuxor(num);\n return num.clone().iuxor(this);\n };\n\n // Not ``this`` with ``width`` bitwidth\n BN.prototype.inotn = function inotn (width) {\n assert(typeof width === 'number' && width >= 0);\n\n var bytesNeeded = Math.ceil(width / 26) | 0;\n var bitsLeft = width % 26;\n\n // Extend the buffer with leading zeroes\n this._expand(bytesNeeded);\n\n if (bitsLeft > 0) {\n bytesNeeded--;\n }\n\n // Handle complete words\n for (var i = 0; i < bytesNeeded; i++) {\n this.words[i] = ~this.words[i] & 0x3ffffff;\n }\n\n // Handle the residue\n if (bitsLeft > 0) {\n this.words[i] = ~this.words[i] & (0x3ffffff >> (26 - bitsLeft));\n }\n\n // And remove leading zeroes\n return this._strip();\n };\n\n BN.prototype.notn = function notn (width) {\n return this.clone().inotn(width);\n };\n\n // Set `bit` of `this`\n BN.prototype.setn = function setn (bit, val) {\n assert(typeof bit === 'number' && bit >= 0);\n\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n this._expand(off + 1);\n\n if (val) {\n this.words[off] = this.words[off] | (1 << wbit);\n } else {\n this.words[off] = this.words[off] & ~(1 << wbit);\n }\n\n return this._strip();\n };\n\n // Add `num` to `this` in-place\n BN.prototype.iadd = function iadd (num) {\n var r;\n\n // negative + positive\n if (this.negative !== 0 && num.negative === 0) {\n this.negative = 0;\n r = this.isub(num);\n this.negative ^= 1;\n return this._normSign();\n\n // positive + negative\n } else if (this.negative === 0 && num.negative !== 0) {\n num.negative = 0;\n r = this.isub(num);\n num.negative = 1;\n return r._normSign();\n }\n\n // a.length > b.length\n var a, b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n\n this.length = a.length;\n if (carry !== 0) {\n this.words[this.length] = carry;\n this.length++;\n // Copy the rest of the words\n } else if (a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n return this;\n };\n\n // Add `num` to `this`\n BN.prototype.add = function add (num) {\n var res;\n if (num.negative !== 0 && this.negative === 0) {\n num.negative = 0;\n res = this.sub(num);\n num.negative ^= 1;\n return res;\n } else if (num.negative === 0 && this.negative !== 0) {\n this.negative = 0;\n res = num.sub(this);\n this.negative = 1;\n return res;\n }\n\n if (this.length > num.length) return this.clone().iadd(num);\n\n return num.clone().iadd(this);\n };\n\n // Subtract `num` from `this` in-place\n BN.prototype.isub = function isub (num) {\n // this - (-num) = this + num\n if (num.negative !== 0) {\n num.negative = 0;\n var r = this.iadd(num);\n num.negative = 1;\n return r._normSign();\n\n // -this - num = -(this + num)\n } else if (this.negative !== 0) {\n this.negative = 0;\n this.iadd(num);\n this.negative = 1;\n return this._normSign();\n }\n\n // At this point both numbers are positive\n var cmp = this.cmp(num);\n\n // Optimization - zeroify\n if (cmp === 0) {\n this.negative = 0;\n this.length = 1;\n this.words[0] = 0;\n return this;\n }\n\n // a > b\n var a, b;\n if (cmp > 0) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n\n // Copy rest of the words\n if (carry === 0 && i < a.length && a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = Math.max(this.length, i);\n\n if (a !== this) {\n this.negative = 1;\n }\n\n return this._strip();\n };\n\n // Subtract `num` from `this`\n BN.prototype.sub = function sub (num) {\n return this.clone().isub(num);\n };\n\n function smallMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n var len = (self.length + num.length) | 0;\n out.length = len;\n len = (len - 1) | 0;\n\n // Peel one iteration (compiler can't do it, because of code complexity)\n var a = self.words[0] | 0;\n var b = num.words[0] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n var carry = (r / 0x4000000) | 0;\n out.words[0] = lo;\n\n for (var k = 1; k < len; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = carry >>> 26;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = (k - j) | 0;\n a = self.words[i] | 0;\n b = num.words[j] | 0;\n r = a * b + rword;\n ncarry += (r / 0x4000000) | 0;\n rword = r & 0x3ffffff;\n }\n out.words[k] = rword | 0;\n carry = ncarry | 0;\n }\n if (carry !== 0) {\n out.words[k] = carry | 0;\n } else {\n out.length--;\n }\n\n return out._strip();\n }\n\n // TODO(indutny): it may be reasonable to omit it for users who don't need\n // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n // multiplication (like elliptic secp256k1).\n var comb10MulTo = function comb10MulTo (self, num, out) {\n var a = self.words;\n var b = num.words;\n var o = out.words;\n var c = 0;\n var lo;\n var mid;\n var hi;\n var a0 = a[0] | 0;\n var al0 = a0 & 0x1fff;\n var ah0 = a0 >>> 13;\n var a1 = a[1] | 0;\n var al1 = a1 & 0x1fff;\n var ah1 = a1 >>> 13;\n var a2 = a[2] | 0;\n var al2 = a2 & 0x1fff;\n var ah2 = a2 >>> 13;\n var a3 = a[3] | 0;\n var al3 = a3 & 0x1fff;\n var ah3 = a3 >>> 13;\n var a4 = a[4] | 0;\n var al4 = a4 & 0x1fff;\n var ah4 = a4 >>> 13;\n var a5 = a[5] | 0;\n var al5 = a5 & 0x1fff;\n var ah5 = a5 >>> 13;\n var a6 = a[6] | 0;\n var al6 = a6 & 0x1fff;\n var ah6 = a6 >>> 13;\n var a7 = a[7] | 0;\n var al7 = a7 & 0x1fff;\n var ah7 = a7 >>> 13;\n var a8 = a[8] | 0;\n var al8 = a8 & 0x1fff;\n var ah8 = a8 >>> 13;\n var a9 = a[9] | 0;\n var al9 = a9 & 0x1fff;\n var ah9 = a9 >>> 13;\n var b0 = b[0] | 0;\n var bl0 = b0 & 0x1fff;\n var bh0 = b0 >>> 13;\n var b1 = b[1] | 0;\n var bl1 = b1 & 0x1fff;\n var bh1 = b1 >>> 13;\n var b2 = b[2] | 0;\n var bl2 = b2 & 0x1fff;\n var bh2 = b2 >>> 13;\n var b3 = b[3] | 0;\n var bl3 = b3 & 0x1fff;\n var bh3 = b3 >>> 13;\n var b4 = b[4] | 0;\n var bl4 = b4 & 0x1fff;\n var bh4 = b4 >>> 13;\n var b5 = b[5] | 0;\n var bl5 = b5 & 0x1fff;\n var bh5 = b5 >>> 13;\n var b6 = b[6] | 0;\n var bl6 = b6 & 0x1fff;\n var bh6 = b6 >>> 13;\n var b7 = b[7] | 0;\n var bl7 = b7 & 0x1fff;\n var bh7 = b7 >>> 13;\n var b8 = b[8] | 0;\n var bl8 = b8 & 0x1fff;\n var bh8 = b8 >>> 13;\n var b9 = b[9] | 0;\n var bl9 = b9 & 0x1fff;\n var bh9 = b9 >>> 13;\n\n out.negative = self.negative ^ num.negative;\n out.length = 19;\n /* k = 0 */\n lo = Math.imul(al0, bl0);\n mid = Math.imul(al0, bh0);\n mid = (mid + Math.imul(ah0, bl0)) | 0;\n hi = Math.imul(ah0, bh0);\n var w0 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w0 >>> 26)) | 0;\n w0 &= 0x3ffffff;\n /* k = 1 */\n lo = Math.imul(al1, bl0);\n mid = Math.imul(al1, bh0);\n mid = (mid + Math.imul(ah1, bl0)) | 0;\n hi = Math.imul(ah1, bh0);\n lo = (lo + Math.imul(al0, bl1)) | 0;\n mid = (mid + Math.imul(al0, bh1)) | 0;\n mid = (mid + Math.imul(ah0, bl1)) | 0;\n hi = (hi + Math.imul(ah0, bh1)) | 0;\n var w1 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w1 >>> 26)) | 0;\n w1 &= 0x3ffffff;\n /* k = 2 */\n lo = Math.imul(al2, bl0);\n mid = Math.imul(al2, bh0);\n mid = (mid + Math.imul(ah2, bl0)) | 0;\n hi = Math.imul(ah2, bh0);\n lo = (lo + Math.imul(al1, bl1)) | 0;\n mid = (mid + Math.imul(al1, bh1)) | 0;\n mid = (mid + Math.imul(ah1, bl1)) | 0;\n hi = (hi + Math.imul(ah1, bh1)) | 0;\n lo = (lo + Math.imul(al0, bl2)) | 0;\n mid = (mid + Math.imul(al0, bh2)) | 0;\n mid = (mid + Math.imul(ah0, bl2)) | 0;\n hi = (hi + Math.imul(ah0, bh2)) | 0;\n var w2 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w2 >>> 26)) | 0;\n w2 &= 0x3ffffff;\n /* k = 3 */\n lo = Math.imul(al3, bl0);\n mid = Math.imul(al3, bh0);\n mid = (mid + Math.imul(ah3, bl0)) | 0;\n hi = Math.imul(ah3, bh0);\n lo = (lo + Math.imul(al2, bl1)) | 0;\n mid = (mid + Math.imul(al2, bh1)) | 0;\n mid = (mid + Math.imul(ah2, bl1)) | 0;\n hi = (hi + Math.imul(ah2, bh1)) | 0;\n lo = (lo + Math.imul(al1, bl2)) | 0;\n mid = (mid + Math.imul(al1, bh2)) | 0;\n mid = (mid + Math.imul(ah1, bl2)) | 0;\n hi = (hi + Math.imul(ah1, bh2)) | 0;\n lo = (lo + Math.imul(al0, bl3)) | 0;\n mid = (mid + Math.imul(al0, bh3)) | 0;\n mid = (mid + Math.imul(ah0, bl3)) | 0;\n hi = (hi + Math.imul(ah0, bh3)) | 0;\n var w3 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w3 >>> 26)) | 0;\n w3 &= 0x3ffffff;\n /* k = 4 */\n lo = Math.imul(al4, bl0);\n mid = Math.imul(al4, bh0);\n mid = (mid + Math.imul(ah4, bl0)) | 0;\n hi = Math.imul(ah4, bh0);\n lo = (lo + Math.imul(al3, bl1)) | 0;\n mid = (mid + Math.imul(al3, bh1)) | 0;\n mid = (mid + Math.imul(ah3, bl1)) | 0;\n hi = (hi + Math.imul(ah3, bh1)) | 0;\n lo = (lo + Math.imul(al2, bl2)) | 0;\n mid = (mid + Math.imul(al2, bh2)) | 0;\n mid = (mid + Math.imul(ah2, bl2)) | 0;\n hi = (hi + Math.imul(ah2, bh2)) | 0;\n lo = (lo + Math.imul(al1, bl3)) | 0;\n mid = (mid + Math.imul(al1, bh3)) | 0;\n mid = (mid + Math.imul(ah1, bl3)) | 0;\n hi = (hi + Math.imul(ah1, bh3)) | 0;\n lo = (lo + Math.imul(al0, bl4)) | 0;\n mid = (mid + Math.imul(al0, bh4)) | 0;\n mid = (mid + Math.imul(ah0, bl4)) | 0;\n hi = (hi + Math.imul(ah0, bh4)) | 0;\n var w4 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w4 >>> 26)) | 0;\n w4 &= 0x3ffffff;\n /* k = 5 */\n lo = Math.imul(al5, bl0);\n mid = Math.imul(al5, bh0);\n mid = (mid + Math.imul(ah5, bl0)) | 0;\n hi = Math.imul(ah5, bh0);\n lo = (lo + Math.imul(al4, bl1)) | 0;\n mid = (mid + Math.imul(al4, bh1)) | 0;\n mid = (mid + Math.imul(ah4, bl1)) | 0;\n hi = (hi + Math.imul(ah4, bh1)) | 0;\n lo = (lo + Math.imul(al3, bl2)) | 0;\n mid = (mid + Math.imul(al3, bh2)) | 0;\n mid = (mid + Math.imul(ah3, bl2)) | 0;\n hi = (hi + Math.imul(ah3, bh2)) | 0;\n lo = (lo + Math.imul(al2, bl3)) | 0;\n mid = (mid + Math.imul(al2, bh3)) | 0;\n mid = (mid + Math.imul(ah2, bl3)) | 0;\n hi = (hi + Math.imul(ah2, bh3)) | 0;\n lo = (lo + Math.imul(al1, bl4)) | 0;\n mid = (mid + Math.imul(al1, bh4)) | 0;\n mid = (mid + Math.imul(ah1, bl4)) | 0;\n hi = (hi + Math.imul(ah1, bh4)) | 0;\n lo = (lo + Math.imul(al0, bl5)) | 0;\n mid = (mid + Math.imul(al0, bh5)) | 0;\n mid = (mid + Math.imul(ah0, bl5)) | 0;\n hi = (hi + Math.imul(ah0, bh5)) | 0;\n var w5 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w5 >>> 26)) | 0;\n w5 &= 0x3ffffff;\n /* k = 6 */\n lo = Math.imul(al6, bl0);\n mid = Math.imul(al6, bh0);\n mid = (mid + Math.imul(ah6, bl0)) | 0;\n hi = Math.imul(ah6, bh0);\n lo = (lo + Math.imul(al5, bl1)) | 0;\n mid = (mid + Math.imul(al5, bh1)) | 0;\n mid = (mid + Math.imul(ah5, bl1)) | 0;\n hi = (hi + Math.imul(ah5, bh1)) | 0;\n lo = (lo + Math.imul(al4, bl2)) | 0;\n mid = (mid + Math.imul(al4, bh2)) | 0;\n mid = (mid + Math.imul(ah4, bl2)) | 0;\n hi = (hi + Math.imul(ah4, bh2)) | 0;\n lo = (lo + Math.imul(al3, bl3)) | 0;\n mid = (mid + Math.imul(al3, bh3)) | 0;\n mid = (mid + Math.imul(ah3, bl3)) | 0;\n hi = (hi + Math.imul(ah3, bh3)) | 0;\n lo = (lo + Math.imul(al2, bl4)) | 0;\n mid = (mid + Math.imul(al2, bh4)) | 0;\n mid = (mid + Math.imul(ah2, bl4)) | 0;\n hi = (hi + Math.imul(ah2, bh4)) | 0;\n lo = (lo + Math.imul(al1, bl5)) | 0;\n mid = (mid + Math.imul(al1, bh5)) | 0;\n mid = (mid + Math.imul(ah1, bl5)) | 0;\n hi = (hi + Math.imul(ah1, bh5)) | 0;\n lo = (lo + Math.imul(al0, bl6)) | 0;\n mid = (mid + Math.imul(al0, bh6)) | 0;\n mid = (mid + Math.imul(ah0, bl6)) | 0;\n hi = (hi + Math.imul(ah0, bh6)) | 0;\n var w6 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w6 >>> 26)) | 0;\n w6 &= 0x3ffffff;\n /* k = 7 */\n lo = Math.imul(al7, bl0);\n mid = Math.imul(al7, bh0);\n mid = (mid + Math.imul(ah7, bl0)) | 0;\n hi = Math.imul(ah7, bh0);\n lo = (lo + Math.imul(al6, bl1)) | 0;\n mid = (mid + Math.imul(al6, bh1)) | 0;\n mid = (mid + Math.imul(ah6, bl1)) | 0;\n hi = (hi + Math.imul(ah6, bh1)) | 0;\n lo = (lo + Math.imul(al5, bl2)) | 0;\n mid = (mid + Math.imul(al5, bh2)) | 0;\n mid = (mid + Math.imul(ah5, bl2)) | 0;\n hi = (hi + Math.imul(ah5, bh2)) | 0;\n lo = (lo + Math.imul(al4, bl3)) | 0;\n mid = (mid + Math.imul(al4, bh3)) | 0;\n mid = (mid + Math.imul(ah4, bl3)) | 0;\n hi = (hi + Math.imul(ah4, bh3)) | 0;\n lo = (lo + Math.imul(al3, bl4)) | 0;\n mid = (mid + Math.imul(al3, bh4)) | 0;\n mid = (mid + Math.imul(ah3, bl4)) | 0;\n hi = (hi + Math.imul(ah3, bh4)) | 0;\n lo = (lo + Math.imul(al2, bl5)) | 0;\n mid = (mid + Math.imul(al2, bh5)) | 0;\n mid = (mid + Math.imul(ah2, bl5)) | 0;\n hi = (hi + Math.imul(ah2, bh5)) | 0;\n lo = (lo + Math.imul(al1, bl6)) | 0;\n mid = (mid + Math.imul(al1, bh6)) | 0;\n mid = (mid + Math.imul(ah1, bl6)) | 0;\n hi = (hi + Math.imul(ah1, bh6)) | 0;\n lo = (lo + Math.imul(al0, bl7)) | 0;\n mid = (mid + Math.imul(al0, bh7)) | 0;\n mid = (mid + Math.imul(ah0, bl7)) | 0;\n hi = (hi + Math.imul(ah0, bh7)) | 0;\n var w7 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w7 >>> 26)) | 0;\n w7 &= 0x3ffffff;\n /* k = 8 */\n lo = Math.imul(al8, bl0);\n mid = Math.imul(al8, bh0);\n mid = (mid + Math.imul(ah8, bl0)) | 0;\n hi = Math.imul(ah8, bh0);\n lo = (lo + Math.imul(al7, bl1)) | 0;\n mid = (mid + Math.imul(al7, bh1)) | 0;\n mid = (mid + Math.imul(ah7, bl1)) | 0;\n hi = (hi + Math.imul(ah7, bh1)) | 0;\n lo = (lo + Math.imul(al6, bl2)) | 0;\n mid = (mid + Math.imul(al6, bh2)) | 0;\n mid = (mid + Math.imul(ah6, bl2)) | 0;\n hi = (hi + Math.imul(ah6, bh2)) | 0;\n lo = (lo + Math.imul(al5, bl3)) | 0;\n mid = (mid + Math.imul(al5, bh3)) | 0;\n mid = (mid + Math.imul(ah5, bl3)) | 0;\n hi = (hi + Math.imul(ah5, bh3)) | 0;\n lo = (lo + Math.imul(al4, bl4)) | 0;\n mid = (mid + Math.imul(al4, bh4)) | 0;\n mid = (mid + Math.imul(ah4, bl4)) | 0;\n hi = (hi + Math.imul(ah4, bh4)) | 0;\n lo = (lo + Math.imul(al3, bl5)) | 0;\n mid = (mid + Math.imul(al3, bh5)) | 0;\n mid = (mid + Math.imul(ah3, bl5)) | 0;\n hi = (hi + Math.imul(ah3, bh5)) | 0;\n lo = (lo + Math.imul(al2, bl6)) | 0;\n mid = (mid + Math.imul(al2, bh6)) | 0;\n mid = (mid + Math.imul(ah2, bl6)) | 0;\n hi = (hi + Math.imul(ah2, bh6)) | 0;\n lo = (lo + Math.imul(al1, bl7)) | 0;\n mid = (mid + Math.imul(al1, bh7)) | 0;\n mid = (mid + Math.imul(ah1, bl7)) | 0;\n hi = (hi + Math.imul(ah1, bh7)) | 0;\n lo = (lo + Math.imul(al0, bl8)) | 0;\n mid = (mid + Math.imul(al0, bh8)) | 0;\n mid = (mid + Math.imul(ah0, bl8)) | 0;\n hi = (hi + Math.imul(ah0, bh8)) | 0;\n var w8 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w8 >>> 26)) | 0;\n w8 &= 0x3ffffff;\n /* k = 9 */\n lo = Math.imul(al9, bl0);\n mid = Math.imul(al9, bh0);\n mid = (mid + Math.imul(ah9, bl0)) | 0;\n hi = Math.imul(ah9, bh0);\n lo = (lo + Math.imul(al8, bl1)) | 0;\n mid = (mid + Math.imul(al8, bh1)) | 0;\n mid = (mid + Math.imul(ah8, bl1)) | 0;\n hi = (hi + Math.imul(ah8, bh1)) | 0;\n lo = (lo + Math.imul(al7, bl2)) | 0;\n mid = (mid + Math.imul(al7, bh2)) | 0;\n mid = (mid + Math.imul(ah7, bl2)) | 0;\n hi = (hi + Math.imul(ah7, bh2)) | 0;\n lo = (lo + Math.imul(al6, bl3)) | 0;\n mid = (mid + Math.imul(al6, bh3)) | 0;\n mid = (mid + Math.imul(ah6, bl3)) | 0;\n hi = (hi + Math.imul(ah6, bh3)) | 0;\n lo = (lo + Math.imul(al5, bl4)) | 0;\n mid = (mid + Math.imul(al5, bh4)) | 0;\n mid = (mid + Math.imul(ah5, bl4)) | 0;\n hi = (hi + Math.imul(ah5, bh4)) | 0;\n lo = (lo + Math.imul(al4, bl5)) | 0;\n mid = (mid + Math.imul(al4, bh5)) | 0;\n mid = (mid + Math.imul(ah4, bl5)) | 0;\n hi = (hi + Math.imul(ah4, bh5)) | 0;\n lo = (lo + Math.imul(al3, bl6)) | 0;\n mid = (mid + Math.imul(al3, bh6)) | 0;\n mid = (mid + Math.imul(ah3, bl6)) | 0;\n hi = (hi + Math.imul(ah3, bh6)) | 0;\n lo = (lo + Math.imul(al2, bl7)) | 0;\n mid = (mid + Math.imul(al2, bh7)) | 0;\n mid = (mid + Math.imul(ah2, bl7)) | 0;\n hi = (hi + Math.imul(ah2, bh7)) | 0;\n lo = (lo + Math.imul(al1, bl8)) | 0;\n mid = (mid + Math.imul(al1, bh8)) | 0;\n mid = (mid + Math.imul(ah1, bl8)) | 0;\n hi = (hi + Math.imul(ah1, bh8)) | 0;\n lo = (lo + Math.imul(al0, bl9)) | 0;\n mid = (mid + Math.imul(al0, bh9)) | 0;\n mid = (mid + Math.imul(ah0, bl9)) | 0;\n hi = (hi + Math.imul(ah0, bh9)) | 0;\n var w9 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w9 >>> 26)) | 0;\n w9 &= 0x3ffffff;\n /* k = 10 */\n lo = Math.imul(al9, bl1);\n mid = Math.imul(al9, bh1);\n mid = (mid + Math.imul(ah9, bl1)) | 0;\n hi = Math.imul(ah9, bh1);\n lo = (lo + Math.imul(al8, bl2)) | 0;\n mid = (mid + Math.imul(al8, bh2)) | 0;\n mid = (mid + Math.imul(ah8, bl2)) | 0;\n hi = (hi + Math.imul(ah8, bh2)) | 0;\n lo = (lo + Math.imul(al7, bl3)) | 0;\n mid = (mid + Math.imul(al7, bh3)) | 0;\n mid = (mid + Math.imul(ah7, bl3)) | 0;\n hi = (hi + Math.imul(ah7, bh3)) | 0;\n lo = (lo + Math.imul(al6, bl4)) | 0;\n mid = (mid + Math.imul(al6, bh4)) | 0;\n mid = (mid + Math.imul(ah6, bl4)) | 0;\n hi = (hi + Math.imul(ah6, bh4)) | 0;\n lo = (lo + Math.imul(al5, bl5)) | 0;\n mid = (mid + Math.imul(al5, bh5)) | 0;\n mid = (mid + Math.imul(ah5, bl5)) | 0;\n hi = (hi + Math.imul(ah5, bh5)) | 0;\n lo = (lo + Math.imul(al4, bl6)) | 0;\n mid = (mid + Math.imul(al4, bh6)) | 0;\n mid = (mid + Math.imul(ah4, bl6)) | 0;\n hi = (hi + Math.imul(ah4, bh6)) | 0;\n lo = (lo + Math.imul(al3, bl7)) | 0;\n mid = (mid + Math.imul(al3, bh7)) | 0;\n mid = (mid + Math.imul(ah3, bl7)) | 0;\n hi = (hi + Math.imul(ah3, bh7)) | 0;\n lo = (lo + Math.imul(al2, bl8)) | 0;\n mid = (mid + Math.imul(al2, bh8)) | 0;\n mid = (mid + Math.imul(ah2, bl8)) | 0;\n hi = (hi + Math.imul(ah2, bh8)) | 0;\n lo = (lo + Math.imul(al1, bl9)) | 0;\n mid = (mid + Math.imul(al1, bh9)) | 0;\n mid = (mid + Math.imul(ah1, bl9)) | 0;\n hi = (hi + Math.imul(ah1, bh9)) | 0;\n var w10 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w10 >>> 26)) | 0;\n w10 &= 0x3ffffff;\n /* k = 11 */\n lo = Math.imul(al9, bl2);\n mid = Math.imul(al9, bh2);\n mid = (mid + Math.imul(ah9, bl2)) | 0;\n hi = Math.imul(ah9, bh2);\n lo = (lo + Math.imul(al8, bl3)) | 0;\n mid = (mid + Math.imul(al8, bh3)) | 0;\n mid = (mid + Math.imul(ah8, bl3)) | 0;\n hi = (hi + Math.imul(ah8, bh3)) | 0;\n lo = (lo + Math.imul(al7, bl4)) | 0;\n mid = (mid + Math.imul(al7, bh4)) | 0;\n mid = (mid + Math.imul(ah7, bl4)) | 0;\n hi = (hi + Math.imul(ah7, bh4)) | 0;\n lo = (lo + Math.imul(al6, bl5)) | 0;\n mid = (mid + Math.imul(al6, bh5)) | 0;\n mid = (mid + Math.imul(ah6, bl5)) | 0;\n hi = (hi + Math.imul(ah6, bh5)) | 0;\n lo = (lo + Math.imul(al5, bl6)) | 0;\n mid = (mid + Math.imul(al5, bh6)) | 0;\n mid = (mid + Math.imul(ah5, bl6)) | 0;\n hi = (hi + Math.imul(ah5, bh6)) | 0;\n lo = (lo + Math.imul(al4, bl7)) | 0;\n mid = (mid + Math.imul(al4, bh7)) | 0;\n mid = (mid + Math.imul(ah4, bl7)) | 0;\n hi = (hi + Math.imul(ah4, bh7)) | 0;\n lo = (lo + Math.imul(al3, bl8)) | 0;\n mid = (mid + Math.imul(al3, bh8)) | 0;\n mid = (mid + Math.imul(ah3, bl8)) | 0;\n hi = (hi + Math.imul(ah3, bh8)) | 0;\n lo = (lo + Math.imul(al2, bl9)) | 0;\n mid = (mid + Math.imul(al2, bh9)) | 0;\n mid = (mid + Math.imul(ah2, bl9)) | 0;\n hi = (hi + Math.imul(ah2, bh9)) | 0;\n var w11 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w11 >>> 26)) | 0;\n w11 &= 0x3ffffff;\n /* k = 12 */\n lo = Math.imul(al9, bl3);\n mid = Math.imul(al9, bh3);\n mid = (mid + Math.imul(ah9, bl3)) | 0;\n hi = Math.imul(ah9, bh3);\n lo = (lo + Math.imul(al8, bl4)) | 0;\n mid = (mid + Math.imul(al8, bh4)) | 0;\n mid = (mid + Math.imul(ah8, bl4)) | 0;\n hi = (hi + Math.imul(ah8, bh4)) | 0;\n lo = (lo + Math.imul(al7, bl5)) | 0;\n mid = (mid + Math.imul(al7, bh5)) | 0;\n mid = (mid + Math.imul(ah7, bl5)) | 0;\n hi = (hi + Math.imul(ah7, bh5)) | 0;\n lo = (lo + Math.imul(al6, bl6)) | 0;\n mid = (mid + Math.imul(al6, bh6)) | 0;\n mid = (mid + Math.imul(ah6, bl6)) | 0;\n hi = (hi + Math.imul(ah6, bh6)) | 0;\n lo = (lo + Math.imul(al5, bl7)) | 0;\n mid = (mid + Math.imul(al5, bh7)) | 0;\n mid = (mid + Math.imul(ah5, bl7)) | 0;\n hi = (hi + Math.imul(ah5, bh7)) | 0;\n lo = (lo + Math.imul(al4, bl8)) | 0;\n mid = (mid + Math.imul(al4, bh8)) | 0;\n mid = (mid + Math.imul(ah4, bl8)) | 0;\n hi = (hi + Math.imul(ah4, bh8)) | 0;\n lo = (lo + Math.imul(al3, bl9)) | 0;\n mid = (mid + Math.imul(al3, bh9)) | 0;\n mid = (mid + Math.imul(ah3, bl9)) | 0;\n hi = (hi + Math.imul(ah3, bh9)) | 0;\n var w12 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w12 >>> 26)) | 0;\n w12 &= 0x3ffffff;\n /* k = 13 */\n lo = Math.imul(al9, bl4);\n mid = Math.imul(al9, bh4);\n mid = (mid + Math.imul(ah9, bl4)) | 0;\n hi = Math.imul(ah9, bh4);\n lo = (lo + Math.imul(al8, bl5)) | 0;\n mid = (mid + Math.imul(al8, bh5)) | 0;\n mid = (mid + Math.imul(ah8, bl5)) | 0;\n hi = (hi + Math.imul(ah8, bh5)) | 0;\n lo = (lo + Math.imul(al7, bl6)) | 0;\n mid = (mid + Math.imul(al7, bh6)) | 0;\n mid = (mid + Math.imul(ah7, bl6)) | 0;\n hi = (hi + Math.imul(ah7, bh6)) | 0;\n lo = (lo + Math.imul(al6, bl7)) | 0;\n mid = (mid + Math.imul(al6, bh7)) | 0;\n mid = (mid + Math.imul(ah6, bl7)) | 0;\n hi = (hi + Math.imul(ah6, bh7)) | 0;\n lo = (lo + Math.imul(al5, bl8)) | 0;\n mid = (mid + Math.imul(al5, bh8)) | 0;\n mid = (mid + Math.imul(ah5, bl8)) | 0;\n hi = (hi + Math.imul(ah5, bh8)) | 0;\n lo = (lo + Math.imul(al4, bl9)) | 0;\n mid = (mid + Math.imul(al4, bh9)) | 0;\n mid = (mid + Math.imul(ah4, bl9)) | 0;\n hi = (hi + Math.imul(ah4, bh9)) | 0;\n var w13 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w13 >>> 26)) | 0;\n w13 &= 0x3ffffff;\n /* k = 14 */\n lo = Math.imul(al9, bl5);\n mid = Math.imul(al9, bh5);\n mid = (mid + Math.imul(ah9, bl5)) | 0;\n hi = Math.imul(ah9, bh5);\n lo = (lo + Math.imul(al8, bl6)) | 0;\n mid = (mid + Math.imul(al8, bh6)) | 0;\n mid = (mid + Math.imul(ah8, bl6)) | 0;\n hi = (hi + Math.imul(ah8, bh6)) | 0;\n lo = (lo + Math.imul(al7, bl7)) | 0;\n mid = (mid + Math.imul(al7, bh7)) | 0;\n mid = (mid + Math.imul(ah7, bl7)) | 0;\n hi = (hi + Math.imul(ah7, bh7)) | 0;\n lo = (lo + Math.imul(al6, bl8)) | 0;\n mid = (mid + Math.imul(al6, bh8)) | 0;\n mid = (mid + Math.imul(ah6, bl8)) | 0;\n hi = (hi + Math.imul(ah6, bh8)) | 0;\n lo = (lo + Math.imul(al5, bl9)) | 0;\n mid = (mid + Math.imul(al5, bh9)) | 0;\n mid = (mid + Math.imul(ah5, bl9)) | 0;\n hi = (hi + Math.imul(ah5, bh9)) | 0;\n var w14 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w14 >>> 26)) | 0;\n w14 &= 0x3ffffff;\n /* k = 15 */\n lo = Math.imul(al9, bl6);\n mid = Math.imul(al9, bh6);\n mid = (mid + Math.imul(ah9, bl6)) | 0;\n hi = Math.imul(ah9, bh6);\n lo = (lo + Math.imul(al8, bl7)) | 0;\n mid = (mid + Math.imul(al8, bh7)) | 0;\n mid = (mid + Math.imul(ah8, bl7)) | 0;\n hi = (hi + Math.imul(ah8, bh7)) | 0;\n lo = (lo + Math.imul(al7, bl8)) | 0;\n mid = (mid + Math.imul(al7, bh8)) | 0;\n mid = (mid + Math.imul(ah7, bl8)) | 0;\n hi = (hi + Math.imul(ah7, bh8)) | 0;\n lo = (lo + Math.imul(al6, bl9)) | 0;\n mid = (mid + Math.imul(al6, bh9)) | 0;\n mid = (mid + Math.imul(ah6, bl9)) | 0;\n hi = (hi + Math.imul(ah6, bh9)) | 0;\n var w15 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w15 >>> 26)) | 0;\n w15 &= 0x3ffffff;\n /* k = 16 */\n lo = Math.imul(al9, bl7);\n mid = Math.imul(al9, bh7);\n mid = (mid + Math.imul(ah9, bl7)) | 0;\n hi = Math.imul(ah9, bh7);\n lo = (lo + Math.imul(al8, bl8)) | 0;\n mid = (mid + Math.imul(al8, bh8)) | 0;\n mid = (mid + Math.imul(ah8, bl8)) | 0;\n hi = (hi + Math.imul(ah8, bh8)) | 0;\n lo = (lo + Math.imul(al7, bl9)) | 0;\n mid = (mid + Math.imul(al7, bh9)) | 0;\n mid = (mid + Math.imul(ah7, bl9)) | 0;\n hi = (hi + Math.imul(ah7, bh9)) | 0;\n var w16 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w16 >>> 26)) | 0;\n w16 &= 0x3ffffff;\n /* k = 17 */\n lo = Math.imul(al9, bl8);\n mid = Math.imul(al9, bh8);\n mid = (mid + Math.imul(ah9, bl8)) | 0;\n hi = Math.imul(ah9, bh8);\n lo = (lo + Math.imul(al8, bl9)) | 0;\n mid = (mid + Math.imul(al8, bh9)) | 0;\n mid = (mid + Math.imul(ah8, bl9)) | 0;\n hi = (hi + Math.imul(ah8, bh9)) | 0;\n var w17 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w17 >>> 26)) | 0;\n w17 &= 0x3ffffff;\n /* k = 18 */\n lo = Math.imul(al9, bl9);\n mid = Math.imul(al9, bh9);\n mid = (mid + Math.imul(ah9, bl9)) | 0;\n hi = Math.imul(ah9, bh9);\n var w18 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w18 >>> 26)) | 0;\n w18 &= 0x3ffffff;\n o[0] = w0;\n o[1] = w1;\n o[2] = w2;\n o[3] = w3;\n o[4] = w4;\n o[5] = w5;\n o[6] = w6;\n o[7] = w7;\n o[8] = w8;\n o[9] = w9;\n o[10] = w10;\n o[11] = w11;\n o[12] = w12;\n o[13] = w13;\n o[14] = w14;\n o[15] = w15;\n o[16] = w16;\n o[17] = w17;\n o[18] = w18;\n if (c !== 0) {\n o[19] = c;\n out.length++;\n }\n return out;\n };\n\n // Polyfill comb\n if (!Math.imul) {\n comb10MulTo = smallMulTo;\n }\n\n function bigMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n out.length = self.length + num.length;\n\n var carry = 0;\n var hncarry = 0;\n for (var k = 0; k < out.length - 1; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = hncarry;\n hncarry = 0;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j;\n var a = self.words[i] | 0;\n var b = num.words[j] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n ncarry = (ncarry + ((r / 0x4000000) | 0)) | 0;\n lo = (lo + rword) | 0;\n rword = lo & 0x3ffffff;\n ncarry = (ncarry + (lo >>> 26)) | 0;\n\n hncarry += ncarry >>> 26;\n ncarry &= 0x3ffffff;\n }\n out.words[k] = rword;\n carry = ncarry;\n ncarry = hncarry;\n }\n if (carry !== 0) {\n out.words[k] = carry;\n } else {\n out.length--;\n }\n\n return out._strip();\n }\n\n function jumboMulTo (self, num, out) {\n // Temporary disable, see https://github.com/indutny/bn.js/issues/211\n // var fftm = new FFTM();\n // return fftm.mulp(self, num, out);\n return bigMulTo(self, num, out);\n }\n\n BN.prototype.mulTo = function mulTo (num, out) {\n var res;\n var len = this.length + num.length;\n if (this.length === 10 && num.length === 10) {\n res = comb10MulTo(this, num, out);\n } else if (len < 63) {\n res = smallMulTo(this, num, out);\n } else if (len < 1024) {\n res = bigMulTo(this, num, out);\n } else {\n res = jumboMulTo(this, num, out);\n }\n\n return res;\n };\n\n // Cooley-Tukey algorithm for FFT\n // slightly revisited to rely on looping instead of recursion\n\n function FFTM (x, y) {\n this.x = x;\n this.y = y;\n }\n\n FFTM.prototype.makeRBT = function makeRBT (N) {\n var t = new Array(N);\n var l = BN.prototype._countBits(N) - 1;\n for (var i = 0; i < N; i++) {\n t[i] = this.revBin(i, l, N);\n }\n\n return t;\n };\n\n // Returns binary-reversed representation of `x`\n FFTM.prototype.revBin = function revBin (x, l, N) {\n if (x === 0 || x === N - 1) return x;\n\n var rb = 0;\n for (var i = 0; i < l; i++) {\n rb |= (x & 1) << (l - i - 1);\n x >>= 1;\n }\n\n return rb;\n };\n\n // Performs \"tweedling\" phase, therefore 'emulating'\n // behaviour of the recursive algorithm\n FFTM.prototype.permute = function permute (rbt, rws, iws, rtws, itws, N) {\n for (var i = 0; i < N; i++) {\n rtws[i] = rws[rbt[i]];\n itws[i] = iws[rbt[i]];\n }\n };\n\n FFTM.prototype.transform = function transform (rws, iws, rtws, itws, N, rbt) {\n this.permute(rbt, rws, iws, rtws, itws, N);\n\n for (var s = 1; s < N; s <<= 1) {\n var l = s << 1;\n\n var rtwdf = Math.cos(2 * Math.PI / l);\n var itwdf = Math.sin(2 * Math.PI / l);\n\n for (var p = 0; p < N; p += l) {\n var rtwdf_ = rtwdf;\n var itwdf_ = itwdf;\n\n for (var j = 0; j < s; j++) {\n var re = rtws[p + j];\n var ie = itws[p + j];\n\n var ro = rtws[p + j + s];\n var io = itws[p + j + s];\n\n var rx = rtwdf_ * ro - itwdf_ * io;\n\n io = rtwdf_ * io + itwdf_ * ro;\n ro = rx;\n\n rtws[p + j] = re + ro;\n itws[p + j] = ie + io;\n\n rtws[p + j + s] = re - ro;\n itws[p + j + s] = ie - io;\n\n /* jshint maxdepth : false */\n if (j !== l) {\n rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n\n itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n rtwdf_ = rx;\n }\n }\n }\n }\n };\n\n FFTM.prototype.guessLen13b = function guessLen13b (n, m) {\n var N = Math.max(m, n) | 1;\n var odd = N & 1;\n var i = 0;\n for (N = N / 2 | 0; N; N = N >>> 1) {\n i++;\n }\n\n return 1 << i + 1 + odd;\n };\n\n FFTM.prototype.conjugate = function conjugate (rws, iws, N) {\n if (N <= 1) return;\n\n for (var i = 0; i < N / 2; i++) {\n var t = rws[i];\n\n rws[i] = rws[N - i - 1];\n rws[N - i - 1] = t;\n\n t = iws[i];\n\n iws[i] = -iws[N - i - 1];\n iws[N - i - 1] = -t;\n }\n };\n\n FFTM.prototype.normalize13b = function normalize13b (ws, N) {\n var carry = 0;\n for (var i = 0; i < N / 2; i++) {\n var w = Math.round(ws[2 * i + 1] / N) * 0x2000 +\n Math.round(ws[2 * i] / N) +\n carry;\n\n ws[i] = w & 0x3ffffff;\n\n if (w < 0x4000000) {\n carry = 0;\n } else {\n carry = w / 0x4000000 | 0;\n }\n }\n\n return ws;\n };\n\n FFTM.prototype.convert13b = function convert13b (ws, len, rws, N) {\n var carry = 0;\n for (var i = 0; i < len; i++) {\n carry = carry + (ws[i] | 0);\n\n rws[2 * i] = carry & 0x1fff; carry = carry >>> 13;\n rws[2 * i + 1] = carry & 0x1fff; carry = carry >>> 13;\n }\n\n // Pad with zeroes\n for (i = 2 * len; i < N; ++i) {\n rws[i] = 0;\n }\n\n assert(carry === 0);\n assert((carry & ~0x1fff) === 0);\n };\n\n FFTM.prototype.stub = function stub (N) {\n var ph = new Array(N);\n for (var i = 0; i < N; i++) {\n ph[i] = 0;\n }\n\n return ph;\n };\n\n FFTM.prototype.mulp = function mulp (x, y, out) {\n var N = 2 * this.guessLen13b(x.length, y.length);\n\n var rbt = this.makeRBT(N);\n\n var _ = this.stub(N);\n\n var rws = new Array(N);\n var rwst = new Array(N);\n var iwst = new Array(N);\n\n var nrws = new Array(N);\n var nrwst = new Array(N);\n var niwst = new Array(N);\n\n var rmws = out.words;\n rmws.length = N;\n\n this.convert13b(x.words, x.length, rws, N);\n this.convert13b(y.words, y.length, nrws, N);\n\n this.transform(rws, _, rwst, iwst, N, rbt);\n this.transform(nrws, _, nrwst, niwst, N, rbt);\n\n for (var i = 0; i < N; i++) {\n var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n rwst[i] = rx;\n }\n\n this.conjugate(rwst, iwst, N);\n this.transform(rwst, iwst, rmws, _, N, rbt);\n this.conjugate(rmws, _, N);\n this.normalize13b(rmws, N);\n\n out.negative = x.negative ^ y.negative;\n out.length = x.length + y.length;\n return out._strip();\n };\n\n // Multiply `this` by `num`\n BN.prototype.mul = function mul (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return this.mulTo(num, out);\n };\n\n // Multiply employing FFT\n BN.prototype.mulf = function mulf (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return jumboMulTo(this, num, out);\n };\n\n // In-place Multiplication\n BN.prototype.imul = function imul (num) {\n return this.clone().mulTo(num, this);\n };\n\n BN.prototype.imuln = function imuln (num) {\n var isNegNum = num < 0;\n if (isNegNum) num = -num;\n\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n\n // Carry\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = (this.words[i] | 0) * num;\n var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n carry >>= 26;\n carry += (w / 0x4000000) | 0;\n // NOTE: lo is 27bit maximum\n carry += lo >>> 26;\n this.words[i] = lo & 0x3ffffff;\n }\n\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n\n return isNegNum ? this.ineg() : this;\n };\n\n BN.prototype.muln = function muln (num) {\n return this.clone().imuln(num);\n };\n\n // `this` * `this`\n BN.prototype.sqr = function sqr () {\n return this.mul(this);\n };\n\n // `this` * `this` in-place\n BN.prototype.isqr = function isqr () {\n return this.imul(this.clone());\n };\n\n // Math.pow(`this`, `num`)\n BN.prototype.pow = function pow (num) {\n var w = toBitArray(num);\n if (w.length === 0) return new BN(1);\n\n // Skip leading zeroes\n var res = this;\n for (var i = 0; i < w.length; i++, res = res.sqr()) {\n if (w[i] !== 0) break;\n }\n\n if (++i < w.length) {\n for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n if (w[i] === 0) continue;\n\n res = res.mul(q);\n }\n }\n\n return res;\n };\n\n // Shift-left in-place\n BN.prototype.iushln = function iushln (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n var carryMask = (0x3ffffff >>> (26 - r)) << (26 - r);\n var i;\n\n if (r !== 0) {\n var carry = 0;\n\n for (i = 0; i < this.length; i++) {\n var newCarry = this.words[i] & carryMask;\n var c = ((this.words[i] | 0) - newCarry) << r;\n this.words[i] = c | carry;\n carry = newCarry >>> (26 - r);\n }\n\n if (carry) {\n this.words[i] = carry;\n this.length++;\n }\n }\n\n if (s !== 0) {\n for (i = this.length - 1; i >= 0; i--) {\n this.words[i + s] = this.words[i];\n }\n\n for (i = 0; i < s; i++) {\n this.words[i] = 0;\n }\n\n this.length += s;\n }\n\n return this._strip();\n };\n\n BN.prototype.ishln = function ishln (bits) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushln(bits);\n };\n\n // Shift-right in-place\n // NOTE: `hint` is a lowest bit before trailing zeroes\n // NOTE: if `extended` is present - it will be filled with destroyed bits\n BN.prototype.iushrn = function iushrn (bits, hint, extended) {\n assert(typeof bits === 'number' && bits >= 0);\n var h;\n if (hint) {\n h = (hint - (hint % 26)) / 26;\n } else {\n h = 0;\n }\n\n var r = bits % 26;\n var s = Math.min((bits - r) / 26, this.length);\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n var maskedWords = extended;\n\n h -= s;\n h = Math.max(0, h);\n\n // Extended mode, copy masked part\n if (maskedWords) {\n for (var i = 0; i < s; i++) {\n maskedWords.words[i] = this.words[i];\n }\n maskedWords.length = s;\n }\n\n if (s === 0) {\n // No-op, we should not move anything at all\n } else if (this.length > s) {\n this.length -= s;\n for (i = 0; i < this.length; i++) {\n this.words[i] = this.words[i + s];\n }\n } else {\n this.words[0] = 0;\n this.length = 1;\n }\n\n var carry = 0;\n for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n var word = this.words[i] | 0;\n this.words[i] = (carry << (26 - r)) | (word >>> r);\n carry = word & mask;\n }\n\n // Push carried bits as a mask\n if (maskedWords && carry !== 0) {\n maskedWords.words[maskedWords.length++] = carry;\n }\n\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n\n return this._strip();\n };\n\n BN.prototype.ishrn = function ishrn (bits, hint, extended) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushrn(bits, hint, extended);\n };\n\n // Shift-left\n BN.prototype.shln = function shln (bits) {\n return this.clone().ishln(bits);\n };\n\n BN.prototype.ushln = function ushln (bits) {\n return this.clone().iushln(bits);\n };\n\n // Shift-right\n BN.prototype.shrn = function shrn (bits) {\n return this.clone().ishrn(bits);\n };\n\n BN.prototype.ushrn = function ushrn (bits) {\n return this.clone().iushrn(bits);\n };\n\n // Test if n bit is set\n BN.prototype.testn = function testn (bit) {\n assert(typeof bit === 'number' && bit >= 0);\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) return false;\n\n // Check bit and return\n var w = this.words[s];\n\n return !!(w & q);\n };\n\n // Return only lowers bits of number (in-place)\n BN.prototype.imaskn = function imaskn (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n\n assert(this.negative === 0, 'imaskn works only with positive numbers');\n\n if (this.length <= s) {\n return this;\n }\n\n if (r !== 0) {\n s++;\n }\n this.length = Math.min(s, this.length);\n\n if (r !== 0) {\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n this.words[this.length - 1] &= mask;\n }\n\n return this._strip();\n };\n\n // Return only lowers bits of number\n BN.prototype.maskn = function maskn (bits) {\n return this.clone().imaskn(bits);\n };\n\n // Add plain number `num` to `this`\n BN.prototype.iaddn = function iaddn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.isubn(-num);\n\n // Possible sign change\n if (this.negative !== 0) {\n if (this.length === 1 && (this.words[0] | 0) <= num) {\n this.words[0] = num - (this.words[0] | 0);\n this.negative = 0;\n return this;\n }\n\n this.negative = 0;\n this.isubn(num);\n this.negative = 1;\n return this;\n }\n\n // Add without checks\n return this._iaddn(num);\n };\n\n BN.prototype._iaddn = function _iaddn (num) {\n this.words[0] += num;\n\n // Carry\n for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n this.words[i] -= 0x4000000;\n if (i === this.length - 1) {\n this.words[i + 1] = 1;\n } else {\n this.words[i + 1]++;\n }\n }\n this.length = Math.max(this.length, i + 1);\n\n return this;\n };\n\n // Subtract plain number `num` from `this`\n BN.prototype.isubn = function isubn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.iaddn(-num);\n\n if (this.negative !== 0) {\n this.negative = 0;\n this.iaddn(num);\n this.negative = 1;\n return this;\n }\n\n this.words[0] -= num;\n\n if (this.length === 1 && this.words[0] < 0) {\n this.words[0] = -this.words[0];\n this.negative = 1;\n } else {\n // Carry\n for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n this.words[i] += 0x4000000;\n this.words[i + 1] -= 1;\n }\n }\n\n return this._strip();\n };\n\n BN.prototype.addn = function addn (num) {\n return this.clone().iaddn(num);\n };\n\n BN.prototype.subn = function subn (num) {\n return this.clone().isubn(num);\n };\n\n BN.prototype.iabs = function iabs () {\n this.negative = 0;\n\n return this;\n };\n\n BN.prototype.abs = function abs () {\n return this.clone().iabs();\n };\n\n BN.prototype._ishlnsubmul = function _ishlnsubmul (num, mul, shift) {\n var len = num.length + shift;\n var i;\n\n this._expand(len);\n\n var w;\n var carry = 0;\n for (i = 0; i < num.length; i++) {\n w = (this.words[i + shift] | 0) + carry;\n var right = (num.words[i] | 0) * mul;\n w -= right & 0x3ffffff;\n carry = (w >> 26) - ((right / 0x4000000) | 0);\n this.words[i + shift] = w & 0x3ffffff;\n }\n for (; i < this.length - shift; i++) {\n w = (this.words[i + shift] | 0) + carry;\n carry = w >> 26;\n this.words[i + shift] = w & 0x3ffffff;\n }\n\n if (carry === 0) return this._strip();\n\n // Subtraction overflow\n assert(carry === -1);\n carry = 0;\n for (i = 0; i < this.length; i++) {\n w = -(this.words[i] | 0) + carry;\n carry = w >> 26;\n this.words[i] = w & 0x3ffffff;\n }\n this.negative = 1;\n\n return this._strip();\n };\n\n BN.prototype._wordDiv = function _wordDiv (num, mode) {\n var shift = this.length - num.length;\n\n var a = this.clone();\n var b = num;\n\n // Normalize\n var bhi = b.words[b.length - 1] | 0;\n var bhiBits = this._countBits(bhi);\n shift = 26 - bhiBits;\n if (shift !== 0) {\n b = b.ushln(shift);\n a.iushln(shift);\n bhi = b.words[b.length - 1] | 0;\n }\n\n // Initialize quotient\n var m = a.length - b.length;\n var q;\n\n if (mode !== 'mod') {\n q = new BN(null);\n q.length = m + 1;\n q.words = new Array(q.length);\n for (var i = 0; i < q.length; i++) {\n q.words[i] = 0;\n }\n }\n\n var diff = a.clone()._ishlnsubmul(b, 1, m);\n if (diff.negative === 0) {\n a = diff;\n if (q) {\n q.words[m] = 1;\n }\n }\n\n for (var j = m - 1; j >= 0; j--) {\n var qj = (a.words[b.length + j] | 0) * 0x4000000 +\n (a.words[b.length + j - 1] | 0);\n\n // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n // (0x7ffffff)\n qj = Math.min((qj / bhi) | 0, 0x3ffffff);\n\n a._ishlnsubmul(b, qj, j);\n while (a.negative !== 0) {\n qj--;\n a.negative = 0;\n a._ishlnsubmul(b, 1, j);\n if (!a.isZero()) {\n a.negative ^= 1;\n }\n }\n if (q) {\n q.words[j] = qj;\n }\n }\n if (q) {\n q._strip();\n }\n a._strip();\n\n // Denormalize\n if (mode !== 'div' && shift !== 0) {\n a.iushrn(shift);\n }\n\n return {\n div: q || null,\n mod: a\n };\n };\n\n // NOTE: 1) `mode` can be set to `mod` to request mod only,\n // to `div` to request div only, or be absent to\n // request both div & mod\n // 2) `positive` is true if unsigned mod is requested\n BN.prototype.divmod = function divmod (num, mode, positive) {\n assert(!num.isZero());\n\n if (this.isZero()) {\n return {\n div: new BN(0),\n mod: new BN(0)\n };\n }\n\n var div, mod, res;\n if (this.negative !== 0 && num.negative === 0) {\n res = this.neg().divmod(num, mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.iadd(num);\n }\n }\n\n return {\n div: div,\n mod: mod\n };\n }\n\n if (this.negative === 0 && num.negative !== 0) {\n res = this.divmod(num.neg(), mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n return {\n div: div,\n mod: res.mod\n };\n }\n\n if ((this.negative & num.negative) !== 0) {\n res = this.neg().divmod(num.neg(), mode);\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.isub(num);\n }\n }\n\n return {\n div: res.div,\n mod: mod\n };\n }\n\n // Both numbers are positive at this point\n\n // Strip both numbers to approximate shift value\n if (num.length > this.length || this.cmp(num) < 0) {\n return {\n div: new BN(0),\n mod: this\n };\n }\n\n // Very short reduction\n if (num.length === 1) {\n if (mode === 'div') {\n return {\n div: this.divn(num.words[0]),\n mod: null\n };\n }\n\n if (mode === 'mod') {\n return {\n div: null,\n mod: new BN(this.modrn(num.words[0]))\n };\n }\n\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modrn(num.words[0]))\n };\n }\n\n return this._wordDiv(num, mode);\n };\n\n // Find `this` / `num`\n BN.prototype.div = function div (num) {\n return this.divmod(num, 'div', false).div;\n };\n\n // Find `this` % `num`\n BN.prototype.mod = function mod (num) {\n return this.divmod(num, 'mod', false).mod;\n };\n\n BN.prototype.umod = function umod (num) {\n return this.divmod(num, 'mod', true).mod;\n };\n\n // Find Round(`this` / `num`)\n BN.prototype.divRound = function divRound (num) {\n var dm = this.divmod(num);\n\n // Fast case - exact division\n if (dm.mod.isZero()) return dm.div;\n\n var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n\n var half = num.ushrn(1);\n var r2 = num.andln(1);\n var cmp = mod.cmp(half);\n\n // Round down\n if (cmp < 0 || (r2 === 1 && cmp === 0)) return dm.div;\n\n // Round up\n return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n };\n\n BN.prototype.modrn = function modrn (num) {\n var isNegNum = num < 0;\n if (isNegNum) num = -num;\n\n assert(num <= 0x3ffffff);\n var p = (1 << 26) % num;\n\n var acc = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n acc = (p * acc + (this.words[i] | 0)) % num;\n }\n\n return isNegNum ? -acc : acc;\n };\n\n // WARNING: DEPRECATED\n BN.prototype.modn = function modn (num) {\n return this.modrn(num);\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn (num) {\n var isNegNum = num < 0;\n if (isNegNum) num = -num;\n\n assert(num <= 0x3ffffff);\n\n var carry = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var w = (this.words[i] | 0) + carry * 0x4000000;\n this.words[i] = (w / num) | 0;\n carry = w % num;\n }\n\n this._strip();\n return isNegNum ? this.ineg() : this;\n };\n\n BN.prototype.divn = function divn (num) {\n return this.clone().idivn(num);\n };\n\n BN.prototype.egcd = function egcd (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var x = this;\n var y = p.clone();\n\n if (x.negative !== 0) {\n x = x.umod(p);\n } else {\n x = x.clone();\n }\n\n // A * x + B * y = x\n var A = new BN(1);\n var B = new BN(0);\n\n // C * x + D * y = y\n var C = new BN(0);\n var D = new BN(1);\n\n var g = 0;\n\n while (x.isEven() && y.isEven()) {\n x.iushrn(1);\n y.iushrn(1);\n ++g;\n }\n\n var yp = y.clone();\n var xp = x.clone();\n\n while (!x.isZero()) {\n for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n x.iushrn(i);\n while (i-- > 0) {\n if (A.isOdd() || B.isOdd()) {\n A.iadd(yp);\n B.isub(xp);\n }\n\n A.iushrn(1);\n B.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n y.iushrn(j);\n while (j-- > 0) {\n if (C.isOdd() || D.isOdd()) {\n C.iadd(yp);\n D.isub(xp);\n }\n\n C.iushrn(1);\n D.iushrn(1);\n }\n }\n\n if (x.cmp(y) >= 0) {\n x.isub(y);\n A.isub(C);\n B.isub(D);\n } else {\n y.isub(x);\n C.isub(A);\n D.isub(B);\n }\n }\n\n return {\n a: C,\n b: D,\n gcd: y.iushln(g)\n };\n };\n\n // This is reduced incarnation of the binary EEA\n // above, designated to invert members of the\n // _prime_ fields F(p) at a maximal speed\n BN.prototype._invmp = function _invmp (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var a = this;\n var b = p.clone();\n\n if (a.negative !== 0) {\n a = a.umod(p);\n } else {\n a = a.clone();\n }\n\n var x1 = new BN(1);\n var x2 = new BN(0);\n\n var delta = b.clone();\n\n while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n a.iushrn(i);\n while (i-- > 0) {\n if (x1.isOdd()) {\n x1.iadd(delta);\n }\n\n x1.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n b.iushrn(j);\n while (j-- > 0) {\n if (x2.isOdd()) {\n x2.iadd(delta);\n }\n\n x2.iushrn(1);\n }\n }\n\n if (a.cmp(b) >= 0) {\n a.isub(b);\n x1.isub(x2);\n } else {\n b.isub(a);\n x2.isub(x1);\n }\n }\n\n var res;\n if (a.cmpn(1) === 0) {\n res = x1;\n } else {\n res = x2;\n }\n\n if (res.cmpn(0) < 0) {\n res.iadd(p);\n }\n\n return res;\n };\n\n BN.prototype.gcd = function gcd (num) {\n if (this.isZero()) return num.abs();\n if (num.isZero()) return this.abs();\n\n var a = this.clone();\n var b = num.clone();\n a.negative = 0;\n b.negative = 0;\n\n // Remove common factor of two\n for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n a.iushrn(1);\n b.iushrn(1);\n }\n\n do {\n while (a.isEven()) {\n a.iushrn(1);\n }\n while (b.isEven()) {\n b.iushrn(1);\n }\n\n var r = a.cmp(b);\n if (r < 0) {\n // Swap `a` and `b` to make `a` always bigger than `b`\n var t = a;\n a = b;\n b = t;\n } else if (r === 0 || b.cmpn(1) === 0) {\n break;\n }\n\n a.isub(b);\n } while (true);\n\n return b.iushln(shift);\n };\n\n // Invert number in the field F(num)\n BN.prototype.invm = function invm (num) {\n return this.egcd(num).a.umod(num);\n };\n\n BN.prototype.isEven = function isEven () {\n return (this.words[0] & 1) === 0;\n };\n\n BN.prototype.isOdd = function isOdd () {\n return (this.words[0] & 1) === 1;\n };\n\n // And first word and num\n BN.prototype.andln = function andln (num) {\n return this.words[0] & num;\n };\n\n // Increment at the bit position in-line\n BN.prototype.bincn = function bincn (bit) {\n assert(typeof bit === 'number');\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) {\n this._expand(s + 1);\n this.words[s] |= q;\n return this;\n }\n\n // Add bit and propagate, if needed\n var carry = q;\n for (var i = s; carry !== 0 && i < this.length; i++) {\n var w = this.words[i] | 0;\n w += carry;\n carry = w >>> 26;\n w &= 0x3ffffff;\n this.words[i] = w;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n\n BN.prototype.isZero = function isZero () {\n return this.length === 1 && this.words[0] === 0;\n };\n\n BN.prototype.cmpn = function cmpn (num) {\n var negative = num < 0;\n\n if (this.negative !== 0 && !negative) return -1;\n if (this.negative === 0 && negative) return 1;\n\n this._strip();\n\n var res;\n if (this.length > 1) {\n res = 1;\n } else {\n if (negative) {\n num = -num;\n }\n\n assert(num <= 0x3ffffff, 'Number is too big');\n\n var w = this.words[0] | 0;\n res = w === num ? 0 : w < num ? -1 : 1;\n }\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Compare two numbers and return:\n // 1 - if `this` > `num`\n // 0 - if `this` == `num`\n // -1 - if `this` < `num`\n BN.prototype.cmp = function cmp (num) {\n if (this.negative !== 0 && num.negative === 0) return -1;\n if (this.negative === 0 && num.negative !== 0) return 1;\n\n var res = this.ucmp(num);\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Unsigned comparison\n BN.prototype.ucmp = function ucmp (num) {\n // At this point both numbers have the same sign\n if (this.length > num.length) return 1;\n if (this.length < num.length) return -1;\n\n var res = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var a = this.words[i] | 0;\n var b = num.words[i] | 0;\n\n if (a === b) continue;\n if (a < b) {\n res = -1;\n } else if (a > b) {\n res = 1;\n }\n break;\n }\n return res;\n };\n\n BN.prototype.gtn = function gtn (num) {\n return this.cmpn(num) === 1;\n };\n\n BN.prototype.gt = function gt (num) {\n return this.cmp(num) === 1;\n };\n\n BN.prototype.gten = function gten (num) {\n return this.cmpn(num) >= 0;\n };\n\n BN.prototype.gte = function gte (num) {\n return this.cmp(num) >= 0;\n };\n\n BN.prototype.ltn = function ltn (num) {\n return this.cmpn(num) === -1;\n };\n\n BN.prototype.lt = function lt (num) {\n return this.cmp(num) === -1;\n };\n\n BN.prototype.lten = function lten (num) {\n return this.cmpn(num) <= 0;\n };\n\n BN.prototype.lte = function lte (num) {\n return this.cmp(num) <= 0;\n };\n\n BN.prototype.eqn = function eqn (num) {\n return this.cmpn(num) === 0;\n };\n\n BN.prototype.eq = function eq (num) {\n return this.cmp(num) === 0;\n };\n\n //\n // A reduce context, could be using montgomery or something better, depending\n // on the `m` itself.\n //\n BN.red = function red (num) {\n return new Red(num);\n };\n\n BN.prototype.toRed = function toRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n assert(this.negative === 0, 'red works only with positives');\n return ctx.convertTo(this)._forceRed(ctx);\n };\n\n BN.prototype.fromRed = function fromRed () {\n assert(this.red, 'fromRed works only with numbers in reduction context');\n return this.red.convertFrom(this);\n };\n\n BN.prototype._forceRed = function _forceRed (ctx) {\n this.red = ctx;\n return this;\n };\n\n BN.prototype.forceRed = function forceRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n return this._forceRed(ctx);\n };\n\n BN.prototype.redAdd = function redAdd (num) {\n assert(this.red, 'redAdd works only with red numbers');\n return this.red.add(this, num);\n };\n\n BN.prototype.redIAdd = function redIAdd (num) {\n assert(this.red, 'redIAdd works only with red numbers');\n return this.red.iadd(this, num);\n };\n\n BN.prototype.redSub = function redSub (num) {\n assert(this.red, 'redSub works only with red numbers');\n return this.red.sub(this, num);\n };\n\n BN.prototype.redISub = function redISub (num) {\n assert(this.red, 'redISub works only with red numbers');\n return this.red.isub(this, num);\n };\n\n BN.prototype.redShl = function redShl (num) {\n assert(this.red, 'redShl works only with red numbers');\n return this.red.shl(this, num);\n };\n\n BN.prototype.redMul = function redMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.mul(this, num);\n };\n\n BN.prototype.redIMul = function redIMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.imul(this, num);\n };\n\n BN.prototype.redSqr = function redSqr () {\n assert(this.red, 'redSqr works only with red numbers');\n this.red._verify1(this);\n return this.red.sqr(this);\n };\n\n BN.prototype.redISqr = function redISqr () {\n assert(this.red, 'redISqr works only with red numbers');\n this.red._verify1(this);\n return this.red.isqr(this);\n };\n\n // Square root over p\n BN.prototype.redSqrt = function redSqrt () {\n assert(this.red, 'redSqrt works only with red numbers');\n this.red._verify1(this);\n return this.red.sqrt(this);\n };\n\n BN.prototype.redInvm = function redInvm () {\n assert(this.red, 'redInvm works only with red numbers');\n this.red._verify1(this);\n return this.red.invm(this);\n };\n\n // Return negative clone of `this` % `red modulo`\n BN.prototype.redNeg = function redNeg () {\n assert(this.red, 'redNeg works only with red numbers');\n this.red._verify1(this);\n return this.red.neg(this);\n };\n\n BN.prototype.redPow = function redPow (num) {\n assert(this.red && !num.red, 'redPow(normalNum)');\n this.red._verify1(this);\n return this.red.pow(this, num);\n };\n\n // Prime numbers with efficient reduction\n var primes = {\n k256: null,\n p224: null,\n p192: null,\n p25519: null\n };\n\n // Pseudo-Mersenne prime\n function MPrime (name, p) {\n // P = 2 ^ N - K\n this.name = name;\n this.p = new BN(p, 16);\n this.n = this.p.bitLength();\n this.k = new BN(1).iushln(this.n).isub(this.p);\n\n this.tmp = this._tmp();\n }\n\n MPrime.prototype._tmp = function _tmp () {\n var tmp = new BN(null);\n tmp.words = new Array(Math.ceil(this.n / 13));\n return tmp;\n };\n\n MPrime.prototype.ireduce = function ireduce (num) {\n // Assumes that `num` is less than `P^2`\n // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n var r = num;\n var rlen;\n\n do {\n this.split(r, this.tmp);\n r = this.imulK(r);\n r = r.iadd(this.tmp);\n rlen = r.bitLength();\n } while (rlen > this.n);\n\n var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n if (cmp === 0) {\n r.words[0] = 0;\n r.length = 1;\n } else if (cmp > 0) {\n r.isub(this.p);\n } else {\n if (r.strip !== undefined) {\n // r is a BN v4 instance\n r.strip();\n } else {\n // r is a BN v5 instance\n r._strip();\n }\n }\n\n return r;\n };\n\n MPrime.prototype.split = function split (input, out) {\n input.iushrn(this.n, 0, out);\n };\n\n MPrime.prototype.imulK = function imulK (num) {\n return num.imul(this.k);\n };\n\n function K256 () {\n MPrime.call(\n this,\n 'k256',\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n }\n inherits(K256, MPrime);\n\n K256.prototype.split = function split (input, output) {\n // 256 = 9 * 26 + 22\n var mask = 0x3fffff;\n\n var outLen = Math.min(input.length, 9);\n for (var i = 0; i < outLen; i++) {\n output.words[i] = input.words[i];\n }\n output.length = outLen;\n\n if (input.length <= 9) {\n input.words[0] = 0;\n input.length = 1;\n return;\n }\n\n // Shift by 9 limbs\n var prev = input.words[9];\n output.words[output.length++] = prev & mask;\n\n for (i = 10; i < input.length; i++) {\n var next = input.words[i] | 0;\n input.words[i - 10] = ((next & mask) << 4) | (prev >>> 22);\n prev = next;\n }\n prev >>>= 22;\n input.words[i - 10] = prev;\n if (prev === 0 && input.length > 10) {\n input.length -= 10;\n } else {\n input.length -= 9;\n }\n };\n\n K256.prototype.imulK = function imulK (num) {\n // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n num.words[num.length] = 0;\n num.words[num.length + 1] = 0;\n num.length += 2;\n\n // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n var lo = 0;\n for (var i = 0; i < num.length; i++) {\n var w = num.words[i] | 0;\n lo += w * 0x3d1;\n num.words[i] = lo & 0x3ffffff;\n lo = w * 0x40 + ((lo / 0x4000000) | 0);\n }\n\n // Fast length reduction\n if (num.words[num.length - 1] === 0) {\n num.length--;\n if (num.words[num.length - 1] === 0) {\n num.length--;\n }\n }\n return num;\n };\n\n function P224 () {\n MPrime.call(\n this,\n 'p224',\n 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n }\n inherits(P224, MPrime);\n\n function P192 () {\n MPrime.call(\n this,\n 'p192',\n 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n }\n inherits(P192, MPrime);\n\n function P25519 () {\n // 2 ^ 255 - 19\n MPrime.call(\n this,\n '25519',\n '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n }\n inherits(P25519, MPrime);\n\n P25519.prototype.imulK = function imulK (num) {\n // K = 0x13\n var carry = 0;\n for (var i = 0; i < num.length; i++) {\n var hi = (num.words[i] | 0) * 0x13 + carry;\n var lo = hi & 0x3ffffff;\n hi >>>= 26;\n\n num.words[i] = lo;\n carry = hi;\n }\n if (carry !== 0) {\n num.words[num.length++] = carry;\n }\n return num;\n };\n\n // Exported mostly for testing purposes, use plain name instead\n BN._prime = function prime (name) {\n // Cached version of prime\n if (primes[name]) return primes[name];\n\n var prime;\n if (name === 'k256') {\n prime = new K256();\n } else if (name === 'p224') {\n prime = new P224();\n } else if (name === 'p192') {\n prime = new P192();\n } else if (name === 'p25519') {\n prime = new P25519();\n } else {\n throw new Error('Unknown prime ' + name);\n }\n primes[name] = prime;\n\n return prime;\n };\n\n //\n // Base reduction engine\n //\n function Red (m) {\n if (typeof m === 'string') {\n var prime = BN._prime(m);\n this.m = prime.p;\n this.prime = prime;\n } else {\n assert(m.gtn(1), 'modulus must be greater than 1');\n this.m = m;\n this.prime = null;\n }\n }\n\n Red.prototype._verify1 = function _verify1 (a) {\n assert(a.negative === 0, 'red works only with positives');\n assert(a.red, 'red works only with red numbers');\n };\n\n Red.prototype._verify2 = function _verify2 (a, b) {\n assert((a.negative | b.negative) === 0, 'red works only with positives');\n assert(a.red && a.red === b.red,\n 'red works only with red numbers');\n };\n\n Red.prototype.imod = function imod (a) {\n if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n\n move(a, a.umod(this.m)._forceRed(this));\n return a;\n };\n\n Red.prototype.neg = function neg (a) {\n if (a.isZero()) {\n return a.clone();\n }\n\n return this.m.sub(a)._forceRed(this);\n };\n\n Red.prototype.add = function add (a, b) {\n this._verify2(a, b);\n\n var res = a.add(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.iadd = function iadd (a, b) {\n this._verify2(a, b);\n\n var res = a.iadd(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res;\n };\n\n Red.prototype.sub = function sub (a, b) {\n this._verify2(a, b);\n\n var res = a.sub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.isub = function isub (a, b) {\n this._verify2(a, b);\n\n var res = a.isub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res;\n };\n\n Red.prototype.shl = function shl (a, num) {\n this._verify1(a);\n return this.imod(a.ushln(num));\n };\n\n Red.prototype.imul = function imul (a, b) {\n this._verify2(a, b);\n return this.imod(a.imul(b));\n };\n\n Red.prototype.mul = function mul (a, b) {\n this._verify2(a, b);\n return this.imod(a.mul(b));\n };\n\n Red.prototype.isqr = function isqr (a) {\n return this.imul(a, a.clone());\n };\n\n Red.prototype.sqr = function sqr (a) {\n return this.mul(a, a);\n };\n\n Red.prototype.sqrt = function sqrt (a) {\n if (a.isZero()) return a.clone();\n\n var mod3 = this.m.andln(3);\n assert(mod3 % 2 === 1);\n\n // Fast case\n if (mod3 === 3) {\n var pow = this.m.add(new BN(1)).iushrn(2);\n return this.pow(a, pow);\n }\n\n // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n //\n // Find Q and S, that Q * 2 ^ S = (P - 1)\n var q = this.m.subn(1);\n var s = 0;\n while (!q.isZero() && q.andln(1) === 0) {\n s++;\n q.iushrn(1);\n }\n assert(!q.isZero());\n\n var one = new BN(1).toRed(this);\n var nOne = one.redNeg();\n\n // Find quadratic non-residue\n // NOTE: Max is such because of generalized Riemann hypothesis.\n var lpow = this.m.subn(1).iushrn(1);\n var z = this.m.bitLength();\n z = new BN(2 * z * z).toRed(this);\n\n while (this.pow(z, lpow).cmp(nOne) !== 0) {\n z.redIAdd(nOne);\n }\n\n var c = this.pow(z, q);\n var r = this.pow(a, q.addn(1).iushrn(1));\n var t = this.pow(a, q);\n var m = s;\n while (t.cmp(one) !== 0) {\n var tmp = t;\n for (var i = 0; tmp.cmp(one) !== 0; i++) {\n tmp = tmp.redSqr();\n }\n assert(i < m);\n var b = this.pow(c, new BN(1).iushln(m - i - 1));\n\n r = r.redMul(b);\n c = b.redSqr();\n t = t.redMul(c);\n m = i;\n }\n\n return r;\n };\n\n Red.prototype.invm = function invm (a) {\n var inv = a._invmp(this.m);\n if (inv.negative !== 0) {\n inv.negative = 0;\n return this.imod(inv).redNeg();\n } else {\n return this.imod(inv);\n }\n };\n\n Red.prototype.pow = function pow (a, num) {\n if (num.isZero()) return new BN(1).toRed(this);\n if (num.cmpn(1) === 0) return a.clone();\n\n var windowSize = 4;\n var wnd = new Array(1 << windowSize);\n wnd[0] = new BN(1).toRed(this);\n wnd[1] = a;\n for (var i = 2; i < wnd.length; i++) {\n wnd[i] = this.mul(wnd[i - 1], a);\n }\n\n var res = wnd[0];\n var current = 0;\n var currentLen = 0;\n var start = num.bitLength() % 26;\n if (start === 0) {\n start = 26;\n }\n\n for (i = num.length - 1; i >= 0; i--) {\n var word = num.words[i];\n for (var j = start - 1; j >= 0; j--) {\n var bit = (word >> j) & 1;\n if (res !== wnd[0]) {\n res = this.sqr(res);\n }\n\n if (bit === 0 && current === 0) {\n currentLen = 0;\n continue;\n }\n\n current <<= 1;\n current |= bit;\n currentLen++;\n if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n\n res = this.mul(res, wnd[current]);\n currentLen = 0;\n current = 0;\n }\n start = 26;\n }\n\n return res;\n };\n\n Red.prototype.convertTo = function convertTo (num) {\n var r = num.umod(this.m);\n\n return r === num ? r.clone() : r;\n };\n\n Red.prototype.convertFrom = function convertFrom (num) {\n var res = num.clone();\n res.red = null;\n return res;\n };\n\n //\n // Montgomery method engine\n //\n\n BN.mont = function mont (num) {\n return new Mont(num);\n };\n\n function Mont (m) {\n Red.call(this, m);\n\n this.shift = this.m.bitLength();\n if (this.shift % 26 !== 0) {\n this.shift += 26 - (this.shift % 26);\n }\n\n this.r = new BN(1).iushln(this.shift);\n this.r2 = this.imod(this.r.sqr());\n this.rinv = this.r._invmp(this.m);\n\n this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n this.minv = this.minv.umod(this.r);\n this.minv = this.r.sub(this.minv);\n }\n inherits(Mont, Red);\n\n Mont.prototype.convertTo = function convertTo (num) {\n return this.imod(num.ushln(this.shift));\n };\n\n Mont.prototype.convertFrom = function convertFrom (num) {\n var r = this.imod(num.mul(this.rinv));\n r.red = null;\n return r;\n };\n\n Mont.prototype.imul = function imul (a, b) {\n if (a.isZero() || b.isZero()) {\n a.words[0] = 0;\n a.length = 1;\n return a;\n }\n\n var t = a.imul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.mul = function mul (a, b) {\n if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n\n var t = a.mul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.invm = function invm (a) {\n // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n var res = this.imod(a._invmp(this.m).mul(this.r2));\n return res._forceRed(this);\n };\n})(typeof module === 'undefined' || module, this);\n","/*! safe-buffer. MIT License. Feross Aboukhadijeh */\n/* eslint-disable node/no-deprecated-api */\nvar buffer = require('buffer')\nvar Buffer = buffer.Buffer\n\n// alternative to using Object.keys for old browsers\nfunction copyProps (src, dst) {\n for (var key in src) {\n dst[key] = src[key]\n }\n}\nif (Buffer.from && Buffer.alloc && Buffer.allocUnsafe && Buffer.allocUnsafeSlow) {\n module.exports = buffer\n} else {\n // Copy properties from require('buffer')\n copyProps(buffer, exports)\n exports.Buffer = SafeBuffer\n}\n\nfunction SafeBuffer (arg, encodingOrOffset, length) {\n return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.prototype = Object.create(Buffer.prototype)\n\n// Copy static methods from Buffer\ncopyProps(Buffer, SafeBuffer)\n\nSafeBuffer.from = function (arg, encodingOrOffset, length) {\n if (typeof arg === 'number') {\n throw new TypeError('Argument must not be a number')\n }\n return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.alloc = function (size, fill, encoding) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n var buf = Buffer(size)\n if (fill !== undefined) {\n if (typeof encoding === 'string') {\n buf.fill(fill, encoding)\n } else {\n buf.fill(fill)\n }\n } else {\n buf.fill(0)\n }\n return buf\n}\n\nSafeBuffer.allocUnsafe = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return Buffer(size)\n}\n\nSafeBuffer.allocUnsafeSlow = function (size) {\n if (typeof size !== 'number') {\n throw new TypeError('Argument must be a number')\n }\n return buffer.SlowBuffer(size)\n}\n","/**\n * A `StructFailure` represents a single specific failure in validation.\n */\n/**\n * `StructError` objects are thrown (or returned) when validation fails.\n *\n * Validation logic is design to exit early for maximum performance. The error\n * represents the first error encountered during validation. For more detail,\n * the `error.failures` property is a generator function that can be run to\n * continue validation and receive all the failures in the data.\n */\nclass StructError extends TypeError {\n constructor(failure, failures) {\n let cached;\n const { message, explanation, ...rest } = failure;\n const { path } = failure;\n const msg = path.length === 0 ? message : `At path: ${path.join('.')} -- ${message}`;\n super(explanation ?? msg);\n if (explanation != null)\n this.cause = msg;\n Object.assign(this, rest);\n this.name = this.constructor.name;\n this.failures = () => {\n return (cached ?? (cached = [failure, ...failures()]));\n };\n }\n}\n\n/**\n * Check if a value is an iterator.\n */\nfunction isIterable(x) {\n return isObject(x) && typeof x[Symbol.iterator] === 'function';\n}\n/**\n * Check if a value is a plain object.\n */\nfunction isObject(x) {\n return typeof x === 'object' && x != null;\n}\n/**\n * Check if a value is a plain object.\n */\nfunction isPlainObject(x) {\n if (Object.prototype.toString.call(x) !== '[object Object]') {\n return false;\n }\n const prototype = Object.getPrototypeOf(x);\n return prototype === null || prototype === Object.prototype;\n}\n/**\n * Return a value as a printable string.\n */\nfunction print(value) {\n if (typeof value === 'symbol') {\n return value.toString();\n }\n return typeof value === 'string' ? JSON.stringify(value) : `${value}`;\n}\n/**\n * Shifts (removes and returns) the first value from the `input` iterator.\n * Like `Array.prototype.shift()` but for an `Iterator`.\n */\nfunction shiftIterator(input) {\n const { done, value } = input.next();\n return done ? undefined : value;\n}\n/**\n * Convert a single validation result to a failure.\n */\nfunction toFailure(result, context, struct, value) {\n if (result === true) {\n return;\n }\n else if (result === false) {\n result = {};\n }\n else if (typeof result === 'string') {\n result = { message: result };\n }\n const { path, branch } = context;\n const { type } = struct;\n const { refinement, message = `Expected a value of type \\`${type}\\`${refinement ? ` with refinement \\`${refinement}\\`` : ''}, but received: \\`${print(value)}\\``, } = result;\n return {\n value,\n type,\n refinement,\n key: path[path.length - 1],\n path,\n branch,\n ...result,\n message,\n };\n}\n/**\n * Convert a validation result to an iterable of failures.\n */\nfunction* toFailures(result, context, struct, value) {\n if (!isIterable(result)) {\n result = [result];\n }\n for (const r of result) {\n const failure = toFailure(r, context, struct, value);\n if (failure) {\n yield failure;\n }\n }\n}\n/**\n * Check a value against a struct, traversing deeply into nested values, and\n * returning an iterator of failures or success.\n */\nfunction* run(value, struct, options = {}) {\n const { path = [], branch = [value], coerce = false, mask = false } = options;\n const ctx = { path, branch };\n if (coerce) {\n value = struct.coercer(value, ctx);\n if (mask &&\n struct.type !== 'type' &&\n isObject(struct.schema) &&\n isObject(value) &&\n !Array.isArray(value)) {\n for (const key in value) {\n if (struct.schema[key] === undefined) {\n delete value[key];\n }\n }\n }\n }\n let status = 'valid';\n for (const failure of struct.validator(value, ctx)) {\n failure.explanation = options.message;\n status = 'not_valid';\n yield [failure, undefined];\n }\n for (let [k, v, s] of struct.entries(value, ctx)) {\n const ts = run(v, s, {\n path: k === undefined ? path : [...path, k],\n branch: k === undefined ? branch : [...branch, v],\n coerce,\n mask,\n message: options.message,\n });\n for (const t of ts) {\n if (t[0]) {\n status = t[0].refinement != null ? 'not_refined' : 'not_valid';\n yield [t[0], undefined];\n }\n else if (coerce) {\n v = t[1];\n if (k === undefined) {\n value = v;\n }\n else if (value instanceof Map) {\n value.set(k, v);\n }\n else if (value instanceof Set) {\n value.add(v);\n }\n else if (isObject(value)) {\n if (v !== undefined || k in value)\n value[k] = v;\n }\n }\n }\n }\n if (status !== 'not_valid') {\n for (const failure of struct.refiner(value, ctx)) {\n failure.explanation = options.message;\n status = 'not_refined';\n yield [failure, undefined];\n }\n }\n if (status === 'valid') {\n yield [undefined, value];\n }\n}\n\n/**\n * `Struct` objects encapsulate the validation logic for a specific type of\n * values. Once constructed, you use the `assert`, `is` or `validate` helpers to\n * validate unknown input data against the struct.\n */\nclass Struct {\n constructor(props) {\n const { type, schema, validator, refiner, coercer = (value) => value, entries = function* () { }, } = props;\n this.type = type;\n this.schema = schema;\n this.entries = entries;\n this.coercer = coercer;\n if (validator) {\n this.validator = (value, context) => {\n const result = validator(value, context);\n return toFailures(result, context, this, value);\n };\n }\n else {\n this.validator = () => [];\n }\n if (refiner) {\n this.refiner = (value, context) => {\n const result = refiner(value, context);\n return toFailures(result, context, this, value);\n };\n }\n else {\n this.refiner = () => [];\n }\n }\n /**\n * Assert that a value passes the struct's validation, throwing if it doesn't.\n */\n assert(value, message) {\n return assert(value, this, message);\n }\n /**\n * Create a value with the struct's coercion logic, then validate it.\n */\n create(value, message) {\n return create(value, this, message);\n }\n /**\n * Check if a value passes the struct's validation.\n */\n is(value) {\n return is(value, this);\n }\n /**\n * Mask a value, coercing and validating it, but returning only the subset of\n * properties defined by the struct's schema.\n */\n mask(value, message) {\n return mask(value, this, message);\n }\n /**\n * Validate a value with the struct's validation logic, returning a tuple\n * representing the result.\n *\n * You may optionally pass `true` for the `withCoercion` argument to coerce\n * the value before attempting to validate it. If you do, the result will\n * contain the coerced result when successful.\n */\n validate(value, options = {}) {\n return validate(value, this, options);\n }\n}\n/**\n * Assert that a value passes a struct, throwing if it doesn't.\n */\nfunction assert(value, struct, message) {\n const result = validate(value, struct, { message });\n if (result[0]) {\n throw result[0];\n }\n}\n/**\n * Create a value with the coercion logic of struct and validate it.\n */\nfunction create(value, struct, message) {\n const result = validate(value, struct, { coerce: true, message });\n if (result[0]) {\n throw result[0];\n }\n else {\n return result[1];\n }\n}\n/**\n * Mask a value, returning only the subset of properties defined by a struct.\n */\nfunction mask(value, struct, message) {\n const result = validate(value, struct, { coerce: true, mask: true, message });\n if (result[0]) {\n throw result[0];\n }\n else {\n return result[1];\n }\n}\n/**\n * Check if a value passes a struct.\n */\nfunction is(value, struct) {\n const result = validate(value, struct);\n return !result[0];\n}\n/**\n * Validate a value against a struct, returning an error if invalid, or the\n * value (with potential coercion) if valid.\n */\nfunction validate(value, struct, options = {}) {\n const tuples = run(value, struct, options);\n const tuple = shiftIterator(tuples);\n if (tuple[0]) {\n const error = new StructError(tuple[0], function* () {\n for (const t of tuples) {\n if (t[0]) {\n yield t[0];\n }\n }\n });\n return [error, undefined];\n }\n else {\n const v = tuple[1];\n return [undefined, v];\n }\n}\n\nfunction assign(...Structs) {\n const isType = Structs[0].type === 'type';\n const schemas = Structs.map((s) => s.schema);\n const schema = Object.assign({}, ...schemas);\n return isType ? type(schema) : object(schema);\n}\n/**\n * Define a new struct type with a custom validation function.\n */\nfunction define(name, validator) {\n return new Struct({ type: name, schema: null, validator });\n}\n/**\n * Create a new struct based on an existing struct, but the value is allowed to\n * be `undefined`. `log` will be called if the value is not `undefined`.\n */\nfunction deprecated(struct, log) {\n return new Struct({\n ...struct,\n refiner: (value, ctx) => value === undefined || struct.refiner(value, ctx),\n validator(value, ctx) {\n if (value === undefined) {\n return true;\n }\n else {\n log(value, ctx);\n return struct.validator(value, ctx);\n }\n },\n });\n}\n/**\n * Create a struct with dynamic validation logic.\n *\n * The callback will receive the value currently being validated, and must\n * return a struct object to validate it with. This can be useful to model\n * validation logic that changes based on its input.\n */\nfunction dynamic(fn) {\n return new Struct({\n type: 'dynamic',\n schema: null,\n *entries(value, ctx) {\n const struct = fn(value, ctx);\n yield* struct.entries(value, ctx);\n },\n validator(value, ctx) {\n const struct = fn(value, ctx);\n return struct.validator(value, ctx);\n },\n coercer(value, ctx) {\n const struct = fn(value, ctx);\n return struct.coercer(value, ctx);\n },\n refiner(value, ctx) {\n const struct = fn(value, ctx);\n return struct.refiner(value, ctx);\n },\n });\n}\n/**\n * Create a struct with lazily evaluated validation logic.\n *\n * The first time validation is run with the struct, the callback will be called\n * and must return a struct object to use. This is useful for cases where you\n * want to have self-referential structs for nested data structures to avoid a\n * circular definition problem.\n */\nfunction lazy(fn) {\n let struct;\n return new Struct({\n type: 'lazy',\n schema: null,\n *entries(value, ctx) {\n struct ?? (struct = fn());\n yield* struct.entries(value, ctx);\n },\n validator(value, ctx) {\n struct ?? (struct = fn());\n return struct.validator(value, ctx);\n },\n coercer(value, ctx) {\n struct ?? (struct = fn());\n return struct.coercer(value, ctx);\n },\n refiner(value, ctx) {\n struct ?? (struct = fn());\n return struct.refiner(value, ctx);\n },\n });\n}\n/**\n * Create a new struct based on an existing object struct, but excluding\n * specific properties.\n *\n * Like TypeScript's `Omit` utility.\n */\nfunction omit(struct, keys) {\n const { schema } = struct;\n const subschema = { ...schema };\n for (const key of keys) {\n delete subschema[key];\n }\n switch (struct.type) {\n case 'type':\n return type(subschema);\n default:\n return object(subschema);\n }\n}\n/**\n * Create a new struct based on an existing object struct, but with all of its\n * properties allowed to be `undefined`.\n *\n * Like TypeScript's `Partial` utility.\n */\nfunction partial(struct) {\n const isStruct = struct instanceof Struct;\n const schema = isStruct ? { ...struct.schema } : { ...struct };\n for (const key in schema) {\n schema[key] = optional(schema[key]);\n }\n if (isStruct && struct.type === 'type') {\n return type(schema);\n }\n return object(schema);\n}\n/**\n * Create a new struct based on an existing object struct, but only including\n * specific properties.\n *\n * Like TypeScript's `Pick` utility.\n */\nfunction pick(struct, keys) {\n const { schema } = struct;\n const subschema = {};\n for (const key of keys) {\n subschema[key] = schema[key];\n }\n switch (struct.type) {\n case 'type':\n return type(subschema);\n default:\n return object(subschema);\n }\n}\n/**\n * Define a new struct type with a custom validation function.\n *\n * @deprecated This function has been renamed to `define`.\n */\nfunction struct(name, validator) {\n console.warn('superstruct@0.11 - The `struct` helper has been renamed to `define`.');\n return define(name, validator);\n}\n\n/**\n * Ensure that any value passes validation.\n */\nfunction any() {\n return define('any', () => true);\n}\nfunction array(Element) {\n return new Struct({\n type: 'array',\n schema: Element,\n *entries(value) {\n if (Element && Array.isArray(value)) {\n for (const [i, v] of value.entries()) {\n yield [i, v, Element];\n }\n }\n },\n coercer(value) {\n return Array.isArray(value) ? value.slice() : value;\n },\n validator(value) {\n return (Array.isArray(value) ||\n `Expected an array value, but received: ${print(value)}`);\n },\n });\n}\n/**\n * Ensure that a value is a bigint.\n */\nfunction bigint() {\n return define('bigint', (value) => {\n return typeof value === 'bigint';\n });\n}\n/**\n * Ensure that a value is a boolean.\n */\nfunction boolean() {\n return define('boolean', (value) => {\n return typeof value === 'boolean';\n });\n}\n/**\n * Ensure that a value is a valid `Date`.\n *\n * Note: this also ensures that the value is *not* an invalid `Date` object,\n * which can occur when parsing a date fails but still returns a `Date`.\n */\nfunction date() {\n return define('date', (value) => {\n return ((value instanceof Date && !isNaN(value.getTime())) ||\n `Expected a valid \\`Date\\` object, but received: ${print(value)}`);\n });\n}\nfunction enums(values) {\n const schema = {};\n const description = values.map((v) => print(v)).join();\n for (const key of values) {\n schema[key] = key;\n }\n return new Struct({\n type: 'enums',\n schema,\n validator(value) {\n return (values.includes(value) ||\n `Expected one of \\`${description}\\`, but received: ${print(value)}`);\n },\n });\n}\n/**\n * Ensure that a value is a function.\n */\nfunction func() {\n return define('func', (value) => {\n return (typeof value === 'function' ||\n `Expected a function, but received: ${print(value)}`);\n });\n}\n/**\n * Ensure that a value is an instance of a specific class.\n */\nfunction instance(Class) {\n return define('instance', (value) => {\n return (value instanceof Class ||\n `Expected a \\`${Class.name}\\` instance, but received: ${print(value)}`);\n });\n}\n/**\n * Ensure that a value is an integer.\n */\nfunction integer() {\n return define('integer', (value) => {\n return ((typeof value === 'number' && !isNaN(value) && Number.isInteger(value)) ||\n `Expected an integer, but received: ${print(value)}`);\n });\n}\n/**\n * Ensure that a value matches all of a set of types.\n */\nfunction intersection(Structs) {\n return new Struct({\n type: 'intersection',\n schema: null,\n *entries(value, ctx) {\n for (const S of Structs) {\n yield* S.entries(value, ctx);\n }\n },\n *validator(value, ctx) {\n for (const S of Structs) {\n yield* S.validator(value, ctx);\n }\n },\n *refiner(value, ctx) {\n for (const S of Structs) {\n yield* S.refiner(value, ctx);\n }\n },\n });\n}\nfunction literal(constant) {\n const description = print(constant);\n const t = typeof constant;\n return new Struct({\n type: 'literal',\n schema: t === 'string' || t === 'number' || t === 'boolean' ? constant : null,\n validator(value) {\n return (value === constant ||\n `Expected the literal \\`${description}\\`, but received: ${print(value)}`);\n },\n });\n}\nfunction map(Key, Value) {\n return new Struct({\n type: 'map',\n schema: null,\n *entries(value) {\n if (Key && Value && value instanceof Map) {\n for (const [k, v] of value.entries()) {\n yield [k, k, Key];\n yield [k, v, Value];\n }\n }\n },\n coercer(value) {\n return value instanceof Map ? new Map(value) : value;\n },\n validator(value) {\n return (value instanceof Map ||\n `Expected a \\`Map\\` object, but received: ${print(value)}`);\n },\n });\n}\n/**\n * Ensure that no value ever passes validation.\n */\nfunction never() {\n return define('never', () => false);\n}\n/**\n * Augment an existing struct to allow `null` values.\n */\nfunction nullable(struct) {\n return new Struct({\n ...struct,\n validator: (value, ctx) => value === null || struct.validator(value, ctx),\n refiner: (value, ctx) => value === null || struct.refiner(value, ctx),\n });\n}\n/**\n * Ensure that a value is a number.\n */\nfunction number() {\n return define('number', (value) => {\n return ((typeof value === 'number' && !isNaN(value)) ||\n `Expected a number, but received: ${print(value)}`);\n });\n}\nfunction object(schema) {\n const knowns = schema ? Object.keys(schema) : [];\n const Never = never();\n return new Struct({\n type: 'object',\n schema: schema ? schema : null,\n *entries(value) {\n if (schema && isObject(value)) {\n const unknowns = new Set(Object.keys(value));\n for (const key of knowns) {\n unknowns.delete(key);\n yield [key, value[key], schema[key]];\n }\n for (const key of unknowns) {\n yield [key, value[key], Never];\n }\n }\n },\n validator(value) {\n return (isObject(value) || `Expected an object, but received: ${print(value)}`);\n },\n coercer(value) {\n return isObject(value) ? { ...value } : value;\n },\n });\n}\n/**\n * Augment a struct to allow `undefined` values.\n */\nfunction optional(struct) {\n return new Struct({\n ...struct,\n validator: (value, ctx) => value === undefined || struct.validator(value, ctx),\n refiner: (value, ctx) => value === undefined || struct.refiner(value, ctx),\n });\n}\n/**\n * Ensure that a value is an object with keys and values of specific types, but\n * without ensuring any specific shape of properties.\n *\n * Like TypeScript's `Record` utility.\n */\nfunction record(Key, Value) {\n return new Struct({\n type: 'record',\n schema: null,\n *entries(value) {\n if (isObject(value)) {\n for (const k in value) {\n const v = value[k];\n yield [k, k, Key];\n yield [k, v, Value];\n }\n }\n },\n validator(value) {\n return (isObject(value) || `Expected an object, but received: ${print(value)}`);\n },\n });\n}\n/**\n * Ensure that a value is a `RegExp`.\n *\n * Note: this does not test the value against the regular expression! For that\n * you need to use the `pattern()` refinement.\n */\nfunction regexp() {\n return define('regexp', (value) => {\n return value instanceof RegExp;\n });\n}\nfunction set(Element) {\n return new Struct({\n type: 'set',\n schema: null,\n *entries(value) {\n if (Element && value instanceof Set) {\n for (const v of value) {\n yield [v, v, Element];\n }\n }\n },\n coercer(value) {\n return value instanceof Set ? new Set(value) : value;\n },\n validator(value) {\n return (value instanceof Set ||\n `Expected a \\`Set\\` object, but received: ${print(value)}`);\n },\n });\n}\n/**\n * Ensure that a value is a string.\n */\nfunction string() {\n return define('string', (value) => {\n return (typeof value === 'string' ||\n `Expected a string, but received: ${print(value)}`);\n });\n}\n/**\n * Ensure that a value is a tuple of a specific length, and that each of its\n * elements is of a specific type.\n */\nfunction tuple(Structs) {\n const Never = never();\n return new Struct({\n type: 'tuple',\n schema: null,\n *entries(value) {\n if (Array.isArray(value)) {\n const length = Math.max(Structs.length, value.length);\n for (let i = 0; i < length; i++) {\n yield [i, value[i], Structs[i] || Never];\n }\n }\n },\n validator(value) {\n return (Array.isArray(value) ||\n `Expected an array, but received: ${print(value)}`);\n },\n });\n}\n/**\n * Ensure that a value has a set of known properties of specific types.\n *\n * Note: Unrecognized properties are allowed and untouched. This is similar to\n * how TypeScript's structural typing works.\n */\nfunction type(schema) {\n const keys = Object.keys(schema);\n return new Struct({\n type: 'type',\n schema,\n *entries(value) {\n if (isObject(value)) {\n for (const k of keys) {\n yield [k, value[k], schema[k]];\n }\n }\n },\n validator(value) {\n return (isObject(value) || `Expected an object, but received: ${print(value)}`);\n },\n coercer(value) {\n return isObject(value) ? { ...value } : value;\n },\n });\n}\n/**\n * Ensure that a value matches one of a set of types.\n */\nfunction union(Structs) {\n const description = Structs.map((s) => s.type).join(' | ');\n return new Struct({\n type: 'union',\n schema: null,\n coercer(value) {\n for (const S of Structs) {\n const [error, coerced] = S.validate(value, { coerce: true });\n if (!error) {\n return coerced;\n }\n }\n return value;\n },\n validator(value, ctx) {\n const failures = [];\n for (const S of Structs) {\n const [...tuples] = run(value, S, ctx);\n const [first] = tuples;\n if (!first[0]) {\n return [];\n }\n else {\n for (const [failure] of tuples) {\n if (failure) {\n failures.push(failure);\n }\n }\n }\n }\n return [\n `Expected the value to satisfy a union of \\`${description}\\`, but received: ${print(value)}`,\n ...failures,\n ];\n },\n });\n}\n/**\n * Ensure that any value passes validation, without widening its type to `any`.\n */\nfunction unknown() {\n return define('unknown', () => true);\n}\n\n/**\n * Augment a `Struct` to add an additional coercion step to its input.\n *\n * This allows you to transform input data before validating it, to increase the\n * likelihood that it passes validation—for example for default values, parsing\n * different formats, etc.\n *\n * Note: You must use `create(value, Struct)` on the value to have the coercion\n * take effect! Using simply `assert()` or `is()` will not use coercion.\n */\nfunction coerce(struct, condition, coercer) {\n return new Struct({\n ...struct,\n coercer: (value, ctx) => {\n return is(value, condition)\n ? struct.coercer(coercer(value, ctx), ctx)\n : struct.coercer(value, ctx);\n },\n });\n}\n/**\n * Augment a struct to replace `undefined` values with a default.\n *\n * Note: You must use `create(value, Struct)` on the value to have the coercion\n * take effect! Using simply `assert()` or `is()` will not use coercion.\n */\nfunction defaulted(struct, fallback, options = {}) {\n return coerce(struct, unknown(), (x) => {\n const f = typeof fallback === 'function' ? fallback() : fallback;\n if (x === undefined) {\n return f;\n }\n if (!options.strict && isPlainObject(x) && isPlainObject(f)) {\n const ret = { ...x };\n let changed = false;\n for (const key in f) {\n if (ret[key] === undefined) {\n ret[key] = f[key];\n changed = true;\n }\n }\n if (changed) {\n return ret;\n }\n }\n return x;\n });\n}\n/**\n * Augment a struct to trim string inputs.\n *\n * Note: You must use `create(value, Struct)` on the value to have the coercion\n * take effect! Using simply `assert()` or `is()` will not use coercion.\n */\nfunction trimmed(struct) {\n return coerce(struct, string(), (x) => x.trim());\n}\n\n/**\n * Ensure that a string, array, map, or set is empty.\n */\nfunction empty(struct) {\n return refine(struct, 'empty', (value) => {\n const size = getSize(value);\n return (size === 0 ||\n `Expected an empty ${struct.type} but received one with a size of \\`${size}\\``);\n });\n}\nfunction getSize(value) {\n if (value instanceof Map || value instanceof Set) {\n return value.size;\n }\n else {\n return value.length;\n }\n}\n/**\n * Ensure that a number or date is below a threshold.\n */\nfunction max(struct, threshold, options = {}) {\n const { exclusive } = options;\n return refine(struct, 'max', (value) => {\n return exclusive\n ? value < threshold\n : value <= threshold ||\n `Expected a ${struct.type} less than ${exclusive ? '' : 'or equal to '}${threshold} but received \\`${value}\\``;\n });\n}\n/**\n * Ensure that a number or date is above a threshold.\n */\nfunction min(struct, threshold, options = {}) {\n const { exclusive } = options;\n return refine(struct, 'min', (value) => {\n return exclusive\n ? value > threshold\n : value >= threshold ||\n `Expected a ${struct.type} greater than ${exclusive ? '' : 'or equal to '}${threshold} but received \\`${value}\\``;\n });\n}\n/**\n * Ensure that a string, array, map or set is not empty.\n */\nfunction nonempty(struct) {\n return refine(struct, 'nonempty', (value) => {\n const size = getSize(value);\n return (size > 0 || `Expected a nonempty ${struct.type} but received an empty one`);\n });\n}\n/**\n * Ensure that a string matches a regular expression.\n */\nfunction pattern(struct, regexp) {\n return refine(struct, 'pattern', (value) => {\n return (regexp.test(value) ||\n `Expected a ${struct.type} matching \\`/${regexp.source}/\\` but received \"${value}\"`);\n });\n}\n/**\n * Ensure that a string, array, number, date, map, or set has a size (or length, or time) between `min` and `max`.\n */\nfunction size(struct, min, max = min) {\n const expected = `Expected a ${struct.type}`;\n const of = min === max ? `of \\`${min}\\`` : `between \\`${min}\\` and \\`${max}\\``;\n return refine(struct, 'size', (value) => {\n if (typeof value === 'number' || value instanceof Date) {\n return ((min <= value && value <= max) ||\n `${expected} ${of} but received \\`${value}\\``);\n }\n else if (value instanceof Map || value instanceof Set) {\n const { size } = value;\n return ((min <= size && size <= max) ||\n `${expected} with a size ${of} but received one with a size of \\`${size}\\``);\n }\n else {\n const { length } = value;\n return ((min <= length && length <= max) ||\n `${expected} with a length ${of} but received one with a length of \\`${length}\\``);\n }\n });\n}\n/**\n * Augment a `Struct` to add an additional refinement to the validation.\n *\n * The refiner function is guaranteed to receive a value of the struct's type,\n * because the struct's existing validation will already have passed. This\n * allows you to layer additional validation on top of existing structs.\n */\nfunction refine(struct, name, refiner) {\n return new Struct({\n ...struct,\n *refiner(value, ctx) {\n yield* struct.refiner(value, ctx);\n const result = refiner(value, ctx);\n const failures = toFailures(result, ctx, struct, value);\n for (const failure of failures) {\n yield { ...failure, refinement: name };\n }\n },\n });\n}\n\nexport { Struct, StructError, any, array, assert, assign, bigint, boolean, coerce, create, date, defaulted, define, deprecated, dynamic, empty, enums, func, instance, integer, intersection, is, lazy, literal, map, mask, max, min, never, nonempty, nullable, number, object, omit, optional, partial, pattern, pick, record, refine, regexp, set, size, string, struct, trimmed, tuple, type, union, unknown, validate };\n//# sourceMappingURL=index.mjs.map\n"],"names":["module","exports","assert","val","msg","inherits","ctor","superCtor","super_","TempCtor","prototype","constructor","BN","number","base","endian","isBN","negative","words","length","red","_init","wordSize","Buffer","window","__webpack_require__","e","parseHex4Bits","string","index","c","charCodeAt","parseHexByte","lowerBound","r","parseBase","str","start","end","mul","b","len","Math","min","i","move","dest","src","num","Array","isArray","max","left","right","cmp","_initNumber","_initArray","toString","replace","_parseHex","_parseBase","toArray","ceil","j","w","off","_strip","parseLength","limbLen","limbPow","total","mod","word","imuln","_iaddn","pow","copy","_move","clone","_expand","size","_normSign","Symbol","for","inspect","zeros","groupSizes","groupBases","smallMulTo","self","out","a","lo","carry","k","ncarry","rword","maxJ","padding","groupSize","groupBase","isZero","modrn","idivn","toNumber","ret","toJSON","toBuffer","toArrayLike","ArrayType","byteLength","reqLength","res","allocUnsafe","_toArrayLikeLE","position","shift","_toArrayLikeBE","clz32","_countBits","t","_zeroBits","bitLength","hi","zeroBits","toTwos","width","abs","inotn","iaddn","fromTwos","testn","notn","ineg","isNeg","neg","iuor","ior","or","uor","iuand","iand","and","uand","iuxor","ixor","xor","uxor","bytesNeeded","bitsLeft","setn","bit","wbit","iadd","isub","add","sub","comb10MulTo","mid","o","a0","al0","ah0","a1","al1","ah1","a2","al2","ah2","a3","al3","ah3","a4","al4","ah4","a5","al5","ah5","a6","al6","ah6","a7","al7","ah7","a8","al8","ah8","a9","al9","ah9","b0","bl0","bh0","b1","bl1","bh1","b2","bl2","bh2","b3","bl3","bh3","b4","bl4","bh4","b5","bl5","bh5","b6","bl6","bh6","b7","bl7","bh7","b8","bl8","bh8","b9","bl9","bh9","w0","imul","w1","w2","w3","w4","w5","w6","w7","w8","w9","w10","w11","w12","w13","w14","w15","w16","w17","w18","bigMulTo","hncarry","FFTM","x","y","mulTo","makeRBT","N","l","revBin","rb","permute","rbt","rws","iws","rtws","itws","transform","s","rtwdf","cos","PI","itwdf","sin","p","rtwdf_","itwdf_","re","ie","ro","io","rx","guessLen13b","n","m","odd","conjugate","normalize13b","ws","round","convert13b","stub","ph","mulp","_","rwst","iwst","nrws","nrwst","niwst","rmws","mulf","isNegNum","muln","sqr","isqr","toBitArray","q","iushln","bits","carryMask","newCarry","ishln","iushrn","hint","extended","h","mask","maskedWords","ishrn","shln","ushln","shrn","ushrn","imaskn","maskn","isubn","addn","subn","iabs","_ishlnsubmul","_wordDiv","mode","bhi","diff","qj","div","divmod","positive","divn","umod","divRound","dm","half","r2","andln","acc","modn","egcd","A","B","C","D","g","isEven","yp","xp","im","isOdd","jm","gcd","_invmp","x1","x2","delta","cmpn","invm","bincn","ucmp","gtn","gt","gten","gte","ltn","lt","lten","lte","eqn","eq","Red","toRed","ctx","convertTo","_forceRed","fromRed","convertFrom","forceRed","redAdd","redIAdd","redSub","redISub","redShl","shl","redMul","_verify2","redIMul","redSqr","_verify1","redISqr","redSqrt","sqrt","redInvm","redNeg","redPow","primes","k256","p224","p192","p25519","MPrime","name","tmp","_tmp","K256","call","P224","P192","P25519","prime","_prime","Mont","imod","rinv","minv","ireduce","rlen","split","imulK","undefined","strip","input","output","outLen","prev","next","mod3","one","nOne","lpow","z","inv","wnd","current","currentLen","mont","u","buffer","copyProps","dst","key","SafeBuffer","arg","encodingOrOffset","from","alloc","allocUnsafeSlow","Object","create","fill","encoding","buf","SlowBuffer","StructError","TypeError","failure","failures","cached","message","explanation","rest","path","join","cause","assign","isObject","isPlainObject","getPrototypeOf","print","value","JSON","stringify","toFailures","result","context","struct","iterator","toFailure","branch","type","refinement","run","options","coerce","coercer","schema","status","validator","v","entries","Map","set","Set","refiner","Struct","props","is","validate","tuples","tuple","shiftIterator","done","Structs","isType","map","object","define","deprecated","log","dynamic","fn","lazy","omit","keys","subschema","partial","isStruct","optional","pick","console","warn","any","array","Element","slice","bigint","boolean","date","Date","isNaN","getTime","enums","values","description","includes","func","instance","Class","integer","Number","isInteger","intersection","S","literal","constant","Key","Value","never","nullable","knowns","Never","unknowns","delete","record","regexp","RegExp","union","error","coerced","first","push","unknown","condition","defaulted","fallback","f","strict","changed","trimmed","trim","empty","refine","getSize","threshold","exclusive","nonempty","pattern","test","source","expected","of"],"sourceRoot":""}