public inbox for bitcoindev@googlegroups.com
 help / color / mirror / Atom feed
From: Jonas Nick <jonasd.nick@gmail.com>
To: bitcoindev@googlegroups.com
Subject: Re: [bitcoindev] Re: DahLIAS: Discrete Logarithm-Based Interactive Aggregate Signatures
Date: Thu, 17 Jul 2025 13:15:40 +0000	[thread overview]
Message-ID: <e15cf0db-bc04-454d-8d63-029bd864d08b@gmail.com> (raw)
In-Reply-To: <182e01b0-30f0-4dec-b4bb-5057bd4ef89fn@googlegroups.com>

Hi waxwing,

Thanks again for your comments.

 > My initial reaction would be, since it's not worsening the scaling of the
 > verifier, does it matter?

I think saving time in signing does matter (3 group exponentiations requiring
O(1) group operations in total vs. O(n/log n) group operations); for example, in
constrained signing devices as you mention. In particular, the "single-b"
variant with the larger signing cost doesn't appear to have advantages (see
below) compared to "multi-b" which has lower signing cost.

 > The scheme is explicitly not limited to Bitcoin, nor blockchains, though,
 > so there's that; is that relevant here?

The scheme is not limited to Bitcoin, but the main application we designed for
is Bitcoin. I agree that verification performance is of primary importance. We
would choose a scheme with lower signing performance, if it gives us a better
verification performance in return (if the trade-off is reasonable).

 > Yes, those are some interesting points to consider. On one detail: "In any
 > case, identifying disruptive participants will work reliably only if the
 > coordinator is honest, so let's assume this." -- this could also be addressed
 > with proofs of knowledge, no?

Maybe I misunderstand what you're getting at, but I don't understand how proofs
of knowledge would get rid of the honest coordinator requirement for identifying
disruptive signers. Moreover, both R_{2,i} and R_{2,j} could have a valid proof
of knowledge attached (for example, if parties i and j share the dlog of R_{2,i}
= R_{2,j}).

 > Anyway, for me it was more a sort of preference for purely algebraic
 > algorithms. It's a little fanciful, but algebraic algorithms are easier to
 > encode in circuits in zero knowledge (though things like equality checks are
 > entirely doable ofc!) and maybe easier to "encode" into modular schemes that
 > use them as a building block. Maybe. Less conditional branches / loops to
 > traverse in the code?

Why exactly would it be easier to encode the multi-b variant in a circuit? The
single-b variant requires checking whether there exists i such that R_{2,i}
matches a fixed R_{2,j}. In the multi-b variant we'd need to compute the product
of all R_{2,i}^{b_i}, which, even with a multiexp implementation, requires at
least visiting all elements plus the actual multiexponentiation involving
O(n/log n) group operations. So encoding the single-b variant appears to be
strictly easier.

-- 
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+unsubscribe@googlegroups.com.
To view this discussion visit https://groups.google.com/d/msgid/bitcoindev/e15cf0db-bc04-454d-8d63-029bd864d08b%40gmail.com.


      reply	other threads:[~2025-07-17 13:34 UTC|newest]

Thread overview: 13+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2025-04-17 16:27 [bitcoindev] DahLIAS: Discrete Logarithm-Based Interactive Aggregate Signatures Jonas Nick
2025-04-19 16:28 ` [bitcoindev] " waxwing/ AdamISZ
2025-04-22 15:29   ` Jonas Nick
2025-04-25 16:08 ` waxwing/ AdamISZ
2025-04-25 16:41   ` Jonas Nick
2025-04-26 15:30 ` waxwing/ AdamISZ
2025-04-26 17:05   ` waxwing/ AdamISZ
2025-04-30  7:59     ` Jonas Nick
2025-04-30 15:54       ` waxwing/ AdamISZ
2025-06-16 19:35         ` waxwing/ AdamISZ
2025-07-02 11:36           ` Tim Ruffing
2025-07-03 14:07             ` waxwing/ AdamISZ
2025-07-17 13:15               ` Jonas Nick [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=e15cf0db-bc04-454d-8d63-029bd864d08b@gmail.com \
    --to=jonasd.nick@gmail.com \
    --cc=bitcoindev@googlegroups.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox