impermax-sdk 2.1.216 → 2.1.218
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.
|
@@ -390,7 +390,7 @@ class UniswapV3Position {
|
|
|
390
390
|
const maxStraightDeleverageValue = this.getValueGivenAmounts(maxStraightDeleverage.amountX, maxStraightDeleverage.amountY);
|
|
391
391
|
const minStraightLeverage = (this.getInitialCollateralValue() - maxStraightDeleverageValue) / this.getInitialEquityValue();
|
|
392
392
|
if (targetLeverage >= minStraightLeverage) {
|
|
393
|
-
const desiredCollateralValue = targetLeverage * this.
|
|
393
|
+
const desiredCollateralValue = targetLeverage * this.getInitialEquityValue();
|
|
394
394
|
const desiredValue = this.getInitialCollateralValue() - desiredCollateralValue;
|
|
395
395
|
const ratio = desiredValue / maxStraightDeleverageValue;
|
|
396
396
|
return {
|
|
@@ -409,6 +409,17 @@ class UniswapV3Position {
|
|
|
409
409
|
repayRatio = this.getValueGivenAmounts(this.getInitialDepositedX(), 0) / this.getInitialCollateralValue();
|
|
410
410
|
}
|
|
411
411
|
const deltaValue = (collateralValue * (targetLeverage - 1) - debtValue * targetLeverage) / (targetLeverage * (1 - repayRatio) - 1);
|
|
412
|
+
// Proof:
|
|
413
|
+
// leverage = newCollateral / (newCollateral - newDebt)
|
|
414
|
+
// newCollateral = collateral - delta
|
|
415
|
+
// newDebt = debt - delta * repayRatio;
|
|
416
|
+
// ((collateral - delta) - (debt - delta * repayRatio)) * leverage = (collateral - delta)
|
|
417
|
+
// (collateral - delta - debt + delta * repayRatio) * leverage - collateral = - delta
|
|
418
|
+
// collateral * leverage - delta * leverage - debt * leverage + delta * repayRatio * leverage - collateral = - delta
|
|
419
|
+
// collateral * leverage - debt * leverage - collateral = - delta + delta * leverage - delta * repayRatio * leverage
|
|
420
|
+
// collateral * (leverage-1) - debt * leverage = delta * (leverage - repayRatio * leverage - 1)
|
|
421
|
+
// collateral * (leverage-1) - debt * leverage = delta * (leverage * (1-repayRatio) - 1)
|
|
422
|
+
// (collateral * (leverage-1) - debt * leverage) / (leverage * (1-repayRatio) - 1) = delta
|
|
412
423
|
// 4. Return amounts if the leverage is achievable
|
|
413
424
|
if (deltaValue < 0 || deltaValue > collateralValue)
|
|
414
425
|
return null;
|