tx · HfZupzK9Mcy2Lv4p4Vpqo2uKoQP6nLSCJ4AQJUEJhJL7

3N4revPn12feiSAyC78tAZEJfsyprVYPzsL:  -0.05000000 Waves

2022.02.21 19:03 [1933634] smart account 3N4revPn12feiSAyC78tAZEJfsyprVYPzsL > SELF 0.00000000 Waves

{ "type": 13, "id": "HfZupzK9Mcy2Lv4p4Vpqo2uKoQP6nLSCJ4AQJUEJhJL7", "fee": 5000000, "feeAssetId": null, "timestamp": 1645459407221, "version": 2, "chainId": 84, "sender": "3N4revPn12feiSAyC78tAZEJfsyprVYPzsL", "senderPublicKey": "5smGxL7bfeRokaN53Z31Y72dF2Lkr5Cg1kuWRV3gniNe", "proofs": [ "48mrdkgkskUZnctgoVUspvAgeZsQuw2A8hMV53dK8E6b6WR6FSbEP1kUPqmHCDA5E5qYk45j54bPJLxmSFXHjpjR" ], "script": "base64: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bGF0ZVNlbmRBbW91bnQAAAAGAAAACGJhbGFuY2VBAAAACGJhbGFuY2VCAAAAFWFtb3VudFRvU2VuZEVzdGltYXRlZAAAABVtaW5Ub2tlblJlY2VpdmVBbW91bnQAAAASdG9rZW5SZWNlaXZlQW1vdW50AAAAB3Rva2VuSWQEAAAADXNsaXBwYWdlVmFsdWUJAABlAAAAAgUAAAAGc2NhbGU4CQAAaQAAAAIJAABoAAAAAgUAAAAGc2NhbGU4AAAAAAAAAAABAAAAAAAAmJaABAAAAB5kZWx0YUJldHdlZW5NYXhBbmRNaW5TZW5kVmFsdWUJAABlAAAAAgUAAAAVYW1vdW50VG9TZW5kRXN0aW1hdGVkBQAAABVtaW5Ub2tlblJlY2VpdmVBbW91bnQEAAAAAXgJAABkAAAAAgUAAAAIYmFsYW5jZUEFAAAAEnRva2VuUmVjZWl2ZUFtb3VudAQAAAABeQkAAGQAAAACBQAAAAhiYWxhbmNlQgUAAAASdG9rZW5SZWNlaXZlQW1vdW50BAAAAAlpbnZhcmlhbnQJAQAAAA1pbnZhcmlhbnRDYWxjAAAAAgUAAAAIYmFsYW5jZUEFAAAACGJhbGFuY2VCBAAAAAxpbnZhcmlhbnROZXcDCQAAAAAAAAIFAAAAB3Rva2VuSWQFAAAAC3N0ckFzc2V0SWRBCQEAAAANaW52YXJpYW50Q2FsYwAAAAIFAAAAAXgJAABlAAAAAgUAAAAIYmFsYW5jZUIFAAAAFWFtb3VudFRvU2VuZEVzdGltYXRlZAMJAAAAAAAAAgUAAAAHdG9rZW5JZAUAAAALc3RyQXNzZXRJZEIJAQAAAA1pbnZhcmlhbnRDYWxjAAAAAgkAAGUAAAACBQAAAAhiYWxhbmNlQQUAAAAVYW1vdW50VG9TZW5kRXN0aW1hdGVkBQAAAAF5CQAAAgAAAAECAAAAFldyb25nIGFzc2V0IGluIHBheW1lbnQEAAAAF2ludmFyaWFudEVzdGltYXRlZFJhdGlvCQAAawAAAAMFAAAABnNjYWxlOAUAAAAJaW52YXJpYW50BQAAAAxpbnZhcmlhbnROZXcKAQAAAA1nZXRTdGVwQW1vdW50AAAAAgAAAANhY2MAAAAEc3RlcAMJAAAAAAAAAgUAAAADYWNjAP//////////BAAAAAxhbW91bnRUb1Nl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bmNlQgUAAAAYZXN0aW1hdGVkQW1vdW50VG9SZWNlaXZlBQAAABJtaW5BbW91bnRUb1JlY2VpdmUFAAAACXBtdEFtb3VudAUAAAAKcG10QXNzZXRJZAQAAAAQZ292ZXJuYW5jZVJld2FyZAkAAGsAAAADBQAAAAZhbW91bnQFAAAADWZlZUdvdmVybmFuY2UFAAAACWZlZVNjYWxlNgQAAAAOYW1vdW50TWludXNGZWUJAABrAAAAAwUAAAAGYW1vdW50CQAAZQAAAAIFAAAACWZlZVNjYWxlNgUAAAADZmVlBQAAAAlmZWVTY2FsZTYJAAROAAAAAgkABEwAAAACCQEAAAAMSW50ZWdlckVudHJ5AAAAAgIAAAAKc2VuZEFtb3VudAUAAAAGYW1vdW50CQAETAAAAAIJAQAAAAxJbnRlZ2VyRW50cnkAAAACAgAAABdzZW5kQW1vdW50V2l0aENvbWlzc2lvbgUAAAAOYW1vdW50TWludXNGZWUJAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAICAAAACWludmFyaWFudAkBAAAADWludmFyaWFudENhbGMAAAACBQAAAAhiYWxhbmNlQQUAAAAIYmFsYW5jZUIFAAAAA25pbAMJAAAAAAAAAgUAAAAKcG10QXNzZXRJZAUAAAALc3RyQXNzZXRJZEEJAARMAAAAAgkBAAAADEludGVnZXJFbnRyeQAAAAICAAAADGludmFyaWFudE5ldwkBAAAADWludmFyaWFudENhbGMAAAACCQAAZAAAAAIFAAAACGJhbGFuY2VBBQAAAAlwbXRBbW91bnQJAABlAAAAAgUAAAAIYmFsYW5jZUIFAAAABmFtb3VudAUAAAADbmlsCQAETAAAAAIJAQAAAAxJbnRlZ2VyRW50cnkAAAACAgAAAAxpbnZhcmlhbnROZXcJAQAAAA1pbnZhcmlhbnRDYWxjAAAAAgkAAGUAAAACBQAAAAhiYWxhbmNlQQUAAAAGYW1vdW50CQAAZAAAAAIFAAAACGJhbGFuY2VCBQAAAAlwbXRBbW91bnQFAAAAA25pbAAAAAEAAAACdHgBAAAABnZlcmlmeQAAAAAJAAH0AAAAAwgFAAAAAnR4AAAACWJvZHlCeXRlcwkAAZEAAAACCAUAAAACdHgAAAAGcHJvb2ZzAAAAAAAAAAAACAUAAAACdHgAAAAPc2VuZGVyUHVibGljS2V5HtCMvA==", "height": 1933634, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 9ecKwtM6oUtrNgrTgpfSHkPFAFMnmSVBxbn9yWxhNngW Next: 2Vc7aHTkra4gYTn8nsDCMfCsMnZfmx3vpoVz9LasQAoD Diff:
OldNewDifferences
2525
2626 let scale12 = 1000000000000
2727
28+let scale16 = 10000000000000000
29+
2830 let slippageScale3 = 1000
2931
3032 let digits8 = 8
4749
4850 let betaBigInt = 460000000000
4951
52+let betaDR = 4600000000000000
53+
5054 func skewness (x,y) = (((fraction(scale12, x, y) + fraction(scale12, y, x)) / 2) / 10000)
5155
5256
5559 let skseconsd = fraction(scale12, y, x)
5660 ((skfirst + skseconsd) / 2)
5761 }
62+
63+
64+func skewnessDR (x,y) = ((fraction(scale16, x, y) + fraction(scale16, y, x)) / 2)
5865
5966
6067 func invariantCalc (x,y) = {
149156
150157
151158 @Callable(i)
159+func invariantCalcDR (x,y) = {
160+ let sk = skewnessDR(x, y)
161+ let firstPow = pow(sk, digits8, alpha, alphaDigits, digits8, CEILING)
162+ let firstSum = fraction((x + y), scale16, firstPow)
163+ let secondSumFraction = fraction(toBigInt(x), toBigInt(y), toBigInt(scale8))
164+ let secondSumFirstPart = toInt(pow(secondSumFraction, 0, toBigInt(5), 1, (digits8 / 2), DOWN))
165+ let secondSumSecondPart = pow((sk - betaDR), digits8, alpha, alphaDigits, digits8, DOWN)
166+ let secondSum = (2 * fraction(secondSumFirstPart, secondSumSecondPart, scale8))
167+ let invariant = (firstSum + secondSum)
168+[IntegerEntry("invariant", invariant)]
169+ }
170+
171+
172+
173+@Callable(i)
152174 func exchange (balanceA,balanceB,pmtAmount,pmtAssetId,estimatedAmountToReceive,minAmountToReceive) = {
153175 let amount = calculateSendAmount(balanceA, balanceB, estimatedAmountToReceive, minAmountToReceive, pmtAmount, pmtAssetId)
154176 let governanceReward = fraction(amount, feeGovernance, feeScale6)
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 5 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let strAssetIdA = "34N9YcEETLWn93qYQ64EsP1x89tSruJU44RrEMSXXEPJ"
55
66 let strAssetIdB = "DG2xFkPdDwKUoBkzGAhQtLpSGzfXLiCYPEzeKH2Ad24p"
77
88 let assetIdA = if ((strAssetIdA == "WAVES"))
99 then unit
1010 else fromBase58String(strAssetIdA)
1111
1212 let assetIdB = if ((strAssetIdB == "WAVES"))
1313 then unit
1414 else fromBase58String(strAssetIdB)
1515
1616 let fee = 500
1717
1818 let feeGovernance = 200
1919
2020 let feeScale6 = 1000000
2121
2222 let scale3 = 1000
2323
2424 let scale8 = 100000000
2525
2626 let scale12 = 1000000000000
2727
28+let scale16 = 10000000000000000
29+
2830 let slippageScale3 = 1000
2931
3032 let digits8 = 8
3133
3234 let digits12 = 12
3335
3436 let dAppThreshold = 50
3537
3638 let dAppThresholdScale2 = 100
3739
3840 let exchangeRatioLimitMin = 90000000
3941
4042 let exchangeRatioLimitMax = 110000000
4143
4244 let alpha = 50
4345
4446 let alphaDigits = 2
4547
4648 let beta = 46000000
4749
4850 let betaBigInt = 460000000000
4951
52+let betaDR = 4600000000000000
53+
5054 func skewness (x,y) = (((fraction(scale12, x, y) + fraction(scale12, y, x)) / 2) / 10000)
5155
5256
5357 func skewnessBigInt (x,y) = {
5458 let skfirst = fraction(scale12, x, y)
5559 let skseconsd = fraction(scale12, y, x)
5660 ((skfirst + skseconsd) / 2)
5761 }
62+
63+
64+func skewnessDR (x,y) = ((fraction(scale16, x, y) + fraction(scale16, y, x)) / 2)
5865
5966
6067 func invariantCalc (x,y) = {
6168 let sk = skewness(x, y)
6269 let xy = (x + y)
6370 let firstpow = pow(sk, digits8, alpha, alphaDigits, digits8, CEILING)
6471 let secondpow = pow(fraction(x, y, scale8), 0, 5, 1, (digits8 / 2), DOWN)
6572 let thirdpow = pow((sk - beta), digits8, alpha, alphaDigits, digits8, DOWN)
6673 let firstsum = fraction(xy, scale8, firstpow)
6774 let secondsum = (2 * fraction(secondpow, thirdpow, scale8))
6875 (firstsum + secondsum)
6976 }
7077
7178
7279 func calculateSendAmount (balanceA,balanceB,amountToSendEstimated,minTokenReceiveAmount,tokenReceiveAmount,tokenId) = {
7380 let slippageValue = (scale8 - ((scale8 * 1) / 10000000))
7481 let deltaBetweenMaxAndMinSendValue = (amountToSendEstimated - minTokenReceiveAmount)
7582 let x = (balanceA + tokenReceiveAmount)
7683 let y = (balanceB + tokenReceiveAmount)
7784 let invariant = invariantCalc(balanceA, balanceB)
7885 let invariantNew = if ((tokenId == strAssetIdA))
7986 then invariantCalc(x, (balanceB - amountToSendEstimated))
8087 else if ((tokenId == strAssetIdB))
8188 then invariantCalc((balanceA - amountToSendEstimated), y)
8289 else throw("Wrong asset in payment")
8390 let invariantEstimatedRatio = fraction(scale8, invariant, invariantNew)
8491 func getStepAmount (acc,step) = if ((acc == -1))
8592 then {
8693 let amountToSend = (amountToSendEstimated - ((step * deltaBetweenMaxAndMinSendValue) / 5))
8794 let stepInvariant = if ((tokenId == strAssetIdA))
8895 then invariantCalc(x, (balanceB - amountToSend))
8996 else invariantCalc((balanceA - amountToSend), y)
9097 if ((stepInvariant > invariant))
9198 then amountToSend
9299 else -1
93100 }
94101 else acc
95102
96103 let stepAmount = {
97104 let $l = [1, 2, 3, 4, 5]
98105 let $s = size($l)
99106 let $acc0 = -1
100107 func $f0_1 ($a,$i) = if (($i >= $s))
101108 then $a
102109 else getStepAmount($a, $l[$i])
103110
104111 func $f0_2 ($a,$i) = if (($i >= $s))
105112 then $a
106113 else throw("List size exceeds 5")
107114
108115 $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5)
109116 }
110117 if ((0 > stepAmount))
111118 then throw("something went wrong while working with amountToSend")
112119 else if (if ((invariantEstimatedRatio > slippageValue))
113120 then (invariantNew > invariant)
114121 else false)
115122 then amountToSendEstimated
116123 else stepAmount
117124 }
118125
119126
120127 @Callable(i)
121128 func invariantCalcc (x,y) = {
122129 let sk = skewness(x, y)
123130 let xy = (x + y)
124131 let firstpow = pow(sk, digits8, alpha, alphaDigits, digits8, CEILING)
125132 let secondpow = pow(fraction(x, y, scale8), 0, 5, 1, (digits8 / 2), DOWN)
126133 let thirdpow = pow((sk - beta), digits8, alpha, alphaDigits, digits8, DOWN)
127134 let fractionFirst = fraction(xy, scale8, firstpow)
128135 let fractionSecond = fraction(secondpow, thirdpow, scale8)
129136 let invariant = (fractionFirst + (2 * fractionSecond))
130137 [IntegerEntry("invariant", invariant)]
131138 }
132139
133140
134141
135142 @Callable(i)
136143 func invariantCalccBigInt (x,y) = {
137144 let sk = skewnessBigInt(x, y)
138145 let xy = toBigInt((x + y))
139146 let firstpow = pow(toBigInt(sk), digits12, toBigInt(alpha), alphaDigits, digits12, CEILING)
140147 let secpowfraction = fraction(toBigInt(x), toBigInt(y), toBigInt(scale8))
141148 let secondpow = pow(secpowfraction, 0, toBigInt(5), 1, (digits8 / 2), DOWN)
142149 let thirdpow = pow(toBigInt((sk - betaBigInt)), digits12, toBigInt(alpha), alphaDigits, digits12, DOWN)
143150 let fractionFirst = toInt(fraction(xy, toBigInt(scale12), firstpow))
144151 let fractionSecond = (2 * toInt(fraction(secondpow, thirdpow, toBigInt(scale12))))
145152 let invariant = (fractionFirst + fractionSecond)
146153 [IntegerEntry("invariant", invariant)]
147154 }
148155
149156
150157
151158 @Callable(i)
159+func invariantCalcDR (x,y) = {
160+ let sk = skewnessDR(x, y)
161+ let firstPow = pow(sk, digits8, alpha, alphaDigits, digits8, CEILING)
162+ let firstSum = fraction((x + y), scale16, firstPow)
163+ let secondSumFraction = fraction(toBigInt(x), toBigInt(y), toBigInt(scale8))
164+ let secondSumFirstPart = toInt(pow(secondSumFraction, 0, toBigInt(5), 1, (digits8 / 2), DOWN))
165+ let secondSumSecondPart = pow((sk - betaDR), digits8, alpha, alphaDigits, digits8, DOWN)
166+ let secondSum = (2 * fraction(secondSumFirstPart, secondSumSecondPart, scale8))
167+ let invariant = (firstSum + secondSum)
168+[IntegerEntry("invariant", invariant)]
169+ }
170+
171+
172+
173+@Callable(i)
152174 func exchange (balanceA,balanceB,pmtAmount,pmtAssetId,estimatedAmountToReceive,minAmountToReceive) = {
153175 let amount = calculateSendAmount(balanceA, balanceB, estimatedAmountToReceive, minAmountToReceive, pmtAmount, pmtAssetId)
154176 let governanceReward = fraction(amount, feeGovernance, feeScale6)
155177 let amountMinusFee = fraction(amount, (feeScale6 - fee), feeScale6)
156178 ([IntegerEntry("sendAmount", amount), IntegerEntry("sendAmountWithComission", amountMinusFee), IntegerEntry("invariant", invariantCalc(balanceA, balanceB))] ++ (if ((pmtAssetId == strAssetIdA))
157179 then [IntegerEntry("invariantNew", invariantCalc((balanceA + pmtAmount), (balanceB - amount)))]
158180 else [IntegerEntry("invariantNew", invariantCalc((balanceA - amount), (balanceB + pmtAmount)))]))
159181 }
160182
161183
162184 @Verifier(tx)
163185 func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)
164186

github/deemru/w8io/169f3d6 
45.34 ms