On Tue, Jul 20, 2021 at 10:56:10PM -0700, Billy Tetrud via bitcoin-dev wrote: > This involves [...] constraining the amount of the fee that output is > allowed to contribute to. [...] fee is specified relative to recent > median fee rates - details in the proposal).
Here are the relevant details: > The medianFeeRate is defined as the median fee rate per vbyte for the > most recent windowLength blocks. The maxFeeContribution is defined as > medianFeeRate * 2^feeFactor of the fee. Note that this is a limitation > on the fee, not on the fee-rate. If feeFactor is -1, > maxFeeContribution is 0. First, I don't think we want full nodes to have to store the feerate for every transaction in a 3,000 block window (~2.5 million txes, assuming all segwit). I'm sure you could tweak this proposal to require a much smaller dataset. Second, I think this requires careful consideration of how it might affect the incentives for miners. Miners can include many small high-fee pay-to-self transactions in their blocks to raise the median feerate, but this puts them at increased risk of fee sniping from other miners, which may incentivize fee-raisers to centralize their mining, which is ultimately bad. I'm not sure that's a huge concern with this proposal, but I think it and other incentive problems require consideration. Finally, I think this fee mechanism is redundant. For any case where this opcode will be used, you'll want to have two things: 1. A mutual spend clause (e.g. a multisignature taproot keypath spend) where all parties agree on a spend of the output and so can set an appropriate feerate at that time. You want this because it'll be the most efficient way to spend. 2. A fee override that allows paying additional fees beyond what OP_CONSTRAINDESTINATION allows, either through attaching an additional input or through CPFP. You want this because you will know more about feerate conditions at spend time than you did when you created the receiving script. If you have the ability to choose feerates through the above mechanisms, you don't need a constrained feerate mechanism that might be manipulable by miners. (I haven't looked closely at the rest of your proposal; the above just caught my attention.) -Dave
signature.asc
Description: PGP signature
_______________________________________________ bitcoin-dev mailing list bitcoin-dev@lists.linuxfoundation.org https://lists.linuxfoundation.org/mailman/listinfo/bitcoin-dev