2026-03-10 23:13:57 +00:00
|
|
|
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
|
|
pragma solidity ^0.8.19;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @notice Dyadic rational input: mantissa × 2^(-shift).
|
|
|
|
|
|
* For shift == 0 (current usage via _toDyadic), value == mantissa.
|
|
|
|
|
|
*/
|
|
|
|
|
|
struct OptimizerInput {
|
|
|
|
|
|
int256 mantissa;
|
|
|
|
|
|
int256 shift;
|
|
|
|
|
|
}
|
2026-03-13 07:20:42 +00:00
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @title IOptimizer
|
|
|
|
|
|
* @notice Minimal interface for the Optimizer contract consumed by LiquidityManager.
|
|
|
|
|
|
* Declaring the ABI here makes upgrade-compatibility explicit: any new
|
|
|
|
|
|
* Optimizer implementation must satisfy this selector or the LiquidityManager
|
|
|
|
|
|
* will fall back to bear-mode defaults via its try-catch.
|
|
|
|
|
|
*/
|
|
|
|
|
|
interface IOptimizer {
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @notice Returns the four liquidity parameters used by LiquidityManager.recenter().
|
2026-03-14 01:40:41 +00:00
|
|
|
|
* @return capitalInefficiency Capital buffer level (0..1e18, clamped to MAX_PARAM_SCALE). CI=0 is safest.
|
|
|
|
|
|
* @return anchorShare Fraction of non-floor ETH in anchor (0..1e18, clamped to MAX_PARAM_SCALE).
|
|
|
|
|
|
* @return anchorWidth Anchor position width in tick units (uint24); max 100 ticks (MAX_ANCHOR_WIDTH), enforced by LiquidityManager.
|
|
|
|
|
|
* @return discoveryDepth Discovery liquidity density (0..1e18, clamped to MAX_PARAM_SCALE).
|
2026-03-13 07:20:42 +00:00
|
|
|
|
*/
|
|
|
|
|
|
function getLiquidityParams()
|
|
|
|
|
|
external
|
|
|
|
|
|
view
|
|
|
|
|
|
returns (uint256 capitalInefficiency, uint256 anchorShare, uint24 anchorWidth, uint256 discoveryDepth);
|
|
|
|
|
|
}
|