One Time Signatures as an Advantage?

102 views
Skip to first unread message

Jason Resch

unread,
May 20, 2026, 1:44:04 PMMay 20
to Bitcoin Development Mailing List
NIST is standardizing SLH-DSA as a stateless, post-quantum-secure hash-based signature scheme. However, to achieve the stateless feature of being able to sign multiple messages, requires a significant size overhead.

SLH-DSA (for parameters n=16, w=16) results in signatures that are 7,888 bytes long.

However, if statelessness isn't required, and this can be reduced to 900 bytes for something like XMSS using the same parameters.

Furthermore, if multiple signings per key are dropped as a requirement, and "one time signatures" are used (e.g. WOTS+) then this size reduces further to 560 bytes.

This is a ~14× reduction in signature size for a feature that Bitcoin transactions not only don't need, but are strongly discouraged if not harmful. Using the same key more than once is only required if one is reusing the same address (discouraged), or if one is attempting some kind of double-spend attack.

This could be seen as a sort of advantage: if one attempts to double-spend, they may expose their private key. This same property was an element of Chaum's digital cash: attempting to double-spend exposed you.

Is there any advocacy for NIST to standardize stateful or one-time-use signature algorithms? They seem well-suited to the block-chain use case, where there is always global and persistent state, and keys ought not be re-used. Though this needs to be carefully managed by wallet software: to only expose a one-time-use address to handle a single transaction with a single payer, and never use a OTS address for any kind of public-facing or long-term donation address. Perhaps this complication makes OTS not worth introducing generally, but their space saving properties are attractive.

Jason

Mikhail Kudinov

unread,
May 21, 2026, 6:00:10 AMMay 21
to Jason Resch, Bitcoin Development Mailing List
Stateful hash-based schemes have been recommended by NIST. See https://nvlpubs.nist.gov/nistpubs/SpecialPublications/NIST.SP.800-208.pdf . Also you might be interested to read about SHRINCS: https://delvingbitcoin.org/t/shrincs-324-byte-stateful-post-quantum-signatures-with-static-backups/2158.

Best,
Mikhail


--
You received this message because you are subscribed to the Google Groups "Bitcoin Development Mailing List" group.
To unsubscribe from this group and stop receiving emails from it, send an email to bitcoindev+...@googlegroups.com.
To view this discussion visit https://groups.google.com/d/msgid/bitcoindev/d3648bd4-03d3-4b98-92bf-d845302be349n%40googlegroups.com.

Jason Resch

unread,
May 21, 2026, 9:34:42 AMMay 21
to Bitcoin Development Mailing List


On Thu, May 21, 2026, 5:54 AM Mikhail Kudinov <mkud...@blockstream.com> wrote:
Stateful hash-based schemes have been recommended by NIST. See https://nvlpubs.nist.gov/nistpubs/SpecialPublications/NIST.SP.800-208.pdf

Is the intention that these recommendations will eventually lead to full standardization and FIPS compliance?

Will Bitcoin wait for that do you think, or will it lead in adopting something like SHRINCS first and then NIST will follow in certifying what would by then have become a de facto standard?
I learned of SHRINCS just after making my post. I think it provides the best of both worlds: short signatures in the general case when state is available + the flexibility to fall back and sign many times in case state is lost or the stateful key is used too many times.

In terms of PQC algorithms I'm aware of, this one seems to be among the best in terms of its conservative security assumptions and compactness, and the flexibility to sign many times when necessary addresses the problem with public donation addresses.

Jason 

Murch

unread,
May 28, 2026, 1:27:28 PM (11 days ago) May 28
to bitco...@googlegroups.com
One-time signature schemes are not well-suited for Bitcoin because they:

- cannot be used to participate in multi-user transaction (as another
participant could fail the process and force a second signature)
- incur lost funds or lost keys upon address reuse (as every node would
need to track every output script to prevent duplicates, and the
recipient has no say in their output script being sent to another time)
- are incompatible with transaction replacement (zero-conf enthusiasts
rejoice!)

 Murch
> --
> You received this message because you are subscribed to the Google
> Groups "Bitcoin Development Mailing List" group.
> To unsubscribe from this group and stop receiving emails from it, send
> an email to bitcoindev+...@googlegroups.com.
> To view this discussion visit
> https://groups.google.com/d/msgid/bitcoindev/d3648bd4-03d3-4b98-92bf-d845302be349n%40googlegroups.com
> <https://groups.google.com/d/msgid/bitcoindev/d3648bd4-03d3-4b98-92bf-d845302be349n%40googlegroups.com?utm_medium=email&utm_source=footer>.

Peter Todd

unread,
Jun 5, 2026, 1:26:34 AM (4 days ago) Jun 5
to Murch, bitco...@googlegroups.com
On Thu, May 28, 2026 at 10:25:51AM -0700, Murch wrote:
> One-time signature schemes are not well-suited for Bitcoin because they:
>
> - cannot be used to participate in multi-user transaction (as another
> participant could fail the process and force a second signature)
> - incur lost funds or lost keys upon address reuse (as every node would need
> to track every output script to prevent duplicates, and the recipient has no
> say in their output script being sent to another time)
> - are incompatible with transaction replacement (zero-conf enthusiasts
> rejoice!)

Note that you can design a message signing scheme where you can use a pubkey to
sign a merkle tree of messages. In the case of a transaction, multiple
conflicting versions of the transaction with different fee rates.

Basically, a One Time Signing Scheme that produces multiple signatures for one
signing event.

--
https://petertodd.org 'peter'[:-1]@petertodd.org
signature.asc

Anthony Towns

unread,
Jun 5, 2026, 4:26:34 AM (3 days ago) Jun 5
to Peter Todd, Murch, bitco...@googlegroups.com
On Thu, Jun 04, 2026 at 11:01:25AM +0000, Peter Todd wrote:
> On Thu, May 28, 2026 at 10:25:51AM -0700, Murch wrote:
> > One-time signature schemes are not well-suited for Bitcoin because they:
> > - cannot be used to participate in multi-user transaction (as another
> > participant could fail the process and force a second signature)
> > - incur lost funds or lost keys upon address reuse (as every node would need
> > to track every output script to prevent duplicates, and the recipient has no
> > say in their output script being sent to another time)
> > - are incompatible with transaction replacement (zero-conf enthusiasts
> > rejoice!)
> Note that you can design a message signing scheme where you can use a pubkey to
> sign a merkle tree of messages. In the case of a transaction, multiple
> conflicting versions of the transaction with different fee rates.

There's a balance to be had between what's considered part of the message
signing scheme versus what's part of the scripting language.

The scheme above could also be thought of as signing a single message
"spend this utxo is valid if this script's conditions are meant",
where the script is "or(fee <= 0.5, and(nSequence >= 100, fee <= 1.0),
and(nSequence >= 1000, fee <= 30.0))"

Delegating to a signed script like this is essentially the "graftroot"
concept.

Cheers,
aj

Peter Todd

unread,
6:45 AM (9 hours ago) 6:45 AM
to Anthony Towns, Murch, bitco...@googlegroups.com
No, that's a very different scheme. Also, I believe it is vulnerable to miners
simply picking the best possible fee rate for them; nSequence isn't big enough
to avoid being guessed.

Indeed, I neglected to point out something important in the above: you probably
want to include secret nonces (or similar) in each individual branch of the
signature tree, to ensure that different versions of it can't be brute forced.
Thus to reveal a new option for miners, you make public a previously secret
nonce. 128-bits would be sufficiently large to prevent brute-forcing.
signature.asc
Reply all
Reply to author
Forward
0 new messages