{"version":3,"file":"js/chunk-vendors-b49fab05.1457c975.js","mappings":"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","sources":["webpack://com.crmtogether.mobilexcrm/./node_modules/isarray/index.js","webpack://com.crmtogether.mobilexcrm/./node_modules/md5.js/index.js","webpack://com.crmtogether.mobilexcrm/./node_modules/miller-rabin/lib/mr.js","webpack://com.crmtogether.mobilexcrm/./node_modules/miller-rabin/node_modules/bn.js/lib/bn.js","webpack://com.crmtogether.mobilexcrm/./node_modules/minimalistic-assert/index.js","webpack://com.crmtogether.mobilexcrm/./node_modules/minimalistic-crypto-utils/lib/utils.js"],"sourcesContent":["var toString = {}.toString;\n\nmodule.exports = Array.isArray || function (arr) {\n return toString.call(arr) == '[object Array]';\n};\n","'use strict'\nvar inherits = require('inherits')\nvar HashBase = require('hash-base')\nvar Buffer = require('safe-buffer').Buffer\n\nvar ARRAY16 = new Array(16)\n\nfunction MD5 () {\n HashBase.call(this, 64)\n\n // state\n this._a = 0x67452301\n this._b = 0xefcdab89\n this._c = 0x98badcfe\n this._d = 0x10325476\n}\n\ninherits(MD5, HashBase)\n\nMD5.prototype._update = function () {\n var M = ARRAY16\n for (var i = 0; i < 16; ++i) M[i] = this._block.readInt32LE(i * 4)\n\n var a = this._a\n var b = this._b\n var c = this._c\n var d = this._d\n\n a = fnF(a, b, c, d, M[0], 0xd76aa478, 7)\n d = fnF(d, a, b, c, M[1], 0xe8c7b756, 12)\n c = fnF(c, d, a, b, M[2], 0x242070db, 17)\n b = fnF(b, c, d, a, M[3], 0xc1bdceee, 22)\n a = fnF(a, b, c, d, M[4], 0xf57c0faf, 7)\n d = fnF(d, a, b, c, M[5], 0x4787c62a, 12)\n c = fnF(c, d, a, b, M[6], 0xa8304613, 17)\n b = fnF(b, c, d, a, M[7], 0xfd469501, 22)\n a = fnF(a, b, c, d, M[8], 0x698098d8, 7)\n d = fnF(d, a, b, c, M[9], 0x8b44f7af, 12)\n c = fnF(c, d, a, b, M[10], 0xffff5bb1, 17)\n b = fnF(b, c, d, a, M[11], 0x895cd7be, 22)\n a = fnF(a, b, c, d, M[12], 0x6b901122, 7)\n d = fnF(d, a, b, c, M[13], 0xfd987193, 12)\n c = fnF(c, d, a, b, M[14], 0xa679438e, 17)\n b = fnF(b, c, d, a, M[15], 0x49b40821, 22)\n\n a = fnG(a, b, c, d, M[1], 0xf61e2562, 5)\n d = fnG(d, a, b, c, M[6], 0xc040b340, 9)\n c = fnG(c, d, a, b, M[11], 0x265e5a51, 14)\n b = fnG(b, c, d, a, M[0], 0xe9b6c7aa, 20)\n a = fnG(a, b, c, d, M[5], 0xd62f105d, 5)\n d = fnG(d, a, b, c, M[10], 0x02441453, 9)\n c = fnG(c, d, a, b, M[15], 0xd8a1e681, 14)\n b = fnG(b, c, d, a, M[4], 0xe7d3fbc8, 20)\n a = fnG(a, b, c, d, M[9], 0x21e1cde6, 5)\n d = fnG(d, a, b, c, M[14], 0xc33707d6, 9)\n c = fnG(c, d, a, b, M[3], 0xf4d50d87, 14)\n b = fnG(b, c, d, a, M[8], 0x455a14ed, 20)\n a = fnG(a, b, c, d, M[13], 0xa9e3e905, 5)\n d = fnG(d, a, b, c, M[2], 0xfcefa3f8, 9)\n c = fnG(c, d, a, b, M[7], 0x676f02d9, 14)\n b = fnG(b, c, d, a, M[12], 0x8d2a4c8a, 20)\n\n a = fnH(a, b, c, d, M[5], 0xfffa3942, 4)\n d = fnH(d, a, b, c, M[8], 0x8771f681, 11)\n c = fnH(c, d, a, b, M[11], 0x6d9d6122, 16)\n b = fnH(b, c, d, a, M[14], 0xfde5380c, 23)\n a = fnH(a, b, c, d, M[1], 0xa4beea44, 4)\n d = fnH(d, a, b, c, M[4], 0x4bdecfa9, 11)\n c = fnH(c, d, a, b, M[7], 0xf6bb4b60, 16)\n b = fnH(b, c, d, a, M[10], 0xbebfbc70, 23)\n a = fnH(a, b, c, d, M[13], 0x289b7ec6, 4)\n d = fnH(d, a, b, c, M[0], 0xeaa127fa, 11)\n c = fnH(c, d, a, b, M[3], 0xd4ef3085, 16)\n b = fnH(b, c, d, a, M[6], 0x04881d05, 23)\n a = fnH(a, b, c, d, M[9], 0xd9d4d039, 4)\n d = fnH(d, a, b, c, M[12], 0xe6db99e5, 11)\n c = fnH(c, d, a, b, M[15], 0x1fa27cf8, 16)\n b = fnH(b, c, d, a, M[2], 0xc4ac5665, 23)\n\n a = fnI(a, b, c, d, M[0], 0xf4292244, 6)\n d = fnI(d, a, b, c, M[7], 0x432aff97, 10)\n c = fnI(c, d, a, b, M[14], 0xab9423a7, 15)\n b = fnI(b, c, d, a, M[5], 0xfc93a039, 21)\n a = fnI(a, b, c, d, M[12], 0x655b59c3, 6)\n d = fnI(d, a, b, c, M[3], 0x8f0ccc92, 10)\n c = fnI(c, d, a, b, M[10], 0xffeff47d, 15)\n b = fnI(b, c, d, a, M[1], 0x85845dd1, 21)\n a = fnI(a, b, c, d, M[8], 0x6fa87e4f, 6)\n d = fnI(d, a, b, c, M[15], 0xfe2ce6e0, 10)\n c = fnI(c, d, a, b, M[6], 0xa3014314, 15)\n b = fnI(b, c, d, a, M[13], 0x4e0811a1, 21)\n a = fnI(a, b, c, d, M[4], 0xf7537e82, 6)\n d = fnI(d, a, b, c, M[11], 0xbd3af235, 10)\n c = fnI(c, d, a, b, M[2], 0x2ad7d2bb, 15)\n b = fnI(b, c, d, a, M[9], 0xeb86d391, 21)\n\n this._a = (this._a + a) | 0\n this._b = (this._b + b) | 0\n this._c = (this._c + c) | 0\n this._d = (this._d + d) | 0\n}\n\nMD5.prototype._digest = function () {\n // create padding and handle blocks\n this._block[this._blockOffset++] = 0x80\n if (this._blockOffset > 56) {\n this._block.fill(0, this._blockOffset, 64)\n this._update()\n this._blockOffset = 0\n }\n\n this._block.fill(0, this._blockOffset, 56)\n this._block.writeUInt32LE(this._length[0], 56)\n this._block.writeUInt32LE(this._length[1], 60)\n this._update()\n\n // produce result\n var buffer = Buffer.allocUnsafe(16)\n buffer.writeInt32LE(this._a, 0)\n buffer.writeInt32LE(this._b, 4)\n buffer.writeInt32LE(this._c, 8)\n buffer.writeInt32LE(this._d, 12)\n return buffer\n}\n\nfunction rotl (x, n) {\n return (x << n) | (x >>> (32 - n))\n}\n\nfunction fnF (a, b, c, d, m, k, s) {\n return (rotl((a + ((b & c) | ((~b) & d)) + m + k) | 0, s) + b) | 0\n}\n\nfunction fnG (a, b, c, d, m, k, s) {\n return (rotl((a + ((b & d) | (c & (~d))) + m + k) | 0, s) + b) | 0\n}\n\nfunction fnH (a, b, c, d, m, k, s) {\n return (rotl((a + (b ^ c ^ d) + m + k) | 0, s) + b) | 0\n}\n\nfunction fnI (a, b, c, d, m, k, s) {\n return (rotl((a + ((c ^ (b | (~d)))) + m + k) | 0, s) + b) | 0\n}\n\nmodule.exports = MD5\n","var bn = require('bn.js');\nvar brorand = require('brorand');\n\nfunction MillerRabin(rand) {\n this.rand = rand || new brorand.Rand();\n}\nmodule.exports = MillerRabin;\n\nMillerRabin.create = function create(rand) {\n return new MillerRabin(rand);\n};\n\nMillerRabin.prototype._randbelow = function _randbelow(n) {\n var len = n.bitLength();\n var min_bytes = Math.ceil(len / 8);\n\n // Generage random bytes until a number less than n is found.\n // This ensures that 0..n-1 have an equal probability of being selected.\n do\n var a = new bn(this.rand.generate(min_bytes));\n while (a.cmp(n) >= 0);\n\n return a;\n};\n\nMillerRabin.prototype._randrange = function _randrange(start, stop) {\n // Generate a random number greater than or equal to start and less than stop.\n var size = stop.sub(start);\n return start.add(this._randbelow(size));\n};\n\nMillerRabin.prototype.test = function test(n, k, cb) {\n var len = n.bitLength();\n var red = bn.mont(n);\n var rone = new bn(1).toRed(red);\n\n if (!k)\n k = Math.max(1, (len / 48) | 0);\n\n // Find d and s, (n - 1) = (2 ^ s) * d;\n var n1 = n.subn(1);\n for (var s = 0; !n1.testn(s); s++) {}\n var d = n.shrn(s);\n\n var rn1 = n1.toRed(red);\n\n var prime = true;\n for (; k > 0; k--) {\n var a = this._randrange(new bn(2), n1);\n if (cb)\n cb(a);\n\n var x = a.toRed(red).redPow(d);\n if (x.cmp(rone) === 0 || x.cmp(rn1) === 0)\n continue;\n\n for (var i = 1; i < s; i++) {\n x = x.redSqr();\n\n if (x.cmp(rone) === 0)\n return false;\n if (x.cmp(rn1) === 0)\n break;\n }\n\n if (i === s)\n return false;\n }\n\n return prime;\n};\n\nMillerRabin.prototype.getDivisor = function getDivisor(n, k) {\n var len = n.bitLength();\n var red = bn.mont(n);\n var rone = new bn(1).toRed(red);\n\n if (!k)\n k = Math.max(1, (len / 48) | 0);\n\n // Find d and s, (n - 1) = (2 ^ s) * d;\n var n1 = n.subn(1);\n for (var s = 0; !n1.testn(s); s++) {}\n var d = n.shrn(s);\n\n var rn1 = n1.toRed(red);\n\n for (; k > 0; k--) {\n var a = this._randrange(new bn(2), n1);\n\n var g = n.gcd(a);\n if (g.cmpn(1) !== 0)\n return g;\n\n var x = a.toRed(red).redPow(d);\n if (x.cmp(rone) === 0 || x.cmp(rn1) === 0)\n continue;\n\n for (var i = 1; i < s; i++) {\n x = x.redSqr();\n\n if (x.cmp(rone) === 0)\n return x.fromRed().subn(1).gcd(n);\n if (x.cmp(rn1) === 0)\n break;\n }\n\n if (i === s) {\n x = x.redSqr();\n return x.fromRed().subn(1).gcd(n);\n }\n }\n\n return false;\n};\n","(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 // 'A' - 'F'\n if (c >= 65 && c <= 70) {\n return c - 55;\n // 'a' - 'f'\n } else if (c >= 97 && c <= 102) {\n return c - 87;\n // '0' - '9'\n } else {\n return (c - 48) & 0xf;\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 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 r += c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n r += c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n r += c;\n }\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 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 BN.prototype.inspect = 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 if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\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.modn(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);\n };\n\n BN.prototype.toBuffer = function toBuffer (endian, length) {\n assert(typeof Buffer !== 'undefined');\n return this.toArrayLike(Buffer, endian, length);\n };\n\n BN.prototype.toArray = function toArray (endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n\n BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) {\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 this.strip();\n var littleEndian = endian === 'le';\n var res = new ArrayType(reqLength);\n\n var b, i;\n var q = this.clone();\n if (!littleEndian) {\n // Assume big-endian\n for (i = 0; i < reqLength - byteLength; i++) {\n res[i] = 0;\n }\n\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[reqLength - i - 1] = b;\n }\n } else {\n for (i = 0; !q.isZero(); i++) {\n b = q.andln(0xff);\n q.iushrn(8);\n\n res[i] = b;\n }\n\n for (; i < reqLength; i++) {\n res[i] = 0;\n }\n }\n\n return res;\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] & (1 << wbit)) >>> wbit;\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 var fftm = new FFTM();\n return fftm.mulp(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 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 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.modn(num.words[0]))\n };\n }\n\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modn(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.modn = function modn (num) {\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 acc;\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn (num) {\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 return this.strip();\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 BN v4 instance\n r.strip();\n } else {\n // r is 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 return a.umod(this.m)._forceRed(this);\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","module.exports = assert;\n\nfunction assert(val, msg) {\n if (!val)\n throw new Error(msg || 'Assertion failed');\n}\n\nassert.equal = function assertEqual(l, r, msg) {\n if (l != r)\n throw new Error(msg || ('Assertion failed: ' + l + ' != ' + r));\n};\n","'use strict';\n\nvar utils = exports;\n\nfunction toArray(msg, enc) {\n if (Array.isArray(msg))\n return msg.slice();\n if (!msg)\n return [];\n var res = [];\n if (typeof msg !== 'string') {\n for (var i = 0; i < msg.length; i++)\n res[i] = msg[i] | 0;\n return res;\n }\n if (enc === 'hex') {\n msg = msg.replace(/[^a-z0-9]+/ig, '');\n if (msg.length % 2 !== 0)\n msg = '0' + msg;\n for (var i = 0; i < msg.length; i += 2)\n res.push(parseInt(msg[i] + msg[i + 1], 16));\n } else {\n for (var i = 0; i < msg.length; i++) {\n var c = msg.charCodeAt(i);\n var hi = c >> 8;\n var lo = c & 0xff;\n if (hi)\n res.push(hi, lo);\n else\n res.push(lo);\n }\n }\n return res;\n}\nutils.toArray = toArray;\n\nfunction zero2(word) {\n if (word.length === 1)\n return '0' + word;\n else\n return word;\n}\nutils.zero2 = zero2;\n\nfunction toHex(msg) {\n var res = '';\n for (var i = 0; i < msg.length; i++)\n res += zero2(msg[i].toString(16));\n return res;\n}\nutils.toHex = toHex;\n\nutils.encode = function encode(arr, enc) {\n if (enc === 'hex')\n return toHex(arr);\n else\n return arr;\n};\n"],"names":["toString","module","exports","Array","isArray","arr","call","inherits","HashBase","Buffer","ARRAY16","MD5","this","_a","_b","_c","_d","rotl","x","n","fnF","a","b","c","d","m","k","s","fnG","fnH","fnI","prototype","_update","M","i","_block","readInt32LE","_digest","_blockOffset","fill","writeUInt32LE","_length","buffer","allocUnsafe","writeInt32LE","bn","brorand","MillerRabin","rand","Rand","create","_randbelow","len","bitLength","min_bytes","Math","ceil","generate","cmp","_randrange","start","stop","size","sub","add","test","cb","red","mont","rone","toRed","max","n1","subn","testn","shrn","rn1","prime","redPow","redSqr","getDivisor","g","gcd","cmpn","fromRed","assert","val","msg","Error","ctor","superCtor","super_","TempCtor","constructor","BN","number","base","endian","isBN","negative","words","length","_init","wordSize","window","e","parseHex4Bits","string","index","charCodeAt","parseHexByte","lowerBound","r","parseBase","str","end","mul","min","num","left","right","_initNumber","_initArray","replace","_parseHex","_parseBase","toArray","j","w","off","strip","parseLength","limbLen","limbPow","total","mod","word","imuln","_iaddn","pow","copy","dest","clone","_expand","_normSign","inspect","zeros","groupSizes","groupBases","toBitArray","bit","wbit","smallMulTo","self","out","lo","carry","ncarry","rword","maxJ","padding","groupSize","groupBase","isZero","modn","idivn","toNumber","ret","toJSON","toBuffer","toArrayLike","ArrayType","byteLength","reqLength","littleEndian","res","q","andln","iushrn","clz32","_countBits","t","_zeroBits","hi","zeroBits","toTwos","width","abs","inotn","iaddn","fromTwos","notn","ineg","isNeg","neg","iuor","ior","or","uor","iuand","iand","and","uand","iuxor","ixor","xor","uxor","bytesNeeded","bitsLeft","setn","iadd","isub","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","imul","w0","w1","w2","w3","w4","w5","w6","w7","w8","w9","w10","w11","w12","w13","w14","w15","w16","w17","w18","bigMulTo","hncarry","jumboMulTo","fftm","FFTM","mulp","y","mulTo","makeRBT","N","l","revBin","rb","permute","rbt","rws","iws","rtws","itws","transform","rtwdf","cos","PI","itwdf","sin","p","rtwdf_","itwdf_","re","ie","ro","io","rx","guessLen13b","odd","conjugate","normalize13b","ws","round","convert13b","stub","ph","_","rwst","iwst","nrws","nrwst","niwst","rmws","mulf","muln","sqr","isqr","iushln","bits","carryMask","newCarry","ishln","hint","extended","h","mask","maskedWords","ishrn","shln","ushln","ushrn","imaskn","maskn","isubn","addn","iabs","_ishlnsubmul","shift","_wordDiv","mode","bhi","bhiBits","diff","qj","div","divmod","positive","divn","umod","divRound","dm","half","r2","acc","egcd","A","B","C","D","isEven","yp","xp","im","isOdd","jm","_invmp","x1","x2","delta","invm","bincn","ucmp","gtn","gt","gten","gte","ltn","lt","lten","lte","eqn","eq","Red","ctx","convertTo","_forceRed","convertFrom","forceRed","redAdd","redIAdd","redSub","redISub","redShl","shl","redMul","_verify2","redIMul","_verify1","redISqr","redSqrt","sqrt","redInvm","redNeg","primes","k256","p224","p192","p25519","MPrime","name","tmp","_tmp","K256","P224","P192","P25519","_prime","Mont","imod","rinv","minv","ireduce","rlen","split","imulK","undefined","_strip","input","output","outLen","prev","next","mod3","one","nOne","lpow","z","inv","windowSize","wnd","current","currentLen","u","equal","utils","enc","slice","push","parseInt","zero2","toHex","encode"],"sourceRoot":""}