@cetusprotocol/dlmm-zap-sdk 1.0.2 → 1.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.d.ts +576 -5
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../node_modules/.pnpm/bn.js@5.2.3/node_modules/bn.js/lib/bn.js","../src/sdk.ts","../src/config/mainnet.ts","../src/config/testnet.ts","../src/modules/zapModule.ts","../src/errors/errors.ts","../src/types/zap.ts","../src/utils/zap.ts","../src/index.ts"],"sourcesContent":["(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert (val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits (ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN (number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n\n BN.BN = BN;\n BN.wordSize = 26;\n\n var Buffer;\n try {\n if (typeof window !== 'undefined' && typeof window.Buffer !== 'undefined') {\n Buffer = window.Buffer;\n } else {\n Buffer = require('buffer').Buffer;\n }\n } catch (e) {\n }\n\n BN.isBN = function isBN (num) {\n if (num instanceof BN) {\n return true;\n }\n\n return num !== null && typeof num === 'object' &&\n num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n };\n\n BN.max = function max (left, right) {\n if (left.cmp(right) > 0) return left;\n return right;\n };\n\n BN.min = function min (left, right) {\n if (left.cmp(right) < 0) return left;\n return right;\n };\n\n BN.prototype._init = function init (number, base, endian) {\n if (typeof number === 'number') {\n return this._initNumber(number, base, endian);\n }\n\n if (typeof number === 'object') {\n return this._initArray(number, base, endian);\n }\n\n if (base === 'hex') {\n base = 16;\n }\n assert(base === (base | 0) && base >= 2 && base <= 36);\n\n number = number.toString().replace(/\\s+/g, '');\n var start = 0;\n if (number[0] === '-') {\n start++;\n this.negative = 1;\n }\n\n if (start < number.length) {\n if (base === 16) {\n this._parseHex(number, start, endian);\n } else {\n this._parseBase(number, base, start);\n if (endian === 'le') {\n this._initArray(this.toArray(), base, endian);\n }\n }\n }\n };\n\n BN.prototype._initNumber = function _initNumber (number, base, endian) {\n if (number < 0) {\n this.negative = 1;\n number = -number;\n }\n if (number < 0x4000000) {\n this.words = [number & 0x3ffffff];\n this.length = 1;\n } else if (number < 0x10000000000000) {\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff\n ];\n this.length = 2;\n } else {\n assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff,\n 1\n ];\n this.length = 3;\n }\n\n if (endian !== 'le') return;\n\n // Reverse the bytes\n this._initArray(this.toArray(), base, endian);\n };\n\n BN.prototype._initArray = function _initArray (number, base, endian) {\n // Perhaps a Uint8Array\n assert(typeof number.length === 'number');\n if (number.length <= 0) {\n this.words = [0];\n this.length = 1;\n return this;\n }\n\n this.length = Math.ceil(number.length / 3);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n var j, w;\n var off = 0;\n if (endian === 'be') {\n for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n w = number[i] | (number[i - 1] << 8) | (number[i - 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n } else if (endian === 'le') {\n for (i = 0, j = 0; i < number.length; i += 3) {\n w = number[i] | (number[i + 1] << 8) | (number[i + 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n }\n return this._strip();\n };\n\n function parseHex4Bits (string, index) {\n var c = string.charCodeAt(index);\n // '0' - '9'\n if (c >= 48 && c <= 57) {\n return c - 48;\n // 'A' - 'F'\n } else if (c >= 65 && c <= 70) {\n return c - 55;\n // 'a' - 'f'\n } else if (c >= 97 && c <= 102) {\n return c - 87;\n } else {\n assert(false, 'Invalid character in ' + string);\n }\n }\n\n function parseHexByte (string, lowerBound, index) {\n var r = parseHex4Bits(string, index);\n if (index - 1 >= lowerBound) {\n r |= parseHex4Bits(string, index - 1) << 4;\n }\n return r;\n }\n\n BN.prototype._parseHex = function _parseHex (number, start, endian) {\n // Create possibly bigger array to ensure that it fits the number\n this.length = Math.ceil((number.length - start) / 6);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n // 24-bits chunks\n var off = 0;\n var j = 0;\n\n var w;\n if (endian === 'be') {\n for (i = number.length - 1; i >= start; i -= 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n } else {\n var parseLength = number.length - start;\n for (i = parseLength % 2 === 0 ? start + 1 : start; i < number.length; i += 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n }\n\n this._strip();\n };\n\n function parseBase (str, start, end, mul) {\n var r = 0;\n var b = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n\n r *= mul;\n\n // 'a'\n if (c >= 49) {\n b = c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n b = c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n b = c;\n }\n assert(c >= 0 && b < mul, 'Invalid character');\n r += b;\n }\n return r;\n }\n\n BN.prototype._parseBase = function _parseBase (number, base, start) {\n // Initialize as zero\n this.words = [0];\n this.length = 1;\n\n // Find length of limb in base\n for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n limbLen++;\n }\n limbLen--;\n limbPow = (limbPow / base) | 0;\n\n var total = number.length - start;\n var mod = total % limbLen;\n var end = Math.min(total, total - mod) + start;\n\n var word = 0;\n for (var i = start; i < end; i += limbLen) {\n word = parseBase(number, i, i + limbLen, base);\n\n this.imuln(limbPow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n if (mod !== 0) {\n var pow = 1;\n word = parseBase(number, i, number.length, base);\n\n for (i = 0; i < mod; i++) {\n pow *= base;\n }\n\n this.imuln(pow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n this._strip();\n };\n\n BN.prototype.copy = function copy (dest) {\n dest.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n dest.words[i] = this.words[i];\n }\n dest.length = this.length;\n dest.negative = this.negative;\n dest.red = this.red;\n };\n\n function move (dest, src) {\n dest.words = src.words;\n dest.length = src.length;\n dest.negative = src.negative;\n dest.red = src.red;\n }\n\n BN.prototype._move = function _move (dest) {\n move(dest, this);\n };\n\n BN.prototype.clone = function clone () {\n var r = new BN(null);\n this.copy(r);\n return r;\n };\n\n BN.prototype._expand = function _expand (size) {\n while (this.length < size) {\n this.words[this.length++] = 0;\n }\n return this;\n };\n\n // Remove leading `0` from `this`\n BN.prototype._strip = function strip () {\n while (this.length > 1 && this.words[this.length - 1] === 0) {\n this.length--;\n }\n return this._normSign();\n };\n\n BN.prototype._normSign = function _normSign () {\n // -0 = 0\n if (this.length === 1 && this.words[0] === 0) {\n this.negative = 0;\n }\n return this;\n };\n\n // Check Symbol.for because not everywhere where Symbol defined\n // See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Symbol#Browser_compatibility\n if (typeof Symbol !== 'undefined' && typeof Symbol.for === 'function') {\n try {\n BN.prototype[Symbol.for('nodejs.util.inspect.custom')] = inspect;\n } catch (e) {\n BN.prototype.inspect = inspect;\n }\n } else {\n BN.prototype.inspect = inspect;\n }\n\n function inspect () {\n return (this.red ? '<BN-R: ' : '<BN: ') + this.toString(16) + '>';\n }\n\n /*\n\n var zeros = [];\n var groupSizes = [];\n var groupBases = [];\n\n var s = '';\n var i = -1;\n while (++i < BN.wordSize) {\n zeros[i] = s;\n s += '0';\n }\n groupSizes[0] = 0;\n groupSizes[1] = 0;\n groupBases[0] = 0;\n groupBases[1] = 0;\n var base = 2 - 1;\n while (++base < 36 + 1) {\n var groupSize = 0;\n var groupBase = 1;\n while (groupBase < (1 << BN.wordSize) / base) {\n groupBase *= base;\n groupSize += 1;\n }\n groupSizes[base] = groupSize;\n groupBases[base] = groupBase;\n }\n\n */\n\n var zeros = [\n '',\n '0',\n '00',\n '000',\n '0000',\n '00000',\n '000000',\n '0000000',\n '00000000',\n '000000000',\n '0000000000',\n '00000000000',\n '000000000000',\n '0000000000000',\n '00000000000000',\n '000000000000000',\n '0000000000000000',\n '00000000000000000',\n '000000000000000000',\n '0000000000000000000',\n '00000000000000000000',\n '000000000000000000000',\n '0000000000000000000000',\n '00000000000000000000000',\n '000000000000000000000000',\n '0000000000000000000000000'\n ];\n\n var groupSizes = [\n 0, 0,\n 25, 16, 12, 11, 10, 9, 8,\n 8, 7, 7, 7, 7, 6, 6,\n 6, 6, 6, 6, 6, 5, 5,\n 5, 5, 5, 5, 5, 5, 5,\n 5, 5, 5, 5, 5, 5, 5\n ];\n\n var groupBases = [\n 0, 0,\n 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216,\n 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625,\n 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632,\n 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149,\n 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176\n ];\n\n BN.prototype.toString = function toString (base, padding) {\n base = base || 10;\n padding = padding | 0 || 1;\n\n var out;\n if (base === 16 || base === 'hex') {\n out = '';\n var off = 0;\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = this.words[i];\n var word = (((w << off) | carry) & 0xffffff).toString(16);\n carry = (w >>> (24 - off)) & 0xffffff;\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\n }\n if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n }\n if (carry !== 0) {\n out = carry.toString(16) + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n if (base === (base | 0) && base >= 2 && base <= 36) {\n // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n var groupSize = groupSizes[base];\n // var groupBase = Math.pow(base, groupSize);\n var groupBase = groupBases[base];\n out = '';\n var c = this.clone();\n c.negative = 0;\n while (!c.isZero()) {\n var r = c.modrn(groupBase).toString(base);\n c = c.idivn(groupBase);\n\n if (!c.isZero()) {\n out = zeros[groupSize - r.length] + r + out;\n } else {\n out = r + out;\n }\n }\n if (this.isZero()) {\n out = '0' + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n assert(false, 'Base should be between 2 and 36');\n };\n\n BN.prototype.toNumber = function toNumber () {\n var ret = this.words[0];\n if (this.length === 2) {\n ret += this.words[1] * 0x4000000;\n } else if (this.length === 3 && this.words[2] === 0x01) {\n // NOTE: at this stage it is known that the top bit is set\n ret += 0x10000000000000 + (this.words[1] * 0x4000000);\n } else if (this.length > 2) {\n assert(false, 'Number can only safely store up to 53 bits');\n }\n return (this.negative !== 0) ? -ret : ret;\n };\n\n BN.prototype.toJSON = function toJSON () {\n return this.toString(16, 2);\n };\n\n if (Buffer) {\n BN.prototype.toBuffer = function toBuffer (endian, length) {\n return this.toArrayLike(Buffer, endian, length);\n };\n }\n\n BN.prototype.toArray = function toArray (endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n\n var allocate = function allocate (ArrayType, size) {\n if (ArrayType.allocUnsafe) {\n return ArrayType.allocUnsafe(size);\n }\n return new ArrayType(size);\n };\n\n BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) {\n this._strip();\n\n var byteLength = this.byteLength();\n var reqLength = length || Math.max(1, byteLength);\n assert(byteLength <= reqLength, 'byte array longer than desired length');\n assert(reqLength > 0, 'Requested array length <= 0');\n\n var res = allocate(ArrayType, reqLength);\n var postfix = endian === 'le' ? 'LE' : 'BE';\n this['_toArrayLike' + postfix](res, byteLength);\n return res;\n };\n\n BN.prototype._toArrayLikeLE = function _toArrayLikeLE (res, byteLength) {\n var position = 0;\n var carry = 0;\n\n for (var i = 0, shift = 0; i < this.length; i++) {\n var word = (this.words[i] << shift) | carry;\n\n res[position++] = word & 0xff;\n if (position < res.length) {\n res[position++] = (word >> 8) & 0xff;\n }\n if (position < res.length) {\n res[position++] = (word >> 16) & 0xff;\n }\n\n if (shift === 6) {\n if (position < res.length) {\n res[position++] = (word >> 24) & 0xff;\n }\n carry = 0;\n shift = 0;\n } else {\n carry = word >>> 24;\n shift += 2;\n }\n }\n\n if (position < res.length) {\n res[position++] = carry;\n\n while (position < res.length) {\n res[position++] = 0;\n }\n }\n };\n\n BN.prototype._toArrayLikeBE = function _toArrayLikeBE (res, byteLength) {\n var position = res.length - 1;\n var carry = 0;\n\n for (var i = 0, shift = 0; i < this.length; i++) {\n var word = (this.words[i] << shift) | carry;\n\n res[position--] = word & 0xff;\n if (position >= 0) {\n res[position--] = (word >> 8) & 0xff;\n }\n if (position >= 0) {\n res[position--] = (word >> 16) & 0xff;\n }\n\n if (shift === 6) {\n if (position >= 0) {\n res[position--] = (word >> 24) & 0xff;\n }\n carry = 0;\n shift = 0;\n } else {\n carry = word >>> 24;\n shift += 2;\n }\n }\n\n if (position >= 0) {\n res[position--] = carry;\n\n while (position >= 0) {\n res[position--] = 0;\n }\n }\n };\n\n if (Math.clz32) {\n BN.prototype._countBits = function _countBits (w) {\n return 32 - Math.clz32(w);\n };\n } else {\n BN.prototype._countBits = function _countBits (w) {\n var t = w;\n var r = 0;\n if (t >= 0x1000) {\n r += 13;\n t >>>= 13;\n }\n if (t >= 0x40) {\n r += 7;\n t >>>= 7;\n }\n if (t >= 0x8) {\n r += 4;\n t >>>= 4;\n }\n if (t >= 0x02) {\n r += 2;\n t >>>= 2;\n }\n return r + t;\n };\n }\n\n BN.prototype._zeroBits = function _zeroBits (w) {\n // Short-cut\n if (w === 0) return 26;\n\n var t = w;\n var r = 0;\n if ((t & 0x1fff) === 0) {\n r += 13;\n t >>>= 13;\n }\n if ((t & 0x7f) === 0) {\n r += 7;\n t >>>= 7;\n }\n if ((t & 0xf) === 0) {\n r += 4;\n t >>>= 4;\n }\n if ((t & 0x3) === 0) {\n r += 2;\n t >>>= 2;\n }\n if ((t & 0x1) === 0) {\n r++;\n }\n return r;\n };\n\n // Return number of used bits in a BN\n BN.prototype.bitLength = function bitLength () {\n var w = this.words[this.length - 1];\n var hi = this._countBits(w);\n return (this.length - 1) * 26 + hi;\n };\n\n function toBitArray (num) {\n var w = new Array(num.bitLength());\n\n for (var bit = 0; bit < w.length; bit++) {\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n w[bit] = (num.words[off] >>> wbit) & 0x01;\n }\n\n return w;\n }\n\n // Number of trailing zero bits\n BN.prototype.zeroBits = function zeroBits () {\n if (this.isZero()) return 0;\n\n var r = 0;\n for (var i = 0; i < this.length; i++) {\n var b = this._zeroBits(this.words[i]);\n r += b;\n if (b !== 26) break;\n }\n return r;\n };\n\n BN.prototype.byteLength = function byteLength () {\n return Math.ceil(this.bitLength() / 8);\n };\n\n BN.prototype.toTwos = function toTwos (width) {\n if (this.negative !== 0) {\n return this.abs().inotn(width).iaddn(1);\n }\n return this.clone();\n };\n\n BN.prototype.fromTwos = function fromTwos (width) {\n if (this.testn(width - 1)) {\n return this.notn(width).iaddn(1).ineg();\n }\n return this.clone();\n };\n\n BN.prototype.isNeg = function isNeg () {\n return this.negative !== 0;\n };\n\n // Return negative clone of `this`\n BN.prototype.neg = function neg () {\n return this.clone().ineg();\n };\n\n BN.prototype.ineg = function ineg () {\n if (!this.isZero()) {\n this.negative ^= 1;\n }\n\n return this;\n };\n\n // Or `num` with `this` in-place\n BN.prototype.iuor = function iuor (num) {\n while (this.length < num.length) {\n this.words[this.length++] = 0;\n }\n\n for (var i = 0; i < num.length; i++) {\n this.words[i] = this.words[i] | num.words[i];\n }\n\n return this._strip();\n };\n\n BN.prototype.ior = function ior (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuor(num);\n };\n\n // Or `num` with `this`\n BN.prototype.or = function or (num) {\n if (this.length > num.length) return this.clone().ior(num);\n return num.clone().ior(this);\n };\n\n BN.prototype.uor = function uor (num) {\n if (this.length > num.length) return this.clone().iuor(num);\n return num.clone().iuor(this);\n };\n\n // And `num` with `this` in-place\n BN.prototype.iuand = function iuand (num) {\n // b = min-length(num, this)\n var b;\n if (this.length > num.length) {\n b = num;\n } else {\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = this.words[i] & num.words[i];\n }\n\n this.length = b.length;\n\n return this._strip();\n };\n\n BN.prototype.iand = function iand (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuand(num);\n };\n\n // And `num` with `this`\n BN.prototype.and = function and (num) {\n if (this.length > num.length) return this.clone().iand(num);\n return num.clone().iand(this);\n };\n\n BN.prototype.uand = function uand (num) {\n if (this.length > num.length) return this.clone().iuand(num);\n return num.clone().iuand(this);\n };\n\n // Xor `num` with `this` in-place\n BN.prototype.iuxor = function iuxor (num) {\n // a.length > b.length\n var a;\n var b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = a.words[i] ^ b.words[i];\n }\n\n if (this !== a) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = a.length;\n\n return this._strip();\n };\n\n BN.prototype.ixor = function ixor (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuxor(num);\n };\n\n // Xor `num` with `this`\n BN.prototype.xor = function xor (num) {\n if (this.length > num.length) return this.clone().ixor(num);\n return num.clone().ixor(this);\n };\n\n BN.prototype.uxor = function uxor (num) {\n if (this.length > num.length) return this.clone().iuxor(num);\n return num.clone().iuxor(this);\n };\n\n // Not ``this`` with ``width`` bitwidth\n BN.prototype.inotn = function inotn (width) {\n assert(typeof width === 'number' && width >= 0);\n\n var bytesNeeded = Math.ceil(width / 26) | 0;\n var bitsLeft = width % 26;\n\n // Extend the buffer with leading zeroes\n this._expand(bytesNeeded);\n\n if (bitsLeft > 0) {\n bytesNeeded--;\n }\n\n // Handle complete words\n for (var i = 0; i < bytesNeeded; i++) {\n this.words[i] = ~this.words[i] & 0x3ffffff;\n }\n\n // Handle the residue\n if (bitsLeft > 0) {\n this.words[i] = ~this.words[i] & (0x3ffffff >> (26 - bitsLeft));\n }\n\n // And remove leading zeroes\n return this._strip();\n };\n\n BN.prototype.notn = function notn (width) {\n return this.clone().inotn(width);\n };\n\n // Set `bit` of `this`\n BN.prototype.setn = function setn (bit, val) {\n assert(typeof bit === 'number' && bit >= 0);\n\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n this._expand(off + 1);\n\n if (val) {\n this.words[off] = this.words[off] | (1 << wbit);\n } else {\n this.words[off] = this.words[off] & ~(1 << wbit);\n }\n\n return this._strip();\n };\n\n // Add `num` to `this` in-place\n BN.prototype.iadd = function iadd (num) {\n var r;\n\n // negative + positive\n if (this.negative !== 0 && num.negative === 0) {\n this.negative = 0;\n r = this.isub(num);\n this.negative ^= 1;\n return this._normSign();\n\n // positive + negative\n } else if (this.negative === 0 && num.negative !== 0) {\n num.negative = 0;\n r = this.isub(num);\n num.negative = 1;\n return r._normSign();\n }\n\n // a.length > b.length\n var a, b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n\n this.length = a.length;\n if (carry !== 0) {\n this.words[this.length] = carry;\n this.length++;\n // Copy the rest of the words\n } else if (a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n return this;\n };\n\n // Add `num` to `this`\n BN.prototype.add = function add (num) {\n var res;\n if (num.negative !== 0 && this.negative === 0) {\n num.negative = 0;\n res = this.sub(num);\n num.negative ^= 1;\n return res;\n } else if (num.negative === 0 && this.negative !== 0) {\n this.negative = 0;\n res = num.sub(this);\n this.negative = 1;\n return res;\n }\n\n if (this.length > num.length) return this.clone().iadd(num);\n\n return num.clone().iadd(this);\n };\n\n // Subtract `num` from `this` in-place\n BN.prototype.isub = function isub (num) {\n // this - (-num) = this + num\n if (num.negative !== 0) {\n num.negative = 0;\n var r = this.iadd(num);\n num.negative = 1;\n return r._normSign();\n\n // -this - num = -(this + num)\n } else if (this.negative !== 0) {\n this.negative = 0;\n this.iadd(num);\n this.negative = 1;\n return this._normSign();\n }\n\n // At this point both numbers are positive\n var cmp = this.cmp(num);\n\n // Optimization - zeroify\n if (cmp === 0) {\n this.negative = 0;\n this.length = 1;\n this.words[0] = 0;\n return this;\n }\n\n // a > b\n var a, b;\n if (cmp > 0) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n\n // Copy rest of the words\n if (carry === 0 && i < a.length && a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = Math.max(this.length, i);\n\n if (a !== this) {\n this.negative = 1;\n }\n\n return this._strip();\n };\n\n // Subtract `num` from `this`\n BN.prototype.sub = function sub (num) {\n return this.clone().isub(num);\n };\n\n function smallMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n var len = (self.length + num.length) | 0;\n out.length = len;\n len = (len - 1) | 0;\n\n // Peel one iteration (compiler can't do it, because of code complexity)\n var a = self.words[0] | 0;\n var b = num.words[0] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n var carry = (r / 0x4000000) | 0;\n out.words[0] = lo;\n\n for (var k = 1; k < len; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = carry >>> 26;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = (k - j) | 0;\n a = self.words[i] | 0;\n b = num.words[j] | 0;\n r = a * b + rword;\n ncarry += (r / 0x4000000) | 0;\n rword = r & 0x3ffffff;\n }\n out.words[k] = rword | 0;\n carry = ncarry | 0;\n }\n if (carry !== 0) {\n out.words[k] = carry | 0;\n } else {\n out.length--;\n }\n\n return out._strip();\n }\n\n // TODO(indutny): it may be reasonable to omit it for users who don't need\n // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n // multiplication (like elliptic secp256k1).\n var comb10MulTo = function comb10MulTo (self, num, out) {\n var a = self.words;\n var b = num.words;\n var o = out.words;\n var c = 0;\n var lo;\n var mid;\n var hi;\n var a0 = a[0] | 0;\n var al0 = a0 & 0x1fff;\n var ah0 = a0 >>> 13;\n var a1 = a[1] | 0;\n var al1 = a1 & 0x1fff;\n var ah1 = a1 >>> 13;\n var a2 = a[2] | 0;\n var al2 = a2 & 0x1fff;\n var ah2 = a2 >>> 13;\n var a3 = a[3] | 0;\n var al3 = a3 & 0x1fff;\n var ah3 = a3 >>> 13;\n var a4 = a[4] | 0;\n var al4 = a4 & 0x1fff;\n var ah4 = a4 >>> 13;\n var a5 = a[5] | 0;\n var al5 = a5 & 0x1fff;\n var ah5 = a5 >>> 13;\n var a6 = a[6] | 0;\n var al6 = a6 & 0x1fff;\n var ah6 = a6 >>> 13;\n var a7 = a[7] | 0;\n var al7 = a7 & 0x1fff;\n var ah7 = a7 >>> 13;\n var a8 = a[8] | 0;\n var al8 = a8 & 0x1fff;\n var ah8 = a8 >>> 13;\n var a9 = a[9] | 0;\n var al9 = a9 & 0x1fff;\n var ah9 = a9 >>> 13;\n var b0 = b[0] | 0;\n var bl0 = b0 & 0x1fff;\n var bh0 = b0 >>> 13;\n var b1 = b[1] | 0;\n var bl1 = b1 & 0x1fff;\n var bh1 = b1 >>> 13;\n var b2 = b[2] | 0;\n var bl2 = b2 & 0x1fff;\n var bh2 = b2 >>> 13;\n var b3 = b[3] | 0;\n var bl3 = b3 & 0x1fff;\n var bh3 = b3 >>> 13;\n var b4 = b[4] | 0;\n var bl4 = b4 & 0x1fff;\n var bh4 = b4 >>> 13;\n var b5 = b[5] | 0;\n var bl5 = b5 & 0x1fff;\n var bh5 = b5 >>> 13;\n var b6 = b[6] | 0;\n var bl6 = b6 & 0x1fff;\n var bh6 = b6 >>> 13;\n var b7 = b[7] | 0;\n var bl7 = b7 & 0x1fff;\n var bh7 = b7 >>> 13;\n var b8 = b[8] | 0;\n var bl8 = b8 & 0x1fff;\n var bh8 = b8 >>> 13;\n var b9 = b[9] | 0;\n var bl9 = b9 & 0x1fff;\n var bh9 = b9 >>> 13;\n\n out.negative = self.negative ^ num.negative;\n out.length = 19;\n /* k = 0 */\n lo = Math.imul(al0, bl0);\n mid = Math.imul(al0, bh0);\n mid = (mid + Math.imul(ah0, bl0)) | 0;\n hi = Math.imul(ah0, bh0);\n var w0 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w0 >>> 26)) | 0;\n w0 &= 0x3ffffff;\n /* k = 1 */\n lo = Math.imul(al1, bl0);\n mid = Math.imul(al1, bh0);\n mid = (mid + Math.imul(ah1, bl0)) | 0;\n hi = Math.imul(ah1, bh0);\n lo = (lo + Math.imul(al0, bl1)) | 0;\n mid = (mid + Math.imul(al0, bh1)) | 0;\n mid = (mid + Math.imul(ah0, bl1)) | 0;\n hi = (hi + Math.imul(ah0, bh1)) | 0;\n var w1 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w1 >>> 26)) | 0;\n w1 &= 0x3ffffff;\n /* k = 2 */\n lo = Math.imul(al2, bl0);\n mid = Math.imul(al2, bh0);\n mid = (mid + Math.imul(ah2, bl0)) | 0;\n hi = Math.imul(ah2, bh0);\n lo = (lo + Math.imul(al1, bl1)) | 0;\n mid = (mid + Math.imul(al1, bh1)) | 0;\n mid = (mid + Math.imul(ah1, bl1)) | 0;\n hi = (hi + Math.imul(ah1, bh1)) | 0;\n lo = (lo + Math.imul(al0, bl2)) | 0;\n mid = (mid + Math.imul(al0, bh2)) | 0;\n mid = (mid + Math.imul(ah0, bl2)) | 0;\n hi = (hi + Math.imul(ah0, bh2)) | 0;\n var w2 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w2 >>> 26)) | 0;\n w2 &= 0x3ffffff;\n /* k = 3 */\n lo = Math.imul(al3, bl0);\n mid = Math.imul(al3, bh0);\n mid = (mid + Math.imul(ah3, bl0)) | 0;\n hi = Math.imul(ah3, bh0);\n lo = (lo + Math.imul(al2, bl1)) | 0;\n mid = (mid + Math.imul(al2, bh1)) | 0;\n mid = (mid + Math.imul(ah2, bl1)) | 0;\n hi = (hi + Math.imul(ah2, bh1)) | 0;\n lo = (lo + Math.imul(al1, bl2)) | 0;\n mid = (mid + Math.imul(al1, bh2)) | 0;\n mid = (mid + Math.imul(ah1, bl2)) | 0;\n hi = (hi + Math.imul(ah1, bh2)) | 0;\n lo = (lo + Math.imul(al0, bl3)) | 0;\n mid = (mid + Math.imul(al0, bh3)) | 0;\n mid = (mid + Math.imul(ah0, bl3)) | 0;\n hi = (hi + Math.imul(ah0, bh3)) | 0;\n var w3 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w3 >>> 26)) | 0;\n w3 &= 0x3ffffff;\n /* k = 4 */\n lo = Math.imul(al4, bl0);\n mid = Math.imul(al4, bh0);\n mid = (mid + Math.imul(ah4, bl0)) | 0;\n hi = Math.imul(ah4, bh0);\n lo = (lo + Math.imul(al3, bl1)) | 0;\n mid = (mid + Math.imul(al3, bh1)) | 0;\n mid = (mid + Math.imul(ah3, bl1)) | 0;\n hi = (hi + Math.imul(ah3, bh1)) | 0;\n lo = (lo + Math.imul(al2, bl2)) | 0;\n mid = (mid + Math.imul(al2, bh2)) | 0;\n mid = (mid + Math.imul(ah2, bl2)) | 0;\n hi = (hi + Math.imul(ah2, bh2)) | 0;\n lo = (lo + Math.imul(al1, bl3)) | 0;\n mid = (mid + Math.imul(al1, bh3)) | 0;\n mid = (mid + Math.imul(ah1, bl3)) | 0;\n hi = (hi + Math.imul(ah1, bh3)) | 0;\n lo = (lo + Math.imul(al0, bl4)) | 0;\n mid = (mid + Math.imul(al0, bh4)) | 0;\n mid = (mid + Math.imul(ah0, bl4)) | 0;\n hi = (hi + Math.imul(ah0, bh4)) | 0;\n var w4 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w4 >>> 26)) | 0;\n w4 &= 0x3ffffff;\n /* k = 5 */\n lo = Math.imul(al5, bl0);\n mid = Math.imul(al5, bh0);\n mid = (mid + Math.imul(ah5, bl0)) | 0;\n hi = Math.imul(ah5, bh0);\n lo = (lo + Math.imul(al4, bl1)) | 0;\n mid = (mid + Math.imul(al4, bh1)) | 0;\n mid = (mid + Math.imul(ah4, bl1)) | 0;\n hi = (hi + Math.imul(ah4, bh1)) | 0;\n lo = (lo + Math.imul(al3, bl2)) | 0;\n mid = (mid + Math.imul(al3, bh2)) | 0;\n mid = (mid + Math.imul(ah3, bl2)) | 0;\n hi = (hi + Math.imul(ah3, bh2)) | 0;\n lo = (lo + Math.imul(al2, bl3)) | 0;\n mid = (mid + Math.imul(al2, bh3)) | 0;\n mid = (mid + Math.imul(ah2, bl3)) | 0;\n hi = (hi + Math.imul(ah2, bh3)) | 0;\n lo = (lo + Math.imul(al1, bl4)) | 0;\n mid = (mid + Math.imul(al1, bh4)) | 0;\n mid = (mid + Math.imul(ah1, bl4)) | 0;\n hi = (hi + Math.imul(ah1, bh4)) | 0;\n lo = (lo + Math.imul(al0, bl5)) | 0;\n mid = (mid + Math.imul(al0, bh5)) | 0;\n mid = (mid + Math.imul(ah0, bl5)) | 0;\n hi = (hi + Math.imul(ah0, bh5)) | 0;\n var w5 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w5 >>> 26)) | 0;\n w5 &= 0x3ffffff;\n /* k = 6 */\n lo = Math.imul(al6, bl0);\n mid = Math.imul(al6, bh0);\n mid = (mid + Math.imul(ah6, bl0)) | 0;\n hi = Math.imul(ah6, bh0);\n lo = (lo + Math.imul(al5, bl1)) | 0;\n mid = (mid + Math.imul(al5, bh1)) | 0;\n mid = (mid + Math.imul(ah5, bl1)) | 0;\n hi = (hi + Math.imul(ah5, bh1)) | 0;\n lo = (lo + Math.imul(al4, bl2)) | 0;\n mid = (mid + Math.imul(al4, bh2)) | 0;\n mid = (mid + Math.imul(ah4, bl2)) | 0;\n hi = (hi + Math.imul(ah4, bh2)) | 0;\n lo = (lo + Math.imul(al3, bl3)) | 0;\n mid = (mid + Math.imul(al3, bh3)) | 0;\n mid = (mid + Math.imul(ah3, bl3)) | 0;\n hi = (hi + Math.imul(ah3, bh3)) | 0;\n lo = (lo + Math.imul(al2, bl4)) | 0;\n mid = (mid + Math.imul(al2, bh4)) | 0;\n mid = (mid + Math.imul(ah2, bl4)) | 0;\n hi = (hi + Math.imul(ah2, bh4)) | 0;\n lo = (lo + Math.imul(al1, bl5)) | 0;\n mid = (mid + Math.imul(al1, bh5)) | 0;\n mid = (mid + Math.imul(ah1, bl5)) | 0;\n hi = (hi + Math.imul(ah1, bh5)) | 0;\n lo = (lo + Math.imul(al0, bl6)) | 0;\n mid = (mid + Math.imul(al0, bh6)) | 0;\n mid = (mid + Math.imul(ah0, bl6)) | 0;\n hi = (hi + Math.imul(ah0, bh6)) | 0;\n var w6 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w6 >>> 26)) | 0;\n w6 &= 0x3ffffff;\n /* k = 7 */\n lo = Math.imul(al7, bl0);\n mid = Math.imul(al7, bh0);\n mid = (mid + Math.imul(ah7, bl0)) | 0;\n hi = Math.imul(ah7, bh0);\n lo = (lo + Math.imul(al6, bl1)) | 0;\n mid = (mid + Math.imul(al6, bh1)) | 0;\n mid = (mid + Math.imul(ah6, bl1)) | 0;\n hi = (hi + Math.imul(ah6, bh1)) | 0;\n lo = (lo + Math.imul(al5, bl2)) | 0;\n mid = (mid + Math.imul(al5, bh2)) | 0;\n mid = (mid + Math.imul(ah5, bl2)) | 0;\n hi = (hi + Math.imul(ah5, bh2)) | 0;\n lo = (lo + Math.imul(al4, bl3)) | 0;\n mid = (mid + Math.imul(al4, bh3)) | 0;\n mid = (mid + Math.imul(ah4, bl3)) | 0;\n hi = (hi + Math.imul(ah4, bh3)) | 0;\n lo = (lo + Math.imul(al3, bl4)) | 0;\n mid = (mid + Math.imul(al3, bh4)) | 0;\n mid = (mid + Math.imul(ah3, bl4)) | 0;\n hi = (hi + Math.imul(ah3, bh4)) | 0;\n lo = (lo + Math.imul(al2, bl5)) | 0;\n mid = (mid + Math.imul(al2, bh5)) | 0;\n mid = (mid + Math.imul(ah2, bl5)) | 0;\n hi = (hi + Math.imul(ah2, bh5)) | 0;\n lo = (lo + Math.imul(al1, bl6)) | 0;\n mid = (mid + Math.imul(al1, bh6)) | 0;\n mid = (mid + Math.imul(ah1, bl6)) | 0;\n hi = (hi + Math.imul(ah1, bh6)) | 0;\n lo = (lo + Math.imul(al0, bl7)) | 0;\n mid = (mid + Math.imul(al0, bh7)) | 0;\n mid = (mid + Math.imul(ah0, bl7)) | 0;\n hi = (hi + Math.imul(ah0, bh7)) | 0;\n var w7 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w7 >>> 26)) | 0;\n w7 &= 0x3ffffff;\n /* k = 8 */\n lo = Math.imul(al8, bl0);\n mid = Math.imul(al8, bh0);\n mid = (mid + Math.imul(ah8, bl0)) | 0;\n hi = Math.imul(ah8, bh0);\n lo = (lo + Math.imul(al7, bl1)) | 0;\n mid = (mid + Math.imul(al7, bh1)) | 0;\n mid = (mid + Math.imul(ah7, bl1)) | 0;\n hi = (hi + Math.imul(ah7, bh1)) | 0;\n lo = (lo + Math.imul(al6, bl2)) | 0;\n mid = (mid + Math.imul(al6, bh2)) | 0;\n mid = (mid + Math.imul(ah6, bl2)) | 0;\n hi = (hi + Math.imul(ah6, bh2)) | 0;\n lo = (lo + Math.imul(al5, bl3)) | 0;\n mid = (mid + Math.imul(al5, bh3)) | 0;\n mid = (mid + Math.imul(ah5, bl3)) | 0;\n hi = (hi + Math.imul(ah5, bh3)) | 0;\n lo = (lo + Math.imul(al4, bl4)) | 0;\n mid = (mid + Math.imul(al4, bh4)) | 0;\n mid = (mid + Math.imul(ah4, bl4)) | 0;\n hi = (hi + Math.imul(ah4, bh4)) | 0;\n lo = (lo + Math.imul(al3, bl5)) | 0;\n mid = (mid + Math.imul(al3, bh5)) | 0;\n mid = (mid + Math.imul(ah3, bl5)) | 0;\n hi = (hi + Math.imul(ah3, bh5)) | 0;\n lo = (lo + Math.imul(al2, bl6)) | 0;\n mid = (mid + Math.imul(al2, bh6)) | 0;\n mid = (mid + Math.imul(ah2, bl6)) | 0;\n hi = (hi + Math.imul(ah2, bh6)) | 0;\n lo = (lo + Math.imul(al1, bl7)) | 0;\n mid = (mid + Math.imul(al1, bh7)) | 0;\n mid = (mid + Math.imul(ah1, bl7)) | 0;\n hi = (hi + Math.imul(ah1, bh7)) | 0;\n lo = (lo + Math.imul(al0, bl8)) | 0;\n mid = (mid + Math.imul(al0, bh8)) | 0;\n mid = (mid + Math.imul(ah0, bl8)) | 0;\n hi = (hi + Math.imul(ah0, bh8)) | 0;\n var w8 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w8 >>> 26)) | 0;\n w8 &= 0x3ffffff;\n /* k = 9 */\n lo = Math.imul(al9, bl0);\n mid = Math.imul(al9, bh0);\n mid = (mid + Math.imul(ah9, bl0)) | 0;\n hi = Math.imul(ah9, bh0);\n lo = (lo + Math.imul(al8, bl1)) | 0;\n mid = (mid + Math.imul(al8, bh1)) | 0;\n mid = (mid + Math.imul(ah8, bl1)) | 0;\n hi = (hi + Math.imul(ah8, bh1)) | 0;\n lo = (lo + Math.imul(al7, bl2)) | 0;\n mid = (mid + Math.imul(al7, bh2)) | 0;\n mid = (mid + Math.imul(ah7, bl2)) | 0;\n hi = (hi + Math.imul(ah7, bh2)) | 0;\n lo = (lo + Math.imul(al6, bl3)) | 0;\n mid = (mid + Math.imul(al6, bh3)) | 0;\n mid = (mid + Math.imul(ah6, bl3)) | 0;\n hi = (hi + Math.imul(ah6, bh3)) | 0;\n lo = (lo + Math.imul(al5, bl4)) | 0;\n mid = (mid + Math.imul(al5, bh4)) | 0;\n mid = (mid + Math.imul(ah5, bl4)) | 0;\n hi = (hi + Math.imul(ah5, bh4)) | 0;\n lo = (lo + Math.imul(al4, bl5)) | 0;\n mid = (mid + Math.imul(al4, bh5)) | 0;\n mid = (mid + Math.imul(ah4, bl5)) | 0;\n hi = (hi + Math.imul(ah4, bh5)) | 0;\n lo = (lo + Math.imul(al3, bl6)) | 0;\n mid = (mid + Math.imul(al3, bh6)) | 0;\n mid = (mid + Math.imul(ah3, bl6)) | 0;\n hi = (hi + Math.imul(ah3, bh6)) | 0;\n lo = (lo + Math.imul(al2, bl7)) | 0;\n mid = (mid + Math.imul(al2, bh7)) | 0;\n mid = (mid + Math.imul(ah2, bl7)) | 0;\n hi = (hi + Math.imul(ah2, bh7)) | 0;\n lo = (lo + Math.imul(al1, bl8)) | 0;\n mid = (mid + Math.imul(al1, bh8)) | 0;\n mid = (mid + Math.imul(ah1, bl8)) | 0;\n hi = (hi + Math.imul(ah1, bh8)) | 0;\n lo = (lo + Math.imul(al0, bl9)) | 0;\n mid = (mid + Math.imul(al0, bh9)) | 0;\n mid = (mid + Math.imul(ah0, bl9)) | 0;\n hi = (hi + Math.imul(ah0, bh9)) | 0;\n var w9 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w9 >>> 26)) | 0;\n w9 &= 0x3ffffff;\n /* k = 10 */\n lo = Math.imul(al9, bl1);\n mid = Math.imul(al9, bh1);\n mid = (mid + Math.imul(ah9, bl1)) | 0;\n hi = Math.imul(ah9, bh1);\n lo = (lo + Math.imul(al8, bl2)) | 0;\n mid = (mid + Math.imul(al8, bh2)) | 0;\n mid = (mid + Math.imul(ah8, bl2)) | 0;\n hi = (hi + Math.imul(ah8, bh2)) | 0;\n lo = (lo + Math.imul(al7, bl3)) | 0;\n mid = (mid + Math.imul(al7, bh3)) | 0;\n mid = (mid + Math.imul(ah7, bl3)) | 0;\n hi = (hi + Math.imul(ah7, bh3)) | 0;\n lo = (lo + Math.imul(al6, bl4)) | 0;\n mid = (mid + Math.imul(al6, bh4)) | 0;\n mid = (mid + Math.imul(ah6, bl4)) | 0;\n hi = (hi + Math.imul(ah6, bh4)) | 0;\n lo = (lo + Math.imul(al5, bl5)) | 0;\n mid = (mid + Math.imul(al5, bh5)) | 0;\n mid = (mid + Math.imul(ah5, bl5)) | 0;\n hi = (hi + Math.imul(ah5, bh5)) | 0;\n lo = (lo + Math.imul(al4, bl6)) | 0;\n mid = (mid + Math.imul(al4, bh6)) | 0;\n mid = (mid + Math.imul(ah4, bl6)) | 0;\n hi = (hi + Math.imul(ah4, bh6)) | 0;\n lo = (lo + Math.imul(al3, bl7)) | 0;\n mid = (mid + Math.imul(al3, bh7)) | 0;\n mid = (mid + Math.imul(ah3, bl7)) | 0;\n hi = (hi + Math.imul(ah3, bh7)) | 0;\n lo = (lo + Math.imul(al2, bl8)) | 0;\n mid = (mid + Math.imul(al2, bh8)) | 0;\n mid = (mid + Math.imul(ah2, bl8)) | 0;\n hi = (hi + Math.imul(ah2, bh8)) | 0;\n lo = (lo + Math.imul(al1, bl9)) | 0;\n mid = (mid + Math.imul(al1, bh9)) | 0;\n mid = (mid + Math.imul(ah1, bl9)) | 0;\n hi = (hi + Math.imul(ah1, bh9)) | 0;\n var w10 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w10 >>> 26)) | 0;\n w10 &= 0x3ffffff;\n /* k = 11 */\n lo = Math.imul(al9, bl2);\n mid = Math.imul(al9, bh2);\n mid = (mid + Math.imul(ah9, bl2)) | 0;\n hi = Math.imul(ah9, bh2);\n lo = (lo + Math.imul(al8, bl3)) | 0;\n mid = (mid + Math.imul(al8, bh3)) | 0;\n mid = (mid + Math.imul(ah8, bl3)) | 0;\n hi = (hi + Math.imul(ah8, bh3)) | 0;\n lo = (lo + Math.imul(al7, bl4)) | 0;\n mid = (mid + Math.imul(al7, bh4)) | 0;\n mid = (mid + Math.imul(ah7, bl4)) | 0;\n hi = (hi + Math.imul(ah7, bh4)) | 0;\n lo = (lo + Math.imul(al6, bl5)) | 0;\n mid = (mid + Math.imul(al6, bh5)) | 0;\n mid = (mid + Math.imul(ah6, bl5)) | 0;\n hi = (hi + Math.imul(ah6, bh5)) | 0;\n lo = (lo + Math.imul(al5, bl6)) | 0;\n mid = (mid + Math.imul(al5, bh6)) | 0;\n mid = (mid + Math.imul(ah5, bl6)) | 0;\n hi = (hi + Math.imul(ah5, bh6)) | 0;\n lo = (lo + Math.imul(al4, bl7)) | 0;\n mid = (mid + Math.imul(al4, bh7)) | 0;\n mid = (mid + Math.imul(ah4, bl7)) | 0;\n hi = (hi + Math.imul(ah4, bh7)) | 0;\n lo = (lo + Math.imul(al3, bl8)) | 0;\n mid = (mid + Math.imul(al3, bh8)) | 0;\n mid = (mid + Math.imul(ah3, bl8)) | 0;\n hi = (hi + Math.imul(ah3, bh8)) | 0;\n lo = (lo + Math.imul(al2, bl9)) | 0;\n mid = (mid + Math.imul(al2, bh9)) | 0;\n mid = (mid + Math.imul(ah2, bl9)) | 0;\n hi = (hi + Math.imul(ah2, bh9)) | 0;\n var w11 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w11 >>> 26)) | 0;\n w11 &= 0x3ffffff;\n /* k = 12 */\n lo = Math.imul(al9, bl3);\n mid = Math.imul(al9, bh3);\n mid = (mid + Math.imul(ah9, bl3)) | 0;\n hi = Math.imul(ah9, bh3);\n lo = (lo + Math.imul(al8, bl4)) | 0;\n mid = (mid + Math.imul(al8, bh4)) | 0;\n mid = (mid + Math.imul(ah8, bl4)) | 0;\n hi = (hi + Math.imul(ah8, bh4)) | 0;\n lo = (lo + Math.imul(al7, bl5)) | 0;\n mid = (mid + Math.imul(al7, bh5)) | 0;\n mid = (mid + Math.imul(ah7, bl5)) | 0;\n hi = (hi + Math.imul(ah7, bh5)) | 0;\n lo = (lo + Math.imul(al6, bl6)) | 0;\n mid = (mid + Math.imul(al6, bh6)) | 0;\n mid = (mid + Math.imul(ah6, bl6)) | 0;\n hi = (hi + Math.imul(ah6, bh6)) | 0;\n lo = (lo + Math.imul(al5, bl7)) | 0;\n mid = (mid + Math.imul(al5, bh7)) | 0;\n mid = (mid + Math.imul(ah5, bl7)) | 0;\n hi = (hi + Math.imul(ah5, bh7)) | 0;\n lo = (lo + Math.imul(al4, bl8)) | 0;\n mid = (mid + Math.imul(al4, bh8)) | 0;\n mid = (mid + Math.imul(ah4, bl8)) | 0;\n hi = (hi + Math.imul(ah4, bh8)) | 0;\n lo = (lo + Math.imul(al3, bl9)) | 0;\n mid = (mid + Math.imul(al3, bh9)) | 0;\n mid = (mid + Math.imul(ah3, bl9)) | 0;\n hi = (hi + Math.imul(ah3, bh9)) | 0;\n var w12 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w12 >>> 26)) | 0;\n w12 &= 0x3ffffff;\n /* k = 13 */\n lo = Math.imul(al9, bl4);\n mid = Math.imul(al9, bh4);\n mid = (mid + Math.imul(ah9, bl4)) | 0;\n hi = Math.imul(ah9, bh4);\n lo = (lo + Math.imul(al8, bl5)) | 0;\n mid = (mid + Math.imul(al8, bh5)) | 0;\n mid = (mid + Math.imul(ah8, bl5)) | 0;\n hi = (hi + Math.imul(ah8, bh5)) | 0;\n lo = (lo + Math.imul(al7, bl6)) | 0;\n mid = (mid + Math.imul(al7, bh6)) | 0;\n mid = (mid + Math.imul(ah7, bl6)) | 0;\n hi = (hi + Math.imul(ah7, bh6)) | 0;\n lo = (lo + Math.imul(al6, bl7)) | 0;\n mid = (mid + Math.imul(al6, bh7)) | 0;\n mid = (mid + Math.imul(ah6, bl7)) | 0;\n hi = (hi + Math.imul(ah6, bh7)) | 0;\n lo = (lo + Math.imul(al5, bl8)) | 0;\n mid = (mid + Math.imul(al5, bh8)) | 0;\n mid = (mid + Math.imul(ah5, bl8)) | 0;\n hi = (hi + Math.imul(ah5, bh8)) | 0;\n lo = (lo + Math.imul(al4, bl9)) | 0;\n mid = (mid + Math.imul(al4, bh9)) | 0;\n mid = (mid + Math.imul(ah4, bl9)) | 0;\n hi = (hi + Math.imul(ah4, bh9)) | 0;\n var w13 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w13 >>> 26)) | 0;\n w13 &= 0x3ffffff;\n /* k = 14 */\n lo = Math.imul(al9, bl5);\n mid = Math.imul(al9, bh5);\n mid = (mid + Math.imul(ah9, bl5)) | 0;\n hi = Math.imul(ah9, bh5);\n lo = (lo + Math.imul(al8, bl6)) | 0;\n mid = (mid + Math.imul(al8, bh6)) | 0;\n mid = (mid + Math.imul(ah8, bl6)) | 0;\n hi = (hi + Math.imul(ah8, bh6)) | 0;\n lo = (lo + Math.imul(al7, bl7)) | 0;\n mid = (mid + Math.imul(al7, bh7)) | 0;\n mid = (mid + Math.imul(ah7, bl7)) | 0;\n hi = (hi + Math.imul(ah7, bh7)) | 0;\n lo = (lo + Math.imul(al6, bl8)) | 0;\n mid = (mid + Math.imul(al6, bh8)) | 0;\n mid = (mid + Math.imul(ah6, bl8)) | 0;\n hi = (hi + Math.imul(ah6, bh8)) | 0;\n lo = (lo + Math.imul(al5, bl9)) | 0;\n mid = (mid + Math.imul(al5, bh9)) | 0;\n mid = (mid + Math.imul(ah5, bl9)) | 0;\n hi = (hi + Math.imul(ah5, bh9)) | 0;\n var w14 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w14 >>> 26)) | 0;\n w14 &= 0x3ffffff;\n /* k = 15 */\n lo = Math.imul(al9, bl6);\n mid = Math.imul(al9, bh6);\n mid = (mid + Math.imul(ah9, bl6)) | 0;\n hi = Math.imul(ah9, bh6);\n lo = (lo + Math.imul(al8, bl7)) | 0;\n mid = (mid + Math.imul(al8, bh7)) | 0;\n mid = (mid + Math.imul(ah8, bl7)) | 0;\n hi = (hi + Math.imul(ah8, bh7)) | 0;\n lo = (lo + Math.imul(al7, bl8)) | 0;\n mid = (mid + Math.imul(al7, bh8)) | 0;\n mid = (mid + Math.imul(ah7, bl8)) | 0;\n hi = (hi + Math.imul(ah7, bh8)) | 0;\n lo = (lo + Math.imul(al6, bl9)) | 0;\n mid = (mid + Math.imul(al6, bh9)) | 0;\n mid = (mid + Math.imul(ah6, bl9)) | 0;\n hi = (hi + Math.imul(ah6, bh9)) | 0;\n var w15 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w15 >>> 26)) | 0;\n w15 &= 0x3ffffff;\n /* k = 16 */\n lo = Math.imul(al9, bl7);\n mid = Math.imul(al9, bh7);\n mid = (mid + Math.imul(ah9, bl7)) | 0;\n hi = Math.imul(ah9, bh7);\n lo = (lo + Math.imul(al8, bl8)) | 0;\n mid = (mid + Math.imul(al8, bh8)) | 0;\n mid = (mid + Math.imul(ah8, bl8)) | 0;\n hi = (hi + Math.imul(ah8, bh8)) | 0;\n lo = (lo + Math.imul(al7, bl9)) | 0;\n mid = (mid + Math.imul(al7, bh9)) | 0;\n mid = (mid + Math.imul(ah7, bl9)) | 0;\n hi = (hi + Math.imul(ah7, bh9)) | 0;\n var w16 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w16 >>> 26)) | 0;\n w16 &= 0x3ffffff;\n /* k = 17 */\n lo = Math.imul(al9, bl8);\n mid = Math.imul(al9, bh8);\n mid = (mid + Math.imul(ah9, bl8)) | 0;\n hi = Math.imul(ah9, bh8);\n lo = (lo + Math.imul(al8, bl9)) | 0;\n mid = (mid + Math.imul(al8, bh9)) | 0;\n mid = (mid + Math.imul(ah8, bl9)) | 0;\n hi = (hi + Math.imul(ah8, bh9)) | 0;\n var w17 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w17 >>> 26)) | 0;\n w17 &= 0x3ffffff;\n /* k = 18 */\n lo = Math.imul(al9, bl9);\n mid = Math.imul(al9, bh9);\n mid = (mid + Math.imul(ah9, bl9)) | 0;\n hi = Math.imul(ah9, bh9);\n var w18 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w18 >>> 26)) | 0;\n w18 &= 0x3ffffff;\n o[0] = w0;\n o[1] = w1;\n o[2] = w2;\n o[3] = w3;\n o[4] = w4;\n o[5] = w5;\n o[6] = w6;\n o[7] = w7;\n o[8] = w8;\n o[9] = w9;\n o[10] = w10;\n o[11] = w11;\n o[12] = w12;\n o[13] = w13;\n o[14] = w14;\n o[15] = w15;\n o[16] = w16;\n o[17] = w17;\n o[18] = w18;\n if (c !== 0) {\n o[19] = c;\n out.length++;\n }\n return out;\n };\n\n // Polyfill comb\n if (!Math.imul) {\n comb10MulTo = smallMulTo;\n }\n\n function bigMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n out.length = self.length + num.length;\n\n var carry = 0;\n var hncarry = 0;\n for (var k = 0; k < out.length - 1; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = hncarry;\n hncarry = 0;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j;\n var a = self.words[i] | 0;\n var b = num.words[j] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n ncarry = (ncarry + ((r / 0x4000000) | 0)) | 0;\n lo = (lo + rword) | 0;\n rword = lo & 0x3ffffff;\n ncarry = (ncarry + (lo >>> 26)) | 0;\n\n hncarry += ncarry >>> 26;\n ncarry &= 0x3ffffff;\n }\n out.words[k] = rword;\n carry = ncarry;\n ncarry = hncarry;\n }\n if (carry !== 0) {\n out.words[k] = carry;\n } else {\n out.length--;\n }\n\n return out._strip();\n }\n\n function jumboMulTo (self, num, out) {\n // Temporary disable, see https://github.com/indutny/bn.js/issues/211\n // var fftm = new FFTM();\n // return fftm.mulp(self, num, out);\n return bigMulTo(self, num, out);\n }\n\n BN.prototype.mulTo = function mulTo (num, out) {\n var res;\n var len = this.length + num.length;\n if (this.length === 10 && num.length === 10) {\n res = comb10MulTo(this, num, out);\n } else if (len < 63) {\n res = smallMulTo(this, num, out);\n } else if (len < 1024) {\n res = bigMulTo(this, num, out);\n } else {\n res = jumboMulTo(this, num, out);\n }\n\n return res;\n };\n\n // Cooley-Tukey algorithm for FFT\n // slightly revisited to rely on looping instead of recursion\n\n function FFTM (x, y) {\n this.x = x;\n this.y = y;\n }\n\n FFTM.prototype.makeRBT = function makeRBT (N) {\n var t = new Array(N);\n var l = BN.prototype._countBits(N) - 1;\n for (var i = 0; i < N; i++) {\n t[i] = this.revBin(i, l, N);\n }\n\n return t;\n };\n\n // Returns binary-reversed representation of `x`\n FFTM.prototype.revBin = function revBin (x, l, N) {\n if (x === 0 || x === N - 1) return x;\n\n var rb = 0;\n for (var i = 0; i < l; i++) {\n rb |= (x & 1) << (l - i - 1);\n x >>= 1;\n }\n\n return rb;\n };\n\n // Performs \"tweedling\" phase, therefore 'emulating'\n // behaviour of the recursive algorithm\n FFTM.prototype.permute = function permute (rbt, rws, iws, rtws, itws, N) {\n for (var i = 0; i < N; i++) {\n rtws[i] = rws[rbt[i]];\n itws[i] = iws[rbt[i]];\n }\n };\n\n FFTM.prototype.transform = function transform (rws, iws, rtws, itws, N, rbt) {\n this.permute(rbt, rws, iws, rtws, itws, N);\n\n for (var s = 1; s < N; s <<= 1) {\n var l = s << 1;\n\n var rtwdf = Math.cos(2 * Math.PI / l);\n var itwdf = Math.sin(2 * Math.PI / l);\n\n for (var p = 0; p < N; p += l) {\n var rtwdf_ = rtwdf;\n var itwdf_ = itwdf;\n\n for (var j = 0; j < s; j++) {\n var re = rtws[p + j];\n var ie = itws[p + j];\n\n var ro = rtws[p + j + s];\n var io = itws[p + j + s];\n\n var rx = rtwdf_ * ro - itwdf_ * io;\n\n io = rtwdf_ * io + itwdf_ * ro;\n ro = rx;\n\n rtws[p + j] = re + ro;\n itws[p + j] = ie + io;\n\n rtws[p + j + s] = re - ro;\n itws[p + j + s] = ie - io;\n\n /* jshint maxdepth : false */\n if (j !== l) {\n rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n\n itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n rtwdf_ = rx;\n }\n }\n }\n }\n };\n\n FFTM.prototype.guessLen13b = function guessLen13b (n, m) {\n var N = Math.max(m, n) | 1;\n var odd = N & 1;\n var i = 0;\n for (N = N / 2 | 0; N; N = N >>> 1) {\n i++;\n }\n\n return 1 << i + 1 + odd;\n };\n\n FFTM.prototype.conjugate = function conjugate (rws, iws, N) {\n if (N <= 1) return;\n\n for (var i = 0; i < N / 2; i++) {\n var t = rws[i];\n\n rws[i] = rws[N - i - 1];\n rws[N - i - 1] = t;\n\n t = iws[i];\n\n iws[i] = -iws[N - i - 1];\n iws[N - i - 1] = -t;\n }\n };\n\n FFTM.prototype.normalize13b = function normalize13b (ws, N) {\n var carry = 0;\n for (var i = 0; i < N / 2; i++) {\n var w = Math.round(ws[2 * i + 1] / N) * 0x2000 +\n Math.round(ws[2 * i] / N) +\n carry;\n\n ws[i] = w & 0x3ffffff;\n\n if (w < 0x4000000) {\n carry = 0;\n } else {\n carry = w / 0x4000000 | 0;\n }\n }\n\n return ws;\n };\n\n FFTM.prototype.convert13b = function convert13b (ws, len, rws, N) {\n var carry = 0;\n for (var i = 0; i < len; i++) {\n carry = carry + (ws[i] | 0);\n\n rws[2 * i] = carry & 0x1fff; carry = carry >>> 13;\n rws[2 * i + 1] = carry & 0x1fff; carry = carry >>> 13;\n }\n\n // Pad with zeroes\n for (i = 2 * len; i < N; ++i) {\n rws[i] = 0;\n }\n\n assert(carry === 0);\n assert((carry & ~0x1fff) === 0);\n };\n\n FFTM.prototype.stub = function stub (N) {\n var ph = new Array(N);\n for (var i = 0; i < N; i++) {\n ph[i] = 0;\n }\n\n return ph;\n };\n\n FFTM.prototype.mulp = function mulp (x, y, out) {\n var N = 2 * this.guessLen13b(x.length, y.length);\n\n var rbt = this.makeRBT(N);\n\n var _ = this.stub(N);\n\n var rws = new Array(N);\n var rwst = new Array(N);\n var iwst = new Array(N);\n\n var nrws = new Array(N);\n var nrwst = new Array(N);\n var niwst = new Array(N);\n\n var rmws = out.words;\n rmws.length = N;\n\n this.convert13b(x.words, x.length, rws, N);\n this.convert13b(y.words, y.length, nrws, N);\n\n this.transform(rws, _, rwst, iwst, N, rbt);\n this.transform(nrws, _, nrwst, niwst, N, rbt);\n\n for (var i = 0; i < N; i++) {\n var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n rwst[i] = rx;\n }\n\n this.conjugate(rwst, iwst, N);\n this.transform(rwst, iwst, rmws, _, N, rbt);\n this.conjugate(rmws, _, N);\n this.normalize13b(rmws, N);\n\n out.negative = x.negative ^ y.negative;\n out.length = x.length + y.length;\n return out._strip();\n };\n\n // Multiply `this` by `num`\n BN.prototype.mul = function mul (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return this.mulTo(num, out);\n };\n\n // Multiply employing FFT\n BN.prototype.mulf = function mulf (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return jumboMulTo(this, num, out);\n };\n\n // In-place Multiplication\n BN.prototype.imul = function imul (num) {\n return this.clone().mulTo(num, this);\n };\n\n BN.prototype.imuln = function imuln (num) {\n var isNegNum = num < 0;\n if (isNegNum) num = -num;\n\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n\n // Carry\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = (this.words[i] | 0) * num;\n var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n carry >>= 26;\n carry += (w / 0x4000000) | 0;\n // NOTE: lo is 27bit maximum\n carry += lo >>> 26;\n this.words[i] = lo & 0x3ffffff;\n }\n\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n this.length = num === 0 ? 1 : this.length;\n\n return isNegNum ? this.ineg() : this;\n };\n\n BN.prototype.muln = function muln (num) {\n return this.clone().imuln(num);\n };\n\n // `this` * `this`\n BN.prototype.sqr = function sqr () {\n return this.mul(this);\n };\n\n // `this` * `this` in-place\n BN.prototype.isqr = function isqr () {\n return this.imul(this.clone());\n };\n\n // Math.pow(`this`, `num`)\n BN.prototype.pow = function pow (num) {\n var w = toBitArray(num);\n if (w.length === 0) return new BN(1);\n\n // Skip leading zeroes\n var res = this;\n for (var i = 0; i < w.length; i++, res = res.sqr()) {\n if (w[i] !== 0) break;\n }\n\n if (++i < w.length) {\n for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n if (w[i] === 0) continue;\n\n res = res.mul(q);\n }\n }\n\n return res;\n };\n\n // Shift-left in-place\n BN.prototype.iushln = function iushln (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n var carryMask = (0x3ffffff >>> (26 - r)) << (26 - r);\n var i;\n\n if (r !== 0) {\n var carry = 0;\n\n for (i = 0; i < this.length; i++) {\n var newCarry = this.words[i] & carryMask;\n var c = ((this.words[i] | 0) - newCarry) << r;\n this.words[i] = c | carry;\n carry = newCarry >>> (26 - r);\n }\n\n if (carry) {\n this.words[i] = carry;\n this.length++;\n }\n }\n\n if (s !== 0) {\n for (i = this.length - 1; i >= 0; i--) {\n this.words[i + s] = this.words[i];\n }\n\n for (i = 0; i < s; i++) {\n this.words[i] = 0;\n }\n\n this.length += s;\n }\n\n return this._strip();\n };\n\n BN.prototype.ishln = function ishln (bits) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushln(bits);\n };\n\n // Shift-right in-place\n // NOTE: `hint` is a lowest bit before trailing zeroes\n // NOTE: if `extended` is present - it will be filled with destroyed bits\n BN.prototype.iushrn = function iushrn (bits, hint, extended) {\n assert(typeof bits === 'number' && bits >= 0);\n var h;\n if (hint) {\n h = (hint - (hint % 26)) / 26;\n } else {\n h = 0;\n }\n\n var r = bits % 26;\n var s = Math.min((bits - r) / 26, this.length);\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n var maskedWords = extended;\n\n h -= s;\n h = Math.max(0, h);\n\n // Extended mode, copy masked part\n if (maskedWords) {\n for (var i = 0; i < s; i++) {\n maskedWords.words[i] = this.words[i];\n }\n maskedWords.length = s;\n }\n\n if (s === 0) {\n // No-op, we should not move anything at all\n } else if (this.length > s) {\n this.length -= s;\n for (i = 0; i < this.length; i++) {\n this.words[i] = this.words[i + s];\n }\n } else {\n this.words[0] = 0;\n this.length = 1;\n }\n\n var carry = 0;\n for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n var word = this.words[i] | 0;\n this.words[i] = (carry << (26 - r)) | (word >>> r);\n carry = word & mask;\n }\n\n // Push carried bits as a mask\n if (maskedWords && carry !== 0) {\n maskedWords.words[maskedWords.length++] = carry;\n }\n\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n\n return this._strip();\n };\n\n BN.prototype.ishrn = function ishrn (bits, hint, extended) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushrn(bits, hint, extended);\n };\n\n // Shift-left\n BN.prototype.shln = function shln (bits) {\n return this.clone().ishln(bits);\n };\n\n BN.prototype.ushln = function ushln (bits) {\n return this.clone().iushln(bits);\n };\n\n // Shift-right\n BN.prototype.shrn = function shrn (bits) {\n return this.clone().ishrn(bits);\n };\n\n BN.prototype.ushrn = function ushrn (bits) {\n return this.clone().iushrn(bits);\n };\n\n // Test if n bit is set\n BN.prototype.testn = function testn (bit) {\n assert(typeof bit === 'number' && bit >= 0);\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) return false;\n\n // Check bit and return\n var w = this.words[s];\n\n return !!(w & q);\n };\n\n // Return only lowers bits of number (in-place)\n BN.prototype.imaskn = function imaskn (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n\n assert(this.negative === 0, 'imaskn works only with positive numbers');\n\n if (this.length <= s) {\n return this;\n }\n\n if (r !== 0) {\n s++;\n }\n this.length = Math.min(s, this.length);\n\n if (r !== 0) {\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n this.words[this.length - 1] &= mask;\n }\n\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n\n return this._strip();\n };\n\n // Return only lowers bits of number\n BN.prototype.maskn = function maskn (bits) {\n return this.clone().imaskn(bits);\n };\n\n // Add plain number `num` to `this`\n BN.prototype.iaddn = function iaddn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.isubn(-num);\n\n // Possible sign change\n if (this.negative !== 0) {\n if (this.length === 1 && (this.words[0] | 0) <= num) {\n this.words[0] = num - (this.words[0] | 0);\n this.negative = 0;\n return this;\n }\n\n this.negative = 0;\n this.isubn(num);\n this.negative = 1;\n return this;\n }\n\n // Add without checks\n return this._iaddn(num);\n };\n\n BN.prototype._iaddn = function _iaddn (num) {\n this.words[0] += num;\n\n // Carry\n for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n this.words[i] -= 0x4000000;\n if (i === this.length - 1) {\n this.words[i + 1] = 1;\n } else {\n this.words[i + 1]++;\n }\n }\n this.length = Math.max(this.length, i + 1);\n\n return this;\n };\n\n // Subtract plain number `num` from `this`\n BN.prototype.isubn = function isubn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.iaddn(-num);\n\n if (this.negative !== 0) {\n this.negative = 0;\n this.iaddn(num);\n this.negative = 1;\n return this;\n }\n\n this.words[0] -= num;\n\n if (this.length === 1 && this.words[0] < 0) {\n this.words[0] = -this.words[0];\n this.negative = 1;\n } else {\n // Carry\n for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n this.words[i] += 0x4000000;\n this.words[i + 1] -= 1;\n }\n }\n\n return this._strip();\n };\n\n BN.prototype.addn = function addn (num) {\n return this.clone().iaddn(num);\n };\n\n BN.prototype.subn = function subn (num) {\n return this.clone().isubn(num);\n };\n\n BN.prototype.iabs = function iabs () {\n this.negative = 0;\n\n return this;\n };\n\n BN.prototype.abs = function abs () {\n return this.clone().iabs();\n };\n\n BN.prototype._ishlnsubmul = function _ishlnsubmul (num, mul, shift) {\n var len = num.length + shift;\n var i;\n\n this._expand(len);\n\n var w;\n var carry = 0;\n for (i = 0; i < num.length; i++) {\n w = (this.words[i + shift] | 0) + carry;\n var right = (num.words[i] | 0) * mul;\n w -= right & 0x3ffffff;\n carry = (w >> 26) - ((right / 0x4000000) | 0);\n this.words[i + shift] = w & 0x3ffffff;\n }\n for (; i < this.length - shift; i++) {\n w = (this.words[i + shift] | 0) + carry;\n carry = w >> 26;\n this.words[i + shift] = w & 0x3ffffff;\n }\n\n if (carry === 0) return this._strip();\n\n // Subtraction overflow\n assert(carry === -1);\n carry = 0;\n for (i = 0; i < this.length; i++) {\n w = -(this.words[i] | 0) + carry;\n carry = w >> 26;\n this.words[i] = w & 0x3ffffff;\n }\n this.negative = 1;\n\n return this._strip();\n };\n\n BN.prototype._wordDiv = function _wordDiv (num, mode) {\n var shift = this.length - num.length;\n\n var a = this.clone();\n var b = num;\n\n // Normalize\n var bhi = b.words[b.length - 1] | 0;\n var bhiBits = this._countBits(bhi);\n shift = 26 - bhiBits;\n if (shift !== 0) {\n b = b.ushln(shift);\n a.iushln(shift);\n bhi = b.words[b.length - 1] | 0;\n }\n\n // Initialize quotient\n var m = a.length - b.length;\n var q;\n\n if (mode !== 'mod') {\n q = new BN(null);\n q.length = m + 1;\n q.words = new Array(q.length);\n for (var i = 0; i < q.length; i++) {\n q.words[i] = 0;\n }\n }\n\n var diff = a.clone()._ishlnsubmul(b, 1, m);\n if (diff.negative === 0) {\n a = diff;\n if (q) {\n q.words[m] = 1;\n }\n }\n\n for (var j = m - 1; j >= 0; j--) {\n var qj = (a.words[b.length + j] | 0) * 0x4000000 +\n (a.words[b.length + j - 1] | 0);\n\n // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n // (0x7ffffff)\n qj = Math.min((qj / bhi) | 0, 0x3ffffff);\n\n a._ishlnsubmul(b, qj, j);\n while (a.negative !== 0) {\n qj--;\n a.negative = 0;\n a._ishlnsubmul(b, 1, j);\n if (!a.isZero()) {\n a.negative ^= 1;\n }\n }\n if (q) {\n q.words[j] = qj;\n }\n }\n if (q) {\n q._strip();\n }\n a._strip();\n\n // Denormalize\n if (mode !== 'div' && shift !== 0) {\n a.iushrn(shift);\n }\n\n return {\n div: q || null,\n mod: a\n };\n };\n\n // NOTE: 1) `mode` can be set to `mod` to request mod only,\n // to `div` to request div only, or be absent to\n // request both div & mod\n // 2) `positive` is true if unsigned mod is requested\n BN.prototype.divmod = function divmod (num, mode, positive) {\n assert(!num.isZero());\n\n if (this.isZero()) {\n return {\n div: new BN(0),\n mod: new BN(0)\n };\n }\n\n var div, mod, res;\n if (this.negative !== 0 && num.negative === 0) {\n res = this.neg().divmod(num, mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.iadd(num);\n }\n }\n\n return {\n div: div,\n mod: mod\n };\n }\n\n if (this.negative === 0 && num.negative !== 0) {\n res = this.divmod(num.neg(), mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n return {\n div: div,\n mod: res.mod\n };\n }\n\n if ((this.negative & num.negative) !== 0) {\n res = this.neg().divmod(num.neg(), mode);\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.isub(num);\n }\n }\n\n return {\n div: res.div,\n mod: mod\n };\n }\n\n // Both numbers are positive at this point\n\n // Strip both numbers to approximate shift value\n if (num.length > this.length || this.cmp(num) < 0) {\n return {\n div: new BN(0),\n mod: this\n };\n }\n\n // Very short reduction\n if (num.length === 1) {\n if (mode === 'div') {\n return {\n div: this.divn(num.words[0]),\n mod: null\n };\n }\n\n if (mode === 'mod') {\n return {\n div: null,\n mod: new BN(this.modrn(num.words[0]))\n };\n }\n\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modrn(num.words[0]))\n };\n }\n\n return this._wordDiv(num, mode);\n };\n\n // Find `this` / `num`\n BN.prototype.div = function div (num) {\n return this.divmod(num, 'div', false).div;\n };\n\n // Find `this` % `num`\n BN.prototype.mod = function mod (num) {\n return this.divmod(num, 'mod', false).mod;\n };\n\n BN.prototype.umod = function umod (num) {\n return this.divmod(num, 'mod', true).mod;\n };\n\n // Find Round(`this` / `num`)\n BN.prototype.divRound = function divRound (num) {\n var dm = this.divmod(num);\n\n // Fast case - exact division\n if (dm.mod.isZero()) return dm.div;\n\n var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n\n var half = num.ushrn(1);\n var r2 = num.andln(1);\n var cmp = mod.cmp(half);\n\n // Round down\n if (cmp < 0 || (r2 === 1 && cmp === 0)) return dm.div;\n\n // Round up\n return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n };\n\n BN.prototype.modrn = function modrn (num) {\n var isNegNum = num < 0;\n if (isNegNum) num = -num;\n\n assert(num <= 0x3ffffff);\n var p = (1 << 26) % num;\n\n var acc = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n acc = (p * acc + (this.words[i] | 0)) % num;\n }\n\n return isNegNum ? -acc : acc;\n };\n\n // WARNING: DEPRECATED\n BN.prototype.modn = function modn (num) {\n return this.modrn(num);\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn (num) {\n var isNegNum = num < 0;\n if (isNegNum) num = -num;\n\n assert(num <= 0x3ffffff);\n\n var carry = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var w = (this.words[i] | 0) + carry * 0x4000000;\n this.words[i] = (w / num) | 0;\n carry = w % num;\n }\n\n this._strip();\n return isNegNum ? this.ineg() : this;\n };\n\n BN.prototype.divn = function divn (num) {\n return this.clone().idivn(num);\n };\n\n BN.prototype.egcd = function egcd (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var x = this;\n var y = p.clone();\n\n if (x.negative !== 0) {\n x = x.umod(p);\n } else {\n x = x.clone();\n }\n\n // A * x + B * y = x\n var A = new BN(1);\n var B = new BN(0);\n\n // C * x + D * y = y\n var C = new BN(0);\n var D = new BN(1);\n\n var g = 0;\n\n while (x.isEven() && y.isEven()) {\n x.iushrn(1);\n y.iushrn(1);\n ++g;\n }\n\n var yp = y.clone();\n var xp = x.clone();\n\n while (!x.isZero()) {\n for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n x.iushrn(i);\n while (i-- > 0) {\n if (A.isOdd() || B.isOdd()) {\n A.iadd(yp);\n B.isub(xp);\n }\n\n A.iushrn(1);\n B.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n y.iushrn(j);\n while (j-- > 0) {\n if (C.isOdd() || D.isOdd()) {\n C.iadd(yp);\n D.isub(xp);\n }\n\n C.iushrn(1);\n D.iushrn(1);\n }\n }\n\n if (x.cmp(y) >= 0) {\n x.isub(y);\n A.isub(C);\n B.isub(D);\n } else {\n y.isub(x);\n C.isub(A);\n D.isub(B);\n }\n }\n\n return {\n a: C,\n b: D,\n gcd: y.iushln(g)\n };\n };\n\n // This is reduced incarnation of the binary EEA\n // above, designated to invert members of the\n // _prime_ fields F(p) at a maximal speed\n BN.prototype._invmp = function _invmp (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var a = this;\n var b = p.clone();\n\n if (a.negative !== 0) {\n a = a.umod(p);\n } else {\n a = a.clone();\n }\n\n var x1 = new BN(1);\n var x2 = new BN(0);\n\n var delta = b.clone();\n\n while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n a.iushrn(i);\n while (i-- > 0) {\n if (x1.isOdd()) {\n x1.iadd(delta);\n }\n\n x1.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n b.iushrn(j);\n while (j-- > 0) {\n if (x2.isOdd()) {\n x2.iadd(delta);\n }\n\n x2.iushrn(1);\n }\n }\n\n if (a.cmp(b) >= 0) {\n a.isub(b);\n x1.isub(x2);\n } else {\n b.isub(a);\n x2.isub(x1);\n }\n }\n\n var res;\n if (a.cmpn(1) === 0) {\n res = x1;\n } else {\n res = x2;\n }\n\n if (res.cmpn(0) < 0) {\n res.iadd(p);\n }\n\n return res;\n };\n\n BN.prototype.gcd = function gcd (num) {\n if (this.isZero()) return num.abs();\n if (num.isZero()) return this.abs();\n\n var a = this.clone();\n var b = num.clone();\n a.negative = 0;\n b.negative = 0;\n\n // Remove common factor of two\n for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n a.iushrn(1);\n b.iushrn(1);\n }\n\n do {\n while (a.isEven()) {\n a.iushrn(1);\n }\n while (b.isEven()) {\n b.iushrn(1);\n }\n\n var r = a.cmp(b);\n if (r < 0) {\n // Swap `a` and `b` to make `a` always bigger than `b`\n var t = a;\n a = b;\n b = t;\n } else if (r === 0 || b.cmpn(1) === 0) {\n break;\n }\n\n a.isub(b);\n } while (true);\n\n return b.iushln(shift);\n };\n\n // Invert number in the field F(num)\n BN.prototype.invm = function invm (num) {\n return this.egcd(num).a.umod(num);\n };\n\n BN.prototype.isEven = function isEven () {\n return (this.words[0] & 1) === 0;\n };\n\n BN.prototype.isOdd = function isOdd () {\n return (this.words[0] & 1) === 1;\n };\n\n // And first word and num\n BN.prototype.andln = function andln (num) {\n return this.words[0] & num;\n };\n\n // Increment at the bit position in-line\n BN.prototype.bincn = function bincn (bit) {\n assert(typeof bit === 'number');\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) {\n this._expand(s + 1);\n this.words[s] |= q;\n return this;\n }\n\n // Add bit and propagate, if needed\n var carry = q;\n for (var i = s; carry !== 0 && i < this.length; i++) {\n var w = this.words[i] | 0;\n w += carry;\n carry = w >>> 26;\n w &= 0x3ffffff;\n this.words[i] = w;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n\n BN.prototype.isZero = function isZero () {\n return this.length === 1 && this.words[0] === 0;\n };\n\n BN.prototype.cmpn = function cmpn (num) {\n var negative = num < 0;\n\n if (this.negative !== 0 && !negative) return -1;\n if (this.negative === 0 && negative) return 1;\n\n this._strip();\n\n var res;\n if (this.length > 1) {\n res = 1;\n } else {\n if (negative) {\n num = -num;\n }\n\n assert(num <= 0x3ffffff, 'Number is too big');\n\n var w = this.words[0] | 0;\n res = w === num ? 0 : w < num ? -1 : 1;\n }\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Compare two numbers and return:\n // 1 - if `this` > `num`\n // 0 - if `this` == `num`\n // -1 - if `this` < `num`\n BN.prototype.cmp = function cmp (num) {\n if (this.negative !== 0 && num.negative === 0) return -1;\n if (this.negative === 0 && num.negative !== 0) return 1;\n\n var res = this.ucmp(num);\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Unsigned comparison\n BN.prototype.ucmp = function ucmp (num) {\n // At this point both numbers have the same sign\n if (this.length > num.length) return 1;\n if (this.length < num.length) return -1;\n\n var res = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var a = this.words[i] | 0;\n var b = num.words[i] | 0;\n\n if (a === b) continue;\n if (a < b) {\n res = -1;\n } else if (a > b) {\n res = 1;\n }\n break;\n }\n return res;\n };\n\n BN.prototype.gtn = function gtn (num) {\n return this.cmpn(num) === 1;\n };\n\n BN.prototype.gt = function gt (num) {\n return this.cmp(num) === 1;\n };\n\n BN.prototype.gten = function gten (num) {\n return this.cmpn(num) >= 0;\n };\n\n BN.prototype.gte = function gte (num) {\n return this.cmp(num) >= 0;\n };\n\n BN.prototype.ltn = function ltn (num) {\n return this.cmpn(num) === -1;\n };\n\n BN.prototype.lt = function lt (num) {\n return this.cmp(num) === -1;\n };\n\n BN.prototype.lten = function lten (num) {\n return this.cmpn(num) <= 0;\n };\n\n BN.prototype.lte = function lte (num) {\n return this.cmp(num) <= 0;\n };\n\n BN.prototype.eqn = function eqn (num) {\n return this.cmpn(num) === 0;\n };\n\n BN.prototype.eq = function eq (num) {\n return this.cmp(num) === 0;\n };\n\n //\n // A reduce context, could be using montgomery or something better, depending\n // on the `m` itself.\n //\n BN.red = function red (num) {\n return new Red(num);\n };\n\n BN.prototype.toRed = function toRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n assert(this.negative === 0, 'red works only with positives');\n return ctx.convertTo(this)._forceRed(ctx);\n };\n\n BN.prototype.fromRed = function fromRed () {\n assert(this.red, 'fromRed works only with numbers in reduction context');\n return this.red.convertFrom(this);\n };\n\n BN.prototype._forceRed = function _forceRed (ctx) {\n this.red = ctx;\n return this;\n };\n\n BN.prototype.forceRed = function forceRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n return this._forceRed(ctx);\n };\n\n BN.prototype.redAdd = function redAdd (num) {\n assert(this.red, 'redAdd works only with red numbers');\n return this.red.add(this, num);\n };\n\n BN.prototype.redIAdd = function redIAdd (num) {\n assert(this.red, 'redIAdd works only with red numbers');\n return this.red.iadd(this, num);\n };\n\n BN.prototype.redSub = function redSub (num) {\n assert(this.red, 'redSub works only with red numbers');\n return this.red.sub(this, num);\n };\n\n BN.prototype.redISub = function redISub (num) {\n assert(this.red, 'redISub works only with red numbers');\n return this.red.isub(this, num);\n };\n\n BN.prototype.redShl = function redShl (num) {\n assert(this.red, 'redShl works only with red numbers');\n return this.red.shl(this, num);\n };\n\n BN.prototype.redMul = function redMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.mul(this, num);\n };\n\n BN.prototype.redIMul = function redIMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.imul(this, num);\n };\n\n BN.prototype.redSqr = function redSqr () {\n assert(this.red, 'redSqr works only with red numbers');\n this.red._verify1(this);\n return this.red.sqr(this);\n };\n\n BN.prototype.redISqr = function redISqr () {\n assert(this.red, 'redISqr works only with red numbers');\n this.red._verify1(this);\n return this.red.isqr(this);\n };\n\n // Square root over p\n BN.prototype.redSqrt = function redSqrt () {\n assert(this.red, 'redSqrt works only with red numbers');\n this.red._verify1(this);\n return this.red.sqrt(this);\n };\n\n BN.prototype.redInvm = function redInvm () {\n assert(this.red, 'redInvm works only with red numbers');\n this.red._verify1(this);\n return this.red.invm(this);\n };\n\n // Return negative clone of `this` % `red modulo`\n BN.prototype.redNeg = function redNeg () {\n assert(this.red, 'redNeg works only with red numbers');\n this.red._verify1(this);\n return this.red.neg(this);\n };\n\n BN.prototype.redPow = function redPow (num) {\n assert(this.red && !num.red, 'redPow(normalNum)');\n this.red._verify1(this);\n return this.red.pow(this, num);\n };\n\n // Prime numbers with efficient reduction\n var primes = {\n k256: null,\n p224: null,\n p192: null,\n p25519: null\n };\n\n // Pseudo-Mersenne prime\n function MPrime (name, p) {\n // P = 2 ^ N - K\n this.name = name;\n this.p = new BN(p, 16);\n this.n = this.p.bitLength();\n this.k = new BN(1).iushln(this.n).isub(this.p);\n\n this.tmp = this._tmp();\n }\n\n MPrime.prototype._tmp = function _tmp () {\n var tmp = new BN(null);\n tmp.words = new Array(Math.ceil(this.n / 13));\n return tmp;\n };\n\n MPrime.prototype.ireduce = function ireduce (num) {\n // Assumes that `num` is less than `P^2`\n // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n var r = num;\n var rlen;\n\n do {\n this.split(r, this.tmp);\n r = this.imulK(r);\n r = r.iadd(this.tmp);\n rlen = r.bitLength();\n } while (rlen > this.n);\n\n var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n if (cmp === 0) {\n r.words[0] = 0;\n r.length = 1;\n } else if (cmp > 0) {\n r.isub(this.p);\n } else {\n if (r.strip !== undefined) {\n // r is a BN v4 instance\n r.strip();\n } else {\n // r is a BN v5 instance\n r._strip();\n }\n }\n\n return r;\n };\n\n MPrime.prototype.split = function split (input, out) {\n input.iushrn(this.n, 0, out);\n };\n\n MPrime.prototype.imulK = function imulK (num) {\n return num.imul(this.k);\n };\n\n function K256 () {\n MPrime.call(\n this,\n 'k256',\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n }\n inherits(K256, MPrime);\n\n K256.prototype.split = function split (input, output) {\n // 256 = 9 * 26 + 22\n var mask = 0x3fffff;\n\n var outLen = Math.min(input.length, 9);\n for (var i = 0; i < outLen; i++) {\n output.words[i] = input.words[i];\n }\n output.length = outLen;\n\n if (input.length <= 9) {\n input.words[0] = 0;\n input.length = 1;\n return;\n }\n\n // Shift by 9 limbs\n var prev = input.words[9];\n output.words[output.length++] = prev & mask;\n\n for (i = 10; i < input.length; i++) {\n var next = input.words[i] | 0;\n input.words[i - 10] = ((next & mask) << 4) | (prev >>> 22);\n prev = next;\n }\n prev >>>= 22;\n input.words[i - 10] = prev;\n if (prev === 0 && input.length > 10) {\n input.length -= 10;\n } else {\n input.length -= 9;\n }\n };\n\n K256.prototype.imulK = function imulK (num) {\n // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n num.words[num.length] = 0;\n num.words[num.length + 1] = 0;\n num.length += 2;\n\n // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n var lo = 0;\n for (var i = 0; i < num.length; i++) {\n var w = num.words[i] | 0;\n lo += w * 0x3d1;\n num.words[i] = lo & 0x3ffffff;\n lo = w * 0x40 + ((lo / 0x4000000) | 0);\n }\n\n // Fast length reduction\n if (num.words[num.length - 1] === 0) {\n num.length--;\n if (num.words[num.length - 1] === 0) {\n num.length--;\n }\n }\n return num;\n };\n\n function P224 () {\n MPrime.call(\n this,\n 'p224',\n 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n }\n inherits(P224, MPrime);\n\n function P192 () {\n MPrime.call(\n this,\n 'p192',\n 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n }\n inherits(P192, MPrime);\n\n function P25519 () {\n // 2 ^ 255 - 19\n MPrime.call(\n this,\n '25519',\n '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n }\n inherits(P25519, MPrime);\n\n P25519.prototype.imulK = function imulK (num) {\n // K = 0x13\n var carry = 0;\n for (var i = 0; i < num.length; i++) {\n var hi = (num.words[i] | 0) * 0x13 + carry;\n var lo = hi & 0x3ffffff;\n hi >>>= 26;\n\n num.words[i] = lo;\n carry = hi;\n }\n if (carry !== 0) {\n num.words[num.length++] = carry;\n }\n return num;\n };\n\n // Exported mostly for testing purposes, use plain name instead\n BN._prime = function prime (name) {\n // Cached version of prime\n if (primes[name]) return primes[name];\n\n var prime;\n if (name === 'k256') {\n prime = new K256();\n } else if (name === 'p224') {\n prime = new P224();\n } else if (name === 'p192') {\n prime = new P192();\n } else if (name === 'p25519') {\n prime = new P25519();\n } else {\n throw new Error('Unknown prime ' + name);\n }\n primes[name] = prime;\n\n return prime;\n };\n\n //\n // Base reduction engine\n //\n function Red (m) {\n if (typeof m === 'string') {\n var prime = BN._prime(m);\n this.m = prime.p;\n this.prime = prime;\n } else {\n assert(m.gtn(1), 'modulus must be greater than 1');\n this.m = m;\n this.prime = null;\n }\n }\n\n Red.prototype._verify1 = function _verify1 (a) {\n assert(a.negative === 0, 'red works only with positives');\n assert(a.red, 'red works only with red numbers');\n };\n\n Red.prototype._verify2 = function _verify2 (a, b) {\n assert((a.negative | b.negative) === 0, 'red works only with positives');\n assert(a.red && a.red === b.red,\n 'red works only with red numbers');\n };\n\n Red.prototype.imod = function imod (a) {\n if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n\n move(a, a.umod(this.m)._forceRed(this));\n return a;\n };\n\n Red.prototype.neg = function neg (a) {\n if (a.isZero()) {\n return a.clone();\n }\n\n return this.m.sub(a)._forceRed(this);\n };\n\n Red.prototype.add = function add (a, b) {\n this._verify2(a, b);\n\n var res = a.add(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.iadd = function iadd (a, b) {\n this._verify2(a, b);\n\n var res = a.iadd(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res;\n };\n\n Red.prototype.sub = function sub (a, b) {\n this._verify2(a, b);\n\n var res = a.sub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.isub = function isub (a, b) {\n this._verify2(a, b);\n\n var res = a.isub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res;\n };\n\n Red.prototype.shl = function shl (a, num) {\n this._verify1(a);\n return this.imod(a.ushln(num));\n };\n\n Red.prototype.imul = function imul (a, b) {\n this._verify2(a, b);\n return this.imod(a.imul(b));\n };\n\n Red.prototype.mul = function mul (a, b) {\n this._verify2(a, b);\n return this.imod(a.mul(b));\n };\n\n Red.prototype.isqr = function isqr (a) {\n return this.imul(a, a.clone());\n };\n\n Red.prototype.sqr = function sqr (a) {\n return this.mul(a, a);\n };\n\n Red.prototype.sqrt = function sqrt (a) {\n if (a.isZero()) return a.clone();\n\n var mod3 = this.m.andln(3);\n assert(mod3 % 2 === 1);\n\n // Fast case\n if (mod3 === 3) {\n var pow = this.m.add(new BN(1)).iushrn(2);\n return this.pow(a, pow);\n }\n\n // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n //\n // Find Q and S, that Q * 2 ^ S = (P - 1)\n var q = this.m.subn(1);\n var s = 0;\n while (!q.isZero() && q.andln(1) === 0) {\n s++;\n q.iushrn(1);\n }\n assert(!q.isZero());\n\n var one = new BN(1).toRed(this);\n var nOne = one.redNeg();\n\n // Find quadratic non-residue\n // NOTE: Max is such because of generalized Riemann hypothesis.\n var lpow = this.m.subn(1).iushrn(1);\n var z = this.m.bitLength();\n z = new BN(2 * z * z).toRed(this);\n\n while (this.pow(z, lpow).cmp(nOne) !== 0) {\n z.redIAdd(nOne);\n }\n\n var c = this.pow(z, q);\n var r = this.pow(a, q.addn(1).iushrn(1));\n var t = this.pow(a, q);\n var m = s;\n while (t.cmp(one) !== 0) {\n var tmp = t;\n for (var i = 0; tmp.cmp(one) !== 0; i++) {\n tmp = tmp.redSqr();\n }\n assert(i < m);\n var b = this.pow(c, new BN(1).iushln(m - i - 1));\n\n r = r.redMul(b);\n c = b.redSqr();\n t = t.redMul(c);\n m = i;\n }\n\n return r;\n };\n\n Red.prototype.invm = function invm (a) {\n var inv = a._invmp(this.m);\n if (inv.negative !== 0) {\n inv.negative = 0;\n return this.imod(inv).redNeg();\n } else {\n return this.imod(inv);\n }\n };\n\n Red.prototype.pow = function pow (a, num) {\n if (num.isZero()) return new BN(1).toRed(this);\n if (num.cmpn(1) === 0) return a.clone();\n\n var windowSize = 4;\n var wnd = new Array(1 << windowSize);\n wnd[0] = new BN(1).toRed(this);\n wnd[1] = a;\n for (var i = 2; i < wnd.length; i++) {\n wnd[i] = this.mul(wnd[i - 1], a);\n }\n\n var res = wnd[0];\n var current = 0;\n var currentLen = 0;\n var start = num.bitLength() % 26;\n if (start === 0) {\n start = 26;\n }\n\n for (i = num.length - 1; i >= 0; i--) {\n var word = num.words[i];\n for (var j = start - 1; j >= 0; j--) {\n var bit = (word >> j) & 1;\n if (res !== wnd[0]) {\n res = this.sqr(res);\n }\n\n if (bit === 0 && current === 0) {\n currentLen = 0;\n continue;\n }\n\n current <<= 1;\n current |= bit;\n currentLen++;\n if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n\n res = this.mul(res, wnd[current]);\n currentLen = 0;\n current = 0;\n }\n start = 26;\n }\n\n return res;\n };\n\n Red.prototype.convertTo = function convertTo (num) {\n var r = num.umod(this.m);\n\n return r === num ? r.clone() : r;\n };\n\n Red.prototype.convertFrom = function convertFrom (num) {\n var res = num.clone();\n res.red = null;\n return res;\n };\n\n //\n // Montgomery method engine\n //\n\n BN.mont = function mont (num) {\n return new Mont(num);\n };\n\n function Mont (m) {\n Red.call(this, m);\n\n this.shift = this.m.bitLength();\n if (this.shift % 26 !== 0) {\n this.shift += 26 - (this.shift % 26);\n }\n\n this.r = new BN(1).iushln(this.shift);\n this.r2 = this.imod(this.r.sqr());\n this.rinv = this.r._invmp(this.m);\n\n this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n this.minv = this.minv.umod(this.r);\n this.minv = this.r.sub(this.minv);\n }\n inherits(Mont, Red);\n\n Mont.prototype.convertTo = function convertTo (num) {\n return this.imod(num.ushln(this.shift));\n };\n\n Mont.prototype.convertFrom = function convertFrom (num) {\n var r = this.imod(num.mul(this.rinv));\n r.red = null;\n return r;\n };\n\n Mont.prototype.imul = function imul (a, b) {\n if (a.isZero() || b.isZero()) {\n a.words[0] = 0;\n a.length = 1;\n return a;\n }\n\n var t = a.imul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.mul = function mul (a, b) {\n if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n\n var t = a.mul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.invm = function invm (a) {\n // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n var res = this.imod(a._invmp(this.m).mul(this.r2));\n return res._forceRed(this);\n };\n})(typeof module === 'undefined' || module, this);\n","import { AggregatorClient, Env } from '@cetusprotocol/aggregator-sdk'\nimport { normalizeSuiAddress } from '@mysten/sui/utils'\nimport { CetusDlmmSDK } from '@cetusprotocol/dlmm-sdk'\nimport { BaseSdkOptions, SdkWrapper } from '@cetusprotocol/common-sdk'\nimport { zapMainnet } from './config/mainnet'\nimport { zapTestnet } from './config/testnet'\nimport { ZapModule } from './modules/zapModule'\nimport { SuiGrpcClient } from '@mysten/sui/grpc'\nimport { SuiJsonRpcClient } from '@mysten/sui/jsonRpc'\n/**\n * Represents options and configurations for an SDK.\n */\nexport interface SdkOptions extends BaseSdkOptions {\n /**\n * The URL of the aggregator service.\n */\n aggregator_url: string\n /**\n * A list of aggregator providers.\n */\n providers: string[]\n\n /**\n * A list of Pyth price ID.\n */\n pyth_urls?: string[]\n}\n\n/**\n * The entry class of CetusDlmmZapSDK, which is almost responsible for all interactions with dlmm zap.\n */\nexport class CetusDlmmZapSDK extends SdkWrapper<SdkOptions> {\n /**\n * Module for managing vaults.\n */\n protected _zapModule: ZapModule\n\n protected _dlmmSDK: CetusDlmmSDK\n\n /**\n * Client for interacting with the Aggregator service.\n */\n protected _aggregatorClient: AggregatorClient\n\n constructor(options: SdkOptions, dlmmSDK?: CetusDlmmSDK) {\n super(options)\n\n /**\n * Initialize the ZapModule.\n */\n this._zapModule = new ZapModule(this)\n\n /**\n * Initialize the DlmmSDK.\n */\n this._dlmmSDK = dlmmSDK || CetusDlmmSDK.createSDK({ env: options.env, full_rpc_url: options.full_rpc_url })\n\n /**\n * Initialize the AggregatorClient.\n */\n this._aggregatorClient = this.createAggregatorClient()\n }\n\n private createAggregatorClient() {\n return new AggregatorClient({\n signer: normalizeSuiAddress('0x0'),\n client: this._sdkOptions.sui_client || new SuiJsonRpcClient({ url: this._sdkOptions.full_rpc_url!, network: this._sdkOptions.env === 'testnet' ? 'testnet' : 'mainnet' }),\n env: this._sdkOptions.env === 'testnet' ? Env.Testnet : Env.Mainnet,\n pythUrls: this._sdkOptions.pyth_urls,\n })\n }\n\n updatePythUrls(pythUrls: string[]) {\n if (pythUrls.length === 0) {\n throw new Error('pythUrls is empty')\n }\n this._sdkOptions.pyth_urls = pythUrls\n this._aggregatorClient = this.createAggregatorClient()\n }\n\n setSenderAddress(value: string): void {\n this._dlmmSDK.setSenderAddress(value)\n }\n\n getSenderAddress(validate: boolean = true): string {\n return this._dlmmSDK.getSenderAddress(validate)\n }\n\n /**\n * Updates the providers for the AggregatorClient.\n * @param providers - The new providers to set.\n */\n updateProviders(providers: string[]) {\n if (providers.length === 0) {\n throw new Error('providers is empty')\n }\n this._sdkOptions.providers = providers\n }\n\n updateFullRpcUrl(url: string): void {\n super.updateFullRpcUrl(url)\n this._dlmmSDK.updateFullRpcUrl(url)\n this._aggregatorClient = new AggregatorClient({\n signer: normalizeSuiAddress('0x0'),\n client: new SuiJsonRpcClient({ url: url, network: this._sdkOptions.env === 'testnet' ? 'testnet' : 'mainnet' }),\n env: this._sdkOptions.env === 'testnet' ? Env.Testnet : Env.Mainnet,\n pythUrls: this._sdkOptions.pyth_urls,\n })\n }\n\n /**\n * Getter for the DlmmSDK property.\n * @returns {CetusDlmmSDK} The DlmmSDK property value.\n */\n get DlmmSDK(): CetusDlmmSDK {\n return this._dlmmSDK\n }\n\n /**\n * Getter for the AggregatorClient property.\n * @returns {AggregatorClient} The AggregatorClient property value.\n */\n get AggregatorClient(): AggregatorClient {\n return this._aggregatorClient\n }\n\n /**\n * Getter for the ZapModule property.\n * @returns {ZapModule} The ZapModule property value.\n */\n get Zap(): ZapModule {\n return this._zapModule\n }\n\n /**\n * Static factory method to initialize the SDK\n * @param options SDK initialization options\n * @param clmm_sdk Optional CLMM SDK instance\n * @returns An instance of CetusZapSDK\n */\n static createSDK(options: BaseSdkOptions, dlmm_sdk?: any): CetusDlmmZapSDK {\n const { env = 'mainnet', full_rpc_url } = options\n return env === 'mainnet'\n ? CetusDlmmZapSDK.createCustomSDK({ ...zapMainnet, ...options }, dlmm_sdk)\n : CetusDlmmZapSDK.createCustomSDK({ ...zapTestnet, ...options }, dlmm_sdk)\n }\n\n /**\n * Create a custom SDK instance with the given options\n * @param options The options for the SDK\n * @returns An instance of CetusBurnSDK\n */\n static createCustomSDK<T extends BaseSdkOptions>(options: T & SdkOptions, dlmm_sdk?: CetusDlmmSDK): CetusDlmmZapSDK {\n return new CetusDlmmZapSDK(options, dlmm_sdk)\n }\n}\n","import { SdkOptions } from '../sdk'\nimport { DefaultProviders, FullRpcUrlMainnet, GraphRpcUrlMainnet } from '@cetusprotocol/common-sdk'\n// mainnet\nexport const zapMainnet: SdkOptions = {\n env: 'mainnet',\n full_rpc_url: FullRpcUrlMainnet,\n graph_rpc_url: GraphRpcUrlMainnet,\n aggregator_url: 'https://api-sui.cetus.zone/router_v3',\n providers: [],\n}\n","import { FullRpcUrlTestnet, GraphRpcUrlTestnet } from '@cetusprotocol/common-sdk'\nimport { SdkOptions } from '../sdk'\nexport const zapTestnet: SdkOptions = {\n env: 'testnet',\n full_rpc_url: FullRpcUrlTestnet,\n graph_rpc_url: GraphRpcUrlTestnet,\n aggregator_url: 'https://api-sui.devcetus.com/router_v3',\n providers: ['CETUS', 'DEEPBOOK', 'KRIYA', 'KRIYAV3', 'FLOWX', 'FLOWXV3', 'AFTERMATH', 'TURBOS', 'HAEDAL', 'VOLO', 'AFSUI'],\n}\n","import { BuildRouterSwapParamsV3, FindRouterParams, PreSwapLpChangeParams } from '@cetusprotocol/aggregator-sdk'\nimport { Transaction, TransactionObjectArgument } from '@mysten/sui/transactions'\n\nimport BN from 'bn.js'\nimport {\n asUintN,\n ClmmPoolUtil,\n CLOCK_ADDRESS,\n CoinAsset,\n CoinAssist,\n convertScientificToDecimal,\n d,\n DETAILS_KEYS,\n fromDecimalsAmount,\n getPackagerConfigs,\n IModule,\n TickMath,\n toDecimalsAmount,\n} from '@cetusprotocol/common-sdk'\nimport Decimal from 'decimal.js'\nimport { handleError, handleMessageError, ZapErrorCode } from '../errors/errors'\nimport {\n BaseDepositOptions,\n CalculationDepositResult,\n CalculationWithdrawAvailableAmountOptions,\n CalculationWithdrawOptions,\n CalculationWithdrawResult,\n defaultSwapSlippage,\n DepositOptions,\n OnlyCoinDepositOptions,\n SwapResult,\n WithdrawOptions,\n} from '../types/zap'\nimport { calcExactSwapAmount, calculateLiquidityAmountEnough, calculateLiquidityAmountSide } from '../utils/zap'\nimport { CetusDlmmZapSDK } from '../sdk'\nimport {\n AddLiquidityOption,\n BinAmount,\n BinLiquidityInfo,\n BinUtils,\n CalculateAddLiquidityAutoFillOption,\n OpenAndAddLiquidityOption,\n RemoveLiquidityOption,\n} from '@cetusprotocol/dlmm-sdk'\nimport e from 'cors'\n\n/**\n * ZapModule handles interactions with clmm pools within the system.\n */\nexport class ZapModule implements IModule<CetusDlmmZapSDK> {\n protected _sdk: CetusDlmmZapSDK\n\n constructor(sdk: CetusDlmmZapSDK) {\n this._sdk = sdk\n }\n\n /**\n * Returns the associated SDK instance\n */\n get sdk() {\n return this._sdk\n }\n\n private async calculateBalanceSwapAmountWithoutActiveId(options: BaseDepositOptions, mode_options: OnlyCoinDepositOptions) {\n const { fix_amount_a, coin_amount } = mode_options\n const { bin_step, pool_id, active_id, lower_bin_id, upper_bin_id, active_bin_of_pool, strategy_type } = options\n const pool = await this._sdk.DlmmSDK.Pool.getPool(pool_id, false)\n\n let best_swap_result: SwapResult | undefined\n let _fix_amount_a = fix_amount_a\n let _coin_amount = coin_amount\n if (active_id > upper_bin_id) {\n _fix_amount_a = false\n if (fix_amount_a) {\n best_swap_result = await this.findRouters(pool.coin_type_a, pool.coin_type_b, coin_amount)\n _coin_amount = d(best_swap_result.swap_out_amount)\n .mul(1 - 0.001)\n .toFixed(0)\n } else {\n _coin_amount = coin_amount\n }\n } else if (active_id < lower_bin_id) {\n _fix_amount_a = true\n if (fix_amount_a) {\n _coin_amount = coin_amount\n } else {\n best_swap_result = await this.findRouters(pool.coin_type_b, pool.coin_type_a, coin_amount)\n _coin_amount = d(best_swap_result.swap_out_amount)\n .mul(1 - 0.001)\n .toFixed(0)\n }\n }\n\n const liquidity_info = await this._sdk.DlmmSDK.Position.calculateAddLiquidityInfo({\n pool_id,\n coin_amount: _coin_amount,\n fix_amount_a: _fix_amount_a,\n active_id,\n bin_step,\n lower_bin_id,\n upper_bin_id,\n active_bin_of_pool,\n strategy_type,\n })\n\n return {\n liquidity_info,\n swap_result: best_swap_result,\n }\n }\n\n private async calculateBalanceSwapAmount(options: BaseDepositOptions, mode_options: OnlyCoinDepositOptions) {\n const { fix_amount_a, coin_amount } = mode_options\n const { bin_step, pool_id, active_id, lower_bin_id, upper_bin_id, active_bin_of_pool, strategy_type } = options\n\n if (active_id > upper_bin_id || active_id < lower_bin_id) {\n return this.calculateBalanceSwapAmountWithoutActiveId(options, mode_options)\n }\n\n const liquidity_info = await this._sdk.DlmmSDK.Position.calculateAddLiquidityInfo({\n pool_id,\n coin_amount,\n fix_amount_a,\n active_id,\n bin_step,\n lower_bin_id,\n upper_bin_id,\n active_bin_of_pool,\n strategy_type,\n })\n const { amount_a, amount_b } = liquidity_info\n\n const target_rate = fix_amount_a ? d(amount_b).div(amount_a) : d(amount_a).div(amount_b)\n let real_price = fix_amount_a\n ? BinUtils.getPricePerLamportFromBinId(active_id, bin_step)\n : d(1).div(BinUtils.getPricePerLamportFromBinId(active_id, bin_step)).toString()\n\n const pool = await this._sdk.DlmmSDK.Pool.getPool(pool_id, false)\n\n try {\n const price_result = await this.findRouters(\n fix_amount_a ? pool.coin_type_a : pool.coin_type_b,\n fix_amount_a ? pool.coin_type_b : pool.coin_type_a,\n coin_amount\n )\n\n if (price_result) {\n real_price = d(price_result.swap_out_amount).div(price_result.swap_in_amount).toString()\n }\n } catch (error) { }\n\n const { swap_amount, final_amount_a, final_amount_b } = calcExactSwapAmount(\n coin_amount,\n fix_amount_a,\n real_price,\n target_rate.toString()\n )\n\n console.log('🚀 ~ ZapModule ~ swap_amount:', {\n swap_amount,\n final_amount_a,\n final_amount_b,\n target_rate,\n real_price,\n coin_amount,\n fix_amount_a,\n })\n\n let swap_amount_in = swap_amount || '0'\n let best_swap_result\n let best_liquidity_info: BinLiquidityInfo | undefined\n let temp_swap_result: SwapResult | undefined\n let count = 0\n const max_remain_rate = 0.02\n\n let cached_swap_result: SwapResult | undefined\n let cached_liquidity_info: BinLiquidityInfo | undefined\n let cached_real_remain_rate: Decimal | undefined\n\n do {\n const deposit_amount = d(coin_amount).sub(swap_amount_in).toFixed(0)\n\n temp_swap_result = await this.findRouters(\n fix_amount_a ? pool.coin_type_a : pool.coin_type_b,\n fix_amount_a ? pool.coin_type_b : pool.coin_type_a,\n swap_amount_in\n )\n const swap_out_amount = d(temp_swap_result.swap_out_amount).toFixed(0)\n\n const liquidity_info = await this._sdk.DlmmSDK.Position.calculateAddLiquidityInfo({\n pool_id,\n coin_amount: deposit_amount,\n fix_amount_a,\n active_id,\n bin_step,\n lower_bin_id,\n upper_bin_id,\n active_bin_of_pool,\n strategy_type,\n })\n const { amount_a, amount_b } = liquidity_info\n const deposit_amount_other = fix_amount_a ? amount_b : amount_a\n const real_remain_rate = d(swap_out_amount).sub(deposit_amount_other).div(swap_out_amount)\n\n if (real_remain_rate.gt(0) && (cached_real_remain_rate === undefined || real_remain_rate.lt(cached_real_remain_rate))) {\n cached_swap_result = temp_swap_result\n cached_liquidity_info = liquidity_info\n cached_real_remain_rate = real_remain_rate\n }\n\n if (d(swap_out_amount).gt(deposit_amount_other)) {\n if (d(real_remain_rate).gt(max_remain_rate)) {\n console.log('calculateBalanceSwapAmount -: ', {\n swap_amount_in,\n real_remain_rate: real_remain_rate.toString(),\n cached_real_remain_rate: cached_real_remain_rate?.toString(),\n temp_swap_result,\n deposit_amount_other,\n count,\n })\n swap_amount_in = d(swap_amount_in)\n .mul(1 - 0.01)\n .toFixed(0)\n\n count++\n } else {\n best_swap_result = temp_swap_result\n best_liquidity_info = liquidity_info\n break\n }\n } else {\n swap_amount_in = d(swap_amount_in)\n .mul(1 + 0.01)\n .toFixed(0)\n swap_amount_in = Math.min(\n Number(\n d(coin_amount)\n .mul(1 - 0.0001)\n .toFixed(0)\n ),\n Number(swap_amount_in)\n ).toString()\n console.log('calculateBalanceSwapAmount +: ', {\n swap_amount_in,\n real_remain_rate: real_remain_rate.toString(),\n cached_real_remain_rate: cached_real_remain_rate?.toString(),\n temp_swap_result,\n deposit_amount_other,\n count,\n })\n count++\n }\n if (count > 5) {\n break\n }\n } while (!best_swap_result && d(swap_amount_in).gt(0))\n\n if (best_swap_result === undefined && cached_swap_result) {\n best_swap_result = cached_swap_result\n best_liquidity_info = cached_liquidity_info\n }\n\n if (best_swap_result === undefined && temp_swap_result) {\n const { swap_out_amount } = temp_swap_result\n const liquidity_info = await this._sdk.DlmmSDK.Position.calculateAddLiquidityInfo({\n pool_id,\n coin_amount: d(swap_out_amount)\n .sub(1 - 0.001)\n .toFixed(0),\n fix_amount_a: !fix_amount_a,\n active_id,\n bin_step,\n lower_bin_id,\n upper_bin_id,\n active_bin_of_pool,\n strategy_type,\n })\n best_swap_result = temp_swap_result\n best_liquidity_info = liquidity_info\n }\n\n return {\n swap_result: best_swap_result,\n liquidity_info: best_liquidity_info,\n }\n }\n\n /**\n * Pre-calculates the deposit amount based on the selected mode.\n * @param options\n * @param mode_options\n * @returns\n */\n async preCalculateDepositAmount(options: BaseDepositOptions, mode_options: OnlyCoinDepositOptions): Promise<CalculationDepositResult> {\n const { fix_amount_a, coin_amount } = mode_options\n console.log('🚀 ~ ZapModule ~ preCalculateDepositAmount ~ options:', {\n options,\n mode_options,\n })\n\n const { liquidity_info: best_liquidity_info, swap_result: best_swap_result } = await this.calculateBalanceSwapAmount(\n options,\n mode_options\n )\n\n if (best_liquidity_info === undefined) {\n return handleMessageError(ZapErrorCode.SwapAmountError, 'Best liquidity info is undefined', {\n [DETAILS_KEYS.METHOD_NAME]: 'preCalculateDepositAmount',\n }) as never\n }\n\n return {\n bin_infos: best_liquidity_info,\n swap_result: best_swap_result,\n fix_amount_a,\n coin_amount,\n }\n }\n\n public async buildDepositPayload(options: DepositOptions, tx?: Transaction): Promise<Transaction> {\n const {\n swap_slippage = defaultSwapSlippage,\n bin_step,\n pool_id,\n active_id,\n lower_bin_id,\n upper_bin_id,\n strategy_type,\n deposit_obj,\n slippage,\n pos_obj,\n } = options\n const { fix_amount_a, coin_amount, swap_result, bin_infos } = deposit_obj\n\n tx = tx || new Transaction()\n const pool = await this._sdk.DlmmSDK.Pool.getPool(pool_id, false)\n const { coin_type_a, coin_type_b } = pool\n\n let deposit_amount_a_coin\n let deposit_amount_b_coin\n if (swap_result) {\n const coin_type = fix_amount_a ? coin_type_a : coin_type_b\n const { swap_in_amount, route_obj } = swap_result\n const swap_amount_in_coin = CoinAssist.buildCoinWithBalance(BigInt(swap_in_amount), coin_type, tx)\n const routerParamsV3: BuildRouterSwapParamsV3 = {\n router: route_obj,\n slippage: swap_slippage,\n txb: tx,\n inputCoin: swap_amount_in_coin,\n }\n const swap_out_coin = await this._sdk.AggregatorClient.fixableRouterSwapV3(routerParamsV3)\n\n if (fix_amount_a) {\n deposit_amount_a_coin = CoinAssist.buildCoinWithBalance(BigInt(bin_infos.amount_a), coin_type_a, tx)\n deposit_amount_b_coin = swap_out_coin\n } else {\n deposit_amount_a_coin = swap_out_coin\n deposit_amount_b_coin = CoinAssist.buildCoinWithBalance(BigInt(bin_infos.amount_b), coin_type_b, tx)\n }\n }\n\n if (pos_obj) {\n const addOption: AddLiquidityOption = {\n pool_id,\n bin_infos: bin_infos,\n coin_type_a,\n coin_type_b,\n active_id,\n strategy_type,\n max_price_slippage: slippage,\n bin_step,\n use_bin_infos: false,\n position_id: pos_obj.pos_id as string,\n collect_fee: pos_obj.collect_fee,\n reward_coins: pos_obj.collect_rewarder_types,\n coin_object_id_a: deposit_amount_a_coin,\n coin_object_id_b: deposit_amount_b_coin,\n }\n this._sdk.DlmmSDK.Position.addLiquidityPayload(addOption, tx)\n } else {\n const addOption: OpenAndAddLiquidityOption = {\n pool_id,\n bin_infos: bin_infos,\n coin_type_a,\n coin_type_b,\n lower_bin_id,\n upper_bin_id,\n active_id,\n strategy_type,\n use_bin_infos: false,\n max_price_slippage: slippage,\n bin_step,\n coin_object_id_a: deposit_amount_a_coin,\n coin_object_id_b: deposit_amount_b_coin,\n }\n this._sdk.DlmmSDK.Position.addLiquidityPayload(addOption, tx)\n }\n\n return tx\n }\n\n public async findRouters(from: string, target: string, amount: string): Promise<SwapResult> {\n const { providers } = this._sdk.sdkOptions\n const client = this._sdk.AggregatorClient\n\n if (d(amount).lt(1)) {\n return handleMessageError(ZapErrorCode.SwapAmountError, 'Swap amount is less than the minimum precision', {\n [DETAILS_KEYS.METHOD_NAME]: 'findRouters',\n }) as never\n }\n\n try {\n // Construct parameters for route finding\n const findRouterParams: FindRouterParams = {\n from,\n target,\n amount: new BN(amount),\n byAmountIn: true,\n depth: 3,\n providers,\n }\n\n // Find the swap route\n const res = await client.findRouters(findRouterParams)\n if (res?.error) {\n return handleMessageError(ZapErrorCode.AggregatorError, `Aggregator findRouters error: ${res?.error}`, {\n [DETAILS_KEYS.METHOD_NAME]: 'findRouters',\n [DETAILS_KEYS.REQUEST_PARAMS]: findRouterParams,\n }) as never\n }\n if (!res?.paths || res?.paths?.length === 0) {\n return handleMessageError(ZapErrorCode.AggregatorError, 'Aggregator findRouters error: no router', {\n [DETAILS_KEYS.METHOD_NAME]: 'findRouters',\n [DETAILS_KEYS.REQUEST_PARAMS]: findRouterParams,\n }) as never\n }\n\n const swap_in_amount = res.amountIn.toString()\n const swap_out_amount = res.amountOut.toString()\n\n // Return the swap result\n const swapResult: SwapResult = {\n swap_in_amount,\n swap_out_amount,\n route_obj: res,\n }\n return swapResult\n } catch (error) {\n console.log('🚀 ~ ZapModule ~ error:', JSON.stringify(error, null, 2))\n return handleError(ZapErrorCode.AggregatorError, error as Error, {\n [DETAILS_KEYS.METHOD_NAME]: 'swapInPools',\n })\n }\n }\n\n public calculateZapOutAvailableAmount(options: CalculationWithdrawAvailableAmountOptions) {\n const { is_receive_coin_a, mode, active_id, bin_step, remove_bin_range, prices, coin_decimal_a, coin_decimal_b } = options\n let price\n if (prices) {\n const { coin_a_price, coin_b_price } = prices\n price = d(coin_a_price).div(coin_b_price).toString()\n } else {\n price = BinUtils.getPriceFromBinId(active_id, bin_step, coin_decimal_a, coin_decimal_b)\n }\n\n let active_bin: BinAmount | undefined\n let user_total_amount_a = '0'\n let user_total_amount_b = '0'\n let available_amount = '0'\n\n remove_bin_range.forEach((bin) => {\n if (bin.bin_id === active_id) {\n active_bin = bin\n }\n user_total_amount_a = d(user_total_amount_a).add(bin.amount_a).toFixed(0)\n user_total_amount_b = d(user_total_amount_b).add(bin.amount_b).toFixed(0)\n })\n\n const user_total_amount_a_no_active = d(user_total_amount_a)\n .sub(active_bin?.amount_a || '0')\n .toFixed(0)\n const user_total_amount_b_no_active = d(user_total_amount_b)\n .sub(active_bin?.amount_b || '0')\n .toFixed(0)\n\n const transformToAmountB = d(\n toDecimalsAmount(d(fromDecimalsAmount(user_total_amount_a, coin_decimal_a)).mul(price).toString(), coin_decimal_b)\n ).toFixed(0)\n const transformToAmountA = d(\n toDecimalsAmount(d(fromDecimalsAmount(user_total_amount_b, coin_decimal_b)).div(price).toString(), coin_decimal_a)\n ).toFixed(0)\n if (mode === 'OnlyCoinA') {\n if (is_receive_coin_a) {\n available_amount = user_total_amount_a_no_active\n } else {\n available_amount = transformToAmountB\n }\n } else if (mode === 'OnlyCoinB') {\n user_total_amount_b = user_total_amount_b_no_active\n if (is_receive_coin_a) {\n available_amount = transformToAmountA\n } else {\n available_amount = user_total_amount_b\n }\n } else if (mode === 'Both') {\n if (is_receive_coin_a) {\n available_amount = d(transformToAmountA).add(user_total_amount_a).toFixed(0)\n } else {\n available_amount = d(transformToAmountB).add(user_total_amount_b).toFixed(0)\n }\n }\n return {\n available_amount,\n user_total_amount_a,\n user_total_amount_b,\n active_bin,\n is_receive_coin_a,\n }\n }\n\n public async preCalculateWithdrawAmount(options: CalculationWithdrawOptions): Promise<CalculationWithdrawResult> {\n const { is_receive_coin_a, remove_bin_range, coin_type_a, coin_type_b, mode, expected_receive_amount, active_id } = options\n\n const { available_amount, user_total_amount_a, user_total_amount_b, active_bin } = this.calculateZapOutAvailableAmount(options)\n if (d(available_amount).lt(d(expected_receive_amount))) {\n return handleMessageError(\n ZapErrorCode.SwapAmountError,\n `Available amount is less than the expected receive amount: ${available_amount} < ${expected_receive_amount}`,\n {\n [DETAILS_KEYS.METHOD_NAME]: 'preCalculateWithdrawAmount',\n [DETAILS_KEYS.REQUEST_PARAMS]: options,\n }\n ) as never\n }\n const remove_percent = d(expected_receive_amount).div(available_amount)\n\n let remove_liquidity_info: BinLiquidityInfo\n if (mode === 'Both') {\n const fix_amount_a = d(user_total_amount_a).gt(0)\n const coin_amount = fix_amount_a\n ? d(user_total_amount_a).mul(remove_percent).toFixed(0)\n : d(user_total_amount_b).mul(remove_percent).toFixed(0)\n remove_liquidity_info = this._sdk.DlmmSDK.Position.calculateRemoveLiquidityInfo({\n bins: remove_bin_range,\n active_id,\n fix_amount_a,\n coin_amount,\n })\n } else {\n const coin_amount =\n mode === 'OnlyCoinA' ? d(user_total_amount_a).mul(remove_percent).toFixed(0) : d(user_total_amount_b).mul(remove_percent).toFixed(0)\n remove_liquidity_info = this._sdk.DlmmSDK.Position.calculateRemoveLiquidityInfo({\n bins: remove_bin_range,\n active_id,\n is_only_a: mode === 'OnlyCoinA',\n coin_amount,\n })\n }\n\n const { amount_a, amount_b } = remove_liquidity_info\n\n let swap_result: SwapResult | undefined\n if (is_receive_coin_a && d(amount_b).gt(0)) {\n swap_result = await this.findRouters(coin_type_b, coin_type_a, amount_b)\n }\n\n if (!is_receive_coin_a && d(amount_a).gt(0)) {\n swap_result = await this.findRouters(coin_type_a, coin_type_b, amount_a)\n }\n\n return {\n remove_liquidity_info,\n swap_result,\n mode,\n is_receive_coin_a,\n expected_receive_amount,\n remove_percent: remove_percent.toString(),\n }\n }\n\n public async buildWithdrawPayload(options: WithdrawOptions): Promise<Transaction> {\n const tx = new Transaction()\n const {\n withdraw_obj,\n swap_slippage = defaultSwapSlippage,\n bin_step,\n pool_id,\n active_id,\n collect_fee,\n reward_coins,\n coin_type_a,\n coin_type_b,\n position_id,\n slippage,\n remove_percent,\n is_close_position,\n } = options\n\n const { remove_liquidity_info, swap_result, is_receive_coin_a } = withdraw_obj\n\n const removeOption: RemoveLiquidityOption = {\n pool_id,\n bin_infos: remove_liquidity_info,\n coin_type_a,\n coin_type_b,\n position_id,\n slippage,\n active_id,\n reward_coins,\n collect_fee,\n bin_step,\n remove_percent: Number(remove_percent),\n }\n const { coin_a_obj, coin_b_obj } = is_close_position\n ? this._sdk.DlmmSDK.Position.closePositionNoTransferPayload(removeOption, tx)\n : this._sdk.DlmmSDK.Position.removeLiquidityNoTransferPayload(removeOption, tx)\n\n if (swap_result) {\n const { route_obj } = swap_result\n const routerParamsV3: BuildRouterSwapParamsV3 = {\n router: route_obj,\n slippage: swap_slippage,\n txb: tx,\n inputCoin: is_receive_coin_a ? coin_b_obj : coin_a_obj,\n }\n const swap_out_coin = await this._sdk.AggregatorClient.fixableRouterSwapV3(routerParamsV3)\n if (is_receive_coin_a) {\n tx.transferObjects([coin_a_obj, swap_out_coin], this._sdk.getSenderAddress())\n } else {\n tx.transferObjects([coin_b_obj, swap_out_coin], this._sdk.getSenderAddress())\n }\n } else {\n tx.transferObjects([coin_a_obj, coin_b_obj], this._sdk.getSenderAddress())\n }\n\n return tx\n }\n}\n","import { BaseError } from '@cetusprotocol/common-sdk'\n\nexport enum ZapErrorCode {\n UnsupportedDepositMode = 'UnsupportedDepositMode',\n PositionIdUndefined = 'PositionIdUndefined',\n ParameterError = 'ParameterError',\n ReachMaxIterations = 'ReachMaxIterations',\n BestLiquidityIsZero = 'BestLiquidityIsZero',\n SwapAmountError = 'SwapAmountError',\n AggregatorError = 'AggregatorError',\n}\n\nexport class ZapError extends BaseError {\n constructor(message: string, errorCode?: ZapErrorCode, details?: Record<string, any>) {\n super(message, errorCode || 'UnknownError', details)\n }\n\n static isZapErrorCode(e: any, code: ZapErrorCode): boolean {\n return this.isErrorCode<ZapError>(e, code)\n }\n}\n\nexport const handleError = (code: ZapErrorCode, error: Error, details?: Record<string, any>) => {\n throw new ZapError(error.message, code, details)\n}\n\nexport const handleMessageError = (code: ZapErrorCode, message: string, details?: Record<string, any>) => {\n throw new ZapError(message, code, details)\n}\n","import { TransactionObjectArgument } from '@mysten/sui/transactions'\nimport { BinAmount, BinLiquidityInfo, StrategyType } from '@cetusprotocol/dlmm-sdk'\nimport { CoinPairType } from '@cetusprotocol/common-sdk'\n\nexport const defaultSwapSlippage = 0.005\n\n/**\n * Result of a swap operation containing amounts and price information\n */\nexport type SwapResult = {\n swap_in_amount: string // Amount of tokens being swapped in\n swap_out_amount: string // Amount of tokens being swapped out\n route_obj?: any // Optional routing information for the swap\n}\n\nexport type BaseDepositOptions = {\n pool_id: string\n strategy_type: StrategyType\n active_bin_of_pool?: BinAmount\n lower_bin_id: number\n upper_bin_id: number\n active_id: number\n bin_step: number\n}\n\nexport type OnlyCoinDepositOptions = {\n fix_amount_a: boolean\n coin_amount: string\n}\n\n/**\n * Result of a deposit calculation\n */\nexport type CalculationDepositResult = {\n bin_infos: BinLiquidityInfo\n swap_result?: SwapResult\n fix_amount_a: boolean\n coin_amount: string\n}\n\n/**\n * Complete options for executing a deposit\n */\nexport type DepositOptions = {\n deposit_obj: CalculationDepositResult\n slippage: number\n pool_id: string\n strategy_type: StrategyType\n lower_bin_id: number\n upper_bin_id: number\n active_id: number\n bin_step: number\n swap_slippage?: number\n pos_obj?: {\n pos_id: string | TransactionObjectArgument\n collect_fee: boolean\n collect_rewarder_types: string[]\n }\n}\n\nexport type WithdrawMode = 'OnlyCoinA' | 'OnlyCoinB' | 'Both'\nexport type CalculationWithdrawOptions = {\n remove_bin_range: BinAmount[]\n active_id: number\n bin_step: number\n expected_receive_amount: string\n is_receive_coin_a: boolean\n mode: WithdrawMode\n coin_decimal_a: number\n coin_decimal_b: number\n prices?: {\n coin_a_price: string\n coin_b_price: string\n }\n} & CoinPairType\n\nexport type CalculationWithdrawAvailableAmountOptions = {\n remove_bin_range: BinAmount[]\n active_id: number\n bin_step: number\n is_receive_coin_a: boolean\n mode: WithdrawMode\n coin_decimal_a: number\n coin_decimal_b: number\n prices?: {\n coin_a_price: string\n coin_b_price: string\n }\n}\n\n/**\n * Result of a withdrawal calculation\n */\nexport type CalculationWithdrawResult = {\n remove_liquidity_info: BinLiquidityInfo\n mode: WithdrawMode\n is_receive_coin_a?: boolean\n swap_result?: SwapResult\n expected_receive_amount: string\n remove_percent: string\n}\n\n/**\n * Complete options for executing a withdrawal\n */\nexport type WithdrawOptions = {\n withdraw_obj: CalculationWithdrawResult\n swap_slippage?: number\n pool_id: string\n position_id: string\n active_id: number\n bin_step: number\n slippage: number\n reward_coins: string[]\n collect_fee: boolean\n remove_percent?: number\n is_close_position: boolean\n} & CoinPairType\n","import BN from 'bn.js'\nimport { SwapResult } from '../types/zap'\nimport { ClmmPoolUtil, d, getTickSide, TickMath } from '@cetusprotocol/common-sdk'\nimport Decimal from 'decimal.js'\n\n/**\n * Calculate if there is enough liquidity amount for adding liquidity to a pool\n * @param amount_a - Amount of token A\n * @param amount_b - Amount of token B\n * @param curr_sqrt_price - Current square root price of the pool\n * @param lower_tick - Lower tick boundary of the position\n * @param upper_tick - Upper tick boundary of the position\n * @param slippage - Slippage tolerance for the calculation\n * @param fix_amount_a - Whether to fix the amount of token A\n * @returns Object containing:\n * - is_enough_amount: Whether there is enough amount for the other token\n * - use_amount_a: Amount of token A to be used\n * - use_amount_b: Amount of token B to be used\n * - liquidity: Calculated liquidity amount\n * - amount_limit_a: Minimum amount limit for token A\n * - amount_limit_b: Minimum amount limit for token B\n * - remain_amount: Remaining amount of the non-fixed token\n */\nexport function calculateLiquidityAmountEnough(\n amount_a: string,\n amount_b: string,\n curr_sqrt_price: string,\n lower_tick: number,\n upper_tick: number,\n slippage: number,\n fix_amount_a: boolean\n) {\n const fixCoinAmount = fix_amount_a ? new BN(amount_a) : new BN(amount_b)\n\n const liquidityInput = ClmmPoolUtil.estLiquidityAndCoinAmountFromOneAmounts(\n lower_tick,\n upper_tick,\n fixCoinAmount,\n fix_amount_a,\n true,\n slippage,\n new BN(curr_sqrt_price)\n )\n\n const use_amount_a = fix_amount_a ? fixCoinAmount.toString() : liquidityInput.coin_amount_a.toString()\n const use_amount_b = fix_amount_a ? liquidityInput.coin_amount_b.toString() : fixCoinAmount.toString()\n\n const remain_amount_a = d(amount_a).sub(use_amount_a)\n const remain_amount_b = d(amount_b).sub(use_amount_b)\n\n const is_enough_amount = fix_amount_a ? remain_amount_b.gte(0) : remain_amount_a.gte(0)\n\n return {\n is_enough_amount,\n use_amount_a,\n use_amount_b,\n liquidity: liquidityInput.liquidity_amount,\n amount_limit_a: liquidityInput.coin_amount_limit_a,\n amount_limit_b: liquidityInput.coin_amount_limit_b,\n remain_amount: fix_amount_a ? remain_amount_b : remain_amount_a,\n }\n}\n/**\n * Calculate the optimal side for adding liquidity based on current price and tick range\n * @param amount_a - Amount of token A\n * @param amount_b - Amount of token B\n * @param curr_sqrt_price - Current square root price of the pool\n * @param lower_tick - Lower tick boundary of the position\n * @param upper_tick - Upper tick boundary of the position\n * @param slippage - Slippage tolerance for the calculation\n * @param fix_amount_a - Whether to fix the amount of token A\n * @returns Object containing:\n * - fix_liquidity_amount_a: Whether to fix token A amount\n * - is_enough_amount: Whether there is enough amount for the other token\n * - use_amount_a: Amount of token A to be used\n * - use_amount_b: Amount of token B to be used\n * - liquidity: Calculated liquidity amount\n * - amount_limit_a: Minimum amount limit for token A\n * - amount_limit_b: Minimum amount limit for token B\n * - remain_amount: Remaining amount of the non-fixed token\n */\nexport function calculateLiquidityAmountSide(\n amount_a: string,\n amount_b: string,\n curr_sqrt_price: string,\n lower_tick: number,\n upper_tick: number,\n slippage: number,\n fix_amount_a: boolean\n) {\n const currTick = TickMath.sqrtPriceX64ToTickIndex(new BN(curr_sqrt_price))\n let fix_liquidity_amount_a = fix_amount_a\n\n if (currTick < lower_tick) {\n fix_liquidity_amount_a = true\n } else if (currTick > upper_tick) {\n fix_liquidity_amount_a = false\n }\n\n let res = calculateLiquidityAmountEnough(amount_a, amount_b, curr_sqrt_price, lower_tick, upper_tick, slippage, fix_liquidity_amount_a)\n // If not enough, fix the other side to add liquidity\n if (!res.is_enough_amount) {\n fix_liquidity_amount_a = !fix_liquidity_amount_a\n res = calculateLiquidityAmountEnough(amount_a, amount_b, curr_sqrt_price, lower_tick, upper_tick, slippage, fix_liquidity_amount_a)\n }\n return {\n fix_liquidity_amount_a,\n ...res,\n }\n}\n\n/**\n * Calculate the swap amount needed to achieve target ratio\n * @param coin_amount - Total coin amount available\n * @param fix_amount_a - Whether to fix token A amount (true) or token B amount (false)\n * @param current_price - Current price:\n * - When fix_amount_a = true: current_price = B/A (price of B in terms of A)\n * - When fix_amount_a = false: current_price = A/B (price of A in terms of B)\n * @param target_ratio - Target ratio to achieve:\n * - When fix_amount_a = true: target_ratio = B/A\n * - When fix_amount_a = false: target_ratio = A/B\n * @param tolerance - Tolerance for the target ratio (default: 0.01)\n * @returns Object containing:\n * - swap_amount: Amount to swap\n * - final_amount_a: Final amount of token A (remaining A when fix_amount_a=true, obtained A when fix_amount_a=false)\n * - final_amount_b: Final amount of token B (obtained B when fix_amount_a=true, remaining B when fix_amount_a=false)\n */\nexport function calcExactSwapAmount(coin_amount: string, fix_amount_a: boolean, current_price: string, target_ratio: string) {\n const amount = d(coin_amount)\n\n const price = d(current_price)\n const target = d(target_ratio)\n\n const maxSwap = amount\n\n // initial balances\n const A0 = fix_amount_a ? amount : d(0)\n const B0 = fix_amount_a ? d(0) : amount\n\n // desired ratio range\n const maxR = target\n // Ensure minR is not negative (ratio must be positive)\n const minR = d(target).mul(0.999)\n\n let left = d(0)\n let right = maxSwap\n let best: Decimal | null = null\n\n function computeFinal(x: Decimal) {\n if (fix_amount_a) {\n const A = A0.minus(x)\n const B = B0.plus(x.mul(price))\n return { A, B, R: B.div(A) }\n } else {\n const A = A0.plus(x.mul(price))\n const B = B0.minus(x)\n return { A, B, R: A.div(B) }\n }\n }\n\n // binary search\n for (let i = 0; i < 120; i++) {\n const mid = left.plus(right).div(2)\n const { A, B, R } = computeFinal(mid)\n\n if (A.lte(0) || B.lte(0)) {\n right = mid\n continue\n }\n\n if (R.gt(maxR)) {\n // Ratio is too high → swapped too much → decrease swap amount\n right = mid\n } else if (R.lt(minR)) {\n // Ratio is too low → swapped too little → increase swap\n left = mid\n } else {\n best = mid // In the range\n if (d(minR).eq(0)) {\n break\n }\n right = mid // Continue to find a smaller swap\n }\n }\n\n if (!best) {\n return {\n swap_amount: '0',\n final_amount_a: A0.toFixed(0),\n final_amount_b: B0.toFixed(0),\n }\n }\n\n const { A, B } = computeFinal(best)\n\n return {\n swap_amount: best.toFixed(0),\n final_amount_a: A.toFixed(0),\n final_amount_b: B.toFixed(0),\n }\n}\n","import { CetusDlmmZapSDK, SdkOptions } from './sdk'\n\nexport * from './utils'\nexport * from './types'\nexport * from './modules'\nexport * from './config'\nexport * from './errors'\nexport { CetusDlmmZapSDK, SdkOptions }\nexport default CetusDlmmZapSDK\n"],"mappings":"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","names":["require_bn","__commonJSMin","exports","module","assert","val","msg","inherits","ctor","superCtor","TempCtor","BN","number","base","endian","Buffer","num","left","right","start","i","j","w","off","parseHex4Bits","string","index","c","parseHexByte","lowerBound","r","parseLength","parseBase","str","end","mul","b","len","limbLen","limbPow","total","mod","word","pow","dest","move","src","size","inspect","zeros","groupSizes","groupBases","padding","out","carry","groupSize","groupBase","ret","length","allocate","ArrayType","byteLength","reqLength","res","postfix","position","shift","t","hi","toBitArray","bit","wbit","width","a","bytesNeeded","bitsLeft","cmp","smallMulTo","self","lo","k","ncarry","rword","maxJ","comb10MulTo","o","mid","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","w1","w2","w3","w4","w5","w6","w7","w8","w9","w10","w11","w12","w13","w14","w15","w16","w17","w18","bigMulTo","hncarry","jumboMulTo","FFTM","x","y","N","l","rb","rbt","rws","iws","rtws","itws","s","rtwdf","itwdf","rtwdf_","itwdf_","re","ie","ro","io","rx","n","m","odd","ws","ph","_","rwst","iwst","nrws","nrwst","niwst","rmws","isNegNum","q","bits","carryMask","newCarry","hint","extended","h","mask","maskedWords","mode","bhi","bhiBits","diff","qj","positive","div","dm","half","r2","p","acc","A","B","C","D","g","yp","xp","im","jm","x1","x2","delta","negative","Red","ctx","primes","MPrime","name","tmp","rlen","input","K256","output","outLen","prev","next","P224","P192","P25519","prime","mod3","one","nOne","lpow","z","inv","windowSize","wnd","current","currentLen","Mont","u","AggregatorClient","Env","normalizeSuiAddress","CetusDlmmSDK","SdkWrapper","FullRpcUrlMainnet","GraphRpcUrlMainnet","zapMainnet","FullRpcUrlTestnet","GraphRpcUrlTestnet","zapTestnet","import_bn","Transaction","CoinAssist","d","DETAILS_KEYS","fromDecimalsAmount","toDecimalsAmount","BaseError","ZapErrorCode","ZapError","message","errorCode","details","e","code","handleError","error","handleMessageError","defaultSwapSlippage","import_bn","ClmmPoolUtil","d","TickMath","calculateLiquidityAmountEnough","amount_a","amount_b","curr_sqrt_price","lower_tick","upper_tick","slippage","fix_amount_a","fixCoinAmount","BN","liquidityInput","use_amount_a","use_amount_b","remain_amount_a","remain_amount_b","calculateLiquidityAmountSide","currTick","fix_liquidity_amount_a","res","calcExactSwapAmount","coin_amount","current_price","target_ratio","amount","price","target","maxSwap","A0","B0","maxR","minR","left","right","best","computeFinal","x","A","i","mid","B","R","BinUtils","ZapModule","sdk","options","mode_options","fix_amount_a","coin_amount","bin_step","pool_id","active_id","lower_bin_id","upper_bin_id","active_bin_of_pool","strategy_type","pool","best_swap_result","_fix_amount_a","_coin_amount","d","liquidity_info","amount_a","amount_b","target_rate","real_price","price_result","swap_amount","final_amount_a","final_amount_b","calcExactSwapAmount","swap_amount_in","best_liquidity_info","temp_swap_result","count","max_remain_rate","cached_swap_result","cached_liquidity_info","cached_real_remain_rate","deposit_amount","swap_out_amount","deposit_amount_other","real_remain_rate","handleMessageError","DETAILS_KEYS","tx","swap_slippage","defaultSwapSlippage","deposit_obj","slippage","pos_obj","swap_result","bin_infos","Transaction","coin_type_a","coin_type_b","deposit_amount_a_coin","deposit_amount_b_coin","coin_type","swap_in_amount","route_obj","swap_amount_in_coin","CoinAssist","routerParamsV3","swap_out_coin","addOption","from","target","amount","providers","client","findRouterParams","BN","res","error","handleError","is_receive_coin_a","mode","remove_bin_range","prices","coin_decimal_a","coin_decimal_b","price","coin_a_price","coin_b_price","active_bin","user_total_amount_a","user_total_amount_b","available_amount","bin","user_total_amount_a_no_active","user_total_amount_b_no_active","transformToAmountB","toDecimalsAmount","fromDecimalsAmount","transformToAmountA","expected_receive_amount","remove_percent","remove_liquidity_info","withdraw_obj","collect_fee","reward_coins","position_id","is_close_position","removeOption","coin_a_obj","coin_b_obj","SuiJsonRpcClient","CetusDlmmZapSDK","_CetusDlmmZapSDK","SdkWrapper","options","dlmmSDK","ZapModule","CetusDlmmSDK","AggregatorClient","normalizeSuiAddress","Env","pythUrls","value","validate","providers","url","dlmm_sdk","env","full_rpc_url","zapMainnet","zapTestnet","index_default","CetusDlmmZapSDK"]}
|
|
1
|
+
{"version":3,"sources":["../../../node_modules/.pnpm/bn.js@5.2.3/node_modules/bn.js/lib/bn.js","../src/sdk.ts","../src/config/mainnet.ts","../src/config/testnet.ts","../src/modules/zapModule.ts","../src/errors/errors.ts","../src/types/zap.ts","../src/utils/zap.ts","../src/modules/compoundModule.ts","../src/utils/compound.ts","../src/index.ts"],"sourcesContent":["(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert (val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits (ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN (number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n\n BN.BN = BN;\n BN.wordSize = 26;\n\n var Buffer;\n try {\n if (typeof window !== 'undefined' && typeof window.Buffer !== 'undefined') {\n Buffer = window.Buffer;\n } else {\n Buffer = require('buffer').Buffer;\n }\n } catch (e) {\n }\n\n BN.isBN = function isBN (num) {\n if (num instanceof BN) {\n return true;\n }\n\n return num !== null && typeof num === 'object' &&\n num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n };\n\n BN.max = function max (left, right) {\n if (left.cmp(right) > 0) return left;\n return right;\n };\n\n BN.min = function min (left, right) {\n if (left.cmp(right) < 0) return left;\n return right;\n };\n\n BN.prototype._init = function init (number, base, endian) {\n if (typeof number === 'number') {\n return this._initNumber(number, base, endian);\n }\n\n if (typeof number === 'object') {\n return this._initArray(number, base, endian);\n }\n\n if (base === 'hex') {\n base = 16;\n }\n assert(base === (base | 0) && base >= 2 && base <= 36);\n\n number = number.toString().replace(/\\s+/g, '');\n var start = 0;\n if (number[0] === '-') {\n start++;\n this.negative = 1;\n }\n\n if (start < number.length) {\n if (base === 16) {\n this._parseHex(number, start, endian);\n } else {\n this._parseBase(number, base, start);\n if (endian === 'le') {\n this._initArray(this.toArray(), base, endian);\n }\n }\n }\n };\n\n BN.prototype._initNumber = function _initNumber (number, base, endian) {\n if (number < 0) {\n this.negative = 1;\n number = -number;\n }\n if (number < 0x4000000) {\n this.words = [number & 0x3ffffff];\n this.length = 1;\n } else if (number < 0x10000000000000) {\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff\n ];\n this.length = 2;\n } else {\n assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n this.words = [\n number & 0x3ffffff,\n (number / 0x4000000) & 0x3ffffff,\n 1\n ];\n this.length = 3;\n }\n\n if (endian !== 'le') return;\n\n // Reverse the bytes\n this._initArray(this.toArray(), base, endian);\n };\n\n BN.prototype._initArray = function _initArray (number, base, endian) {\n // Perhaps a Uint8Array\n assert(typeof number.length === 'number');\n if (number.length <= 0) {\n this.words = [0];\n this.length = 1;\n return this;\n }\n\n this.length = Math.ceil(number.length / 3);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n var j, w;\n var off = 0;\n if (endian === 'be') {\n for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n w = number[i] | (number[i - 1] << 8) | (number[i - 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n } else if (endian === 'le') {\n for (i = 0, j = 0; i < number.length; i += 3) {\n w = number[i] | (number[i + 1] << 8) | (number[i + 2] << 16);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n }\n return this._strip();\n };\n\n function parseHex4Bits (string, index) {\n var c = string.charCodeAt(index);\n // '0' - '9'\n if (c >= 48 && c <= 57) {\n return c - 48;\n // 'A' - 'F'\n } else if (c >= 65 && c <= 70) {\n return c - 55;\n // 'a' - 'f'\n } else if (c >= 97 && c <= 102) {\n return c - 87;\n } else {\n assert(false, 'Invalid character in ' + string);\n }\n }\n\n function parseHexByte (string, lowerBound, index) {\n var r = parseHex4Bits(string, index);\n if (index - 1 >= lowerBound) {\n r |= parseHex4Bits(string, index - 1) << 4;\n }\n return r;\n }\n\n BN.prototype._parseHex = function _parseHex (number, start, endian) {\n // Create possibly bigger array to ensure that it fits the number\n this.length = Math.ceil((number.length - start) / 6);\n this.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n this.words[i] = 0;\n }\n\n // 24-bits chunks\n var off = 0;\n var j = 0;\n\n var w;\n if (endian === 'be') {\n for (i = number.length - 1; i >= start; i -= 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n } else {\n var parseLength = number.length - start;\n for (i = parseLength % 2 === 0 ? start + 1 : start; i < number.length; i += 2) {\n w = parseHexByte(number, start, i) << off;\n this.words[j] |= w & 0x3ffffff;\n if (off >= 18) {\n off -= 18;\n j += 1;\n this.words[j] |= w >>> 26;\n } else {\n off += 8;\n }\n }\n }\n\n this._strip();\n };\n\n function parseBase (str, start, end, mul) {\n var r = 0;\n var b = 0;\n var len = Math.min(str.length, end);\n for (var i = start; i < len; i++) {\n var c = str.charCodeAt(i) - 48;\n\n r *= mul;\n\n // 'a'\n if (c >= 49) {\n b = c - 49 + 0xa;\n\n // 'A'\n } else if (c >= 17) {\n b = c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n b = c;\n }\n assert(c >= 0 && b < mul, 'Invalid character');\n r += b;\n }\n return r;\n }\n\n BN.prototype._parseBase = function _parseBase (number, base, start) {\n // Initialize as zero\n this.words = [0];\n this.length = 1;\n\n // Find length of limb in base\n for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n limbLen++;\n }\n limbLen--;\n limbPow = (limbPow / base) | 0;\n\n var total = number.length - start;\n var mod = total % limbLen;\n var end = Math.min(total, total - mod) + start;\n\n var word = 0;\n for (var i = start; i < end; i += limbLen) {\n word = parseBase(number, i, i + limbLen, base);\n\n this.imuln(limbPow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n if (mod !== 0) {\n var pow = 1;\n word = parseBase(number, i, number.length, base);\n\n for (i = 0; i < mod; i++) {\n pow *= base;\n }\n\n this.imuln(pow);\n if (this.words[0] + word < 0x4000000) {\n this.words[0] += word;\n } else {\n this._iaddn(word);\n }\n }\n\n this._strip();\n };\n\n BN.prototype.copy = function copy (dest) {\n dest.words = new Array(this.length);\n for (var i = 0; i < this.length; i++) {\n dest.words[i] = this.words[i];\n }\n dest.length = this.length;\n dest.negative = this.negative;\n dest.red = this.red;\n };\n\n function move (dest, src) {\n dest.words = src.words;\n dest.length = src.length;\n dest.negative = src.negative;\n dest.red = src.red;\n }\n\n BN.prototype._move = function _move (dest) {\n move(dest, this);\n };\n\n BN.prototype.clone = function clone () {\n var r = new BN(null);\n this.copy(r);\n return r;\n };\n\n BN.prototype._expand = function _expand (size) {\n while (this.length < size) {\n this.words[this.length++] = 0;\n }\n return this;\n };\n\n // Remove leading `0` from `this`\n BN.prototype._strip = function strip () {\n while (this.length > 1 && this.words[this.length - 1] === 0) {\n this.length--;\n }\n return this._normSign();\n };\n\n BN.prototype._normSign = function _normSign () {\n // -0 = 0\n if (this.length === 1 && this.words[0] === 0) {\n this.negative = 0;\n }\n return this;\n };\n\n // Check Symbol.for because not everywhere where Symbol defined\n // See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Symbol#Browser_compatibility\n if (typeof Symbol !== 'undefined' && typeof Symbol.for === 'function') {\n try {\n BN.prototype[Symbol.for('nodejs.util.inspect.custom')] = inspect;\n } catch (e) {\n BN.prototype.inspect = inspect;\n }\n } else {\n BN.prototype.inspect = inspect;\n }\n\n function inspect () {\n return (this.red ? '<BN-R: ' : '<BN: ') + this.toString(16) + '>';\n }\n\n /*\n\n var zeros = [];\n var groupSizes = [];\n var groupBases = [];\n\n var s = '';\n var i = -1;\n while (++i < BN.wordSize) {\n zeros[i] = s;\n s += '0';\n }\n groupSizes[0] = 0;\n groupSizes[1] = 0;\n groupBases[0] = 0;\n groupBases[1] = 0;\n var base = 2 - 1;\n while (++base < 36 + 1) {\n var groupSize = 0;\n var groupBase = 1;\n while (groupBase < (1 << BN.wordSize) / base) {\n groupBase *= base;\n groupSize += 1;\n }\n groupSizes[base] = groupSize;\n groupBases[base] = groupBase;\n }\n\n */\n\n var zeros = [\n '',\n '0',\n '00',\n '000',\n '0000',\n '00000',\n '000000',\n '0000000',\n '00000000',\n '000000000',\n '0000000000',\n '00000000000',\n '000000000000',\n '0000000000000',\n '00000000000000',\n '000000000000000',\n '0000000000000000',\n '00000000000000000',\n '000000000000000000',\n '0000000000000000000',\n '00000000000000000000',\n '000000000000000000000',\n '0000000000000000000000',\n '00000000000000000000000',\n '000000000000000000000000',\n '0000000000000000000000000'\n ];\n\n var groupSizes = [\n 0, 0,\n 25, 16, 12, 11, 10, 9, 8,\n 8, 7, 7, 7, 7, 6, 6,\n 6, 6, 6, 6, 6, 5, 5,\n 5, 5, 5, 5, 5, 5, 5,\n 5, 5, 5, 5, 5, 5, 5\n ];\n\n var groupBases = [\n 0, 0,\n 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216,\n 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625,\n 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632,\n 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149,\n 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176\n ];\n\n BN.prototype.toString = function toString (base, padding) {\n base = base || 10;\n padding = padding | 0 || 1;\n\n var out;\n if (base === 16 || base === 'hex') {\n out = '';\n var off = 0;\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = this.words[i];\n var word = (((w << off) | carry) & 0xffffff).toString(16);\n carry = (w >>> (24 - off)) & 0xffffff;\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\n }\n if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n }\n if (carry !== 0) {\n out = carry.toString(16) + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n if (base === (base | 0) && base >= 2 && base <= 36) {\n // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n var groupSize = groupSizes[base];\n // var groupBase = Math.pow(base, groupSize);\n var groupBase = groupBases[base];\n out = '';\n var c = this.clone();\n c.negative = 0;\n while (!c.isZero()) {\n var r = c.modrn(groupBase).toString(base);\n c = c.idivn(groupBase);\n\n if (!c.isZero()) {\n out = zeros[groupSize - r.length] + r + out;\n } else {\n out = r + out;\n }\n }\n if (this.isZero()) {\n out = '0' + out;\n }\n while (out.length % padding !== 0) {\n out = '0' + out;\n }\n if (this.negative !== 0) {\n out = '-' + out;\n }\n return out;\n }\n\n assert(false, 'Base should be between 2 and 36');\n };\n\n BN.prototype.toNumber = function toNumber () {\n var ret = this.words[0];\n if (this.length === 2) {\n ret += this.words[1] * 0x4000000;\n } else if (this.length === 3 && this.words[2] === 0x01) {\n // NOTE: at this stage it is known that the top bit is set\n ret += 0x10000000000000 + (this.words[1] * 0x4000000);\n } else if (this.length > 2) {\n assert(false, 'Number can only safely store up to 53 bits');\n }\n return (this.negative !== 0) ? -ret : ret;\n };\n\n BN.prototype.toJSON = function toJSON () {\n return this.toString(16, 2);\n };\n\n if (Buffer) {\n BN.prototype.toBuffer = function toBuffer (endian, length) {\n return this.toArrayLike(Buffer, endian, length);\n };\n }\n\n BN.prototype.toArray = function toArray (endian, length) {\n return this.toArrayLike(Array, endian, length);\n };\n\n var allocate = function allocate (ArrayType, size) {\n if (ArrayType.allocUnsafe) {\n return ArrayType.allocUnsafe(size);\n }\n return new ArrayType(size);\n };\n\n BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) {\n this._strip();\n\n var byteLength = this.byteLength();\n var reqLength = length || Math.max(1, byteLength);\n assert(byteLength <= reqLength, 'byte array longer than desired length');\n assert(reqLength > 0, 'Requested array length <= 0');\n\n var res = allocate(ArrayType, reqLength);\n var postfix = endian === 'le' ? 'LE' : 'BE';\n this['_toArrayLike' + postfix](res, byteLength);\n return res;\n };\n\n BN.prototype._toArrayLikeLE = function _toArrayLikeLE (res, byteLength) {\n var position = 0;\n var carry = 0;\n\n for (var i = 0, shift = 0; i < this.length; i++) {\n var word = (this.words[i] << shift) | carry;\n\n res[position++] = word & 0xff;\n if (position < res.length) {\n res[position++] = (word >> 8) & 0xff;\n }\n if (position < res.length) {\n res[position++] = (word >> 16) & 0xff;\n }\n\n if (shift === 6) {\n if (position < res.length) {\n res[position++] = (word >> 24) & 0xff;\n }\n carry = 0;\n shift = 0;\n } else {\n carry = word >>> 24;\n shift += 2;\n }\n }\n\n if (position < res.length) {\n res[position++] = carry;\n\n while (position < res.length) {\n res[position++] = 0;\n }\n }\n };\n\n BN.prototype._toArrayLikeBE = function _toArrayLikeBE (res, byteLength) {\n var position = res.length - 1;\n var carry = 0;\n\n for (var i = 0, shift = 0; i < this.length; i++) {\n var word = (this.words[i] << shift) | carry;\n\n res[position--] = word & 0xff;\n if (position >= 0) {\n res[position--] = (word >> 8) & 0xff;\n }\n if (position >= 0) {\n res[position--] = (word >> 16) & 0xff;\n }\n\n if (shift === 6) {\n if (position >= 0) {\n res[position--] = (word >> 24) & 0xff;\n }\n carry = 0;\n shift = 0;\n } else {\n carry = word >>> 24;\n shift += 2;\n }\n }\n\n if (position >= 0) {\n res[position--] = carry;\n\n while (position >= 0) {\n res[position--] = 0;\n }\n }\n };\n\n if (Math.clz32) {\n BN.prototype._countBits = function _countBits (w) {\n return 32 - Math.clz32(w);\n };\n } else {\n BN.prototype._countBits = function _countBits (w) {\n var t = w;\n var r = 0;\n if (t >= 0x1000) {\n r += 13;\n t >>>= 13;\n }\n if (t >= 0x40) {\n r += 7;\n t >>>= 7;\n }\n if (t >= 0x8) {\n r += 4;\n t >>>= 4;\n }\n if (t >= 0x02) {\n r += 2;\n t >>>= 2;\n }\n return r + t;\n };\n }\n\n BN.prototype._zeroBits = function _zeroBits (w) {\n // Short-cut\n if (w === 0) return 26;\n\n var t = w;\n var r = 0;\n if ((t & 0x1fff) === 0) {\n r += 13;\n t >>>= 13;\n }\n if ((t & 0x7f) === 0) {\n r += 7;\n t >>>= 7;\n }\n if ((t & 0xf) === 0) {\n r += 4;\n t >>>= 4;\n }\n if ((t & 0x3) === 0) {\n r += 2;\n t >>>= 2;\n }\n if ((t & 0x1) === 0) {\n r++;\n }\n return r;\n };\n\n // Return number of used bits in a BN\n BN.prototype.bitLength = function bitLength () {\n var w = this.words[this.length - 1];\n var hi = this._countBits(w);\n return (this.length - 1) * 26 + hi;\n };\n\n function toBitArray (num) {\n var w = new Array(num.bitLength());\n\n for (var bit = 0; bit < w.length; bit++) {\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n w[bit] = (num.words[off] >>> wbit) & 0x01;\n }\n\n return w;\n }\n\n // Number of trailing zero bits\n BN.prototype.zeroBits = function zeroBits () {\n if (this.isZero()) return 0;\n\n var r = 0;\n for (var i = 0; i < this.length; i++) {\n var b = this._zeroBits(this.words[i]);\n r += b;\n if (b !== 26) break;\n }\n return r;\n };\n\n BN.prototype.byteLength = function byteLength () {\n return Math.ceil(this.bitLength() / 8);\n };\n\n BN.prototype.toTwos = function toTwos (width) {\n if (this.negative !== 0) {\n return this.abs().inotn(width).iaddn(1);\n }\n return this.clone();\n };\n\n BN.prototype.fromTwos = function fromTwos (width) {\n if (this.testn(width - 1)) {\n return this.notn(width).iaddn(1).ineg();\n }\n return this.clone();\n };\n\n BN.prototype.isNeg = function isNeg () {\n return this.negative !== 0;\n };\n\n // Return negative clone of `this`\n BN.prototype.neg = function neg () {\n return this.clone().ineg();\n };\n\n BN.prototype.ineg = function ineg () {\n if (!this.isZero()) {\n this.negative ^= 1;\n }\n\n return this;\n };\n\n // Or `num` with `this` in-place\n BN.prototype.iuor = function iuor (num) {\n while (this.length < num.length) {\n this.words[this.length++] = 0;\n }\n\n for (var i = 0; i < num.length; i++) {\n this.words[i] = this.words[i] | num.words[i];\n }\n\n return this._strip();\n };\n\n BN.prototype.ior = function ior (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuor(num);\n };\n\n // Or `num` with `this`\n BN.prototype.or = function or (num) {\n if (this.length > num.length) return this.clone().ior(num);\n return num.clone().ior(this);\n };\n\n BN.prototype.uor = function uor (num) {\n if (this.length > num.length) return this.clone().iuor(num);\n return num.clone().iuor(this);\n };\n\n // And `num` with `this` in-place\n BN.prototype.iuand = function iuand (num) {\n // b = min-length(num, this)\n var b;\n if (this.length > num.length) {\n b = num;\n } else {\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = this.words[i] & num.words[i];\n }\n\n this.length = b.length;\n\n return this._strip();\n };\n\n BN.prototype.iand = function iand (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuand(num);\n };\n\n // And `num` with `this`\n BN.prototype.and = function and (num) {\n if (this.length > num.length) return this.clone().iand(num);\n return num.clone().iand(this);\n };\n\n BN.prototype.uand = function uand (num) {\n if (this.length > num.length) return this.clone().iuand(num);\n return num.clone().iuand(this);\n };\n\n // Xor `num` with `this` in-place\n BN.prototype.iuxor = function iuxor (num) {\n // a.length > b.length\n var a;\n var b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n for (var i = 0; i < b.length; i++) {\n this.words[i] = a.words[i] ^ b.words[i];\n }\n\n if (this !== a) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = a.length;\n\n return this._strip();\n };\n\n BN.prototype.ixor = function ixor (num) {\n assert((this.negative | num.negative) === 0);\n return this.iuxor(num);\n };\n\n // Xor `num` with `this`\n BN.prototype.xor = function xor (num) {\n if (this.length > num.length) return this.clone().ixor(num);\n return num.clone().ixor(this);\n };\n\n BN.prototype.uxor = function uxor (num) {\n if (this.length > num.length) return this.clone().iuxor(num);\n return num.clone().iuxor(this);\n };\n\n // Not ``this`` with ``width`` bitwidth\n BN.prototype.inotn = function inotn (width) {\n assert(typeof width === 'number' && width >= 0);\n\n var bytesNeeded = Math.ceil(width / 26) | 0;\n var bitsLeft = width % 26;\n\n // Extend the buffer with leading zeroes\n this._expand(bytesNeeded);\n\n if (bitsLeft > 0) {\n bytesNeeded--;\n }\n\n // Handle complete words\n for (var i = 0; i < bytesNeeded; i++) {\n this.words[i] = ~this.words[i] & 0x3ffffff;\n }\n\n // Handle the residue\n if (bitsLeft > 0) {\n this.words[i] = ~this.words[i] & (0x3ffffff >> (26 - bitsLeft));\n }\n\n // And remove leading zeroes\n return this._strip();\n };\n\n BN.prototype.notn = function notn (width) {\n return this.clone().inotn(width);\n };\n\n // Set `bit` of `this`\n BN.prototype.setn = function setn (bit, val) {\n assert(typeof bit === 'number' && bit >= 0);\n\n var off = (bit / 26) | 0;\n var wbit = bit % 26;\n\n this._expand(off + 1);\n\n if (val) {\n this.words[off] = this.words[off] | (1 << wbit);\n } else {\n this.words[off] = this.words[off] & ~(1 << wbit);\n }\n\n return this._strip();\n };\n\n // Add `num` to `this` in-place\n BN.prototype.iadd = function iadd (num) {\n var r;\n\n // negative + positive\n if (this.negative !== 0 && num.negative === 0) {\n this.negative = 0;\n r = this.isub(num);\n this.negative ^= 1;\n return this._normSign();\n\n // positive + negative\n } else if (this.negative === 0 && num.negative !== 0) {\n num.negative = 0;\n r = this.isub(num);\n num.negative = 1;\n return r._normSign();\n }\n\n // a.length > b.length\n var a, b;\n if (this.length > num.length) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n this.words[i] = r & 0x3ffffff;\n carry = r >>> 26;\n }\n\n this.length = a.length;\n if (carry !== 0) {\n this.words[this.length] = carry;\n this.length++;\n // Copy the rest of the words\n } else if (a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n return this;\n };\n\n // Add `num` to `this`\n BN.prototype.add = function add (num) {\n var res;\n if (num.negative !== 0 && this.negative === 0) {\n num.negative = 0;\n res = this.sub(num);\n num.negative ^= 1;\n return res;\n } else if (num.negative === 0 && this.negative !== 0) {\n this.negative = 0;\n res = num.sub(this);\n this.negative = 1;\n return res;\n }\n\n if (this.length > num.length) return this.clone().iadd(num);\n\n return num.clone().iadd(this);\n };\n\n // Subtract `num` from `this` in-place\n BN.prototype.isub = function isub (num) {\n // this - (-num) = this + num\n if (num.negative !== 0) {\n num.negative = 0;\n var r = this.iadd(num);\n num.negative = 1;\n return r._normSign();\n\n // -this - num = -(this + num)\n } else if (this.negative !== 0) {\n this.negative = 0;\n this.iadd(num);\n this.negative = 1;\n return this._normSign();\n }\n\n // At this point both numbers are positive\n var cmp = this.cmp(num);\n\n // Optimization - zeroify\n if (cmp === 0) {\n this.negative = 0;\n this.length = 1;\n this.words[0] = 0;\n return this;\n }\n\n // a > b\n var a, b;\n if (cmp > 0) {\n a = this;\n b = num;\n } else {\n a = num;\n b = this;\n }\n\n var carry = 0;\n for (var i = 0; i < b.length; i++) {\n r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n for (; carry !== 0 && i < a.length; i++) {\n r = (a.words[i] | 0) + carry;\n carry = r >> 26;\n this.words[i] = r & 0x3ffffff;\n }\n\n // Copy rest of the words\n if (carry === 0 && i < a.length && a !== this) {\n for (; i < a.length; i++) {\n this.words[i] = a.words[i];\n }\n }\n\n this.length = Math.max(this.length, i);\n\n if (a !== this) {\n this.negative = 1;\n }\n\n return this._strip();\n };\n\n // Subtract `num` from `this`\n BN.prototype.sub = function sub (num) {\n return this.clone().isub(num);\n };\n\n function smallMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n var len = (self.length + num.length) | 0;\n out.length = len;\n len = (len - 1) | 0;\n\n // Peel one iteration (compiler can't do it, because of code complexity)\n var a = self.words[0] | 0;\n var b = num.words[0] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n var carry = (r / 0x4000000) | 0;\n out.words[0] = lo;\n\n for (var k = 1; k < len; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = carry >>> 26;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = (k - j) | 0;\n a = self.words[i] | 0;\n b = num.words[j] | 0;\n r = a * b + rword;\n ncarry += (r / 0x4000000) | 0;\n rword = r & 0x3ffffff;\n }\n out.words[k] = rword | 0;\n carry = ncarry | 0;\n }\n if (carry !== 0) {\n out.words[k] = carry | 0;\n } else {\n out.length--;\n }\n\n return out._strip();\n }\n\n // TODO(indutny): it may be reasonable to omit it for users who don't need\n // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n // multiplication (like elliptic secp256k1).\n var comb10MulTo = function comb10MulTo (self, num, out) {\n var a = self.words;\n var b = num.words;\n var o = out.words;\n var c = 0;\n var lo;\n var mid;\n var hi;\n var a0 = a[0] | 0;\n var al0 = a0 & 0x1fff;\n var ah0 = a0 >>> 13;\n var a1 = a[1] | 0;\n var al1 = a1 & 0x1fff;\n var ah1 = a1 >>> 13;\n var a2 = a[2] | 0;\n var al2 = a2 & 0x1fff;\n var ah2 = a2 >>> 13;\n var a3 = a[3] | 0;\n var al3 = a3 & 0x1fff;\n var ah3 = a3 >>> 13;\n var a4 = a[4] | 0;\n var al4 = a4 & 0x1fff;\n var ah4 = a4 >>> 13;\n var a5 = a[5] | 0;\n var al5 = a5 & 0x1fff;\n var ah5 = a5 >>> 13;\n var a6 = a[6] | 0;\n var al6 = a6 & 0x1fff;\n var ah6 = a6 >>> 13;\n var a7 = a[7] | 0;\n var al7 = a7 & 0x1fff;\n var ah7 = a7 >>> 13;\n var a8 = a[8] | 0;\n var al8 = a8 & 0x1fff;\n var ah8 = a8 >>> 13;\n var a9 = a[9] | 0;\n var al9 = a9 & 0x1fff;\n var ah9 = a9 >>> 13;\n var b0 = b[0] | 0;\n var bl0 = b0 & 0x1fff;\n var bh0 = b0 >>> 13;\n var b1 = b[1] | 0;\n var bl1 = b1 & 0x1fff;\n var bh1 = b1 >>> 13;\n var b2 = b[2] | 0;\n var bl2 = b2 & 0x1fff;\n var bh2 = b2 >>> 13;\n var b3 = b[3] | 0;\n var bl3 = b3 & 0x1fff;\n var bh3 = b3 >>> 13;\n var b4 = b[4] | 0;\n var bl4 = b4 & 0x1fff;\n var bh4 = b4 >>> 13;\n var b5 = b[5] | 0;\n var bl5 = b5 & 0x1fff;\n var bh5 = b5 >>> 13;\n var b6 = b[6] | 0;\n var bl6 = b6 & 0x1fff;\n var bh6 = b6 >>> 13;\n var b7 = b[7] | 0;\n var bl7 = b7 & 0x1fff;\n var bh7 = b7 >>> 13;\n var b8 = b[8] | 0;\n var bl8 = b8 & 0x1fff;\n var bh8 = b8 >>> 13;\n var b9 = b[9] | 0;\n var bl9 = b9 & 0x1fff;\n var bh9 = b9 >>> 13;\n\n out.negative = self.negative ^ num.negative;\n out.length = 19;\n /* k = 0 */\n lo = Math.imul(al0, bl0);\n mid = Math.imul(al0, bh0);\n mid = (mid + Math.imul(ah0, bl0)) | 0;\n hi = Math.imul(ah0, bh0);\n var w0 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w0 >>> 26)) | 0;\n w0 &= 0x3ffffff;\n /* k = 1 */\n lo = Math.imul(al1, bl0);\n mid = Math.imul(al1, bh0);\n mid = (mid + Math.imul(ah1, bl0)) | 0;\n hi = Math.imul(ah1, bh0);\n lo = (lo + Math.imul(al0, bl1)) | 0;\n mid = (mid + Math.imul(al0, bh1)) | 0;\n mid = (mid + Math.imul(ah0, bl1)) | 0;\n hi = (hi + Math.imul(ah0, bh1)) | 0;\n var w1 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w1 >>> 26)) | 0;\n w1 &= 0x3ffffff;\n /* k = 2 */\n lo = Math.imul(al2, bl0);\n mid = Math.imul(al2, bh0);\n mid = (mid + Math.imul(ah2, bl0)) | 0;\n hi = Math.imul(ah2, bh0);\n lo = (lo + Math.imul(al1, bl1)) | 0;\n mid = (mid + Math.imul(al1, bh1)) | 0;\n mid = (mid + Math.imul(ah1, bl1)) | 0;\n hi = (hi + Math.imul(ah1, bh1)) | 0;\n lo = (lo + Math.imul(al0, bl2)) | 0;\n mid = (mid + Math.imul(al0, bh2)) | 0;\n mid = (mid + Math.imul(ah0, bl2)) | 0;\n hi = (hi + Math.imul(ah0, bh2)) | 0;\n var w2 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w2 >>> 26)) | 0;\n w2 &= 0x3ffffff;\n /* k = 3 */\n lo = Math.imul(al3, bl0);\n mid = Math.imul(al3, bh0);\n mid = (mid + Math.imul(ah3, bl0)) | 0;\n hi = Math.imul(ah3, bh0);\n lo = (lo + Math.imul(al2, bl1)) | 0;\n mid = (mid + Math.imul(al2, bh1)) | 0;\n mid = (mid + Math.imul(ah2, bl1)) | 0;\n hi = (hi + Math.imul(ah2, bh1)) | 0;\n lo = (lo + Math.imul(al1, bl2)) | 0;\n mid = (mid + Math.imul(al1, bh2)) | 0;\n mid = (mid + Math.imul(ah1, bl2)) | 0;\n hi = (hi + Math.imul(ah1, bh2)) | 0;\n lo = (lo + Math.imul(al0, bl3)) | 0;\n mid = (mid + Math.imul(al0, bh3)) | 0;\n mid = (mid + Math.imul(ah0, bl3)) | 0;\n hi = (hi + Math.imul(ah0, bh3)) | 0;\n var w3 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w3 >>> 26)) | 0;\n w3 &= 0x3ffffff;\n /* k = 4 */\n lo = Math.imul(al4, bl0);\n mid = Math.imul(al4, bh0);\n mid = (mid + Math.imul(ah4, bl0)) | 0;\n hi = Math.imul(ah4, bh0);\n lo = (lo + Math.imul(al3, bl1)) | 0;\n mid = (mid + Math.imul(al3, bh1)) | 0;\n mid = (mid + Math.imul(ah3, bl1)) | 0;\n hi = (hi + Math.imul(ah3, bh1)) | 0;\n lo = (lo + Math.imul(al2, bl2)) | 0;\n mid = (mid + Math.imul(al2, bh2)) | 0;\n mid = (mid + Math.imul(ah2, bl2)) | 0;\n hi = (hi + Math.imul(ah2, bh2)) | 0;\n lo = (lo + Math.imul(al1, bl3)) | 0;\n mid = (mid + Math.imul(al1, bh3)) | 0;\n mid = (mid + Math.imul(ah1, bl3)) | 0;\n hi = (hi + Math.imul(ah1, bh3)) | 0;\n lo = (lo + Math.imul(al0, bl4)) | 0;\n mid = (mid + Math.imul(al0, bh4)) | 0;\n mid = (mid + Math.imul(ah0, bl4)) | 0;\n hi = (hi + Math.imul(ah0, bh4)) | 0;\n var w4 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w4 >>> 26)) | 0;\n w4 &= 0x3ffffff;\n /* k = 5 */\n lo = Math.imul(al5, bl0);\n mid = Math.imul(al5, bh0);\n mid = (mid + Math.imul(ah5, bl0)) | 0;\n hi = Math.imul(ah5, bh0);\n lo = (lo + Math.imul(al4, bl1)) | 0;\n mid = (mid + Math.imul(al4, bh1)) | 0;\n mid = (mid + Math.imul(ah4, bl1)) | 0;\n hi = (hi + Math.imul(ah4, bh1)) | 0;\n lo = (lo + Math.imul(al3, bl2)) | 0;\n mid = (mid + Math.imul(al3, bh2)) | 0;\n mid = (mid + Math.imul(ah3, bl2)) | 0;\n hi = (hi + Math.imul(ah3, bh2)) | 0;\n lo = (lo + Math.imul(al2, bl3)) | 0;\n mid = (mid + Math.imul(al2, bh3)) | 0;\n mid = (mid + Math.imul(ah2, bl3)) | 0;\n hi = (hi + Math.imul(ah2, bh3)) | 0;\n lo = (lo + Math.imul(al1, bl4)) | 0;\n mid = (mid + Math.imul(al1, bh4)) | 0;\n mid = (mid + Math.imul(ah1, bl4)) | 0;\n hi = (hi + Math.imul(ah1, bh4)) | 0;\n lo = (lo + Math.imul(al0, bl5)) | 0;\n mid = (mid + Math.imul(al0, bh5)) | 0;\n mid = (mid + Math.imul(ah0, bl5)) | 0;\n hi = (hi + Math.imul(ah0, bh5)) | 0;\n var w5 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w5 >>> 26)) | 0;\n w5 &= 0x3ffffff;\n /* k = 6 */\n lo = Math.imul(al6, bl0);\n mid = Math.imul(al6, bh0);\n mid = (mid + Math.imul(ah6, bl0)) | 0;\n hi = Math.imul(ah6, bh0);\n lo = (lo + Math.imul(al5, bl1)) | 0;\n mid = (mid + Math.imul(al5, bh1)) | 0;\n mid = (mid + Math.imul(ah5, bl1)) | 0;\n hi = (hi + Math.imul(ah5, bh1)) | 0;\n lo = (lo + Math.imul(al4, bl2)) | 0;\n mid = (mid + Math.imul(al4, bh2)) | 0;\n mid = (mid + Math.imul(ah4, bl2)) | 0;\n hi = (hi + Math.imul(ah4, bh2)) | 0;\n lo = (lo + Math.imul(al3, bl3)) | 0;\n mid = (mid + Math.imul(al3, bh3)) | 0;\n mid = (mid + Math.imul(ah3, bl3)) | 0;\n hi = (hi + Math.imul(ah3, bh3)) | 0;\n lo = (lo + Math.imul(al2, bl4)) | 0;\n mid = (mid + Math.imul(al2, bh4)) | 0;\n mid = (mid + Math.imul(ah2, bl4)) | 0;\n hi = (hi + Math.imul(ah2, bh4)) | 0;\n lo = (lo + Math.imul(al1, bl5)) | 0;\n mid = (mid + Math.imul(al1, bh5)) | 0;\n mid = (mid + Math.imul(ah1, bl5)) | 0;\n hi = (hi + Math.imul(ah1, bh5)) | 0;\n lo = (lo + Math.imul(al0, bl6)) | 0;\n mid = (mid + Math.imul(al0, bh6)) | 0;\n mid = (mid + Math.imul(ah0, bl6)) | 0;\n hi = (hi + Math.imul(ah0, bh6)) | 0;\n var w6 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w6 >>> 26)) | 0;\n w6 &= 0x3ffffff;\n /* k = 7 */\n lo = Math.imul(al7, bl0);\n mid = Math.imul(al7, bh0);\n mid = (mid + Math.imul(ah7, bl0)) | 0;\n hi = Math.imul(ah7, bh0);\n lo = (lo + Math.imul(al6, bl1)) | 0;\n mid = (mid + Math.imul(al6, bh1)) | 0;\n mid = (mid + Math.imul(ah6, bl1)) | 0;\n hi = (hi + Math.imul(ah6, bh1)) | 0;\n lo = (lo + Math.imul(al5, bl2)) | 0;\n mid = (mid + Math.imul(al5, bh2)) | 0;\n mid = (mid + Math.imul(ah5, bl2)) | 0;\n hi = (hi + Math.imul(ah5, bh2)) | 0;\n lo = (lo + Math.imul(al4, bl3)) | 0;\n mid = (mid + Math.imul(al4, bh3)) | 0;\n mid = (mid + Math.imul(ah4, bl3)) | 0;\n hi = (hi + Math.imul(ah4, bh3)) | 0;\n lo = (lo + Math.imul(al3, bl4)) | 0;\n mid = (mid + Math.imul(al3, bh4)) | 0;\n mid = (mid + Math.imul(ah3, bl4)) | 0;\n hi = (hi + Math.imul(ah3, bh4)) | 0;\n lo = (lo + Math.imul(al2, bl5)) | 0;\n mid = (mid + Math.imul(al2, bh5)) | 0;\n mid = (mid + Math.imul(ah2, bl5)) | 0;\n hi = (hi + Math.imul(ah2, bh5)) | 0;\n lo = (lo + Math.imul(al1, bl6)) | 0;\n mid = (mid + Math.imul(al1, bh6)) | 0;\n mid = (mid + Math.imul(ah1, bl6)) | 0;\n hi = (hi + Math.imul(ah1, bh6)) | 0;\n lo = (lo + Math.imul(al0, bl7)) | 0;\n mid = (mid + Math.imul(al0, bh7)) | 0;\n mid = (mid + Math.imul(ah0, bl7)) | 0;\n hi = (hi + Math.imul(ah0, bh7)) | 0;\n var w7 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w7 >>> 26)) | 0;\n w7 &= 0x3ffffff;\n /* k = 8 */\n lo = Math.imul(al8, bl0);\n mid = Math.imul(al8, bh0);\n mid = (mid + Math.imul(ah8, bl0)) | 0;\n hi = Math.imul(ah8, bh0);\n lo = (lo + Math.imul(al7, bl1)) | 0;\n mid = (mid + Math.imul(al7, bh1)) | 0;\n mid = (mid + Math.imul(ah7, bl1)) | 0;\n hi = (hi + Math.imul(ah7, bh1)) | 0;\n lo = (lo + Math.imul(al6, bl2)) | 0;\n mid = (mid + Math.imul(al6, bh2)) | 0;\n mid = (mid + Math.imul(ah6, bl2)) | 0;\n hi = (hi + Math.imul(ah6, bh2)) | 0;\n lo = (lo + Math.imul(al5, bl3)) | 0;\n mid = (mid + Math.imul(al5, bh3)) | 0;\n mid = (mid + Math.imul(ah5, bl3)) | 0;\n hi = (hi + Math.imul(ah5, bh3)) | 0;\n lo = (lo + Math.imul(al4, bl4)) | 0;\n mid = (mid + Math.imul(al4, bh4)) | 0;\n mid = (mid + Math.imul(ah4, bl4)) | 0;\n hi = (hi + Math.imul(ah4, bh4)) | 0;\n lo = (lo + Math.imul(al3, bl5)) | 0;\n mid = (mid + Math.imul(al3, bh5)) | 0;\n mid = (mid + Math.imul(ah3, bl5)) | 0;\n hi = (hi + Math.imul(ah3, bh5)) | 0;\n lo = (lo + Math.imul(al2, bl6)) | 0;\n mid = (mid + Math.imul(al2, bh6)) | 0;\n mid = (mid + Math.imul(ah2, bl6)) | 0;\n hi = (hi + Math.imul(ah2, bh6)) | 0;\n lo = (lo + Math.imul(al1, bl7)) | 0;\n mid = (mid + Math.imul(al1, bh7)) | 0;\n mid = (mid + Math.imul(ah1, bl7)) | 0;\n hi = (hi + Math.imul(ah1, bh7)) | 0;\n lo = (lo + Math.imul(al0, bl8)) | 0;\n mid = (mid + Math.imul(al0, bh8)) | 0;\n mid = (mid + Math.imul(ah0, bl8)) | 0;\n hi = (hi + Math.imul(ah0, bh8)) | 0;\n var w8 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w8 >>> 26)) | 0;\n w8 &= 0x3ffffff;\n /* k = 9 */\n lo = Math.imul(al9, bl0);\n mid = Math.imul(al9, bh0);\n mid = (mid + Math.imul(ah9, bl0)) | 0;\n hi = Math.imul(ah9, bh0);\n lo = (lo + Math.imul(al8, bl1)) | 0;\n mid = (mid + Math.imul(al8, bh1)) | 0;\n mid = (mid + Math.imul(ah8, bl1)) | 0;\n hi = (hi + Math.imul(ah8, bh1)) | 0;\n lo = (lo + Math.imul(al7, bl2)) | 0;\n mid = (mid + Math.imul(al7, bh2)) | 0;\n mid = (mid + Math.imul(ah7, bl2)) | 0;\n hi = (hi + Math.imul(ah7, bh2)) | 0;\n lo = (lo + Math.imul(al6, bl3)) | 0;\n mid = (mid + Math.imul(al6, bh3)) | 0;\n mid = (mid + Math.imul(ah6, bl3)) | 0;\n hi = (hi + Math.imul(ah6, bh3)) | 0;\n lo = (lo + Math.imul(al5, bl4)) | 0;\n mid = (mid + Math.imul(al5, bh4)) | 0;\n mid = (mid + Math.imul(ah5, bl4)) | 0;\n hi = (hi + Math.imul(ah5, bh4)) | 0;\n lo = (lo + Math.imul(al4, bl5)) | 0;\n mid = (mid + Math.imul(al4, bh5)) | 0;\n mid = (mid + Math.imul(ah4, bl5)) | 0;\n hi = (hi + Math.imul(ah4, bh5)) | 0;\n lo = (lo + Math.imul(al3, bl6)) | 0;\n mid = (mid + Math.imul(al3, bh6)) | 0;\n mid = (mid + Math.imul(ah3, bl6)) | 0;\n hi = (hi + Math.imul(ah3, bh6)) | 0;\n lo = (lo + Math.imul(al2, bl7)) | 0;\n mid = (mid + Math.imul(al2, bh7)) | 0;\n mid = (mid + Math.imul(ah2, bl7)) | 0;\n hi = (hi + Math.imul(ah2, bh7)) | 0;\n lo = (lo + Math.imul(al1, bl8)) | 0;\n mid = (mid + Math.imul(al1, bh8)) | 0;\n mid = (mid + Math.imul(ah1, bl8)) | 0;\n hi = (hi + Math.imul(ah1, bh8)) | 0;\n lo = (lo + Math.imul(al0, bl9)) | 0;\n mid = (mid + Math.imul(al0, bh9)) | 0;\n mid = (mid + Math.imul(ah0, bl9)) | 0;\n hi = (hi + Math.imul(ah0, bh9)) | 0;\n var w9 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w9 >>> 26)) | 0;\n w9 &= 0x3ffffff;\n /* k = 10 */\n lo = Math.imul(al9, bl1);\n mid = Math.imul(al9, bh1);\n mid = (mid + Math.imul(ah9, bl1)) | 0;\n hi = Math.imul(ah9, bh1);\n lo = (lo + Math.imul(al8, bl2)) | 0;\n mid = (mid + Math.imul(al8, bh2)) | 0;\n mid = (mid + Math.imul(ah8, bl2)) | 0;\n hi = (hi + Math.imul(ah8, bh2)) | 0;\n lo = (lo + Math.imul(al7, bl3)) | 0;\n mid = (mid + Math.imul(al7, bh3)) | 0;\n mid = (mid + Math.imul(ah7, bl3)) | 0;\n hi = (hi + Math.imul(ah7, bh3)) | 0;\n lo = (lo + Math.imul(al6, bl4)) | 0;\n mid = (mid + Math.imul(al6, bh4)) | 0;\n mid = (mid + Math.imul(ah6, bl4)) | 0;\n hi = (hi + Math.imul(ah6, bh4)) | 0;\n lo = (lo + Math.imul(al5, bl5)) | 0;\n mid = (mid + Math.imul(al5, bh5)) | 0;\n mid = (mid + Math.imul(ah5, bl5)) | 0;\n hi = (hi + Math.imul(ah5, bh5)) | 0;\n lo = (lo + Math.imul(al4, bl6)) | 0;\n mid = (mid + Math.imul(al4, bh6)) | 0;\n mid = (mid + Math.imul(ah4, bl6)) | 0;\n hi = (hi + Math.imul(ah4, bh6)) | 0;\n lo = (lo + Math.imul(al3, bl7)) | 0;\n mid = (mid + Math.imul(al3, bh7)) | 0;\n mid = (mid + Math.imul(ah3, bl7)) | 0;\n hi = (hi + Math.imul(ah3, bh7)) | 0;\n lo = (lo + Math.imul(al2, bl8)) | 0;\n mid = (mid + Math.imul(al2, bh8)) | 0;\n mid = (mid + Math.imul(ah2, bl8)) | 0;\n hi = (hi + Math.imul(ah2, bh8)) | 0;\n lo = (lo + Math.imul(al1, bl9)) | 0;\n mid = (mid + Math.imul(al1, bh9)) | 0;\n mid = (mid + Math.imul(ah1, bl9)) | 0;\n hi = (hi + Math.imul(ah1, bh9)) | 0;\n var w10 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w10 >>> 26)) | 0;\n w10 &= 0x3ffffff;\n /* k = 11 */\n lo = Math.imul(al9, bl2);\n mid = Math.imul(al9, bh2);\n mid = (mid + Math.imul(ah9, bl2)) | 0;\n hi = Math.imul(ah9, bh2);\n lo = (lo + Math.imul(al8, bl3)) | 0;\n mid = (mid + Math.imul(al8, bh3)) | 0;\n mid = (mid + Math.imul(ah8, bl3)) | 0;\n hi = (hi + Math.imul(ah8, bh3)) | 0;\n lo = (lo + Math.imul(al7, bl4)) | 0;\n mid = (mid + Math.imul(al7, bh4)) | 0;\n mid = (mid + Math.imul(ah7, bl4)) | 0;\n hi = (hi + Math.imul(ah7, bh4)) | 0;\n lo = (lo + Math.imul(al6, bl5)) | 0;\n mid = (mid + Math.imul(al6, bh5)) | 0;\n mid = (mid + Math.imul(ah6, bl5)) | 0;\n hi = (hi + Math.imul(ah6, bh5)) | 0;\n lo = (lo + Math.imul(al5, bl6)) | 0;\n mid = (mid + Math.imul(al5, bh6)) | 0;\n mid = (mid + Math.imul(ah5, bl6)) | 0;\n hi = (hi + Math.imul(ah5, bh6)) | 0;\n lo = (lo + Math.imul(al4, bl7)) | 0;\n mid = (mid + Math.imul(al4, bh7)) | 0;\n mid = (mid + Math.imul(ah4, bl7)) | 0;\n hi = (hi + Math.imul(ah4, bh7)) | 0;\n lo = (lo + Math.imul(al3, bl8)) | 0;\n mid = (mid + Math.imul(al3, bh8)) | 0;\n mid = (mid + Math.imul(ah3, bl8)) | 0;\n hi = (hi + Math.imul(ah3, bh8)) | 0;\n lo = (lo + Math.imul(al2, bl9)) | 0;\n mid = (mid + Math.imul(al2, bh9)) | 0;\n mid = (mid + Math.imul(ah2, bl9)) | 0;\n hi = (hi + Math.imul(ah2, bh9)) | 0;\n var w11 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w11 >>> 26)) | 0;\n w11 &= 0x3ffffff;\n /* k = 12 */\n lo = Math.imul(al9, bl3);\n mid = Math.imul(al9, bh3);\n mid = (mid + Math.imul(ah9, bl3)) | 0;\n hi = Math.imul(ah9, bh3);\n lo = (lo + Math.imul(al8, bl4)) | 0;\n mid = (mid + Math.imul(al8, bh4)) | 0;\n mid = (mid + Math.imul(ah8, bl4)) | 0;\n hi = (hi + Math.imul(ah8, bh4)) | 0;\n lo = (lo + Math.imul(al7, bl5)) | 0;\n mid = (mid + Math.imul(al7, bh5)) | 0;\n mid = (mid + Math.imul(ah7, bl5)) | 0;\n hi = (hi + Math.imul(ah7, bh5)) | 0;\n lo = (lo + Math.imul(al6, bl6)) | 0;\n mid = (mid + Math.imul(al6, bh6)) | 0;\n mid = (mid + Math.imul(ah6, bl6)) | 0;\n hi = (hi + Math.imul(ah6, bh6)) | 0;\n lo = (lo + Math.imul(al5, bl7)) | 0;\n mid = (mid + Math.imul(al5, bh7)) | 0;\n mid = (mid + Math.imul(ah5, bl7)) | 0;\n hi = (hi + Math.imul(ah5, bh7)) | 0;\n lo = (lo + Math.imul(al4, bl8)) | 0;\n mid = (mid + Math.imul(al4, bh8)) | 0;\n mid = (mid + Math.imul(ah4, bl8)) | 0;\n hi = (hi + Math.imul(ah4, bh8)) | 0;\n lo = (lo + Math.imul(al3, bl9)) | 0;\n mid = (mid + Math.imul(al3, bh9)) | 0;\n mid = (mid + Math.imul(ah3, bl9)) | 0;\n hi = (hi + Math.imul(ah3, bh9)) | 0;\n var w12 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w12 >>> 26)) | 0;\n w12 &= 0x3ffffff;\n /* k = 13 */\n lo = Math.imul(al9, bl4);\n mid = Math.imul(al9, bh4);\n mid = (mid + Math.imul(ah9, bl4)) | 0;\n hi = Math.imul(ah9, bh4);\n lo = (lo + Math.imul(al8, bl5)) | 0;\n mid = (mid + Math.imul(al8, bh5)) | 0;\n mid = (mid + Math.imul(ah8, bl5)) | 0;\n hi = (hi + Math.imul(ah8, bh5)) | 0;\n lo = (lo + Math.imul(al7, bl6)) | 0;\n mid = (mid + Math.imul(al7, bh6)) | 0;\n mid = (mid + Math.imul(ah7, bl6)) | 0;\n hi = (hi + Math.imul(ah7, bh6)) | 0;\n lo = (lo + Math.imul(al6, bl7)) | 0;\n mid = (mid + Math.imul(al6, bh7)) | 0;\n mid = (mid + Math.imul(ah6, bl7)) | 0;\n hi = (hi + Math.imul(ah6, bh7)) | 0;\n lo = (lo + Math.imul(al5, bl8)) | 0;\n mid = (mid + Math.imul(al5, bh8)) | 0;\n mid = (mid + Math.imul(ah5, bl8)) | 0;\n hi = (hi + Math.imul(ah5, bh8)) | 0;\n lo = (lo + Math.imul(al4, bl9)) | 0;\n mid = (mid + Math.imul(al4, bh9)) | 0;\n mid = (mid + Math.imul(ah4, bl9)) | 0;\n hi = (hi + Math.imul(ah4, bh9)) | 0;\n var w13 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w13 >>> 26)) | 0;\n w13 &= 0x3ffffff;\n /* k = 14 */\n lo = Math.imul(al9, bl5);\n mid = Math.imul(al9, bh5);\n mid = (mid + Math.imul(ah9, bl5)) | 0;\n hi = Math.imul(ah9, bh5);\n lo = (lo + Math.imul(al8, bl6)) | 0;\n mid = (mid + Math.imul(al8, bh6)) | 0;\n mid = (mid + Math.imul(ah8, bl6)) | 0;\n hi = (hi + Math.imul(ah8, bh6)) | 0;\n lo = (lo + Math.imul(al7, bl7)) | 0;\n mid = (mid + Math.imul(al7, bh7)) | 0;\n mid = (mid + Math.imul(ah7, bl7)) | 0;\n hi = (hi + Math.imul(ah7, bh7)) | 0;\n lo = (lo + Math.imul(al6, bl8)) | 0;\n mid = (mid + Math.imul(al6, bh8)) | 0;\n mid = (mid + Math.imul(ah6, bl8)) | 0;\n hi = (hi + Math.imul(ah6, bh8)) | 0;\n lo = (lo + Math.imul(al5, bl9)) | 0;\n mid = (mid + Math.imul(al5, bh9)) | 0;\n mid = (mid + Math.imul(ah5, bl9)) | 0;\n hi = (hi + Math.imul(ah5, bh9)) | 0;\n var w14 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w14 >>> 26)) | 0;\n w14 &= 0x3ffffff;\n /* k = 15 */\n lo = Math.imul(al9, bl6);\n mid = Math.imul(al9, bh6);\n mid = (mid + Math.imul(ah9, bl6)) | 0;\n hi = Math.imul(ah9, bh6);\n lo = (lo + Math.imul(al8, bl7)) | 0;\n mid = (mid + Math.imul(al8, bh7)) | 0;\n mid = (mid + Math.imul(ah8, bl7)) | 0;\n hi = (hi + Math.imul(ah8, bh7)) | 0;\n lo = (lo + Math.imul(al7, bl8)) | 0;\n mid = (mid + Math.imul(al7, bh8)) | 0;\n mid = (mid + Math.imul(ah7, bl8)) | 0;\n hi = (hi + Math.imul(ah7, bh8)) | 0;\n lo = (lo + Math.imul(al6, bl9)) | 0;\n mid = (mid + Math.imul(al6, bh9)) | 0;\n mid = (mid + Math.imul(ah6, bl9)) | 0;\n hi = (hi + Math.imul(ah6, bh9)) | 0;\n var w15 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w15 >>> 26)) | 0;\n w15 &= 0x3ffffff;\n /* k = 16 */\n lo = Math.imul(al9, bl7);\n mid = Math.imul(al9, bh7);\n mid = (mid + Math.imul(ah9, bl7)) | 0;\n hi = Math.imul(ah9, bh7);\n lo = (lo + Math.imul(al8, bl8)) | 0;\n mid = (mid + Math.imul(al8, bh8)) | 0;\n mid = (mid + Math.imul(ah8, bl8)) | 0;\n hi = (hi + Math.imul(ah8, bh8)) | 0;\n lo = (lo + Math.imul(al7, bl9)) | 0;\n mid = (mid + Math.imul(al7, bh9)) | 0;\n mid = (mid + Math.imul(ah7, bl9)) | 0;\n hi = (hi + Math.imul(ah7, bh9)) | 0;\n var w16 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w16 >>> 26)) | 0;\n w16 &= 0x3ffffff;\n /* k = 17 */\n lo = Math.imul(al9, bl8);\n mid = Math.imul(al9, bh8);\n mid = (mid + Math.imul(ah9, bl8)) | 0;\n hi = Math.imul(ah9, bh8);\n lo = (lo + Math.imul(al8, bl9)) | 0;\n mid = (mid + Math.imul(al8, bh9)) | 0;\n mid = (mid + Math.imul(ah8, bl9)) | 0;\n hi = (hi + Math.imul(ah8, bh9)) | 0;\n var w17 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w17 >>> 26)) | 0;\n w17 &= 0x3ffffff;\n /* k = 18 */\n lo = Math.imul(al9, bl9);\n mid = Math.imul(al9, bh9);\n mid = (mid + Math.imul(ah9, bl9)) | 0;\n hi = Math.imul(ah9, bh9);\n var w18 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n c = (((hi + (mid >>> 13)) | 0) + (w18 >>> 26)) | 0;\n w18 &= 0x3ffffff;\n o[0] = w0;\n o[1] = w1;\n o[2] = w2;\n o[3] = w3;\n o[4] = w4;\n o[5] = w5;\n o[6] = w6;\n o[7] = w7;\n o[8] = w8;\n o[9] = w9;\n o[10] = w10;\n o[11] = w11;\n o[12] = w12;\n o[13] = w13;\n o[14] = w14;\n o[15] = w15;\n o[16] = w16;\n o[17] = w17;\n o[18] = w18;\n if (c !== 0) {\n o[19] = c;\n out.length++;\n }\n return out;\n };\n\n // Polyfill comb\n if (!Math.imul) {\n comb10MulTo = smallMulTo;\n }\n\n function bigMulTo (self, num, out) {\n out.negative = num.negative ^ self.negative;\n out.length = self.length + num.length;\n\n var carry = 0;\n var hncarry = 0;\n for (var k = 0; k < out.length - 1; k++) {\n // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n // note that ncarry could be >= 0x3ffffff\n var ncarry = hncarry;\n hncarry = 0;\n var rword = carry & 0x3ffffff;\n var maxJ = Math.min(k, num.length - 1);\n for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n var i = k - j;\n var a = self.words[i] | 0;\n var b = num.words[j] | 0;\n var r = a * b;\n\n var lo = r & 0x3ffffff;\n ncarry = (ncarry + ((r / 0x4000000) | 0)) | 0;\n lo = (lo + rword) | 0;\n rword = lo & 0x3ffffff;\n ncarry = (ncarry + (lo >>> 26)) | 0;\n\n hncarry += ncarry >>> 26;\n ncarry &= 0x3ffffff;\n }\n out.words[k] = rword;\n carry = ncarry;\n ncarry = hncarry;\n }\n if (carry !== 0) {\n out.words[k] = carry;\n } else {\n out.length--;\n }\n\n return out._strip();\n }\n\n function jumboMulTo (self, num, out) {\n // Temporary disable, see https://github.com/indutny/bn.js/issues/211\n // var fftm = new FFTM();\n // return fftm.mulp(self, num, out);\n return bigMulTo(self, num, out);\n }\n\n BN.prototype.mulTo = function mulTo (num, out) {\n var res;\n var len = this.length + num.length;\n if (this.length === 10 && num.length === 10) {\n res = comb10MulTo(this, num, out);\n } else if (len < 63) {\n res = smallMulTo(this, num, out);\n } else if (len < 1024) {\n res = bigMulTo(this, num, out);\n } else {\n res = jumboMulTo(this, num, out);\n }\n\n return res;\n };\n\n // Cooley-Tukey algorithm for FFT\n // slightly revisited to rely on looping instead of recursion\n\n function FFTM (x, y) {\n this.x = x;\n this.y = y;\n }\n\n FFTM.prototype.makeRBT = function makeRBT (N) {\n var t = new Array(N);\n var l = BN.prototype._countBits(N) - 1;\n for (var i = 0; i < N; i++) {\n t[i] = this.revBin(i, l, N);\n }\n\n return t;\n };\n\n // Returns binary-reversed representation of `x`\n FFTM.prototype.revBin = function revBin (x, l, N) {\n if (x === 0 || x === N - 1) return x;\n\n var rb = 0;\n for (var i = 0; i < l; i++) {\n rb |= (x & 1) << (l - i - 1);\n x >>= 1;\n }\n\n return rb;\n };\n\n // Performs \"tweedling\" phase, therefore 'emulating'\n // behaviour of the recursive algorithm\n FFTM.prototype.permute = function permute (rbt, rws, iws, rtws, itws, N) {\n for (var i = 0; i < N; i++) {\n rtws[i] = rws[rbt[i]];\n itws[i] = iws[rbt[i]];\n }\n };\n\n FFTM.prototype.transform = function transform (rws, iws, rtws, itws, N, rbt) {\n this.permute(rbt, rws, iws, rtws, itws, N);\n\n for (var s = 1; s < N; s <<= 1) {\n var l = s << 1;\n\n var rtwdf = Math.cos(2 * Math.PI / l);\n var itwdf = Math.sin(2 * Math.PI / l);\n\n for (var p = 0; p < N; p += l) {\n var rtwdf_ = rtwdf;\n var itwdf_ = itwdf;\n\n for (var j = 0; j < s; j++) {\n var re = rtws[p + j];\n var ie = itws[p + j];\n\n var ro = rtws[p + j + s];\n var io = itws[p + j + s];\n\n var rx = rtwdf_ * ro - itwdf_ * io;\n\n io = rtwdf_ * io + itwdf_ * ro;\n ro = rx;\n\n rtws[p + j] = re + ro;\n itws[p + j] = ie + io;\n\n rtws[p + j + s] = re - ro;\n itws[p + j + s] = ie - io;\n\n /* jshint maxdepth : false */\n if (j !== l) {\n rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n\n itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n rtwdf_ = rx;\n }\n }\n }\n }\n };\n\n FFTM.prototype.guessLen13b = function guessLen13b (n, m) {\n var N = Math.max(m, n) | 1;\n var odd = N & 1;\n var i = 0;\n for (N = N / 2 | 0; N; N = N >>> 1) {\n i++;\n }\n\n return 1 << i + 1 + odd;\n };\n\n FFTM.prototype.conjugate = function conjugate (rws, iws, N) {\n if (N <= 1) return;\n\n for (var i = 0; i < N / 2; i++) {\n var t = rws[i];\n\n rws[i] = rws[N - i - 1];\n rws[N - i - 1] = t;\n\n t = iws[i];\n\n iws[i] = -iws[N - i - 1];\n iws[N - i - 1] = -t;\n }\n };\n\n FFTM.prototype.normalize13b = function normalize13b (ws, N) {\n var carry = 0;\n for (var i = 0; i < N / 2; i++) {\n var w = Math.round(ws[2 * i + 1] / N) * 0x2000 +\n Math.round(ws[2 * i] / N) +\n carry;\n\n ws[i] = w & 0x3ffffff;\n\n if (w < 0x4000000) {\n carry = 0;\n } else {\n carry = w / 0x4000000 | 0;\n }\n }\n\n return ws;\n };\n\n FFTM.prototype.convert13b = function convert13b (ws, len, rws, N) {\n var carry = 0;\n for (var i = 0; i < len; i++) {\n carry = carry + (ws[i] | 0);\n\n rws[2 * i] = carry & 0x1fff; carry = carry >>> 13;\n rws[2 * i + 1] = carry & 0x1fff; carry = carry >>> 13;\n }\n\n // Pad with zeroes\n for (i = 2 * len; i < N; ++i) {\n rws[i] = 0;\n }\n\n assert(carry === 0);\n assert((carry & ~0x1fff) === 0);\n };\n\n FFTM.prototype.stub = function stub (N) {\n var ph = new Array(N);\n for (var i = 0; i < N; i++) {\n ph[i] = 0;\n }\n\n return ph;\n };\n\n FFTM.prototype.mulp = function mulp (x, y, out) {\n var N = 2 * this.guessLen13b(x.length, y.length);\n\n var rbt = this.makeRBT(N);\n\n var _ = this.stub(N);\n\n var rws = new Array(N);\n var rwst = new Array(N);\n var iwst = new Array(N);\n\n var nrws = new Array(N);\n var nrwst = new Array(N);\n var niwst = new Array(N);\n\n var rmws = out.words;\n rmws.length = N;\n\n this.convert13b(x.words, x.length, rws, N);\n this.convert13b(y.words, y.length, nrws, N);\n\n this.transform(rws, _, rwst, iwst, N, rbt);\n this.transform(nrws, _, nrwst, niwst, N, rbt);\n\n for (var i = 0; i < N; i++) {\n var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n rwst[i] = rx;\n }\n\n this.conjugate(rwst, iwst, N);\n this.transform(rwst, iwst, rmws, _, N, rbt);\n this.conjugate(rmws, _, N);\n this.normalize13b(rmws, N);\n\n out.negative = x.negative ^ y.negative;\n out.length = x.length + y.length;\n return out._strip();\n };\n\n // Multiply `this` by `num`\n BN.prototype.mul = function mul (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return this.mulTo(num, out);\n };\n\n // Multiply employing FFT\n BN.prototype.mulf = function mulf (num) {\n var out = new BN(null);\n out.words = new Array(this.length + num.length);\n return jumboMulTo(this, num, out);\n };\n\n // In-place Multiplication\n BN.prototype.imul = function imul (num) {\n return this.clone().mulTo(num, this);\n };\n\n BN.prototype.imuln = function imuln (num) {\n var isNegNum = num < 0;\n if (isNegNum) num = -num;\n\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n\n // Carry\n var carry = 0;\n for (var i = 0; i < this.length; i++) {\n var w = (this.words[i] | 0) * num;\n var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n carry >>= 26;\n carry += (w / 0x4000000) | 0;\n // NOTE: lo is 27bit maximum\n carry += lo >>> 26;\n this.words[i] = lo & 0x3ffffff;\n }\n\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n this.length = num === 0 ? 1 : this.length;\n\n return isNegNum ? this.ineg() : this;\n };\n\n BN.prototype.muln = function muln (num) {\n return this.clone().imuln(num);\n };\n\n // `this` * `this`\n BN.prototype.sqr = function sqr () {\n return this.mul(this);\n };\n\n // `this` * `this` in-place\n BN.prototype.isqr = function isqr () {\n return this.imul(this.clone());\n };\n\n // Math.pow(`this`, `num`)\n BN.prototype.pow = function pow (num) {\n var w = toBitArray(num);\n if (w.length === 0) return new BN(1);\n\n // Skip leading zeroes\n var res = this;\n for (var i = 0; i < w.length; i++, res = res.sqr()) {\n if (w[i] !== 0) break;\n }\n\n if (++i < w.length) {\n for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n if (w[i] === 0) continue;\n\n res = res.mul(q);\n }\n }\n\n return res;\n };\n\n // Shift-left in-place\n BN.prototype.iushln = function iushln (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n var carryMask = (0x3ffffff >>> (26 - r)) << (26 - r);\n var i;\n\n if (r !== 0) {\n var carry = 0;\n\n for (i = 0; i < this.length; i++) {\n var newCarry = this.words[i] & carryMask;\n var c = ((this.words[i] | 0) - newCarry) << r;\n this.words[i] = c | carry;\n carry = newCarry >>> (26 - r);\n }\n\n if (carry) {\n this.words[i] = carry;\n this.length++;\n }\n }\n\n if (s !== 0) {\n for (i = this.length - 1; i >= 0; i--) {\n this.words[i + s] = this.words[i];\n }\n\n for (i = 0; i < s; i++) {\n this.words[i] = 0;\n }\n\n this.length += s;\n }\n\n return this._strip();\n };\n\n BN.prototype.ishln = function ishln (bits) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushln(bits);\n };\n\n // Shift-right in-place\n // NOTE: `hint` is a lowest bit before trailing zeroes\n // NOTE: if `extended` is present - it will be filled with destroyed bits\n BN.prototype.iushrn = function iushrn (bits, hint, extended) {\n assert(typeof bits === 'number' && bits >= 0);\n var h;\n if (hint) {\n h = (hint - (hint % 26)) / 26;\n } else {\n h = 0;\n }\n\n var r = bits % 26;\n var s = Math.min((bits - r) / 26, this.length);\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n var maskedWords = extended;\n\n h -= s;\n h = Math.max(0, h);\n\n // Extended mode, copy masked part\n if (maskedWords) {\n for (var i = 0; i < s; i++) {\n maskedWords.words[i] = this.words[i];\n }\n maskedWords.length = s;\n }\n\n if (s === 0) {\n // No-op, we should not move anything at all\n } else if (this.length > s) {\n this.length -= s;\n for (i = 0; i < this.length; i++) {\n this.words[i] = this.words[i + s];\n }\n } else {\n this.words[0] = 0;\n this.length = 1;\n }\n\n var carry = 0;\n for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n var word = this.words[i] | 0;\n this.words[i] = (carry << (26 - r)) | (word >>> r);\n carry = word & mask;\n }\n\n // Push carried bits as a mask\n if (maskedWords && carry !== 0) {\n maskedWords.words[maskedWords.length++] = carry;\n }\n\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n\n return this._strip();\n };\n\n BN.prototype.ishrn = function ishrn (bits, hint, extended) {\n // TODO(indutny): implement me\n assert(this.negative === 0);\n return this.iushrn(bits, hint, extended);\n };\n\n // Shift-left\n BN.prototype.shln = function shln (bits) {\n return this.clone().ishln(bits);\n };\n\n BN.prototype.ushln = function ushln (bits) {\n return this.clone().iushln(bits);\n };\n\n // Shift-right\n BN.prototype.shrn = function shrn (bits) {\n return this.clone().ishrn(bits);\n };\n\n BN.prototype.ushrn = function ushrn (bits) {\n return this.clone().iushrn(bits);\n };\n\n // Test if n bit is set\n BN.prototype.testn = function testn (bit) {\n assert(typeof bit === 'number' && bit >= 0);\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) return false;\n\n // Check bit and return\n var w = this.words[s];\n\n return !!(w & q);\n };\n\n // Return only lowers bits of number (in-place)\n BN.prototype.imaskn = function imaskn (bits) {\n assert(typeof bits === 'number' && bits >= 0);\n var r = bits % 26;\n var s = (bits - r) / 26;\n\n assert(this.negative === 0, 'imaskn works only with positive numbers');\n\n if (this.length <= s) {\n return this;\n }\n\n if (r !== 0) {\n s++;\n }\n this.length = Math.min(s, this.length);\n\n if (r !== 0) {\n var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n this.words[this.length - 1] &= mask;\n }\n\n if (this.length === 0) {\n this.words[0] = 0;\n this.length = 1;\n }\n\n return this._strip();\n };\n\n // Return only lowers bits of number\n BN.prototype.maskn = function maskn (bits) {\n return this.clone().imaskn(bits);\n };\n\n // Add plain number `num` to `this`\n BN.prototype.iaddn = function iaddn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.isubn(-num);\n\n // Possible sign change\n if (this.negative !== 0) {\n if (this.length === 1 && (this.words[0] | 0) <= num) {\n this.words[0] = num - (this.words[0] | 0);\n this.negative = 0;\n return this;\n }\n\n this.negative = 0;\n this.isubn(num);\n this.negative = 1;\n return this;\n }\n\n // Add without checks\n return this._iaddn(num);\n };\n\n BN.prototype._iaddn = function _iaddn (num) {\n this.words[0] += num;\n\n // Carry\n for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n this.words[i] -= 0x4000000;\n if (i === this.length - 1) {\n this.words[i + 1] = 1;\n } else {\n this.words[i + 1]++;\n }\n }\n this.length = Math.max(this.length, i + 1);\n\n return this;\n };\n\n // Subtract plain number `num` from `this`\n BN.prototype.isubn = function isubn (num) {\n assert(typeof num === 'number');\n assert(num < 0x4000000);\n if (num < 0) return this.iaddn(-num);\n\n if (this.negative !== 0) {\n this.negative = 0;\n this.iaddn(num);\n this.negative = 1;\n return this;\n }\n\n this.words[0] -= num;\n\n if (this.length === 1 && this.words[0] < 0) {\n this.words[0] = -this.words[0];\n this.negative = 1;\n } else {\n // Carry\n for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n this.words[i] += 0x4000000;\n this.words[i + 1] -= 1;\n }\n }\n\n return this._strip();\n };\n\n BN.prototype.addn = function addn (num) {\n return this.clone().iaddn(num);\n };\n\n BN.prototype.subn = function subn (num) {\n return this.clone().isubn(num);\n };\n\n BN.prototype.iabs = function iabs () {\n this.negative = 0;\n\n return this;\n };\n\n BN.prototype.abs = function abs () {\n return this.clone().iabs();\n };\n\n BN.prototype._ishlnsubmul = function _ishlnsubmul (num, mul, shift) {\n var len = num.length + shift;\n var i;\n\n this._expand(len);\n\n var w;\n var carry = 0;\n for (i = 0; i < num.length; i++) {\n w = (this.words[i + shift] | 0) + carry;\n var right = (num.words[i] | 0) * mul;\n w -= right & 0x3ffffff;\n carry = (w >> 26) - ((right / 0x4000000) | 0);\n this.words[i + shift] = w & 0x3ffffff;\n }\n for (; i < this.length - shift; i++) {\n w = (this.words[i + shift] | 0) + carry;\n carry = w >> 26;\n this.words[i + shift] = w & 0x3ffffff;\n }\n\n if (carry === 0) return this._strip();\n\n // Subtraction overflow\n assert(carry === -1);\n carry = 0;\n for (i = 0; i < this.length; i++) {\n w = -(this.words[i] | 0) + carry;\n carry = w >> 26;\n this.words[i] = w & 0x3ffffff;\n }\n this.negative = 1;\n\n return this._strip();\n };\n\n BN.prototype._wordDiv = function _wordDiv (num, mode) {\n var shift = this.length - num.length;\n\n var a = this.clone();\n var b = num;\n\n // Normalize\n var bhi = b.words[b.length - 1] | 0;\n var bhiBits = this._countBits(bhi);\n shift = 26 - bhiBits;\n if (shift !== 0) {\n b = b.ushln(shift);\n a.iushln(shift);\n bhi = b.words[b.length - 1] | 0;\n }\n\n // Initialize quotient\n var m = a.length - b.length;\n var q;\n\n if (mode !== 'mod') {\n q = new BN(null);\n q.length = m + 1;\n q.words = new Array(q.length);\n for (var i = 0; i < q.length; i++) {\n q.words[i] = 0;\n }\n }\n\n var diff = a.clone()._ishlnsubmul(b, 1, m);\n if (diff.negative === 0) {\n a = diff;\n if (q) {\n q.words[m] = 1;\n }\n }\n\n for (var j = m - 1; j >= 0; j--) {\n var qj = (a.words[b.length + j] | 0) * 0x4000000 +\n (a.words[b.length + j - 1] | 0);\n\n // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n // (0x7ffffff)\n qj = Math.min((qj / bhi) | 0, 0x3ffffff);\n\n a._ishlnsubmul(b, qj, j);\n while (a.negative !== 0) {\n qj--;\n a.negative = 0;\n a._ishlnsubmul(b, 1, j);\n if (!a.isZero()) {\n a.negative ^= 1;\n }\n }\n if (q) {\n q.words[j] = qj;\n }\n }\n if (q) {\n q._strip();\n }\n a._strip();\n\n // Denormalize\n if (mode !== 'div' && shift !== 0) {\n a.iushrn(shift);\n }\n\n return {\n div: q || null,\n mod: a\n };\n };\n\n // NOTE: 1) `mode` can be set to `mod` to request mod only,\n // to `div` to request div only, or be absent to\n // request both div & mod\n // 2) `positive` is true if unsigned mod is requested\n BN.prototype.divmod = function divmod (num, mode, positive) {\n assert(!num.isZero());\n\n if (this.isZero()) {\n return {\n div: new BN(0),\n mod: new BN(0)\n };\n }\n\n var div, mod, res;\n if (this.negative !== 0 && num.negative === 0) {\n res = this.neg().divmod(num, mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.iadd(num);\n }\n }\n\n return {\n div: div,\n mod: mod\n };\n }\n\n if (this.negative === 0 && num.negative !== 0) {\n res = this.divmod(num.neg(), mode);\n\n if (mode !== 'mod') {\n div = res.div.neg();\n }\n\n return {\n div: div,\n mod: res.mod\n };\n }\n\n if ((this.negative & num.negative) !== 0) {\n res = this.neg().divmod(num.neg(), mode);\n\n if (mode !== 'div') {\n mod = res.mod.neg();\n if (positive && mod.negative !== 0) {\n mod.isub(num);\n }\n }\n\n return {\n div: res.div,\n mod: mod\n };\n }\n\n // Both numbers are positive at this point\n\n // Strip both numbers to approximate shift value\n if (num.length > this.length || this.cmp(num) < 0) {\n return {\n div: new BN(0),\n mod: this\n };\n }\n\n // Very short reduction\n if (num.length === 1) {\n if (mode === 'div') {\n return {\n div: this.divn(num.words[0]),\n mod: null\n };\n }\n\n if (mode === 'mod') {\n return {\n div: null,\n mod: new BN(this.modrn(num.words[0]))\n };\n }\n\n return {\n div: this.divn(num.words[0]),\n mod: new BN(this.modrn(num.words[0]))\n };\n }\n\n return this._wordDiv(num, mode);\n };\n\n // Find `this` / `num`\n BN.prototype.div = function div (num) {\n return this.divmod(num, 'div', false).div;\n };\n\n // Find `this` % `num`\n BN.prototype.mod = function mod (num) {\n return this.divmod(num, 'mod', false).mod;\n };\n\n BN.prototype.umod = function umod (num) {\n return this.divmod(num, 'mod', true).mod;\n };\n\n // Find Round(`this` / `num`)\n BN.prototype.divRound = function divRound (num) {\n var dm = this.divmod(num);\n\n // Fast case - exact division\n if (dm.mod.isZero()) return dm.div;\n\n var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n\n var half = num.ushrn(1);\n var r2 = num.andln(1);\n var cmp = mod.cmp(half);\n\n // Round down\n if (cmp < 0 || (r2 === 1 && cmp === 0)) return dm.div;\n\n // Round up\n return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n };\n\n BN.prototype.modrn = function modrn (num) {\n var isNegNum = num < 0;\n if (isNegNum) num = -num;\n\n assert(num <= 0x3ffffff);\n var p = (1 << 26) % num;\n\n var acc = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n acc = (p * acc + (this.words[i] | 0)) % num;\n }\n\n return isNegNum ? -acc : acc;\n };\n\n // WARNING: DEPRECATED\n BN.prototype.modn = function modn (num) {\n return this.modrn(num);\n };\n\n // In-place division by number\n BN.prototype.idivn = function idivn (num) {\n var isNegNum = num < 0;\n if (isNegNum) num = -num;\n\n assert(num <= 0x3ffffff);\n\n var carry = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var w = (this.words[i] | 0) + carry * 0x4000000;\n this.words[i] = (w / num) | 0;\n carry = w % num;\n }\n\n this._strip();\n return isNegNum ? this.ineg() : this;\n };\n\n BN.prototype.divn = function divn (num) {\n return this.clone().idivn(num);\n };\n\n BN.prototype.egcd = function egcd (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var x = this;\n var y = p.clone();\n\n if (x.negative !== 0) {\n x = x.umod(p);\n } else {\n x = x.clone();\n }\n\n // A * x + B * y = x\n var A = new BN(1);\n var B = new BN(0);\n\n // C * x + D * y = y\n var C = new BN(0);\n var D = new BN(1);\n\n var g = 0;\n\n while (x.isEven() && y.isEven()) {\n x.iushrn(1);\n y.iushrn(1);\n ++g;\n }\n\n var yp = y.clone();\n var xp = x.clone();\n\n while (!x.isZero()) {\n for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n x.iushrn(i);\n while (i-- > 0) {\n if (A.isOdd() || B.isOdd()) {\n A.iadd(yp);\n B.isub(xp);\n }\n\n A.iushrn(1);\n B.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n y.iushrn(j);\n while (j-- > 0) {\n if (C.isOdd() || D.isOdd()) {\n C.iadd(yp);\n D.isub(xp);\n }\n\n C.iushrn(1);\n D.iushrn(1);\n }\n }\n\n if (x.cmp(y) >= 0) {\n x.isub(y);\n A.isub(C);\n B.isub(D);\n } else {\n y.isub(x);\n C.isub(A);\n D.isub(B);\n }\n }\n\n return {\n a: C,\n b: D,\n gcd: y.iushln(g)\n };\n };\n\n // This is reduced incarnation of the binary EEA\n // above, designated to invert members of the\n // _prime_ fields F(p) at a maximal speed\n BN.prototype._invmp = function _invmp (p) {\n assert(p.negative === 0);\n assert(!p.isZero());\n\n var a = this;\n var b = p.clone();\n\n if (a.negative !== 0) {\n a = a.umod(p);\n } else {\n a = a.clone();\n }\n\n var x1 = new BN(1);\n var x2 = new BN(0);\n\n var delta = b.clone();\n\n while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n if (i > 0) {\n a.iushrn(i);\n while (i-- > 0) {\n if (x1.isOdd()) {\n x1.iadd(delta);\n }\n\n x1.iushrn(1);\n }\n }\n\n for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n if (j > 0) {\n b.iushrn(j);\n while (j-- > 0) {\n if (x2.isOdd()) {\n x2.iadd(delta);\n }\n\n x2.iushrn(1);\n }\n }\n\n if (a.cmp(b) >= 0) {\n a.isub(b);\n x1.isub(x2);\n } else {\n b.isub(a);\n x2.isub(x1);\n }\n }\n\n var res;\n if (a.cmpn(1) === 0) {\n res = x1;\n } else {\n res = x2;\n }\n\n if (res.cmpn(0) < 0) {\n res.iadd(p);\n }\n\n return res;\n };\n\n BN.prototype.gcd = function gcd (num) {\n if (this.isZero()) return num.abs();\n if (num.isZero()) return this.abs();\n\n var a = this.clone();\n var b = num.clone();\n a.negative = 0;\n b.negative = 0;\n\n // Remove common factor of two\n for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n a.iushrn(1);\n b.iushrn(1);\n }\n\n do {\n while (a.isEven()) {\n a.iushrn(1);\n }\n while (b.isEven()) {\n b.iushrn(1);\n }\n\n var r = a.cmp(b);\n if (r < 0) {\n // Swap `a` and `b` to make `a` always bigger than `b`\n var t = a;\n a = b;\n b = t;\n } else if (r === 0 || b.cmpn(1) === 0) {\n break;\n }\n\n a.isub(b);\n } while (true);\n\n return b.iushln(shift);\n };\n\n // Invert number in the field F(num)\n BN.prototype.invm = function invm (num) {\n return this.egcd(num).a.umod(num);\n };\n\n BN.prototype.isEven = function isEven () {\n return (this.words[0] & 1) === 0;\n };\n\n BN.prototype.isOdd = function isOdd () {\n return (this.words[0] & 1) === 1;\n };\n\n // And first word and num\n BN.prototype.andln = function andln (num) {\n return this.words[0] & num;\n };\n\n // Increment at the bit position in-line\n BN.prototype.bincn = function bincn (bit) {\n assert(typeof bit === 'number');\n var r = bit % 26;\n var s = (bit - r) / 26;\n var q = 1 << r;\n\n // Fast case: bit is much higher than all existing words\n if (this.length <= s) {\n this._expand(s + 1);\n this.words[s] |= q;\n return this;\n }\n\n // Add bit and propagate, if needed\n var carry = q;\n for (var i = s; carry !== 0 && i < this.length; i++) {\n var w = this.words[i] | 0;\n w += carry;\n carry = w >>> 26;\n w &= 0x3ffffff;\n this.words[i] = w;\n }\n if (carry !== 0) {\n this.words[i] = carry;\n this.length++;\n }\n return this;\n };\n\n BN.prototype.isZero = function isZero () {\n return this.length === 1 && this.words[0] === 0;\n };\n\n BN.prototype.cmpn = function cmpn (num) {\n var negative = num < 0;\n\n if (this.negative !== 0 && !negative) return -1;\n if (this.negative === 0 && negative) return 1;\n\n this._strip();\n\n var res;\n if (this.length > 1) {\n res = 1;\n } else {\n if (negative) {\n num = -num;\n }\n\n assert(num <= 0x3ffffff, 'Number is too big');\n\n var w = this.words[0] | 0;\n res = w === num ? 0 : w < num ? -1 : 1;\n }\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Compare two numbers and return:\n // 1 - if `this` > `num`\n // 0 - if `this` == `num`\n // -1 - if `this` < `num`\n BN.prototype.cmp = function cmp (num) {\n if (this.negative !== 0 && num.negative === 0) return -1;\n if (this.negative === 0 && num.negative !== 0) return 1;\n\n var res = this.ucmp(num);\n if (this.negative !== 0) return -res | 0;\n return res;\n };\n\n // Unsigned comparison\n BN.prototype.ucmp = function ucmp (num) {\n // At this point both numbers have the same sign\n if (this.length > num.length) return 1;\n if (this.length < num.length) return -1;\n\n var res = 0;\n for (var i = this.length - 1; i >= 0; i--) {\n var a = this.words[i] | 0;\n var b = num.words[i] | 0;\n\n if (a === b) continue;\n if (a < b) {\n res = -1;\n } else if (a > b) {\n res = 1;\n }\n break;\n }\n return res;\n };\n\n BN.prototype.gtn = function gtn (num) {\n return this.cmpn(num) === 1;\n };\n\n BN.prototype.gt = function gt (num) {\n return this.cmp(num) === 1;\n };\n\n BN.prototype.gten = function gten (num) {\n return this.cmpn(num) >= 0;\n };\n\n BN.prototype.gte = function gte (num) {\n return this.cmp(num) >= 0;\n };\n\n BN.prototype.ltn = function ltn (num) {\n return this.cmpn(num) === -1;\n };\n\n BN.prototype.lt = function lt (num) {\n return this.cmp(num) === -1;\n };\n\n BN.prototype.lten = function lten (num) {\n return this.cmpn(num) <= 0;\n };\n\n BN.prototype.lte = function lte (num) {\n return this.cmp(num) <= 0;\n };\n\n BN.prototype.eqn = function eqn (num) {\n return this.cmpn(num) === 0;\n };\n\n BN.prototype.eq = function eq (num) {\n return this.cmp(num) === 0;\n };\n\n //\n // A reduce context, could be using montgomery or something better, depending\n // on the `m` itself.\n //\n BN.red = function red (num) {\n return new Red(num);\n };\n\n BN.prototype.toRed = function toRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n assert(this.negative === 0, 'red works only with positives');\n return ctx.convertTo(this)._forceRed(ctx);\n };\n\n BN.prototype.fromRed = function fromRed () {\n assert(this.red, 'fromRed works only with numbers in reduction context');\n return this.red.convertFrom(this);\n };\n\n BN.prototype._forceRed = function _forceRed (ctx) {\n this.red = ctx;\n return this;\n };\n\n BN.prototype.forceRed = function forceRed (ctx) {\n assert(!this.red, 'Already a number in reduction context');\n return this._forceRed(ctx);\n };\n\n BN.prototype.redAdd = function redAdd (num) {\n assert(this.red, 'redAdd works only with red numbers');\n return this.red.add(this, num);\n };\n\n BN.prototype.redIAdd = function redIAdd (num) {\n assert(this.red, 'redIAdd works only with red numbers');\n return this.red.iadd(this, num);\n };\n\n BN.prototype.redSub = function redSub (num) {\n assert(this.red, 'redSub works only with red numbers');\n return this.red.sub(this, num);\n };\n\n BN.prototype.redISub = function redISub (num) {\n assert(this.red, 'redISub works only with red numbers');\n return this.red.isub(this, num);\n };\n\n BN.prototype.redShl = function redShl (num) {\n assert(this.red, 'redShl works only with red numbers');\n return this.red.shl(this, num);\n };\n\n BN.prototype.redMul = function redMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.mul(this, num);\n };\n\n BN.prototype.redIMul = function redIMul (num) {\n assert(this.red, 'redMul works only with red numbers');\n this.red._verify2(this, num);\n return this.red.imul(this, num);\n };\n\n BN.prototype.redSqr = function redSqr () {\n assert(this.red, 'redSqr works only with red numbers');\n this.red._verify1(this);\n return this.red.sqr(this);\n };\n\n BN.prototype.redISqr = function redISqr () {\n assert(this.red, 'redISqr works only with red numbers');\n this.red._verify1(this);\n return this.red.isqr(this);\n };\n\n // Square root over p\n BN.prototype.redSqrt = function redSqrt () {\n assert(this.red, 'redSqrt works only with red numbers');\n this.red._verify1(this);\n return this.red.sqrt(this);\n };\n\n BN.prototype.redInvm = function redInvm () {\n assert(this.red, 'redInvm works only with red numbers');\n this.red._verify1(this);\n return this.red.invm(this);\n };\n\n // Return negative clone of `this` % `red modulo`\n BN.prototype.redNeg = function redNeg () {\n assert(this.red, 'redNeg works only with red numbers');\n this.red._verify1(this);\n return this.red.neg(this);\n };\n\n BN.prototype.redPow = function redPow (num) {\n assert(this.red && !num.red, 'redPow(normalNum)');\n this.red._verify1(this);\n return this.red.pow(this, num);\n };\n\n // Prime numbers with efficient reduction\n var primes = {\n k256: null,\n p224: null,\n p192: null,\n p25519: null\n };\n\n // Pseudo-Mersenne prime\n function MPrime (name, p) {\n // P = 2 ^ N - K\n this.name = name;\n this.p = new BN(p, 16);\n this.n = this.p.bitLength();\n this.k = new BN(1).iushln(this.n).isub(this.p);\n\n this.tmp = this._tmp();\n }\n\n MPrime.prototype._tmp = function _tmp () {\n var tmp = new BN(null);\n tmp.words = new Array(Math.ceil(this.n / 13));\n return tmp;\n };\n\n MPrime.prototype.ireduce = function ireduce (num) {\n // Assumes that `num` is less than `P^2`\n // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n var r = num;\n var rlen;\n\n do {\n this.split(r, this.tmp);\n r = this.imulK(r);\n r = r.iadd(this.tmp);\n rlen = r.bitLength();\n } while (rlen > this.n);\n\n var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n if (cmp === 0) {\n r.words[0] = 0;\n r.length = 1;\n } else if (cmp > 0) {\n r.isub(this.p);\n } else {\n if (r.strip !== undefined) {\n // r is a BN v4 instance\n r.strip();\n } else {\n // r is a BN v5 instance\n r._strip();\n }\n }\n\n return r;\n };\n\n MPrime.prototype.split = function split (input, out) {\n input.iushrn(this.n, 0, out);\n };\n\n MPrime.prototype.imulK = function imulK (num) {\n return num.imul(this.k);\n };\n\n function K256 () {\n MPrime.call(\n this,\n 'k256',\n 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n }\n inherits(K256, MPrime);\n\n K256.prototype.split = function split (input, output) {\n // 256 = 9 * 26 + 22\n var mask = 0x3fffff;\n\n var outLen = Math.min(input.length, 9);\n for (var i = 0; i < outLen; i++) {\n output.words[i] = input.words[i];\n }\n output.length = outLen;\n\n if (input.length <= 9) {\n input.words[0] = 0;\n input.length = 1;\n return;\n }\n\n // Shift by 9 limbs\n var prev = input.words[9];\n output.words[output.length++] = prev & mask;\n\n for (i = 10; i < input.length; i++) {\n var next = input.words[i] | 0;\n input.words[i - 10] = ((next & mask) << 4) | (prev >>> 22);\n prev = next;\n }\n prev >>>= 22;\n input.words[i - 10] = prev;\n if (prev === 0 && input.length > 10) {\n input.length -= 10;\n } else {\n input.length -= 9;\n }\n };\n\n K256.prototype.imulK = function imulK (num) {\n // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n num.words[num.length] = 0;\n num.words[num.length + 1] = 0;\n num.length += 2;\n\n // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n var lo = 0;\n for (var i = 0; i < num.length; i++) {\n var w = num.words[i] | 0;\n lo += w * 0x3d1;\n num.words[i] = lo & 0x3ffffff;\n lo = w * 0x40 + ((lo / 0x4000000) | 0);\n }\n\n // Fast length reduction\n if (num.words[num.length - 1] === 0) {\n num.length--;\n if (num.words[num.length - 1] === 0) {\n num.length--;\n }\n }\n return num;\n };\n\n function P224 () {\n MPrime.call(\n this,\n 'p224',\n 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n }\n inherits(P224, MPrime);\n\n function P192 () {\n MPrime.call(\n this,\n 'p192',\n 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n }\n inherits(P192, MPrime);\n\n function P25519 () {\n // 2 ^ 255 - 19\n MPrime.call(\n this,\n '25519',\n '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n }\n inherits(P25519, MPrime);\n\n P25519.prototype.imulK = function imulK (num) {\n // K = 0x13\n var carry = 0;\n for (var i = 0; i < num.length; i++) {\n var hi = (num.words[i] | 0) * 0x13 + carry;\n var lo = hi & 0x3ffffff;\n hi >>>= 26;\n\n num.words[i] = lo;\n carry = hi;\n }\n if (carry !== 0) {\n num.words[num.length++] = carry;\n }\n return num;\n };\n\n // Exported mostly for testing purposes, use plain name instead\n BN._prime = function prime (name) {\n // Cached version of prime\n if (primes[name]) return primes[name];\n\n var prime;\n if (name === 'k256') {\n prime = new K256();\n } else if (name === 'p224') {\n prime = new P224();\n } else if (name === 'p192') {\n prime = new P192();\n } else if (name === 'p25519') {\n prime = new P25519();\n } else {\n throw new Error('Unknown prime ' + name);\n }\n primes[name] = prime;\n\n return prime;\n };\n\n //\n // Base reduction engine\n //\n function Red (m) {\n if (typeof m === 'string') {\n var prime = BN._prime(m);\n this.m = prime.p;\n this.prime = prime;\n } else {\n assert(m.gtn(1), 'modulus must be greater than 1');\n this.m = m;\n this.prime = null;\n }\n }\n\n Red.prototype._verify1 = function _verify1 (a) {\n assert(a.negative === 0, 'red works only with positives');\n assert(a.red, 'red works only with red numbers');\n };\n\n Red.prototype._verify2 = function _verify2 (a, b) {\n assert((a.negative | b.negative) === 0, 'red works only with positives');\n assert(a.red && a.red === b.red,\n 'red works only with red numbers');\n };\n\n Red.prototype.imod = function imod (a) {\n if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n\n move(a, a.umod(this.m)._forceRed(this));\n return a;\n };\n\n Red.prototype.neg = function neg (a) {\n if (a.isZero()) {\n return a.clone();\n }\n\n return this.m.sub(a)._forceRed(this);\n };\n\n Red.prototype.add = function add (a, b) {\n this._verify2(a, b);\n\n var res = a.add(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.iadd = function iadd (a, b) {\n this._verify2(a, b);\n\n var res = a.iadd(b);\n if (res.cmp(this.m) >= 0) {\n res.isub(this.m);\n }\n return res;\n };\n\n Red.prototype.sub = function sub (a, b) {\n this._verify2(a, b);\n\n var res = a.sub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res._forceRed(this);\n };\n\n Red.prototype.isub = function isub (a, b) {\n this._verify2(a, b);\n\n var res = a.isub(b);\n if (res.cmpn(0) < 0) {\n res.iadd(this.m);\n }\n return res;\n };\n\n Red.prototype.shl = function shl (a, num) {\n this._verify1(a);\n return this.imod(a.ushln(num));\n };\n\n Red.prototype.imul = function imul (a, b) {\n this._verify2(a, b);\n return this.imod(a.imul(b));\n };\n\n Red.prototype.mul = function mul (a, b) {\n this._verify2(a, b);\n return this.imod(a.mul(b));\n };\n\n Red.prototype.isqr = function isqr (a) {\n return this.imul(a, a.clone());\n };\n\n Red.prototype.sqr = function sqr (a) {\n return this.mul(a, a);\n };\n\n Red.prototype.sqrt = function sqrt (a) {\n if (a.isZero()) return a.clone();\n\n var mod3 = this.m.andln(3);\n assert(mod3 % 2 === 1);\n\n // Fast case\n if (mod3 === 3) {\n var pow = this.m.add(new BN(1)).iushrn(2);\n return this.pow(a, pow);\n }\n\n // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n //\n // Find Q and S, that Q * 2 ^ S = (P - 1)\n var q = this.m.subn(1);\n var s = 0;\n while (!q.isZero() && q.andln(1) === 0) {\n s++;\n q.iushrn(1);\n }\n assert(!q.isZero());\n\n var one = new BN(1).toRed(this);\n var nOne = one.redNeg();\n\n // Find quadratic non-residue\n // NOTE: Max is such because of generalized Riemann hypothesis.\n var lpow = this.m.subn(1).iushrn(1);\n var z = this.m.bitLength();\n z = new BN(2 * z * z).toRed(this);\n\n while (this.pow(z, lpow).cmp(nOne) !== 0) {\n z.redIAdd(nOne);\n }\n\n var c = this.pow(z, q);\n var r = this.pow(a, q.addn(1).iushrn(1));\n var t = this.pow(a, q);\n var m = s;\n while (t.cmp(one) !== 0) {\n var tmp = t;\n for (var i = 0; tmp.cmp(one) !== 0; i++) {\n tmp = tmp.redSqr();\n }\n assert(i < m);\n var b = this.pow(c, new BN(1).iushln(m - i - 1));\n\n r = r.redMul(b);\n c = b.redSqr();\n t = t.redMul(c);\n m = i;\n }\n\n return r;\n };\n\n Red.prototype.invm = function invm (a) {\n var inv = a._invmp(this.m);\n if (inv.negative !== 0) {\n inv.negative = 0;\n return this.imod(inv).redNeg();\n } else {\n return this.imod(inv);\n }\n };\n\n Red.prototype.pow = function pow (a, num) {\n if (num.isZero()) return new BN(1).toRed(this);\n if (num.cmpn(1) === 0) return a.clone();\n\n var windowSize = 4;\n var wnd = new Array(1 << windowSize);\n wnd[0] = new BN(1).toRed(this);\n wnd[1] = a;\n for (var i = 2; i < wnd.length; i++) {\n wnd[i] = this.mul(wnd[i - 1], a);\n }\n\n var res = wnd[0];\n var current = 0;\n var currentLen = 0;\n var start = num.bitLength() % 26;\n if (start === 0) {\n start = 26;\n }\n\n for (i = num.length - 1; i >= 0; i--) {\n var word = num.words[i];\n for (var j = start - 1; j >= 0; j--) {\n var bit = (word >> j) & 1;\n if (res !== wnd[0]) {\n res = this.sqr(res);\n }\n\n if (bit === 0 && current === 0) {\n currentLen = 0;\n continue;\n }\n\n current <<= 1;\n current |= bit;\n currentLen++;\n if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n\n res = this.mul(res, wnd[current]);\n currentLen = 0;\n current = 0;\n }\n start = 26;\n }\n\n return res;\n };\n\n Red.prototype.convertTo = function convertTo (num) {\n var r = num.umod(this.m);\n\n return r === num ? r.clone() : r;\n };\n\n Red.prototype.convertFrom = function convertFrom (num) {\n var res = num.clone();\n res.red = null;\n return res;\n };\n\n //\n // Montgomery method engine\n //\n\n BN.mont = function mont (num) {\n return new Mont(num);\n };\n\n function Mont (m) {\n Red.call(this, m);\n\n this.shift = this.m.bitLength();\n if (this.shift % 26 !== 0) {\n this.shift += 26 - (this.shift % 26);\n }\n\n this.r = new BN(1).iushln(this.shift);\n this.r2 = this.imod(this.r.sqr());\n this.rinv = this.r._invmp(this.m);\n\n this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n this.minv = this.minv.umod(this.r);\n this.minv = this.r.sub(this.minv);\n }\n inherits(Mont, Red);\n\n Mont.prototype.convertTo = function convertTo (num) {\n return this.imod(num.ushln(this.shift));\n };\n\n Mont.prototype.convertFrom = function convertFrom (num) {\n var r = this.imod(num.mul(this.rinv));\n r.red = null;\n return r;\n };\n\n Mont.prototype.imul = function imul (a, b) {\n if (a.isZero() || b.isZero()) {\n a.words[0] = 0;\n a.length = 1;\n return a;\n }\n\n var t = a.imul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.mul = function mul (a, b) {\n if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n\n var t = a.mul(b);\n var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n var u = t.isub(c).iushrn(this.shift);\n var res = u;\n if (u.cmp(this.m) >= 0) {\n res = u.isub(this.m);\n } else if (u.cmpn(0) < 0) {\n res = u.iadd(this.m);\n }\n\n return res._forceRed(this);\n };\n\n Mont.prototype.invm = function invm (a) {\n // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n var res = this.imod(a._invmp(this.m).mul(this.r2));\n return res._forceRed(this);\n };\n})(typeof module === 'undefined' || module, this);\n","import { AggregatorClient, Env } from '@cetusprotocol/aggregator-sdk'\nimport { normalizeSuiAddress } from '@mysten/sui/utils'\nimport { CetusDlmmSDK } from '@cetusprotocol/dlmm-sdk'\nimport { BaseSdkOptions, SdkWrapper } from '@cetusprotocol/common-sdk'\nimport { zapMainnet } from './config/mainnet'\nimport { zapTestnet } from './config/testnet'\nimport { ZapModule } from './modules/zapModule'\nimport { CompoundModule } from './modules/compoundModule'\nimport { SuiGrpcClient } from '@mysten/sui/grpc'\nimport { SuiJsonRpcClient } from '@mysten/sui/jsonRpc'\n/**\n * Represents options and configurations for an SDK.\n */\nexport interface SdkOptions extends BaseSdkOptions {\n /**\n * The URL of the aggregator service.\n */\n aggregator_url: string\n /**\n * A list of aggregator providers.\n */\n providers: string[]\n\n /**\n * A list of Pyth price ID.\n */\n pyth_urls?: string[]\n}\n\n/**\n * The entry class of CetusDlmmZapSDK, which is almost responsible for all interactions with dlmm zap.\n */\nexport class CetusDlmmZapSDK extends SdkWrapper<SdkOptions> {\n /**\n * Module for managing vaults.\n */\n protected _zapModule: ZapModule\n\n protected _compoundModule: CompoundModule\n\n protected _dlmmSDK: CetusDlmmSDK\n\n /**\n * Client for interacting with the Aggregator service.\n */\n protected _aggregatorClient: AggregatorClient\n\n\n constructor(options: SdkOptions, dlmmSDK?: CetusDlmmSDK) {\n super(options)\n\n /**\n * Initialize the ZapModule.\n */\n this._zapModule = new ZapModule(this)\n this._compoundModule = new CompoundModule(this)\n\n /**\n * Initialize the DlmmSDK.\n */\n this._dlmmSDK = dlmmSDK || CetusDlmmSDK.createSDK({ env: options.env, full_rpc_url: options.full_rpc_url })\n\n /**\n * Initialize the AggregatorClient.\n */\n this._aggregatorClient = this.createAggregatorClient()\n }\n\n private createAggregatorClient() {\n return new AggregatorClient({\n signer: normalizeSuiAddress('0x0'),\n client: this._sdkOptions.sui_client || new SuiJsonRpcClient({ url: this._sdkOptions.full_rpc_url!, network: this._sdkOptions.env === 'testnet' ? 'testnet' : 'mainnet' }),\n env: this._sdkOptions.env === 'testnet' ? Env.Testnet : Env.Mainnet,\n pythUrls: this._sdkOptions.pyth_urls,\n })\n }\n\n updatePythUrls(pythUrls: string[]) {\n if (pythUrls.length === 0) {\n throw new Error('pythUrls is empty')\n }\n this._sdkOptions.pyth_urls = pythUrls\n this._aggregatorClient = this.createAggregatorClient()\n }\n\n setSenderAddress(value: string): void {\n this._dlmmSDK.setSenderAddress(value)\n }\n\n getSenderAddress(validate: boolean = true): string {\n return this._dlmmSDK.getSenderAddress(validate)\n }\n\n /**\n * Updates the providers for the AggregatorClient.\n * @param providers - The new providers to set.\n */\n updateProviders(providers: string[]) {\n if (providers.length === 0) {\n throw new Error('providers is empty')\n }\n this._sdkOptions.providers = providers\n }\n\n updateFullRpcUrl(url: string): void {\n super.updateFullRpcUrl(url)\n this._dlmmSDK.updateFullRpcUrl(url)\n this._aggregatorClient = new AggregatorClient({\n signer: normalizeSuiAddress('0x0'),\n client: new SuiJsonRpcClient({ url: url, network: this._sdkOptions.env === 'testnet' ? 'testnet' : 'mainnet' }),\n env: this._sdkOptions.env === 'testnet' ? Env.Testnet : Env.Mainnet,\n pythUrls: this._sdkOptions.pyth_urls,\n })\n }\n\n /**\n * Getter for the DlmmSDK property.\n * @returns {CetusDlmmSDK} The DlmmSDK property value.\n */\n get DlmmSDK(): CetusDlmmSDK {\n return this._dlmmSDK\n }\n\n /**\n * Getter for the AggregatorClient property.\n * @returns {AggregatorClient} The AggregatorClient property value.\n */\n get AggregatorClient(): AggregatorClient {\n return this._aggregatorClient\n }\n\n /**\n * Getter for the ZapModule property.\n * @returns {ZapModule} The ZapModule property value.\n */\n get Zap(): ZapModule {\n return this._zapModule\n }\n\n get Compound(): CompoundModule {\n return this._compoundModule\n }\n\n /**\n * Static factory method to initialize the SDK\n * @param options SDK initialization options\n * @param clmm_sdk Optional CLMM SDK instance\n * @returns An instance of CetusZapSDK\n */\n static createSDK(options: BaseSdkOptions, dlmm_sdk?: any): CetusDlmmZapSDK {\n const { env = 'mainnet', full_rpc_url } = options\n return env === 'mainnet'\n ? CetusDlmmZapSDK.createCustomSDK({ ...zapMainnet, ...options }, dlmm_sdk)\n : CetusDlmmZapSDK.createCustomSDK({ ...zapTestnet, ...options }, dlmm_sdk)\n }\n\n /**\n * Create a custom SDK instance with the given options\n * @param options The options for the SDK\n * @returns An instance of CetusBurnSDK\n */\n static createCustomSDK<T extends BaseSdkOptions>(options: T & SdkOptions, dlmm_sdk?: CetusDlmmSDK): CetusDlmmZapSDK {\n return new CetusDlmmZapSDK(options, dlmm_sdk)\n }\n}\n","import { SdkOptions } from '../sdk'\nimport { DefaultProviders, FullRpcUrlMainnet, GraphRpcUrlMainnet } from '@cetusprotocol/common-sdk'\n// mainnet\nexport const zapMainnet: SdkOptions = {\n env: 'mainnet',\n full_rpc_url: FullRpcUrlMainnet,\n graph_rpc_url: GraphRpcUrlMainnet,\n aggregator_url: 'https://api-sui.cetus.zone/router_v3',\n providers: [],\n}\n","import { FullRpcUrlTestnet, GraphRpcUrlTestnet } from '@cetusprotocol/common-sdk'\nimport { SdkOptions } from '../sdk'\nexport const zapTestnet: SdkOptions = {\n env: 'testnet',\n full_rpc_url: FullRpcUrlTestnet,\n graph_rpc_url: GraphRpcUrlTestnet,\n aggregator_url: 'https://api-sui.devcetus.com/router_v3',\n providers: ['CETUS', 'DEEPBOOK', 'KRIYA', 'KRIYAV3', 'FLOWX', 'FLOWXV3', 'AFTERMATH', 'TURBOS', 'HAEDAL', 'VOLO', 'AFSUI'],\n}\n","import { BuildRouterSwapParamsV3, FindRouterParams, PreSwapLpChangeParams } from '@cetusprotocol/aggregator-sdk'\nimport { Transaction, TransactionObjectArgument } from '@mysten/sui/transactions'\n\nimport BN from 'bn.js'\nimport {\n asUintN,\n ClmmPoolUtil,\n CLOCK_ADDRESS,\n CoinAsset,\n CoinAssist,\n convertScientificToDecimal,\n d,\n DETAILS_KEYS,\n fromDecimalsAmount,\n getPackagerConfigs,\n IModule,\n TickMath,\n toDecimalsAmount,\n} from '@cetusprotocol/common-sdk'\nimport Decimal from 'decimal.js'\nimport { handleError, handleMessageError, ZapErrorCode } from '../errors/errors'\nimport {\n BaseDepositOptions,\n CalculationDepositResult,\n CalculationWithdrawAvailableAmountOptions,\n CalculationWithdrawOptions,\n CalculationWithdrawResult,\n defaultSwapSlippage,\n DepositOptions,\n OnlyCoinDepositOptions,\n SwapResult,\n WithdrawOptions,\n} from '../types/zap'\nimport { calcExactSwapAmount, calculateLiquidityAmountEnough, calculateLiquidityAmountSide } from '../utils/zap'\nimport { CetusDlmmZapSDK } from '../sdk'\nimport {\n AddLiquidityOption,\n BinAmount,\n BinLiquidityInfo,\n BinUtils,\n CalculateAddLiquidityAutoFillOption,\n OpenAndAddLiquidityOption,\n RemoveLiquidityOption,\n} from '@cetusprotocol/dlmm-sdk'\nimport e from 'cors'\n\n/**\n * ZapModule handles interactions with clmm pools within the system.\n */\nexport class ZapModule implements IModule<CetusDlmmZapSDK> {\n protected _sdk: CetusDlmmZapSDK\n\n constructor(sdk: CetusDlmmZapSDK) {\n this._sdk = sdk\n }\n\n /**\n * Returns the associated SDK instance\n */\n get sdk() {\n return this._sdk\n }\n\n private async calculateBalanceSwapAmountWithoutActiveId(options: BaseDepositOptions, mode_options: OnlyCoinDepositOptions) {\n const { fix_amount_a, coin_amount } = mode_options\n const { bin_step, pool_id, active_id, lower_bin_id, upper_bin_id, active_bin_of_pool, strategy_type } = options\n const pool = await this._sdk.DlmmSDK.Pool.getPool(pool_id, false)\n\n let best_swap_result: SwapResult | undefined\n let _fix_amount_a = fix_amount_a\n let _coin_amount = coin_amount\n if (active_id > upper_bin_id) {\n _fix_amount_a = false\n if (fix_amount_a) {\n best_swap_result = await this.findRouters(pool.coin_type_a, pool.coin_type_b, coin_amount)\n _coin_amount = d(best_swap_result.swap_out_amount)\n .mul(1 - 0.001)\n .toFixed(0)\n } else {\n _coin_amount = coin_amount\n }\n } else if (active_id < lower_bin_id) {\n _fix_amount_a = true\n if (fix_amount_a) {\n _coin_amount = coin_amount\n } else {\n best_swap_result = await this.findRouters(pool.coin_type_b, pool.coin_type_a, coin_amount)\n _coin_amount = d(best_swap_result.swap_out_amount)\n .mul(1 - 0.001)\n .toFixed(0)\n }\n }\n\n const liquidity_info = await this._sdk.DlmmSDK.Position.calculateAddLiquidityInfo({\n pool_id,\n coin_amount: _coin_amount,\n fix_amount_a: _fix_amount_a,\n active_id,\n bin_step,\n lower_bin_id,\n upper_bin_id,\n active_bin_of_pool,\n strategy_type,\n })\n\n return {\n liquidity_info,\n swap_result: best_swap_result,\n }\n }\n\n private async calculateBalanceSwapAmount(options: BaseDepositOptions, mode_options: OnlyCoinDepositOptions) {\n const { fix_amount_a, coin_amount } = mode_options\n const { bin_step, pool_id, active_id, lower_bin_id, upper_bin_id, active_bin_of_pool, strategy_type } = options\n\n if (active_id > upper_bin_id || active_id < lower_bin_id) {\n return this.calculateBalanceSwapAmountWithoutActiveId(options, mode_options)\n }\n\n const liquidity_info = await this._sdk.DlmmSDK.Position.calculateAddLiquidityInfo({\n pool_id,\n coin_amount,\n fix_amount_a,\n active_id,\n bin_step,\n lower_bin_id,\n upper_bin_id,\n active_bin_of_pool,\n strategy_type,\n })\n const { amount_a, amount_b } = liquidity_info\n\n const target_rate = fix_amount_a ? d(amount_b).div(amount_a) : d(amount_a).div(amount_b)\n let real_price = fix_amount_a\n ? BinUtils.getPricePerLamportFromBinId(active_id, bin_step)\n : d(1).div(BinUtils.getPricePerLamportFromBinId(active_id, bin_step)).toString()\n\n const pool = await this._sdk.DlmmSDK.Pool.getPool(pool_id, false)\n\n try {\n const price_result = await this.findRouters(\n fix_amount_a ? pool.coin_type_a : pool.coin_type_b,\n fix_amount_a ? pool.coin_type_b : pool.coin_type_a,\n coin_amount\n )\n\n if (price_result) {\n real_price = d(price_result.swap_out_amount).div(price_result.swap_in_amount).toString()\n }\n } catch (error) { }\n\n const { swap_amount, final_amount_a, final_amount_b } = calcExactSwapAmount(\n coin_amount,\n fix_amount_a,\n real_price,\n target_rate.toString()\n )\n\n console.log('🚀 ~ ZapModule ~ swap_amount:', {\n swap_amount,\n final_amount_a,\n final_amount_b,\n target_rate,\n real_price,\n coin_amount,\n fix_amount_a,\n })\n\n let swap_amount_in = swap_amount || '0'\n let best_swap_result\n let best_liquidity_info: BinLiquidityInfo | undefined\n let temp_swap_result: SwapResult | undefined\n let count = 0\n const max_remain_rate = 0.02\n\n let cached_swap_result: SwapResult | undefined\n let cached_liquidity_info: BinLiquidityInfo | undefined\n let cached_real_remain_rate: Decimal | undefined\n\n do {\n const deposit_amount = d(coin_amount).sub(swap_amount_in).toFixed(0)\n\n temp_swap_result = await this.findRouters(\n fix_amount_a ? pool.coin_type_a : pool.coin_type_b,\n fix_amount_a ? pool.coin_type_b : pool.coin_type_a,\n swap_amount_in\n )\n const swap_out_amount = d(temp_swap_result.swap_out_amount).toFixed(0)\n\n const liquidity_info = await this._sdk.DlmmSDK.Position.calculateAddLiquidityInfo({\n pool_id,\n coin_amount: deposit_amount,\n fix_amount_a,\n active_id,\n bin_step,\n lower_bin_id,\n upper_bin_id,\n active_bin_of_pool,\n strategy_type,\n })\n const { amount_a, amount_b } = liquidity_info\n const deposit_amount_other = fix_amount_a ? amount_b : amount_a\n const real_remain_rate = d(swap_out_amount).sub(deposit_amount_other).div(swap_out_amount)\n\n if (real_remain_rate.gt(0) && (cached_real_remain_rate === undefined || real_remain_rate.lt(cached_real_remain_rate))) {\n cached_swap_result = temp_swap_result\n cached_liquidity_info = liquidity_info\n cached_real_remain_rate = real_remain_rate\n }\n\n if (d(swap_out_amount).gt(deposit_amount_other)) {\n if (d(real_remain_rate).gt(max_remain_rate)) {\n console.log('calculateBalanceSwapAmount -: ', {\n swap_amount_in,\n real_remain_rate: real_remain_rate.toString(),\n cached_real_remain_rate: cached_real_remain_rate?.toString(),\n temp_swap_result,\n deposit_amount_other,\n count,\n })\n swap_amount_in = d(swap_amount_in)\n .mul(1 - 0.01)\n .toFixed(0)\n\n count++\n } else {\n best_swap_result = temp_swap_result\n best_liquidity_info = liquidity_info\n break\n }\n } else {\n swap_amount_in = d(swap_amount_in)\n .mul(1 + 0.01)\n .toFixed(0)\n swap_amount_in = Math.min(\n Number(\n d(coin_amount)\n .mul(1 - 0.0001)\n .toFixed(0)\n ),\n Number(swap_amount_in)\n ).toString()\n console.log('calculateBalanceSwapAmount +: ', {\n swap_amount_in,\n real_remain_rate: real_remain_rate.toString(),\n cached_real_remain_rate: cached_real_remain_rate?.toString(),\n temp_swap_result,\n deposit_amount_other,\n count,\n })\n count++\n }\n if (count > 5) {\n break\n }\n } while (!best_swap_result && d(swap_amount_in).gt(0))\n\n if (best_swap_result === undefined && cached_swap_result) {\n best_swap_result = cached_swap_result\n best_liquidity_info = cached_liquidity_info\n }\n\n if (best_swap_result === undefined && temp_swap_result) {\n const { swap_out_amount } = temp_swap_result\n const liquidity_info = await this._sdk.DlmmSDK.Position.calculateAddLiquidityInfo({\n pool_id,\n coin_amount: d(swap_out_amount)\n .sub(1 - 0.001)\n .toFixed(0),\n fix_amount_a: !fix_amount_a,\n active_id,\n bin_step,\n lower_bin_id,\n upper_bin_id,\n active_bin_of_pool,\n strategy_type,\n })\n best_swap_result = temp_swap_result\n best_liquidity_info = liquidity_info\n }\n\n return {\n swap_result: best_swap_result,\n liquidity_info: best_liquidity_info,\n }\n }\n\n /**\n * Pre-calculates the deposit amount based on the selected mode.\n * @param options\n * @param mode_options\n * @returns\n */\n async preCalculateDepositAmount(options: BaseDepositOptions, mode_options: OnlyCoinDepositOptions): Promise<CalculationDepositResult> {\n const { fix_amount_a, coin_amount } = mode_options\n console.log('🚀 ~ ZapModule ~ preCalculateDepositAmount ~ options:', {\n options,\n mode_options,\n })\n\n const { liquidity_info: best_liquidity_info, swap_result: best_swap_result } = await this.calculateBalanceSwapAmount(\n options,\n mode_options\n )\n\n if (best_liquidity_info === undefined) {\n return handleMessageError(ZapErrorCode.SwapAmountError, 'Best liquidity info is undefined', {\n [DETAILS_KEYS.METHOD_NAME]: 'preCalculateDepositAmount',\n }) as never\n }\n\n return {\n bin_infos: best_liquidity_info,\n swap_result: best_swap_result,\n fix_amount_a,\n coin_amount,\n }\n }\n\n public async buildDepositPayload(options: DepositOptions, tx?: Transaction): Promise<Transaction> {\n const {\n swap_slippage = defaultSwapSlippage,\n bin_step,\n pool_id,\n active_id,\n lower_bin_id,\n upper_bin_id,\n strategy_type,\n deposit_obj,\n slippage,\n pos_obj,\n } = options\n const { fix_amount_a, coin_amount, swap_result, bin_infos } = deposit_obj\n\n tx = tx || new Transaction()\n const pool = await this._sdk.DlmmSDK.Pool.getPool(pool_id, false)\n const { coin_type_a, coin_type_b } = pool\n\n let deposit_amount_a_coin\n let deposit_amount_b_coin\n if (swap_result) {\n const coin_type = fix_amount_a ? coin_type_a : coin_type_b\n const { swap_in_amount, route_obj } = swap_result\n const swap_amount_in_coin = CoinAssist.buildCoinWithBalance(BigInt(swap_in_amount), coin_type, tx)\n const routerParamsV3: BuildRouterSwapParamsV3 = {\n router: route_obj,\n slippage: swap_slippage,\n txb: tx,\n inputCoin: swap_amount_in_coin,\n }\n const swap_out_coin = await this._sdk.AggregatorClient.fixableRouterSwapV3(routerParamsV3)\n\n if (fix_amount_a) {\n deposit_amount_a_coin = CoinAssist.buildCoinWithBalance(BigInt(bin_infos.amount_a), coin_type_a, tx)\n deposit_amount_b_coin = swap_out_coin\n } else {\n deposit_amount_a_coin = swap_out_coin\n deposit_amount_b_coin = CoinAssist.buildCoinWithBalance(BigInt(bin_infos.amount_b), coin_type_b, tx)\n }\n }\n\n if (pos_obj) {\n const addOption: AddLiquidityOption = {\n pool_id,\n bin_infos: bin_infos,\n coin_type_a,\n coin_type_b,\n active_id,\n strategy_type,\n max_price_slippage: slippage,\n bin_step,\n use_bin_infos: false,\n position_id: pos_obj.pos_id as string,\n collect_fee: pos_obj.collect_fee,\n reward_coins: pos_obj.collect_rewarder_types,\n coin_object_id_a: deposit_amount_a_coin,\n coin_object_id_b: deposit_amount_b_coin,\n }\n this._sdk.DlmmSDK.Position.addLiquidityPayload(addOption, tx)\n } else {\n const addOption: OpenAndAddLiquidityOption = {\n pool_id,\n bin_infos: bin_infos,\n coin_type_a,\n coin_type_b,\n lower_bin_id,\n upper_bin_id,\n active_id,\n strategy_type,\n use_bin_infos: false,\n max_price_slippage: slippage,\n bin_step,\n coin_object_id_a: deposit_amount_a_coin,\n coin_object_id_b: deposit_amount_b_coin,\n }\n this._sdk.DlmmSDK.Position.addLiquidityPayload(addOption, tx)\n }\n\n return tx\n }\n\n public async findRouters(from: string, target: string, amount: string): Promise<SwapResult> {\n const { providers } = this._sdk.sdkOptions\n const client = this._sdk.AggregatorClient\n\n if (d(amount).lt(1)) {\n return handleMessageError(ZapErrorCode.SwapAmountError, 'Swap amount is less than the minimum precision', {\n [DETAILS_KEYS.METHOD_NAME]: 'findRouters',\n }) as never\n }\n\n try {\n // Construct parameters for route finding\n const findRouterParams: FindRouterParams = {\n from,\n target,\n amount: new BN(amount),\n byAmountIn: true,\n depth: 3,\n providers,\n }\n\n // Find the swap route\n const res = await client.findRouters(findRouterParams)\n if (res?.error) {\n return handleMessageError(ZapErrorCode.AggregatorError, `Aggregator findRouters error: ${res?.error}`, {\n [DETAILS_KEYS.METHOD_NAME]: 'findRouters',\n [DETAILS_KEYS.REQUEST_PARAMS]: findRouterParams,\n }) as never\n }\n if (!res?.paths || res?.paths?.length === 0) {\n return handleMessageError(ZapErrorCode.AggregatorError, 'Aggregator findRouters error: no router', {\n [DETAILS_KEYS.METHOD_NAME]: 'findRouters',\n [DETAILS_KEYS.REQUEST_PARAMS]: findRouterParams,\n }) as never\n }\n\n const swap_in_amount = res.amountIn.toString()\n const swap_out_amount = res.amountOut.toString()\n\n // Return the swap result\n const swapResult: SwapResult = {\n swap_in_amount,\n swap_out_amount,\n route_obj: res,\n }\n return swapResult\n } catch (error) {\n console.log('🚀 ~ ZapModule ~ error:', JSON.stringify(error, null, 2))\n return handleError(ZapErrorCode.AggregatorError, error as Error, {\n [DETAILS_KEYS.METHOD_NAME]: 'swapInPools',\n })\n }\n }\n\n public calculateZapOutAvailableAmount(options: CalculationWithdrawAvailableAmountOptions) {\n const { is_receive_coin_a, mode, active_id, bin_step, remove_bin_range, prices, coin_decimal_a, coin_decimal_b } = options\n let price\n if (prices) {\n const { coin_a_price, coin_b_price } = prices\n price = d(coin_a_price).div(coin_b_price).toString()\n } else {\n price = BinUtils.getPriceFromBinId(active_id, bin_step, coin_decimal_a, coin_decimal_b)\n }\n\n let active_bin: BinAmount | undefined\n let user_total_amount_a = '0'\n let user_total_amount_b = '0'\n let available_amount = '0'\n\n remove_bin_range.forEach((bin) => {\n if (bin.bin_id === active_id) {\n active_bin = bin\n }\n user_total_amount_a = d(user_total_amount_a).add(bin.amount_a).toFixed(0)\n user_total_amount_b = d(user_total_amount_b).add(bin.amount_b).toFixed(0)\n })\n\n const user_total_amount_a_no_active = d(user_total_amount_a)\n .sub(active_bin?.amount_a || '0')\n .toFixed(0)\n const user_total_amount_b_no_active = d(user_total_amount_b)\n .sub(active_bin?.amount_b || '0')\n .toFixed(0)\n\n const transformToAmountB = d(\n toDecimalsAmount(d(fromDecimalsAmount(user_total_amount_a, coin_decimal_a)).mul(price).toString(), coin_decimal_b)\n ).toFixed(0)\n const transformToAmountA = d(\n toDecimalsAmount(d(fromDecimalsAmount(user_total_amount_b, coin_decimal_b)).div(price).toString(), coin_decimal_a)\n ).toFixed(0)\n if (mode === 'OnlyCoinA') {\n if (is_receive_coin_a) {\n available_amount = user_total_amount_a_no_active\n } else {\n available_amount = transformToAmountB\n }\n } else if (mode === 'OnlyCoinB') {\n user_total_amount_b = user_total_amount_b_no_active\n if (is_receive_coin_a) {\n available_amount = transformToAmountA\n } else {\n available_amount = user_total_amount_b\n }\n } else if (mode === 'Both') {\n if (is_receive_coin_a) {\n available_amount = d(transformToAmountA).add(user_total_amount_a).toFixed(0)\n } else {\n available_amount = d(transformToAmountB).add(user_total_amount_b).toFixed(0)\n }\n }\n return {\n available_amount,\n user_total_amount_a,\n user_total_amount_b,\n active_bin,\n is_receive_coin_a,\n }\n }\n\n public async preCalculateWithdrawAmount(options: CalculationWithdrawOptions): Promise<CalculationWithdrawResult> {\n const { is_receive_coin_a, remove_bin_range, coin_type_a, coin_type_b, mode, expected_receive_amount, active_id } = options\n\n const { available_amount, user_total_amount_a, user_total_amount_b, active_bin } = this.calculateZapOutAvailableAmount(options)\n if (d(available_amount).lt(d(expected_receive_amount))) {\n return handleMessageError(\n ZapErrorCode.SwapAmountError,\n `Available amount is less than the expected receive amount: ${available_amount} < ${expected_receive_amount}`,\n {\n [DETAILS_KEYS.METHOD_NAME]: 'preCalculateWithdrawAmount',\n [DETAILS_KEYS.REQUEST_PARAMS]: options,\n }\n ) as never\n }\n const remove_percent = d(expected_receive_amount).div(available_amount)\n\n let remove_liquidity_info: BinLiquidityInfo\n if (mode === 'Both') {\n const fix_amount_a = d(user_total_amount_a).gt(0)\n const coin_amount = fix_amount_a\n ? d(user_total_amount_a).mul(remove_percent).toFixed(0)\n : d(user_total_amount_b).mul(remove_percent).toFixed(0)\n remove_liquidity_info = this._sdk.DlmmSDK.Position.calculateRemoveLiquidityInfo({\n bins: remove_bin_range,\n active_id,\n fix_amount_a,\n coin_amount,\n })\n } else {\n const coin_amount =\n mode === 'OnlyCoinA' ? d(user_total_amount_a).mul(remove_percent).toFixed(0) : d(user_total_amount_b).mul(remove_percent).toFixed(0)\n remove_liquidity_info = this._sdk.DlmmSDK.Position.calculateRemoveLiquidityInfo({\n bins: remove_bin_range,\n active_id,\n is_only_a: mode === 'OnlyCoinA',\n coin_amount,\n })\n }\n\n const { amount_a, amount_b } = remove_liquidity_info\n\n let swap_result: SwapResult | undefined\n if (is_receive_coin_a && d(amount_b).gt(0)) {\n swap_result = await this.findRouters(coin_type_b, coin_type_a, amount_b)\n }\n\n if (!is_receive_coin_a && d(amount_a).gt(0)) {\n swap_result = await this.findRouters(coin_type_a, coin_type_b, amount_a)\n }\n\n return {\n remove_liquidity_info,\n swap_result,\n mode,\n is_receive_coin_a,\n expected_receive_amount,\n remove_percent: remove_percent.toString(),\n }\n }\n\n public async buildWithdrawPayload(options: WithdrawOptions): Promise<Transaction> {\n const tx = new Transaction()\n const {\n withdraw_obj,\n swap_slippage = defaultSwapSlippage,\n bin_step,\n pool_id,\n active_id,\n collect_fee,\n reward_coins,\n coin_type_a,\n coin_type_b,\n position_id,\n slippage,\n remove_percent,\n is_close_position,\n } = options\n\n const { remove_liquidity_info, swap_result, is_receive_coin_a } = withdraw_obj\n\n const removeOption: RemoveLiquidityOption = {\n pool_id,\n bin_infos: remove_liquidity_info,\n coin_type_a,\n coin_type_b,\n position_id,\n slippage,\n active_id,\n reward_coins,\n collect_fee,\n bin_step,\n remove_percent: Number(remove_percent),\n }\n const { coin_a_obj, coin_b_obj } = is_close_position\n ? this._sdk.DlmmSDK.Position.closePositionNoTransferPayload(removeOption, tx)\n : this._sdk.DlmmSDK.Position.removeLiquidityNoTransferPayload(removeOption, tx)\n\n if (swap_result) {\n const { route_obj } = swap_result\n const routerParamsV3: BuildRouterSwapParamsV3 = {\n router: route_obj,\n slippage: swap_slippage,\n txb: tx,\n inputCoin: is_receive_coin_a ? coin_b_obj : coin_a_obj,\n }\n const swap_out_coin = await this._sdk.AggregatorClient.fixableRouterSwapV3(routerParamsV3)\n if (is_receive_coin_a) {\n tx.transferObjects([coin_a_obj, swap_out_coin], this._sdk.getSenderAddress())\n } else {\n tx.transferObjects([coin_b_obj, swap_out_coin], this._sdk.getSenderAddress())\n }\n } else {\n tx.transferObjects([coin_a_obj, coin_b_obj], this._sdk.getSenderAddress())\n }\n\n return tx\n }\n}\n","import { BaseError } from '@cetusprotocol/common-sdk'\n\nexport enum ZapErrorCode {\n UnsupportedDepositMode = 'UnsupportedDepositMode',\n PositionIdUndefined = 'PositionIdUndefined',\n ParameterError = 'ParameterError',\n ReachMaxIterations = 'ReachMaxIterations',\n BestLiquidityIsZero = 'BestLiquidityIsZero',\n SwapAmountError = 'SwapAmountError',\n AggregatorError = 'AggregatorError',\n}\n\nexport class ZapError extends BaseError {\n constructor(message: string, errorCode?: ZapErrorCode, details?: Record<string, any>) {\n super(message, errorCode || 'UnknownError', details)\n }\n\n static isZapErrorCode(e: any, code: ZapErrorCode): boolean {\n return this.isErrorCode<ZapError>(e, code)\n }\n}\n\nexport const handleError = (code: ZapErrorCode, error: Error, details?: Record<string, any>) => {\n throw new ZapError(error.message, code, details)\n}\n\nexport const handleMessageError = (code: ZapErrorCode, message: string, details?: Record<string, any>) => {\n throw new ZapError(message, code, details)\n}\n","import { TransactionObjectArgument } from '@mysten/sui/transactions'\nimport { BinAmount, BinLiquidityInfo, StrategyType } from '@cetusprotocol/dlmm-sdk'\nimport { CoinPairType } from '@cetusprotocol/common-sdk'\n\nexport const defaultSwapSlippage = 0.005\n\n/**\n * Result of a swap operation containing amounts and price information\n */\nexport type SwapResult = {\n swap_in_amount: string // Amount of tokens being swapped in\n swap_out_amount: string // Amount of tokens being swapped out\n route_obj?: any // Optional routing information for the swap\n}\n\nexport type BaseDepositOptions = {\n pool_id: string\n strategy_type: StrategyType\n active_bin_of_pool?: BinAmount\n lower_bin_id: number\n upper_bin_id: number\n active_id: number\n bin_step: number\n}\n\nexport type OnlyCoinDepositOptions = {\n fix_amount_a: boolean\n coin_amount: string\n}\n\n/**\n * Result of a deposit calculation\n */\nexport type CalculationDepositResult = {\n bin_infos: BinLiquidityInfo\n swap_result?: SwapResult\n fix_amount_a: boolean\n coin_amount: string\n}\n\n/**\n * Complete options for executing a deposit\n */\nexport type DepositOptions = {\n deposit_obj: CalculationDepositResult\n slippage: number\n pool_id: string\n strategy_type: StrategyType\n lower_bin_id: number\n upper_bin_id: number\n active_id: number\n bin_step: number\n swap_slippage?: number\n pos_obj?: {\n pos_id: string | TransactionObjectArgument\n collect_fee: boolean\n collect_rewarder_types: string[]\n }\n}\n\nexport type WithdrawMode = 'OnlyCoinA' | 'OnlyCoinB' | 'Both'\nexport type CalculationWithdrawOptions = {\n remove_bin_range: BinAmount[]\n active_id: number\n bin_step: number\n expected_receive_amount: string\n is_receive_coin_a: boolean\n mode: WithdrawMode\n coin_decimal_a: number\n coin_decimal_b: number\n prices?: {\n coin_a_price: string\n coin_b_price: string\n }\n} & CoinPairType\n\nexport type CalculationWithdrawAvailableAmountOptions = {\n remove_bin_range: BinAmount[]\n active_id: number\n bin_step: number\n is_receive_coin_a: boolean\n mode: WithdrawMode\n coin_decimal_a: number\n coin_decimal_b: number\n prices?: {\n coin_a_price: string\n coin_b_price: string\n }\n}\n\n/**\n * Result of a withdrawal calculation\n */\nexport type CalculationWithdrawResult = {\n remove_liquidity_info: BinLiquidityInfo\n mode: WithdrawMode\n is_receive_coin_a?: boolean\n swap_result?: SwapResult\n expected_receive_amount: string\n remove_percent: string\n}\n\n/**\n * Complete options for executing a withdrawal\n */\nexport type WithdrawOptions = {\n withdraw_obj: CalculationWithdrawResult\n swap_slippage?: number\n pool_id: string\n position_id: string\n active_id: number\n bin_step: number\n slippage: number\n reward_coins: string[]\n collect_fee: boolean\n remove_percent?: number\n is_close_position: boolean\n} & CoinPairType\n","import BN from 'bn.js'\nimport { SwapResult } from '../types/zap'\nimport { ClmmPoolUtil, d, getTickSide, TickMath } from '@cetusprotocol/common-sdk'\nimport Decimal from 'decimal.js'\n\n/**\n * Calculate if there is enough liquidity amount for adding liquidity to a pool\n * @param amount_a - Amount of token A\n * @param amount_b - Amount of token B\n * @param curr_sqrt_price - Current square root price of the pool\n * @param lower_tick - Lower tick boundary of the position\n * @param upper_tick - Upper tick boundary of the position\n * @param slippage - Slippage tolerance for the calculation\n * @param fix_amount_a - Whether to fix the amount of token A\n * @returns Object containing:\n * - is_enough_amount: Whether there is enough amount for the other token\n * - use_amount_a: Amount of token A to be used\n * - use_amount_b: Amount of token B to be used\n * - liquidity: Calculated liquidity amount\n * - amount_limit_a: Minimum amount limit for token A\n * - amount_limit_b: Minimum amount limit for token B\n * - remain_amount: Remaining amount of the non-fixed token\n */\nexport function calculateLiquidityAmountEnough(\n amount_a: string,\n amount_b: string,\n curr_sqrt_price: string,\n lower_tick: number,\n upper_tick: number,\n slippage: number,\n fix_amount_a: boolean\n) {\n const fixCoinAmount = fix_amount_a ? new BN(amount_a) : new BN(amount_b)\n\n const liquidityInput = ClmmPoolUtil.estLiquidityAndCoinAmountFromOneAmounts(\n lower_tick,\n upper_tick,\n fixCoinAmount,\n fix_amount_a,\n true,\n slippage,\n new BN(curr_sqrt_price)\n )\n\n const use_amount_a = fix_amount_a ? fixCoinAmount.toString() : liquidityInput.coin_amount_a.toString()\n const use_amount_b = fix_amount_a ? liquidityInput.coin_amount_b.toString() : fixCoinAmount.toString()\n\n const remain_amount_a = d(amount_a).sub(use_amount_a)\n const remain_amount_b = d(amount_b).sub(use_amount_b)\n\n const is_enough_amount = fix_amount_a ? remain_amount_b.gte(0) : remain_amount_a.gte(0)\n\n return {\n is_enough_amount,\n use_amount_a,\n use_amount_b,\n liquidity: liquidityInput.liquidity_amount,\n amount_limit_a: liquidityInput.coin_amount_limit_a,\n amount_limit_b: liquidityInput.coin_amount_limit_b,\n remain_amount: fix_amount_a ? remain_amount_b : remain_amount_a,\n }\n}\n/**\n * Calculate the optimal side for adding liquidity based on current price and tick range\n * @param amount_a - Amount of token A\n * @param amount_b - Amount of token B\n * @param curr_sqrt_price - Current square root price of the pool\n * @param lower_tick - Lower tick boundary of the position\n * @param upper_tick - Upper tick boundary of the position\n * @param slippage - Slippage tolerance for the calculation\n * @param fix_amount_a - Whether to fix the amount of token A\n * @returns Object containing:\n * - fix_liquidity_amount_a: Whether to fix token A amount\n * - is_enough_amount: Whether there is enough amount for the other token\n * - use_amount_a: Amount of token A to be used\n * - use_amount_b: Amount of token B to be used\n * - liquidity: Calculated liquidity amount\n * - amount_limit_a: Minimum amount limit for token A\n * - amount_limit_b: Minimum amount limit for token B\n * - remain_amount: Remaining amount of the non-fixed token\n */\nexport function calculateLiquidityAmountSide(\n amount_a: string,\n amount_b: string,\n curr_sqrt_price: string,\n lower_tick: number,\n upper_tick: number,\n slippage: number,\n fix_amount_a: boolean\n) {\n const currTick = TickMath.sqrtPriceX64ToTickIndex(new BN(curr_sqrt_price))\n let fix_liquidity_amount_a = fix_amount_a\n\n if (currTick < lower_tick) {\n fix_liquidity_amount_a = true\n } else if (currTick > upper_tick) {\n fix_liquidity_amount_a = false\n }\n\n let res = calculateLiquidityAmountEnough(amount_a, amount_b, curr_sqrt_price, lower_tick, upper_tick, slippage, fix_liquidity_amount_a)\n // If not enough, fix the other side to add liquidity\n if (!res.is_enough_amount) {\n fix_liquidity_amount_a = !fix_liquidity_amount_a\n res = calculateLiquidityAmountEnough(amount_a, amount_b, curr_sqrt_price, lower_tick, upper_tick, slippage, fix_liquidity_amount_a)\n }\n return {\n fix_liquidity_amount_a,\n ...res,\n }\n}\n\n/**\n * Calculate the swap amount needed to achieve target ratio\n * @param coin_amount - Total coin amount available\n * @param fix_amount_a - Whether to fix token A amount (true) or token B amount (false)\n * @param current_price - Current price:\n * - When fix_amount_a = true: current_price = B/A (price of B in terms of A)\n * - When fix_amount_a = false: current_price = A/B (price of A in terms of B)\n * @param target_ratio - Target ratio to achieve:\n * - When fix_amount_a = true: target_ratio = B/A\n * - When fix_amount_a = false: target_ratio = A/B\n * @param tolerance - Tolerance for the target ratio (default: 0.01)\n * @returns Object containing:\n * - swap_amount: Amount to swap\n * - final_amount_a: Final amount of token A (remaining A when fix_amount_a=true, obtained A when fix_amount_a=false)\n * - final_amount_b: Final amount of token B (obtained B when fix_amount_a=true, remaining B when fix_amount_a=false)\n */\n/**\n * Calculate the swap amount needed to adjust two coin balances to a target ratio.\n *\n * The function automatically determines whether to swap A→B or B→A based on\n * the current balances and the target ratio, then binary-searches for the\n * minimal swap size that brings the final B/A ratio within 0.1 % of `target_ratio`.\n *\n * @param amount_a - Current amount of coin A\n * @param amount_b - Current amount of coin B\n * @param current_price - Real exchange rate expressed as B/A (how many B per 1 A)\n * @param target_ratio - Desired final ratio expressed as B/A (final_b / final_a)\n * @returns\n * - swap_amount: Amount to swap (denominated in the source coin)\n * - final_amount_a: Final amount of coin A after the swap\n * - final_amount_b: Final amount of coin B after the swap\n * - a_to_b: Swap direction – true = sell A for B, false = sell B for A\n */\nexport function calcSwapAmountForTargetRatio(\n amount_a: string,\n amount_b: string,\n current_price: string,\n target_ratio: string\n) {\n const amountA = d(amount_a)\n const amountB = d(amount_b)\n const price = d(current_price)\n const target = d(target_ratio)\n\n if (amountA.eq(0) && amountB.eq(0)) {\n return {\n swap_amount: '0',\n final_amount_a: '0',\n final_amount_b: '0',\n a_to_b: true,\n }\n }\n\n let a_to_b: boolean\n if (amountA.eq(0)) {\n a_to_b = false\n } else if (amountB.eq(0)) {\n a_to_b = true\n } else {\n const currentRatio = amountB.div(amountA)\n a_to_b = currentRatio.lt(target)\n }\n\n if (target.eq(0)) {\n if (!a_to_b) {\n const finalA = amountA.plus(amountB.div(price))\n return { swap_amount: amountB.toFixed(0), final_amount_a: finalA.toFixed(0), final_amount_b: '0', a_to_b }\n }\n return { swap_amount: '0', final_amount_a: amountA.toFixed(0), final_amount_b: amountB.toFixed(0), a_to_b }\n }\n\n const maxSwap = a_to_b ? amountA : amountB\n const maxR = target\n const minR = target.mul(0.999)\n\n let left = d(0)\n let right = maxSwap\n let best: Decimal | null = null\n\n function computeFinal(x: Decimal) {\n if (a_to_b) {\n const A = amountA.minus(x)\n const B = amountB.plus(x.mul(price))\n return { A, B, R: A.gt(0) ? B.div(A) : d(Number.MAX_SAFE_INTEGER) }\n }\n const A = amountA.plus(x.div(price))\n const B = amountB.minus(x)\n return { A, B, R: A.gt(0) ? B.div(A) : d(0) }\n }\n\n for (let i = 0; i < 120; i++) {\n const mid = left.plus(right).div(2)\n const { A, B, R } = computeFinal(mid)\n\n if (A.lte(0) || B.lte(0)) {\n right = mid\n continue\n }\n\n if (R.gt(maxR)) {\n if (a_to_b) {\n right = mid\n } else {\n left = mid\n }\n } else if (R.lt(minR)) {\n if (a_to_b) {\n left = mid\n } else {\n right = mid\n }\n } else {\n best = mid\n if (minR.eq(0)) {\n break\n }\n right = mid\n }\n }\n\n if (!best) {\n return {\n swap_amount: '0',\n final_amount_a: amountA.toFixed(0),\n final_amount_b: amountB.toFixed(0),\n a_to_b,\n }\n }\n\n const { A, B } = computeFinal(best)\n\n return {\n swap_amount: best.toFixed(0),\n final_amount_a: A.toFixed(0),\n final_amount_b: B.toFixed(0),\n a_to_b,\n }\n}\n\nexport function calcExactSwapAmount(coin_amount: string, fix_amount_a: boolean, current_price: string, target_ratio: string) {\n const amount = d(coin_amount)\n\n const price = d(current_price)\n const target = d(target_ratio)\n\n const maxSwap = amount\n\n // initial balances\n const A0 = fix_amount_a ? amount : d(0)\n const B0 = fix_amount_a ? d(0) : amount\n\n // desired ratio range\n const maxR = target\n // Ensure minR is not negative (ratio must be positive)\n const minR = d(target).mul(0.999)\n\n let left = d(0)\n let right = maxSwap\n let best: Decimal | null = null\n\n function computeFinal(x: Decimal) {\n if (fix_amount_a) {\n const A = A0.minus(x)\n const B = B0.plus(x.mul(price))\n return { A, B, R: B.div(A) }\n } else {\n const A = A0.plus(x.mul(price))\n const B = B0.minus(x)\n return { A, B, R: A.div(B) }\n }\n }\n\n // binary search\n for (let i = 0; i < 120; i++) {\n const mid = left.plus(right).div(2)\n const { A, B, R } = computeFinal(mid)\n\n if (A.lte(0) || B.lte(0)) {\n right = mid\n continue\n }\n\n if (R.gt(maxR)) {\n // Ratio is too high → swapped too much → decrease swap amount\n right = mid\n } else if (R.lt(minR)) {\n // Ratio is too low → swapped too little → increase swap\n left = mid\n } else {\n best = mid // In the range\n if (d(minR).eq(0)) {\n break\n }\n right = mid // Continue to find a smaller swap\n }\n }\n\n if (!best) {\n return {\n swap_amount: '0',\n final_amount_a: A0.toFixed(0),\n final_amount_b: B0.toFixed(0),\n }\n }\n\n const { A, B } = computeFinal(best)\n\n return {\n swap_amount: best.toFixed(0),\n final_amount_a: A.toFixed(0),\n final_amount_b: B.toFixed(0),\n }\n}\n","import { CetusDlmmZapSDK } from '../sdk'\nimport {\n CalculateClaimMergeParams,\n CalculateRebalanceParams,\n ClosePosOnlyReturnAmountCoinsParams,\n ClosePosReturnAmountCoinAParams,\n CreateClaimMergePayloadParams,\n CreateCompoundRebalanceAddPayload,\n CreateMovePositionPayloadParams,\n PreSwapParams,\n RebalanceResult,\n} from '../types'\nimport { Transaction } from '@mysten/sui/transactions'\nimport { d, fixCoinType, SuiAddressType, IModule, toDecimalsAmount } from '@cetusprotocol/common-sdk'\nimport { BuildRouterSwapParamsV3 } from '@cetusprotocol/aggregator-sdk'\nimport { BinUtils } from '@cetusprotocol/dlmm-sdk'\nimport { calcSwapAmountForTargetRatio } from '../utils/zap'\nimport { isEmptyObj, isNotMergeCoin, isSameType } from '../utils/compound'\n\nconst DEFAULT_SLIPPAGE = 0.005\nconst DEFAULT_DEPTH = 3\n\n/**\n * DLMM 复投/调仓模块。\n * 该模块负责三类核心能力:\n * 1) 仓位手续费与奖励的归集、可选合并兑换;\n * 2) 根据目标配比计算再平衡(是否需要先 swap);\n * 3) 关老仓并把资产迁移到新价格区间(move position)。\n */\nexport class CompoundModule implements IModule<CetusDlmmZapSDK> {\n protected _sdk: CetusDlmmZapSDK\n\n constructor(sdk: CetusDlmmZapSDK) {\n this._sdk = sdk\n }\n\n get sdk() {\n return this._sdk\n }\n\n /** 统一滑点处理:按向下取整保守估算可得数量,避免高估导致后续交易失败。 */\n private calculateAmountWithSlippage(amount: string, slippage: number): string {\n return d(amount).mul(d(1 - slippage)).floor().toString()\n }\n\n /**\n * 拉取单个仓位当前可领取的 fee/reward 快照。\n * 注意:这里只做读取,不构建交易,也不改变链上状态。\n */\n private async fetchFeeAndRewardSnapshot(params: {\n pool_id: string\n position_id: string\n coin_type_a: string\n coin_type_b: string\n rewarder_types: string[]\n }) {\n const { feeData, rewardData } = await this._sdk.DlmmSDK.Position.fetchPositionFeeAndReward([\n {\n pool_id: params.pool_id,\n position_id: params.position_id,\n coin_type_a: params.coin_type_a,\n coin_type_b: params.coin_type_b,\n reward_coins: params.rewarder_types || [],\n },\n ])\n return { fee: feeData[params.position_id], reward: rewardData[params.position_id] }\n }\n\n /**\n * 获取“归集后可用”的 A/B 两币数量:\n * - fee + reward 中同币种会合并到 coin_amount_a / coin_amount_b;\n * - 其它奖励币会尝试聚合路由估算后并入目标币;\n * - not_merge_coins 中的币不会进入 merge swap。\n */\n async getFeeAndReward(params: {\n pool_id: string\n position_id: string\n coin_type_a: SuiAddressType\n coin_type_b: SuiAddressType\n rewarder_types: string[]\n merge_swap_target_coin_type: string\n not_merge_coins: string[]\n }) {\n const { pool_id, position_id, coin_type_a, coin_type_b, rewarder_types, merge_swap_target_coin_type, not_merge_coins } = params\n let coin_amount_a = '0'\n let coin_amount_b = '0'\n const other_rewarder: Record<string, string> = {}\n const snapshot = await this.fetchFeeAndRewardSnapshot({ pool_id, position_id, coin_type_a, coin_type_b, rewarder_types })\n\n if (snapshot.fee) {\n // 手续费仅在“允许合并/保留”的币种范围内计入。\n coin_amount_a = isNotMergeCoin(not_merge_coins, coin_type_a) ? snapshot.fee.fee_owned_a : '0'\n coin_amount_b = isNotMergeCoin(not_merge_coins, coin_type_b) ? snapshot.fee.fee_owned_b : '0'\n }\n\n // 将奖励币按 A/B/其它 三类归并,后续仅“其它”进入聚合路由估算。\n snapshot.reward?.rewards?.forEach((rewarder) => {\n const rewardType = fixCoinType(rewarder.coin_type)\n if (rewardType === fixCoinType(coin_type_a) && isNotMergeCoin(not_merge_coins, coin_type_a)) {\n coin_amount_a = d(coin_amount_a).add(rewarder.reward_owned).toString()\n } else if (rewardType === fixCoinType(coin_type_b) && isNotMergeCoin(not_merge_coins, coin_type_b)) {\n coin_amount_b = d(coin_amount_b).add(rewarder.reward_owned).toString()\n } else if (rewardType !== fixCoinType(merge_swap_target_coin_type) && isNotMergeCoin(not_merge_coins, rewardType)) {\n other_rewarder[rewardType] = rewarder.reward_owned\n }\n })\n\n let mergeSwapResult\n if (!isEmptyObj(other_rewarder)) {\n // 对其它奖励币做一次“按输入金额”的合并路由查询,仅做预估,不发交易。\n mergeSwapResult = await this._sdk.AggregatorClient.findMergeSwapRouters({\n target: merge_swap_target_coin_type,\n byAmountIn: true,\n depth: DEFAULT_DEPTH,\n froms: Object.entries(other_rewarder).map(([coinType, amount]) => ({ coinType, amount })),\n })\n if (mergeSwapResult?.totalAmountOut) {\n // 预估输出统一扣默认滑点,保证上层展示与执行更保守。\n const out = this.calculateAmountWithSlippage(mergeSwapResult.totalAmountOut.toString(), DEFAULT_SLIPPAGE)\n if (fixCoinType(merge_swap_target_coin_type) === fixCoinType(coin_type_a)) coin_amount_a = d(coin_amount_a).add(out).toString()\n else coin_amount_b = d(coin_amount_b).add(out).toString()\n }\n }\n\n return { coin_amount_a, coin_amount_b, merge_routers: mergeSwapResult }\n }\n\n /**\n * 计算“claim 后一次性 merge 到目标币”的路由输入集合。\n * 返回 null 表示无可合并资产,调用方可直接跳过 merge 流程。\n */\n async calculateClaimMerge(params: CalculateClaimMergeParams) {\n const { coin_type_a, coin_type_b, pool_id, position_id, rewarder_types, target_coin_type, not_merge_coins } = params\n const mergeSwapFromMap: Record<string, { coinType: string; amount: string }> = {}\n const normalizedNotMergeCoins = new Set(not_merge_coins.map((coin) => fixCoinType(coin)))\n const addMergeFrom = (coinType: string, amount: string) => {\n if (d(amount).lte(0)) return\n const normalizedCoinType = fixCoinType(coinType)\n if (normalizedNotMergeCoins.has(normalizedCoinType)) return\n\n if (!mergeSwapFromMap[normalizedCoinType]) {\n mergeSwapFromMap[normalizedCoinType] = { coinType, amount }\n return\n }\n\n mergeSwapFromMap[normalizedCoinType].amount = d(mergeSwapFromMap[normalizedCoinType].amount).add(amount).toString()\n }\n const snapshot = await this.fetchFeeAndRewardSnapshot({ pool_id, position_id, coin_type_a, coin_type_b, rewarder_types })\n\n if (snapshot.fee) {\n // fee 为正且不在禁止列表中,才加入 merge 输入。\n addMergeFrom(coin_type_a, snapshot.fee.fee_owned_a)\n addMergeFrom(coin_type_b, snapshot.fee.fee_owned_b)\n }\n snapshot.reward?.rewards?.forEach((rewarder) => {\n addMergeFrom(rewarder.coin_type, rewarder.reward_owned)\n })\n\n const mergeSwapFroms = Object.values(mergeSwapFromMap)\n if (mergeSwapFroms.length === 0) return null\n return this._sdk.AggregatorClient.findMergeSwapRouters({ target: target_coin_type, byAmountIn: true, depth: DEFAULT_DEPTH, froms: mergeSwapFroms })\n }\n\n /**\n * 计算再平衡方案:\n * 1) 先用当前 A/B 数量求“理论可加仓分布”;\n * 2) 若明显偏单边,则按目标配比求需 swap 数量;\n * 3) 使用 swap 后的真实数量重新计算最终 bin_infos。\n */\n async calculateRebalance(params: CalculateRebalanceParams): Promise<RebalanceResult> {\n const { pool_id, amount_a, amount_b, active_id, bin_step, lower_bin_id, upper_bin_id, strategy_type, active_bin_of_pool, slippage } = params\n const initialInfos = await this._sdk.DlmmSDK.Position.calculateAddLiquidityInfo({\n pool_id,\n amount_a,\n amount_b,\n active_id,\n bin_step,\n lower_bin_id,\n upper_bin_id,\n active_bin_of_pool,\n strategy_type,\n })\n // 用模拟值计算区间目标配比,避免受用户输入比例影响。\n const simulationInfos = await this._sdk.DlmmSDK.Position.calculateAddLiquidityInfo({\n pool_id,\n coin_amount: toDecimalsAmount(100, 9).toString(),\n fix_amount_a: active_id < upper_bin_id,\n active_id,\n bin_step,\n lower_bin_id,\n upper_bin_id,\n active_bin_of_pool,\n strategy_type,\n })\n\n const simulationAmountA = d(simulationInfos.amount_a)\n const simulationAmountB = d(simulationInfos.amount_b)\n\n // 当前价格使用 active_id + bin_step 推导,不依赖 CLMM 的 sqrt_price。\n const currentPrice = BinUtils.getPricePerLamportFromBinId(active_id, bin_step)\n let swapCalc: { a_to_b: boolean; swap_amount: string }\n\n if (simulationAmountA.eq(0) && simulationAmountB.eq(0)) {\n // 区间不可加仓,直接返回当前计算结果。\n return { bin_infos: initialInfos, lower_bin_id, upper_bin_id, use_amount_a: initialInfos.amount_a, use_amount_b: initialInfos.amount_b, fix_amount_a: d(initialInfos.amount_a).gte(initialInfos.amount_b), remain_amount: '0' }\n } else if (simulationAmountA.eq(0)) {\n // 区间为单边 B:A 全量换成 B。\n swapCalc = { a_to_b: true, swap_amount: amount_a }\n } else if (simulationAmountB.eq(0)) {\n // 区间为单边 A:B 全量换成 A。\n swapCalc = { a_to_b: false, swap_amount: amount_b }\n } else {\n const targetRatio = simulationAmountB.div(simulationAmountA).toString()\n swapCalc = calcSwapAmountForTargetRatio(amount_a, amount_b, currentPrice, targetRatio)\n }\n\n if (d(swapCalc.swap_amount).lte(0)) {\n // 不需要 swap,保持初始加仓方案。\n return { bin_infos: initialInfos, lower_bin_id, upper_bin_id, use_amount_a: initialInfos.amount_a, use_amount_b: initialInfos.amount_b, fix_amount_a: d(initialInfos.amount_a).gte(initialInfos.amount_b), remain_amount: '0' }\n }\n\n const fromCoinType = swapCalc.a_to_b ? params.coin_type_a : params.coin_type_b\n const targetCoinType = swapCalc.a_to_b ? params.coin_type_b : params.coin_type_a\n const swapResult = await this._sdk.Zap.findRouters(fromCoinType, targetCoinType, swapCalc.swap_amount)\n const out = this.calculateAmountWithSlippage(swapResult.swap_out_amount, slippage)\n // 用“swap 实际输入 + 滑点后输出”重算可用资产,保证后续 addLiquidity 可执行。\n const realAmountA = swapCalc.a_to_b ? d(amount_a).sub(swapResult.swap_in_amount).toFixed(0) : d(amount_a).add(out).toFixed(0)\n const realAmountB = swapCalc.a_to_b ? d(amount_b).add(out).toFixed(0) : d(amount_b).sub(swapResult.swap_in_amount).toFixed(0)\n\n const finalInfos = await this._sdk.DlmmSDK.Position.calculateAddLiquidityInfo({\n pool_id,\n amount_a: realAmountA,\n amount_b: realAmountB,\n active_id,\n bin_step,\n lower_bin_id,\n upper_bin_id,\n active_bin_of_pool,\n strategy_type,\n })\n const remainAmountA = d(realAmountA).sub(finalInfos.amount_a).abs()\n const remainAmountB = d(realAmountB).sub(finalInfos.amount_b).abs()\n return {\n bin_infos: finalInfos,\n lower_bin_id,\n upper_bin_id,\n use_amount_a: finalInfos.amount_a,\n use_amount_b: finalInfos.amount_b,\n fix_amount_a: d(finalInfos.amount_a).gte(finalInfos.amount_b),\n remain_amount: remainAmountA.lt(remainAmountB) ? remainAmountA.toFixed(0) : remainAmountB.toFixed(0),\n swap_result: swapResult,\n }\n }\n\n /** 单次预交换查询:返回路由、路由价格、滑点后最小可得数量。 */\n async preSwap(params: PreSwapParams): Promise<{ swapResult: any; routerPrice: string; swapAmountOutWithSlippage: string }> {\n const { from_coin_type, target_coin_type, amount, is_a2b, slippage } = params\n const swapResult = await this._sdk.Zap.findRouters(from_coin_type, target_coin_type, amount)\n const swapAmountOutWithSlippage = this.calculateAmountWithSlippage(swapResult.swap_out_amount, slippage)\n const routerPrice = is_a2b ? d(swapResult.swap_out_amount).div(swapResult.swap_in_amount).toString() : d(swapResult.swap_in_amount).div(swapResult.swap_out_amount).toString()\n return { swapResult, routerPrice, swapAmountOutWithSlippage }\n }\n\n /**\n * 构造“领取 fee/reward 且不立即转账”的交易片段,并把同币奖励合并到 fee 结果中:\n * - fee_a / fee_b 作为后续复投主输入;\n * - 其它奖励币独立返回,交给上层决定是 merge 还是直接转走。\n */\n async collectFeeAndRewardsAndReturnCoins(params: { pool_id: string; pos_id: string; coin_type_a: string; coin_type_b: string; rewarder_coin_types: string[] }, tx: Transaction) {\n const { pool_id, pos_id, coin_type_a, coin_type_b, rewarder_coin_types } = params\n this._sdk.DlmmSDK.Position.updatePositionFeeAndRewards({ pool_id, position_id: pos_id, coin_type_a, coin_type_b }, tx)\n const feeRes = this._sdk.DlmmSDK.Position.collectFeePayloadWithoutTransfer({ pool_id, position_id: pos_id, coin_type_a, coin_type_b }, tx)\n const fee_a = feeRes.fee_a_obj\n const fee_b = feeRes.fee_b_obj\n const rewardRes = this._sdk.DlmmSDK.Position.collectRewardPayloadWithoutTransfer({ pool_id, position_id: pos_id, coin_type_a, coin_type_b, reward_coins: rewarder_coin_types || [] }, tx)\n\n const other_rewarder: Record<string, any> = {}\n rewardRes.reward_coin_objs.forEach((coinObj, index) => {\n const rewardType = rewarder_coin_types[index]\n // 同币奖励直接 merge,减少后续 coin object 数量。\n if (isSameType(rewardType, coin_type_a)) tx.mergeCoins(fee_a, [coinObj])\n else if (isSameType(rewardType, coin_type_b)) tx.mergeCoins(fee_b, [coinObj])\n else other_rewarder[rewardType] = coinObj\n })\n return { fee_a, fee_b, other_rewarder }\n }\n\n /**\n * 领取并处理奖励:\n * - A/B 同币奖励直接并入 coin_a/coin_b;\n * - 可 merge 的其它奖励币收集进 mergeInputCoinMap;\n * - 不处理的其它奖励币直接转回用户地址。\n */\n async claimFeeAndRewardsAndMergeRewards(\n baseParams: { pool_id: string; pos_id: string; coin_type_a: SuiAddressType; coin_type_b: SuiAddressType; rewarder_coin_types: SuiAddressType[] },\n rewarderMergeOption?: { merge_routers: any; slippage: number; not_merge_coins: string[] },\n tx = new Transaction()\n ) {\n const { coin_type_a, coin_type_b } = baseParams\n const { fee_a, fee_b, other_rewarder } = await this.collectFeeAndRewardsAndReturnCoins(baseParams, tx)\n let coin_a: any = fee_a\n let coin_b: any = fee_b\n const mergeInputCoinMap: any = {}\n for (const key in other_rewarder) {\n const coin = other_rewarder[key]\n if (rewarderMergeOption && isNotMergeCoin(rewarderMergeOption.not_merge_coins, key)) {\n if (fixCoinType(key) === fixCoinType(coin_type_a)) tx.mergeCoins(coin_a, [coin])\n else if (fixCoinType(key) === fixCoinType(coin_type_b)) tx.mergeCoins(coin_b, [coin])\n else mergeInputCoinMap[fixCoinType(key)] = { coinType: key, coin }\n } else if (fixCoinType(coin_type_a) === fixCoinType(key)) {\n tx.mergeCoins(coin_a, [coin])\n } else if (fixCoinType(coin_type_b) === fixCoinType(key)) {\n tx.mergeCoins(coin_b, [coin])\n } else {\n // 未参与 merge 的非目标奖励币直接返还给用户,避免残留在交易上下文中。\n tx.transferObjects([coin], this.sdk.getSenderAddress())\n }\n }\n\n if (!isEmptyObj(mergeInputCoinMap) && rewarderMergeOption?.merge_routers) {\n // 执行多币合并兑换,并将目标币并入 A/B 主币对象。\n const inputCoins = rewarderMergeOption.merge_routers.allRoutes?.map((item: any) => mergeInputCoinMap[fixCoinType(item.paths[0].from)])\n const targetCoin = await this._sdk.AggregatorClient.mergeSwap({ router: rewarderMergeOption.merge_routers, inputCoins, slippage: rewarderMergeOption.slippage, txb: tx })\n const targetType = rewarderMergeOption.merge_routers.allRoutes[0].paths[rewarderMergeOption.merge_routers.allRoutes[0].paths.length - 1].target\n if (fixCoinType(targetType) === fixCoinType(coin_type_a)) tx.mergeCoins(coin_a, [targetCoin])\n else tx.mergeCoins(coin_b, [targetCoin])\n }\n return { coin_a, coin_b }\n }\n\n /**\n * 关闭或部分移除老仓,仅返回“仓位本金币对象”:\n * - fee/reward 先领取并直接转给用户;\n * - close_position=true 走 closePosition;\n * - 否则走 removeLiquidity(按 remove_percent)。\n */\n async closePosOnlyReturnAmountCoins(params: ClosePosOnlyReturnAmountCoinsParams, tx: Transaction) {\n const { pool_id, pos_id, coin_type_a, coin_type_b, rewarder_coin_types, close_position = true } = params\n const { fee_a, fee_b, other_rewarder } = await this.collectFeeAndRewardsAndReturnCoins(params, tx)\n tx.transferObjects([fee_a, fee_b], this.sdk.getSenderAddress())\n for (const key in other_rewarder) tx.transferObjects([other_rewarder[key]], this.sdk.getSenderAddress())\n if (close_position) {\n const { coin_a_obj, coin_b_obj } = this._sdk.DlmmSDK.Position.closePositionNoTransferPayload(\n { pool_id, position_id: pos_id, reward_coins: rewarder_coin_types, coin_type_a, coin_type_b },\n tx\n )\n return { coin_a: coin_a_obj, coin_b: coin_b_obj }\n }\n // 不关闭仓位时,仅移除指定比例流动性并返回对应资产。\n const { coin_a_obj, coin_b_obj } = this._sdk.DlmmSDK.Position.removeLiquidityNoTransferPayload(\n {\n pool_id,\n position_id: pos_id,\n active_id: params.active_id,\n bin_step: params.bin_step,\n bin_infos: params.bin_infos,\n slippage: params.slippage,\n reward_coins: rewarder_coin_types,\n collect_fee: false,\n remove_percent: params.remove_percent,\n coin_type_a,\n coin_type_b,\n },\n tx\n )\n return { coin_a: coin_a_obj, coin_b: coin_b_obj }\n }\n\n /**\n * 关闭/部分移除仓位并保留 A/B 两币对象:\n * - 与 closePosOnlyReturnAmountCoins 的区别是,这里会先做奖励 merge;\n * - 最终把仓位本金并回 coin_a/coin_b,作为后续复投输入。\n */\n async closePosReturnCoinWithMerge(params: ClosePosReturnAmountCoinAParams, rewarderMergeOption?: { merge_routers: any; slippage: number; not_merge_coins: string[] }, tx = new Transaction()) {\n const { coin_type_a, coin_type_b, pool_id, pos_id, close_position = true } = params\n const { coin_a, coin_b } = await this.claimFeeAndRewardsAndMergeRewards(params, rewarderMergeOption, tx)\n const res = close_position\n ? this._sdk.DlmmSDK.Position.closePositionNoTransferPayload(\n { pool_id, position_id: pos_id, reward_coins: params.rewarder_coin_types, coin_type_a, coin_type_b },\n tx\n )\n : this._sdk.DlmmSDK.Position.removeLiquidityNoTransferPayload(\n {\n pool_id,\n position_id: pos_id,\n active_id: params.active_id,\n bin_step: params.bin_step,\n bin_infos: params.bin_infos,\n slippage: params.slippage,\n reward_coins: params.rewarder_coin_types,\n collect_fee: false,\n remove_percent: params.remove_percent,\n coin_type_a,\n coin_type_b,\n },\n tx\n )\n tx.mergeCoins(coin_a, [res.coin_a_obj])\n tx.mergeCoins(coin_b, [res.coin_b_obj])\n return { coin_a, coin_b }\n }\n\n /**\n * 仅构建 claim + merge + transfer 的独立交易:\n * 适用于“先把奖励统一换成目标币并提现”场景,不含加仓行为。\n */\n async createClaimMergePayload(params: CreateClaimMergePayloadParams) {\n const { coin_type_a, coin_type_b, not_merge_coins, merge_routers, slippage, target_coin_type } = params\n const tx = new Transaction()\n const { fee_a, fee_b, other_rewarder } = await this.collectFeeAndRewardsAndReturnCoins(params, tx)\n const inputCoinMap: any = {}\n let coin_a: any\n let coin_b: any\n // A/B fee 先按策略判断是否保留用于 merge,否则直接返还用户。\n if (fee_a && isNotMergeCoin(not_merge_coins, coin_type_a) && !isSameType(target_coin_type, coin_type_a)) coin_a = fee_a\n else if (fee_a) tx.transferObjects([fee_a], this.sdk.getSenderAddress())\n if (fee_b && isNotMergeCoin(not_merge_coins, coin_type_b) && !isSameType(target_coin_type, coin_type_b)) coin_b = fee_b\n else if (fee_b) tx.transferObjects([fee_b], this.sdk.getSenderAddress())\n\n for (const key in other_rewarder) {\n const coin = other_rewarder[key]\n if (isNotMergeCoin(not_merge_coins, key) && !isSameType(target_coin_type, key)) {\n if (isSameType(key, coin_type_a)) coin_a ? tx.mergeCoins(coin_a, [coin]) : (coin_a = coin)\n else if (isSameType(key, coin_type_b)) coin_b ? tx.mergeCoins(coin_b, [coin]) : (coin_b = coin)\n else inputCoinMap[fixCoinType(key)] = { coinType: key, coin }\n } else tx.transferObjects([coin], this.sdk.getSenderAddress())\n }\n\n // 构造 merge 输入并执行最终兑换,输出目标币后转给用户。\n if (coin_a) inputCoinMap[fixCoinType(coin_type_a)] = { coinType: coin_type_a, coin: coin_a }\n if (coin_b) inputCoinMap[fixCoinType(coin_type_b)] = { coinType: coin_type_b, coin: coin_b }\n const inputCoins = merge_routers.allRoutes?.map((item: any) => inputCoinMap[fixCoinType(item.paths[0].from)])\n const targetCoin = await this._sdk.AggregatorClient.mergeSwap({ router: merge_routers, inputCoins, slippage, txb: tx })\n tx.transferObjects([targetCoin], this.sdk.getSenderAddress())\n return tx\n }\n\n /**\n * 复投主流程(不迁仓):\n * - 先 claim + 可选 merge;\n * - 若 rebalance 需要 swap,则在 tx 内先完成路由兑换;\n * - 最后按 rebalance 计算结果 addLiquidity 回原仓位。\n */\n async createCompoundRebalanceAddPayload(params: CreateCompoundRebalanceAddPayload) {\n const tx = params.tx || new Transaction()\n const { baseParams, rebalancePre, rewarderMergeOption } = params\n const { pool_id, pos_id, coin_type_a, coin_type_b, active_id, bin_step, strategy_type } = baseParams\n const { slippage } = rewarderMergeOption\n const { swap_result, bin_infos } = rebalancePre\n const { coin_a, coin_b } = await this.claimFeeAndRewardsAndMergeRewards(baseParams as any, rewarderMergeOption, tx)\n\n if (swap_result?.route_obj) {\n // 路由 from 决定拆分 coin_a 或 coin_b,swap 后再并入对侧币对象。\n const fromIsCoinA = fixCoinType(swap_result.route_obj.paths[0].from) === fixCoinType(coin_type_a)\n const swapInputCoin = fromIsCoinA ? tx.splitCoins(coin_a, [tx.pure.u64(swap_result.swap_in_amount)]) : tx.splitCoins(coin_b, [tx.pure.u64(swap_result.swap_in_amount)])\n const swapOutCoin = await this._sdk.AggregatorClient.fixableRouterSwapV3({\n router: swap_result.route_obj,\n slippage,\n txb: tx,\n inputCoin: swapInputCoin,\n } as BuildRouterSwapParamsV3)\n if (fromIsCoinA) tx.mergeCoins(coin_b, [swapOutCoin])\n else tx.mergeCoins(coin_a, [swapOutCoin])\n }\n\n this._sdk.DlmmSDK.Position.addLiquidityPayload(\n {\n pool_id,\n position_id: pos_id,\n coin_type_a,\n coin_type_b,\n bin_infos,\n active_id,\n bin_step,\n strategy_type,\n max_price_slippage: slippage,\n collect_fee: false,\n reward_coins: [],\n use_bin_infos: false,\n coin_object_id_a: coin_a,\n coin_object_id_b: coin_b,\n },\n tx\n )\n return tx\n }\n\n /**\n * 迁仓主流程(move position):\n * 1) 老仓位取回资产(可选是否已 claim);\n * 2) 按 rebalancePre 需要执行一次 swap;\n * 3) 将资产按新 bin 区间 addLiquidity 到新仓位配置。\n */\n async createMovePositionPayload(params: CreateMovePositionPayloadParams, tx = new Transaction()) {\n const { newPos, oldPos, rebalancePre, slippage, rewarderMergeOption, have_claim } = params\n const { pool_id, pos_id, coin_type_a, coin_type_b, rewarder_coin_types } = oldPos\n const { swap_result, bin_infos } = rebalancePre\n const res = have_claim\n // have_claim=true 表示外部已处理过奖励 merge,这里只拿本金资产。\n ? await this.closePosOnlyReturnAmountCoins(\n {\n pool_id,\n pos_id,\n coin_type_a,\n coin_type_b,\n rewarder_coin_types,\n active_id: oldPos.active_id,\n bin_step: oldPos.bin_step,\n slippage: oldPos.slippage,\n bin_infos: oldPos.bin_infos,\n remove_percent: oldPos.remove_percent,\n close_position: oldPos.close_position ?? true,\n },\n tx\n )\n // 否则在本流程内一并处理奖励 merge。\n : await this.closePosReturnCoinWithMerge(\n {\n pool_id,\n pos_id,\n coin_type_a,\n coin_type_b,\n rewarder_coin_types,\n active_id: oldPos.active_id,\n bin_step: oldPos.bin_step,\n slippage: oldPos.slippage,\n bin_infos: oldPos.bin_infos,\n remove_percent: oldPos.remove_percent,\n close_position: oldPos.close_position ?? true,\n },\n rewarderMergeOption,\n tx\n )\n\n let coin_a = res.coin_a\n let coin_b = res.coin_b\n if (swap_result?.route_obj) {\n const fromIsCoinA = fixCoinType(swap_result.route_obj.paths[0].from) === fixCoinType(coin_type_a)\n const swapInputCoin = fromIsCoinA ? tx.splitCoins(coin_a, [tx.pure.u64(swap_result.swap_in_amount)]) : tx.splitCoins(coin_b, [tx.pure.u64(swap_result.swap_in_amount)])\n const swapOutCoin = await this._sdk.AggregatorClient.fixableRouterSwapV3({\n router: swap_result.route_obj,\n slippage,\n txb: tx,\n inputCoin: swapInputCoin,\n } as BuildRouterSwapParamsV3)\n if (fromIsCoinA) tx.mergeCoins(coin_b, [swapOutCoin])\n else tx.mergeCoins(coin_a, [swapOutCoin])\n }\n\n\n\n // 使用 newPos 的 bin 区间与策略,把资产迁移到新仓位分布。\n this._sdk.DlmmSDK.Position.addLiquidityPayload(\n {\n pool_id,\n coin_type_a,\n coin_type_b,\n lower_bin_id: newPos.lower_bin_id,\n upper_bin_id: newPos.upper_bin_id,\n active_id: newPos.active_id,\n bin_step: newPos.bin_step,\n strategy_type: newPos.strategy_type,\n active_bin_of_pool: newPos.active_bin_of_pool,\n max_price_slippage: slippage,\n use_bin_infos: false,\n bin_infos,\n coin_object_id_a: tx.splitCoins(coin_a, [tx.pure.u64(bin_infos.amount_a)]),\n coin_object_id_b: tx.splitCoins(coin_b, [tx.pure.u64(bin_infos.amount_b)]),\n } as any,\n tx\n )\n\n tx.transferObjects([coin_a, coin_b], this.sdk.getSenderAddress())\n\n return tx\n }\n}\n","import BN from 'bn.js'\nimport { ClmmPoolUtil, d, fixCoinType } from '@cetusprotocol/common-sdk'\n\n/**\n * Calculate liquidity amounts with fallback strategy\n * First tries to fix amount_a, if not enough then tries to fix amount_b\n * @param current_sqrt_price - Current sqrt price of the pool\n * @param tick_lower - Lower tick boundary of the position\n * @param tick_upper - Upper tick boundary of the position\n * @param amount_a - Amount of token A available\n * @param amount_b - Amount of token B available\n * @param slippage - Slippage tolerance for the calculation\n * @returns Object containing:\n * - liquidity: Calculated liquidity amount\n * - use_amount_a: Amount of token A to be used\n * - use_amount_b: Amount of token B to be used\n * - amount_limit_a: Minimum amount limit for token A\n * - amount_limit_b: Minimum amount limit for token B\n * - fix_amount_a: Whether amount A was fixed (true) or amount B was fixed (false)\n * - remain_amount: Remaining amount of the non-fixed token\n * - is_enough_amount: Whether there was enough amount for the calculation\n */\nexport function calculateLiquidityWithFallback({\n current_sqrt_price,\n tick_lower,\n tick_upper,\n amount_a,\n amount_b,\n slippage\n}: {\n current_sqrt_price: string,\n tick_lower: number,\n tick_upper: number,\n amount_a: string,\n amount_b: string,\n slippage: number\n}\n) {\n // First try to fix amount_a (fix_amount_a = true)\n const fixAmountA = new BN(amount_a)\n\n const liquidityInputA = ClmmPoolUtil.estLiquidityAndCoinAmountFromOneAmounts(\n tick_lower,\n tick_upper,\n fixAmountA,\n true, // fix_amount_a = true\n true, // round_up = true\n slippage,\n new BN(current_sqrt_price)\n )\n\n const use_amount_a_fixed = fixAmountA.toString()\n const use_amount_b_calculated = liquidityInputA.coin_amount_b.toString()\n\n const remain_amount_b = d(amount_b).sub(use_amount_b_calculated)\n const is_enough_amount_b = remain_amount_b.gte(0)\n\n // If we have enough amount_b, return the result with fix_amount_a = true\n if (is_enough_amount_b) {\n return {\n liquidity: liquidityInputA.liquidity_amount,\n use_amount_a: use_amount_a_fixed,\n use_amount_b: use_amount_b_calculated,\n amount_limit_a: liquidityInputA.coin_amount_limit_a,\n amount_limit_b: liquidityInputA.coin_amount_limit_b,\n fix_amount_a: true,\n remain_amount: remain_amount_b,\n is_enough_amount: true\n }\n }\n\n // If not enough amount_b, try to fix amount_b (fix_amount_a = false)\n const fixAmountB = new BN(amount_b)\n console.log(\"🚀 ~ calculateLiquidityWithFallback ~ fixAmountB:\", fixAmountB.toString())\n\n const liquidityInputB = ClmmPoolUtil.estLiquidityAndCoinAmountFromOneAmounts(\n tick_lower,\n tick_upper,\n fixAmountB,\n false, // fix_amount_a = false\n true, // round_up = true\n slippage,\n new BN(current_sqrt_price)\n )\n console.log(\"🚀 ~ calculateLiquidityWithFallback ~ liquidityInputB:\", JSON.stringify(liquidityInputB, null, 2))\n\n const use_amount_a_calculated = liquidityInputB.coin_amount_a.toString()\n const use_amount_b_fixed = fixAmountB.toString()\n\n const remain_amount_a = d(amount_a).sub(use_amount_a_calculated)\n const is_enough_amount_a = remain_amount_a.gte(0)\n\n // Return the result with fix_amount_a = false\n return {\n liquidity: liquidityInputB.liquidity_amount,\n use_amount_a: use_amount_a_calculated,\n use_amount_b: use_amount_b_fixed,\n amount_limit_a: liquidityInputB.coin_amount_limit_a,\n amount_limit_b: liquidityInputB.coin_amount_limit_b,\n fix_amount_a: false,\n remain_amount: remain_amount_a,\n is_enough_amount: is_enough_amount_a\n }\n}\n\nexport function isEmptyObj(obj: any) {\n if (obj === null || typeof obj !== 'object') {\n return true;\n }\n return Object.keys(obj).length === 0;\n}\n\nexport function isNotMergeCoin(not_merge_coins: string[], coin_type: string) {\n const fixCoinTypeNotMergeCoins = not_merge_coins.map((coin) => fixCoinType(coin))\n return !fixCoinTypeNotMergeCoins.includes(fixCoinType(coin_type))\n}\n\nexport function isSameType(coin_type1: string, coin_type2: string) {\n return fixCoinType(coin_type1) === fixCoinType(coin_type2)\n}\n","import { CetusDlmmZapSDK, SdkOptions } from './sdk'\n\nexport * from './utils'\nexport * from './types'\nexport * from './modules'\nexport * from './config'\nexport * from './errors'\nexport { CetusDlmmZapSDK, SdkOptions }\nexport default CetusDlmmZapSDK\n"],"mappings":"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","names":["require_bn","__commonJSMin","exports","module","assert","val","msg","inherits","ctor","superCtor","TempCtor","BN","number","base","endian","Buffer","num","left","right","start","i","j","w","off","parseHex4Bits","string","index","c","parseHexByte","lowerBound","parseLength","parseBase","str","end","mul","r","b","len","limbLen","limbPow","total","mod","word","pow","dest","move","src","size","inspect","zeros","groupSizes","groupBases","padding","out","carry","groupSize","groupBase","ret","length","allocate","ArrayType","byteLength","reqLength","res","postfix","position","shift","t","hi","toBitArray","bit","wbit","width","a","bytesNeeded","bitsLeft","cmp","smallMulTo","self","lo","k","ncarry","rword","maxJ","comb10MulTo","o","mid","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","w1","w2","w3","w4","w5","w6","w7","w8","w9","w10","w11","w12","w13","w14","w15","w16","w17","w18","bigMulTo","hncarry","jumboMulTo","FFTM","x","y","N","l","rb","rbt","rws","iws","rtws","itws","s","rtwdf","itwdf","p","rtwdf_","itwdf_","re","ie","ro","io","rx","n","m","odd","ws","ph","_","rwst","iwst","nrws","nrwst","niwst","rmws","isNegNum","q","bits","carryMask","newCarry","hint","extended","h","mask","maskedWords","mode","bhi","bhiBits","diff","qj","positive","div","dm","half","r2","acc","A","B","C","D","g","yp","xp","im","jm","x1","x2","delta","negative","Red","ctx","primes","MPrime","name","tmp","rlen","input","K256","output","outLen","prev","next","P224","P192","P25519","prime","mod3","one","nOne","lpow","z","inv","windowSize","wnd","current","currentLen","Mont","u","AggregatorClient","Env","normalizeSuiAddress","CetusDlmmSDK","SdkWrapper","FullRpcUrlMainnet","GraphRpcUrlMainnet","zapMainnet","FullRpcUrlTestnet","GraphRpcUrlTestnet","zapTestnet","import_bn","Transaction","CoinAssist","d","DETAILS_KEYS","fromDecimalsAmount","toDecimalsAmount","BaseError","ZapErrorCode","ZapError","message","errorCode","details","e","code","handleError","error","handleMessageError","defaultSwapSlippage","import_bn","ClmmPoolUtil","d","TickMath","calculateLiquidityAmountEnough","amount_a","amount_b","curr_sqrt_price","lower_tick","upper_tick","slippage","fix_amount_a","fixCoinAmount","BN","liquidityInput","use_amount_a","use_amount_b","remain_amount_a","remain_amount_b","calculateLiquidityAmountSide","currTick","fix_liquidity_amount_a","res","calcSwapAmountForTargetRatio","current_price","target_ratio","amountA","amountB","price","target","a_to_b","finalA","maxSwap","maxR","minR","left","right","best","computeFinal","x","A","B","i","mid","R","calcExactSwapAmount","coin_amount","amount","A0","B0","BinUtils","ZapModule","sdk","options","mode_options","fix_amount_a","coin_amount","bin_step","pool_id","active_id","lower_bin_id","upper_bin_id","active_bin_of_pool","strategy_type","pool","best_swap_result","_fix_amount_a","_coin_amount","d","liquidity_info","amount_a","amount_b","target_rate","real_price","price_result","swap_amount","final_amount_a","final_amount_b","calcExactSwapAmount","swap_amount_in","best_liquidity_info","temp_swap_result","count","max_remain_rate","cached_swap_result","cached_liquidity_info","cached_real_remain_rate","deposit_amount","swap_out_amount","deposit_amount_other","real_remain_rate","handleMessageError","DETAILS_KEYS","tx","swap_slippage","defaultSwapSlippage","deposit_obj","slippage","pos_obj","swap_result","bin_infos","Transaction","coin_type_a","coin_type_b","deposit_amount_a_coin","deposit_amount_b_coin","coin_type","swap_in_amount","route_obj","swap_amount_in_coin","CoinAssist","routerParamsV3","swap_out_coin","addOption","from","target","amount","providers","client","findRouterParams","BN","res","error","handleError","is_receive_coin_a","mode","remove_bin_range","prices","coin_decimal_a","coin_decimal_b","price","coin_a_price","coin_b_price","active_bin","user_total_amount_a","user_total_amount_b","available_amount","bin","user_total_amount_a_no_active","user_total_amount_b_no_active","transformToAmountB","toDecimalsAmount","fromDecimalsAmount","transformToAmountA","expected_receive_amount","remove_percent","remove_liquidity_info","withdraw_obj","collect_fee","reward_coins","position_id","is_close_position","removeOption","coin_a_obj","coin_b_obj","Transaction","d","fixCoinType","toDecimalsAmount","BinUtils","import_bn","ClmmPoolUtil","d","fixCoinType","calculateLiquidityWithFallback","current_sqrt_price","tick_lower","tick_upper","amount_a","amount_b","slippage","fixAmountA","BN","liquidityInputA","use_amount_a_fixed","use_amount_b_calculated","remain_amount_b","fixAmountB","liquidityInputB","use_amount_a_calculated","use_amount_b_fixed","remain_amount_a","is_enough_amount_a","isEmptyObj","obj","isNotMergeCoin","not_merge_coins","coin_type","coin","isSameType","coin_type1","coin_type2","DEFAULT_SLIPPAGE","DEFAULT_DEPTH","CompoundModule","sdk","amount","slippage","d","params","feeData","rewardData","pool_id","position_id","coin_type_a","coin_type_b","rewarder_types","merge_swap_target_coin_type","not_merge_coins","coin_amount_a","coin_amount_b","other_rewarder","snapshot","isNotMergeCoin","rewarder","rewardType","fixCoinType","mergeSwapResult","isEmptyObj","coinType","out","target_coin_type","mergeSwapFromMap","normalizedNotMergeCoins","coin","addMergeFrom","normalizedCoinType","mergeSwapFroms","amount_a","amount_b","active_id","bin_step","lower_bin_id","upper_bin_id","strategy_type","active_bin_of_pool","initialInfos","simulationInfos","toDecimalsAmount","simulationAmountA","simulationAmountB","currentPrice","BinUtils","swapCalc","targetRatio","calcSwapAmountForTargetRatio","fromCoinType","targetCoinType","swapResult","realAmountA","realAmountB","finalInfos","remainAmountA","remainAmountB","from_coin_type","is_a2b","swapAmountOutWithSlippage","routerPrice","tx","pos_id","rewarder_coin_types","feeRes","fee_a","fee_b","rewardRes","coinObj","index","isSameType","baseParams","rewarderMergeOption","Transaction","coin_a","coin_b","mergeInputCoinMap","key","inputCoins","item","targetCoin","targetType","close_position","coin_a_obj","coin_b_obj","res","merge_routers","inputCoinMap","rebalancePre","swap_result","bin_infos","fromIsCoinA","swapInputCoin","swapOutCoin","newPos","oldPos","have_claim","SuiJsonRpcClient","CetusDlmmZapSDK","_CetusDlmmZapSDK","SdkWrapper","options","dlmmSDK","ZapModule","CompoundModule","CetusDlmmSDK","AggregatorClient","normalizeSuiAddress","Env","pythUrls","value","validate","providers","url","dlmm_sdk","env","full_rpc_url","zapMainnet","zapTestnet","index_default","CetusDlmmZapSDK"]}
|