Skip to content

Commit

Permalink
Merge pull request #113 from balancer/invariant-approx
Browse files Browse the repository at this point in the history
Invariant approximation
  • Loading branch information
danielmkm authored Jul 1, 2024
2 parents 7978b06 + 89f2f29 commit b14d0c9
Showing 1 changed file with 9 additions and 9 deletions.
18 changes: 9 additions & 9 deletions docs/concepts/vault/liquidity-invariant-approximation.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,32 +5,32 @@ order: 10

# Liquidity Invariant Approximation

Adding and removing liquidity are considered liquidity operations in the context of this page. A Balancer pool allows to not only add & remove liquidity proportionally but also in unbalanced ways. An unbalanced add or remove liquidity can also be considered to be a combination of proportional add or remove liquidity plus a swap. The vault must handle both scenarios with the same outcome for users & LPs to ensure a fair settlement system.
Adding and removing liquidity are considered liquidity operations in the context of this page. A Balancer pool allows adding and removing liquidity not only proportionally, but also in non-proportional or "unbalanced" ways. An unbalanced add or remove liquidity can be considered a combination of a proportional add or remove plus a swap. The vault must handle both scenarios with the same outcome for users and LPs, in order to ensure a fair settlement system.

## Theory

Liquidity operations that are disproportionate allow for indirect swaps. This scenario must have the same outcome than swaps & proportional liquidity operations combined. This means:
Liquidity operations that are disproportionate allow for indirect swaps. This scenario must have the same outcome as swaps and proportional liquidity operations combined. This means:

- Swap fees for indirect swaps must not be lower than those for direct swaps
- BPT amounts are properly minted to the users of an indirect swap and a user of a proportional liquidity operation and a swap
- The compared users having the same net token balances after the respective operation
- BPT amounts are properly minted in both cases (an indirect swap, and a proportional liquidity operation plus a swap)
- Both users must have the same net token balances after each operation

## Examples

Alice starts with balances of [100, 0]. She executes addLiquidityUnbalanced([100, 0]) and then removes liquidity proportionally, resulting in balances of [66, 33]. Bob, starting with the same balances [100, 0], performs a swapExactIn(34). We determine the amount Alice indirectly traded as 34 (100 - 66 = 34), allowing us to compare the swap fees incurred on the trade. This comparison ensures that the fees for a direct swap remain higher than those for an indirect swap. Finally, we assess the final balances of Alice and Bob. Two criteria must be satisfied:
Alice starts with balances of [100, 0]. She executes addLiquidityUnbalanced([100, 0]) and then removes liquidity proportionally, resulting in balances of [66, 33]. Bob, starting with the same balances [100, 0], performs a swapExactIn(34). We determine the amount Alice indirectly traded as 34 (100 - 66 = 34), allowing us to compare the swap fees incurred on the trades. This comparison ensures that the fees for a direct swap remain higher than those for an indirect swap. Finally, we assess the final balances of Alice and Bob. Two criteria must be satisfied:

1. The initial coin balances for the trade should be identical, meaning Alice's [66, ...] should correspond to Bob's [66, ...].
1. The initial token balances for the trade should be identical, meaning Alice's [66, ...] should correspond to Bob's [66, ...].
2. The resulting balances from the trade should ensure that Bob always has an equal or greater amount than Alice. However, the difference should not be excessive, i.e., we aim not to disadvantage users in liquidity operations. This implies that Alice's balance [..., 33] should be less than or at most equal to Bob's [..., 34].

## Implications

This methodology and evaluation criteria apply to all disproportionate liquidity operations and pool types. Moreover, this approach confirms the correct amount of BPT (Balancer Pool Tokens) minted or burned for liquidity operations. If more BPT were minted or fewer BPT were burned than required, it would result in Alice having more assets at the end than Bob.

::: info Custom pool implication
As a custom pool developer you are faced with the choice of allowing these combinations in your pool. If you chose to do so, you must verify
As a custom pool developer, you are faced with the choice of allowing these combinations in your pool. If you chose to do so, you must verify
the liquidity-invariant approximation approach in your tests to ensure fair & even settlement across various operations.
:::

## Verification.
## Verification

The interested reader is forwarded to the [`LiquidityApproximation.t.sol`](https://github.com/balancer/balancer-v3-monorepo/blob/main/pkg/vault/test/foundry/LiquidityApproximation.t.sol#L682) test file where the required assertions are verified in `assertLLiquidityOperationNoSwapFee()` & `assertLiquidityOperation()`.
For reference, see the [`LiquidityApproximation.t.sol`](https://github.com/balancer/balancer-v3-monorepo/blob/main/pkg/vault/test/foundry/LiquidityApproximation.t.sol#L682) test file where the required assertions are verified in `assertLLiquidityOperationNoSwapFee()` and `assertLiquidityOperation()`.

0 comments on commit b14d0c9

Please sign in to comment.