-
Notifications
You must be signed in to change notification settings - Fork 36.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Fee Estimation via Fee rate Forecasters #30157
base: master
Are you sure you want to change the base?
Conversation
The following sections might be updated with supplementary metadata relevant to reviewers and maintainers. Code Coverage & BenchmarksFor details see: https://corecheck.dev/bitcoin/bitcoin/pulls/30157. ReviewsSee the guideline for information on the review process.
If your review is incorrectly listed, please react with 👎 to this comment and the bot will ignore it on the next update. ConflictsReviewers, this pull request conflicts with the following ones:
If you consider this pull request important, please also help to review the conflicting pull requests. Ideally, start with the one that should be merged first. |
🚧 At least one of the CI tasks failed. Make sure to run all tests locally, according to the Possibly this is due to a silent merge conflict (the changes in this pull request being Leave a comment here, if you need help tracking down a confusing failure. |
The state of the node's mempool may not accurately reflect the state of others' mempools, and not even its own mempool when the block is found in the future. It isn't a good single source of information. Perhaps it is a good idea to use it as a secondary source, but probably it should only ever adjust fee estimations upward, not down. |
Correct. The rationale behind this set of changes can be summed up briefly as follows:
In the present, there is a strong tendency for users of Bitcoin Core to consult external fee estimation services when they want timely (next 1 or 2 blocks) confirmation of transactions, whilst also not overpaying. Examples of these include mempool.space, whatthefee.io, Samourai's nextblock.is (now down), johoe, blockchair etc., with more popping up every month. We also analysed/estimated Bitcoin Core users not using in-built estimation in a post here. In our opinion having users feel the need to use external fee estimation services that they could equally have served to them by their own node, feels sub-optimal. In addition to this, when users do use the current Bitcoin Core fee estimator, there are often times when they end up overpaying, see delving bitcoin post Mempool based fee estimation and various issues over the years e.g. #30009 . This is avoidable. Work from a student of @renepickhardt link demonstrated something we also measured independently -- that bitcoin core's current estimates are often overpaying significantly following fee spikes. This effect can be directly mitigated by using a mempool-based estimation.
In this changeset we take the approach of using the lowest result from all "confident" Comments from @harding link explained that it may be possible for miners to artificially increase a strictly-mempool-based fee-rate. By taking the lower (confident) result from We do plan to add additional sanity checks to the mempool-based Forcaster as described in #27995, but these are not yet implemented. In any case, even without these additional checks we have been seeing much-improved short time-scale estimations from Bitcoin Core. |
f6748c9
to
6fb2e37
Compare
6fb2e37
to
64ebda7
Compare
64ebda7
to
a28d079
Compare
🚧 At least one of the CI tasks failed. Make sure to run all tests locally, according to the Possibly this is due to a silent merge conflict (the changes in this pull request being Leave a comment here, if you need help tracking down a confusing failure. |
a28d079
to
df7c856
Compare
- This class represents the response returned by a fee rate forecaster.
- Defines the types of confirmation targets for fee rate forecasters. - This enable having a generic input for fee rate forecasters.
- This commit implements `Forecaster` abstract class as the base class of fee rate forecasters. - Derived classes must provide concrete implementation of the virtual methods. Co-authored-by: willcl-ark <will@256k1.dev>
- ForecastType will be used to identify forecasters. - Each time a new forecaster is added, a corresponding enum value should be added to ForecastType. - This allows users to identify which forecasting strategy was used to make a fee rate estimate.
- Its a module for managing and utilising multiple fee rate forecasters to provide fee rate forecast. - The ForecasterManager class allows for the registration of multiple fee rate forecasters. Co-authored-by: willcl-ark <will@256k1.dev>
- Also remame the test suite name to match the new name.
- Also move it to policy/fees and update the includes - Note: the block_policy_estimator.h include in block_policy_estimator.cpp was done manually.
- Also move them to policy/fees/ and update includes - Note: the block_policy_estimator_args.h include in block_policy_estimator_args.cpp was done manually.
- This changes `CBlockPolicyEstimator` to a shared pointer this gives us three advantages. - Registering to validation interface using shared pointer - Scheduling block policy estimator flushes using shared pointer - Registering block policy estimator to forecaster_man
- This method converts a ForecastType enum to its string representation.
- The CalculatePercentiles function, given a vector of feerates in the order they were added to the block, will return the 25th, 50th, 75th, and 95th percentile feerates. - Also add a unit test for this function.
- The mempool based fee rate forecaster generate a predicted fee rate estimate for a given confirmation target using the mempool unconfirmed transactions. Co-authored-by: willcl-ark <will@256k1.dev>
- Provide new estimates only when the time delta from previous forecast is older than 30 seconds. - This caching helps avoid the high cost of frequently generating block templates, preventing users from inadvertently calling `estimateFee` repeatedly. Co-authored-by: willcl-ark <will@256k1.dev>
- Fallback to Block policy estimator estimates whenever mempool forecaster estimates are higher than block policy estimator.
- Given a confirmation target, we use fee estimator module that call all available fee estimator forcasters and return the lowest fee rate that if a transaction use will likely confirm in a given confirmation target. Co-authored-by: willcl-ark <will@256k1.dev>
415692a
to
6d0c2c7
Compare
This PR aims to improve Bitcoin Core Fee Estimation by:
BlockPolicyEstimator
. This issue has been documented and acknowledged by various sources:The detailed design document for this PR can be found here. Please note that the design is subject to change as we refine the approach.
We are currently seeking conceptual acknowledgment for this PR.
This is a collaborative effort with @willcl-ark and incorporates insights from other contributors.