{"version":3,"file":"js/chunk-vendors-ad6a2f20.3d85d537.js","mappings":"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","sources":["webpack://com.crmtogether.mobilexcrm/./node_modules/cipher-base/index.js","webpack://com.crmtogether.mobilexcrm/./node_modules/console-browserify/index.js","webpack://com.crmtogether.mobilexcrm/./node_modules/create-ecdh/browser.js","webpack://com.crmtogether.mobilexcrm/./node_modules/create-ecdh/node_modules/bn.js/lib/bn.js","webpack://com.crmtogether.mobilexcrm/./node_modules/create-hash/browser.js","webpack://com.crmtogether.mobilexcrm/./node_modules/create-hash/md5.js","webpack://com.crmtogether.mobilexcrm/./node_modules/create-hmac/browser.js","webpack://com.crmtogether.mobilexcrm/./node_modules/create-hmac/legacy.js","webpack://com.crmtogether.mobilexcrm/./node_modules/crypto-browserify/index.js","webpack://com.crmtogether.mobilexcrm/./node_modules/define-properties/index.js","webpack://com.crmtogether.mobilexcrm/./node_modules/des.js/lib/des.js","webpack://com.crmtogether.mobilexcrm/./node_modules/des.js/lib/des/cbc.js","webpack://com.crmtogether.mobilexcrm/./node_modules/des.js/lib/des/cipher.js","webpack://com.crmtogether.mobilexcrm/./node_modules/des.js/lib/des/des.js","webpack://com.crmtogether.mobilexcrm/./node_modules/des.js/lib/des/ede.js","webpack://com.crmtogether.mobilexcrm/./node_modules/des.js/lib/des/utils.js","webpack://com.crmtogether.mobilexcrm/./node_modules/diffie-hellman/browser.js","webpack://com.crmtogether.mobilexcrm/./node_modules/diffie-hellman/lib/dh.js","webpack://com.crmtogether.mobilexcrm/./node_modules/diffie-hellman/lib/generatePrime.js","webpack://com.crmtogether.mobilexcrm/./node_modules/diffie-hellman/node_modules/bn.js/lib/bn.js"],"sourcesContent":["var Buffer = require('safe-buffer').Buffer\nvar Transform = require('stream').Transform\nvar StringDecoder = require('string_decoder').StringDecoder\nvar inherits = require('inherits')\n\nfunction CipherBase (hashMode) {\n Transform.call(this)\n this.hashMode = typeof hashMode === 'string'\n if (this.hashMode) {\n this[hashMode] = this._finalOrDigest\n } else {\n this.final = this._finalOrDigest\n }\n if (this._final) {\n this.__final = this._final\n this._final = null\n }\n this._decoder = null\n this._encoding = null\n}\ninherits(CipherBase, Transform)\n\nCipherBase.prototype.update = function (data, inputEnc, outputEnc) {\n if (typeof data === 'string') {\n data = Buffer.from(data, inputEnc)\n }\n\n var outData = this._update(data)\n if (this.hashMode) return this\n\n if (outputEnc) {\n outData = this._toString(outData, outputEnc)\n }\n\n return outData\n}\n\nCipherBase.prototype.setAutoPadding = function () {}\nCipherBase.prototype.getAuthTag = function () {\n throw new Error('trying to get auth tag in unsupported state')\n}\n\nCipherBase.prototype.setAuthTag = function () {\n throw new Error('trying to set auth tag in unsupported state')\n}\n\nCipherBase.prototype.setAAD = function () {\n throw new Error('trying to set aad in unsupported state')\n}\n\nCipherBase.prototype._transform = function (data, _, next) {\n var err\n try {\n if (this.hashMode) {\n this._update(data)\n } else {\n this.push(this._update(data))\n }\n } catch (e) {\n err = e\n } finally {\n next(err)\n }\n}\nCipherBase.prototype._flush = function (done) {\n var err\n try {\n this.push(this.__final())\n } catch (e) {\n err = e\n }\n\n done(err)\n}\nCipherBase.prototype._finalOrDigest = function (outputEnc) {\n var outData = this.__final() || Buffer.alloc(0)\n if (outputEnc) {\n outData = this._toString(outData, outputEnc, true)\n }\n return outData\n}\n\nCipherBase.prototype._toString = function (value, enc, fin) {\n if (!this._decoder) {\n this._decoder = new StringDecoder(enc)\n this._encoding = enc\n }\n\n if (this._encoding !== enc) throw new Error('can\\'t switch encodings')\n\n var out = this._decoder.write(value)\n if (fin) {\n out += this._decoder.end()\n }\n\n return out\n}\n\nmodule.exports = CipherBase\n","/*global window, global*/\nvar util = require(\"util\")\nvar assert = require(\"assert\")\nfunction now() { return new Date().getTime() }\n\nvar slice = Array.prototype.slice\nvar console\nvar times = {}\n\nif (typeof global !== \"undefined\" && global.console) {\n console = global.console\n} else if (typeof window !== \"undefined\" && window.console) {\n console = window.console\n} else {\n console = {}\n}\n\nvar functions = [\n [log, \"log\"],\n [info, \"info\"],\n [warn, \"warn\"],\n [error, \"error\"],\n [time, \"time\"],\n [timeEnd, \"timeEnd\"],\n [trace, \"trace\"],\n [dir, \"dir\"],\n [consoleAssert, \"assert\"]\n]\n\nfor (var i = 0; i < functions.length; i++) {\n var tuple = functions[i]\n var f = tuple[0]\n var name = tuple[1]\n\n if (!console[name]) {\n console[name] = f\n }\n}\n\nmodule.exports = console\n\nfunction log() {}\n\nfunction info() {\n console.log.apply(console, arguments)\n}\n\nfunction warn() {\n console.log.apply(console, arguments)\n}\n\nfunction error() {\n console.warn.apply(console, arguments)\n}\n\nfunction time(label) {\n times[label] = now()\n}\n\nfunction timeEnd(label) {\n var time = times[label]\n if (!time) {\n throw new Error(\"No such label: \" + label)\n }\n\n delete times[label]\n var duration = now() - time\n console.log(label + \": \" + duration + \"ms\")\n}\n\nfunction trace() {\n var err = new Error()\n err.name = \"Trace\"\n err.message = util.format.apply(null, arguments)\n console.error(err.stack)\n}\n\nfunction dir(object) {\n console.log(util.inspect(object) + \"\\n\")\n}\n\nfunction consoleAssert(expression) {\n if (!expression) {\n var arr = slice.call(arguments, 1)\n assert.ok(false, util.format.apply(null, arr))\n }\n}\n","var elliptic = require('elliptic')\nvar BN = require('bn.js')\n\nmodule.exports = function createECDH (curve) {\n return new ECDH(curve)\n}\n\nvar aliases = {\n secp256k1: {\n name: 'secp256k1',\n byteLength: 32\n },\n secp224r1: {\n name: 'p224',\n byteLength: 28\n },\n prime256v1: {\n name: 'p256',\n byteLength: 32\n },\n prime192v1: {\n name: 'p192',\n byteLength: 24\n },\n ed25519: {\n name: 'ed25519',\n byteLength: 32\n },\n secp384r1: {\n name: 'p384',\n byteLength: 48\n },\n secp521r1: {\n name: 'p521',\n byteLength: 66\n }\n}\n\naliases.p224 = aliases.secp224r1\naliases.p256 = aliases.secp256r1 = aliases.prime256v1\naliases.p192 = aliases.secp192r1 = aliases.prime192v1\naliases.p384 = aliases.secp384r1\naliases.p521 = aliases.secp521r1\n\nfunction ECDH (curve) {\n this.curveType = aliases[curve]\n if (!this.curveType) {\n this.curveType = {\n name: curve\n }\n }\n this.curve = new elliptic.ec(this.curveType.name) // eslint-disable-line new-cap\n this.keys = void 0\n}\n\nECDH.prototype.generateKeys = function (enc, format) {\n this.keys = this.curve.genKeyPair()\n return this.getPublicKey(enc, format)\n}\n\nECDH.prototype.computeSecret = function (other, inenc, enc) {\n inenc = inenc || 'utf8'\n if (!Buffer.isBuffer(other)) {\n other = new Buffer(other, inenc)\n }\n var otherPub = this.curve.keyFromPublic(other).getPublic()\n var out = otherPub.mul(this.keys.getPrivate()).getX()\n return formatReturnValue(out, enc, this.curveType.byteLength)\n}\n\nECDH.prototype.getPublicKey = function (enc, format) {\n var key = this.keys.getPublic(format === 'compressed', true)\n if (format === 'hybrid') {\n if (key[key.length - 1] % 2) {\n key[0] = 7\n } else {\n key[0] = 6\n }\n }\n return formatReturnValue(key, enc)\n}\n\nECDH.prototype.getPrivateKey = function (enc) {\n return formatReturnValue(this.keys.getPrivate(), enc)\n}\n\nECDH.prototype.setPublicKey = function (pub, enc) {\n enc = enc || 'utf8'\n if (!Buffer.isBuffer(pub)) {\n pub = new Buffer(pub, enc)\n }\n this.keys._importPublic(pub)\n return this\n}\n\nECDH.prototype.setPrivateKey = function (priv, enc) {\n enc = enc || 'utf8'\n if (!Buffer.isBuffer(priv)) {\n priv = new Buffer(priv, enc)\n }\n\n var _priv = new BN(priv)\n _priv = _priv.toString(16)\n this.keys = this.curve.genKeyPair()\n this.keys._importPrivate(_priv)\n return this\n}\n\nfunction formatReturnValue (bn, enc, len) {\n if (!Array.isArray(bn)) {\n bn = bn.toArray()\n }\n var buf = new Buffer(bn)\n if (len && buf.length < len) {\n var zeros = new Buffer(len - buf.length)\n zeros.fill(0)\n buf = Buffer.concat([zeros, buf])\n }\n if (!enc) {\n return buf\n } else {\n return buf.toString(enc)\n }\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","'use strict'\nvar inherits = require('inherits')\nvar MD5 = require('md5.js')\nvar RIPEMD160 = require('ripemd160')\nvar sha = require('sha.js')\nvar Base = require('cipher-base')\n\nfunction Hash (hash) {\n Base.call(this, 'digest')\n\n this._hash = hash\n}\n\ninherits(Hash, Base)\n\nHash.prototype._update = function (data) {\n this._hash.update(data)\n}\n\nHash.prototype._final = function () {\n return this._hash.digest()\n}\n\nmodule.exports = function createHash (alg) {\n alg = alg.toLowerCase()\n if (alg === 'md5') return new MD5()\n if (alg === 'rmd160' || alg === 'ripemd160') return new RIPEMD160()\n\n return new Hash(sha(alg))\n}\n","var MD5 = require('md5.js')\n\nmodule.exports = function (buffer) {\n return new MD5().update(buffer).digest()\n}\n","'use strict'\nvar inherits = require('inherits')\nvar Legacy = require('./legacy')\nvar Base = require('cipher-base')\nvar Buffer = require('safe-buffer').Buffer\nvar md5 = require('create-hash/md5')\nvar RIPEMD160 = require('ripemd160')\n\nvar sha = require('sha.js')\n\nvar ZEROS = Buffer.alloc(128)\n\nfunction Hmac (alg, key) {\n Base.call(this, 'digest')\n if (typeof key === 'string') {\n key = Buffer.from(key)\n }\n\n var blocksize = (alg === 'sha512' || alg === 'sha384') ? 128 : 64\n\n this._alg = alg\n this._key = key\n if (key.length > blocksize) {\n var hash = alg === 'rmd160' ? new RIPEMD160() : sha(alg)\n key = hash.update(key).digest()\n } else if (key.length < blocksize) {\n key = Buffer.concat([key, ZEROS], blocksize)\n }\n\n var ipad = this._ipad = Buffer.allocUnsafe(blocksize)\n var opad = this._opad = Buffer.allocUnsafe(blocksize)\n\n for (var i = 0; i < blocksize; i++) {\n ipad[i] = key[i] ^ 0x36\n opad[i] = key[i] ^ 0x5C\n }\n this._hash = alg === 'rmd160' ? new RIPEMD160() : sha(alg)\n this._hash.update(ipad)\n}\n\ninherits(Hmac, Base)\n\nHmac.prototype._update = function (data) {\n this._hash.update(data)\n}\n\nHmac.prototype._final = function () {\n var h = this._hash.digest()\n var hash = this._alg === 'rmd160' ? new RIPEMD160() : sha(this._alg)\n return hash.update(this._opad).update(h).digest()\n}\n\nmodule.exports = function createHmac (alg, key) {\n alg = alg.toLowerCase()\n if (alg === 'rmd160' || alg === 'ripemd160') {\n return new Hmac('rmd160', key)\n }\n if (alg === 'md5') {\n return new Legacy(md5, key)\n }\n return new Hmac(alg, key)\n}\n","'use strict'\nvar inherits = require('inherits')\nvar Buffer = require('safe-buffer').Buffer\n\nvar Base = require('cipher-base')\n\nvar ZEROS = Buffer.alloc(128)\nvar blocksize = 64\n\nfunction Hmac (alg, key) {\n Base.call(this, 'digest')\n if (typeof key === 'string') {\n key = Buffer.from(key)\n }\n\n this._alg = alg\n this._key = key\n\n if (key.length > blocksize) {\n key = alg(key)\n } else if (key.length < blocksize) {\n key = Buffer.concat([key, ZEROS], blocksize)\n }\n\n var ipad = this._ipad = Buffer.allocUnsafe(blocksize)\n var opad = this._opad = Buffer.allocUnsafe(blocksize)\n\n for (var i = 0; i < blocksize; i++) {\n ipad[i] = key[i] ^ 0x36\n opad[i] = key[i] ^ 0x5C\n }\n\n this._hash = [ipad]\n}\n\ninherits(Hmac, Base)\n\nHmac.prototype._update = function (data) {\n this._hash.push(data)\n}\n\nHmac.prototype._final = function () {\n var h = this._alg(Buffer.concat(this._hash))\n return this._alg(Buffer.concat([this._opad, h]))\n}\nmodule.exports = Hmac\n","'use strict'\n\nexports.randomBytes = exports.rng = exports.pseudoRandomBytes = exports.prng = require('randombytes')\nexports.createHash = exports.Hash = require('create-hash')\nexports.createHmac = exports.Hmac = require('create-hmac')\n\nvar algos = require('browserify-sign/algos')\nvar algoKeys = Object.keys(algos)\nvar hashes = ['sha1', 'sha224', 'sha256', 'sha384', 'sha512', 'md5', 'rmd160'].concat(algoKeys)\nexports.getHashes = function () {\n return hashes\n}\n\nvar p = require('pbkdf2')\nexports.pbkdf2 = p.pbkdf2\nexports.pbkdf2Sync = p.pbkdf2Sync\n\nvar aes = require('browserify-cipher')\n\nexports.Cipher = aes.Cipher\nexports.createCipher = aes.createCipher\nexports.Cipheriv = aes.Cipheriv\nexports.createCipheriv = aes.createCipheriv\nexports.Decipher = aes.Decipher\nexports.createDecipher = aes.createDecipher\nexports.Decipheriv = aes.Decipheriv\nexports.createDecipheriv = aes.createDecipheriv\nexports.getCiphers = aes.getCiphers\nexports.listCiphers = aes.listCiphers\n\nvar dh = require('diffie-hellman')\n\nexports.DiffieHellmanGroup = dh.DiffieHellmanGroup\nexports.createDiffieHellmanGroup = dh.createDiffieHellmanGroup\nexports.getDiffieHellman = dh.getDiffieHellman\nexports.createDiffieHellman = dh.createDiffieHellman\nexports.DiffieHellman = dh.DiffieHellman\n\nvar sign = require('browserify-sign')\n\nexports.createSign = sign.createSign\nexports.Sign = sign.Sign\nexports.createVerify = sign.createVerify\nexports.Verify = sign.Verify\n\nexports.createECDH = require('create-ecdh')\n\nvar publicEncrypt = require('public-encrypt')\n\nexports.publicEncrypt = publicEncrypt.publicEncrypt\nexports.privateEncrypt = publicEncrypt.privateEncrypt\nexports.publicDecrypt = publicEncrypt.publicDecrypt\nexports.privateDecrypt = publicEncrypt.privateDecrypt\n\n// the least I can do is make error messages for the rest of the node.js/crypto api.\n// ;[\n// 'createCredentials'\n// ].forEach(function (name) {\n// exports[name] = function () {\n// throw new Error([\n// 'sorry, ' + name + ' is not implemented yet',\n// 'we accept pull requests',\n// 'https://github.com/crypto-browserify/crypto-browserify'\n// ].join('\\n'))\n// }\n// })\n\nvar rf = require('randomfill')\n\nexports.randomFill = rf.randomFill\nexports.randomFillSync = rf.randomFillSync\n\nexports.createCredentials = function () {\n throw new Error([\n 'sorry, createCredentials is not implemented yet',\n 'we accept pull requests',\n 'https://github.com/crypto-browserify/crypto-browserify'\n ].join('\\n'))\n}\n\nexports.constants = {\n 'DH_CHECK_P_NOT_SAFE_PRIME': 2,\n 'DH_CHECK_P_NOT_PRIME': 1,\n 'DH_UNABLE_TO_CHECK_GENERATOR': 4,\n 'DH_NOT_SUITABLE_GENERATOR': 8,\n 'NPN_ENABLED': 1,\n 'ALPN_ENABLED': 1,\n 'RSA_PKCS1_PADDING': 1,\n 'RSA_SSLV23_PADDING': 2,\n 'RSA_NO_PADDING': 3,\n 'RSA_PKCS1_OAEP_PADDING': 4,\n 'RSA_X931_PADDING': 5,\n 'RSA_PKCS1_PSS_PADDING': 6,\n 'POINT_CONVERSION_COMPRESSED': 2,\n 'POINT_CONVERSION_UNCOMPRESSED': 4,\n 'POINT_CONVERSION_HYBRID': 6\n}\n","'use strict';\n\nvar keys = require('object-keys');\nvar hasSymbols = typeof Symbol === 'function' && typeof Symbol('foo') === 'symbol';\n\nvar toStr = Object.prototype.toString;\nvar concat = Array.prototype.concat;\nvar origDefineProperty = Object.defineProperty;\n\nvar isFunction = function (fn) {\n\treturn typeof fn === 'function' && toStr.call(fn) === '[object Function]';\n};\n\nvar hasPropertyDescriptors = require('has-property-descriptors')();\n\nvar supportsDescriptors = origDefineProperty && hasPropertyDescriptors;\n\nvar defineProperty = function (object, name, value, predicate) {\n\tif (name in object) {\n\t\tif (predicate === true) {\n\t\t\tif (object[name] === value) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t} else if (!isFunction(predicate) || !predicate()) {\n\t\t\treturn;\n\t\t}\n\t}\n\tif (supportsDescriptors) {\n\t\torigDefineProperty(object, name, {\n\t\t\tconfigurable: true,\n\t\t\tenumerable: false,\n\t\t\tvalue: value,\n\t\t\twritable: true\n\t\t});\n\t} else {\n\t\tobject[name] = value; // eslint-disable-line no-param-reassign\n\t}\n};\n\nvar defineProperties = function (object, map) {\n\tvar predicates = arguments.length > 2 ? arguments[2] : {};\n\tvar props = keys(map);\n\tif (hasSymbols) {\n\t\tprops = concat.call(props, Object.getOwnPropertySymbols(map));\n\t}\n\tfor (var i = 0; i < props.length; i += 1) {\n\t\tdefineProperty(object, props[i], map[props[i]], predicates[props[i]]);\n\t}\n};\n\ndefineProperties.supportsDescriptors = !!supportsDescriptors;\n\nmodule.exports = defineProperties;\n","'use strict';\n\nexports.utils = require('./des/utils');\nexports.Cipher = require('./des/cipher');\nexports.DES = require('./des/des');\nexports.CBC = require('./des/cbc');\nexports.EDE = require('./des/ede');\n","'use strict';\n\nvar assert = require('minimalistic-assert');\nvar inherits = require('inherits');\n\nvar proto = {};\n\nfunction CBCState(iv) {\n assert.equal(iv.length, 8, 'Invalid IV length');\n\n this.iv = new Array(8);\n for (var i = 0; i < this.iv.length; i++)\n this.iv[i] = iv[i];\n}\n\nfunction instantiate(Base) {\n function CBC(options) {\n Base.call(this, options);\n this._cbcInit();\n }\n inherits(CBC, Base);\n\n var keys = Object.keys(proto);\n for (var i = 0; i < keys.length; i++) {\n var key = keys[i];\n CBC.prototype[key] = proto[key];\n }\n\n CBC.create = function create(options) {\n return new CBC(options);\n };\n\n return CBC;\n}\n\nexports.instantiate = instantiate;\n\nproto._cbcInit = function _cbcInit() {\n var state = new CBCState(this.options.iv);\n this._cbcState = state;\n};\n\nproto._update = function _update(inp, inOff, out, outOff) {\n var state = this._cbcState;\n var superProto = this.constructor.super_.prototype;\n\n var iv = state.iv;\n if (this.type === 'encrypt') {\n for (var i = 0; i < this.blockSize; i++)\n iv[i] ^= inp[inOff + i];\n\n superProto._update.call(this, iv, 0, out, outOff);\n\n for (var i = 0; i < this.blockSize; i++)\n iv[i] = out[outOff + i];\n } else {\n superProto._update.call(this, inp, inOff, out, outOff);\n\n for (var i = 0; i < this.blockSize; i++)\n out[outOff + i] ^= iv[i];\n\n for (var i = 0; i < this.blockSize; i++)\n iv[i] = inp[inOff + i];\n }\n};\n","'use strict';\n\nvar assert = require('minimalistic-assert');\n\nfunction Cipher(options) {\n this.options = options;\n\n this.type = this.options.type;\n this.blockSize = 8;\n this._init();\n\n this.buffer = new Array(this.blockSize);\n this.bufferOff = 0;\n this.padding = options.padding !== false\n}\nmodule.exports = Cipher;\n\nCipher.prototype._init = function _init() {\n // Might be overrided\n};\n\nCipher.prototype.update = function update(data) {\n if (data.length === 0)\n return [];\n\n if (this.type === 'decrypt')\n return this._updateDecrypt(data);\n else\n return this._updateEncrypt(data);\n};\n\nCipher.prototype._buffer = function _buffer(data, off) {\n // Append data to buffer\n var min = Math.min(this.buffer.length - this.bufferOff, data.length - off);\n for (var i = 0; i < min; i++)\n this.buffer[this.bufferOff + i] = data[off + i];\n this.bufferOff += min;\n\n // Shift next\n return min;\n};\n\nCipher.prototype._flushBuffer = function _flushBuffer(out, off) {\n this._update(this.buffer, 0, out, off);\n this.bufferOff = 0;\n return this.blockSize;\n};\n\nCipher.prototype._updateEncrypt = function _updateEncrypt(data) {\n var inputOff = 0;\n var outputOff = 0;\n\n var count = ((this.bufferOff + data.length) / this.blockSize) | 0;\n var out = new Array(count * this.blockSize);\n\n if (this.bufferOff !== 0) {\n inputOff += this._buffer(data, inputOff);\n\n if (this.bufferOff === this.buffer.length)\n outputOff += this._flushBuffer(out, outputOff);\n }\n\n // Write blocks\n var max = data.length - ((data.length - inputOff) % this.blockSize);\n for (; inputOff < max; inputOff += this.blockSize) {\n this._update(data, inputOff, out, outputOff);\n outputOff += this.blockSize;\n }\n\n // Queue rest\n for (; inputOff < data.length; inputOff++, this.bufferOff++)\n this.buffer[this.bufferOff] = data[inputOff];\n\n return out;\n};\n\nCipher.prototype._updateDecrypt = function _updateDecrypt(data) {\n var inputOff = 0;\n var outputOff = 0;\n\n var count = Math.ceil((this.bufferOff + data.length) / this.blockSize) - 1;\n var out = new Array(count * this.blockSize);\n\n // TODO(indutny): optimize it, this is far from optimal\n for (; count > 0; count--) {\n inputOff += this._buffer(data, inputOff);\n outputOff += this._flushBuffer(out, outputOff);\n }\n\n // Buffer rest of the input\n inputOff += this._buffer(data, inputOff);\n\n return out;\n};\n\nCipher.prototype.final = function final(buffer) {\n var first;\n if (buffer)\n first = this.update(buffer);\n\n var last;\n if (this.type === 'encrypt')\n last = this._finalEncrypt();\n else\n last = this._finalDecrypt();\n\n if (first)\n return first.concat(last);\n else\n return last;\n};\n\nCipher.prototype._pad = function _pad(buffer, off) {\n if (off === 0)\n return false;\n\n while (off < buffer.length)\n buffer[off++] = 0;\n\n return true;\n};\n\nCipher.prototype._finalEncrypt = function _finalEncrypt() {\n if (!this._pad(this.buffer, this.bufferOff))\n return [];\n\n var out = new Array(this.blockSize);\n this._update(this.buffer, 0, out, 0);\n return out;\n};\n\nCipher.prototype._unpad = function _unpad(buffer) {\n return buffer;\n};\n\nCipher.prototype._finalDecrypt = function _finalDecrypt() {\n assert.equal(this.bufferOff, this.blockSize, 'Not enough data to decrypt');\n var out = new Array(this.blockSize);\n this._flushBuffer(out, 0);\n\n return this._unpad(out);\n};\n","'use strict';\n\nvar assert = require('minimalistic-assert');\nvar inherits = require('inherits');\n\nvar utils = require('./utils');\nvar Cipher = require('./cipher');\n\nfunction DESState() {\n this.tmp = new Array(2);\n this.keys = null;\n}\n\nfunction DES(options) {\n Cipher.call(this, options);\n\n var state = new DESState();\n this._desState = state;\n\n this.deriveKeys(state, options.key);\n}\ninherits(DES, Cipher);\nmodule.exports = DES;\n\nDES.create = function create(options) {\n return new DES(options);\n};\n\nvar shiftTable = [\n 1, 1, 2, 2, 2, 2, 2, 2,\n 1, 2, 2, 2, 2, 2, 2, 1\n];\n\nDES.prototype.deriveKeys = function deriveKeys(state, key) {\n state.keys = new Array(16 * 2);\n\n assert.equal(key.length, this.blockSize, 'Invalid key length');\n\n var kL = utils.readUInt32BE(key, 0);\n var kR = utils.readUInt32BE(key, 4);\n\n utils.pc1(kL, kR, state.tmp, 0);\n kL = state.tmp[0];\n kR = state.tmp[1];\n for (var i = 0; i < state.keys.length; i += 2) {\n var shift = shiftTable[i >>> 1];\n kL = utils.r28shl(kL, shift);\n kR = utils.r28shl(kR, shift);\n utils.pc2(kL, kR, state.keys, i);\n }\n};\n\nDES.prototype._update = function _update(inp, inOff, out, outOff) {\n var state = this._desState;\n\n var l = utils.readUInt32BE(inp, inOff);\n var r = utils.readUInt32BE(inp, inOff + 4);\n\n // Initial Permutation\n utils.ip(l, r, state.tmp, 0);\n l = state.tmp[0];\n r = state.tmp[1];\n\n if (this.type === 'encrypt')\n this._encrypt(state, l, r, state.tmp, 0);\n else\n this._decrypt(state, l, r, state.tmp, 0);\n\n l = state.tmp[0];\n r = state.tmp[1];\n\n utils.writeUInt32BE(out, l, outOff);\n utils.writeUInt32BE(out, r, outOff + 4);\n};\n\nDES.prototype._pad = function _pad(buffer, off) {\n if (this.padding === false) {\n return false;\n }\n\n var value = buffer.length - off;\n for (var i = off; i < buffer.length; i++)\n buffer[i] = value;\n\n return true;\n};\n\nDES.prototype._unpad = function _unpad(buffer) {\n if (this.padding === false) {\n return buffer;\n }\n\n var pad = buffer[buffer.length - 1];\n for (var i = buffer.length - pad; i < buffer.length; i++)\n assert.equal(buffer[i], pad);\n\n return buffer.slice(0, buffer.length - pad);\n};\n\nDES.prototype._encrypt = function _encrypt(state, lStart, rStart, out, off) {\n var l = lStart;\n var r = rStart;\n\n // Apply f() x16 times\n for (var i = 0; i < state.keys.length; i += 2) {\n var keyL = state.keys[i];\n var keyR = state.keys[i + 1];\n\n // f(r, k)\n utils.expand(r, state.tmp, 0);\n\n keyL ^= state.tmp[0];\n keyR ^= state.tmp[1];\n var s = utils.substitute(keyL, keyR);\n var f = utils.permute(s);\n\n var t = r;\n r = (l ^ f) >>> 0;\n l = t;\n }\n\n // Reverse Initial Permutation\n utils.rip(r, l, out, off);\n};\n\nDES.prototype._decrypt = function _decrypt(state, lStart, rStart, out, off) {\n var l = rStart;\n var r = lStart;\n\n // Apply f() x16 times\n for (var i = state.keys.length - 2; i >= 0; i -= 2) {\n var keyL = state.keys[i];\n var keyR = state.keys[i + 1];\n\n // f(r, k)\n utils.expand(l, state.tmp, 0);\n\n keyL ^= state.tmp[0];\n keyR ^= state.tmp[1];\n var s = utils.substitute(keyL, keyR);\n var f = utils.permute(s);\n\n var t = l;\n l = (r ^ f) >>> 0;\n r = t;\n }\n\n // Reverse Initial Permutation\n utils.rip(l, r, out, off);\n};\n","'use strict';\n\nvar assert = require('minimalistic-assert');\nvar inherits = require('inherits');\n\nvar Cipher = require('./cipher');\nvar DES = require('./des');\n\nfunction EDEState(type, key) {\n assert.equal(key.length, 24, 'Invalid key length');\n\n var k1 = key.slice(0, 8);\n var k2 = key.slice(8, 16);\n var k3 = key.slice(16, 24);\n\n if (type === 'encrypt') {\n this.ciphers = [\n DES.create({ type: 'encrypt', key: k1 }),\n DES.create({ type: 'decrypt', key: k2 }),\n DES.create({ type: 'encrypt', key: k3 })\n ];\n } else {\n this.ciphers = [\n DES.create({ type: 'decrypt', key: k3 }),\n DES.create({ type: 'encrypt', key: k2 }),\n DES.create({ type: 'decrypt', key: k1 })\n ];\n }\n}\n\nfunction EDE(options) {\n Cipher.call(this, options);\n\n var state = new EDEState(this.type, this.options.key);\n this._edeState = state;\n}\ninherits(EDE, Cipher);\n\nmodule.exports = EDE;\n\nEDE.create = function create(options) {\n return new EDE(options);\n};\n\nEDE.prototype._update = function _update(inp, inOff, out, outOff) {\n var state = this._edeState;\n\n state.ciphers[0]._update(inp, inOff, out, outOff);\n state.ciphers[1]._update(out, outOff, out, outOff);\n state.ciphers[2]._update(out, outOff, out, outOff);\n};\n\nEDE.prototype._pad = DES.prototype._pad;\nEDE.prototype._unpad = DES.prototype._unpad;\n","'use strict';\n\nexports.readUInt32BE = function readUInt32BE(bytes, off) {\n var res = (bytes[0 + off] << 24) |\n (bytes[1 + off] << 16) |\n (bytes[2 + off] << 8) |\n bytes[3 + off];\n return res >>> 0;\n};\n\nexports.writeUInt32BE = function writeUInt32BE(bytes, value, off) {\n bytes[0 + off] = value >>> 24;\n bytes[1 + off] = (value >>> 16) & 0xff;\n bytes[2 + off] = (value >>> 8) & 0xff;\n bytes[3 + off] = value & 0xff;\n};\n\nexports.ip = function ip(inL, inR, out, off) {\n var outL = 0;\n var outR = 0;\n\n for (var i = 6; i >= 0; i -= 2) {\n for (var j = 0; j <= 24; j += 8) {\n outL <<= 1;\n outL |= (inR >>> (j + i)) & 1;\n }\n for (var j = 0; j <= 24; j += 8) {\n outL <<= 1;\n outL |= (inL >>> (j + i)) & 1;\n }\n }\n\n for (var i = 6; i >= 0; i -= 2) {\n for (var j = 1; j <= 25; j += 8) {\n outR <<= 1;\n outR |= (inR >>> (j + i)) & 1;\n }\n for (var j = 1; j <= 25; j += 8) {\n outR <<= 1;\n outR |= (inL >>> (j + i)) & 1;\n }\n }\n\n out[off + 0] = outL >>> 0;\n out[off + 1] = outR >>> 0;\n};\n\nexports.rip = function rip(inL, inR, out, off) {\n var outL = 0;\n var outR = 0;\n\n for (var i = 0; i < 4; i++) {\n for (var j = 24; j >= 0; j -= 8) {\n outL <<= 1;\n outL |= (inR >>> (j + i)) & 1;\n outL <<= 1;\n outL |= (inL >>> (j + i)) & 1;\n }\n }\n for (var i = 4; i < 8; i++) {\n for (var j = 24; j >= 0; j -= 8) {\n outR <<= 1;\n outR |= (inR >>> (j + i)) & 1;\n outR <<= 1;\n outR |= (inL >>> (j + i)) & 1;\n }\n }\n\n out[off + 0] = outL >>> 0;\n out[off + 1] = outR >>> 0;\n};\n\nexports.pc1 = function pc1(inL, inR, out, off) {\n var outL = 0;\n var outR = 0;\n\n // 7, 15, 23, 31, 39, 47, 55, 63\n // 6, 14, 22, 30, 39, 47, 55, 63\n // 5, 13, 21, 29, 39, 47, 55, 63\n // 4, 12, 20, 28\n for (var i = 7; i >= 5; i--) {\n for (var j = 0; j <= 24; j += 8) {\n outL <<= 1;\n outL |= (inR >> (j + i)) & 1;\n }\n for (var j = 0; j <= 24; j += 8) {\n outL <<= 1;\n outL |= (inL >> (j + i)) & 1;\n }\n }\n for (var j = 0; j <= 24; j += 8) {\n outL <<= 1;\n outL |= (inR >> (j + i)) & 1;\n }\n\n // 1, 9, 17, 25, 33, 41, 49, 57\n // 2, 10, 18, 26, 34, 42, 50, 58\n // 3, 11, 19, 27, 35, 43, 51, 59\n // 36, 44, 52, 60\n for (var i = 1; i <= 3; i++) {\n for (var j = 0; j <= 24; j += 8) {\n outR <<= 1;\n outR |= (inR >> (j + i)) & 1;\n }\n for (var j = 0; j <= 24; j += 8) {\n outR <<= 1;\n outR |= (inL >> (j + i)) & 1;\n }\n }\n for (var j = 0; j <= 24; j += 8) {\n outR <<= 1;\n outR |= (inL >> (j + i)) & 1;\n }\n\n out[off + 0] = outL >>> 0;\n out[off + 1] = outR >>> 0;\n};\n\nexports.r28shl = function r28shl(num, shift) {\n return ((num << shift) & 0xfffffff) | (num >>> (28 - shift));\n};\n\nvar pc2table = [\n // inL => outL\n 14, 11, 17, 4, 27, 23, 25, 0,\n 13, 22, 7, 18, 5, 9, 16, 24,\n 2, 20, 12, 21, 1, 8, 15, 26,\n\n // inR => outR\n 15, 4, 25, 19, 9, 1, 26, 16,\n 5, 11, 23, 8, 12, 7, 17, 0,\n 22, 3, 10, 14, 6, 20, 27, 24\n];\n\nexports.pc2 = function pc2(inL, inR, out, off) {\n var outL = 0;\n var outR = 0;\n\n var len = pc2table.length >>> 1;\n for (var i = 0; i < len; i++) {\n outL <<= 1;\n outL |= (inL >>> pc2table[i]) & 0x1;\n }\n for (var i = len; i < pc2table.length; i++) {\n outR <<= 1;\n outR |= (inR >>> pc2table[i]) & 0x1;\n }\n\n out[off + 0] = outL >>> 0;\n out[off + 1] = outR >>> 0;\n};\n\nexports.expand = function expand(r, out, off) {\n var outL = 0;\n var outR = 0;\n\n outL = ((r & 1) << 5) | (r >>> 27);\n for (var i = 23; i >= 15; i -= 4) {\n outL <<= 6;\n outL |= (r >>> i) & 0x3f;\n }\n for (var i = 11; i >= 3; i -= 4) {\n outR |= (r >>> i) & 0x3f;\n outR <<= 6;\n }\n outR |= ((r & 0x1f) << 1) | (r >>> 31);\n\n out[off + 0] = outL >>> 0;\n out[off + 1] = outR >>> 0;\n};\n\nvar sTable = [\n 14, 0, 4, 15, 13, 7, 1, 4, 2, 14, 15, 2, 11, 13, 8, 1,\n 3, 10, 10, 6, 6, 12, 12, 11, 5, 9, 9, 5, 0, 3, 7, 8,\n 4, 15, 1, 12, 14, 8, 8, 2, 13, 4, 6, 9, 2, 1, 11, 7,\n 15, 5, 12, 11, 9, 3, 7, 14, 3, 10, 10, 0, 5, 6, 0, 13,\n\n 15, 3, 1, 13, 8, 4, 14, 7, 6, 15, 11, 2, 3, 8, 4, 14,\n 9, 12, 7, 0, 2, 1, 13, 10, 12, 6, 0, 9, 5, 11, 10, 5,\n 0, 13, 14, 8, 7, 10, 11, 1, 10, 3, 4, 15, 13, 4, 1, 2,\n 5, 11, 8, 6, 12, 7, 6, 12, 9, 0, 3, 5, 2, 14, 15, 9,\n\n 10, 13, 0, 7, 9, 0, 14, 9, 6, 3, 3, 4, 15, 6, 5, 10,\n 1, 2, 13, 8, 12, 5, 7, 14, 11, 12, 4, 11, 2, 15, 8, 1,\n 13, 1, 6, 10, 4, 13, 9, 0, 8, 6, 15, 9, 3, 8, 0, 7,\n 11, 4, 1, 15, 2, 14, 12, 3, 5, 11, 10, 5, 14, 2, 7, 12,\n\n 7, 13, 13, 8, 14, 11, 3, 5, 0, 6, 6, 15, 9, 0, 10, 3,\n 1, 4, 2, 7, 8, 2, 5, 12, 11, 1, 12, 10, 4, 14, 15, 9,\n 10, 3, 6, 15, 9, 0, 0, 6, 12, 10, 11, 1, 7, 13, 13, 8,\n 15, 9, 1, 4, 3, 5, 14, 11, 5, 12, 2, 7, 8, 2, 4, 14,\n\n 2, 14, 12, 11, 4, 2, 1, 12, 7, 4, 10, 7, 11, 13, 6, 1,\n 8, 5, 5, 0, 3, 15, 15, 10, 13, 3, 0, 9, 14, 8, 9, 6,\n 4, 11, 2, 8, 1, 12, 11, 7, 10, 1, 13, 14, 7, 2, 8, 13,\n 15, 6, 9, 15, 12, 0, 5, 9, 6, 10, 3, 4, 0, 5, 14, 3,\n\n 12, 10, 1, 15, 10, 4, 15, 2, 9, 7, 2, 12, 6, 9, 8, 5,\n 0, 6, 13, 1, 3, 13, 4, 14, 14, 0, 7, 11, 5, 3, 11, 8,\n 9, 4, 14, 3, 15, 2, 5, 12, 2, 9, 8, 5, 12, 15, 3, 10,\n 7, 11, 0, 14, 4, 1, 10, 7, 1, 6, 13, 0, 11, 8, 6, 13,\n\n 4, 13, 11, 0, 2, 11, 14, 7, 15, 4, 0, 9, 8, 1, 13, 10,\n 3, 14, 12, 3, 9, 5, 7, 12, 5, 2, 10, 15, 6, 8, 1, 6,\n 1, 6, 4, 11, 11, 13, 13, 8, 12, 1, 3, 4, 7, 10, 14, 7,\n 10, 9, 15, 5, 6, 0, 8, 15, 0, 14, 5, 2, 9, 3, 2, 12,\n\n 13, 1, 2, 15, 8, 13, 4, 8, 6, 10, 15, 3, 11, 7, 1, 4,\n 10, 12, 9, 5, 3, 6, 14, 11, 5, 0, 0, 14, 12, 9, 7, 2,\n 7, 2, 11, 1, 4, 14, 1, 7, 9, 4, 12, 10, 14, 8, 2, 13,\n 0, 15, 6, 12, 10, 9, 13, 0, 15, 3, 3, 5, 5, 6, 8, 11\n];\n\nexports.substitute = function substitute(inL, inR) {\n var out = 0;\n for (var i = 0; i < 4; i++) {\n var b = (inL >>> (18 - i * 6)) & 0x3f;\n var sb = sTable[i * 0x40 + b];\n\n out <<= 4;\n out |= sb;\n }\n for (var i = 0; i < 4; i++) {\n var b = (inR >>> (18 - i * 6)) & 0x3f;\n var sb = sTable[4 * 0x40 + i * 0x40 + b];\n\n out <<= 4;\n out |= sb;\n }\n return out >>> 0;\n};\n\nvar permuteTable = [\n 16, 25, 12, 11, 3, 20, 4, 15, 31, 17, 9, 6, 27, 14, 1, 22,\n 30, 24, 8, 18, 0, 5, 29, 23, 13, 19, 2, 26, 10, 21, 28, 7\n];\n\nexports.permute = function permute(num) {\n var out = 0;\n for (var i = 0; i < permuteTable.length; i++) {\n out <<= 1;\n out |= (num >>> permuteTable[i]) & 0x1;\n }\n return out >>> 0;\n};\n\nexports.padSplit = function padSplit(num, size, group) {\n var str = num.toString(2);\n while (str.length < size)\n str = '0' + str;\n\n var out = [];\n for (var i = 0; i < size; i += group)\n out.push(str.slice(i, i + group));\n return out.join(' ');\n};\n","var generatePrime = require('./lib/generatePrime')\nvar primes = require('./lib/primes.json')\n\nvar DH = require('./lib/dh')\n\nfunction getDiffieHellman (mod) {\n var prime = new Buffer(primes[mod].prime, 'hex')\n var gen = new Buffer(primes[mod].gen, 'hex')\n\n return new DH(prime, gen)\n}\n\nvar ENCODINGS = {\n 'binary': true, 'hex': true, 'base64': true\n}\n\nfunction createDiffieHellman (prime, enc, generator, genc) {\n if (Buffer.isBuffer(enc) || ENCODINGS[enc] === undefined) {\n return createDiffieHellman(prime, 'binary', enc, generator)\n }\n\n enc = enc || 'binary'\n genc = genc || 'binary'\n generator = generator || new Buffer([2])\n\n if (!Buffer.isBuffer(generator)) {\n generator = new Buffer(generator, genc)\n }\n\n if (typeof prime === 'number') {\n return new DH(generatePrime(prime, generator), generator, true)\n }\n\n if (!Buffer.isBuffer(prime)) {\n prime = new Buffer(prime, enc)\n }\n\n return new DH(prime, generator, true)\n}\n\nexports.DiffieHellmanGroup = exports.createDiffieHellmanGroup = exports.getDiffieHellman = getDiffieHellman\nexports.createDiffieHellman = exports.DiffieHellman = createDiffieHellman\n","var BN = require('bn.js');\nvar MillerRabin = require('miller-rabin');\nvar millerRabin = new MillerRabin();\nvar TWENTYFOUR = new BN(24);\nvar ELEVEN = new BN(11);\nvar TEN = new BN(10);\nvar THREE = new BN(3);\nvar SEVEN = new BN(7);\nvar primes = require('./generatePrime');\nvar randomBytes = require('randombytes');\nmodule.exports = DH;\n\nfunction setPublicKey(pub, enc) {\n enc = enc || 'utf8';\n if (!Buffer.isBuffer(pub)) {\n pub = new Buffer(pub, enc);\n }\n this._pub = new BN(pub);\n return this;\n}\n\nfunction setPrivateKey(priv, enc) {\n enc = enc || 'utf8';\n if (!Buffer.isBuffer(priv)) {\n priv = new Buffer(priv, enc);\n }\n this._priv = new BN(priv);\n return this;\n}\n\nvar primeCache = {};\nfunction checkPrime(prime, generator) {\n var gen = generator.toString('hex');\n var hex = [gen, prime.toString(16)].join('_');\n if (hex in primeCache) {\n return primeCache[hex];\n }\n var error = 0;\n\n if (prime.isEven() ||\n !primes.simpleSieve ||\n !primes.fermatTest(prime) ||\n !millerRabin.test(prime)) {\n //not a prime so +1\n error += 1;\n\n if (gen === '02' || gen === '05') {\n // we'd be able to check the generator\n // it would fail so +8\n error += 8;\n } else {\n //we wouldn't be able to test the generator\n // so +4\n error += 4;\n }\n primeCache[hex] = error;\n return error;\n }\n if (!millerRabin.test(prime.shrn(1))) {\n //not a safe prime\n error += 2;\n }\n var rem;\n switch (gen) {\n case '02':\n if (prime.mod(TWENTYFOUR).cmp(ELEVEN)) {\n // unsuidable generator\n error += 8;\n }\n break;\n case '05':\n rem = prime.mod(TEN);\n if (rem.cmp(THREE) && rem.cmp(SEVEN)) {\n // prime mod 10 needs to equal 3 or 7\n error += 8;\n }\n break;\n default:\n error += 4;\n }\n primeCache[hex] = error;\n return error;\n}\n\nfunction DH(prime, generator, malleable) {\n this.setGenerator(generator);\n this.__prime = new BN(prime);\n this._prime = BN.mont(this.__prime);\n this._primeLen = prime.length;\n this._pub = undefined;\n this._priv = undefined;\n this._primeCode = undefined;\n if (malleable) {\n this.setPublicKey = setPublicKey;\n this.setPrivateKey = setPrivateKey;\n } else {\n this._primeCode = 8;\n }\n}\nObject.defineProperty(DH.prototype, 'verifyError', {\n enumerable: true,\n get: function () {\n if (typeof this._primeCode !== 'number') {\n this._primeCode = checkPrime(this.__prime, this.__gen);\n }\n return this._primeCode;\n }\n});\nDH.prototype.generateKeys = function () {\n if (!this._priv) {\n this._priv = new BN(randomBytes(this._primeLen));\n }\n this._pub = this._gen.toRed(this._prime).redPow(this._priv).fromRed();\n return this.getPublicKey();\n};\n\nDH.prototype.computeSecret = function (other) {\n other = new BN(other);\n other = other.toRed(this._prime);\n var secret = other.redPow(this._priv).fromRed();\n var out = new Buffer(secret.toArray());\n var prime = this.getPrime();\n if (out.length < prime.length) {\n var front = new Buffer(prime.length - out.length);\n front.fill(0);\n out = Buffer.concat([front, out]);\n }\n return out;\n};\n\nDH.prototype.getPublicKey = function getPublicKey(enc) {\n return formatReturnValue(this._pub, enc);\n};\n\nDH.prototype.getPrivateKey = function getPrivateKey(enc) {\n return formatReturnValue(this._priv, enc);\n};\n\nDH.prototype.getPrime = function (enc) {\n return formatReturnValue(this.__prime, enc);\n};\n\nDH.prototype.getGenerator = function (enc) {\n return formatReturnValue(this._gen, enc);\n};\n\nDH.prototype.setGenerator = function (gen, enc) {\n enc = enc || 'utf8';\n if (!Buffer.isBuffer(gen)) {\n gen = new Buffer(gen, enc);\n }\n this.__gen = gen;\n this._gen = new BN(gen);\n return this;\n};\n\nfunction formatReturnValue(bn, enc) {\n var buf = new Buffer(bn.toArray());\n if (!enc) {\n return buf;\n } else {\n return buf.toString(enc);\n }\n}\n","var randomBytes = require('randombytes');\nmodule.exports = findPrime;\nfindPrime.simpleSieve = simpleSieve;\nfindPrime.fermatTest = fermatTest;\nvar BN = require('bn.js');\nvar TWENTYFOUR = new BN(24);\nvar MillerRabin = require('miller-rabin');\nvar millerRabin = new MillerRabin();\nvar ONE = new BN(1);\nvar TWO = new BN(2);\nvar FIVE = new BN(5);\nvar SIXTEEN = new BN(16);\nvar EIGHT = new BN(8);\nvar TEN = new BN(10);\nvar THREE = new BN(3);\nvar SEVEN = new BN(7);\nvar ELEVEN = new BN(11);\nvar FOUR = new BN(4);\nvar TWELVE = new BN(12);\nvar primes = null;\n\nfunction _getPrimes() {\n if (primes !== null)\n return primes;\n\n var limit = 0x100000;\n var res = [];\n res[0] = 2;\n for (var i = 1, k = 3; k < limit; k += 2) {\n var sqrt = Math.ceil(Math.sqrt(k));\n for (var j = 0; j < i && res[j] <= sqrt; j++)\n if (k % res[j] === 0)\n break;\n\n if (i !== j && res[j] <= sqrt)\n continue;\n\n res[i++] = k;\n }\n primes = res;\n return res;\n}\n\nfunction simpleSieve(p) {\n var primes = _getPrimes();\n\n for (var i = 0; i < primes.length; i++)\n if (p.modn(primes[i]) === 0) {\n if (p.cmpn(primes[i]) === 0) {\n return true;\n } else {\n return false;\n }\n }\n\n return true;\n}\n\nfunction fermatTest(p) {\n var red = BN.mont(p);\n return TWO.toRed(red).redPow(p.subn(1)).fromRed().cmpn(1) === 0;\n}\n\nfunction findPrime(bits, gen) {\n if (bits < 16) {\n // this is what openssl does\n if (gen === 2 || gen === 5) {\n return new BN([0x8c, 0x7b]);\n } else {\n return new BN([0x8c, 0x27]);\n }\n }\n gen = new BN(gen);\n\n var num, n2;\n\n while (true) {\n num = new BN(randomBytes(Math.ceil(bits / 8)));\n while (num.bitLength() > bits) {\n num.ishrn(1);\n }\n if (num.isEven()) {\n num.iadd(ONE);\n }\n if (!num.testn(1)) {\n num.iadd(TWO);\n }\n if (!gen.cmp(TWO)) {\n while (num.mod(TWENTYFOUR).cmp(ELEVEN)) {\n num.iadd(FOUR);\n }\n } else if (!gen.cmp(FIVE)) {\n while (num.mod(TEN).cmp(THREE)) {\n num.iadd(FOUR);\n }\n }\n n2 = num.shrn(1);\n if (simpleSieve(n2) && simpleSieve(num) &&\n fermatTest(n2) && fermatTest(num) &&\n millerRabin.test(n2) && millerRabin.test(num)) {\n return num;\n }\n }\n\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"],"names":["Buffer","Transform","StringDecoder","inherits","CipherBase","hashMode","call","this","_finalOrDigest","final","_final","__final","_decoder","_encoding","prototype","update","data","inputEnc","outputEnc","from","outData","_update","_toString","setAutoPadding","getAuthTag","Error","setAuthTag","setAAD","_transform","_","next","err","push","e","_flush","done","alloc","value","enc","fin","out","write","end","module","exports","util","assert","now","Date","getTime","console","slice","Array","times","g","window","functions","log","info","warn","error","time","timeEnd","trace","dir","consoleAssert","i","length","tuple","f","name","apply","arguments","label","duration","message","format","stack","object","inspect","expression","arr","ok","elliptic","BN","curve","ECDH","aliases","secp256k1","byteLength","secp224r1","prime256v1","prime192v1","ed25519","secp384r1","secp521r1","curveType","ec","keys","formatReturnValue","bn","len","isArray","toArray","buf","zeros","fill","concat","toString","p224","p256","secp256r1","p192","secp192r1","p384","p521","generateKeys","genKeyPair","getPublicKey","computeSecret","other","inenc","isBuffer","otherPub","keyFromPublic","getPublic","mul","getPrivate","getX","key","getPrivateKey","setPublicKey","pub","_importPublic","setPrivateKey","priv","_priv","_importPrivate","val","msg","ctor","superCtor","super_","TempCtor","constructor","number","base","endian","isBN","negative","words","red","_init","wordSize","parseHex4Bits","string","index","c","charCodeAt","parseHexByte","lowerBound","r","parseBase","str","start","Math","min","num","max","left","right","cmp","_initNumber","_initArray","replace","_parseHex","_parseBase","ceil","j","w","off","strip","parseLength","limbLen","limbPow","total","mod","word","imuln","_iaddn","pow","copy","dest","clone","_expand","size","_normSign","groupSizes","groupBases","toBitArray","bitLength","bit","wbit","smallMulTo","self","a","b","lo","carry","k","ncarry","rword","maxJ","padding","groupSize","groupBase","isZero","modn","idivn","toNumber","ret","toJSON","toBuffer","toArrayLike","ArrayType","reqLength","littleEndian","res","q","andln","iushrn","clz32","_countBits","t","_zeroBits","hi","zeroBits","toTwos","width","abs","inotn","iaddn","fromTwos","testn","notn","ineg","isNeg","neg","iuor","ior","or","uor","iuand","iand","and","uand","iuxor","ixor","xor","uxor","bytesNeeded","bitsLeft","setn","iadd","isub","add","sub","comb10MulTo","mid","o","a0","al0","ah0","a1","al1","ah1","a2","al2","ah2","a3","al3","ah3","a4","al4","ah4","a5","al5","ah5","a6","al6","ah6","a7","al7","ah7","a8","al8","ah8","a9","al9","ah9","b0","bl0","bh0","b1","bl1","bh1","b2","bl2","bh2","b3","bl3","bh3","b4","bl4","bh4","b5","bl5","bh5","b6","bl6","bh6","b7","bl7","bh7","b8","bl8","bh8","b9","bl9","bh9","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","x","y","mulTo","makeRBT","N","l","revBin","rb","permute","rbt","rws","iws","rtws","itws","transform","s","rtwdf","cos","PI","itwdf","sin","p","rtwdf_","itwdf_","re","ie","ro","io","rx","guessLen13b","n","m","odd","conjugate","normalize13b","ws","round","convert13b","stub","ph","rwst","iwst","nrws","nrwst","niwst","rmws","mulf","muln","sqr","isqr","iushln","bits","carryMask","newCarry","ishln","hint","extended","h","mask","maskedWords","ishrn","shln","ushln","shrn","ushrn","imaskn","maskn","isubn","addn","subn","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","gcd","_invmp","x1","x2","delta","cmpn","invm","bincn","ucmp","gtn","gt","gten","gte","ltn","lt","lten","lte","eqn","eq","Red","toRed","ctx","convertTo","_forceRed","fromRed","convertFrom","forceRed","redAdd","redIAdd","redSub","redISub","redShl","shl","redMul","_verify2","redIMul","redSqr","_verify1","redISqr","redSqrt","sqrt","redInvm","redNeg","redPow","primes","k256","p25519","MPrime","tmp","_tmp","K256","P224","P192","P25519","prime","_prime","Mont","imod","rinv","minv","ireduce","rlen","split","imulK","undefined","_strip","input","output","outLen","prev","mod3","one","nOne","lpow","z","inv","windowSize","wnd","current","currentLen","mont","u","MD5","RIPEMD160","sha","Base","Hash","hash","_hash","digest","alg","toLowerCase","buffer","Legacy","md5","ZEROS","Hmac","blocksize","_alg","_key","ipad","_ipad","allocUnsafe","opad","_opad","randomBytes","rng","pseudoRandomBytes","prng","createHash","createHmac","algos","algoKeys","Object","hashes","getHashes","pbkdf2","pbkdf2Sync","aes","Cipher","createCipher","Cipheriv","createCipheriv","Decipher","createDecipher","Decipheriv","createDecipheriv","getCiphers","listCiphers","dh","DiffieHellmanGroup","createDiffieHellmanGroup","getDiffieHellman","createDiffieHellman","DiffieHellman","sign","createSign","Sign","createVerify","Verify","createECDH","publicEncrypt","privateEncrypt","publicDecrypt","privateDecrypt","rf","randomFill","randomFillSync","createCredentials","join","constants","hasSymbols","Symbol","toStr","origDefineProperty","defineProperty","isFunction","fn","hasPropertyDescriptors","supportsDescriptors","predicate","configurable","enumerable","writable","defineProperties","map","predicates","props","getOwnPropertySymbols","utils","DES","CBC","EDE","proto","CBCState","iv","equal","instantiate","options","_cbcInit","create","state","_cbcState","inp","inOff","outOff","superProto","type","blockSize","bufferOff","_updateDecrypt","_updateEncrypt","_buffer","_flushBuffer","inputOff","outputOff","count","first","last","_finalEncrypt","_finalDecrypt","_pad","_unpad","DESState","_desState","deriveKeys","shiftTable","kL","readUInt32BE","kR","pc1","r28shl","pc2","ip","_encrypt","_decrypt","writeUInt32BE","pad","lStart","rStart","keyL","keyR","expand","substitute","rip","EDEState","k1","k2","k3","ciphers","_edeState","bytes","inL","inR","outL","outR","pc2table","sTable","sb","permuteTable","padSplit","group","generatePrime","DH","gen","ENCODINGS","generator","genc","MillerRabin","millerRabin","TWENTYFOUR","ELEVEN","TEN","THREE","SEVEN","_pub","primeCache","checkPrime","hex","rem","simpleSieve","fermatTest","test","malleable","setGenerator","__prime","_primeLen","_primeCode","get","__gen","_gen","secret","getPrime","front","getGenerator","findPrime","ONE","TWO","FIVE","FOUR","_getPrimes","limit","n2"],"sourceRoot":""}