tx · GCWgDzrBFEqFBNMmL57vUrn5y7ow2tbAmFnFqcmRZJmU 3N11gzZic4yASFhatzjC8zvLnpNhDo2B1Rv: -0.01000000 Waves 2023.10.08 22:46 [2790094] smart account 3N11gzZic4yASFhatzjC8zvLnpNhDo2B1Rv > SELF 0.00000000 Waves
{ "type": 13, "id": "GCWgDzrBFEqFBNMmL57vUrn5y7ow2tbAmFnFqcmRZJmU", "fee": 1000000, "feeAssetId": null, "timestamp": 1696794368927, "version": 2, "chainId": 84, "sender": "3N11gzZic4yASFhatzjC8zvLnpNhDo2B1Rv", "senderPublicKey": "EnUXxxhBK8wUfh1FveDYv9G5HBMXop6YwZWzVrBrLo2i", "proofs": [ "3wmzERFxyg8j2PPdS69XDNj6gtR9cc1pSdTKKSvPuVikRQB4HXVzArofr4CvvFaWXYQZk6m7J872uD2o9tK9FDf5" ], "script": "base64:BgIJCAISBQoDAQEYBwELd3JpdGVTdHJpbmcCA2tleQtzdHJpbmdWYWx1ZQkBC1N0cmluZ0VudHJ5AgUDa2V5BQtzdHJpbmdWYWx1ZQENc3BsaXRDZm1tSnNvbgEFZW50cnkJALUJAgUFZW50cnkCAS8BH2NhbGNFeGNlc3NBbW91bnRQZXJDZm1tUG9zaXRpdmUCCmRpZmZlcmVuY2ULbnVtYmVyQ2ZtbXMECHF1b3RpZW50CQBuBAUKZGlmZmVyZW5jZQABBQtudW1iZXJDZm1tcwUERE9XTgQWdG90YWxEaXN0cmlidXRlZEFtb3VudAkAaAIFCHF1b3RpZW50BQtudW1iZXJDZm1tcwQPcmVtYWluaW5nQW1vdW50CQBlAgUKZGlmZmVyZW5jZQUWdG90YWxEaXN0cmlidXRlZEFtb3VudAMJAGYCBQ9yZW1haW5pbmdBbW91bnQAAAkAlAoCBQhxdW90aWVudAUPcmVtYWluaW5nQW1vdW50CQCUCgIFCHF1b3RpZW50AAABH2NhbGNFeGNlc3NBbW91bnRQZXJDZm1tTmVnYXRpdmUCCmRpZmZlcmVuY2ULbnVtYmVyQ2ZtbXMECHF1b3RpZW50CQBuBAUKZGlmZmVyZW5jZQABBQtudW1iZXJDZm1tcwUERE9XTgQWdG90YWxEaXN0cmlidXRlZEFtb3VudAkAaAIFCHF1b3RpZW50BQtudW1iZXJDZm1tcwQPcmVtYWluaW5nQW1vdW50CQBlAgUKZGlmZmVyZW5jZQUWdG90YWxEaXN0cmlidXRlZEFtb3VudAMJAGYCAAAFD3JlbWFpbmluZ0Ftb3VudAkAlAoCBQhxdW90aWVudAUPcmVtYWluaW5nQW1vdW50CQCUCgIFCHF1b3RpZW50AAABGmRpc3RyaWJ1dGVBZGRpdGlvbmFsVG9rZW5zAgVzd2FwcwRkaWZmBAp0b3RhbFN3YXBzCQCQAwEFBXN3YXBzBAskdDAxMjIxMTMwNAkBH2NhbGNFeGNlc3NBbW91bnRQZXJDZm1tUG9zaXRpdmUCBQRkaWZmBQp0b3RhbFN3YXBzBAhxdW90aWVudAgFCyR0MDEyMjExMzA0Al8xBA9yZW1haW5pbmdBbW91bnQIBQskdDAxMjIxMTMwNAJfMgoBDWFkanVzdEFtb3VudHMCBWFjY3VtBG5leHQECyR0MDEzNzcxNDE5BQVhY2N1bQQNYWRqdXN0ZWRTd2FwcwgFCyR0MDEzNzcxNDE5Al8xBA1yZW1haW5pbmdEaWZmCAULJHQwMTM3NzE0MTkCXzIEBGl0ZW0JAQ1zcGxpdENmbW1Kc29uAQUEbmV4dAQLaW5wdXRBbW91bnQJALYJAQkAkQMCBQRpdGVtAAIEByRtYXRjaDAFC2lucHV0QW1vdW50AwkAAQIFByRtYXRjaDACA0ludAQFaW5wdXQFByRtYXRjaDAEDmFtb3VudFRvQWRqdXN0AwkAZgIFDXJlbWFpbmluZ0RpZmYAAAkAZAIJAGQCBQVpbnB1dAUIcXVvdGllbnQAAQkAZAIFBWlucHV0BQhxdW90aWVudAQHbmV3SXRlbQkArAICCQCsAgIJAKwCAgkArAICCQCRAwIFBGl0ZW0AAAIBLwkAkQMCBQRpdGVtAAECAS8JAKQDAQUOYW1vdW50VG9BZGp1c3QEEG5ld1JlbWFpbmluZ0RpZmYDCQBmAgUNcmVtYWluaW5nRGlmZgAACQBlAgUNcmVtYWluaW5nRGlmZgABBQ1yZW1haW5pbmdEaWZmCQCUCgIJAM0IAgUNYWRqdXN0ZWRTd2FwcwUHbmV3SXRlbQUQbmV3UmVtYWluaW5nRGlmZgkAAgECGUlucHV0IGhhcyB3cm9uZyBkYXRhdHlwZSEKAAIkbAUFc3dhcHMKAAIkcwkAkAMBBQIkbAoABSRhY2MwCQCUCgIFA25pbAUPcmVtYWluaW5nQW1vdW50CgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQ1hZGp1c3RBbW91bnRzAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyA0MAkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKAAsADAANAA4ADwAQABEAEgATABQAFQAWABcAGAAZABoAGwAcAB0AHgAfACAAIQAiACMAJAAlACYAJwAoARhkaXN0cmlidXRlUmVtYWluaW5nRGlmZnMCDXJlbWFpbmluZ0RpZmYFc3dhcHMKARZkaXN0cmlidXRlUHJvcG9ydGlvbmFsAgVhY2N1bQRuZXh0BAskdDAyMjY5MjMwOAUFYWNjdW0EDWFkanVzdGVkU3dhcHMIBQskdDAyMjY5MjMwOAJfMQQKcmVtYWluRGlmZggFCyR0MDIyNjkyMzA4Al8yBARpdGVtCQENc3BsaXRDZm1tSnNvbgEFBG5leHQEC2lucHV0QW1vdW50CQC2CQEJAJEDAgUEaXRlbQACBBBpbnB1dEFtb3VudENoZWNrBAckbWF0Y2gwBQtpbnB1dEFtb3VudAMJAAECBQckbWF0Y2gwAgNJbnQEBWlucHV0BQckbWF0Y2gwBQVpbnB1dAkAAgECJElucHV0IGFtb3VudCBoYXMgdGhlIHdyb25nIGRhdGEgdHlwZQQPbWF4U3VidHJhY3RhYmxlAwkAZgIFEGlucHV0QW1vdW50Q2hlY2sABAkAawMFEGlucHV0QW1vdW50Q2hlY2sAAwAEAAAECyR0MDI3MDYzMzIwAwMJAAACBQpyZW1haW5EaWZmAAAGCQAAAgUPbWF4U3VidHJhY3RhYmxlAAAJAJQKAgUKcmVtYWluRGlmZgAAAwkAZgIJAGQCBQpyZW1haW5EaWZmBQ9tYXhTdWJ0cmFjdGFibGUAAAQVcmVtYWluaW5nU3VidHJhY3RhYmxlCQBkAgUKcmVtYWluRGlmZgUPbWF4U3VidHJhY3RhYmxlCQCUCgIAAAkAZQIFD21heFN1YnRyYWN0YWJsZQUVcmVtYWluaW5nU3VidHJhY3RhYmxlAwkAZgIAAAkAZAIFCnJlbWFpbkRpZmYFD21heFN1YnRyYWN0YWJsZQkAlAoCCQBkAgUKcmVtYWluRGlmZgUPbWF4U3VidHJhY3RhYmxlBQ9tYXhTdWJ0cmFjdGFibGUJAJQKAgAABQ9tYXhTdWJ0cmFjdGFibGUEEG5ld1JlbWFpbmluZ0RpZmYIBQskdDAyNzA2MzMyMAJfMQQSc3VidHJhY3RhYmxlQW1vdW50CAULJHQwMjcwNjMzMjACXzIEDmFtb3VudFRvQWRqdXN0CQBlAgUQaW5wdXRBbW91bnRDaGVjawUSc3VidHJhY3RhYmxlQW1vdW50BAduZXdJdGVtCQCsAgIJAKwCAgkArAICCQCsAgIJAJEDAgUEaXRlbQAAAgEvCQCRAwIFBGl0ZW0AAQIBLwkApAMBBQ5hbW91bnRUb0FkanVzdAkAlAoCCQDNCAIFDWFkanVzdGVkU3dhcHMFB25ld0l0ZW0FEG5ld1JlbWFpbmluZ0RpZmYKAAIkbAUFc3dhcHMKAAIkcwkAkAMBBQIkbAoABSRhY2MwCQCUCgIFA25pbAUNcmVtYWluaW5nRGlmZgoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEWZGlzdHJpYnV0ZVByb3BvcnRpb25hbAIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgNDAJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgALAAwADQAOAA8AEAARABIAEwAUABUAFgAXABgAGQAaABsAHAAdAB4AHwAgACEAIgAjACQAJQAmACcAKAEYZGlzdHJpYnV0ZU5lZ2F0aXZlVG9rZW5zAgVzd2FwcwRkaWZmBAp0b3RhbFN3YXBzCQCQAwEFBXN3YXBzBAskdDAzNjg1Mzc2OAkBH2NhbGNFeGNlc3NBbW91bnRQZXJDZm1tTmVnYXRpdmUCBQRkaWZmBQp0b3RhbFN3YXBzBAhxdW90aWVudAgFCyR0MDM2ODUzNzY4Al8xBA9yZW1haW5pbmdBbW91bnQIBQskdDAzNjg1Mzc2OAJfMgoBDWFkanVzdEFtb3VudHMCBWFjY3VtBG5leHQECyR0MDM4NDEzODgzBQVhY2N1bQQNYWRqdXN0ZWRTd2FwcwgFCyR0MDM4NDEzODgzAl8xBA1yZW1haW5pbmdEaWZmCAULJHQwMzg0MTM4ODMCXzIEBGl0ZW0JAQ1zcGxpdENmbW1Kc29uAQUEbmV4dAQLaW5wdXRBbW91bnQJALYJAQkAkQMCBQRpdGVtAAIEByRtYXRjaDAFC2lucHV0QW1vdW50AwkAAQIFByRtYXRjaDACA0ludAQFaW5wdXQFByRtYXRjaDAECyR0MDQwMjA0MzcwAwkAZwIJAGQCBQVpbnB1dAUIcXVvdGllbnQAAQMDCQBmAgUNcmVtYWluaW5nRGlmZgAACQBnAgkAZQIJAGQCBQVpbnB1dAUIcXVvdGllbnQAAQABBwkAlAoCCQBlAgkAZAIFBWlucHV0BQhxdW90aWVudAABCQBlAgUNcmVtYWluaW5nRGlmZgABCQCUCgIJAGQCBQVpbnB1dAUIcXVvdGllbnQFDXJlbWFpbmluZ0RpZmYJAJQKAgUFaW5wdXQJAGQCBQ1yZW1haW5pbmdEaWZmBQhxdW90aWVudAQOYW1vdW50VG9BZGp1c3QIBQskdDA0MDIwNDM3MAJfMQQQbmV3UmVtYWluaW5nRGlmZggFCyR0MDQwMjA0MzcwAl8yBAduZXdJdGVtCQCsAgIJAKwCAgkArAICCQCsAgIJAJEDAgUEaXRlbQAAAgEvCQCRAwIFBGl0ZW0AAQIBLwkApAMBBQ5hbW91bnRUb0FkanVzdAkAlAoCCQDNCAIFDWFkanVzdGVkU3dhcHMFB25ld0l0ZW0FEG5ld1JlbWFpbmluZ0RpZmYJAAIBAhlJbnB1dCBoYXMgd3JvbmcgZGF0YXR5cGUhBAskdDA0NTY5NDY2MAoAAiRsBQVzd2FwcwoAAiRzCQCQAwEFAiRsCgAFJGFjYzAJAJQKAgUDbmlsBQ9yZW1haW5pbmdBbW91bnQKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBDWFkanVzdEFtb3VudHMCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDQwCQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoACwAMAA0ADgAPABAAEQASABMAFAAVABYAFwAYABkAGgAbABwAHQAeAB8AIAAhACIAIwAkACUAJgAnACgEDWFkanVzdGVkU3dhcHMIBQskdDA0NTY5NDY2MAJfMQQOcmVtYWluaW5nRGlmZnMIBQskdDA0NTY5NDY2MAJfMgQLJHQwNDY2NDQ3NDQJARhkaXN0cmlidXRlUmVtYWluaW5nRGlmZnMCBQ5yZW1haW5pbmdEaWZmcwUNYWRqdXN0ZWRTd2FwcwQKZmluYWxTd2FwcwgFCyR0MDQ2NjQ0NzQ0Al8xBAVkaWZmcwgFCyR0MDQ2NjQ0NzQ0Al8yBQpmaW5hbFN3YXBzAQFpAQRjYWxsAxNwcmVkZXRlcm1pbmVkQW1vdW50D2F2YWlsYWJsZUFtb3VudAVzd2FwcwQEZGlmZgkAZQIFD2F2YWlsYWJsZUFtb3VudAUTcHJlZGV0ZXJtaW5lZEFtb3VudAQNYWRqdXN0ZWRTd2FwcwMJAGYCBQRkaWZmAAAICQEaZGlzdHJpYnV0ZUFkZGl0aW9uYWxUb2tlbnMCBQVzd2FwcwUEZGlmZgJfMQMJAGYCAAAFBGRpZmYJARhkaXN0cmlidXRlTmVnYXRpdmVUb2tlbnMCBQVzd2FwcwUEZGlmZgUFc3dhcHMJAMwIAgkBC3dyaXRlU3RyaW5nAgIFc3dhcHMJALkJAgUFc3dhcHMCASwJAMwIAgkBC3dyaXRlU3RyaW5nAgINYWRqdXN0ZWRTd2FwcwkAuQkCBQ1hZGp1c3RlZFN3YXBzAgEsBQNuaWwBAnR4AQZ2ZXJpZnkACQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAACAUCdHgPc2VuZGVyUHVibGljS2V5aZ0JyA==", "height": 2790094, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: Ca66mpEXSrbvRDtuvEMVGJ2SQ3GRfcrBy7rJXboDTjtS Next: none Diff:
Old | New | Differences | |
---|---|---|---|
7 | 7 | func splitCfmmJson (entry) = split(entry, "/") | |
8 | 8 | ||
9 | 9 | ||
10 | - | func | |
11 | - | let quotient = (difference | |
10 | + | func calcExcessAmountPerCfmmPositive (difference,numberCfmms) = { | |
11 | + | let quotient = fraction(difference, 1, numberCfmms, DOWN) | |
12 | 12 | let totalDistributedAmount = (quotient * numberCfmms) | |
13 | 13 | let remainingAmount = (difference - totalDistributedAmount) | |
14 | 14 | if ((remainingAmount > 0)) | |
17 | 17 | } | |
18 | 18 | ||
19 | 19 | ||
20 | + | func calcExcessAmountPerCfmmNegative (difference,numberCfmms) = { | |
21 | + | let quotient = fraction(difference, 1, numberCfmms, DOWN) | |
22 | + | let totalDistributedAmount = (quotient * numberCfmms) | |
23 | + | let remainingAmount = (difference - totalDistributedAmount) | |
24 | + | if ((0 > remainingAmount)) | |
25 | + | then $Tuple2(quotient, remainingAmount) | |
26 | + | else $Tuple2(quotient, 0) | |
27 | + | } | |
28 | + | ||
29 | + | ||
20 | 30 | func distributeAdditionalTokens (swaps,diff) = { | |
21 | 31 | let totalSwaps = size(swaps) | |
22 | - | let $ | |
23 | - | let quotient = $ | |
24 | - | let remainingAmount = $ | |
32 | + | let $t012211304 = calcExcessAmountPerCfmmPositive(diff, totalSwaps) | |
33 | + | let quotient = $t012211304._1 | |
34 | + | let remainingAmount = $t012211304._2 | |
25 | 35 | func adjustAmounts (accum,next) = { | |
26 | - | let $ | |
27 | - | let adjustedSwaps = $ | |
28 | - | let remainingDiff = $ | |
36 | + | let $t013771419 = accum | |
37 | + | let adjustedSwaps = $t013771419._1 | |
38 | + | let remainingDiff = $t013771419._2 | |
29 | 39 | let item = splitCfmmJson(next) | |
30 | 40 | let inputAmount = parseInt(item[2]) | |
31 | 41 | match inputAmount { | |
58 | 68 | } | |
59 | 69 | ||
60 | 70 | ||
71 | + | func distributeRemainingDiffs (remainingDiff,swaps) = { | |
72 | + | func distributeProportional (accum,next) = { | |
73 | + | let $t022692308 = accum | |
74 | + | let adjustedSwaps = $t022692308._1 | |
75 | + | let remainDiff = $t022692308._2 | |
76 | + | let item = splitCfmmJson(next) | |
77 | + | let inputAmount = parseInt(item[2]) | |
78 | + | let inputAmountCheck = match inputAmount { | |
79 | + | case input: Int => | |
80 | + | input | |
81 | + | case _ => | |
82 | + | throw("Input amount has the wrong data type") | |
83 | + | } | |
84 | + | let maxSubtractable = if ((inputAmountCheck > 4)) | |
85 | + | then fraction(inputAmountCheck, 3, 4) | |
86 | + | else 0 | |
87 | + | let $t027063320 = if (if ((remainDiff == 0)) | |
88 | + | then true | |
89 | + | else (maxSubtractable == 0)) | |
90 | + | then $Tuple2(remainDiff, 0) | |
91 | + | else if (((remainDiff + maxSubtractable) > 0)) | |
92 | + | then { | |
93 | + | let remainingSubtractable = (remainDiff + maxSubtractable) | |
94 | + | $Tuple2(0, (maxSubtractable - remainingSubtractable)) | |
95 | + | } | |
96 | + | else if ((0 > (remainDiff + maxSubtractable))) | |
97 | + | then $Tuple2((remainDiff + maxSubtractable), maxSubtractable) | |
98 | + | else $Tuple2(0, maxSubtractable) | |
99 | + | let newRemainingDiff = $t027063320._1 | |
100 | + | let subtractableAmount = $t027063320._2 | |
101 | + | let amountToAdjust = (inputAmountCheck - subtractableAmount) | |
102 | + | let newItem = ((((item[0] + "/") + item[1]) + "/") + toString(amountToAdjust)) | |
103 | + | $Tuple2((adjustedSwaps :+ newItem), newRemainingDiff) | |
104 | + | } | |
105 | + | ||
106 | + | let $l = swaps | |
107 | + | let $s = size($l) | |
108 | + | let $acc0 = $Tuple2(nil, remainingDiff) | |
109 | + | func $f0_1 ($a,$i) = if (($i >= $s)) | |
110 | + | then $a | |
111 | + | else distributeProportional($a, $l[$i]) | |
112 | + | ||
113 | + | func $f0_2 ($a,$i) = if (($i >= $s)) | |
114 | + | then $a | |
115 | + | else throw("List size exceeds 40") | |
116 | + | ||
117 | + | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20), 21), 22), 23), 24), 25), 26), 27), 28), 29), 30), 31), 32), 33), 34), 35), 36), 37), 38), 39), 40) | |
118 | + | } | |
119 | + | ||
120 | + | ||
121 | + | func distributeNegativeTokens (swaps,diff) = { | |
122 | + | let totalSwaps = size(swaps) | |
123 | + | let $t036853768 = calcExcessAmountPerCfmmNegative(diff, totalSwaps) | |
124 | + | let quotient = $t036853768._1 | |
125 | + | let remainingAmount = $t036853768._2 | |
126 | + | func adjustAmounts (accum,next) = { | |
127 | + | let $t038413883 = accum | |
128 | + | let adjustedSwaps = $t038413883._1 | |
129 | + | let remainingDiff = $t038413883._2 | |
130 | + | let item = splitCfmmJson(next) | |
131 | + | let inputAmount = parseInt(item[2]) | |
132 | + | match inputAmount { | |
133 | + | case input: Int => | |
134 | + | let $t040204370 = if (((input + quotient) >= 1)) | |
135 | + | then if (if ((remainingDiff > 0)) | |
136 | + | then (((input + quotient) - 1) >= 1) | |
137 | + | else false) | |
138 | + | then $Tuple2(((input + quotient) - 1), (remainingDiff - 1)) | |
139 | + | else $Tuple2((input + quotient), remainingDiff) | |
140 | + | else $Tuple2(input, (remainingDiff + quotient)) | |
141 | + | let amountToAdjust = $t040204370._1 | |
142 | + | let newRemainingDiff = $t040204370._2 | |
143 | + | let newItem = ((((item[0] + "/") + item[1]) + "/") + toString(amountToAdjust)) | |
144 | + | $Tuple2((adjustedSwaps :+ newItem), newRemainingDiff) | |
145 | + | case _ => | |
146 | + | throw("Input has wrong datatype!") | |
147 | + | } | |
148 | + | } | |
149 | + | ||
150 | + | let $t045694660 = { | |
151 | + | let $l = swaps | |
152 | + | let $s = size($l) | |
153 | + | let $acc0 = $Tuple2(nil, remainingAmount) | |
154 | + | func $f0_1 ($a,$i) = if (($i >= $s)) | |
155 | + | then $a | |
156 | + | else adjustAmounts($a, $l[$i]) | |
157 | + | ||
158 | + | func $f0_2 ($a,$i) = if (($i >= $s)) | |
159 | + | then $a | |
160 | + | else throw("List size exceeds 40") | |
161 | + | ||
162 | + | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20), 21), 22), 23), 24), 25), 26), 27), 28), 29), 30), 31), 32), 33), 34), 35), 36), 37), 38), 39), 40) | |
163 | + | } | |
164 | + | let adjustedSwaps = $t045694660._1 | |
165 | + | let remainingDiffs = $t045694660._2 | |
166 | + | let $t046644744 = distributeRemainingDiffs(remainingDiffs, adjustedSwaps) | |
167 | + | let finalSwaps = $t046644744._1 | |
168 | + | let diffs = $t046644744._2 | |
169 | + | finalSwaps | |
170 | + | } | |
171 | + | ||
172 | + | ||
61 | 173 | @Callable(i) | |
62 | 174 | func call (predeterminedAmount,availableAmount,swaps) = { | |
63 | 175 | let diff = (availableAmount - predeterminedAmount) | |
64 | 176 | let adjustedSwaps = if ((diff > 0)) | |
65 | 177 | then distributeAdditionalTokens(swaps, diff)._1 | |
66 | - | else swaps | |
178 | + | else if ((0 > diff)) | |
179 | + | then distributeNegativeTokens(swaps, diff) | |
180 | + | else swaps | |
67 | 181 | [writeString("swaps", makeString(swaps, ",")), writeString("adjustedSwaps", makeString(adjustedSwaps, ","))] | |
68 | 182 | } | |
69 | 183 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | func writeString (key,stringValue) = StringEntry(key, stringValue) | |
5 | 5 | ||
6 | 6 | ||
7 | 7 | func splitCfmmJson (entry) = split(entry, "/") | |
8 | 8 | ||
9 | 9 | ||
10 | - | func | |
11 | - | let quotient = (difference | |
10 | + | func calcExcessAmountPerCfmmPositive (difference,numberCfmms) = { | |
11 | + | let quotient = fraction(difference, 1, numberCfmms, DOWN) | |
12 | 12 | let totalDistributedAmount = (quotient * numberCfmms) | |
13 | 13 | let remainingAmount = (difference - totalDistributedAmount) | |
14 | 14 | if ((remainingAmount > 0)) | |
15 | 15 | then $Tuple2(quotient, remainingAmount) | |
16 | 16 | else $Tuple2(quotient, 0) | |
17 | 17 | } | |
18 | 18 | ||
19 | 19 | ||
20 | + | func calcExcessAmountPerCfmmNegative (difference,numberCfmms) = { | |
21 | + | let quotient = fraction(difference, 1, numberCfmms, DOWN) | |
22 | + | let totalDistributedAmount = (quotient * numberCfmms) | |
23 | + | let remainingAmount = (difference - totalDistributedAmount) | |
24 | + | if ((0 > remainingAmount)) | |
25 | + | then $Tuple2(quotient, remainingAmount) | |
26 | + | else $Tuple2(quotient, 0) | |
27 | + | } | |
28 | + | ||
29 | + | ||
20 | 30 | func distributeAdditionalTokens (swaps,diff) = { | |
21 | 31 | let totalSwaps = size(swaps) | |
22 | - | let $ | |
23 | - | let quotient = $ | |
24 | - | let remainingAmount = $ | |
32 | + | let $t012211304 = calcExcessAmountPerCfmmPositive(diff, totalSwaps) | |
33 | + | let quotient = $t012211304._1 | |
34 | + | let remainingAmount = $t012211304._2 | |
25 | 35 | func adjustAmounts (accum,next) = { | |
26 | - | let $ | |
27 | - | let adjustedSwaps = $ | |
28 | - | let remainingDiff = $ | |
36 | + | let $t013771419 = accum | |
37 | + | let adjustedSwaps = $t013771419._1 | |
38 | + | let remainingDiff = $t013771419._2 | |
29 | 39 | let item = splitCfmmJson(next) | |
30 | 40 | let inputAmount = parseInt(item[2]) | |
31 | 41 | match inputAmount { | |
32 | 42 | case input: Int => | |
33 | 43 | let amountToAdjust = if ((remainingDiff > 0)) | |
34 | 44 | then ((input + quotient) + 1) | |
35 | 45 | else (input + quotient) | |
36 | 46 | let newItem = ((((item[0] + "/") + item[1]) + "/") + toString(amountToAdjust)) | |
37 | 47 | let newRemainingDiff = if ((remainingDiff > 0)) | |
38 | 48 | then (remainingDiff - 1) | |
39 | 49 | else remainingDiff | |
40 | 50 | $Tuple2((adjustedSwaps :+ newItem), newRemainingDiff) | |
41 | 51 | case _ => | |
42 | 52 | throw("Input has wrong datatype!") | |
43 | 53 | } | |
44 | 54 | } | |
45 | 55 | ||
46 | 56 | let $l = swaps | |
47 | 57 | let $s = size($l) | |
48 | 58 | let $acc0 = $Tuple2(nil, remainingAmount) | |
49 | 59 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
50 | 60 | then $a | |
51 | 61 | else adjustAmounts($a, $l[$i]) | |
52 | 62 | ||
53 | 63 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
54 | 64 | then $a | |
55 | 65 | else throw("List size exceeds 40") | |
56 | 66 | ||
57 | 67 | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20), 21), 22), 23), 24), 25), 26), 27), 28), 29), 30), 31), 32), 33), 34), 35), 36), 37), 38), 39), 40) | |
58 | 68 | } | |
59 | 69 | ||
60 | 70 | ||
71 | + | func distributeRemainingDiffs (remainingDiff,swaps) = { | |
72 | + | func distributeProportional (accum,next) = { | |
73 | + | let $t022692308 = accum | |
74 | + | let adjustedSwaps = $t022692308._1 | |
75 | + | let remainDiff = $t022692308._2 | |
76 | + | let item = splitCfmmJson(next) | |
77 | + | let inputAmount = parseInt(item[2]) | |
78 | + | let inputAmountCheck = match inputAmount { | |
79 | + | case input: Int => | |
80 | + | input | |
81 | + | case _ => | |
82 | + | throw("Input amount has the wrong data type") | |
83 | + | } | |
84 | + | let maxSubtractable = if ((inputAmountCheck > 4)) | |
85 | + | then fraction(inputAmountCheck, 3, 4) | |
86 | + | else 0 | |
87 | + | let $t027063320 = if (if ((remainDiff == 0)) | |
88 | + | then true | |
89 | + | else (maxSubtractable == 0)) | |
90 | + | then $Tuple2(remainDiff, 0) | |
91 | + | else if (((remainDiff + maxSubtractable) > 0)) | |
92 | + | then { | |
93 | + | let remainingSubtractable = (remainDiff + maxSubtractable) | |
94 | + | $Tuple2(0, (maxSubtractable - remainingSubtractable)) | |
95 | + | } | |
96 | + | else if ((0 > (remainDiff + maxSubtractable))) | |
97 | + | then $Tuple2((remainDiff + maxSubtractable), maxSubtractable) | |
98 | + | else $Tuple2(0, maxSubtractable) | |
99 | + | let newRemainingDiff = $t027063320._1 | |
100 | + | let subtractableAmount = $t027063320._2 | |
101 | + | let amountToAdjust = (inputAmountCheck - subtractableAmount) | |
102 | + | let newItem = ((((item[0] + "/") + item[1]) + "/") + toString(amountToAdjust)) | |
103 | + | $Tuple2((adjustedSwaps :+ newItem), newRemainingDiff) | |
104 | + | } | |
105 | + | ||
106 | + | let $l = swaps | |
107 | + | let $s = size($l) | |
108 | + | let $acc0 = $Tuple2(nil, remainingDiff) | |
109 | + | func $f0_1 ($a,$i) = if (($i >= $s)) | |
110 | + | then $a | |
111 | + | else distributeProportional($a, $l[$i]) | |
112 | + | ||
113 | + | func $f0_2 ($a,$i) = if (($i >= $s)) | |
114 | + | then $a | |
115 | + | else throw("List size exceeds 40") | |
116 | + | ||
117 | + | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20), 21), 22), 23), 24), 25), 26), 27), 28), 29), 30), 31), 32), 33), 34), 35), 36), 37), 38), 39), 40) | |
118 | + | } | |
119 | + | ||
120 | + | ||
121 | + | func distributeNegativeTokens (swaps,diff) = { | |
122 | + | let totalSwaps = size(swaps) | |
123 | + | let $t036853768 = calcExcessAmountPerCfmmNegative(diff, totalSwaps) | |
124 | + | let quotient = $t036853768._1 | |
125 | + | let remainingAmount = $t036853768._2 | |
126 | + | func adjustAmounts (accum,next) = { | |
127 | + | let $t038413883 = accum | |
128 | + | let adjustedSwaps = $t038413883._1 | |
129 | + | let remainingDiff = $t038413883._2 | |
130 | + | let item = splitCfmmJson(next) | |
131 | + | let inputAmount = parseInt(item[2]) | |
132 | + | match inputAmount { | |
133 | + | case input: Int => | |
134 | + | let $t040204370 = if (((input + quotient) >= 1)) | |
135 | + | then if (if ((remainingDiff > 0)) | |
136 | + | then (((input + quotient) - 1) >= 1) | |
137 | + | else false) | |
138 | + | then $Tuple2(((input + quotient) - 1), (remainingDiff - 1)) | |
139 | + | else $Tuple2((input + quotient), remainingDiff) | |
140 | + | else $Tuple2(input, (remainingDiff + quotient)) | |
141 | + | let amountToAdjust = $t040204370._1 | |
142 | + | let newRemainingDiff = $t040204370._2 | |
143 | + | let newItem = ((((item[0] + "/") + item[1]) + "/") + toString(amountToAdjust)) | |
144 | + | $Tuple2((adjustedSwaps :+ newItem), newRemainingDiff) | |
145 | + | case _ => | |
146 | + | throw("Input has wrong datatype!") | |
147 | + | } | |
148 | + | } | |
149 | + | ||
150 | + | let $t045694660 = { | |
151 | + | let $l = swaps | |
152 | + | let $s = size($l) | |
153 | + | let $acc0 = $Tuple2(nil, remainingAmount) | |
154 | + | func $f0_1 ($a,$i) = if (($i >= $s)) | |
155 | + | then $a | |
156 | + | else adjustAmounts($a, $l[$i]) | |
157 | + | ||
158 | + | func $f0_2 ($a,$i) = if (($i >= $s)) | |
159 | + | then $a | |
160 | + | else throw("List size exceeds 40") | |
161 | + | ||
162 | + | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20), 21), 22), 23), 24), 25), 26), 27), 28), 29), 30), 31), 32), 33), 34), 35), 36), 37), 38), 39), 40) | |
163 | + | } | |
164 | + | let adjustedSwaps = $t045694660._1 | |
165 | + | let remainingDiffs = $t045694660._2 | |
166 | + | let $t046644744 = distributeRemainingDiffs(remainingDiffs, adjustedSwaps) | |
167 | + | let finalSwaps = $t046644744._1 | |
168 | + | let diffs = $t046644744._2 | |
169 | + | finalSwaps | |
170 | + | } | |
171 | + | ||
172 | + | ||
61 | 173 | @Callable(i) | |
62 | 174 | func call (predeterminedAmount,availableAmount,swaps) = { | |
63 | 175 | let diff = (availableAmount - predeterminedAmount) | |
64 | 176 | let adjustedSwaps = if ((diff > 0)) | |
65 | 177 | then distributeAdditionalTokens(swaps, diff)._1 | |
66 | - | else swaps | |
178 | + | else if ((0 > diff)) | |
179 | + | then distributeNegativeTokens(swaps, diff) | |
180 | + | else swaps | |
67 | 181 | [writeString("swaps", makeString(swaps, ",")), writeString("adjustedSwaps", makeString(adjustedSwaps, ","))] | |
68 | 182 | } | |
69 | 183 | ||
70 | 184 | ||
71 | 185 | @Verifier(tx) | |
72 | 186 | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
73 | 187 |
github/deemru/w8io/169f3d6 29.53 ms ◑