{"version":3,"sources":["../node_modules/memoize-one/dist/memoize-one.esm.js","../node_modules/md5.js/index.js","../node_modules/miller-rabin/lib/mr.js","../node_modules/minimalistic-crypto-utils/lib/utils.js","../node_modules/mini-create-react-context/dist/esm/index.js","../node_modules/miller-rabin/node_modules/bn.js/lib/bn.js","../node_modules/ms/index.js","../node_modules/minimalistic-assert/index.js"],"names":["safeIsNaN","Number","isNaN","value","areInputsEqual","newInputs","lastInputs","length","i","first","second","memoizeOne","resultFn","isEqual","lastThis","lastResult","lastArgs","calledOnce","newArgs","_i","arguments","this","apply","inherits","require","HashBase","Buffer","ARRAY16","Array","MD5","call","_a","_b","_c","_d","rotl","x","n","fnF","a","b","c","d","m","k","s","fnG","fnH","fnI","prototype","_update","M","_block","readInt32LE","_digest","_blockOffset","fill","writeUInt32LE","_length","buffer","allocUnsafe","writeInt32LE","module","exports","bn","brorand","MillerRabin","rand","Rand","create","_randbelow","len","bitLength","min_bytes","Math","ceil","generate","cmp","_randrange","start","stop","size","sub","add","test","cb","red","mont","rone","toRed","max","n1","subn","testn","shrn","rn1","redPow","redSqr","getDivisor","g","gcd","cmpn","fromRed","utils","zero2","word","toHex","msg","res","toString","toArray","enc","isArray","slice","replace","push","parseInt","charCodeAt","hi","lo","encode","arr","MAX_SIGNED_31_BIT_INT","commonjsGlobal","globalThis","window","global","createEventEmitter","handlers","on","handler","off","filter","h","get","set","newValue","changedBits","forEach","index","React","createContext","defaultValue","calculateChangedBits","_Provider$childContex","_Consumer$contextType","contextProp","key","getUniqueId","Provider","_Component","_this","emitter","props","_inheritsLoose","_proto","getChildContext","_ref","componentWillReceiveProps","nextProps","oldValue","y","render","children","Component","childContextTypes","PropTypes","object","isRequired","Consumer","_Component2","_this2","state","getValue","onUpdate","observedBits","setState","_proto2","undefined","componentDidMount","context","componentWillUnmount","contextTypes","assert","val","Error","ctor","superCtor","super_","TempCtor","constructor","BN","number","base","endian","isBN","negative","words","_init","wordSize","e","parseHex4Bits","string","parseHexByte","lowerBound","r","parseBase","str","end","mul","min","num","left","right","_initNumber","_initArray","_parseHex","_parseBase","j","w","strip","limbLen","limbPow","total","mod","imuln","_iaddn","pow","copy","dest","clone","_expand","_normSign","inspect","zeros","groupSizes","groupBases","smallMulTo","self","out","carry","ncarry","rword","maxJ","padding","groupSize","groupBase","isZero","modn","idivn","toNumber","ret","toJSON","toBuffer","toArrayLike","ArrayType","byteLength","reqLength","littleEndian","q","andln","iushrn","clz32","_countBits","t","_zeroBits","zeroBits","toTwos","width","abs","inotn","iaddn","fromTwos","notn","ineg","isNeg","neg","iuor","ior","or","uor","iuand","iand","and","uand","iuxor","ixor","xor","uxor","bytesNeeded","bitsLeft","setn","bit","wbit","iadd","isub","comb10MulTo","mid","o","a0","al0","ah0","a1","al1","ah1","a2","al2","ah2","a3","al3","ah3","a4","al4","ah4","a5","al5","ah5","a6","al6","ah6","a7","al7","ah7","a8","al8","ah8","a9","al9","ah9","b0","bl0","bh0","b1","bl1","bh1","b2","bl2","bh2","b3","bl3","bh3","b4","bl4","bh4","b5","bl5","bh5","b6","bl6","bh6","b7","bl7","bh7","b8","bl8","bh8","b9","bl9","bh9","w0","imul","w1","w2","w3","w4","w5","w6","w7","w8","w9","w10","w11","w12","w13","w14","w15","w16","w17","w18","jumboMulTo","FFTM","mulp","mulTo","hncarry","bigMulTo","makeRBT","N","l","revBin","rb","permute","rbt","rws","iws","rtws","itws","transform","rtwdf","cos","PI","itwdf","sin","p","rtwdf_","itwdf_","re","ie","ro","io","rx","guessLen13b","odd","conjugate","normalize13b","ws","round","convert13b","stub","ph","_","rwst","iwst","nrws","nrwst","niwst","rmws","mulf","muln","sqr","isqr","toBitArray","iushln","bits","carryMask","newCarry","ishln","hint","extended","mask","maskedWords","ishrn","shln","ushln","ushrn","imaskn","maskn","isubn","addn","iabs","_ishlnsubmul","shift","_wordDiv","mode","bhi","diff","qj","div","divmod","positive","divn","umod","divRound","dm","half","r2","acc","egcd","A","B","C","D","isEven","yp","xp","im","isOdd","jm","_invmp","x1","x2","delta","invm","bincn","ucmp","gtn","gt","gten","gte","ltn","lt","lten","lte","eqn","eq","Red","ctx","convertTo","_forceRed","convertFrom","forceRed","redAdd","redIAdd","redSub","redISub","redShl","shl","redMul","_verify2","redIMul","_verify1","redISqr","redSqrt","sqrt","redInvm","redNeg","primes","k256","p224","p192","p25519","MPrime","name","tmp","_tmp","K256","P224","P192","P25519","prime","_prime","Mont","imod","rinv","minv","ireduce","rlen","split","imulK","_strip","input","output","outLen","prev","next","mod3","one","nOne","lpow","z","inv","wnd","current","currentLen","u","plural","ms","msAbs","isPlural","options","type","String","match","exec","parseFloat","toLowerCase","parse","isFinite","long","fmtLong","fmtShort","JSON","stringify","equal"],"mappings":"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","file":"static/js/main~56e1be11.549eb3f5.chunk.js","sourcesContent":["var safeIsNaN = Number.isNaN ||\n function ponyfill(value) {\n return typeof value === 'number' && value !== value;\n };\nfunction isEqual(first, second) {\n if (first === second) {\n return true;\n }\n if (safeIsNaN(first) && safeIsNaN(second)) {\n return true;\n }\n return false;\n}\nfunction areInputsEqual(newInputs, lastInputs) {\n if (newInputs.length !== lastInputs.length) {\n return false;\n }\n for (var i = 0; i < newInputs.length; i++) {\n if (!isEqual(newInputs[i], lastInputs[i])) {\n return false;\n }\n }\n return true;\n}\n\nfunction memoizeOne(resultFn, isEqual) {\n if (isEqual === void 0) { isEqual = areInputsEqual; }\n var lastThis;\n var lastArgs = [];\n var lastResult;\n var calledOnce = false;\n function memoized() {\n var newArgs = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n newArgs[_i] = arguments[_i];\n }\n if (calledOnce && lastThis === this && isEqual(newArgs, lastArgs)) {\n return lastResult;\n }\n lastResult = resultFn.apply(this, newArgs);\n calledOnce = true;\n lastThis = this;\n lastArgs = newArgs;\n return lastResult;\n }\n return memoized;\n}\n\nexport default memoizeOne;\n","'use strict'\nvar inherits = require('inherits')\nvar HashBase = require('hash-base')\nvar Buffer = require('safe-buffer').Buffer\n\nvar ARRAY16 = new Array(16)\n\nfunction MD5 () {\n HashBase.call(this, 64)\n\n // state\n this._a = 0x67452301\n this._b = 0xefcdab89\n this._c = 0x98badcfe\n this._d = 0x10325476\n}\n\ninherits(MD5, HashBase)\n\nMD5.prototype._update = function () {\n var M = ARRAY16\n for (var i = 0; i < 16; ++i) M[i] = this._block.readInt32LE(i * 4)\n\n var a = this._a\n var b = this._b\n var c = this._c\n var d = this._d\n\n a = fnF(a, b, c, d, M[0], 0xd76aa478, 7)\n d = fnF(d, a, b, c, M[1], 0xe8c7b756, 12)\n c = fnF(c, d, a, b, M[2], 0x242070db, 17)\n b = fnF(b, c, d, a, M[3], 0xc1bdceee, 22)\n a = fnF(a, b, c, d, M[4], 0xf57c0faf, 7)\n d = fnF(d, a, b, c, M[5], 0x4787c62a, 12)\n c = fnF(c, d, a, b, M[6], 0xa8304613, 17)\n b = fnF(b, c, d, a, M[7], 0xfd469501, 22)\n a = fnF(a, b, c, d, M[8], 0x698098d8, 7)\n d = fnF(d, a, b, c, M[9], 0x8b44f7af, 12)\n c = fnF(c, d, a, b, M[10], 0xffff5bb1, 17)\n b = fnF(b, c, d, a, M[11], 0x895cd7be, 22)\n a = fnF(a, b, c, d, M[12], 0x6b901122, 7)\n d = fnF(d, a, b, c, M[13], 0xfd987193, 12)\n c = fnF(c, d, a, b, M[14], 0xa679438e, 17)\n b = fnF(b, c, d, a, M[15], 0x49b40821, 22)\n\n a = fnG(a, b, c, d, M[1], 0xf61e2562, 5)\n d = fnG(d, a, b, c, M[6], 0xc040b340, 9)\n c = fnG(c, d, a, b, M[11], 0x265e5a51, 14)\n b = fnG(b, c, d, a, M[0], 0xe9b6c7aa, 20)\n a = fnG(a, b, c, d, M[5], 0xd62f105d, 5)\n d = fnG(d, a, b, c, M[10], 0x02441453, 9)\n c = fnG(c, d, a, b, M[15], 0xd8a1e681, 14)\n b = fnG(b, c, d, a, M[4], 0xe7d3fbc8, 20)\n a = fnG(a, b, c, d, M[9], 0x21e1cde6, 5)\n d = fnG(d, a, b, c, M[14], 0xc33707d6, 9)\n c = fnG(c, d, a, b, M[3], 0xf4d50d87, 14)\n b = fnG(b, c, d, a, M[8], 0x455a14ed, 20)\n a = fnG(a, b, c, d, M[13], 0xa9e3e905, 5)\n d = fnG(d, a, b, c, M[2], 0xfcefa3f8, 9)\n c = fnG(c, d, a, b, M[7], 0x676f02d9, 14)\n b = fnG(b, c, d, a, M[12], 0x8d2a4c8a, 20)\n\n a = fnH(a, b, c, d, M[5], 0xfffa3942, 4)\n d = fnH(d, a, b, c, M[8], 0x8771f681, 11)\n c = fnH(c, d, a, b, M[11], 0x6d9d6122, 16)\n b = fnH(b, c, d, a, M[14], 0xfde5380c, 23)\n a = fnH(a, b, c, d, M[1], 0xa4beea44, 4)\n d = fnH(d, a, b, c, M[4], 0x4bdecfa9, 11)\n c = fnH(c, d, a, b, M[7], 0xf6bb4b60, 16)\n b = fnH(b, c, d, a, M[10], 0xbebfbc70, 23)\n a = fnH(a, b, c, d, M[13], 0x289b7ec6, 4)\n d = fnH(d, a, b, c, M[0], 0xeaa127fa, 11)\n c = fnH(c, d, a, b, M[3], 0xd4ef3085, 16)\n b = fnH(b, c, d, a, M[6], 0x04881d05, 23)\n a = fnH(a, b, c, d, M[9], 0xd9d4d039, 4)\n d = fnH(d, a, b, c, M[12], 0xe6db99e5, 11)\n c = fnH(c, d, a, b, M[15], 0x1fa27cf8, 16)\n b = fnH(b, c, d, a, M[2], 0xc4ac5665, 23)\n\n a = fnI(a, b, c, d, M[0], 0xf4292244, 6)\n d = fnI(d, a, b, c, M[7], 0x432aff97, 10)\n c = fnI(c, d, a, b, M[14], 0xab9423a7, 15)\n b = fnI(b, c, d, a, M[5], 0xfc93a039, 21)\n a = fnI(a, b, c, d, M[12], 0x655b59c3, 6)\n d = fnI(d, a, b, c, M[3], 0x8f0ccc92, 10)\n c = fnI(c, d, a, b, M[10], 0xffeff47d, 15)\n b = fnI(b, c, d, a, M[1], 0x85845dd1, 21)\n a = fnI(a, b, c, d, M[8], 0x6fa87e4f, 6)\n d = fnI(d, a, b, c, M[15], 0xfe2ce6e0, 10)\n c = fnI(c, d, a, b, M[6], 0xa3014314, 15)\n b = fnI(b, c, d, a, M[13], 0x4e0811a1, 21)\n a = fnI(a, b, c, d, M[4], 0xf7537e82, 6)\n d = fnI(d, a, b, c, M[11], 0xbd3af235, 10)\n c = fnI(c, d, a, b, M[2], 0x2ad7d2bb, 15)\n b = fnI(b, c, d, a, M[9], 0xeb86d391, 21)\n\n this._a = (this._a + a) | 0\n this._b = (this._b + b) | 0\n this._c = (this._c + c) | 0\n this._d = (this._d + d) | 0\n}\n\nMD5.prototype._digest = function () {\n // create padding and handle blocks\n this._block[this._blockOffset++] = 0x80\n if (this._blockOffset > 56) {\n this._block.fill(0, this._blockOffset, 64)\n this._update()\n this._blockOffset = 0\n }\n\n this._block.fill(0, this._blockOffset, 56)\n this._block.writeUInt32LE(this._length[0], 56)\n this._block.writeUInt32LE(this._length[1], 60)\n this._update()\n\n // produce result\n var buffer = Buffer.allocUnsafe(16)\n buffer.writeInt32LE(this._a, 0)\n buffer.writeInt32LE(this._b, 4)\n buffer.writeInt32LE(this._c, 8)\n buffer.writeInt32LE(this._d, 12)\n return buffer\n}\n\nfunction rotl (x, n) {\n return (x << n) | (x >>> (32 - n))\n}\n\nfunction fnF (a, b, c, d, m, k, s) {\n return (rotl((a + ((b & c) | ((~b) & d)) + m + k) | 0, s) + b) | 0\n}\n\nfunction fnG (a, b, c, d, m, k, s) {\n return (rotl((a + ((b & d) | (c & (~d))) + m + k) | 0, s) + b) | 0\n}\n\nfunction fnH (a, b, c, d, m, k, s) {\n return (rotl((a + (b ^ c ^ d) + m + k) | 0, s) + b) | 0\n}\n\nfunction fnI (a, b, c, d, m, k, s) {\n return (rotl((a + ((c ^ (b | (~d)))) + m + k) | 0, s) + b) | 0\n}\n\nmodule.exports = MD5\n","var bn = require('bn.js');\nvar brorand = require('brorand');\n\nfunction MillerRabin(rand) {\n this.rand = rand || new brorand.Rand();\n}\nmodule.exports = MillerRabin;\n\nMillerRabin.create = function create(rand) {\n return new MillerRabin(rand);\n};\n\nMillerRabin.prototype._randbelow = function _randbelow(n) {\n var len = n.bitLength();\n var min_bytes = Math.ceil(len / 8);\n\n // Generage random bytes until a number less than n is found.\n // This ensures that 0..n-1 have an equal probability of being selected.\n do\n var a = new bn(this.rand.generate(min_bytes));\n while (a.cmp(n) >= 0);\n\n return a;\n};\n\nMillerRabin.prototype._randrange = function _randrange(start, stop) {\n // Generate a random number greater than or equal to start and less than stop.\n var size = stop.sub(start);\n return start.add(this._randbelow(size));\n};\n\nMillerRabin.prototype.test = function test(n, k, cb) {\n var len = n.bitLength();\n var red = bn.mont(n);\n var rone = new bn(1).toRed(red);\n\n if (!k)\n k = Math.max(1, (len / 48) | 0);\n\n // Find d and s, (n - 1) = (2 ^ s) * d;\n var n1 = n.subn(1);\n for (var s = 0; !n1.testn(s); s++) {}\n var d = n.shrn(s);\n\n var rn1 = n1.toRed(red);\n\n var prime = true;\n for (; k > 0; k--) {\n var a = this._randrange(new bn(2), n1);\n if (cb)\n cb(a);\n\n var x = a.toRed(red).redPow(d);\n if (x.cmp(rone) === 0 || x.cmp(rn1) === 0)\n continue;\n\n for (var i = 1; i < s; i++) {\n x = x.redSqr();\n\n if (x.cmp(rone) === 0)\n return false;\n if (x.cmp(rn1) === 0)\n break;\n }\n\n if (i === s)\n return false;\n }\n\n return prime;\n};\n\nMillerRabin.prototype.getDivisor = function getDivisor(n, k) {\n var len = n.bitLength();\n var red = bn.mont(n);\n var rone = new bn(1).toRed(red);\n\n if (!k)\n k = Math.max(1, (len / 48) | 0);\n\n // Find d and s, (n - 1) = (2 ^ s) * d;\n var n1 = n.subn(1);\n for (var s = 0; !n1.testn(s); s++) {}\n var d = n.shrn(s);\n\n var rn1 = n1.toRed(red);\n\n for (; k > 0; k--) {\n var a = this._randrange(new bn(2), n1);\n\n var g = n.gcd(a);\n if (g.cmpn(1) !== 0)\n return g;\n\n var x = a.toRed(red).redPow(d);\n if (x.cmp(rone) === 0 || x.cmp(rn1) === 0)\n continue;\n\n for (var i = 1; i < s; i++) {\n x = x.redSqr();\n\n if (x.cmp(rone) === 0)\n return x.fromRed().subn(1).gcd(n);\n if (x.cmp(rn1) === 0)\n break;\n }\n\n if (i === s) {\n x = x.redSqr();\n return x.fromRed().subn(1).gcd(n);\n }\n }\n\n return false;\n};\n","'use strict';\n\nvar utils = exports;\n\nfunction toArray(msg, enc) {\n if (Array.isArray(msg))\n return msg.slice();\n if (!msg)\n return [];\n var res = [];\n if (typeof msg !== 'string') {\n for (var i = 0; i < msg.length; i++)\n res[i] = msg[i] | 0;\n return res;\n }\n if (enc === 'hex') {\n msg = msg.replace(/[^a-z0-9]+/ig, '');\n if (msg.length % 2 !== 0)\n msg = '0' + msg;\n for (var i = 0; i < msg.length; i += 2)\n res.push(parseInt(msg[i] + msg[i + 1], 16));\n } else {\n for (var i = 0; i < msg.length; i++) {\n var c = msg.charCodeAt(i);\n var hi = c >> 8;\n var lo = c & 0xff;\n if (hi)\n res.push(hi, lo);\n else\n res.push(lo);\n }\n }\n return res;\n}\nutils.toArray = toArray;\n\nfunction zero2(word) {\n if (word.length === 1)\n return '0' + word;\n else\n return word;\n}\nutils.zero2 = zero2;\n\nfunction toHex(msg) {\n var res = '';\n for (var i = 0; i < msg.length; i++)\n res += zero2(msg[i].toString(16));\n return res;\n}\nutils.toHex = toHex;\n\nutils.encode = function encode(arr, enc) {\n if (enc === 'hex')\n return toHex(arr);\n else\n return arr;\n};\n","import React, { Component } from 'react';\nimport _inheritsLoose from '@babel/runtime/helpers/esm/inheritsLoose';\nimport PropTypes from 'prop-types';\nimport warning from 'tiny-warning';\n\nvar MAX_SIGNED_31_BIT_INT = 1073741823;\nvar commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : {};\n\nfunction getUniqueId() {\n var key = '__global_unique_id__';\n return commonjsGlobal[key] = (commonjsGlobal[key] || 0) + 1;\n}\n\nfunction objectIs(x, y) {\n if (x === y) {\n return x !== 0 || 1 / x === 1 / y;\n } else {\n return x !== x && y !== y;\n }\n}\n\nfunction createEventEmitter(value) {\n var handlers = [];\n return {\n on: function on(handler) {\n handlers.push(handler);\n },\n off: function off(handler) {\n handlers = handlers.filter(function (h) {\n return h !== handler;\n });\n },\n get: function get() {\n return value;\n },\n set: function set(newValue, changedBits) {\n value = newValue;\n handlers.forEach(function (handler) {\n return handler(value, changedBits);\n });\n }\n };\n}\n\nfunction onlyChild(children) {\n return Array.isArray(children) ? children[0] : children;\n}\n\nfunction createReactContext(defaultValue, calculateChangedBits) {\n var _Provider$childContex, _Consumer$contextType;\n\n var contextProp = '__create-react-context-' + getUniqueId() + '__';\n\n var Provider = /*#__PURE__*/function (_Component) {\n _inheritsLoose(Provider, _Component);\n\n function Provider() {\n var _this;\n\n _this = _Component.apply(this, arguments) || this;\n _this.emitter = createEventEmitter(_this.props.value);\n return _this;\n }\n\n var _proto = Provider.prototype;\n\n _proto.getChildContext = function getChildContext() {\n var _ref;\n\n return _ref = {}, _ref[contextProp] = this.emitter, _ref;\n };\n\n _proto.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n if (this.props.value !== nextProps.value) {\n var oldValue = this.props.value;\n var newValue = nextProps.value;\n var changedBits;\n\n if (objectIs(oldValue, newValue)) {\n changedBits = 0;\n } else {\n changedBits = typeof calculateChangedBits === 'function' ? calculateChangedBits(oldValue, newValue) : MAX_SIGNED_31_BIT_INT;\n\n if (process.env.NODE_ENV !== 'production') {\n warning((changedBits & MAX_SIGNED_31_BIT_INT) === changedBits, 'calculateChangedBits: Expected the return value to be a ' + '31-bit integer. Instead received: ' + changedBits);\n }\n\n changedBits |= 0;\n\n if (changedBits !== 0) {\n this.emitter.set(nextProps.value, changedBits);\n }\n }\n }\n };\n\n _proto.render = function render() {\n return this.props.children;\n };\n\n return Provider;\n }(Component);\n\n Provider.childContextTypes = (_Provider$childContex = {}, _Provider$childContex[contextProp] = PropTypes.object.isRequired, _Provider$childContex);\n\n var Consumer = /*#__PURE__*/function (_Component2) {\n _inheritsLoose(Consumer, _Component2);\n\n function Consumer() {\n var _this2;\n\n _this2 = _Component2.apply(this, arguments) || this;\n _this2.state = {\n value: _this2.getValue()\n };\n\n _this2.onUpdate = function (newValue, changedBits) {\n var observedBits = _this2.observedBits | 0;\n\n if ((observedBits & changedBits) !== 0) {\n _this2.setState({\n value: _this2.getValue()\n });\n }\n };\n\n return _this2;\n }\n\n var _proto2 = Consumer.prototype;\n\n _proto2.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n var observedBits = nextProps.observedBits;\n this.observedBits = observedBits === undefined || observedBits === null ? MAX_SIGNED_31_BIT_INT : observedBits;\n };\n\n _proto2.componentDidMount = function componentDidMount() {\n if (this.context[contextProp]) {\n this.context[contextProp].on(this.onUpdate);\n }\n\n var observedBits = this.props.observedBits;\n this.observedBits = observedBits === undefined || observedBits === null ? MAX_SIGNED_31_BIT_INT : observedBits;\n };\n\n _proto2.componentWillUnmount = function componentWillUnmount() {\n if (this.context[contextProp]) {\n this.context[contextProp].off(this.onUpdate);\n }\n };\n\n _proto2.getValue = function getValue() {\n if (this.context[contextProp]) {\n return this.context[contextProp].get();\n } else {\n return defaultValue;\n }\n };\n\n _proto2.render = function render() {\n return onlyChild(this.props.children)(this.state.value);\n };\n\n return Consumer;\n }(Component);\n\n Consumer.contextTypes = (_Consumer$contextType = {}, _Consumer$contextType[contextProp] = PropTypes.object, _Consumer$contextType);\n return {\n Provider: Provider,\n Consumer: Consumer\n };\n}\n\nvar index = React.createContext || createReactContext;\n\nexport default index;\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","/**\n * Helpers.\n */\n\nvar s = 1000;\nvar m = s * 60;\nvar h = m * 60;\nvar d = h * 24;\nvar w = d * 7;\nvar y = d * 365.25;\n\n/**\n * Parse or format the given `val`.\n *\n * Options:\n *\n * - `long` verbose formatting [false]\n *\n * @param {String|Number} val\n * @param {Object} [options]\n * @throws {Error} throw an error if val is not a non-empty string or a number\n * @return {String|Number}\n * @api public\n */\n\nmodule.exports = function (val, options) {\n options = options || {};\n var type = typeof val;\n if (type === 'string' && val.length > 0) {\n return parse(val);\n } else if (type === 'number' && isFinite(val)) {\n return options.long ? fmtLong(val) : fmtShort(val);\n }\n throw new Error(\n 'val is not a non-empty string or a valid number. val=' +\n JSON.stringify(val)\n );\n};\n\n/**\n * Parse the given `str` and return milliseconds.\n *\n * @param {String} str\n * @return {Number}\n * @api private\n */\n\nfunction parse(str) {\n str = String(str);\n if (str.length > 100) {\n return;\n }\n var match = /^(-?(?:\\d+)?\\.?\\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(\n str\n );\n if (!match) {\n return;\n }\n var n = parseFloat(match[1]);\n var type = (match[2] || 'ms').toLowerCase();\n switch (type) {\n case 'years':\n case 'year':\n case 'yrs':\n case 'yr':\n case 'y':\n return n * y;\n case 'weeks':\n case 'week':\n case 'w':\n return n * w;\n case 'days':\n case 'day':\n case 'd':\n return n * d;\n case 'hours':\n case 'hour':\n case 'hrs':\n case 'hr':\n case 'h':\n return n * h;\n case 'minutes':\n case 'minute':\n case 'mins':\n case 'min':\n case 'm':\n return n * m;\n case 'seconds':\n case 'second':\n case 'secs':\n case 'sec':\n case 's':\n return n * s;\n case 'milliseconds':\n case 'millisecond':\n case 'msecs':\n case 'msec':\n case 'ms':\n return n;\n default:\n return undefined;\n }\n}\n\n/**\n * Short format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtShort(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return Math.round(ms / d) + 'd';\n }\n if (msAbs >= h) {\n return Math.round(ms / h) + 'h';\n }\n if (msAbs >= m) {\n return Math.round(ms / m) + 'm';\n }\n if (msAbs >= s) {\n return Math.round(ms / s) + 's';\n }\n return ms + 'ms';\n}\n\n/**\n * Long format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtLong(ms) {\n var msAbs = Math.abs(ms);\n if (msAbs >= d) {\n return plural(ms, msAbs, d, 'day');\n }\n if (msAbs >= h) {\n return plural(ms, msAbs, h, 'hour');\n }\n if (msAbs >= m) {\n return plural(ms, msAbs, m, 'minute');\n }\n if (msAbs >= s) {\n return plural(ms, msAbs, s, 'second');\n }\n return ms + ' ms';\n}\n\n/**\n * Pluralization helper.\n */\n\nfunction plural(ms, msAbs, n, name) {\n var isPlural = msAbs >= n * 1.5;\n return Math.round(ms / n) + ' ' + name + (isPlural ? 's' : '');\n}\n","module.exports = assert;\n\nfunction assert(val, msg) {\n if (!val)\n throw new Error(msg || 'Assertion failed');\n}\n\nassert.equal = function assertEqual(l, r, msg) {\n if (l != r)\n throw new Error(msg || ('Assertion failed: ' + l + ' != ' + r));\n};\n"],"sourceRoot":""}