Matt Corallo [ARCHIVE] on Nostr: ๐
Original date posted:2022-09-17 ๐ Original message:On 9/17/22 2:14 AM, ...
๐
Original date posted:2022-09-17
๐ Original message:On 9/17/22 2:14 AM, Anthony Towns wrote:
> On Fri, Sep 16, 2022 at 12:46:53PM -0400, Matt Corallo via bitcoin-dev wrote:
>> On 9/16/22 3:15 AM, Anthony Towns via bitcoin-dev wrote:
>>> As we've seen from the attempt at a CHECKTEMPLATEVERIFY activation earlier
>>> in the year [0], the question of "how to successfully get soft fork
>>> ideas from concept to deployment" doesn't really have a good answer today.
>> I strongly disagree with this.
>
> Okay? "X is good" is obviously just a statement of opinion, so if you
> want to disagree, that's obviously allowed.
>
> I also kind of feel like that's the *least* interesting paragraph in the
> entire email to talk further about; if you think the current answer's
> already good, then the rest of the mail's just about (hopefully) making
> it better, which would be worthwhile anyway?
No, I think its at least a good chunk of the "statement of problem". Yes, more testing is good, and
this project is a way to get that. Cool. But implying that lack of test frameworks is in any
material way part of the lack of movement on forks in Bitcoin I think is very wrong, so its worth
pointing out, whether the particular project is useful or not is separate.
>> Going back many, many years we've had many
>> discussions about fork process, and the parts people (historically) agreed
>> with tend to be:
>> (1) come up with an idea
>> (2) socialize the idea in the technical community, see if anyone comes up
>> with any major issues or can suggest better ideas which solve the same
>> use-cases in cleaner ways
>> (3) propose the concrete idea with a more well-defined strawman, socialize
>> that, get some kind of rough consensus in the loosely-defined, subjective,
>> "technical community" (ie just ask people and adapt to feedback until you
>> have found some kind of average of the opinions of people you, the
>> fork-champion, think are reasonably well-informed!).
>> (4) okay, admittedly beyond this is a bit less defined, but we can deal with it when we get there.
>> Turns out, the issue today is a lack of champions following steps 1-3, we
>> can debate what the correct answer is to step (4) once we actually have
>> people who want to be champions who are willing to (humbly) push an idea
>> forward towards rough agreement of the world of technical bitcoiners
>> (without which I highly doubt you'd ever see broader-community consensus).
>
> Personally, I think this is easily refuted by contradiction.
>
> 1) If we did have a good answer for how to progress a soft-fork, then
> the great consensus cleanup [0] would have made more progress over the
> past 3.5 years
No? Who is the champion for it? I haven't been. No one else is obliged to take up the reins and run
with it, that's not how open-source works. And no one has emerged who has strong interest in doing
so, and that's totally fine. It means it hasn't made any progress, but that's an indication that no
one feels strongly enough about it that its risen to the top of their personal priority list so
clearly doesn't *need* to make progress.
> Maybe not all of the ideas in it were unambiguously good
> [1], but personally, I'm convinced at least some of them are, and I
> don't think I'm alone in thinking that. Even if the excuse is that its
> original champion wasn't humble enough, there's something wrong with
> the process if there doesn't exist some other potential champion with
> the right balance of humility, confidence, interest and time who could
> have taken it over in that timeframe.
No? Its not up to the community to find a champion for someone who wants a fork to happen. Either
someone thinks its a good enough idea that they step up, or no one does. If no one does, then so be
it. If the original proper (me, in this case) thought it was that important then its *their*
responsibility to be the champion, no one else's.
> 2) Many will argue that CTV has already done steps (1) through (3) above:
> certainly there's been an idea, it's been socialised through giving talks,
> having discussion forums, having research workshops [2], documenting use
> cases use cases; there's been a concrete implementation for years now,
> with a test network that supports the proposed feature, and new tools
> that demonstrate some of the proposed use cases, and while alternative
> approaches have been suggested [3], none of them have even really made
> it to step (2), let alone step (3).
I don't really see how you can make this argument seriously. Honestly, if a soft-fork BIP only has
one author on the list, then I'm not sure one can argue that step (3) has really been completed, and
maybe not even step (2).
> So that leaves a few possibilities
> to my mind:
> * CTV should be in step (4), and its lack of definition is a problem,
> and trying the "deal with it when we get there" approach is precisely
> what didn't work back in April.
>
> * The evaluation process is too inconclusive: it should either be
> saying "CTV is not good enough, fix these problems", or "CTV hasn't
> sufficiently demonstrated its value/cost, work on X next", but it
> isn't.
>
> * Parts (2) to (3) are too hard, and that's preventing alternatives
> from making progress, which in turn is preventing people from
> being able to decide whether CTV is the superior approach, or some
> alternative is.
I think this is most of it, but its not that they're too hard, its that people are *too busy*. There
seemed to be more positive feedback, for example, to Rusty's proposal, but being the champion for a
soft-fork is a full-time job for months on end, and last I checked Rusty has a lightning
implementation to maintain, which tends to be a more-than-full-time job already.
To my knowledge, no one but Jeremy has made any serious attempt at being the champion for a
soft-fork since Taproot, and before that Segwit (if someone reading this who contributes to Core
already wants to, and isn't sure how to, there's lots of people who would happily mentor you! I'm
sure you can figure out who to reach out to!).
Matt
Published at
2023-06-07 23:13:31Event JSON
{
"id": "f18e3c5771ff99e0becbcd2c6ad2c9e6ff1fd5c8cb94ef1d22e308d42dffe2c8",
"pubkey": "cd753aa8fbc112e14ffe9fe09d3630f0eff76ca68e376e004b8e77b687adddba",
"created_at": 1686179611,
"kind": 1,
"tags": [
[
"e",
"2ac589e49ebcf69e5e0c0f74981f090043414ccce35cc1264b0db21e4f35bbfa",
"",
"root"
],
[
"e",
"d78ea842a0c1df5c2ee9ed7d11468e8e1c8b9e918635b759c8cd478f59d44345",
"",
"reply"
],
[
"p",
"f0feda6ad58ea9f486e469f87b3b9996494363a26982b864667c5d8acb0542ab"
]
],
"content": "๐
Original date posted:2022-09-17\n๐ Original message:On 9/17/22 2:14 AM, Anthony Towns wrote:\n\u003e On Fri, Sep 16, 2022 at 12:46:53PM -0400, Matt Corallo via bitcoin-dev wrote:\n\u003e\u003e On 9/16/22 3:15 AM, Anthony Towns via bitcoin-dev wrote:\n\u003e\u003e\u003e As we've seen from the attempt at a CHECKTEMPLATEVERIFY activation earlier\n\u003e\u003e\u003e in the year [0], the question of \"how to successfully get soft fork\n\u003e\u003e\u003e ideas from concept to deployment\" doesn't really have a good answer today.\n\u003e\u003e I strongly disagree with this.\n\u003e \n\u003e Okay? \"X is good\" is obviously just a statement of opinion, so if you\n\u003e want to disagree, that's obviously allowed.\n\u003e \n\u003e I also kind of feel like that's the *least* interesting paragraph in the\n\u003e entire email to talk further about; if you think the current answer's\n\u003e already good, then the rest of the mail's just about (hopefully) making\n\u003e it better, which would be worthwhile anyway?\n\nNo, I think its at least a good chunk of the \"statement of problem\". Yes, more testing is good, and \nthis project is a way to get that. Cool. But implying that lack of test frameworks is in any \nmaterial way part of the lack of movement on forks in Bitcoin I think is very wrong, so its worth \npointing out, whether the particular project is useful or not is separate.\n\n\u003e\u003e Going back many, many years we've had many\n\u003e\u003e discussions about fork process, and the parts people (historically) agreed\n\u003e\u003e with tend to be:\n\u003e\u003e (1) come up with an idea\n\u003e\u003e (2) socialize the idea in the technical community, see if anyone comes up\n\u003e\u003e with any major issues or can suggest better ideas which solve the same\n\u003e\u003e use-cases in cleaner ways\n\u003e\u003e (3) propose the concrete idea with a more well-defined strawman, socialize\n\u003e\u003e that, get some kind of rough consensus in the loosely-defined, subjective,\n\u003e\u003e \"technical community\" (ie just ask people and adapt to feedback until you\n\u003e\u003e have found some kind of average of the opinions of people you, the\n\u003e\u003e fork-champion, think are reasonably well-informed!).\n\u003e\u003e (4) okay, admittedly beyond this is a bit less defined, but we can deal with it when we get there.\n\u003e\u003e Turns out, the issue today is a lack of champions following steps 1-3, we\n\u003e\u003e can debate what the correct answer is to step (4) once we actually have\n\u003e\u003e people who want to be champions who are willing to (humbly) push an idea\n\u003e\u003e forward towards rough agreement of the world of technical bitcoiners\n\u003e\u003e (without which I highly doubt you'd ever see broader-community consensus).\n\u003e \n\u003e Personally, I think this is easily refuted by contradiction.\n\u003e \n\u003e 1) If we did have a good answer for how to progress a soft-fork, then\n\u003e the great consensus cleanup [0] would have made more progress over the\n\u003e past 3.5 years\n\nNo? Who is the champion for it? I haven't been. No one else is obliged to take up the reins and run \nwith it, that's not how open-source works. And no one has emerged who has strong interest in doing \nso, and that's totally fine. It means it hasn't made any progress, but that's an indication that no \none feels strongly enough about it that its risen to the top of their personal priority list so \nclearly doesn't *need* to make progress.\n\n\u003e Maybe not all of the ideas in it were unambiguously good\n\u003e [1], but personally, I'm convinced at least some of them are, and I\n\u003e don't think I'm alone in thinking that. Even if the excuse is that its\n\u003e original champion wasn't humble enough, there's something wrong with\n\u003e the process if there doesn't exist some other potential champion with\n\u003e the right balance of humility, confidence, interest and time who could\n\u003e have taken it over in that timeframe.\n\nNo? Its not up to the community to find a champion for someone who wants a fork to happen. Either \nsomeone thinks its a good enough idea that they step up, or no one does. If no one does, then so be \nit. If the original proper (me, in this case) thought it was that important then its *their* \nresponsibility to be the champion, no one else's.\n\n\u003e 2) Many will argue that CTV has already done steps (1) through (3) above:\n\u003e certainly there's been an idea, it's been socialised through giving talks,\n\u003e having discussion forums, having research workshops [2], documenting use\n\u003e cases use cases; there's been a concrete implementation for years now,\n\u003e with a test network that supports the proposed feature, and new tools\n\u003e that demonstrate some of the proposed use cases, and while alternative\n\u003e approaches have been suggested [3], none of them have even really made\n\u003e it to step (2), let alone step (3).\n\nI don't really see how you can make this argument seriously. Honestly, if a soft-fork BIP only has \none author on the list, then I'm not sure one can argue that step (3) has really been completed, and \nmaybe not even step (2).\n\n\u003e So that leaves a few possibilities\n\u003e to my mind:\n\n\u003e * CTV should be in step (4), and its lack of definition is a problem,\n\u003e and trying the \"deal with it when we get there\" approach is precisely\n\u003e what didn't work back in April.\n\u003e \n\u003e * The evaluation process is too inconclusive: it should either be\n\u003e saying \"CTV is not good enough, fix these problems\", or \"CTV hasn't\n\u003e sufficiently demonstrated its value/cost, work on X next\", but it\n\u003e isn't.\n\u003e \n\u003e * Parts (2) to (3) are too hard, and that's preventing alternatives\n\u003e from making progress, which in turn is preventing people from\n\u003e being able to decide whether CTV is the superior approach, or some\n\u003e alternative is.\n\nI think this is most of it, but its not that they're too hard, its that people are *too busy*. There \nseemed to be more positive feedback, for example, to Rusty's proposal, but being the champion for a \nsoft-fork is a full-time job for months on end, and last I checked Rusty has a lightning \nimplementation to maintain, which tends to be a more-than-full-time job already.\n\nTo my knowledge, no one but Jeremy has made any serious attempt at being the champion for a \nsoft-fork since Taproot, and before that Segwit (if someone reading this who contributes to Core \nalready wants to, and isn't sure how to, there's lots of people who would happily mentor you! I'm \nsure you can figure out who to reach out to!).\n\nMatt",
"sig": "60cb8d97eed2a08064608a9f65fe8dd02a72fd8e2fd65decc27e436f36491f718cef275e17a9b13fe340b26734d7fe3c23a40ec00b23712e50521008051a6532"
}