Good morning John, > dear ZmnSCPxj, > > > Which I suppose is my point: you lose some of the "magic shrinking > > blockchain" property in implementing relative locktimes, as you now > > increase the data you have to store forever (i.e. the kernels). > > The "magic shrinking" of MW never applied to kernels. To validate the > current UTXO set, you need to validate all the kernels, each of > which is a Pedersen commitment to zero together with a Schnorr > signature using said commitment as public key.
However, my understanding is that, at least with the original mimblewimble.txt from Jedusor, the signatures and the Pedersen-commitment-to-0 could all be aggregated into a single signature and Pedersen-commitment-to-0, if we were to use Schnorr-like signatures. (it is possible I misunderstand this; I am not in fact a cryptographer. Indeed, the original mimblewimble.txt mentions having to store every `k*G` and every signature attesting to it, although does not mention Schnorr and might not have considered the possibility of signature aggregation when using Schnorr-like signatures. There could be security issues I am unaware of, for example.) In addition, the mimblewimble.pdf from andytoshi includes a "Sinking Signatures" section, which to my understanding, combines absolute-locktime kernels with partial O(log n) aggregation of the signatures that attest it. Again, it is possible I misunderstand this. It seems to me that neither technique is possible with relative locktime kernels. Again, this may be merely my ignorance of such. In any case, this is mostly moot and I ask only out of curiosity in order to know more about kernels in non-relative-locktime MimbleWimble chains. >Then you need to check > that the sum of UTXO commitments (outputs) minus the summed block > rewards times G (inputs) equals the sum of kernel commitments. > Basically, the same check that is applied to individual transactions. > > Decker-Russell-Osuntokun ("eltoo") is harder due to the `SIGHASH_NOINPUT` > > requirement. > > I have tried to derive an equivalent to this `SIGHASH_NOINPUT` somehow by > > considering that the "reference to previous kernel" as being akin to the > > Bitcoin transaction input referring to a previous output, however it seems > > to be not easy to create a retargatable "reference to previous kernel" in > > this way. > > The Grin "Elder channel" design of [3] is similar in spirit to eltoo > though, as the revocation transaction can be combined with the final > close transaction to counter any closing attempt to an obsolete state. > The design also offers some bandwidth savings compared to the > Poon-Dryja design. This seems interesting. I shall look into this further. Regards, ZmnSCPxj _______________________________________________ bitcoin-dev mailing list bitcoin-dev@lists.linuxfoundation.org https://lists.linuxfoundation.org/mailman/listinfo/bitcoin-dev