Lecture Notes
Lecture Notes
Cryptographic Protocols
Version 1.10
February 7, 2025
Berry Schoenmakers
Department of Mathematics and Computer Science,
Technical University of Eindhoven,
P.O. Box 513, 5600 MB Eindhoven, Netherlands.
berry@win.tue.nl
l.a.m.schoenmakers@tue.nl
Spring 2025
Available online:
• matching lecture slides (printable handout) with links to relevant parts of MPyC
2
Preface
As a motivating example for the cryptographic protocols covered in these lecture notes con-
sider the Dutch tradition of “Sinterklaaslootjes trekken,” internationally known as “Secret
Santa,” in which a group of people anonymously exchange small gifts—often accompanied by
poems quite a few rhyming couplets long. A lot of websites are available to help people orga-
nize such drawings over the internet; see, for example, lootjestrekken.nl and the “Secret
Santa” service at elfster.com. The interesting question is how to do this securely! That is,
without trusting the website or program providing this service, but with the guarantee (a)
that indeed a random drawing is performed, corresponding to a random permutation without
fixed points, and (b) such that each participant learns nothing except who he or she is a
Secret Santa for.
More serious applications of such privacy-protecting cryptographic protocols are emerging
in lots of places. For instance, over the last two decades many electronic elections using
advanced cryptography have already been conducted. Other applications involve the use of
anonymous cash, anonymous credentials, group signatures, secure auctions, etc., all the way
to (secure) multiparty computation.
To this end we study cryptographic techniques that go beyond what we like to refer to
as Crypto 1.0. Basically, Crypto 1.0 concerns encryption and authentication of data during
communication, storage, and retrieval. Well-known Crypto 1.0 primitives are symmetric (se-
cret key) primitives such as stream ciphers, block ciphers, and message authentication codes;
asymmetric (public key) primitives such as public key encryption, digital signatures, and key
exchange protocols; and, keyless primitives such as cryptographic hash functions. The com-
mon goal is to protect against malicious outsiders, say, attacking storage or communication
media.
On the other hand, Crypto 2.0 additionally aims at protection against malicious insiders,
that is, against attacks by the other parties engaged in the protocol that one is running.
Thus, Crypto 2.0 concerns computing with encrypted data, partial information release of
data, and hiding the identity of data owners or any link with them. Well-known Crypto 2.0
primitives are homomorphic encryption, secret sharing, oblivious transfer, blind signatures,
zero-knowledge proofs, and multiparty computation, which will all be treated to a certain
extent in these lecture notes.
The treatment throughout will be introductory yet precise at various stages. Familiarity
with basic cryptography is assumed. We focus on asymmetric techniques for cryptographic
protocols, also considering proofs of security for various constructions. The topic of zero-
knowledge proofs plays a central role. In particular, Σ-protocols are treated in detail as a
primary example of the so-called simulation paradigm, which forms the basis of much of
modern cryptography.
The first and major version of these lecture notes was written in the period of December
2003 through March 2004. Many thanks to all the students and readers over the years for their
feedback, both directly and indirectly, which helped to finally produce the first full version of
this text. Berry Schoenmakers
3
Contents
Preface 3
List of Figures 6
1 Introduction 7
1.1 Terminology 7
1.2 Preliminaries 8
Number Theory – Group Theory – Probability Theory – Complexity Theory
1.3 Assumptions 13
Discrete Log and Diffie–Hellman Assumptions – Indistinguishability – Random Self-Reducibility – Random Oracle Model
3 Commitment Schemes 30
3.1 Definitions 30
3.2 Examples 31
Using a Cryptographic Hash Function – Using a Discrete Log Setting – Impossibility Result
4 Identification Protocols 34
4.1 Definitions 34
4.2 Password-Based Schemes 35
4.3 One-Way Hash Chains 36
4.4 Basic Challenge-Response Protocols 36
Using Symmetric Encryption – Using Symmetric Authentication – Using Asymmetric Encryption – Using Asymmetric Authentication
4
5 Zero-Knowledge Proofs 47
5.1 Σ-Protocols 47
5.2 Composition of Σ-Protocols 52
Parallel Composition – AND-Composition – EQ-Composition – OR-Composition – NEQ-Composition
5.3 Miscellaneous Constructions 59
5.4 Noninteractive Σ-Proofs 62
Digital Signatures from Σ-Protocols – Proofs of Validity – Group Signatures
5.5 Bibliographic Notes 67
6 Threshold Cryptography 69
6.1 Secret Sharing 69
Shamir Threshold Scheme
6.2 Verifiable Secret Sharing 71
Feldman VSS – Pedersen VSS
6.3 Threshold Cryptosystems 75
Threshold ElGamal Cryptosystem
6.4 Bibliographic Notes 77
7 Multiparty Computation 78
7.1 Electronic Voting 78
7.2 Based on Threshold Homomorphic Cryptosystems 81
7.3 Based on Oblivious Transfer 83
7.4 Based on Threshold Secret Sharing 84
7.5 Bibliographic Notes 87
8 Blind Signatures 88
8.1 Definitions 88
8.2 Chaum Blind Signature Scheme 89
8.3 Blind Signatures from Σ-Protocols 90
8.4 Bibliographic Notes 91
Solutions to Exercises 93
Bibliography 144
5
List of Figures
6
CHAPTER 1
Introduction
1.1 TERMINOLOGY
The field of cryptology is generally divided into the two mutually dependent fields of cryp-
tography and cryptanalysis. Cryptography concerns the design of (mathematical) schemes
related to information security which resist cryptanalysis, whereas cryptanalysis is the study
of (mathematical) techniques for attacking cryptographic schemes.
The following distinction is commonly made between cryptographic algorithms, crypto-
graphic protocols, and cryptographic schemes.
DEFINITION 1.1 A cryptographic algorithm is a well-defined transformation, which on
a given input value produces an output value, achieving certain security objectives. A cryp-
tographic protocol is a distributed algorithm describing precisely the interactions between
two or more entities, achieving certain security objectives. A cryptographic scheme is
a suite of related cryptographic algorithms and cryptographic protocols, achieving certain
security objectives.
7
8 CHAPTER 1 Introduction
1.2 PRELIMINARIES
Throughout these lecture notes, basic familiarity with the following notions from mathematics
and theoretical computer science is assumed: number theory, group theory, probability theory,
and complexity theory. Particularly relevant aspects of these theories are highlighted below.
EXERCISE 1.2.1 Prove the elementary bound n/ϕ(n) = O(log n), using that the number of
distinct prime factors ω(n) of n is O(log n), and that the ith smallest prime factor of n is at
least i + 1 for i = 1, 2, . . . , ω(n).
Interestingly, the following generalization of Euler’s phi function will play a role in the analysis
of a variant of the decision Diffie–Hellman problem (see Exercise 1.3.5(b)). The (order-2)
Schemmel totient function is defined as ϕ2 (n) = |{x ∈ Zn : gcd(x, n) = gcd(x + 1, n) = 1}|.
For n odd, we have ϕ2 (n) = n p|n (1 − 2/p) and n/ϕ2 (n) = O((log log n)2 ).
Q
EXERCISE 1.2.2 For n odd, prove the elementary bound n/ϕ2 (n) = O(log2 n), using again
that ω(n) = O(log n) and that the ith smallest prime factor of n is now at least i + 2 for
i = 1, 2, . . . , ω(n).
denote its order, hence ord(h) | n by Lagrange’s theorem. Any g ∈ Gn with ord(g) = n is a
generator of Gn , that is, Gn = ⟨g⟩ = {g x : x ∈ Zn }, or equivalently, the elements of Gn can
be enumerated as 1, g, g 2 , g 3 , . . . , g n−1 , noting that g n = 1.
The discrete logarithm (or, discrete log) of an element h ∈ ⟨g⟩ is defined as the
unique integer x ∈ Zn satisfying h = g x . We write x = logg h. For the following groups it is
commonly assumed that computing discrete logarithms is hard for appropriate values of n.
EXAMPLE 1.3 Take Gn = Z∗p , for a prime p. Then Gn is a cyclic group of order n = p − 1.
Clearly, n is not prime (unless p = 3, of course).
More generally, one may take Gn = F∗q , the multiplicative group of a finite field of order
q = pd , for some positive integer d. Then Gn is a cyclic group of order n = q − 1.
EXAMPLE 1.4 Take Gn = ⟨g⟩, where g denotes an element of order p′ in Z∗p , with p′ | p − 1,
p, p′ prime. Then Gn is a cyclic group of order n = p′ . Clearly, n is prime in this case.
More generally, one may take Gn = ⟨g⟩, where g denotes an element of order p′ in F∗q ,
with p′ | q − 1.
EXAMPLE 1.5 Consider E(Fq ), the finite group of points of an elliptic curve over Fq , which
is usually written additively, with the point at infinity O as identity element. Then E(Fq ) is
abelian, but not necessarily cyclic. In general, E(Fq ) is isomorphic to Zn1 ×Zn2 , where n1 | n2
and n1 | q − 1. So, E(Fq ) is cyclic if and only if n1 = 1. Hence, one may take Gn = E(Fq ) if
n1 = 1; otherwise, one may take a cyclic subgroup of E(Fq ) for Gn .
Finally, as a convenient notation, we let ⟨g⟩∗ = {g x : x ∈ Z∗n } denote the set of all
generators of ⟨g⟩. Clearly, |⟨g⟩∗ | = ϕ(n), which is the number of generators of any cyclic
group of order n.
EXERCISE 1.2.3 Show that for any h ∈ ⟨g⟩, the following conditions are equivalent:
(i) h ∈ ⟨g⟩∗ ,
EXERCISE 1.2.4 (a) Show that alogh b = blogh a for any a, b ∈ ⟨g⟩ and h ∈ ⟨g⟩∗ . (b) For
a, b ∈ ⟨g⟩, define a ∗ b = alogg b as the Diffie–Hellman (DH) product of a and b. Show that
(⟨g⟩∗ , ∗) is an abelian group.
DEFINITION 1.6 The statistical distance ∆(X; Y ) between random variables X and Y
is defined as X
∆(X; Y ) = 21 Pr[X = v] − Pr[Y = v] ,
v∈V
(ii) ∆(X; Y ) = 0 if and only if ∀v∈V Pr[X = v] = Pr[Y = v], “identical distributions”
Clearly, ∆(X; X) = 0.
Alternative ways to characterize or compute statistical distance are as follows.
PROPOSITION 1.8 For random variables X and Y :
(i) ∆(X; Y ) = v∈V + Pr[X = v]−Pr[Y = v] , with V + ={v ∈ V : Pr[X=v] > Pr[Y =v]},
P
P
(ii) ∆(X; Y ) = v∈V Pr[X = v] −. Pr[Y = v], with x−y
. = max(x−y, 0) (“x monus y”),
P
(iii) ∆(X; Y ) = 1 − v∈V min Pr[X = v], Pr[Y = v] ,
EXERCISE 1.2.5 (a) Prove Proposition 1.7. (b) Prove Proposition 1.8.
EXERCISE 1.2.6 Prove that ∆(f (X); f (Y )) ≤ ∆(X; Y ) for any function f defined on V .
X = {u : u ∈R {0, . . . , n − 1}},
Y = {u + d : u ∈R {0, . . . , n − 1}}.
X = {u : u ∈R {0, . . . , n − 1}},
Y = {2u : u ∈R {0, . . . , n − 1}},
Z = {2u + 1 : u ∈R {0, . . . , n − 1}}.
Show that ∆(Y ; Z) = 1. Show that ∆(X; Y ) = ∆(X; Z) = 1/2 for even n, and also determine
∆(X; Y ) and ∆(X; Z) for odd n.
EXERCISE 1.2.9 For n ≥ 1, let X ∈R Zn and Y ∈R Z∗n . (a) Determine ∆(X; Y ). (b) Show
that ∆(X + Y ; XY ) = 0, where addition and multiplication are done modulo n.
EXERCISE 1.2.10 For n prime, let h and M0 be arbitrary, fixed elements of Gn = ⟨g⟩, h ̸= 1.
Consider distributions X, Y , and Z given by
Show that ∆(X; Y ) = 0 and ∆(Y ; Z) = 1 − 1/n. Show that also ∆(X; Z) = 1 − 1/n (e.g.,
using triangle inequalities).
EXERCISE 1.2.11 For n ≥ d ≥ 1, let random variable X take on values in {0, . . . , d − 1},
and let U ∈R {0, . . . , n − 1}. Show ∆(U ; X + U ) ≤ (d − 1)/n, and that this bound is tight.
The result of Exercise 1.2.11 implies that ∆(U ; X + U ) is small if d ≪ n. For instance, if
one sets n = d2k , we see that the statistical distance between U and X + U is less than 1/2k ,
which approaches 0 exponentially fast as a function of k. In other words, one can mask an
integer value X from a bounded range {0, . . . , d − 1} by adding a uniformly random integer
U from a much larger range {0, . . . , n − 1}.
This way one can do one-time pad encryption with integers, using X as plaintext, U as
one-time pad, and X + U as ciphertext. The next exercise confirms that near-perfect secrecy
is achieved as the mutual information I(X; X +U ) between plaintext X and ciphertext X +U
vanishes for d ≪ n.
EXERCISE 1.2.12 See Exercise 1.2.11. Define I(X; C) = H(X) − H(X|C) as the mutual
information between X and C = X + U , where
d−1
X
H(X) = − Pr[X = w] log2 Pr[X = w],
w=0
d+n−2
X d−1
X
H(X|C) = − Pr[C = v] Pr[X = w | C = v] log2 Pr[X = w | C = v]
v=0 w=0
denote the (Shannon) entropy of X and the conditional entropy of X given C, respectively.
Show that I(X; C) ≤ H(X)(d − 1)/n.
EXERCISE 1.2.13 For nonempty sets S and T , let X ∈R S and Y ∈R T . Prove that
|S ∩ T |
∆(X; Y ) = 1 − .
max(|S|, |T |)
12 CHAPTER 1 Introduction
x, this probability is at most 1/3.6 Throughout, we will thus say that a problem is “easy”
(or, “feasible”) if it is in BPP, hence can be solved by a p.p.t. algorithm, and we say it is
“hard” (or, “infeasible”) otherwise. Thus, “hard” means that any efficient algorithm only
succeeds with negligibly small probability in computing the correct output.
1.3 ASSUMPTIONS
Throughout these lecture notes, we focus on a discrete log (DL) setting in terms of an abstract
cyclic group Gn = ⟨g⟩. The well-known computational and decisional hardness assumptions
for this generic DL setting are introduced informally below. Three notions of indistinguisha-
bility playing a central role in cryptography are introduced next, all defined in terms of statis-
tical distance. The fundamental notion of random self-reducibility is introduced as well—for
lots of reasons actually, but in particular to show that the hardness assumptions for the DL
setting formulated in terms of average-case complexity are no stronger than their worst-case
cousins. Finally, the random oracle model is presented, which is essentially a particular way
to formulate hardness assumptions for cryptographic hash functions.
DEFINITION 1.10 The Diffie–Hellman (DH) assumption for group ⟨g⟩ states that it
is hard to compute g xy given random group elements g x and g y .
DEFINITION 1.11 The Decisional Diffie–Hellman (DDH) assumption for group ⟨g⟩
states that it is hard to distinguish g xy from a random group element g z given random group
elements g x and g y .
The DH assumption is sometimes called the Computational Diffie–Hellman (CDH) as-
sumption to stress the difference with the DDH assumption.
Evidently, these assumptions satisfy: DL ⇐ DH ⇐ DDH. Therefore it is better if a scheme
can be proved secure under just the DL assumption. It turns out, however, that in many
6
The role of BPP should not be confused with the role of the complexity class NP, which is defined as
the set of all problems which can be solved by a nondeterministic polynomial time Turing machine. Here,
the time needed by a nondeterministic Turing machine on a given input string is defined as the least number of
steps before it halts (as if one—by magic—always makes the right choice to solve a problem instance as quickly
as possible). The big open question is whether P = NP, or not. If indeed P ̸= NP7 , then it would follow that
the so-called NP-complete problems take more than polynomial time to solve in the worst case—but, this says
nothing about the average case.
7
If P ̸= NP, then there exist so-called NP-intermediate problems which are problems in NP that are not
NP-complete but are also outside P. The discrete logarithm problem and the integer factorization problem are
conjectured to be NP-intermediate. Of course, both problems are also conjectured to be outside BPP. Shor’s
algorithm, however, puts these two problems in the complexity class BQP, the class of problems that can
be solved with bounded-error by a p.p.t. quantum Turing machine. Quantum Turing machines and equivalent
notions such as quantum circuits capture the potential of universal quantum computation. Physical realization
of universal quantum computers of significant size, though, is probably still decades away.
14 CHAPTER 1 Introduction
cases the security can only be proved under the DH assumption, or even only under the DDH
assumption.8
1.3.2 INDISTINGUISHABILITY
The DDH assumption is then that X⟨g⟩ and Y⟨g⟩ are computationally indistinguishable.
Note that it does not matter whether we take distribution Y⟨g⟩ or the related distribution
′
Y⟨g⟩ given by
′
Y⟨g⟩ = {(g x , g y , g z ) : x, y, z ∈R Zn }, “random triples”
since these two distributions are statistically indistinguishable. This can be verified as follows,
using Definition 1.6:
P
∆(Y ; Y ′ ) = 12 Pr[Y = (g x , g y , g z )] − Pr[Y ′ = (g x , g y , g z )]
x,y,z∈Zn
1 P x y z ′ x y z
= 2 x,y,z∈Zn ,z̸=xy Pr[Y = (g , g , g )] − Pr[Y = (g , g , g )]
+ x,y,z∈Zn ,z=xy Pr[Y = (g x , g y , g z )] − Pr[Y ′ = (g x , g y , g z )]
P
= 12 (n3 − n2 ) n3 −n 1
2 − 1
n3
+ n 2 0− 1
n3
= 1/n.
= 1.
Hence, ∆(X; Y ) is maximal, which is no surprise as X⟨g⟩ and Y⟨g⟩ are disjoint. Yet, the
distributions cannot be distinguished from each other, under the DDH assumption. By the
triangle inequality for statistical distance, it follows that
2. Solve instance I ′ .
It is reassuring that the standard discrete log and Diffie–Hellman problems are all random
self-reducible, where these problems are formulated as follows, for any group ⟨g⟩ of order n:
Note that for n prime the DDH problem corresponds to distinguishing the (disjoint) distri-
butions X⟨g⟩ = {(g x , g y , g xy ) : x, y ∈R Zn } and Y⟨g⟩ = {(g x , g y , g z ) : x, y, z ∈R Zn , z ̸= xy}, as
explained in Section 1.3.2.
The above problem formulations allow for arbitrary—potentially, worst-case—problem
instances. In cryptography, however, we generally need to allow for random problem instances,
cf. the hardness assumptions in Definitions 1.9–1.11. The following proposition implies that
these assumptions are not stronger than their worst-case cousins.
PROPOSITION 1.16 The DL, DH, and DDH problems are random self-reducible.
PROOF For the DL problem, any given instance h = g x with x ∈ Zn is solved as follows:
Many protocols make use of cryptographic hash functions, commonly defined as hash functions
with some specific security requirements.
DEFINITION 1.18 A function H : {0, 1}∗ → {0, 1}k , mapping bit strings of arbitrary length
to bit strings of a fixed length k, k ≥ 0, is called a hash function. Function H is called a
cryptographic hash function, if it is easy to compute H(x) given any string x, and one or
more of the following requirements are satisfied:
(i) Let y ∈ {0, 1}k be given. The probability that E finds a preimage x such that H(x) = y
is at most t/2k .
(ii) Let x ∈ {0, 1}∗ be given. The probability that E finds a 2nd-preimage x′ , x′ ̸= x, such
that H(x′ ) = H(x) is at most t/2k .
(iii) The probability that E finds a collision (x, x′ ), x ̸= x′ , such that H(x) = H(x′ ) is at
most t2 /2k .
PROOF Without loss of generality, assume all hash queries are distinct.
(i) For each hash query, the probability of an output equal to y is exactly 2−k .
(ii) Let y = H(x). For each hash query on inputs different from x, the probability of an
output equal to y is again exactly 2−k .
√ √
(iii) Write m = 2k . If t ≥ m, then the bound is immediate. So assume t < m. For hash
queries on inputs x1 , . . . , xt , the probability of at least one collision is equal to
1 − m(m − 1)(m − 2) · · · (m − t + 1)/mt .
This probability is bounded above by
1 − (1 − 1/m)(1 − 2/m) · · · (1 − (t − 1)/m)
≤ 1 − e−2/m e−4/m · · · e−2(t−1)/m
= 1 − e−t(t−1)/m
≤ 1 − (1 − t(t − 1)/m)
= t(t − 1)/m
≤ t2 /m,
EXERCISE 1.3.9 See the proof of Proposition 1.19(iii). Show that the upper bound for the
probability of finding at least one collision is almost tight by showing that this probability is
√
bounded below by 14 t(t − 1)/m, for t < m.
There are numerous further requirements that can be demanded of a cryptographic hash
function beyond what is stated in Definition 1.18. In general, any deviation from what can
be statistically expected of a random function should be absent or unlikely, and in any case it
should be infeasible to exploit such statistical weaknesses. By definition, the random oracle
model is robust w.r.t. such additional requirements. For example, partial preimage resistance
(or, local one-wayness) basically states that given a k-bit string y it is hard to find (partial)
information about any input x satisfying H(x) = y. Many applications of hash functions,
such as the bit commitment scheme of Section 3.2.1, rely on this requirement rather than
the (much weaker) requirement of preimage resistance. Clearly, partial preimage resistance
also holds in the random oracle model, in which each hash value is, by definition, statistically
independent of the input value.
§1.4 Bibliographic Notes 21
EXERCISE 1.3.10 Let H be a preimage resistant hash function. Show that partial preimage
resistance is strictly stronger than preimage resistance, by constructing a preimage resistant
hash function H ′ (from H) which is not partial preimage resistant.
EXERCISE 1.3.11 Suppose one demands of a hash function H that it is hard to find a pair
of bit strings (x, x′ ) satisfying H(x) = H(x′ ), where s denotes the bitwise complement of bit
string s. Analyze the probability that an adversary E making at most t hash queries finds
such a pair, where H is viewed as a random oracle.
EXERCISE 1.3.12 Let y = H 2 (x), where x ∈ {0, 1}∗ . Let E be an adversary that, given y
only, makes t hash queries on distinct inputs x1 , . . . , xt ∈ {0, 1}k . View H : {0, 1}∗ → {0, 1}k
as a random oracle to show that E finds a preimage of y with probability exactly equal to
ϵ(2 − ϵ), with ϵ = t/2k . Also, argue why there is no contradiction with Proposition 1.19(i)
even though ϵ(2 − ϵ) ≥ ϵ.
Most of the notions covered in this chapter have become standard, and are widely used
in cryptography. The particular variants of the discrete log and Diffie–Hellman problems
introduced in Section 1.3.3 are among the exceptions, as these are usually studied for the case
that n is prime only. Our study of the (perfect) random self-reducibility of these problems
was motivated by the need for some additional exercises, but is believed to be of independent
interest as well. The Schemmel totient function [Sch69], presented in Section 1.2.1, turns
out to play a role in the analysis of the random self-reducibility of our DDH∗∗ problem, cf.
Exercise 1.3.5(b).
Below, we highlight a few of the more recent developments.
The DL assumption has been known for a long time, and nowadays many groups have
been identified for which the DL problem is assumed to be hard. As for the examples given
in the text, we note that Z∗p and F∗q (Example 1.3) are classical instances. The particular
advantages of using a (prime) order p′ subgroup of Z∗p (Example 1.4) were identified by
Schnorr [Sch91], noting that p′ can be much smaller than p (e.g., p should be of length at
least 2048 bits to counter index-calculus methods, whereas for p′ a length of 256 bits suffices
to counter Pollard’s rho method). The use of elliptic curves for cryptography (Example 1.5)
was proposed independently by Koblitz [Kob87] and Miller [Mil86].
The DH assumption was part of the seminal paper by Diffie and Hellman [DH76] in-
troducing the basic ideas of asymmetric cryptography. The explicit statement of the DDH
assumption was only identified years later (first in [Bra93]), and is now known to be equivalent
to the semantic security of the ElGamal cryptosystem (see Section 2.1.4). The fact that the
DDH problem is random self-reducible was found independently by [Sta96] and [NR97]. See
also [Bon98] for an overview of the DDH assumption.
The notions of indistinguishability and their use in cryptography date back to the early
1980s, with the papers by Yao [Yao82b] and Goldwasser and Micali [GM84] playing a major
role in this respect.
The notion of random self-reducibility was introduced in the context of various crypto-
graphic primitives [AL83, TW87]; it also plays a role in complexity theory. We have used a
limited form of random self-reducibility, which suffices for our purposes (see Definition 1.14).
More generally, random self-reducibility may comprise solving multiple (polynomially many)
22 CHAPTER 1 Introduction
random instances I1′ , I2′ , . . . in order to solve a given instance I, where these instances may
even be determined adaptively (e.g., when I2′ is computed as a function of I and the answer
for I1′ ); see, e.g., [FF93].
The idea and use of the random oracle model was first elaborated in [BR93], thereby for-
malizing the use of hash functions in common constructions such as the Fiat–Shamir heuristic
(see Section 5.4). Many papers have employed the random oracle model since. Additional
requirements for hash functions such as partial preimage resistance are considered throughout
the literature; e.g., see [MOV97, p. 331], which also mentions noncorrelation (of input bits
and output bits) and near-collision resistance as specific requirements. The hash collisions
mentioned in footnote 10 are published in [WY05, BCJ+ 05, SBK+ 17], respectively.
CHAPTER 2
EXERCISE 2.1.1 Explain what happens if the secret exponents xA and xB are chosen from
Zn instead of Z∗n . Confirm your findings by computing the statistical distance ∆(K; K ′ ),
′ ′
where K = g xA xB with xA , xB ∈R Z∗n and K ′ = g xA xB with x′A , x′B ∈R Zn .
easily computed. We have the following table, where each case occurs approximately with
23
24 CHAPTER 2 Key Exchange Protocols
probability 1/4:
ord(hA ) ord(hB ) ord(K)
p′ p′ p′
p ′ 2p ′ p′
2p ′ p ′ p′
2p′ 2p′ 2p′
Hence, the order of the key K is biased, as Pr[ord(K) = p′ ] ≈ 3/4 and Pr[ord(K) = 2p′ ] ≈ 1/4.
If K would be generated uniformly at random in ⟨g⟩, then we would have Pr[ord(K) = p′ ] ≈
Pr[ord(K) = 2p′ ] ≈ 1/2.
Such a slight deviation in the distribution of K seems innocent. However, suppose key
K is used to encrypt a 1-bit plaintext, say M ∈R {0, 1}, using C = g M K as ciphertext
(similar to one-time pad encryption). In that case, an eavesdropper would compute ord(C).
If ord(C) = p′ then M = 0 is most likely, and if ord(C) = 2p′ then M = 1 is most likely.
EXAMPLE 2.1 Take ⟨g⟩ = Z∗p as in Example 1.3, and suppose p − 1 = 2p′ , where p′ is prime.
Recall that the even powers of g are quadratic residues modulo p and that the odd powers of
g are quadratic nonresidues modulo p. Hence, Z∗p = QR p ∪ QR p , where
′ ′
QR p = (Z∗p )2 = {1, g 2 , . . . , g 2p −2 }, QR p = {g, g 3 , . . . , g 2p −1 }.
′
Note that 1 ∈ QR p and −1 = g p ∈ QR p . Furthermore, all elements of QR p \ {1} are of order
p′ and all elements of QR p \ {−1} are of order 2p′ .
We then have the following table:
hA hB K
QR p QR p QR p
QR p QR p QR p
QR p QR p QR p
QR p QR p QR p
By actually computing ord(K) from ord(hA ) and ord(hB ), one can see that ord(g M ) hence
M itself can be determined from ord(C) in case n = 2p′ . See also Exercise 2.1.5.
EXERCISE 2.1.2 Argue that the DDH assumption is false when n contains a small prime
factor.
The simplest and most efficient way to guarantee that n contains no small prime factors
is to require that n itself is a sufficiently large prime. As an additional benefit, we have that
Zn is a field (rather than a ring)!
We now wish to show that if an eavesdropper would be able to determine any partial
information on key K, then we would get a contradiction with the DDH assumption. For the
scope of these lecture notes, we show this for a limited scenario only.
We consider balanced functions f : ⟨g⟩ → {0, 1}, for which the a priori probabilities
satisfy Pr[f (u) = 0] = Pr[f (u) = 1] = 1/2 for u ∈R ⟨g⟩. Now, suppose there exists an
§2.1 Diffie–Hellman Key Exchange 25
attacker E (which is a p.p.t. algorithm) and a balanced function f for which Pr[E(hA , hB ) =
f (K)] > 1/2 + ϵ, for some nonnegligible value ϵ. Then, the claim is that we have the following
distinguisher D for DDH:
1, if E(g x , g y ) = f (g z ),
x y z
D(g , g , g ) =
0, if E(g x , g y ) ̸= f (g z ).
EXERCISE 2.1.3 Extend the above analysis to the case that the a priori probabilities are
given by Pr[f (u) = 0] = p0 and Pr[f (u) = 1] = p1 = 1 − p0 .
Pr[E(hA , hB ) = f (K)]
= Pr[E(hA , hB ) = f (K) | L] Pr[L] + Pr[E(hA , hB ) = f (K) | ¬L] Pr[¬L]
≤ Pr[L] + Pr[E(hA , hB ) = f (K) | ¬L] Pr[¬L]
= Pr[L] + 21 (1 − Pr[L])
1
= 2 + 12 Pr[L],
26 CHAPTER 2 Key Exchange Protocols
using that Pr[E(hA , hB ) = f (K) | ¬L] = 1/2, since E has no information on K = H(g xA xB )
if it does not query H on g xA xB .
It remains to bound Pr[L]. We show that Pr[L] is negligible under the DH assumption.
Let E ′ be an algorithm that takes hA and hB as input and runs E as a subroutine on these
inputs, while recording all H queries made by E. When E halts, E ′ picks one of the inputs used
by E in an H query at random, and returns this value as output. Clearly, E ′ is a probabilistic
polynomial time algorithm. We then have
where t denotes the total number of H queries. Since the running time of E is polynomial, t
is polynomial as well. Then, by the DH assumption, we have that Pr[E ′ (hA , hB ) = g xA xB ] is
negligible, hence that Pr[L] is negligible.
EXERCISE 2.1.4 Extend the above analysis to the case that the a priori probabilities are
given by Pr[f (u) = 0] = p0 and Pr[f (u) = 1] = p1 = 1 − p0 .
Key generation. Pick a group ⟨g⟩ at random among all groups of “size” k. Let n denote
the order of g. Next, pick x ∈R Z∗n . The private key is x, the public key is h = g x .
Encryption. Given a plaintext M ∈ ⟨g⟩, pick u ∈R Zn . The ciphertext for a public key h is
the pair (g u , hu M ).
Decryption. Given a ciphertext (A, B), the plaintext is recovered as M = B/Ax , using
private key x.
Note that key generation and encryption are randomized, while decryption is deterministic.
In practice, the group ⟨g⟩ may be shared between many users.
The ElGamal cryptosystem is semantically secure under the DDH assumption. That is,
the ciphertext does not leak any (partial) information on the plaintext.
EXERCISE 2.1.5 Show how to break the ElGamal cryptosystem for ⟨g⟩ = Z∗p , with p =
2p′ + 1, p, p′ both prime. Focus on the case that M ∈ {1, g}, and show how to recover M .
Encryption. Given a plaintext M ∈ {0, 1}k , pick u ∈R Zn . The ciphertext for a public key
h is the pair (g u , H(hu ) ⊕ M ).
Decryption. Given a ciphertext (A, B), the plaintext is recovered as M = H(Ax ) ⊕ B, using
private key x.
This variant is secure under the DH assumption, in the random oracle model. One may think
of H(Ax ) as a one-time pad.
§2.2 Authenticated Key Exchange 27
Attack 1. The attacker uses h′A = g and h′B = g, which results in K = hA as the “common”
key for A and K = hB as the “common” key for B. These keys will be known to any passive
eavesdropper as well. Note that an event such as hA = g does not happen in practice, as such
a particular event occurs with a negligible probability of 1/n only.
′ ′
Attack 2. The attacker uses h′A = g xA and h′B = g xB , with x′A , x′B ∈R Z∗n . This will go
completely unnoticed to A and B as h′A and h′B follow exactly the same distribution as hA
′
and hB . At the end of the protocol, A will compute g xA xB as its “common” key while B will
′
compute g xA xB as its “common” key.
This is the standard man-in-the-middle attack, and it constitutes a complete break of the
protocol. The keys used by A and B are not even equal to each other, and both are fully
known to the attacker.
Attack 3. The attacker uses h′A = hA g u and h′B = hB , with u ∈R Zn . Then A will compute
KAB = g xA xB , while B computes KAB ′ = g (xA +u)xB . Clearly, these keys are uncorrelated
(hence different from each other, except with negligible probability). However, the attacker
does not know anything about the keys KAB and KAB ′ , except that K ′ u
AB = KAB hB .
Attack 4. The attacker uses h′A = 1/hA and h′B = 1/hB . Then A and B compute as
common key g −xA xB . Then A and B agree on the common key and the attacker does not
know any information on the shared key. However, the key is different than intended or
expected.
For instance, suppose ⟨g⟩ is a group of points on an elliptic curve (see Example 1.5).
To perform the attack, the attacker only needs to negate the y-coordinate of the points
exchanged by A and B (assuming the curve equation is of the form Y 2 = f (X)). As a result,
the y-coordinate of the resulting common key is negated.
EXERCISE 2.2.1 Consider the two protocols of Figure 2.1 between parties A and B connected
by an insecure communication channel: protocol I for sending a plaintext M ∈ ⟨g⟩∗ securely
from party A to party B, and protocol II for sending a plaintext b ∈ {0, 1} securely from
party A to party B. The object of both protocols is that the plaintext remains completely
hidden from other parties than A and B, and that the plaintext cannot be modified by other
parties than A or B.
28 CHAPTER 2 Key Exchange Protocols
First, verify that M ′ = M and b′ = b if A and B follow protocols I and II, respectively.
Next, determine for protocol I whether it is secure against passive attacks, and whether it is
secure against active attacks. If secure, describe the relevant computational assumption (if
any); if insecure, show an attack. Then, do the same for protocol II.
of hB = Dw (Ew (hB )). Similarly, party B recovers the value of hA , using w. As before, the
agreed upon key is K = g xA xB .
An eavesdropper who wants to guess the password sees Ew (hA ) and Ew (hB ). These values
do not give any information on the password w, since hA and hB are random and unknown
to the eavesdropper.
An active attacker may try a candidate password w′ by sending a value Ew′ (hA ) on behalf
of A. When the attacker succeeds, it guessed the password correctly. However, the best
the attacker can do is trying all passwords one by one. The attacker cannot do an off-line
dictionary attack.
The Diffie–Hellman key exchange protocol is from the seminal paper by Diffie and Hell-
man [DH76], in which the other fundamental notions of public key cryptography, namely
asymmetric cryptosystems and digital signature schemes, were also introduced. The inti-
mately related ElGamal cryptosystem—sometimes called Diffie–Hellman encryption for that
reason—was introduced by ElGamal in [ElG85], together with a secure digital signature
scheme based on a discrete log assumption. Originally, these results were formulated for the
group Z∗p only (cf. Example 1.3), but the generalization to any finite cyclic group is easy.
Many ways have been proposed to extend the basic Diffie–Hellman protocol to an au-
thenticated key exchange protocol. The approach of Section 2.2.2 is rather generic, and
leads to provably secure protocols for various settings (see, e.g., Shoup’s paper [Sho99], which
introduces several models for (authenticated) key exchange protocols and formally analyzes
various instances of such protocols). The approach of Section 2.2.3, which allows for password-
based authentication rather than strong authentication, is known as EKE (Encrypted Key
Exchange) and is due to Bellovin and Merritt [BM92].
Key exchange and similar protocols are probably the most widely studied and applied
type of protocol in cryptography. For instance, the book by Boyd and Mathuria [BM03]
contains over 150 protocols for authentication and key establishment—which is still far from
exhaustive as noted by the authors.
Protocol I in Figure 2.1 is known as Shamir’s no-key protocol and also as Shamir’s three-
pass protocol (cf. [MOV97, Section 12.3]).
CHAPTER 3
Commitment Schemes
3.1 DEFINITIONS
A commitment scheme consists of two protocols, called commit and reveal, between two
parties, usually called the sender and the receiver. In many cases, the protocols commit and
reveal can be defined in terms of a single algorithm, requiring no interaction between the
sender and receiver at all. Such commitment schemes are called noninteractive.
DEFINITION 3.1 Let commit : {0, 1}k × {0, 1}∗ → {0, 1}∗ be a deterministic polynomial
time algorithm, where k is a security parameter. A (noninteractive) commitment scheme
consists of two protocols between a sender and a receiver:
Commit Phase. A protocol in which the sender commits to a value x ∈ {0, 1}∗ by com-
puting C = commit(u, x), where u ∈R {0, 1}k , and sending C to the receiver. The
receiver stores C for later use.
30
§3.2 Examples 31
In the special case that the committed value is a bit, that is, x ∈ {0, 1}, one speaks of a
bit commitment scheme. The security requirements for a bit commitment scheme are the
following.
The commitment must be binding, i.e., for any adversary E, the probability of generating
u, u′ ∈ {0, 1}k satisfying commit(u, 0) = commit(u′ , 1) should be negligible (as a function
of k). Furthermore, the commitment must be hiding, i.e., the distributions induced by
commit(u, 0) and commit(u, 1) (with u ∈R {0, 1}k ) are indistinguishable.
Moreover, one makes the following distinctions. A commitment scheme is called com-
putationally binding if the adversary E is restricted to be a p.p.t. algorithm. If no such
restriction is made (in other words, the adversary may be unlimitedly powerful), the scheme
is called information-theoretically binding. Similarly, if the distributions induced by
commit(u, 0) and commit(u, 1) are computationally indistinguishable the scheme is called
computationally hiding and the scheme is called information-theoretically hiding if
these distributions are statistically (or even perfectly) indistinguishable.
The security properties are easily extended to the case that x is an arbitrary bit string.
Note that the above security requirements only cover attacks by either the sender or the
receiver. For example, suppose party A acts as the sender and party B acts as the receiver,
and A sends a commitment C to B. Then there is no guarantee that B will notice if an
attacker replaces C by a commitment C ′ = commit(u′ , x′ ) during the commit protocol, and
replaces u, x by u′ , x′ during the reveal protocol. Such attacks may be stopped by using an
authenticated channel between A and B.
3.2 EXAMPLES
The basic security requirements for a commitment scheme are that it must be binding and
hiding. Another relevant property of a commitment scheme is that it may be homomorphic.
For the moment we will introduce the homomorphic property by means of an example. Con-
sider Pedersen’s commitment scheme, given by commit1 (u, x) = g u hx , where u ∈R Zn and
x ∈ Zn . This scheme is additively homomorphic in the sense that:
where the multiplication on the left-hand side is in the group ⟨g⟩ and the additions on the
right-hand side are in Zn . So, the product of two commitments is a commitment to the sum
of the committed values.
Homomorphic properties turn out to be very useful, e.g., for achieving secure multiparty
computation, as we will see later on. As a concrete example, homomorphic commitments
can be used as a building block for secure election schemes: very roughly, during the voting
stage, voters put their votes into homomorphic commitments, and during the tallying stage,
the votes are counted in a verifiable manner by taking the product of all commitments.
EXERCISE 3.3.1 Assume the setting of Exercise 1.3.8. The Quadratic Residuosity (QR)
assumption states that the QR problem is hard.
Let y ∈ JN denote a quadratic nonresidue modulo N (e.g., y = −1 is a quadratic non-
residue modulo N when N is a Blum integer, that is, N = pq with p ≡ q ≡ 3 (mod 4)).
Consider the following bit commitment scheme:
commit(u, x) = u2 y x mod N,
where u ∈R Z∗N and x ∈ {0, 1}. In what sense is the scheme binding? In what sense is the
scheme hiding? In what sense is the scheme homomorphic?
The concept of a commitment scheme emerged in the early 1980s, most notably in the paper
by Blum [Blu82] on “coin flipping by telephone,” which was also used as a motivating example
in the beginning of this chapter. Commitment schemes have been an important cryptographic
primitive ever since.
Pedersen’s commitment scheme first appeared in [Ped92], where it is presented as part of
a noninteractive verifiable secret sharing scheme (see Section 6.2.2).
The impossibility of a commitment scheme which is both binding and hiding in an
information-theoretic sense is folklore.
The commitments of Exercise 3.3.1 correspond to ciphertexts in the Goldwasser–Micali
public key cryptosystem, which was actually the first probabilistic cryptosystem (see [GM84],
where also the notion of semantic security is introduced and proved to hold for this cryp-
tosystem under the QR assumption).
CHAPTER 4
Identification Protocols
We consider identification protocols between two parties, where one party, called the verifier,
needs to get convinced that the other party, called the prover, is as claimed. A typical
example is when a user wants to gain access to a computer account (secure login), or when
someone needs to enter a secured room.
In general, identification protocols may be based on one or more of the following factors.
• What you have. Smart cards, SIM cards, or similar hardware tokens.
4.1 DEFINITIONS
34
§4.2 Password-Based Schemes 35
scheme, registration will end with both parties sharing a public key, for which only the prover
knows the private key. (In more advanced schemes, also the verifier may have a private key.)
A major advantage of asymmetric schemes is that the prover may use its public key with
several, possibly many, verifiers.
We consider attacks on the identification protocol only. Hence, we assume that the regis-
tration protocol is performed in a secure environment. Furthermore, we consider only cryp-
tographic attacks.1
The basic security requirement for an identification protocol is that it stops imperson-
ation attacks, that is, it should be impossible for an attacker to successfully identify itself
as another party. We distinguish several passive and active impersonation attacks.
The main type of passive impersonation attack is eavesdropping on communication be-
tween a prover and a verifier in legal executions of the identification protocol. Another type
of passive attack is a key-only attack for asymmetric schemes, in which the attacker tries to
find the private key from the public key. However, we will not be concerned with key-only
attacks.
A simple form of active impersonation attack is a guessing attack, in which the attacker
poses as the prover and hopes to make the right guesses, without knowing the prover’s secret
key or private key. The success rate of a guessing attack may be increased considerably by
combining it with a cheating verifier attack, in which the attacker poses as a verifier and
hopes to extract some useful information from the prover by deviating from the protocol.
Finally, the attacker may apply a man-in-the-middle attack : an honest prover P thinks
it runs the identification protocol with verifier V ∗ but actually V ∗ relays all messages to a
verifier V who thinks it runs the protocol with P. For example, one may identify itself to
open a certain door X but the attacker will have you open another door Y (while you get the
message that there was some malfunctioning at door X).
The man-in-the-middle attack is reminiscent of the so-called grandmaster chess attack, in
which an amateur chess player tries to increase his or her rating by playing correspondence
chess with two grandmasters at the same time. The amateur chess player will engage in a
chess game with both grandmasters, playing white in one game and black in the other one.
Once started, the amateur simply copies all moves from one grandmaster to the other one.
As a result, the amateur will either win one game and lose the other one, or play two draws.
In any event, the amateur’s rating will increase considerably.
We will be concerned mostly with cheating verifier attacks.
The conventional way to login to a computer is to provide a user-id and a password. Upon
registration it is ensured that the prover gets a unique user-id. The prover is also allowed
to pick a password. During identification, the prover sends the user-id and password to the
verifier.
A password scheme is a symmetric identification scheme, supposed to withstand guessing
attacks. One may think of the password as a random bit string in {0, 1}k . If the password is
human-memorizable, the security parameter k is usually rather small, say k ≤ 20. (We will
1
Noncryptographic attacks in which one breaks into the prover’s or verifier’s computer to steal or modify
a key are not considered, as such attacks cannot be stopped by purely cryptographic means. Note that for an
asymmetric scheme it is indeed important that the prover’s public key, as stored by the verifier, is authentic.
36 CHAPTER 4 Identification Protocols
not discuss dictionary attacks and related issues.) Clearly, it is possible to withstand guessing
attacks by taking k = 80, but then the password will be harder to memorize.
A password scheme does not withstand eavesdropping attacks at all. Once the password
is intercepted, the scheme is broken.
Lamport’s identification scheme provides a relatively easy way to stop eavesdropping attacks
by using so-called (one-way) hash chains. A hash chain of length ℓ is a sequence of values
xi , 0 ≤ i ≤ ℓ, satisfying xi+1 = H(xi ), for 0 ≤ i < ℓ, where H : {0, 1}∗ → {0, 1}k is a
cryptographic hash function.
For registration, the prover picks x0 ∈R {0, 1}k , computes xℓ = H ℓ (x0 ), and sends xℓ to
the verifier. Both the prover and the verifier keep a counter i, initially i = 0. The prover
stores x0 for later use. The verifier keeps a variable v, which is initially set to xℓ .
For identification, the prover increments counter i, computes xℓ−i = H ℓ−i (x0 ) and sends
this value to the verifier. The verifier tests whether H(xℓ−i ) = v. If so, identification is
successful and the verifier increments i and sets v = xℓ−i ; otherwise, the verifier discards the
identification attempt.
Lamport’s identification scheme thus requires the prover and the verifier to remain “in
sync” (cf. counter i), but unlike a completely symmetric scheme, the verifier does not need
to store a secret key.
A key-only attack is infeasible (cf. the random oracle model, Section 1.3.4). The scheme
withstands eavesdropping attacks as interception of a value xℓ−i does not help the attacker
in succeeding in any of the subsequent runs of the identification protocol.
We do not consider active attacks for this scheme.
REMARK 4.1 Hash chains have been considered for applications in which the length of the
hash chain is very large. For such “ultra long” hash chains one takes, for instance, ℓ = 232 .
For ultra-long hash chains, the naive implementation in which xℓ−i is computed from x0
in each run of the identification protocol is not acceptable. Similarly, it is not feasible to store
the entire sequence xi , for i = 0, . . . , ℓ − 1.
However, using so-called pebbling algorithms it is possible to achieve the following per-
formance. The space complexity is measured as the number of k-bit strings stored, whereas
the time complexity is measured as the number of applications of the hash function H. The
prover uses O(log ℓ) storage, and the verifier uses O(1) storage. For registration the prover
spends O(ℓ) time, and the verifier needs O(1) time. For each run of the identification protocol,
the prover needs O(log ℓ) time, whereas the verifier needs O(1) time.
(a) (b)
(c) (d)
Assume that prover and verifier share a symmetric key K ∈R {0, 1}k . Let EK denote an
encryption algorithm using key K, and let DK denote the corresponding decryption algorithm.
Assume for simplicity that EK , DK : {0, 1}k → {0, 1}k .
See Figure 4.1(a). The identification protocol starts with the verifier sending a challenge
c ∈R {0, 1}k , for which the prover is supposed to return the response r = EK (c). The verifier
checks that indeed DK (r) = c.
To withstand eavesdropping attacks an encryption scheme withstanding known-plaintext
attacks must be used. To withstand cheating verifier attacks, the encryption scheme must
withstand adaptive chosen-plaintext attacks.
EXERCISE 4.4.1 Consider the alternative protocol in which the verifier challenges the prover
with c = EK (M ), where M ∈R {0, 1}k , and for which the prover is supposed to produce
response r = M . Discuss eavesdropping attacks and cheating verifier attacks for this protocol.
Assume that prover and verifier share a symmetric key K ∈R {0, 1}k . Let H : {0, 1}∗ →
{0, 1}k denote a cryptographic hash function.
See Figure 4.1(b). The identification protocol starts with the verifier sending a challenge
c ∈R {0, 1}k , for which the prover is supposed to return the response r = H(K ∥ c). The
verifier checks that indeed r = H(K ∥ c).
38 CHAPTER 4 Identification Protocols
In the random oracle model, the scheme withstands both eavesdropping and cheating
verifier attacks.
Assume that prover and verifier share a public key pk for which the prover knows the pri-
vate key sk. Let Epk denote an encryption algorithm using key pk, and let Dsk denote the
corresponding decryption algorithm using key sk.
See Figure 4.1(c). The verifier challenges the prover with c = Epk (M ) with M ∈R {0, 1}k ,
for which the prover is supposed to produce response r = Dsk (c). The verifier checks that
indeed r = M holds.
To withstand eavesdropping attacks the encryption scheme must be semantically se-
cure. To withstand cheating verifier attacks, the encryption scheme must withstand adaptive
chosen-ciphertext attacks.
Assume that prover and verifier share a public key pk for which the prover knows the private
key sk. Let Ssk denote a signing algorithm using key sk, and let Vpk denote the corresponding
verification algorithm using key pk.
See Figure 4.1(d). The identification protocol starts with the verifier sending a challenge
c ∈R {0, 1}k , for which the prover is supposed to return the response r = Ssk (c). The verifier
checks that indeed Vpk (c, r) holds, that is, whether r is indeed a signature on message c under
public key pk.
To withstand eavesdropping attacks the digital signature scheme must withstand known-
message attacks. To withstand cheating verifier attacks, the digital signature scheme must
withstand adaptive chosen-message attacks.
The schemes of the previous section are secure when used with sufficiently strong encryption or
authentication schemes. The cost of a digital signature scheme withstanding adaptive chosen-
message attack is quite high, though. In addition, the work for the prover for computing the
response may be costly, in particular considering the work the prover needs to do strictly
after receiving the challenge.
In this section we will consider zero-knowledge identification protocols, which will have
the property that no matter what a cheating verifier does, it will not extract any useful
information from the (honest) prover. More precisely, the term “zero-knowledge” refers to
the fact that whatever information the cheating verifier learns from (interacting with) the
prover, that information could have been generated by the cheating verifier on its own—
without interacting with the prover at all. In other words, it is possible to show that the
messages sent by the prover can be (efficiently) simulated without actually involving the
prover. An honest verifier, however, will be convinced that the prover knows the private key,
as required.
§4.5 Zero-Knowledge Identification Protocols 39
Prover Verifier
(x = logg h)
u ∈R Zn
a ← gu a
−−−−−−−−−→
−
c ∈R {0, 1}
c
−−−−−−−−−−
←
u, if c = 0 r r ? a, if c = 0
r ←n − g =
−−−−−−−−−→
u + x, if c = 1 ah, if c = 1
g r0 = a, g r1 = ah,
But this means that the prover actually knows x, since x = r1 − r0 mod n holds!
Consequently, at each iteration of Schnorr’s protocol a cheating prover “survives” with
probability at most 50% essentially. Thus after k iterations, a cheating prover succeeds with
probability at most 2−k essentially.4
Now, we discuss why Schnorr’s protocol is zero-knowledge. A cheating verifier may
engage many times in the identification protocol, obtaining a conversation (a; c; r) for each
run of the protocol. Here, “many times” means at most O(k γ ) times for some constant γ ∈ N
(polynomially bounded in the security parameter k). The cheating verifier thus obtains many
conversations (a; c; r). However, it turns out that the verifier may generate these conversations
completely on its own, without interacting with the prover at all: the verifier may generate
simulated conversations (a; c; r) that follow exactly the same distribution as the conversations
(a; c; r) that occur in executions of the identification protocol with a real prover.
We first consider the zero-knowledge property for the case of an honest verifier V, that is,
the verifier picks c uniformly at random in {0, 1} as prescribed by the protocol. Below, we
present two p.p.t. algorithms, one for generating real conversations (following the protocol),
and one for generating simulated conversations (deviating from the protocol).
Real conversations Simulated conversations
Input: private key x Input: public key h
Output: conversation (a; c; r) Output: conversation (a; c; r)
1. u ∈R Zn 1. c ∈R {0, 1}
2. a ← gu 2. r ∈R Zn
3. c ∈R {0, 1} 3. a ← g r h−c
4. r ←n u + cx 4. output (a; c; r)
5. output (a; c; r)
Both algorithms generate accepting conversations (a; c; r) uniformly at random, that is,
1
Pr[(a; c; r) = (A; C; R)] = 2n for any triple (A; C; R) ∈ ⟨g⟩ × {0, 1} × Zn satisfying g R = AhC .
The crux is that the real conversations are generated given access to the private key x, whereas
the simulated conversations are generated given access to the public key h only.
REMARK 4.2 The fact that an identification protocol is zero-knowledge against an honest
verifier essentially reduces any passive impersonation attack to a key-only attack (see Sec-
tion 4.1). In particular, eavesdropping conversations between honest provers and verifiers
does not yield anything about a prover’s private key beyond what can be deduced from the
corresponding public key already.
Next, we consider the zero-knowledge property for the general case of any p.p.t. cheating
verifier V ∗ . We will use probabilistic Turing machine V ∗ as a rewindable black-box, which
means (i) that we access V ∗ in a black-box manner only, restricted to exchanging messages
with V ∗ through its input and output tapes, and (ii) that we can rewind V ∗ to any prior
configuration. Recall from Section 1.2.4 that the configuration of a probabilistic Turing
machine is determined by the state of its finite control part, the contents of its tapes (incl.
the random tape) as well as the positions of its tape heads. By rewinding V ∗ we can test it
on several input values until a desired output value is obtained.
It is possible to show in a rigorous way that any p.p.t. cheating prover only succeeds with probability 2−k
4
plus a further negligible term representing the success probability of finding x = logg h directly.
§4.5 Zero-Knowledge Identification Protocols 41
1. u ∈R Zn 1. c ∈R {0, 1}
2. a ← gu 2. r ∈R Zn
3. send a to V ∗ 3. a ← g r h−c
4. receive c ∈ {0, 1} from V ∗ 4. send a to V ∗
5. r ←n u + cx 5. receive c′ ∈ {0, 1} from V ∗
6. send r to V ∗ 6. if c ̸= c′ rewind V ∗ to point prior to
7. output (a; c; r) receiving a and go to step 1
7. send r to V ∗
8. output (a; c; r)
At step 6 of the simulation, the probability that c = c′ is exactly 1/2, since c ∈R {0, 1}.
Hence, on average two iterations are required to generate a simulated conversation (a; c; r).
The conclusion is that no matter what algorithm (or “strategy”) a cheating verifier V ∗
follows in trying to extract useful information from the prover, the same algorithm can be
used to generate identically distributed conversations without needing the cooperation of the
prover. Whereas the real conversations are generated using the private key x as input, the
simulated conversations are generated using only the public key h as input.
Prover Verifier
(x = logg h)
u ∈R Zn
a ← gu
a
−−−−−−−−−→
−
c ∈R Zn
c
−−−−−−−−−−
←
r ←n u + cx
r
−−−−−−−−−→
−
?
g r = ahc
The zero-knowledge property can also be proved for Schnorr’s protocol similarly as above
for the case of an honest verifier V. The distributions of the real conversations (generated
using private key x ∈ Zn ) and of the simulated conversations (generated using public key
h ∈ ⟨g⟩ only) are, respectively:
{(a; c; r) : u, c ∈R Zn ; a ← g u ; r ←n u + cx},
{(a; c; r) : c, r ∈R Zn ; a ← g r h−c }.
These distributions are identical, as each valid conversation (a; c; r) (satisfying c, r ∈ Zn and
g r = ahc ) occurs with probability 1/n2 in both distributions.
In trying to simulate conversations for an arbitrary verifier V ∗ , we run into a problem.
We may use the same algorithm as before, first picking c, r ∈R Zn , setting a = g r h−c , feeding
a to V ∗ and then hoping that the c′ returned by V ∗ matches c. However, Pr[c = c′ ] = 1/n
which is negligibly small, and it will take n tries on average to find a valid conversation this
way. In other words, the running time of the simulator is O(n), which is exponentially large.
In conclusion, Schnorr’s protocol is sound and honest-verifier zero-knowledge. Although
it cannot be proved zero-knowledge in general, no attacks are known for this protocol, hence
it can be used as an identification protocol, if so desired.
Later, we will see how to obtain so-called Schnorr signatures from Schnorr’s identification
protocol. At this point, we remark that if one could prove that Schnorr’s protocol is zero-
knowledge then it would follow that Schnorr signatures can be forged. In a way it is therefore
good that Schnorr’s protocol is not zero-knowledge.
The identification protocol by Guillou and Quisquater is similar to Schnorr’s protocol, except
that it is defined in an RSA setting instead of a DL setting.
Let N = pq be an RSA modulus, that is, p and q are large, distinct primes of bit length
k, for security parameter k. Let e be a positive integer satisfying gcd(e, ϕ(N )) = 1, where
ϕ(N ) = (p − 1)(q − 1). (See Exercise 1.3.7.) As an additional requirement for e we have that
e is a large prime such that 1/e is negligible in security parameter k. For example, e may be
a 128-bit prime.
§4.5 Zero-Knowledge Identification Protocols 43
Prover Verifier
(x = y 1/e mod N )
u ∈R Z∗N
a ←N ue
a
−−−−−−−−−→
−
c ∈R Ze
c
−−−−−−−−−−
←
r ←N uxc
r
−−−−−−−−−→
−
?
re =N ay c
Recall that the RSA problem is to compute x = y 1/e mod N given y ∈ Z∗N , which is
assumed to be hard for sufficiently large values of k. For Guillou–Quisquater’s protocol
(Figure 4.4), the private key of the prover is therefore a number x ∈ Z∗N , and the corresponding
public key is y = xe mod N . One can easily verify that the verifier indeed accepts if the prover
follows the protocol, as we have (modulo N ):
re = (uxc )e = ue (xe )c = ay c .
The security properties of Guillou–Quisquater’s protocol are as follows. The soundness
property holds as the success probability of a cheating prover is basically bounded by 1/e for
the following reason. Suppose that a prover is able to answer two distinct challenges c, c′ ∈ Ze
correctly, after sending announcement a to the verifier. In other words, suppose a prover is
able to produce two accepting conversations (a; c; r) and (a; c′ ; r′ ), with c ̸= c′ . Then we have
(modulo N ):
′
re = ay c , r′e = ay c ,
which implies
′
(r/r′ )e = y c−c .
To isolate y in this equation, we note that gcd(e, c − c′ ) = 1, since e is prime and c, c′ ∈
Ze , c ̸= c′ . By the extended Euclidean algorithm integers s, t can thus be computed efficiently
satisfying se + t(c − c′ ) = 1. Raising both sides of the equation to the power t we get:
′
(r/r′ )te = y t(c−c ) = y 1−se ,
hence
y = (y s (r/r′ )t )e .
Summarizing, given accepting conversations (a; c; r), (a; c′ ; r′ ), where c ̸= c′ , the private key
x can be computed as x = y s (r/r′ )t mod N , where s, t satisfy se + t(c − c′ ) = 1 (as obtained
by the extended Euclidean algorithm).
The protocol is honest-verifier zero-knowledge, since the distributions of the real conver-
sations (generated using private key x ∈ Z∗N ) and of the simulated conversations (generated
using public key y ∈ Z∗N only) are identical:
{(a; c; r) : u ∈R Z∗N ; c ∈R Ze ; a ←N ue ; r ←N uxc },
{(a; c; r) : c ∈R Ze ; r ∈R Z∗N ; a ←N re y −c }.
44 CHAPTER 4 Identification Protocols
Schnorr’s identification protocol is quite efficient, but it can be proved zero-knowledge only
for an honest verifier. By using k iterations of Schnorr’s protocol (with binary challenges),
the resulting protocol is zero-knowledge for arbitrary verifiers, but, clearly, the computational
complexity of the protocol also increases by a factor of k.
Witness hiding identification protocols strike a nice balance between security and effi-
ciency. Consider a protocol that satisfies the soundness property as described above. It
follows that a prover can only be successful if it actually knows the complete private key.
So, the only problem we need to care about is that a cheating verifier is not able to learn
the complete private key. Therefore, an identification protocol is called witness hiding if a
cheating verifier is not able to obtain the prover’s private key by interacting with the prover.
If a protocol is witness hiding, it is not necessarily zero-knowledge (but the converse is
always true). A cheating verifier may be able to extract some partial information on the
private key, but the amount of information it is able to get is not sufficient for successful
impersonation of the prover.
Prover Verifier
(h = g1x1 g2x2 )
u1 , u2 ∈R Zn
a ← g1u1 g2u2
a
−−−−−−−−−→
−
c ∈R Zn
c
−−−−−−−−−−
←
r1 ←n u1 + cx1
r , r2
r2 ←n u2 + cx2 −−−−1−−− −−
→
?
g1r1 g2r2 = ahc
Indeed,
u′ u′ x′ x′
a′ = g1 1 g2 2 = g1u1 g2u2 (g1x1 g2x2 )c /(g1 1 g2 2 )c = a,
and (modulo n)
However, now viewing the prover P(x1 ,x2 ) and the verifier V ∗ as one “big” p.p.t. algorithm
E, it follows that E is able to compute two pairs (x1 , x2 ) ̸= (x′1 , x′2 ) satisfying
x′ x′
h = g1x1 g2x2 , h = g1 1 g2 2 .
REMARK 4.4 As mentioned above, there are n possible witnesses (x1 , x2 ) for a given public
key h = g1x1 g2x2 in Okamoto’s protocol. Interestingly, the protocol remains witness hiding even
if the number of possible witnesses used by the prover is limited to just two. For instance, if
either x1 = 0 or x2 = 0 (hence either h = g1x1 or h = g2x2 ), the same analysis applies, except
that the probability for two different witnesses is now bounded below by 1/2.
Many identification schemes have been proposed throughout the cryptographic literature.
Lamport’s identification scheme using hash chains is from [Lam81], building on the idea of
iterated hash functions which is attributed to Winternitz (see [Mer87, Mer89], where Merkle
refers to a personal communication with Winternitz). The use of ultra long hash chains (see
Remark 4.1) is from Jakobsson [Jak02] (see also [CJ02]), building on the pebbling algorithm
of [IR01] for efficient key updates in a forward-secure digital signature scheme. See [Sch16,
Sch17] for optimal binary pebbling algorithms, for which the prover stores at most log2 ℓ hash
values and uses at most 21 log2 ℓ hashes in each run of Lamport’s identification protocol. Also,
see [Szy04] for extended techniques to generate the successive authentication paths when
traversing Merkle trees (“hash trees”).
The notion of zero-knowledge was formally introduced by Goldwasser, Micali, and Rack-
off in [GMR89], soon after the first such protocol was presented at Eurocrypt 1984 by Fis-
cher, Micali, and Rackoff [FMR96], and is now more broadly referred to as the simulation
paradigm. A practical scheme for zero-knowledge identification was first presented by Fiat and
Shamir [FS87], followed by the slightly improved scheme of Feige, Fiat, and Shamir [FFS88].
Guillou–Quisquater’s protocol is from [GQ88], and Schnorr’s protocol is from [Sch91]. For
more on zero-knowledge proofs, see the next chapter.
The notions of witness indistinguishable and witness hiding protocols are due to Feige
and Shamir [FS90], who also gave applications to identification. The elegant and efficient
variation of Schnorr’s identification protocol is due to Okamoto [Oka93].
CHAPTER 5
Zero-Knowledge Proofs
Zero-knowledge proofs are a general class of protocols between two parties, called the prover
and the verifier. By means of a zero-knowledge proof, the prover convinces the verifier of
the validity of a given statement without revealing any information beyond the truth of the
statement.
In zero-knowledge identification protocols, the statement proved is something like “I know
the private key for this public key.” But much more involved statements are possible, such
as “I know the private key for this public key or for that public key, and that in any case
the private keys are different.” In fact, the theory of zero-knowledge proofs tells us that
any NP-statement can be proved efficiently in zero-knowledge (see also Exercise 5.3.5 and
Exercise 5.3.6).
5.1 Σ-PROTOCOLS
47
48 CHAPTER 5 Zero-Knowledge Proofs
Prover P Verifier V
((v; w) ∈ R) (v ∈ V )
a ← α(v; w; uP )
announcement a
−
−−−−−−−−−−−−→−
−
c ∈R C
challenge c
−−−−−−−−−−−−−−
←
r ← ρ(v; w; c; uP )
response r
−−−−−−−−−−−−−−→
φ(v; a; c; r)?
Conversation (a; c; r) accepting if φ(v; a; c; r) holds.
Polynomial time predicate φ, finite set C ̸= ∅,
random tape uP , p.p.t. algorithms α and ρ.
Special soundness. There exists a p.p.t. algorithm E (extractor) which given any v ∈
V and any pair of accepting conversations (a; c; r) and (a; c′ ; r′ ) with c ̸= c′ always
computes a witness w satisfying (v; w) ∈ R.
It can be proved rigorously that special soundness implies that a cheating prover succeeds
with probability at most 1/n essentially, where n denotes the cardinality of the challenge
space C. Hence, assuming that n is sufficiently large, a Σ-protocol proves knowledge of a
witness w for a public input v.2
As can be seen from the following proposition, the special honest-verifier zero-knowledge
property is not much stronger than (plain) honest-verifier zero-knowledgeness. For conve-
nience, we let (C, +) be an additive finite group.
2
Because of the (special) soundness property, Σ-protocols are actually proofs of knowledge rather than
just proofs of language membership. For v ∈ V , it is not only proved that v ∈ LR but also that the prover
knows a witness w satisfying (v; w) ∈ R, which is formalized in terms of the existence of an extractor. For some
Σ-protocols language membership is trivial, e.g., for Schnorr’s identification protocol LR = ⟨g⟩ = V . But for
EQ-composition of Schnorr’s protocol (see Fig. 5.8), for instance, we have LR = {(g1 , h1 , g2 , h2 ) : logg1 h1 =
logg2 h2 } for which deciding language membership is as hard as breaking the DDH assumption.
§5.1 Σ-Protocols 49
Prover Verifier
((v; w) ∈ R) (v ∈ V )
a ← α(v; w; uP )
a, cP
cP ∈R C −−−−−−−−−→
cV ∈R C
cV
−−−−−−−−−
←
r ← ρ(v; w; cP + cV ; uP )
r
−−−−−−−−−→
−
φ(v; a; cP + cV ; r)?
PROPOSITION 5.2 The transformed protocol in Figure 5.2 is a Σ-protocol for relation
R, provided that the original protocol as given in Figure 5.1 satisfies completeness, special
soundness, and plain honest-verifier zero-knowledgeness.
PROOF Completeness holds because α, ρ, and φ are applied in the same way as in the
original protocol with c replaced by cP + cV .
For special soundness, consider two accepting conversations (a, cP ; cV ; r) and (a, cP ; c′V ; r′ )
with cV ̸= c′V . Define c = cP + cV and c′ = cP + c′V . Then (a; c; r) and (a; c′ ; r′ ) are two
accepting conversations for the original protocol with c ̸= c′ , hence special soundness implies
that a witness w can be obtained efficiently.
Finally, for special honest-verifier zero-knowledgeness, let S be a simulator for the original
protocol. The simulator for the transformed protocol proceeds as follows. For any given
challenge cV , generate an accepting conversation (a; c; r) using simulator S on input v, and
put cP = c − cV . The simulated conversation is defined as (a, cP ; cV ; r), which is accepting by
construction. Moreover, if v ∈ LR , honest-verifier zero-knowledgeness of the original protocol
implies that (a; c; r) follows the distribution of conversations of the original protocol. Hence,
in particular, c ∈ C is distributed uniformly at random. Therefore, cP is also uniformly
random, and (a, cP ; cV ; r) exactly follows the distribution of conversations of the transformed
protocol. □
The particular way in which Definition 5.1 treats the case v ∈ V \LR is chosen in order to
streamline OR-composition covered in the next section. For special soundness, extractor E is
required to output a witness w for any v ∈ V , given any pair of accepting conversations with
identical announcements but different challenges—which implies that such pairs of conversa-
tions cannot exist (or cannot be found efficiently under some computational assumption) if
v ∈ V \LR . Similarly, for special honest-verifier zero-knowledgeness, simulator S is required to
output an accepting conversation for any v ∈ V —without any constraints on the distribution
of these conversations if v ∈ V \LR .
As a simple illustration we show that Schnorr’s protocol (see Figure 4.3) is a Σ-protocol
for proving knowledge of a witness x ∈ Zn satisfying h = g x . Note that from now on we will
not explicitly indicate anymore that all calculations involving elements of the finite field Zn
are actually done modulo n (e.g., “c ̸= c′ ” is short for “c ̸= c′ mod n,” and hence division by
c − c′ is well-defined modulo n).
50 CHAPTER 5 Zero-Knowledge Proofs
Prover Verifier
(x = logg h)
u ∈R Z∗n
a ← gu a
−−−−−−−−−→
−
c ∈R Zn
c
−−−−−−−−−−
←
r ←n cu + x
r
−−−−−−−−−→
−
?
g r = ac h
PROPOSITION 5.3 The protocol in Figure 4.3 is a Σ-protocol for relation {(h; x) : h = g x }.
PROOF Completeness clearly holds, as
g r = g u+cx = g u (g x )c = ahc ,
{(a; c; r) : u ∈R Zn ; a ← g u ; r ←n u + cx},
{(a; c; r) : r ∈R Zn ; a ← g r h−c },
given an arbitrary challenge c. These distributions are identical (each conversation occurs
exactly with probability 1/n). □
EXERCISE 5.1.1 To understand why honest-verifier zero-knowledgeness does not imply zero-
knowledgeness for arbitrarily cheating verifiers, consider the protocol given in Figure 5.3.
Show that the protocol is complete, special sound, and honest-verifier zero-knowledge. Also,
show that the protocol is completely insecure against a cheating verifier.
EXERCISE 5.1.2 The protocol in Figure 5.3 avoids the case u = 0, but this is not essential.
Show that the protocol remains complete, special sound, and honest-verifier zero-knowledge
(and insecure against a cheating verifier) if one uses u ∈R Zn instead of u ∈R Z∗n , by exhibiting
a slightly more involved simulation.
§5.1 Σ-Protocols 51
Prover Verifier
(G1 = π G0 ) (G0 , G1 )
υ ∈R SX
H ← υ G1
H
−−−−−−−−−
→
c ∈R {0, 1}
c
−−−−−−−−−−
←
υ ◦ π, if c = 0
ρ←
υ, if c = 1
ρ
−−−−−−−−−→
−
?
ρ Gc = H
REMARK 5.4 By applying the transformation of Proposition 5.2 to the protocol in Fig-
ure 5.3, we obtain a Σ-protocol which is completely insecure against a cheating verifier.
The next exercise considers a Σ-protocol for graph isomorphism, which not only lets a
prover convince a verifier that two graphs are isomorphic but also that the prover actually
knows an isomorphism between these two graphs (by running multiple instances in series or
in parallel). This is an example of a basic Σ-protocol for which deciding language membership
is presumably hard.
EXERCISE 5.1.3 Let SX denote the set of permutations of a finite set X. Recall that for
permutations π, π ′ ∈ SX , their composition π ′′ = π ′ ◦ π satisfies π ′′ (x) = π ′ (π(x)) for all
x ∈ X. Also, for π ∈ SX , its inverse π −1 satisfies π −1 (π(x)) = π(π −1 (x)) = x for all x ∈ X.
Two directed graphs G0 = (V0 , E0 ) and G1 = (V1 , E1 ) with V0 = V1 = X are isomorphic if
there exists a π ∈ SX such that (x, y) ∈ E0 ⇔ (π(x), π(y)) ∈ E1 holds for all x, y ∈ X. We
write G1 = π G0 and also G0 = π −1 G1 . Computing such a permutation π given G0 and G1
is conjectured to be a hard problem (beyond the complexity class BPP). Let
RGI = {(G0 , G1 ; π) : G1 = π G0 }.
Prove that the protocol of Figure 5.4 is a Σ-protocol for relation RGI .
EXERCISE 5.1.4 Consider the following commitment scheme for a sender and a receiver,
similar to Definition 3.1. Given a Σ-protocol for relation R of the form shown in Figure 5.1,
let S denote a p.p.t. simulator for the Σ-protocol. For any fixed v ∈ LR , the protocols for the
commit and reveal phases are defined as follows:
Commit Phase. The sender commits to a value c ∈ C by running (a; c; r) ← S(v; c) and
sending a as commitment to the receiver.
Reveal Phase. The sender opens commitment a by sending c and r to the receiver. The
receiver checks if φ(v; a; c; r) holds.
52 CHAPTER 5 Zero-Knowledge Proofs
Prover Verifier
(x = logg h)
u1 , u2 ∈R Zn
a1 ← g u1
a1 , a2
a2 ← g u2 −−−−−−−−−− →
c1 , c2 ∈R Zn
c1 , c2
−−−−−−−−−
←
r1 ←n u1 + c1 x
r , r2
r2 ←n u2 + c2 x −−−−1−−− −−
→
?
g r1 = a1 hc1
?
g r2 = a2 hc2
Note that the sender’s randomness sits inside simulator S, and that we obtain basically
Pedersen’s commitment scheme by using Schnorr’s Σ-protocol for relation {(h; x) : h = g x },
as the simulator outputs (a; c; r) with a = g r h−c and r ∈R Zn for given h and value c ∈ Zn .
The construction works for an arbitrary nontrivial Σ-protocol, assuming it is hard to find
any witness w satisfying (v; w) ∈ R. Show that (i) the receiver’s check succeeds if both parties
follow the protocol steps, (ii) the commitment scheme is computationally binding, and (iii)
the commitment scheme is information-theoretically hiding.
Prover Verifier
(x1 = logg h1 , x2 = logg h2 )
u1 , u2 ∈R Zn
a1 ← g u1
a1 , a2
a2 ← g u2 −−−−−−−−−− →
c ∈R Zn
c
−−−−−−−−−−
←
r1 ←n u1 + cx1
r1 , r2
r2 ←n u2 + cx2 −−−−−−−−− →
?
g r1 = a1 hc1
?
g r2 = a2 hc2
it follows from the special soundness of Schnorr’s protocol that the witness is obtained as
x = (r1 − r1′ )/(c1 − c′1 ). More concretely, we have:
′ ′
g r1 = a1 hc1 , g r1 = a1 hc1
′ ′
⇒ g r1 −r1 = hc1 −c1
r1 −r1′
c1 −c′1
⇔ h=g .
Similarly, if c2 ̸= c′2 , the (same) witness is obtained as x = (r2 − r2′ )/(c2 − c′2 ). Hence, the
witness x satisfying h = g x can be recovered in either case.
Finally, special honest-verifier zero-knowledgeness follows from the fact that the Schnorr
protocol is so, and parallel composition uses two independent runs of Schnorr’s protocol.
More concretely, we have that for an arbitrary (fixed) challenge (c1 , c2 ), the distribution of
the real conversations is identical to the distribution of the simulated conversations, which
are respectively given by
Note that in both cases each conversation occurs exactly with probability 1/n2 . □
5.2.2 AND-COMPOSITION
Given two relations R1 = {(v1 ; w1 )} and R2 = {(v2 ; w2 )}, a Σ-protocol is obtained for relation
R1 ∧ R2 := {(v1 , v2 ; w1 , w2 ) : (v1 ; w1 ) ∈ R1 , (v2 ; w2 ) ∈ R2 } by running a Σ-protocol for R1
and a Σ-protocol for R2 in parallel, using a common challenge (assuming that both protocols
use the same challenge space).
Given two public keys h1 and h2 , a proof of knowledge of both logg h1 and logg h2 is
obtained, by running two instances of Schnorr’s protocol in parallel, using a common challenge,
as shown in Figure 5.6.
54 CHAPTER 5 Zero-Knowledge Proofs
{(h1 , h2 ; x1 , x2 ) : h1 = g x1 , h2 = g x2 }.
g r1 = g u1 +cx1 = g u1 (g x1 )c = a1 hc1 ,
g r2 = g u2 +cx2 = g u2 (g x2 )c = a2 hc2 .
These distributions are identical, each conversation occurring with probability 1/n2 . □
EXERCISE 5.2.1 By considering the special soundness property, explain why running the
Schnorr Σ-protocol (see Figure 4.3) in parallel for h1 and h2 does not yield a Σ-protocol for
relation {(h1 , h2 ; x1 , x2 ) : h1 = g x1 , h2 = g x2 }. Hint: consider a prover who knows x1 = logg h1
but does not know x2 = logg h2 .
EXERCISE 5.2.2 Consider the protocol in Figure 5.7 as a possible Σ-protocol for relation
{(h1 , h2 ; x1 , x2 ) : h1 = g x1 , h2 = g x2 }. (i) Show that the protocol is complete and special
honest-verifier zero-knowledge. (ii) Why does special soundness not hold for this protocol?
Hint: consider a prover who knows x1 = logg h1 but does not know x2 = logg h2 . (iii) Show
that soundness holds in the following sense: for any (h1 , h2 ) ∈ ⟨g⟩ × ⟨g⟩, given three accepting
conversations (a; c; r), (a; c′ ; r′ ), (a; c′′ ; r′′ ) with c ̸= c′ , c ̸= c′′ , c′ ̸= c′′ one can efficiently
compute witness (x1 , x2 ) satisfying h1 = g x1 and h2 = g x2 .
5.2.3 EQ-COMPOSITION
As another important example of composition of Σ-protocols, we consider a special case of
AND-composition, in which the prover uses a common witness for two instances of a relation.
That is, we give a Σ-protocol for relation {(v1 , v2 ; w) : (v1 ; w) ∈ R, (v2 ; w) ∈ R}, given a
Σ-protocol for relation R.
§5.2 Composition of Σ-Protocols 55
Prover Verifier
(x1 = logg h1 , x2 = logg h2 )
u ∈R Zn
a ← gu
a
−−−−−−−−−→
−
c ∈R Zn
c
−−−−−−−−−−
←
r ←n u + cx1 + c2 x2
r
−−−−−−−−−→
−
? 2
g r = ahc1 hc2
Prover Verifier
(x = logg1 h1 = logg2 h2 )
u ∈R Zn
a1 ← g1u
a1 , a2
a2 ← g2u −−−−−−−−−− →
c ∈R Zn
c
−−−−−−−−−−
←
r ←n u + cx
r
−−−−−−−−−→
−
?
g1r = a1 hc1
?
g2r = a2 hc2
The basic idea is to use AND-composition of the Σ-protocol for R, but this time the prover
uses the same random tape uP (see Figure 5.1) in both cases (and the same witness w).
We give an example based on Schnorr’s protocol. Note that it does not make much sense
to consider a single generator g and two public keys h1 and h2 , for which we prove knowledge
of an x such that x = logg h1 = logg h2 : this would imply that h1 = h2 . Therefore, we will
work with two generators g1 , g2 .
Given two public keys g1 , h1 and g2 , h2 , one proves knowledge of x = logg1 h1 = logg2 h2 ,
by running two instances of the Schnorr protocol in parallel, using a common random nonce
u, a common challenge c and a common response r.
PROPOSITION 5.7 The protocol in Figure 5.8 is a Σ-protocol for relation
These distributions are identical provided logg1 h1 = logg2 h2 , cf. Definition 5.1; furthermore,
if logg1 h1 ̸= logg2 h2 , the simulated conversations are accepting, as required. □
5.2.4 OR-COMPOSITION
Our next goal is to construct a Σ-protocol for relation R1 ∨ R2 = {(v1 , v2 ; w1 , w2 ) : (v1 ; w1 ) ∈
R1 ∨ (v2 ; w2 ) ∈ R2 }, given Σ-protocols for relations R1 and R2 . This turns out to be possible,
using a Σ-protocol of similar complexity as used for AND-composition.
Suppose that the prover knows a witness (w1 , w2 ) with (v1 ; w1 ) ∈ R1 . Hence, the prover
knows a witness for R1 ∨ R2 . The prover is able to run the Σ-protocol for R1 . However,
the prover need not be able to do so for R2 as it need not know a witness w2 such that
(v2 ; w2 ) ∈ R2 . Of course, if the prover knows a witness (w1 , w2 ) with (v2 ; w2 ) ∈ R2 and
possibly (v1 ; w1 ) ̸∈ R1 the same problem arises.
The way out is that the verifier may let the prover “cheat” a little bit by allowing the
prover to use the simulator of the Σ-protocol for the relation Ri for which the prover does
not know witness wi (i = 1 or i = 2). The verifier will do so by providing a single challenge
c which the prover is allowed to split into two challenges c1 , c2 provided c1 , c2 satisfy a linear
constraint in terms of c. For example, the constraint may be c = c1 ⊕ c2 if the challenges
happen to be bit strings. Essentially, the prover gets one degree of freedom to cheat.
Given two public keys h1 and h2 , a proof of knowledge of either x1 = logg h1 or x2 = logg h2
(or, possibly, both) is obtained, by composing one run of Schnorr’s protocol with one run of the
simulator for Schnorr’s protocol, as shown in Figure 5.9. The respective challenges c1 , c2 ∈ Zn
must sum to c (modulo n). If the prover knows x1 it follows the steps on the left-hand side of
the vertical bar. The values (a1 ; c1 ; r1 ) are generated as in a normal run of Schnorr’s protocol
(note that c1 ∈R Zn since c ∈R Zn ). The values (a2 ; c2 ; r2 ) are simulated. If the prover knows
x2 , it is the other way around.
PROPOSITION 5.8 The protocol in Figure 5.9 is a Σ-protocol for relation
{(h1 , h2 ; x1 , x2 ) : h1 = g x1 ∨ h2 = g x2 }.
§5.2 Composition of Σ-Protocols 57
Prover Verifier
a1 , a2
a2 ← g r2 h−c 2
2
a2 ← g u2 −−−−−−−−−→ −
c ∈R Zn
c
−−−− −−−−
←
c1 ←n c − c2 c2 ←n c − c1
c1 , c2 , r1 , r2 ?
r1 ←n u1 + c1 x1 r2 ←n u2 + c2 x2 −−−−−−−−− →− c1 + c2 =n c
?
g r1 = a1 hc11
?
g r2 = a2 hc22
PROOF To show completeness, consider the case that the prover uses x1 . Then we have:
c1 + c2 = c − c2 + c2 = c,
If c1 ̸= c′1 , we obtain witness x1 = (r1 − r1′ )/(c1 − c′1 ) satisfying h1 = g x1 ; otherwise c2 ̸= c′2 ,
and we obtain witness x2 = (r2 − r2′ )/(c2 − c′2 ) satisfying h2 = g x2 . So, we either obtain a
correct witness x1 or a correct witness x2 (or both).
Finally, we show that special honest-verifier zero-knowledgeness holds. The honest-verifier
and simulated distributions are, respectively (again considering the case of a prover using x1 ):
{(a1 , a2 ; c; c1 , c2 , r1 , r2 ) : u1 , r2 , c2 ∈R Zn ; a1 ← g u1 ; a2 ← g r2 h−c
2 ; c1 ←n c − c2 ;
2
r1 ←n u1 + c1 x1 },
{(a1 , a2 ; c; c1 , c2 , r1 , r2 ) : c1 , r1 , r2 ∈R Zn ; c2 ←n c − c1 ; a1 ← g r1 h−c r2 −c2
1 ; a2 ← g h2 },
1
for any given challenge c. These distributions are identical (uniform distribution on all ac-
cepting conversations, each one occurring with a probability of 1/n3 ). □
58 CHAPTER 5 Zero-Knowledge Proofs
Prover Verifier
(x1 = logg1 h1 , x2 = logg2 h2 )
u1 , u2 , u3 , u4 ∈R Zn
a1 ← g1u1
a2 ← g2u2
a1 , a2 , a3
a3 ← (g1 g2 )u3 (h1 h2 )u4 −−−−−−−−−→ −
c ∈R Zn
c
−−−−−−−−−−
←
r1 ←n u1 + cx1
r2 ←n u2 + cx2
r3 ←n u3 + cx1 /(x1 − x2 )
r1 , r2 , r3 , r4 ?
r4 ←n u4 + c/(x2 − x1 ) −−−−−−−−−→ − g1r1 = a1 hc1
?
g2r2 = a2 hc2
?
(g1 g2 )r3 (h1 h2 )r4 = a3 g2c
EXERCISE 5.2.3 As a slight optimization of the protocol of Figure 5.9, note that the prover
?
may omit sending the value of c2 , in which case the verifier must replace the test c1 + c2 =n c
by the assignment c2 ←n c − c1 . (Thus, the prover omits sending c2 independent of whether it
knows x1 and/or x2 .) Prove that the resulting protocol is a Σ-protocol for the same relation
as before.
5.2.5 NEQ-COMPOSITION
Finally, as the counterpart of EQ-composition, we consider NEQ-composition, which is a form
of AND-composition with the additional property that the two witnesses are different from
each other. We consider NEQ-composition for two instances of a given relation. That is, we
give a Σ-protocol for relation {(v1 , v2 ; w1 , w2 ) : (v1 ; w1 ) ∈ R, (v2 ; w2 ) ∈ R, w1 ̸= w2 }, given a
Σ-protocol for relation R.
As a first step, note that it is easy to use AND-composition of the Σ-protocol for R to
prove knowledge of both witnesses. The protocol then needs to be extended to show that the
witnesses are indeed different.
We give an example based on Schnorr’s protocol. Again, we work with two generators
g1 , g2 , this time assuming that logg1 g2 is unknown. Given two public keys g1 , h1 and g2 , h2 ,
we know how to prove knowledge of x1 = logg1 h1 and x2 = logg2 h2 . Moreover, since x1 ̸= x2
we have that x1 − x2 ̸= 0, hence we know that the multiplicative inverse of x1 − x2 modulo
n is defined. Starting from
h1 h2 = g1x1 g2x2 = (g1 g2 )x1 g2x2 −x1 ,
we therefore have
g2 = (g1 g2 )x1 /(x1 −x2 ) (h1 h2 )1/(x2 −x1 ) . (5.1)
Using Okamoto’s protocol we may thus prove that we can write g2 as a product of powers of
g1 g2 and h1 h2 . This will suffice to get the desired protocol as the AND-composition of two
instances of Schnorr’s protocol and one instance of Okamoto’ protocol.
§5.3 Miscellaneous Constructions 59
(g1 g2 )r3 (h1 h2 )r4 = (g1 g2 )u3 (h1 h2 )u4 ((g1 g2 )cx1 /(x1 −x2 ) (h1 h2 )c/(x2 −x1 ) ) = a3 g2c ,
Using Eq. (5.1), these distributions can be seen to be identical provided logg1 h1 ̸= logg2 h2 , cf.
Definition 5.1; furthermore, if logg1 h1 = logg2 h2 , the simulated conversations are accepting,
as required. □
In this section we explore some more examples of Σ-protocols, using various applications of
AND-composition, EQ-composition, OR-composition, and NEQ-composition. We start out
with an elaborate example, followed by several exercises.
EXAMPLE 5.10 Let g, h denote generators of a group of large prime order n such that logg h
is unknown to anyone. Suppose we need to design a Σ-protocol for the following (arbitrary)
relation:
R = {(A, B; x, y, z) : A = g x hy ∧ B = g xy h(1−x)z ∧ x ∈ {0, 1}}.
To break down the problem, we distinguish the cases x = 0 and x = 1 for a given pair
(A, B; x, y, z) ∈ R. If x = 0, then we have for a such a pair that A = hy ∧ B = hz holds.
60 CHAPTER 5 Zero-Knowledge Proofs
Prover Verifier
(case x = 0) (case x = 1)
u0A , u0B ∈R Zn u1 ∈R Zn
a0A ← hu0A a1A ← hu1
a0B ← hu0B a1B ← g u1
c1 , r1 ∈R Zn c0 , r0A , r0B ∈R Zn
a1A ← hr1 (A/g)−c1 a0A ← hr0A A−c0
a1B ← g r1 B −c1 a0B ← hr0B B −c0
a0A , a0B , a1A , a1B
−−−−−−−−−−−−−− →
−
c ∈R Zn
c
−−−−−−−−−−−−−−
←
c0 ←n c − c1 c1 ←n c − c0
r0A ←n u0A + c0 y r1 ←n u1 + c1 y
c0 , c1 , r0A , r0B , r1 ?
r0B ←n u0B + c0 z −−−−−−−−−−−−−− →− c0 + c1 =n c
?
hr0A = a0A Ac0
?
hr0B = a0B B c0
?
hr1 = a1A (A/g)c1
?
g r1 = a1B B c1
EXERCISE 5.3.1 Prove that the protocol of Figure 5.11 is a Σ-protocol for relation R, as
defined in Example 5.10.
EXERCISE 5.3.2 Let g, h denote generators of a group of large prime order n such that
logg h is unknown to anyone. Let B = g x hy denote the common input to prover and verifier,
where x, y ∈ Zn is private input to the prover. In each of the following cases, design a
Σ-protocol for proving knowledge of x, y ∈ Zn such that B = g x hy and ψ(x, y) holds, for
given predicate ψ(x, y). In each case, prove that your protocol is indeed a Σ-protocol for the
relation {(B; x, y) : B = g x hy , ψ(x, y)}; see hints below.
(b) ψ(x, y) ≡ x = y;
(f) ψ(x, y) ≡ x ̸= 0;
(g) ψ(x, y) ≡ x ̸= y;
(i) ψ(x, y) ≡ xy = 1;
(k) ψ(x, y) ≡ x2 = y 2 .
Hints: for part (a) use Okamoto’s protocol (see Figure 4.5); for part (b) consider modifications
of EQ-composition of Schnorr’s protocol (see Figure 5.8), or eliminate variable x or y directly
using that x = y; for part (c) eliminate variable x using the given equation for x and y; for part
(d) use OR-composition as in Example 5.10; for part (e) consider the binary representation
of x and use ℓ instances of the protocol of part (d); for part (f) use an instance of Okamoto’s
protocol by isolating g on one side of the equation B = g x hy , similar to Eq. (5.1) in NEQ-
composition; parts (g) and (h) are generalizations of part (f); for part (i) isolate g on one
side of the equation for B y and use EQ-composition with equation for B; for part (j) use
AND-composition and EQ-composition; for part (k) eliminate one of the variables and use
OR-composition.
EXERCISE 5.3.3 See Figure 4.5. Is the protocol of Figure 5.12 a Σ-protocol for the relation
{(h; x1 , x2 ) : h = g1x1 g2x2 }?
EXERCISE 5.3.4 Let g, h denote generators of a group of large prime order n such that logg h
is unknown to anyone. Design Σ-protocols (and prove correctness) for the following relations:
Prover Verifier
(h = g1x1 g2x2 )
u1 , u2 ∈R Zn
a1 ← g1u1
a1 , a2
a2 ← g2u2 −−−−−−−−−− →
c ∈R Zn
c
−−−−−−−−−−
←
r1 ←n u1 + cx1
r , r2
r2 ←n u2 + cx2 −−−−1−−− −−
→
?
g1r1 g2r2 = a1 a2 hc
EXERCISE 5.3.5 Let g, h denote generators of a group of large prime order n such that
logg h is unknown to anyone. Consider an instance of the 3SAT problem for Boolean variables
v1 , . . . , vℓ , given by a Boolean formula Φ consisting of m clauses, which each consist of three
literals:
Φ = (l1,1 ∨ l1,2 ∨ l1,3 ) ∧ · · · ∧ (lm,1 ∨ lm,2 ∨ lm,3 ).
Each literal is of the form li,j = vk or li,j = v k = 1 − vk (negation of vk ), 1 ≤ k ≤ ℓ. Construct
a Σ-protocol (including a correctness proof) for the following relation:
′
R3SAT = {(Φ, B1 , . . . , Bℓ ; x1 , y1 , . . . , xℓ , yℓ ) : Φ(x1 , . . . , xℓ ), ∀ℓk=1 Bk = g xk hyk , xk ∈ {0, 1}}.
EXERCISE 5.3.6 See the previous exercise. A Σ-protocol for R3SAT ′ actually proves knowl-
edge of witnesses to open the given commitments B1 , . . . , Bℓ . Construct a more flexible way
for proving that Φ is satisfiable, by considering the following relation instead:
EXERCISE 5.3.7 Let g, h denote generators of a group of large prime order n such that logg h
is unknown to anyone. Design two alternative Σ-protocols (and prove correctness) for relation
n−1
Rneq0 = {(A, B; x, y, z) : A = g x hy , B = g x hz }.
(i) By applying OR-composition distinguishing cases x = 0 and x ̸= 0 for the first proto-
col. (ii) By applying an appropriate form of EQ-composition for exponent x for the second
protocol (not using OR-composition at all). The Σ-protocols you are looking for both have
announcements consisting of four ⟨g⟩-elements each, but the response for (i) will comprise
six Zn -elements (using the optimization of Exercise 5.2.3), whereas (ii) can be done with a
response comprising four Zn -elements only.
Recall that there are basically two forms of authentication schemes: interactive authentica-
tion schemes (e.g., identification schemes) and noninteractive authentication schemes (e.g.,
digital signature schemes). Similarly, one may distinguish two forms of zero-knowledge proof
§5.4 Noninteractive Σ-Proofs 63
schemes: interactive proof schemes and noninteractive proof schemes. An interactive proof
scheme comprises a protocol by which a prover convinces a verifier that a certain statement
holds. A noninteractive proof scheme comprises an algorithm by which a prover generates a
proof for a certain statement and another algorithm by which a verifier may verify a given
proof.
It turns out that there is a simple but effective way to make any Σ-protocol noninteractive,
known as the Fiat–Shamir heuristic. To emphasize the difference between an interactive Σ-
protocol and its noninteractive counterpart, we will refer to the noninteractive version as a
Σ-proof.
A distinctive feature of a noninteractive Σ-proof is that any entity may play the role of the
verifier. As a consequence, a noninteractive Σ-proof can be verified independently by many
entities—just as a digital signature can be verified by anyone who is interested in its validity.
Key generation. A key pair (h; x) is generated by choosing private key x ∈R Zn and then
setting public key h by h ← g x .
Signature verification. On input of a message M , a pair (c, r), and a public key h, accept
(c, r) as a signature on M if and only if c = H(g r h−c ; M ) holds.
Clearly, the Schnorr signature scheme is quite efficient. The computational cost of signature
generation is dominated by the time to perform a single exponentiation of the form g u ; if
desired, this exponentiation can be done beforehand, that is, before the message M is known.
64 CHAPTER 5 Zero-Knowledge Proofs
Prover Verifier
(x = logg h)
u ∈R Z∗n
a ← gu a
−−−−−−−−−→
−
c ∈R Zn
c
−−−−−−−−−−
←
r ←n (c − F (a))u + x
r
−−−−−−−−−→
−
?
g r = ac−F (a) h
The computational cost of signature verification is dominated by the time to perform a “dou-
ble” exponentiation of the form g r h−c ; such an exponentiation can be computed considerably
faster than just computing g r and h−c and multiplying the result. Since a Schnorr signature
(c, r) consists of two numbers in Zn , the size of a signature is rather small (in practice, n may
be a 256-bit number, hence a signature is just 512 bits.)
The Fiat–Shamir heuristic for converting Σ-protocols into signature schemes can be proved
secure (against adaptive chosen-message attacks) in the random oracle model. The next exer-
cise, however, shows that for contrived cases the resulting signature scheme may be insecure.
EXERCISE 5.4.1 To see that the Fiat–Shamir heuristic does not necessarily lead to secure
signature schemes, consider the following variant of Schnorr’s protocol, see Figure 5.13. The
function F : ⟨g⟩ → Zn can be replaced by your favorite hash function; for simplicity it is
assumed that the hash function maps into Zn . Note that the constant function F (w) = 0, for
w ∈ ⟨g⟩, yields the protocol of Exercise 5.1.1.
(i) Show that the protocol is complete, special sound, and honest-verifier zero-knowledge
(for any function F : ⟨g⟩ → Zn ).
Proof generation. Given (v; w) ∈ R, a Σ-proof is a pair (α(v; w; uP ); ρ(v; w; H(a; v); uP )).
Proof verification. For v ∈ V , (a; r) is accepted as Σ-proof if and only if φ(v; a; H(a; v); r).
EXAMPLE 5.12 The Σ-protocol of Exercise 5.3.2(d) is converted into a Σ-proof as follows.
Let B = g x hy be given and let x ∈ {0, 1}, y ∈ Zn be the private input for the prover. Write
x = 1 − x for x ∈ {0, 1}.
Proof generation. Choose ux , cx , rx ∈R Zn , and set ax ← hux and ax ← hrx (B/g x )−cx .
Set the challenge c as c ← H(a0 , a1 ; B), and compute the responses cx ←n c − cx and
rx ←n ux + cx y. The Σ-proof is the tuple (c0 , c1 , r0 , r1 ).
It is important to note that for a Σ-proof, value v is included in the input to the hash
function, as well as announcement a. This way the “context” (statement to be proved) is fixed,
and forgery of proofs is prevented. Hence, in Example 5.12, it is important that commitment
B is included in the input to the hash function. Otherwise the Σ-proof can be forged, that is,
valid Σ-proofs can be generated without knowing any x ∈ {0, 1}, y ∈ Zn satisfying B = g x hy .
EXERCISE 5.4.2 Show how to forge a Σ-proof (c0 , c1 , r0 , r1 ) for a commitment B if proof
verification is changed into c0 + c1 =n H(hr0 B −c0 , hr1 (B/g)−c1 ) by making a suitable choice
for B. Hint: B can be set after c = H(a0 , a1 ) is computed.
Key generation. A protocol between P0 , P1 , . . . , Pm for generating a public key h for the
group, a private key x0 for the group manager P0 and a private key xi for each group
member Pi , 1 ≤ i ≤ m.
66 CHAPTER 5 Zero-Knowledge Proofs
Signature opening. An algorithm that on input of a message M , the public key h of the
group, a valid group signature S, and the private key x0 of the group manager, outputs
the identity of the group member who generated S.
A group signature scheme must meet similar security requirements as a basic digital signa-
ture scheme. In addition, there are requirements related to the anonymity of a group member
and the role of the group manager. Given a signature, no-one except the group manager
should be able to tell which group member produced the signature.4 More generally, given
two signatures, no-one except the group manager should be able to tell whether these signa-
ture were produced by the same group member or not (this property is called unlinkability).
Of course, group members should not be able to produce signatures on behalf of other group
members. Similarly, a group manager should not be able to frame a group member Pi by
opening a signature produced by Pj as if it was produced by Pi (i ̸= j).
We next describe a simple group signature scheme, where we assume that all parties have
access to a generator g of order n. As a warm-up exercise we first consider the problem of
proving knowledge of 1-out-of-m private keys. The base case m = 1 is just a Schnorr proof.
The case m = 2 can be solved by an OR-composition of two Schnorr proofs. The general case
may be solved by repeating OR-composition m − 1 times starting from m Schnorr proofs,
noting that OR-composition of a 1-out-of-m1 proof and a 1-out-of-m2 proof yields a 1-out-of-
(m1 + m2 ) proof.
Rm = {(h1 , . . . , hm ; x) : ∃m x
i=1 hi = g }
Ignoring the role of the group manager for a moment, we obtain a group signature by
applying the Fiat–Shamir heuristic to the Σ-protocol of Exercise 5.4.3. To do so, we would
set c ← H(a1 , . . . , am ; M ) for a given message M . The group signature for M is then defined
as S = (c1 , r1 , . . . , cm , rm ).
The complete group signature scheme is now as follows, where group member Pi is required
to include an ElGamal encryption of g xi under the group manager’s public key in each group
signature produced by Pi .
Key generation. Each group member Pi picks its private key xi ∈R Zn . Similarly, the
group manager picks its private key x0 ∈R Zn . The public key of the group is then set
to h = (h0 , h1 , . . . , hm ), where hi = g xi , 0 ≤ i ≤ m.
4
For simplicity, we assume that group members do not keep track of which signatures they produced and
so on.
§5.5 Bibliographic Notes 67
The given message M is also included as an additional input to the hash function in
the Σ-proof (similar to the way a Schnorr signature is generated).
Signature verification. The Σ-proof contained in the group signature is verified (similar
to the way a Schnorr signature is verified).
Signature opening. The group manager decrypts the ElGamal encryption contained in the
group signature, and proves that it performed decryption correctly. More precisely,
given ElGamal ciphertext (A, B), the group manager outputs d = Ax0 and a Σ-proof
for x0 = logg h0 = logA d, using EQ-composition. From d anyone may compute B/d
which matches the public key of the group member who produced the signature.
EXERCISE 5.4.4 Give a Σ-protocol for relation Rm ′ and prove its correctness, in each of the
The notion of a Σ-protocol was identified and studied in [Cra97], as a further abstraction of
the (special) honest-verifier zero-knowledge, special-sound protocols considered in [CDS94].
Nowadays many variants of Σ-protocols exist in the cryptographic literature.5 The defining
properties of completeness, soundness, and zero-knowledgeness in this text (cf. Definition 5.1)
have been chosen as strong as reasonably possible. Special attention has been paid to ensure
that the notion of a Σ-protocol is preserved under the compositions treated in Section 5.2.
It is well-known that Σ-protocols are in fact proofs of knowledge because of the extractor
demanded by the (special) soundness property (e.g., see [Dam10]). The formal notion of proofs
of knowledge, pioneered in [TW87, FFS88] and further developed in [GMR89, BG92], leads
to precise bounds on the success probability of a cheating prover (not knowing a witness).
The transformation from plain honest-verifier zero-knowledgeness to special honest-verifier
zero-knowledgeness in Figure 5.2 is from [Dam10]. The Σ-protocol for graph isomorphism in
Figure 5.4 is directly based on the perfect zero-knowledge proof from [GMW91]. The com-
mitment scheme constructed from any Σ-protocol in Exercise 5.1.4 is also from [Dam10]. OR-
composition is from [CDS94], whereas Exercise 5.3.2(d) is from [CFSY96]. EQ-composition
is based on the protocol for proving equality of discrete logarithms from [CP93]. The Σ-
protocol for linear relations (Exercise 5.3.2(c)) and the “not” proof (Exercise 5.3.2(f)–(h))
are from [Bra97]. NEQ-composition is related to (but different from) both the “not” proof
and the disavowal protocol in undeniable signature schemes (see, e.g., [BCDP91]). The Σ-
protocol of Exercise 5.3.4(b) is from [CD98].
5
Since 2001, the name SIGMA (“SIGn-and-MAc”) is also used by Hugo Krawczyk for a certain type of
authenticated key exchange protocol. Incidentally, there is also the thriller “The Sigma Protocol” by Robert
Ludlum (October 2001).
68 CHAPTER 5 Zero-Knowledge Proofs
The Fiat–Shamir heuristic is from [FS87]. Group signatures are due to [CH91], and the
scheme considered in the text using ElGamal is from [Cam97]. However, the 1-out-of-m
signature scheme based on the Σ-protocol of Exercise 5.4.3 already dates back to [CDS94,
Section 5].
CHAPTER 6
Threshold Cryptography
Secret sharing schemes form the basis for threshold cryptography. The idea is to split a secret
into several shares, such that the secret can be reconstructed whenever a sufficient number
of shares is available; if an insufficient number of shares is available, it should not be possible
to reconstruct the secret, nor any part of it.
In constructing secret sharing schemes one should be aware of certain pitfalls, as demon-
strated in the following example.
EXAMPLE 6.1 Consider the RSA cryptosystem with public exponent e = 3 and modulus
N , gcd(e, ϕ(N )) = 1. Two persons like to split the private key d = 1/e mod ϕ(N ) into
two halves such that both halves are required to recover d. What about splitting d into its
most-significant half and its least-significant half?
Let N = pq, with distinct primes p, q > 3 of the same bit length. Then 3d = 1 + lϕ(N )
for some integer l. Since 0 < d < ϕ(N ) it follows that l = 1 or l = 2. Since p and q are not
divisible by 3, ϕ(N ) ̸≡ 2 (mod 3), it follows that l ≡ 2 (mod 3). Hence l = 2. Consequently,
d = (1 + 2ϕ(N ))/3, which we may approximate by
$ √ %
1 + 2(N − 2 N + 1)
db = .
3
69
70 CHAPTER 6 Threshold Cryptography
Distribution. A protocol in which dealer D shares a secret s such that each participant Pi
obtains a share si , 1 ≤ i ≤ m.
The set Γ of all qualified (or, authorized) subsets of {P1 , . . . , Pm } is called the access
structure. More formally, access structure Γ is a subset of the powerset of {P1 , . . . , Pm },
or in symbols, Γ ⊆ 2{P1 ,...,Pm } , where 2X = {A : A ⊆ X} for a set X. Usually, an access
structure Γ is monotone, which means that Γ is closed under taking supersets: if A ∈ Γ and
A ⊆ B, then also B ∈ Γ, for all A, B ⊆ {P1 , . . . , Pm }.
The following security requirements are imposed on a secret sharing scheme:
(i) any qualified set of participants is able to determine the value of s by pooling their
shares, and
(ii) any nonqualified set of participants cannot determine any information on the value of
s when pooling their shares.
§6.2 Verifiable Secret Sharing 71
Distribution. The dealer picks a random polynomial a(X) ∈R Zp [X] of degree at most t
satisfying a(0) = s. It sends share si = a(i) to participant Pi , for i = 1, . . . , m.
Reconstruction. Any set Q of t + 1 participants may recover secret s from their shares by
Lagrange interpolation:2
X Y j
s= si λQ,i , with λQ,i = .
j−i
i∈Q j∈Q\{i}
To see why reconstruction works, recall that the Lagrange interpolation formula for the unique
polynomial a(X) of degree at most t passing through the points (i, si ), i ∈ Q, is given by
X Y X −j
a(X) = si .
i−j
i∈Q j∈Q\{i}
Since we are interested in the constant term s = a(0) only, we may substitute 0 for X.
Next, we need to argue that nonqualified sets of participants cannot find the secret s.
Suppose that participants Pi pool their shares si , i ∈ A, where |A| = t. Fix any (hypothetical)
value s̃ ∈ Zp for the secret, as used by the dealer. Lagrange interpolation of the points (0, s̃)
and (i, si ), i ∈ A, implies that there exists a unique polynomial ã(X) of degree at most t
passing through these points. In other words, given shares si , i ∈ A, any value s̃ for the secret
is equally probable, which means that from these shares no information on the secret s can
be gained. Therefore, the scheme is perfect.
Note that the security of Shamir’s scheme does not depend on the size of p. The only
condition on p is that p > m holds.
A basic secret sharing scheme is defined to resist passive attacks only, which means that its
security depends on the assumption that all parties involved run the protocols as prescribed
1
If nonqualified sets of participants are able to determine some (partial) information on secret s then the
scheme is not perfect. Without going into detail, we mention that such schemes are also of use.
2
Note that we frequently write i ∈ Q as a shorthand for Pi ∈ Q.
72 CHAPTER 6 Threshold Cryptography
by the scheme. After (honestly) taking part in the distribution protocol, a nonqualified set
of participants is not able to deduce any information on the secret.
In many applications, however, a secret sharing scheme is also required to withstand
active attacks. This is accomplished by a verifiable secret sharing (VSS) scheme, which
is designed to resist (combinations of) the following two types of active attacks:
• a dealer sending incorrect shares to some or all of the participants during the distribution
protocol, and
Clearly, Shamir’s scheme is not a VSS scheme, since it does not exclude either of these active
attacks. During the distribution protocol, there is no guarantee that the shares si received
actually correspond to a single polynomial a(X) of degree at most t. Similarly, during the
reconstruction protocol, there is no guarantee that a share si provided by participant Pi is
actually equal to the share received by Pi during the distribution protocol: nothing prevents
Pi from using a random value sei ∈R Zp instead of the correct value si ; the reconstructed value
s̃ will be useless, but if Pi is the only cheating participant during reconstruction, Pi will still
be able to find the value of s using the other t correct shares.
We will consider two basic VSS schemes.
a(X) = s + u1 X + · · · + ut X t ,
The commitments Bj broadcast by the dealer, commit the dealer to a single polynomial a(X)
of degree at most t over Zn . If si = a(i), then Eq. (6.1) will indeed hold:
Pt t t
uj ij j j
Y Y
g si = g a(i) = g j=0 = g uj i = Bji .
j=0 j=0
§6.2 Verifiable Secret Sharing 73
Therefore, any attempts at cheating by the dealer or by one or more participants is detected.
This security property does not depend on the DL assumption (or any other computational
assumption).
To complete the security analysis of Feldman’s scheme, however, we need to argue that
any set of t participants is not able to find the secret from their shares, given the fact that
they also get to see the commitments Bj , j = 0, . . . , t. In particular, note that B0 = g u0 = g s
is available, hence it is possible to find s if one is able to compute discrete logs w.r.t. g. Thus,
we will prove that if the DL assumption holds for ⟨g⟩, it follows that t or less participants are
not able to find the secret s.
Let h ∈ ⟨g⟩ be given, such that logg h is unknown. Suppose w.l.o.g. that participants
P1 , . . . , Pt (hence, collectively forming the adversary) are able to find the secret s. We show
how to compute logg h, which contradicts the DL assumption.
Given h we construct a modified instance of Feldman’s VSS as follows. The distribution
protocol is modified by letting the dealer set B0 = h (which means that the secret is s = logg h
is not known to the dealer). The dealer also chooses s1 , . . . , st ∈R Zn , and computes Bj for
j = 1, . . . , t such that Eq. (6.1) holds for participants P1 , . . . , Pt . (The shares for participants
Pt+1 , . . . , Pm are irrelevant.)
It is essential that the dealer is able to compute Bj for j = 1, . . . , t without knowing
s = logg h by setting:
Yt
Bj = (g sk /h)γj,k . (6.2)
k=1
Here t × t matrix (γj,k ) is the inverse of the following Vandermonde matrix:
1 1 ··· 1
2 22 · · · 2t
.
.. .. ..
. . .
t t 2 · · · tt
EXERCISE 6.2.1 Verify that Eq. (6.1) holds for 1 ≤ i ≤ t if B0 = h and Bj , 1 ≤ j ≤ t, are
defined by (6.2).
The view of participants P1 , . . . , Pt in the above modified instance of Feldman’s scheme
is identical to their view in a regular instance of the scheme. Therefore, any successful attack
on the regular instances will be equally successful on the modified instances. However, in the
modified instances the dealer itself does not even know the secret s, and breaking a modified
instance actually means computing the “embedded” discrete logarithm logg h. Any successful
attack on Feldman’s scheme, recovering the secret from t shares only, would thus contradict
the DL assumption.
EXERCISE 6.2.2 The special case of an m-out-of-m threshold scheme for secrets s ∈ Zn can
be solvedPsimply by setting the shares as follows: choose si ∈R Zn for i = 2, . . . , m and set
s1 = (s − m i=2 si ) mod n. Extend this basic secret sharing scheme to a Feldman VSS scheme,
and provide a security analysis of the resulting VSS scheme.
Distribution. The dealer chooses random polynomials a(X), b(X) of the form
a(X) = u0 + u1 X + · · · + ut X t
b(X) = v0 + v1 X + · · · + vt X t ,
t
j
Y
g si1 hsi2 = Cji . (6.3)
j=0
Informally, the security of Pedersen’s VSS scheme is analyzed as follows. Using that
u0 = s, note that the dealer broadcasts commitment C0 = g s hv0 . Since this is a Pedersen
commitment, it follows that the secret s is hidden in an information-theoretic way. This line
of reasoning can be extended to show that even when t shares are known in addition to the
commitments Cj , 0 ≤ j ≤ t, nothing can be deduced about the value of s (other than what
already follows from the a priori distribution of s).
A technical detail is that the dealer would be able to cheat if it would know logg h. The fact
that Pedersen’s commitment scheme is computationally binding (under the DL assumption),
however, ensures that the dealer is committed to the polynomials a(X) and b(X) once it
broadcasts the Cj values.
EXERCISE 6.2.3 See Exercise 6.2.2. This time P extend the basic m-out-of-m scheme, where
shares si1 ∈R Zn for i = 2, . . . , m and s11 = (s − mi=2 si1 ) mod n, to a Pedersen VSS scheme,
and provide a security analysis of the resulting VSS scheme.
§6.3 Threshold Cryptosystems 75
In a basic public key cryptosystem the private key is held by a single party. The object of a
(t, m)-threshold cryptosystem is to distribute the knowledge of a private key between parties
P1 , . . . , Pm such that at least t + 1 of these parties are required for successful decryption,
0 ≤ t < m. As a concrete example we will consider a (t, m)-threshold ElGamal cryptosystem.
Recall from Section 2.1.4 that the basic ElGamal cryptosystem consists of a key generation
algorithm, an encryption algorithm, and a decryption algorithm. To appreciate the definition
of a threshold cryptosystem (Definition 6.3), we first consider a simple but flawed approach
for obtaining a threshold version of the ElGamal cryptosystem.
The idea is to incorporate a (verifiable) secret sharing scheme as follows. A dealer first
runs the key generation algorithm of the ElGamal cryptosystem, resulting in a private key x
and a public key h, say. Subsequently, the dealer runs the distribution protocol of a (t, m)-
threshold secret sharing scheme, using x as the secret (e.g., using Feldman’s VSS scheme).
As a result, party Pi gets a share xi of the private key. The encryption algorithm remains the
same, using public key h. Finally, for decryption, the reconstruction protocol of the secret
sharing scheme is run first to obtain the private key x, which is then used as input to the
decryption algorithm.
However, this simple method suffers from two major drawbacks. Firstly, the dealer gets to
know the private key x, hence the dealer must be trusted not to use x on its own. Secondly,
during decryption the private key x is reconstructed, hence the parties involved must be
trusted not to use x on their own as well.
To address these problems, a threshold cryptosystem is defined as follows.
DEFINITION 6.3 A (t, m)-threshold cryptosystem, 0 ≤ t < m, is a scheme for parties
P1 , . . . , Pm consisting of the following three components.
Threshold decryption. A protocol between any set of t + 1 parties Pi0 , . . . , Pit that on
input of a ciphertext C, private shares xi0 , . . . , xit , and verification keys hi0 , . . . , hit ,
outputs plaintext M .
A basic security requirement for a threshold cryptosystem is that the private key x remains
secret at all times, unless t + 1 or more parties decide to cheat by pooling their shares.
Therefore, the distributed key generation (DKG) protocol is symmetric with respect to the
roles of P1 , . . . , Pm , hence the DKG protocol does not rely on a specific party acting as
a (trusted) dealer in a secret sharing scheme. Similarly, the threshold decryption protocol
should be such that it does not rely on reconstructing the private key x.
EXERCISE 6.3.1 See Section 2.1.4. Assuming honest behavior of partiesQm P1 , . . . , Pm , design
an m-out-of-m threshold ElGamal cryptosystem with public key h = i=1 hi , where xi ∈ Zn
is the private share of Pi and hi = g xi is the corresponding verification key, 1 ≤ i ≤ m.
Discuss its security against passive attacks.
76 CHAPTER 6 Threshold Cryptography
The observation that for small e the RSA cryptosystem leaks the most-significant half of the
private key d can be traced back to [BDF98, p. 29]. Example 6.1 builds on this idea, using a
slightly better approximation db and optimizing for the case e = 3.
The Shamir threshold secret sharing scheme is from [Sha79]. Independently, Blakley dis-
covered another way to do threshold secret sharing [Bla79]. Threshold cryptography was in-
troduced as a new concept together with some first solutions in [Des88, DF90], see also [Des94].
The Feldman VSS and Pedersen VSS schemes are from [Fel87] and [Ped92], respectively. The
threshold ElGamal cryptosystem is based on [Ped91].
CHAPTER 7
Multiparty Computation
The problem of finding secure and efficient electronic voting schemes has been a challenge
since the beginning of the 1980s. Assuming that votes are binary (that is, either “yes” or
“no”), electronic voting can be viewed as an instance of multiparty computation, where the
function to be evaluated is f (x1 , . . . , xm ) = x1 + · · · + xm for votes x1 , . . . , xm ∈ {0, 1}.
Given the techniques developed in the preceding chapters it is possible to arrive at a practical
solution in just a few steps.
Let us briefly state the basic security requirements for an electronic voting scheme.
• Eligibility means that only eligible voters can cast a vote, and also that each eligible
voter can cast at most one vote.
78
§7.1 Electronic Voting 79
• Privacy of an individual vote is assured against any reasonably sized coalition of parties
(not including the voter herself). Depending on the implementation some cryptographic
assumptions need to be assumed as well.
• Universal Verifiability ensures that any party, including any outside observer, can
check that the election is fair, i.e., that the published final tally is computed fairly from
the ballots that were correctly cast.
• Robustness (or, fault-tolerance) means that the faulty behavior (either benign or ma-
licious) of any reasonably sized coalition of participants can be tolerated. In large-scale
elections this means that no coalition of voters of any size can disrupt the election; in
other words, any cheating voter can be detected and discarded.
We will formulate a solution in terms of two types of roles: voters and talliers. Let
V1 , . . . , Vm′ denote the voters and T1 , . . . , Tm denote the talliers taking part in the election.
The role of a voter is simply to cast a vote as an encrypted and authenticated message. The
talliers will take care of computing the final tally (i.e., the sum of the votes), however, without
compromising the privacy of the votes. The problem is to resolve the apparent contradiction
that in order to compute the sum of the votes, the talliers need to decrypt the individual
votes thereby compromising privacy.
A single party (person or entity) may take part as a voter, as a tallier, or as both a
voter and a tallier. Two typical cases are large-scale elections with m′ ≫ m and boardroom
elections with m′ = m. In large-scale elections the number of voters may range from 100 to
1,000,000 say, while the number of talliers is limited, e.g., between 5 and 50. In a boardroom
election every person plays the role of both voter and tallier (see Exercise 7.1.2). The voting
scheme below is suited for large-scale elections, limiting the work for voters to sending a single
message.
For the solution presented below, the main tool is a threshold homomorphic cryp-
tosystem. As a concrete example of such a cryptosystem, we will consider the threshold
homomorphic ElGamal cryptosystem. This version of the ElGamal cryptosystem is the same
as the threshold ElGamal cryptosystem of Section 6.3.1 with the modification that the plain-
text space is Zn instead of ⟨g⟩, where encryption of a plaintext M ∈ Zn under public key h
is defined as
(A, B) = (g u , hu g M ), u ∈R Zn .
In other words, a value M ∈ Zn is encoded as a value g M ∈ ⟨g⟩. Note that during decryption
we need to apply the reverse transformation, that is given g M for some M ∈ Zn , we need
to compute M . In general, we would need to solve the discrete log problem to do so, which
we assume to be infeasible. The way out is that we will see to it that M belongs to a small
subset of Zn .
This modified ElGamal cryptosystem then enjoys the following (additive) homomorphic
property. If we multiply an encryption (A, B) of M with an encryption (A′ , B ′ ) of M ′ we
obtain an encryption of M + M ′ :
′ ′ ′
(A, B) ∗ (A′ , B ′ ) = (AA′ , BB ′ ) = (g u+u , hu+u g M +M ).
Voting. Each voter Vi casts a vote vi ∈ {0, 1} ≃ {“no”, “yes”} by broadcasting a ballot1
which is a message consisting of an ElGamal encryption (Ai , Bi ) = (g ui , hui g vi ), where
ui ∈R Zn , and a Σ-proof that (Ai , Bi ) is correctly formed.
Q ′ Pm′
Tallying. The talliers decrypt the product (A, B) = m i=1 (Ai , Bi ) to obtain g i=1 vi as inter-
P ′ Pm′
mediate result, from which m i=1 vi is easily determined using that 0 ≤ i=1 vi ≤ m .
′ 2
If all (Ai , Bi ) are correctly formed, it follows from the homomorphic property that (A, B) =
P m′
(g u , hu g i=1 vi ) for some u ∈ Zn , which ensures the validity of the final tally.
EXERCISE 7.1.1 Construct a Σ-protocol (and prove its correctness) for proving that (Ai , Bi )
is correctly formed, and turn it into a Σ-proof (see Section 5.4.2).
In practice, voter Vi needs to authenticate its ballot, say by producing a digital signature
on (Ai , Bi ) and the accompanying proof. The officials running the voting scheme must know
the public keys of the voters. During an election, the officials will check the signature on each
submitted ballot. At most one ballot will be accepted and recorded for each voter.
The property of universal verifiability is that anyone is able to check that (i) all ballots
(Ai , Bi ) used to calculate the product (A, B) are correctly formed (by checking the accom-
panying proofs), (ii) each ballot (Ai , Bi ) is correctly signed w.r.t. the public key of voter Vi ,
(iii) product (A, B) is computed correctly, (iv) each tallier produced a correct share of the
decryption of (A, B) (by checking the proofs, see Section 6.3.1), and finally (v) that the final
tally corresponds to the decrypted value of (A, B).
EXERCISE 7.1.2 The topic of this exercise is a boardroom election scheme involving voters
(doubling as talliers) V1 , . . . , Vm , m ≥ 1. QEach voter Vi has a public key hi = g xi , where
xi ∈R Zn is Vi ’s private key. Let Hi = hm i−1 j=1 hj , for 1 ≤ i ≤ m.
First, voter Vm broadcasts the following encryption of its vote vm ∈ {0, 1}:
(Am , Bm ) = (g um , Hm
um vm
g ),
where um ∈R Zn . Next, for i = m − 1, . . . , 1 (in this order), voter Vi broadcasts the following
encryption of its vote vi ∈ {0, 1}:
The homomorphic ElGamal cryptosystem introduced in the previous section provides an easy
way to compute an encryption of x + y (modulo n), given encryptions of x and y. We will
express this fact in a somewhat abstract way by saying that given homomorphic encryptions
E(x) and E(y), we may compute the encryption E(x + y) = E(x)E(y). Here, E(x) stands
for a homomorphic ElGamal encryption of x ∈ Zn under some understood, fixed public key
h; hence, E(x) = (g u , hu g x ) for some u ∈R Zn .
So, addition is easily covered. What about multiplication, that is, computing E(xy) from
E(x) and E(y)? This is indeed an important question as a solution to this problem basically
implies that we would be able to compute any function f : Zn × Zn → Zn . To compute
E(f (x, y)) from E(x) and E(y) we express f (x, y) as a polynomial in Zn [x, y], and repeatedly
apply addition and multiplication to evaluate the polynomial. For example, to compute
E((x + y)2 ) we first use addition to compute E(x + y) and then use multiplication to compute
E((x + y)(x + y)). Without going into details, we state that a solution for multiplication
allows us, in principle, to handle any efficiently computable function.
We will now focus on the computation of E(xy) given E(x) and E(y), considering the
special case that x, y ∈ {0, 1}. Also, we restrict ourselves to the case of two-party computation
(m = 2), writing A and B for parties P1 and P2 . Despite these restrictions the problem of
computing E(xy) is still nontrivial.
We first consider the case where party A knows x and party B knows y. In other words, x is
the private input of A and y is the private input of B. Securely computing xy in this case may
be interpreted as a way to implement the ultimate dating service, as may be concluded from
Figure 7.1. The idea is as follows. Say, Alice and Bob like to find out if they want to go on a
date (with each other). They might simply tell each other whether they are interested or not.
In case they are both interested, this simple solution is satisfactory. However, if for example
Alice is not interested in Bob but Bob is interested in Alice, Bob might feel embarrassed
afterwards because he expressed interest in her; if he would have known beforehand that
Alice was not interested anyway, he would have told Alice that he was not interested.
In terms of bits, we see that if xy = 1 it follows that x = y = 1 and there is nothing to
hide. If xy = 0, then x = 0 and/or y = 0. If x = 0, then it follows that xy = 0 regardless
of the value of y; in this case, a secure computation of xy is required to completely hide the
value of y. Hence, if Alice is not interested in Bob, and she knows that there is not going to
be a match anyway, she should not be able to find out whether Bob was interested or not.
The same reasoning applies to the case y = 0.
Let x ∈ {0, 1} be the private input of party A, and let y ∈ {0, 1} be the private input of
party B. To compute xy securely, the following protocol is executed, assuming that A and B
have set up a (1, 2)-threshold ElGamal cryptosystem with public key h.
82 CHAPTER 7 Multiparty Computation
2. Party B raises the encryption to the power y and sends the randomized result (C, D) =
(g v Ay , hv B y ), where v ∈R Zn , to party A.
The protocol is described for the passive case, that is, the case in which the parties follow
the protocol exactly. If A and B follow the protocol, we see that (C, D) = (g v+uy , hv+uy g xy ),
hence decryption of (C, D) indeed results in the value of xy.
To prove the security of the protocol in the passive case, we still need to do some work
though. Namely, we must show that party A is not able to deduce any information on y other
than implied by the values of its own input x and the common output xy. The only additional
information A gets on y is the encryption (C, D), but note that (C, D) = (g v Ay , hv B y ), where
v ∈R Zn is only known to party B. Under the DDH assumption, it follows that (C, D) does
not give any information on y. Similarly, the only additional information B gets on x is the
encryption (A, B) which gives no information on x, again under the DDH assumption.
To cover the active case, zero-knowledge proofs should be added to enforce parties A and
B to follow the protocol. In this case, A is required to prove that (A, B) is an encryption of a
bit value, and B is required to prove that (C, D) is indeed of the form (g s Ay , hs B y ) for some
s ∈ Zn and some y ∈ {0, 1}.
Next, we consider the more general case where values x and y are not known to parties
A and B, respectively, but x and y are only given by encryptions E(x) and E(y) say. (This
case arises for example when x and y result from earlier intermediate computations.) In
order to compute an encryption E(xy) we will decrypt some information related to x but
without revealing any information on x. For convenience, we will assume that the bits x, y
are represented as X = (−1)x and Y = (−1)y respectively, mapping {0, 1} to {1, −1}.3 The
protocol for the passive case is as follows, where each E(0) denotes a “fresh” encryption of 0:
1. Party A chooses u ∈R {1, −1} and sends encryptions E(Xu) = E(0) E(X)u and
E(Y u) = E(0) E(Y )u to party B.
2. Party B chooses v ∈R {1, −1} and sends encryptions E(Xuv) = E(0) E(Xu)v and
E(Y uv) = E(0) E(Y u)v to party A.
3. Parties A and B jointly decrypt E(Xuv) to obtain the value of z = Xuv. The output
of the protocol is set to E(Y uvz) = E(Y uv)z .
It follows that the output of the protocol is indeed E(Y uvz) = E(Y uvXuv) = E(XY ).
Moreover, the value z = Xuv as decrypted during the protocol is statistically independent of
the value of X, both from A’s point of view and from B’s point of view: A does not know v,
which is chosen at random in {1, −1} by B, and similarly B does not know u.
EXERCISE 7.2.1 Show how to obtain E(xy) efficiently from E(x), E(y), E(XY ) using the
homomorphic property of E(·).
3
Since (−1)x = 1 − 2x for x ∈ {0, 1} we have that E(X) = E(1)/E(x)2 . The reverse transformation is
given by E(x) = (E(1)/E(X))1/2 . These transformations can be computed efficiently using the homomorphic
property of E(·).
§7.3 Based on Oblivious Transfer 83
Sender Receiver
(x0 , x1 ∈ {0, 1}) (s ∈ {0, 1})
u ∈R Zn
hs ← g u
h0 , h1
u0 , u1 ∈R Zn ←−−−−−−−−−−−−−
− h1−s ← h/hs
u
(A0 , B0 ) ← (g u0 , h0 0 g x0 )
(A1 , B1 ) ← (g u1 , hu1 1 g x1 ) (A0 , B0 ), (A1 , B1 )
−−−−−−−−−−−−−− →− xs ← logg (Bs /Aus )
2
FIGURE 7.2: 1 -OT protocol
and the receiver uses one private input bit s. At the completion of the protocol, the receiver
now gets the bit xs , whereas the sender does not get any information on the value of s, i.e.,
the sender does not know which bit was selected by the receiver. This functionality is denoted
by OT(x0 , x1 ; s) = xs .
These two types of oblivious transfer are equivalent in the sense that either type can be
constructed from the other one, using a polynomial time transformation. For the remainder
2
of this section, we will only use 1 -OT.
In Figure 7.2 an example of a 21 -OT protocol for a discrete log setting is given. The
common input to the protocol consists of a group ⟨g⟩ and a group element h ∈ ⟨g⟩, for which
logg h is not known to any party. The receiver is supposed to pick elements h0 , h1 such that
h0 h1 = h, which implies that the receiver cannot know both logg h0 and logg h1 . Given h0
and h1 , the sender returns homomorphic ElGamal encryptions of bits x0 and x1 , respectively,
using h0 and h1 as public keys. The receiver is then able to decrypt one of these encryptions,
to recover either x0 or x1 .
If both parties follow the protocol, the receiver learns exactly one of the bits x0 and x1
(obtaining no information about the other bit), and the sender does not learn which bit the
2
receiver gets. Hence, the 1 -OT protocol of Figure 7.2 achieves its goal in the passive case.
Next, we show how parties A and B, holding private input bits x and y respectively, may
use such an OT protocol for computing the product xy. Hence, this is an alternative solution
for matching without embarrassments. Focusing, again,on the passive case, we see that this
problem can be handled using just a single run of a 21 -OT protocol, say in which A plays
84 CHAPTER 7 Multiparty Computation
the role of sender and B the role of receiver. The important observation is that
OT(x0 , x1 ; s) = xs = x0 s ⊕ x1 s,
which implies that if A uses 0 and x as values to send, and B uses y as selection bit, then we
get OT(0, x; y) = 0(1 − y) ⊕ xy = xy.
EXERCISE 7.3.1 Show how each of the 16 Boolean functions f : {0, 1}2 → {0, 1} with two
private input bits x and y held by parties A and B, respectively, can be evaluated using a
single run of a 21 -OT protocol of the form OT(x0 , x1 ; s) with x0 , x1 ∈ {0, x, x, 1} and s = y.
More generally, it is possible to let two parties A and B multiply bits x and y securely,
such that neither of them learns the values of x, y, and z = xy. This is done by letting A
and B additively share these values, that is, at the start of the protocol A holds bits xa , ya
and B holds bits xb , yb satisfying x = xa ⊕ xb and y = ya ⊕ yb , and at the end A will hold a
bit za and B a bit zb satisfying z = za ⊕ zb .
Of course, the shares held by A should be independent of the values x, y, z and the same
should be true for B. Only if the shares are combined, the values x, y, z will result. A first
attempt is to write xy = (xa ⊕ xb )(ya ⊕ yb ) = xa ya ⊕ xa yb ⊕ xb ya ⊕ xb yb , but it is unclear how
to split this into shares za and zb . Surely, the terms xa ya and xb yb can be computed by A
and B on their own, whereas the terms xa yb and xb ya can be computed by two applications
of the above protocol for the case of private inputs. However, by assembling za and zb from
these values, shares za and zb will not be completely independent of shares xb , yb and xa , ya ,
respectively, which is also necessary for security.
The way out is to let both A and B contribute some randomness to the protocol. Con-
cretely, each of them chooses a random bit ua , ub ∈R {0, 1}, respectively, and uses it in a run
of the OT protocol. The shares of z = xy are computed symmetrically like this:
za = xa ya ⊕ ua ⊕ OT(ub , xb ⊕ ub ; ya ) = xa ya ⊕ ua ⊕ ub ⊕ xb ya
zb = xb yb ⊕ ub ⊕ OT(ua , xa ⊕ ua ; yb ) = xb yb ⊕ ub ⊕ ua ⊕ xa yb .
Clearly, the share za is now uniformly distributed and independent of all other values if ub is
selected uniformly at random (as an honest B will do), and similarly for zb .
EXERCISE 7.3.2 Show how each of the 16 Boolean functions f : {0, 1}2 → {0, 1} with
two input bits x and y, both secret-shared additively between parties A and B, can be
computed using at most one run of the above secure multiplication protocol such that the
output z = f (x, y) is also secret-shared additively between A and B.
The approaches to realizing multiparty computation presented so far all rely on a computa-
tional assumption to ensure privacy.4 To achieve multiparty computation with information-
theoretic privacy (and without physical assumptions) we will avoid the use of public key
cryptosystems and use secret sharing instead.
4
For OT-based multiparty computation, one may argue that OT does not necessarily rely on a computa-
tional assumption. Parties connected by analog communication channels—rather than by digital (error-free)
communication channels—may depend on physical characteristics of these channels to realize OT.
§7.4 Based on Threshold Secret Sharing 85
As a start, we show how to upgrade the electronic voting scheme of Section 7.1 to ensure
information-theoretic privacy by using threshold secret sharing instead of threshold homo-
morphic Elgamal. Basically, each voter casts a vote by acting as the dealer in an instance of
Shamir’s (t, m)-threshold scheme from Section 6.1.1, where the vote is the secret s and the
talliers are the m participants.
To tally all votes without divulging the individual votes, the talliers rely on the following
(additive) homomorphic property of Shamir’s threshold scheme. If two secrets s and s′
have been shared among the same m participants using polynomials a(X) and a′ (X) of degree
at most t, respectively, we can obtain the sum s + s′ = a(0) + a′ (0) in two equivalent ways:
X X X
λQ,i a(i) + a′ (i) = a(0) + a′ (0) = λQ,i a′ (i),
λQ,i a(i) +
i∈Q i∈Q i∈Q
for any set Q of t + 1 participants. That is, if we first let participants add their shares a(i)
and a′ (i) locally and then reconstruct the secret sum s + s′ , we get the same result as when
we would first reconstruct secrets s and s′ separately and then add these.
Thus, to compute the final tally in an election, each tallier locally sums all its shares
received from the voters, followed by a single reconstruction to reveal the sum of the votes.
This way we obtain a voting scheme with information-theoretic privacy secure against passive
adversaries. To cover the active case, we resort to verifiable secret sharing, in particular using
Pedersen VSS to retain information-theoretic privacy; also requiring each voter to prove that
its Pedersen commitment contains a valid vote, using the Σ-proof from Example 5.12.
Next, we extend the above approach to realize general multiparty computation with
information-theoretic privacy. We focus on the passive case, relying on Shamir’s (t, m)-
threshold scheme. For fundamental reasons, however, we will limit the fraction of corrupted
parties as follows: to withstand (at most) t passively corrupt parties, we require t/m < 1/2.
This means that we require an honest majority among parties P1 , . . . , Pm with the number
of honest parties m − t exceeding the number of corrupt parties t:
An honest majority is only possible when m ≥ 2t + 1, which means that m ≥ 3 for any
nontrivial m-party computation withstanding t ≥ 1 corrupt parties.
For general multiparty computation, we show how to securely add and multiply two given
secret-shared values x = a(0) and y = b(0), where a(X), b(X) are polynomials of degree at
most t, such that each party Pi starts out with shares a(i), b(i) and ends up with a share c(i)
for some polynomial c(X) of degree at most t, where z = c(0) satisfies z = x + y and z = xy,
respectively.
For secure addition, we rely on the above homomorphic property of Shamir secret sharing,
which implies that letting each party Pi set c(i) = a(i) + b(i) locally does the job. The sum
polynomial c(X) = a(X) + b(X) is of degree at most t and z = c(0) = a(0) + b(0) = x + y is
the sum of the secrets x and y.
For secure multiplication, we start out in the same way by letting each party Pi compute
si = a(i)b(i) locally. This time, however, the product polynomial a(X)b(X) is of degree 2t,
generally. To resolve this problem and obtain a (random) polynomial c(X) of degree at most
t with c(0) = xy, we proceed along the same lines as in the DKG protocol of the threshold
ElGamal cryptosystem from Section 6.3.1: each party Pi acts as the dealer in an instance of
Shamir’s threshold scheme with si as secret, using a random polynomial ci (X) of degree at
86 CHAPTER 7 Multiparty Computation
obtains j∈Q′ λQ ,j sji = c(i) as its share of the product xy. Indeed, polynomial c(X) is of
′
The above process is often referred to as a “resharing,” as we let all parties Pi ∈ Q′ perform
another sharing of their shares si = a(i)b(i).
The privacy claim for the above protocols is that a collusion of t parties cannot find
any information on the secret values; only when t + 1 or more parties pool their shares the
secret values are revealed. For secure multiplication this holds because the polynomial c(X)
is uniformly distributed and independent of all other values, subject only to the condition
c(0) = xy.
While secure addition can be done without any interaction between the parties, we see
that secure multiplication requires one round of communication, in which the parties exchange
shares between each other. More precisely, in the common case m = 2t + 1, we see that each
party sends and receives exactly m − 1 = 2t finite field elements (one per party).
Interestingly, we can generalize secure multiplication to secure dot products with no
changes in the communication cost at all. Given vectors x and y secret-shared elementwise,
n
Pnfor some polynomials {ak (X), bk (X)}k=1
i.e., x = (a1 (0), . . . , an (0)) and y = (b1 (0), . . . , bn (0))
of degree at most t, the dot product z = x · y = k=1 xk yk can be computed securely by a
simple modification of the above protocol for secure multiplication. Pn This time, each party Pi
n
starts out with shares {ak (i), bk (i)}k=1 and computes si = k=1 ak (i)bk (i) locally. For the
remainder of the protocol, the parties perform a resharing of their shares si , exactly the same
as in a secure multiplication.
EXERCISE 7.4.2 Verify the correctness of the above protocol for secure dot products.
This efficient protocol for secure dot products hinges on the additive homomorphic property
of Shamir secret sharing, which is often referred to as the linearity of the Shamir threshold
scheme. In essence, the linearity allows us to use a single resharing instead of the n resharings
that would arise if we perform secure multiplications xk yk separately for k = 1, . . . , n (and
then add the results locally).
EXERCISE 7.4.3 Design Pae protocol for secure multiplication of two given polynomials f (Z) =
P d k l
k=0 xk Z and g(Z) = l=0 yl Z and prove its correctness. Use one resharing per coefficient
of the product polynomial h(Z) = f (Z)g(Z). The polynomials f (Z), g(Z), and h(Z) are
secret-shared coefficientwise.
§7.5 Bibliographic Notes 87
The basic results for secure multiparty computation date back to Yao’s papers [Yao82a,
Yao86], who focuses on the two-party case (and considers the millionaires problem as a con-
crete example), and to [GMW87, BGW88, CCD88] for the multiparty case. The electronic
voting scheme in Section 7.1 is from [CGS97], and the variant with information-theoretic
privacy sketched at the start of Section 7.4 is from [CFSY96]; see [Sch10b] for a survey of
cryptographic voting schemes.
The general approach for multiparty computation based on threshold homomorphic cryp-
tosystems is due to [CDN01], whereas the adaptation to ElGamal is from [ST04]. Interest-
ingly, the use of homomorphic cryptosystems for secure computation was already put forward
in [RAD78], as a positive twist to the insecurity of plain versions of RSA, in which the RSA
encryption and digital signature schemes are used without any message padding [RSA78].
The basic form of oblivious transfer in which the receiver gets the
bit with 50% probability
2
(and otherwise an undefined value) is due to Rabin [Rab81]. The 1 -OT protocol of Figure 7.2
is due to [BM89]. The (polynomial time) equivalence to 21 -OT was shown in [Cré87]. Kilian
showed that OT is complete for secure multiparty computation, which basically means that
protocols for securely evaluating any given efficiently computable function f can be built from
OT only [Kil88]. His result covers the active case by showing how to implement the required
commitments and zero-knowledge proofs from OT, whereas the case of passive adversaries
had already been covered by [GMW87] (for which the subprotocol described in Section 7.3 is
an efficiency improvement due to [GV88]). The use of physical channel characteristics for OT
mentioned in footnote 4 was first studied in [CK88], presenting noisy channels and quantum
channels as the two common options; see, e.g., [HMZ+ 14] and [BBCS91], respectively, for
steps toward practical application.
The general approach for multiparty computation based on threshold secret sharing is
from [BGW88], where the elegant resharing step in secure multiplication is due to [GRR98].
The generalization to degree-2 multivariate polynomials—with secure dot products and secure
polynomial multiplication as special cases—seems to be folklore; an early reference relying on
these “well-known techniques for privately evaluating polynomials” and “the homomorphic
property of Shamir’s scheme” is [IK00, Lemma 4.3, pp. 300 and 304]. The concrete protocol for
secure dot products in Section 7.4 is from [CH10], and similarly the protocol of Exercise 7.4.3
is from [Sch10a].
CHAPTER 8
Blind Signatures
A digital signature scheme provides the basic functionality of message authentication, allowing
the holder of a private key to produce signatures on arbitrary messages. In many applications,
however, there is a need for cryptographic schemes which are similar to digital signatures but
not quite the same. The group signatures of Section 5.4.3 are an example. In this chapter,
we will consider blind signature schemes as another variation.
Suppose we like to build an electronic payment scheme in which a bank issues electronic
money to users who may then spend it at various shops. In such a scheme the bank may issue
electronic money by sending the users digitally signed messages saying “This is a banknote
worth $20. Serial number: P01144099136.” To spend electronic money at a shop, the user
will include such an electronic banknote in a payment to the shop. Since these banknotes are
trivial to duplicate, however, the shop needs to deposit any received banknotes immediately
at the bank to make sure that these banknotes have not been spent already at some other
shop. The bank keeps a database containing all spent banknotes, and each banknote can be
used for payment only once. If a payment to a shop contains a banknote that was already
spent before, the payment is rejected.
Now, a basic property of any such payment scheme is that the bank is able to trace exactly
at which places a user spends its money. This is due to the fact that in a digital signature
scheme the signer gets to see all the messages it signs, and obviously, the signer knows all
the signatures it produces for these messages. To achieve the level of anonymity as provided
by cash payments using (metal) coins, where payment transactions need not leave any trace
about the identity of the payers, one may use blind signatures instead of (ordinary) digital
signatures.
8.1 DEFINITIONS
Like digital signatures, blind signatures are unforgeable and can be verified against a public
key. The difference is that blind signatures are generated by means of a protocol between
the signer and a receiver such that the signer does not see the message being signed. And, in
addition, the signer does not learn any useful information on the signature being produced.
DEFINITION 8.1 A blind signature scheme consists of the following three components.
88
§8.2 Chaum Blind Signature Scheme 89
Signature verification. An algorithm that on input of a message M , a public key pk, and
a signature S, determines whether S is a valid signature on M with respect to public
key pk.
The two basic security requirements for a blind signature scheme are unforgeability and
unlinkability, which we state informally as follows. Let (sk, pk) be a key pair for a blind
signature scheme. A pair (M, S) is valid if signature verification of M and S with respect to
public key pk succeeds.
A blind signature scheme is unforgeable if for an adversary (not knowing sk) the only
feasible way to obtain valid pairs (M, S) is to execute the signature generation protocol with
a signer holding private key sk. More precisely, a blind signature scheme should withstand a
one-more forgery: if an adversary is able to obtain ℓ valid pairs of messages and signatures,
then the signer executed the signature generation protocol at least ℓ times. Preferably, we
like this to hold for any positive ℓ bounded polynomially in the security parameter k.
A blind signature scheme is unlinkable if for an adversary (colluding with a signer) it is
infeasible to link any valid pair (M, S) to the instance of the signature generation protocol in
which it was created. More precisely, suppose a signer S and a receiver R play the following
game. First they run the signature generation protocol resulting in a pair (M0 , S0 ) and then
they run it once more, resulting in (M1 , S1 ). Then R flips a coin, that is, chooses b ∈R {0, 1}
and sends (Mb , Sb ), (M1−b , S1−b ) (in this order) to S. Finally, S makes a guess for the value
of b. Unlinkability means that the probability of S guessing b correctly is 21 , except for a
difference negligible in the security parameter k.
Recall the RSA digital signature scheme, in which a public key consists of an RSA modulus
N = pq and a public exponent e, with gcd(e, ϕ(N )) = 1, and a corresponding private key
consists of prime factors p, q and the private exponent d = 1/e mod ϕ(N ). A signature S on a
message M ∈ {0, 1}∗ is generated as S = H(M )d mod N , where H is a suitable cryptographic
hash function.1 A signature is verified by checking that S e = H(M ) mod N .
Chaum’s blind signature scheme is a modification of the RSA scheme, where signature
generation is done using the protocol of Figure 8.1. The role of the signer is simply to extract
an eth root for any value y ∈ Z∗N it gets from a receiver. Thus a receiver is able to get
signatures on arbitrary messages M ∈ {0, 1}∗ . Instead of simply sending H(M ) to the signer,
however, the receiver blinds it by sending y = H(M )/ue mod N , where u is a random value,
called a blinding factor. After receiving x = y 1/e mod N , the receiver is able to unblind it
such that a signature on M is obtained after all:
Signer Receiver
(d = 1/e mod ϕ(N ))
u ∈R Z∗N
y ←N H(M )/ue
y
−−−−−−−−−−
←
x ←N y d x
−−−−−−−−−−→
−
S ←N xu
?
S e =N H(M )
The use of a blinding factor u ∈ Z∗N ensures that the pair (M, S) is statistically inde-
pendent of the pair (x, y), implying (perfect) unlinkability. On the other hand, it is not
known whether unforgeability holds for Chaum’s blind signature scheme under the standard
RSA assumption (cf. Exercise 1.3.7). Under a special type of RSA assumption it is possible,
however, to prove that the scheme is unforgeable.
EXERCISE 8.2.1 Consider Chaum’s blind signature protocol (Figure 8.1) for a fixed message
M . Show that the pair (x, y) is distributed uniformly random by proving that Pr[(x, y) =
(x0 , y0 )] = 1/ϕ(N ) for any x0 , y0 ∈ Z∗N satisfying y0 = xe0 mod N .
EXERCISE 8.2.2 In this exercise, we use the extended Euclidean algorithm to let a receiver
obtain two blind signatures S1 , S2 for two messages M1 , M2 satisfying S1e1 = H(M1 ) mod N
and S2e2 = H(M2 ) mod N , respectively, from just one interaction with the signer. That is,
the signer follows the same steps as in Chaum’s protocol (Figure 8.1), but this time with
e = e1 e2 , where not only gcd(e, ϕ(N )) = 1 but also gcd(e1 , e2 ) = 1.
Suppose that the receiver sends y = H(M1 )e2 H(M2 )e1 /ue mod N with u ∈R Z∗N and
the signer replies with x = y 1/e mod N . Find an efficient method for the receiver to extract
signatures S1 and S2 w.r.t. public exponents e1 and e2 , respectively, from S = xu mod N , in
the same vein as the extended Euclidean algorithm is used to establish special soundness for
Guillou–Quisquater’s protocol in Section 4.5.3. Prove that your method works.
Almost all of the Σ-protocols we have seen so far enjoy the property that the verification
relation is homomorphic. For example, referring to Schnorr’s protocol of Figure 4.3, we have
the following homomorphic property for two accepting conversations (a; c; r) and (a′ ; c′ ; r′ ):
′ ′ ′ ′
g r = ahc , g r = a′ hc ⇒ g r+r = aa′ hc+c .
That is, (aa′ ; c + c′ ; r + r′ ) is an accepting conversation as well. For this reason it is easy
to obtain blind signature schemes from Σ-protocols. Figure 8.2 shows a blind signature
protocol based on Schnorr’s protocol. The output of the protocol is a signature S = (c′ , r′ )
′ ′
on message M satisfying c′ = H(g r h−c ; M ), which is the same verification relation as for
Schnorr signatures.
§8.4 Bibliographic Notes 91
Signer Receiver
(x = logg h)
u ∈R Zn
a ← gu a s, t ∈R Zn
−−−−−−−−−→
−
a′ ← ag s h−t
c ← H(a′ ; M )
′
c c ←n c′ − t
−−−−−−−−−−
←
r ←n u + cx
r
−−−−−−−−−→
−
r′ ←n r + s
′ ? ′
g r = a′ hc
The notion of blind signatures was introduced by Chaum at CRYPTO’82 [Cha83], who also
presented the first blind signature protocol at CRYPTO’83 [Cha84] (see also the corresponding
2
In fact, when many interactions with the signer can be executed in parallel a one-more forgery becomes
possible under certain circumstances.
92 CHAPTER 8 Blind Signatures
patent [Cha88]). Originally, one of the main applications of blind signatures was anonymous
electronic cash, which formed together with follow-up patents the core technology of the eCash
system (developed by Chaum’s company DigiCash when the world wide web was spun in the
early 1990s, see also [Sch97]). The optimization of Exercise 8.2.2 by batching Chaum blind
signatures is based on [Cha90] (see also [Sch97], where a connection with [Sha83] is made;
see [Fia97] for techniques to handle the case of multiple co-prime public exponents e1 , . . . , eℓ
more efficiently than the obvious solutions).
The idea that for many protocols, including Σ-protocols, one may render blind signature
schemes in a systematic way is from Okamoto and Ohta [OO90]. The technique is called
divertibility, and in the case of Σ-protocols, divertibility boils down to an intermediate party
blinding and unblinding the messages exchanged between a prover and a verifier. This way
unlinkability is ensured, but whether the resulting blind signature scheme is unforgeable as
well depends on more specific properties of the underlying Σ-protocol.
For instance, Pointcheval and Stern [PS00] have shown that by diverting Okamoto’s
witness-indistinguishable Σ-protocol (see Exercise 8.3.2), one obtains a blind signature scheme
which is unforgeable as long as the number of parallel runs in which an attacker may engage
is sufficiently small as a function of a security parameter. The attack by Benhamouda et
al. [BLL+ 21], extending earlier work by Wagner [Wag02], shows that the number of parallel
runs should certainly not be allowed to exceed log2 n. A possible countermeasure for this
type of attack is to limit the number of parallel runs that can be active at any given mo-
ment in time, but such a limitation may be undesirable in some situations and may be hard
to enforce. Using more advanced—but also costlier—techniques, it is possible to get blind
signature schemes without such limitations; see, e.g., [Fis06]. Also, the “clause” variant of
the Schnorr-based blind signature protocol due to Fuchsbauer et al. [FPS20], which roughly
doubles the cost compared to the original protocol, is not affected by parallel attacks under
a seemingly reasonable assumption.
Solutions to Exercises
1.2.1 We have
ω(n)
n Y p Y i+1
= ≤ = ω(n) + 1 = O(log n),
ϕ(n) p−1 i
p|n i=1
p 1
as p−1 =1+ p−1 ≤ 1+ 1i = i+1
i follows from p ≥ i+1 for the ith smallest prime factor p of n.
1.2.4 (a) Indeed, we have that a, b ∈ ⟨h⟩ as well, using the result from Exercise 1.2.3.
Therefore,
alogh b = hlogh a logh b = blogh a .
(b) Since g ∈ ⟨g⟩∗ we immediately see from part (a) that a ∗ b = b ∗ a, hence the DH product is
commutative. By definition logg a, logg b ∈ Z∗n for a, b ∈ ⟨g⟩∗ , hence a ∗ b = g logg a logg b ∈ ⟨g⟩∗
as well. The DH product is also associative because
logg c
(a ∗ b) ∗ c = (alogg b )logg c = alogg b logg c = alogg b = a ∗ (b ∗ c).
Generator g is the identity element as g ∗ a = g loga = a. Finally, for a ∈ ⟨g⟩∗ we have as
inverse a−1 = g 1/ logg a , using that logg a ∈ Z∗n . Clearly, a−1 ∗ a = (g 1/ logg a )logg a = g.
Another way to view the DH product ∗ is to note that g x ∗ g y = g xy . And that the inverse
of g x w.r.t. ∗ is equal to g 1/x , for x ∈ Z∗n .
93
94 Solutions to Exercises
|a + b| ≤ |a| + |b|
Hence, ∆(X; Y ) ≤ 21 ( v∈V Pr[X = v] + Pr[Y = v]) = 1 with equality if and only if Pr[X =
P
v] Pr[Y = v] = 0 for all v ∈ V (i.e., X and Y are disjoint). This proves parts (i) and (iii).
Part (ii) simply states that ∆(X; Y ) = 0 if and only if the probability distributions of X
and Y are identical, which follows directly from the definition of ∆(X; Y ). Similarly, part
(iv) follows directly.
Finally, part (v) follows from the fact that, for any v ∈ V ,
as can be seen from the triangle inequality by putting a = Pr[X = v] − Pr[Y = v] and
b = Pr[Y = v] − Pr[Z = v].
P P P P
Since v∈V + Pr[X = v] + v̸∈V + Pr[X = v] = 1 = v∈V + Pr[Y = v] + v̸∈V + Pr[Y = v],
the sums on the right-hand side are equal to each other, hence both are equal to ∆(X; Y ).
Part (ii) is clearly equivalent to part (i), because Pr[X = v] −. Pr[Y = v] is equal to
Pr[X = v] − Pr[Y = v] if v ∈ V + and otherwise it is equal to 0.
Rewriting (ii) results in (iii):
Finally, to obtain (iv), write W + = {v ∈ W : Pr[X = v] > Pr[Y = v]} for any set W ⊆ V ,
and observe, splitting the sum over W in its positive terms and its nonnegative terms in the
Solutions to Exercises 95
second step, that the maximum is attained in the third step if either W = V + or W = V \V + :
= ∆(X; Y ),
using Proposition 1.8(iv) twice. The first inequality can actually be shown to be an equality,
but the second one cannot in general (e.g., consider functions f for which |f (V )| = 1).
1.2.7 So, X takes on values in {0, . . . , n − 1} and Y takes on values in {d, . . . , d + n − 1}. If
d > n, these ranges are disjoint, hence ∆(X; Y ) = 1. If d ≤ n, we split the combined range
V = {0, . . . , d + n − 1} as follows:
X
2∆(X; Y ) = Pr[X = v] − Pr[Y = v]
v∈V
d−1 n−1 d+n−1
X 1 X 1 1 X 1
= −0 + − + 0−
n n n v=n
n
v=0 v=d
d d
= +0+ .
n n
d−1
X X 1 d
∆(X; Y ) = Pr[X = v] − Pr[Y = v] = −0 = .
n n
v∈V + v=0
96 Solutions to Exercises
1.2.8 Since Y and Z are disjoint, clearly ∆(Y ; Z) = 1. For any n, we have:
X
2∆(X; Y ) = Pr[X = v] − Pr[Y = v]
0≤v<2n
X 1 1 X 1 X 1
= − + −0 + 0−
n n n n
0≤v<n, v even 0≤v<n, v odd n≤v<2n, v even
1 X X
= 1+ 1 ,
n
0≤v<n, v odd n≤v<2n, v even
and
X
2∆(X; Z) = Pr[X = v] − Pr[Z = v]
0≤v<2n
X 1 X 1 1 X 1
= −0 + − + 0−
n n n n
0≤v<n, v even 0≤v<n, v odd n≤v<2n, v odd
1 X X
= 1+ 1 .
n
0≤v<n, v even n≤v<2n, v odd
If n is even, one sees that each of the above four sums is equal to n/2, so ∆(X; Y ) = ∆(X; Z) =
1/2. For odd n, we have that
X X
1= 1 = (n − 1)/2,
0≤v<n, v odd n≤v<2n, v even
X X
1= 1 = (n + 1)/2,
0≤v<n, v even n≤v<2n, v odd
and X 1 1
X 1
Pr[XY = v] = Pr[X = v/w, Y = w] = = .
n ϕ(n) n
w∈Z∗n ∗
w∈Zn
Solutions to Exercises 97
1.2.10 For any pair (A, B) ∈ ⟨g⟩ × ⟨g⟩, clearly Pr[X = (A, B)] = 1/n2 . Since (u, M ) 7→
(g u , hu M ) is a bijection from Zn × ⟨g⟩ to ⟨g⟩ × ⟨g⟩, it follows that Pr[Y = (A, B)] = 1/n2 as
well. Hence, ∆(X; Y ) = 0.
Next, we have:
X
2∆(Y ; Z) = Pr[Y = (g u , hu M )] − Pr[Z = (g u , hu M )]
u∈Zn ,M ∈⟨g⟩
X 1 1 X 1
= 2
− + −0
n n n2
u∈Zn ,M =M0 u∈Zn ,M ∈⟨g⟩\{M0 }
= 2n(n − 1)/n2 ,
hence ∆(Y ; Z) = 1 − 1/n.
Since X and Y are identical, clearly ∆(X; Z) = 1 − 1/n as well, which is proved by
observing that if ∆(X; Y ) = 0, Proposition 1.7(v) says that ∆(Y ; Z) ≥ ∆(X; Z) and that, by
interchanging X and Y , also that ∆(X; Z) ≥ ∆(Y ; Z), hence ∆(X; Z) = ∆(Y ; Z).
Pd−1
1.2.11 For any v, we have that Pr[X + U = v] = w=0 Pr[X = w] Pr[U = v − w], hence
that 0 ≤ Pr[X + U = v] ≤ 1/n, and, if d − 1 ≤ v < n, that Pr[X + U = v] = 1/n. Thus,
d+n−2
X
1
∆(U ; X + U ) = 2 Pr[U = v] − Pr[X + U = v]
v=0
d−2
X n−1 d+n−2
1 1 X 1 1 X 1
≤ 2 −0 + − + 0−
n n n v=n
n
v=0 v=d−1
= (d − 1)/n.
Take X = d − 1 (constant) to conclude that this bound is tight.
Incidentally, note that ∆(U ; X + U ) = E[X]/n, where E[X] denotes the expected value of
X. Therefore, equality ∆(U ; X + U ) = (d − 1)/n holds if and only if X = d − 1.
1.2.12 First, note that for any v, w such that d − 1 ≤ v < n and 0 ≤ w < d we have both
Pr[C = v] = 1/n and Pr[U = v − w] = 1/n, and hence
Pr[X = w, X + U = v] Pr[X = w] Pr[U = v − w]
Pr[X = w | C = v] = = = Pr[X = w].
Pr[C = v] Pr[C = v]
Therefore, H(X|C) can be bounded below as follows:
d+n−2
X d−1
X
H(X|C) = − Pr[C = v] Pr[X = w | C = v] log2 Pr[X = w | C = v]
v=0 w=0
n−1
X d−1
X
≥ − Pr[C = v] Pr[X = w | C = v] log2 Pr[X = w | C = v]
v=d−1 w=0
n−1 d−1
X 1 X
= − Pr[X = w] log2 Pr[X = w]
n
v=d−1 w=0
1
= (n − d + 1)H(X).
n
98 Solutions to Exercises
1.2.13 With X and Y uniformly random on sets S and T , resp., Proposition 1.8(iii) yields:
X
∆(X; Y ) = 1 − min(Pr[X = v], Pr[Y = v])
v∈S∪T
X 1 1
= 1− min ,
|S| |T |
v∈S∩T
|S ∩ T |
= 1− ,
max(|S|, |T |)
hence
AdvD (Xi , Yi )
= Pr[D(Xi ) = 1] − Pr[D(Yi ) = 1]
1 1
= 2 Pr[D(Xi ) = 0] − Pr[D(Yi ) = 0] + 2 Pr[D(Xi ) = 1] − Pr[D(Yi ) = 1]
= ∆(D(Xi ); D(Yi )).
1.3.2 The point is that ∆(D(Xi ); D(Yi )) ≤ ∆(Xi ; Yi ) for any deterministic Boolean distin-
guisher D (or even for any, possibly noncomputable, Boolean function D), as follows directly
from Exercise 1.2.6. Equality holds when the distinguisher is such that D(v) = 1 if and only
if Pr[Xi = v] > Pr[Yi = v].
The same bound holds if D is any p.p.t. algorithm, since any probabilistic algorithm can
be viewed as a deterministic algorithm (function) if its random coin tosses are viewed as an
additional input—uniformly distributed and independent of anything else. So, in general, we
have, where DU (Z) denotes a p.p.t. algorithm D using uniformly random bit string U (of
polynomial length) applied to input Z:
The inequality holds on account of Exercise 1.2.6. The equality holds because ∆(R; S) = 0,
noting that R and Xi are independent as well as S and Yi .
1.3.3
P
∆(X; Y ′ ) = 1
Pr[X = (g x , g y , g z )] − Pr[Y ′ = (g x , g y , g z )]
2 Px,y,z∈Zn
= 1
2 x,y,z∈Zn ,z=xy Pr[X = (g x , g y , g z )] − Pr[Y ′ = (g x , g y , g z )]
x y z ′ x y z
P
+ x,y,z∈Zn ,z̸=xy Pr[X = (g , g , g )] − Pr[Y = (g , g , g )]
= 12 n2 n12 − n13 + (n3 − n2 ) 0 − n13
= 1 − 1/n.
Solutions to Exercises 99
1.3.4 (a) Any given instance I = (g x , g y ) with x ∈ Z∗n and y ∈ Zn is solved as follows:
′ ′
1. Transform I into I ′ = (g x , g y ) = ((g x )t , g y g u ) with t ∈R Z∗n and u ∈R Zn .
′ ′
2. Solve uniformly random instance I ′ yielding g x y = g xt(y+u) = g xyt+xtu .
′ ′
3. Extract the solution as g xy = (g x y )1/t /(g x )u .
′ ′
Note that I ′ = (g x , g y ) is distributed uniformly on ⟨g⟩∗ × ⟨g⟩, as required.
(b) Any given instance I = (g x , g y ) with x, y ∈ Z∗n is solved as follows:
′ ′
1. Transform I into I ′ = (g x , g y ) = ((g x )t , (g y )u ) with t, u ∈R Z∗n .
′ ′
2. Solve uniformly random instance I ′ yielding g x y = g xtyu .
′ ′
3. Extract the solution as g xy = (g x y )1/(tu) .
′ ′
Note that I ′ = (g x , g y ) is distributed uniformly on ⟨g⟩∗ × ⟨g⟩∗ , as required.
using that st ∈ Z∗n . If z = xy, then clearly the triple I ′ is uniform among all DH-triples
′ ′ ′ ′
(g x , g y , g x y ), independent of I. If z − xy ∈ Z∗n , then s, t, u are determined uniquely by
s = x′ /x, t = (z ′ − x′ y ′ )/(s(z − xy)), and u = y ′ − yt, implying that I ′ is uniform among all
′ ′ ′
triples (g x , g y , g z ) with z ′ − x′ y ′ ∈ Z∗n , independent of I as well.
More precisely, if z = xy then for any values v ∈ Z∗n and w ∈ Zn we have
1
Pr[x′ = v, y ′ = w, z ′ = vw] = .
ϕ(n)n
And if z − xy ∈ Z∗n , then
v r − vw 1
Pr[x′ = v, y ′ = w, z ′ = r] = Pr[s = ,t = , u = w − yt] = ,
x s(z − xy) (ϕ(n))2 n
for any values v ∈ Z∗n and r, w ∈ Zn with r − vw ∈ Z∗n .
(b) First note that the DDH∗∗ problem is trivial for n even, as z − xy ∈ Z∗n is not possible for
x, y, z ∈ Z∗n . Hence, all triples are of the form (g x , g y , g xy ), which can simply be randomized
uniformly by the transformation of part (a) with u = 0.
For n odd, we proceed as follows. Any given instance I = (g x , g y , g z ) with x, y, z ∈ Z∗n
′ ′ ′
is solved as in part (a), except that we try values for I ′ = (g x , g y , g z ) in step 1 until both
′ ′
g y ∈ ⟨g⟩∗ and g z ∈ ⟨g⟩∗ . On average, this takes at most n/ϕ2 (n) = O((log log n)2 ) iterations,
where ϕ2 (n) denotes the Schemmel totient function from Section 1.2.1, as we show next.
To obtain the lower bound
′ ′ ϕ2 (n)
Pr[g y ∈ ⟨g⟩∗ , g z ∈ ⟨g⟩∗ ] ≥ ,
n
100 Solutions to Exercises
we have:
′ ′
Pr[g y ∈ ⟨g⟩∗ , g z ∈ ⟨g⟩∗ ]
= Pr[y ′ ∈ Z∗n , z ′ ∈ Z∗n ]
= Pr[yt + u ∈ Z∗n , zst + xsu ∈ Z∗n ]
= Pr[x(yt + u) ∈ Z∗n , x(yt + u) + (z − xy)t ∈ Z∗n ].
1
Pr[x′ = v, y ′ = w, z ′ = vw] = ,
(ϕ(n))2
1.3.6
1.3.8 Given any instance y ∈ JN , we form y ′ = yu2 mod N with u ∈R Z∗N . Then y ′ ∈ Z∗N
and (y ′ |N ) = (y|N )(u|N )2 = (y|N ) = 1, hence y ′ ∈ JN . Moreover, y ′ is uniformly distributed
on QR N if y ∈ QR N , and otherwise y ′ is uniformly distributed on JN \ QR N . We solve the
QR problem for y ′ , telling us whether y ′ ∈ QR N , hence whether y ∈ QR N .
102 Solutions to Exercises
again using that ex ≥ 1 + x for all x ∈ R and that 1 − x ≥ e−2x for 0 ≤ x ≤ 3/4.
1.3.10 Let ∥ denote concatenation of bit strings. Define H ′ by H ′ (x) = x0 ∥ H(x), that is,
the first bit of the input is copied to the output (defining x0 = 0 if x is empty). Then, by
construction, H ′ is not partial preimage resistant as it leaks the first bit of its input.
However, H ′ inherits the preimage resistance property from H. To see why, suppose to the
contrary that H ′ is not preimage resistant, which means that given a bit string y ′ ∈ {0, 1}k+1 ,
a preimage x satisfying H ′ (x) = y ′ can be found efficiently (with a certain success probability).
Then, given a bit string y ∈ {0, 1}k , we can use this fact to find a preimage of H ′ for bit
strings 0 ∥ y and/or 1 ∥ y. By construction, such a preimage x will satisfy H(x) = y, hence
contradicting the preimage resistance of H.
1.3.11 First note that x ̸= x′ necessarily holds if H(x) = H(x′ ). And also H(x′ ) = H(x),
hence these “complementing” pairs (x, x′ ) can be thought of as unordered pairs of distinct
values (similar to collisions).
Consider t hash queries on distinct inputs x1 , . . . , xt . Let E denote the event that at least
one complementing pair of hash values is present among H(x1 ), . . . , H(xt ). Writing m = 2k ,
we have, similar to the probability of at least one collision occurring:
This upper bound follows by counting the number of ways one gets no complementing pairs
among H(x1 ), . . . , H(xt ). We observe that this number is at least m(m − 1)(m − 2) · · · (m −
t + 1), since there are m possibilities for H(x1 ), leaving m − 1 possibilities for H(x2 ), then
leaving at least m − 2 possibilities for H(x3 ) (if H(x1 ) = H(x2 ), there would even be m − 1
possibilities left for H(x3 )), and so on.
From the proof of Proposition 1.19(iii) we conclude that Pr[E] ≤ t2 /2k .
2.1.1 For xA , xB ∈R Z∗n , the value of xA xB is also uniformly distributed on Z∗n , hence any
possible value for the secret key K is equally likely.
Solutions to Exercises 103
For x′A , x′B ∈R Zn , we have that Pr[x′A x′B = 0] = (2n − 1)/n2 , hence x′A x′B is not uniformly
distributed on Zn . The value K ′ = 1 is more likely than other values for K ′ . However, if n is
large, the event x′A x′B = 0 occurs with negligible probability only.
Phrased differently, there is no noticeable difference between keys generated in either way,
as the statistical distance between K and K ′ is negligible for large n:
using Proposition 1.8(i) and noting that Pr[K ′ = v] > Pr[K = v] holds only for v = 1. In
other words, K and K ′ are statistically indistinguishable, cf. Definition 1.13.
2.1.2 Recall that the DDH assumption says that it should be hard to decide whether z ≡ xy
(mod n) given g x , g y , g z . The reasoning in the text for the case that n is even, hence 2 | n,
shows that we get some partial information on x, y, z as we are able to determine these values
modulo 2. Therefore, we may check whether z ≡ xy (mod 2) holds. If this is not the case,
then we know for sure that z ̸≡ xy (mod n).
This line of reasoning can be extended to the case of other small prime factors. For
instance, if 3 | n, then we are able to evaluate z ≡ xy (mod 3), which already gives us some
information. Note the connection with the Pohlig–Hellman algorithm for computing discrete
logs modulo small factors of the group order.
2.1.3 Assume without loss of generality that p0 ≤ p1 . Then the best strategy to guess f (u)
for a random group element u is to guess that f (u) is equal to 1, which achieves a success
probability of p1 .
Suppose an attacker E achieves Pr[E(hA , hB ) = f (K)] > p1 + ϵ, for some nonnegligible
value ϵ. Then, using the same distinguisher D as in the text, we have
Pr[D(hA , hB , u) = 1]
= Pr[E(hA , hB ) = f (u)]
= Pr[E(hA , hB ) = 0 | f (u) = 0] Pr[f (u) = 0] + Pr[E(hA , hB ) = 1 | f (u) = 1] Pr[f (u) = 1]
= Pr[E(hA , hB ) = 0] p0 + Pr[E(hA , hB ) = 1] p1
= p0 + Pr[E(hA , hB ) = 1] (p1 − p0 )
≤ p1 ,
using that p0 ≤ p1 . Hence, we get a nonnegligible difference ϵ in this case as well, contradicting
the DDH assumption.
2.1.4 Assume without loss of generality that p0 ≤ p1 , hence the best strategy to guess f (u)
for a random group element u is to guess that f (u) is equal to 1. This guess will be correct
with probability p1 .
104 Solutions to Exercises
Pr[E(hA , hB ) = f (K)]
= Pr[E(hA , hB ) = f (K) | L] Pr[L] + Pr[E(hA , hB ) = f (K) | ¬L] Pr[¬L]
≤ Pr[L] + Pr[E(hA , hB ) = f (K) | ¬L] Pr[¬L]
≤ Pr[L] + p1 (1 − Pr[L])
= p1 + p0 Pr[L].
Here, we use the fact that Pr[E(hA , hB ) = f (K) | ¬L] ≤ p1 in the random oracle model: E has
no information on K = H(g xA xB ) if it does not query H on g xA xB , so f (K) can be guessed
correctly with probability at most p1 (as K is uniformly random).
By the same argument as before we have that Pr[L] is negligible under the DH assumption,
so no p.p.t. adversary can guess f (K) nonnegligibly better than what already can be achieved
based on the a priori probabilities.
Note that this extended analysis is useful only if p0 is nonnegligible; e.g., in the extreme
case p0 = 0, any attack on the protocol is trivial.
2.1.5 See Example 2.1 for basic facts on quadratic residues (modulo p).
Let (A, B) = (g u , hu M ) be a given ElGamal ciphertext for public key h = g x . Since either
M = 1 ∈ QR p or M = g ∈ QR p , it suffices to determine the quadratic residuosity of M from
the given ciphertext (A, B).
′
The quadratic residuosity of A, B, and h can be computed directly, because Ap = 1 mod
p ⇔ A ∈ QR p , and similarly for B and h. Given the quadratic residuosities of A, B, and h,
the quadratic residuosity of M is now fixed, as M = B/Ax and h = g x :
M ∈ QR p ⇔ B ∈ QR p ⇔ (A ∈ QR p ∨ h ∈ QR p ) .
b′ = cB ⊕ bB = cAB ⊕ bA ⊕ bB = cA ⊕ bB ⊕ bA ⊕ bB = cA ⊕ bA = b.
Protocol I is secure against passive attacks under the DDH assumption. The attacker
learns hA = M xA , hAB = M xA xB , and hB = M xB from which it must find M . The connection
with the Diffie–Hellman problem can be seen by letting g = M xA xB , g x = M xA , g y = M xB ,
and g xy = M , hence with x = 1/xB and y = 1/xA .
Protocol I is not secure against active attacks. If A and B want to run the protocol, an
attacker may first impersonate B, using its own value for xB . Once the attacker knows M , the
attacker may run the protocol once more, now impersonating A, using its own value for xA ,
Solutions to Exercises 105
sending M (or any modified plaintext) to B. Hence, the attacker learns M and may modify
M arbitrarily.
Protocol II is not secure against passive attacks. The attacker recovers b by xor-ing the
messages cA , cAB , and cB :
Clearly, protocol II is therefore not secure against active attacks either, as passive attacks are
subsumed by active attacks.
3.2.1 The same reasoning applies as in the case x ∈ {0, 1}, except that for showing that
commit1 is computationally binding we need a more general argument. Suppose it is fea-
sible to find u, u′ , x, x′ ∈ Zn with x ̸= x′ (i.e., x ̸≡ x′ mod n) such that commit1 (u, x) =
′ ′ ′ ′
commit1 (u′ , x′ ). This means that g u hx = g u hx , or equivalently g u−u = hx −x . Hence,
logg h = (u − u′ )/(x′ − x), which is a well-defined because x ̸= x′ . Since u, u′ , x, x′ are all
known, it follows that the discrete log of h with respect to g can be computed, contradicting
the DL assumption.
3.2.2 Since scheme commit1 is information-theoretically hiding, the value of the committed
bit x is hidden even if the receiver knows logg h.
For scheme commit2 , the receiver is able to compute the value of hx = B/Alogg h , where
(A, B) = commit2 (u, x). If x ∈ {0, 1}, then hx ∈ {1, h} and the value of x is easily determined.
Hence, scheme commit2 is not hiding anymore if the receiver knows logg h. (If x ∈ Zn and no
additional information on x is known, then computing x from hx will be hard under the DL
assumption.)
′
3.2.3 This scheme is not useful as it is not binding. Let x′ = xg u , for arbitrary u′ ∈ Zn .
′
Then commit(u, x) = g u x = g u−u x′ = commit(u − u′ , x′ ). So, commitment commit(u, x)
′
can be opened as a commitment to any value x′ with x′ = xg u . The scheme is information-
theoretically hiding though.
3.3.1 Note that x = 0 if and only if commit(u, x) is a quadratic residue modulo N . Therefore,
the scheme is information-theoretically binding and computationally hiding (similar to the
ElGamal-like scheme). The homomorphic property for this scheme is given by
′
commit(u, x) commit(u′ , x′ ) = commit(uu′ y ⌊(x+x )/2⌋ , x ⊕ x′ ) mod N,
hence the product of two commitments is a commitment to the xor of the committed bits.
′
The correction factor y ⌊(x+x )/2⌋ is needed because x ⊕ x′ = (x + x′ ) mod 2:
′ ′ ′
u2 y x u′2 y x = (uu′ y ⌊(x+x )/2⌋ )2 y (x+x ) mod 2 mod N,
4.4.1 With regard to eavesdropping attacks, the situation is exactly the same as for the orig-
inal protocol: the encryption scheme must withstand known-plaintext attacks. With regard
to cheating verifier attacks, the encryption scheme must now withstand adaptive chosen-
ciphertext attacks.
106 Solutions to Exercises
g r = g cu+x = (g u )c g x = ac h.
For special soundness, let (a; c; r) and (a; c′ ; r′ ) be two accepting conversations, with c ̸= c′ .
Then we have:
′ ′
g r = ac h, g r = ac h
′ ′ ′ ′ ′
⇒ g rc = acc hc , g r c = ac c hc
′ ′ ′
⇒ g rc −r c = hc −c
rc′ −r ′ c
⇔ h=g c′ −c ,
5.1.2 Completeness is easily checked. For special soundness, let (a; c; r) and (a; c′ ; r′ ) be two
accepting conversations, with c ̸= c′ . If a ̸= 1, the same argument as before applies. If a = 1,
we note that g r = 1c h = h, so the witness can be extracted as x = r.
For honest-verifier zero-knowledgeness, the conversations with an honest verifier are dis-
tributed as follows:
{(a; c; r) : u ∈R Zn ; c ∈R Zn ; a ← g u ; r ←n cu + x}.
So, r = x exactly when cu = 0, which happens with probability (2n − 1)/n2 . To simulate this
we will now pick two values at random to increase the chances of finding x. The simulated
conversations then become:
a ← g t ; c ← 0; r ← s, if g s = h
a ← 1; c ←n s − t; r ← t, t
(a; c; r) : s, t ∈R Zn ; else if g = h .
∗ r 1/c
c ∈R Zn ; r ← s; a ← (g /h) , otherwise
Both distributions contain the same conversations, each of which occurs with probability
1/n2 . In particular, c = 0 occurs with probability 1/n, in both cases, and a = 1 occurs with
probability 1/n, in both cases too.
Solutions to Exercises 107
ρ G1 = υ G1 = H.
ρ G1 = H, ρ ′ G0 = H
⇒ ρ G1 = ρ′ G0
⇔ G1 = (ρ−1 ◦ ρ′ ) G0 .
{(H; c; ρ) : υ ∈R SX ; H ← υ G1 ; ρ ← υ ◦ π 1−c },
{(H; c; ρ) : ρ ∈R SX ; H ← ρ Gc }.
These distributions are identical, each conversation occurring with probability 1/|SX | =
1/|X|!, provided graphs G0 and G1 are isomorphic; otherwise, the simulated conversations
are in any case accepting, as required by Definition 5.1. Note that if G0 and G1 are not
isomorphic the distributions are still identical for c = 1, but for c = 0 the distributions are
in fact disjoint: H is isomorphic to G1 in the real conversations, whereas H is isomorphic to
Gc = G0 in the simulated conversations.
5.1.4 (i) The receiver checks if φ(v; a; c; r) holds, which will succeed because conversa-
tions (a; c; r) produced by S are accepting, as these conversations are distributed identi-
cally to conversations between honest prover and verifier due to special honest-verifier zero-
knowledgeness, and these are in turn accepting due to completeness.
(ii) If the sender would be able to successfully open a commitment a in two ways by
sending either c, r or c′ , r′ for different committed values c ̸= c′ , we have two accepting
conversations (a; c; r) and (a; c′ ; r′ ) with c ̸= c′ . Due to special soundness, we then efficiently
obtain a witness w such that (v; w) ∈ R. But this is assumed hard for relation R, hence the
commitment scheme is computationally binding.
(iii) Due to special honest-verifier zero-knowledgeness, conversations (a; c; r) ← S(v; c)
are distributed identically to the conversations between honest prover and verifier in the
Σ-protocol. By construction, announcement a ← α(v; w; uP ) is generated independently
from challenge c in the Σ-protocol. Therefore, a is statistically independent from c, and the
commitment scheme is information-theoretically hiding.
5.2.1 Cf. proof of Proposition 5.5. Let (a1 , a2 ; c1 , c2 ; r1 , r2 ) and (a1 , a2 ; c′1 , c′2 ; r1′ , r2′ ) be
accepting conversations and assume that (c1 , c2 ) ̸= (c′1 , c′2 ). Then c1 ̸= c′1 and/or c2 ̸= c′2 .
If c1 ̸= c′1 , it follows that x1 = (r1 − r1′ )/(c1 − c′1 ). And if c2 ̸= c′2 , we have that x2 =
(r2 − r2′ )/(c2 − c′2 ).
108 Solutions to Exercises
So, only if both c1 ̸= c′1 and c2 ̸= c′2 hold, we get witness (x1 , x2 ). If (c1 , c2 ) ̸= (c′1 , c′2 )
it is possible that c1 = c′1 or that c2 = c′2 , in which case one of x1 and x2 cannot be
obtained. Indeed, suppose a cheating prover P ∗ knows only x1 = logg h1 . Then P ∗ may act
∗ −c∗
as follows: pick u1 , c∗2 , r2∗ ∈ Zn , and send a1 = g u1 and a2 = g r2 h2 2 to the verifier. Now
all challenges (c1 , c2 ) ∈ Zn × Zn with c2 = c∗2 can be handled successfully by replying with
r1 = u1 + c1 x1 mod n and r2 = r2∗ . The number of challenges with c2 = c∗2 is equal to n out
of n2 , hence the success probability of P ∗ is 1/n (which is still negligibly small). However,
for special soundness to hold, a cheating prover—not knowing a full witness—should be able
to reply successfully to one challenge only!
More precisely, one reasons as follows. Suppose that parallel composition of two Schnorr
protocols for proving knowledge of logg h1 and logg h2 , respectively, is special sound. Then
we can use the p.p.t. extractor E to solve any given instance h = g x of the DL problem as
follows. Pick x1 ∈R Zn , and set h1 = g x1 and h2 = h. Compute two accepting conversations
with identical announcements but different challenges, as above, and feed these into E. Fi-
nally, extractor E will output the witness (x1 , x2 ), hence by setting x = x2 we find logg h,
contradicting the DL assumption.
To circumvent this problem, AND-composition uses a single challenge c = c1 = c2 .
{(a; c; r) : u ∈R Zn ; a ← g u ; r ←n u + cx1 + c2 x2 },
2
{(a; c; r) : r ∈R Zn ; a ← g r h−c −c
1 h2 }.
These distributions are identical, each conversation occurring with probability 1/n.
(ii) Special soundness cannot hold for this protocol because knowing only x1 = logg h1 one can
compute two accepting conversations (a; c; r), (a; c′ ; r′ ) with c ̸= c′ as follows. Pick c ∈R Z∗n
−c2
and r ∈R Zn , and set a = g r h−c ′
1 h2 . Clearly, (a; c; r) is accepting. Now set c = −c (hence
′ ′ ′ ′
c ̸= c because c ̸= 0) and r = r − 2cx1 to make (a; c ; r ) accepting as well:
′ 2 ′ ′2
g r = g r−2cx1 = ahc1 hc2 (g x1 )−2c = ahc1 hc2 .
(iii) Given accepting (a; c; r), (a; c′ ; r′ ), (a; c′′ ; r′′ ) with c ̸= c′ , c ̸= c′′ , c′ ̸= c′′ . Then
2 ′ ′ ′2 ′′ ′′ ′′2
g r = ahc1 hc2 , g r = ahc1 hc2 , g r = ahc1 hc2
implies
′ ′ 2 ′2 ′ ′
g r−r = hc−c
1 hc2 −c = (h1 h2c+c )c−c
′ ′′ ′ ′′ ′2 ′′2 ′ ′′ ′ ′′
g r −r = hc1 −c hc2 −c = (h1 hc2 +c )c −c .
Hence, witness (x1 , x2 ) is obtained as:
′
r′ −r′′
x2 = r−rc−c′ − c′ −c′′ /(c − c′′ )
r−r′
x1 = c−c′ − x2 (c + c′ ).
Solutions to Exercises 109
Prover Verifier
a1 , a2
a2 ← g r2 h−c 2
2
a2 ← g u2 −−−−−−− →−
c ∈R Zn
c
−−−−−−
←
c1 ←n c − c2 c2 ←n c − c1
c1 , r1 , r2
r1 ←n u1 + c1 x1 r2 ←n u2 + c2 x2 −
−−−−−→ −− c2 ←n c − c1
?
g r1 = a1 hc11
?
g r2 = a2 hc22
5.2.3 The optimized protocol is shown in Figure S.1. To show completeness, consider the
case that the prover uses x1 . Then we have c2 = c − c1 both for the prover and the verifier.
Also, by inspection of the protocol,
If c1 ̸= c′1 , we obtain witness x1 = (r1 − r1′ )/(c1 − c′1 ) satisfying h1 = g x1 ; otherwise c2 ̸= c′2 ,
and we obtain witness x2 = (r2 − r2′ )/(c2 − c′2 ) satisfying h2 = g x2 . So, we either obtain a
correct witness x1 or a correct witness x2 (or both).
Finally, we show that special honest-verifier zero-knowledgeness holds. The honest-verifier
and simulated distributions are, respectively (again considering the case of a prover using x1 ):
{(a1 , a2 ; c; c1 , r1 , r2 ) : u1 , c2 , r2 ∈R Zn ; a1 ← g u1 ; a2 ← g r2 h−c
2 ; c1 ←n c − c2 ;
2
r1 ←n u1 + c1 x1 },
{(a1 , a2 ; c; c1 , r1 , r2 ) : c1 , r1 , r2 ∈R Zn ; c2 ←n c − c1 ; a1 ← g r1 h−c r2 −c2
1 ; a2 ← g h2 },
1
for any given challenge c. These distributions are identical (uniform distribution on all ac-
cepting conversations, each one occurring with a probability of 1/n3 ).
5.3.1 To show completeness, we assume that the prover knows a witness (x, y, z) satisfying
(A, B; x, y, z) ∈ R. Let us consider the case x = 0 (case x = 1 is similar), hence A = hy and
110 Solutions to Exercises
B = hz holds. Clearly, if the prover follows the protocol, then c0 + c1 = c. Also, the fact
that hr1 = a1A (A/g)c1 and g r1 = a1B B c1 hold follows directly from the way a1A and a1B are
computed, respectively. Finally, for the remaining two verification equations we have:
and
′ ′ ′ ′ ′ ′ ′ ′
c′ = c′0 + c′1 , hr0A = a0A Ac0 , hr0B = a0B B c0 , hr1 = a1A (A/g)c1 , g r1 = a1B B c1 .
Hence,
′ ′ ′ ′ ′ ′ ′ ′
hr0A −r0A = Ac0 −c0 , hr0B −r0B = B c0 −c0 , hr1 −r1 = (A/g)c1 −c1 , g r1 −r1 = B c1 −c1 .
Since c ̸= c′ , it must be the case that c0 ̸= c′0 or c1 ̸= c′1 (or both). If c0 ̸= c′0 , we set
′
r0A − r0A ′
r0B − r0B
x = 0, y = , z = .
c0 − c′0 c0 − c′0
Otherwise, c1 ̸= c′1 , and we set
r1 − r1′
x = 1, y = .
c1 − c′1
In both cases we have that A = g x hy ∧ B = g xy h(1−x)z holds, and it follows that indeed
(A, B; x, y, z) ∈ R.
To show special honest-verifier zero-knowledgeness, let c be any given challenge. The
honest-verifier distributions for the cases x = 0 and x = 1 are, respectively:
{(a0A , a0B , a1A , a1B ; c; c0 , c1 , r0A , r0B , r1 ) : c1 , u0A , u0B , r1 ∈R Zn ;
a0A ← hu0A ; a0B ← hu0B ; a1A ← hr1 (A/g)−c1 ; a1B ← g r1 B −c1 ;
c0 ←n c − c1 ; r0A ←n u0A + c0 y; r0B ←n u0B + c0 z},
{(a0A , a0B , a1A , a1B ; c; c0 , c1 , r0A , r0B , r1 ) : c0 , r0A , r0B , u1 ∈R Zn ;
a0A ← hr0A A−c0 ; a0B ← hr0B B −c0 ; a1A ← hu1 ; a1B ← g u1 ;
c1 ←n c − c0 ; r1 ←n u1 + c1 y},
The simulated distribution is given by
{(a0A , a0B , a1A , a1B ; c; c0 , c1 , r0A , r0B , r1 ) : c0 , r0A , r0B , r1 ∈R Zn ;
c1 ←n c − c0 ;
a0A ← h A ; a0B ← h B ; a1A ← h (A/g) ; a1B ← g r1 B −c1 }.
r0A −c 0 r0B −c 0 r 1 −c 1
These three distributions can be seen to be identical with each conversation occurring with
probability exactly 1/n4 .
5.3.2
(a) The protocol in Figure S.2 proves knowledge of x, y such that B = g x hy , for given B.
Solutions to Exercises 111
Prover Verifier
u, v ∈R Zn
a ← g u hv
a
−−−−−−−−−→
−
c ∈R Zn
c
−−−−−−−−−−
←
r ←n u + cx
s ←n v + cy
r, s
−−−−−−−−−−
→
?
g r hs = aB c
Completeness. Clearly,
g r hs = g u+cx hv+cy = g u hv (g x hy )c = aB c .
Completeness. Clearly,
(gh)r = (gh)u+cx = (gh)u ((gh)x )c = aB c .
112 Solutions to Exercises
Prover Verifier
u ∈R Zn
a ← (gh)u
a
−−−−−−−−−→
−
c ∈R Zn
c
−−−−−−−−−−
←
r ←n u + cx
r
−−−−−−−−−→
−
?
(gh)r = aB c
Prover Verifier
u ∈R Zn
a ← (hα /g β )u
a
−−−−−−−−−→
−
c ∈R Zn
c
←
−−−−−−−−−−
r ←n u + cy
r
−−−−−−−−−→
−
?
(hα /g β )r = a(B α /g γ )c
(c) The protocol in Figure S.4 proves knowledge of x, y such that B = g x hy with αx+βy = γ,
for given α ∈ Z∗n , β, γ ∈ Zn and given B. Note that ψ(x, y) ≡ x = y corresponds to the
case α = 1, β = −1, γ = 0. We eliminate x by using the equation x = (γ − βy)/α.
This time hα /g β ̸= 1 can be assumed (hence that it is a generator as well), because
otherwise we would know that logg h = β/α.
Prover Verifier
ux , cx , rx ∈R Zn
ax ← hux
ax ← hrx (B/g x )−cx
a0 , a1
−−−−−−−−−− →
c ∈R Zn
c
−−−−−−−−−−
←
cx ←n c − cx
rx ←n ux + cx y
c0 , c1 , r0 , r1
−−−−−−−−−→ −
?
c0 + c1 =n c
?
hr0 = a0 B c0
?
hr1 = a1 (B/g)c1
It follows from c ̸= c′ that c0 ̸= c′0 or c1 ̸= c′1 (or both). If c0 ̸= c′0 , then a witness
is obtained as x = 0 and y = (r0 − r0′ )/(c0 − c′0 ). Otherwise c1 ̸= c′1 , and a witness is
obtained as x = 1 and y = (r1 − r1′ )/(c1 − c′1 ).
Prover Verifier
(yi ∈R Zn )ℓ−1 i=1
y0 ←n y − ℓ−1 i
P
i=1 yi 2
ℓ−1
B i ← g xi h yi
uxi ,i , cxi ,i , rxi ,i ∈R Zn
axi ,i ← huxi ,i
axi ,i ← hrxi ,i (Bi /g xi )−cxi ,i i=0
(Bi , a0,i , a1,i )ℓ−1
i=0
−−−−−−−−−−−−− →
−
c ∈R Zn
c
ℓ−1 −−−−−− −−−−−−
←
cxi ,i ←n c − cxi ,i
rxi ,i ←n uxi ,i + cxi ,i yi i=0
(c0,i , r0,i , r1,i )ℓ−1
i=0
−−−−−−−−−−−−− →
−
Qℓ−1 i ?
i=0Bi2 = B
ℓ−1
c1,i ←n c − c0,i
r0,i ? c
h = a0,i Bi 0,i
r ? c
h 1,i = a1,i (Bi /g) 1,i
i=0
Furthermore, we have for any i, 0 ≤ i < ℓ, that xi ∈ {0, 1}, hence that cxi ,i + cxi ,i = c is
equivalent to c0,i + c1,i = c, and that
Special soundness. For accepting conversations ((Bi , a0,i , a1,i )ℓ−1 ℓ−1
i=0 ; c; (c0,i , r0,i , r1,i )i=0 )
ℓ−1 ′ ′ ′ ′ ℓ−1 ′
and ((Bi , a0,i , a1,i )i=0 ; c ; (c0,i , r0,i , r1,i )i=0 ) with c ̸= c , we reason as follows.
For each i, 0 ≤ i < ℓ, put c1,i = c − c0,i and c′1,i = c′ − c′0,i . It follows from c ̸= c′ that
c0,i ̸= c′0,i or c1,i ̸= c′1,i (or both).
If c0,i ̸= c′0,i , then we have:
c ′ c′
hr0,i = a0,i Bi 0,i , hr0,i = a0,i Bi 0,i
′ c0,i −c′0,i
⇒ hr0,i −r0,i = Bi ,
116 Solutions to Exercises
Prover Verifier
u, v ∈R Zn
a ← B u hv
a
−−−−−−−−−→
−
c ∈R Zn
c
−−−−−−−−−−
←
r ←n u + c/x
s ←n v − cy/x
r, s
−−−−−−−−−−
→
?
B r hs = ag c
′ )/(c
hence we set xi = 0 and yi = (r0,i − r0,i ′
0,i − c0,i ).
′ )/(c
and we set xi = 1 and yi = (r1,i − r1,i ′
1,i − c1,i ).
(f) The protocol in Figure S.7 proves knowledge of x, y such that B = g x hy with x ̸= 0, for
given B. Similar to Eq. (5.1) in NEQ-composition, we rewrite B = g x hy as g = B 1/x h−y/x ,
which is possible only if x ̸= 0. Next, we let the prover use Okamoto’s protocol to show
that it can write g as a product of powers of B and h, where the prover knows the
exponents.
Solutions to Exercises 117
Prover Verifier
u, v ∈R Zn
a ← B u (gh)v
a
−−−−−−−−−→
−
c ∈R Zn
c
−−−−−−−−−−
←
r ←n u + c/(x − y)
s ←n v + cy/(y − x)
r, s
−−−−−−−−−−
→
?
B r (gh)s = ag c
Prover Verifier
u, v ∈R Zn
a ← (B α /g γ )u (hα /g β )v
a
−−−−−−−−−→
−
c ∈R Zn
c
−−−−−−−−−−
←
r ←n u + c/(αx + βy − γ)
s ←n v − cy/(αx + βy − γ)
r, s
−−−−−−−−−−
→
?
(B α /g γ )r (hα /g β )s = ag c
(h) The protocol in Figure S.9 proves knowledge of x, y such that B = g x hy with αx+βy ̸= γ,
for given B. Let δ = αx + βy − γ, hence δ ̸= 0. Similar to Eq. (5.1) in NEQ-composition,
we rewrite B = g x hy as g = (B α /g γ )1/δ (hα /g β )−y/δ , which is possible only if δ ̸= 0.
Next, we let the prover use Okamoto’s protocol to show that it can write g as a product
of powers of B α /g γ and hα /g β , where the prover knows the exponents.
As in part(c), hα /g β can again be assumed to be a generator.
Prover Verifier
u, v, w ∈R Zn
a ← g u hv
b ← B v hw
a, b
−−−−−−−−−−
→
c ∈R Zn
c
−−−−−−−−−−
←
r ←n u + cx
s ←n v + cy
t ←n w − cy 2
r, s, t
−−−−−−−−− →
?
g r hs = aB c
?
B s ht = bg c
Completeness. We have:
g r hs = g u+cx hv+cy = g u hv (g x hy )c = aB c ,
2 2
B s ht = B v+cy hw−cy = B v hw (B y h−y )c = b(g xy )c = bg c ,
using that xy = 1.
120 Solutions to Exercises
Prover Verifier
z, u, v, w ∈R Zn
A ← g χ hz
a ← g u hv
b ← Au hw
A, a, b
−−−−−−−−−→ −
c ∈R Zn
c
−−−−−−−−−−
←
r ←n u + cχ
s ←n v + cz
t ←n w + c(y − zχ)
r, s, t
−−−−−−−−− →
?
g r hs = aAc
?
Ar ht = bB c
{(a, b; c; r, s, t) : u, v, w ∈R Zn ; a ← g u hv ; b ← B v hw ;
r ←n u + cx; s ←n v + cy; t ←n w − cy 2 },
{(a, b; c; r, s, t) : r, s, t ∈R Zn ; a ← g r hs B −c ; b ← B s ht g −c }.
These distributions can be seen to be identical for any B satisfying ∃x∈Z∗n B = g x h1/x ,
cf. Definition 5.1; for the remaining B, the simulated conversations are accepting, as
required.
(j) The protocol in Figure S.11 proves knowledge of x, y such that B = g x hy and there exists
a χ ∈ Zn such that x = χ2 . In other words, x is quadratic residue modulo n. Let χ
denote a square root of x modulo n.
Solutions to Exercises 121
Prover Verifier
Completeness. We have:
g r hs = g u+cχ hv+cz = g u hv (g χ hz )c = aAc ,
2
Ar ht = Au+cχ hw+c(y−zχ) = Au hw (Aχ hy−zχ )c = b(g χ hzχ hy−zχ )c = bB c .
c1 + c2 = c − c2 + c2 = c,
If c1 ̸= c′1 , we obtain x = (r1 − r1′ )/(c1 − c′1 ) satisfying B = (gh)x and we set y = x;
otherwise c2 ̸= c′2 , and we obtain x = (r2 − r2′ )/(c2 − c′2 ) satisfying B = (g/h)x and we
set y = −x. So, in any case we obtain a witness (x, y) satisfying B = g x hy and x2 = y 2
as required.
5.3.3 It is left to the reader to verify that the protocol is complete and special sound. How-
ever, the protocol is not honest-verifier zero-knowledge (hence, certainly not special honest-
verifier zero-knowledge). When interacting with an honest verifier, the protocol leaks the
value of g1x1 = (g1r1 /a1 )1/c (for c ̸= 0), and hence the value of g2x2 = h/g1x1 as well. One
cannot compute these values given only h = g1x1 g2x2 (the value of the pair (x1 , x2 ) is not even
determined by h). Therefore, the protocol cannot be simulated given just h.
5.3.4
(a) The protocol in Figure S.13 proves knowledge of x, y, z such that A = g x hy , B = g 1/x hz ,
hence that B is a Pedersen commitment to the (multiplicative) inverse of the committed
value in the Pedersen commitment A. The protocol is based on the fact that B x = ghzx ,
hence that g can be written as g = B x h−zx . Since A = g x hy as well, we apply EQ-
composition for exponent x.
Solutions to Exercises 123
Prover Verifier
u, v, w ∈R Zn
a ← g u hv
a, b
b ← B u hw −−−−−−−−−−
→
c c ∈R Zn
−−−−−−−−−−
←
r ←n u + cx
s ←n v + cy
r, s, t r s ? c
t ←n w − czx −−−−−−−−− → g h = aA
?
B r ht = bg c
Prover Verifier
u1 , u2 , v1 , v2 , v3 ∈R Zn
a1 ← g u1 hv1
a2 ← g u2 hv2
a1 , a2 , b
b ← Au1 2 hv3 −−−−−−−−−−− →
r1 ←n u1 + cx1 c c ∈R Zn
−−−−−−−−−−−−
←
r2 ←n u2 + cx2
s1 ←n v1 + cy1
s2 ←n v2 + cy2
r1 , r2 , s1 , s2 , s3 r1 s1 ? c
s3 ←n v3 + c(z − y1 x2 ) −
−−−−−−−−−−→ −− g h = a1 A1
?
g r2 hs2 = a2 Ac2
?
Ar12 hs3 = bB c
Completeness. We have:
{(a1 , a2 , b; c; r1 , r2 , s1 , s2 , s3 ) : u1 , u2 , v1 , v2 , v3 ∈R Zn ;
a1 ← g u1 hv1 ; a2 ← g u2 hv2 ; b ← Au1 2 hv3 ;
r1 ←n u1 + cx1 ; r2 ←n u2 + cx2 ;
s1 ←n v1 + cy1 ; s2 ←n v2 + cy2 ; s3 ←n v3 + c(z − y1 x2 )},
{(a1 , a2 , b; c; r1 , r2 , s1 , s2 , s3 ) : r1 , r2 , s1 , s2 , s3 ∈R Zn ;
a1 ← g r1 hs1 A−c r2 s2 −c
1 ; a2 ← g h A2 ; b ← A1 h B }.
r2 s3 −c
These distributions are identical (each conversation occurs exactly with probability 1/n5 ).
5.3.5 The prover knows a witness x1 , y1 , . . . , xℓ , yℓ , which consists of a truth assignment for
Φ with v1 := x1 ,. . . ,vℓ := xℓ satisfying ∀ℓk=1 Bk = g xk hyk , xk ∈ {0, 1}. Noting that the latter
part is easily dealt with by using ℓ instances of the Σ-protocol of Exercise 5.3.2(d), we focus
on showing that Φ(x1 , . . . , xℓ ) holds.
For each literal li,j , we define xi,j = xk , yi,j = yk , if li,j = vk , and xi,j = 1 − xk , yi,j = −yk ,
if li,j = vk . Then, writing x bi = xi,1 + xi,2 + xi,3 , we see that the ith clause li,1 ∨ li,2 ∨ li,3
evaluates to true if and only if x bi ̸= 0.
This immediately leads to the protocol of Figure S.15, writing also ybi = yi,1 +yi,2 +yi,3 and
Bi = g xbi hybi . In addition to proving for each variable vk that Bk = g xk hyk , with xk ∈ {0, 1},
b
it is proved for each clause li,1 ∨ li,2 ∨ li,3 that B bi = g xbi hybi , with x bi ̸= 0, using m instances of
the Σ-protocol of Exercise 5.3.2(f). Note that Bi can be computed by the verifier as follows:
b
let Bi,j = Bk , if li,j = vk , and Bi,j = g/Bk , if li,j = vk , and set B bi = Bi,1 Bi,2 Bi,3 .
It is easily seen that completeness holds by construction.
To show special soundness, let ((ak,0 , ak,1 )ℓk=1 , (ai )m ℓ m
i=1 ; c; (ck,0 , rk,0 , rk,1 )k=1 , (ri , si )i=1 ) and
ℓ m ′ ′ ′ ′ ℓ ′ ′ m
((ak,0 , ak,1 )k=1 , (ai )i=1 ; c ; (ck,0 , rk,0 , rk,1 )k=1 , (ri , si )i=1 ) be two accepting conversations with
c ̸= c′ . As in Exercise 5.3.2(d), we can extract from accepting (ak,0 , ak,1 ; c; ck,0 , rk,0 , rk,1 )
and (ak,0 , ak,1 ; c′ ; c′k,0 , rk,0
′ , r ′ ) values x , y satisfying B = g xk hyk and x ∈ {0, 1}, for each
k,1 k k k k
k = 1, . . . , ℓ. (As an aside, we note that these witnesses must be unique: we cannot have
witnesses xk = 0, yk and x′k = 1, yk′ for Bk because then one also knows logg h, which is
assumed to be unknown to anyone.) Similarly, for each i = 1, . . . , m, we can extract (cf.
Exercise 5.3.2(f)) from accepting ((ai )m m m ′ ′ ′ m
i=1 ; c; (ri , si )i=1 ) and ((ai )i=1 ; c ; (ri , si )i=1 ) values x bi , ybi
satisfying B x
b y
bi = g i h i and xbi ̸= 0, using the assumption that logg h is unknown to anyone.
b
(ai ← B b ri hsi g −c )m }.
i i=1
These simulated conversations are identically distributed to the conversations with an honest
verifier (uniform with probability 1/n3ℓ+2m for each conversation) provided Φ is satisfiable,
cf. Definition 5.1; otherwise, the simulated conversations are accepting, as required.
126 Solutions to Exercises
Prover Verifier
ℓ
uk,xk , ck,xk , rk,xk ∈R Zn
ak,x ← huk,xk
k
rk,xk x −ck,xk
ak,xk ← h (Bk /g ) k
k=1
m
ui , vi ∈R Zn
ai ← B b ui hvi
i i=1
(ak,0 , ak,1 )ℓk=1 , (ai )m
i=1
−−−−−−−−−−−−−−−−− →−
c ∈R Zn
c
←
−−−−−−−−−−−−−−−−−−
ℓ
ck,xk ←n c − ck,xk
rk,xk ←n uk,xk + ck,xk yk k=1
m
ri ←n ui + c/b
xi
si ←n vi − cb
yi /b
xi i=1
(ck,0 , rk,0 , rk,1 )ℓk=1 ,
(ri , si )m
i=1
−−−−−−−−−−−−−−−−− →− !ℓ
? c
hrk,0 = ak,0 Bkk,0
?
hrk,1 = ak,1 (Bk /g)c−ck,0 k=1
m
?
b r i hs i =
B i ai g c
i=1
′
FIGURE S.15: Σ-protocol for R3SAT
Note that the more straightforward approach of using a 3-way OR-composition for each
clause leads to a less efficient and more complicated Σ-protocol for R3SAT ′ . Moreover, the
protocol of Figure S.15 can be extended—almost for free—to handle general Boolean formulas
Φ with a variable number of literals per clause: the only difference is that the time to compute
x
bi , ybi , and B
bi will depend on the number of literals of the ith clause.
5.3.6 The idea is to extend the Σ-protocol of the previous exercise as follows. The prover gen-
erates y1 , . . . , yℓ ∈R Zn and then computes the Pedersen commitments B1 = g x1 hy1 ,. . . ,Bℓ =
g xℓ hyℓ using its witnesses x1 , . . . , xℓ . The commitments B1 , . . . , Bℓ are prepended to the
announcement shown in Figure S.15. The challenge and response remain unchanged.
The resulting Σ-protocol can be proved correct as before. To generate the simulated
conversations we simply add B1 , . . . , Bℓ ∈R ⟨g⟩ as an initial step. Each simulated conversation
will now occur with probability 1/n4ℓ+2m .
5.3.7 (i) The protocol in Figure S.16 proves knowledge of x, y, z such that A = g x hy and
n−1
B = g x hz . The protocol is obtained by OR-composition distinguishing the cases x = 0
and x ̸= 0. If x = 0, we get A = hy and B = hz , which is proved easily using two instances
of Schnorr’s protocol. If x ̸= 0, Fermat’s little theorem implies that xn−1 = 1, so we get
B/g = hz , which is proved using another instance of Schnorr’s protocol. Finally, we need to
rewrite the remaining part A = g x hy into g = A1/x h−y/x as in Exercise 5.3.2(f) and prove
Solutions to Exercises 127
Prover Verifier
(case x = 0) (case x ̸= 0)
c1 , r1 , s1 , t1 , v0 , w0 ∈R Zn c0 , s0 , t0 , u1 , v1 , w1 ∈R Zn
a0 ← hv0 a0 ← hs0 A−c0
b0 ← hw0 b0 ← ht0 B −c0
a1 ← Ar1 hs1 g −c1 a1 ← Au1 hv1
b1 ← ht1 (B/g)−c1 b1 ← hw1
a0 , a1 , b0 , b1
−−−−−−−−−−−−− →
−
c ∈R Zn
c
−−−−−−−−−−−−−−
←
c0 ←n c − c1 c1 ←n c − c0
r1 ←n u1 + c1 /x
s0 ←n v0 + c0 y s1 ←n v1 − c1 y/x
t0 ←n w0 + c0 z t1 ←n w1 + c1 z
c0 , r1 , s0 , s1 , t0 , t1
−
−−−−−−−−−−−−→ −−
c1 ←n c − c0
?
hs 0 = a 0 Ac0
?
ht0 = b0 B c0
?
Ar1 hs1 = a1 g c1
?
ht1 = b1 (B/g)c1
this using an instance of Okamoto’s protocol; this way we ensure that x ̸= 0 can actually be
concluded upon extraction of x when showing special soundness below.
Completeness. The values of c0 , c1 as used by the prover and the verifier clearly match as
n−1
c0 + c1 = c holds on both sides. Furthermore, if x = 0, we have g x = g x = 1, so
{(a0 , a1 , b0 , b1 ; c; c0 , r1 , s0 , s1 , t0 , t1 ) : c1 , r1 , s1 , t1 , v0 , w0 ∈R Zn ;
a0 ← hv0 ; b0 ← hw0 ; a1 ← Ar1 hs1 g −c1 ; b1 ← ht1 (B/g)−c1 ;
c0 ←n c − c1 ; s0 ←n v0 + c0 y; t0 ←n w0 + c0 z},
{{(a0 , a1 , b0 , b1 ; c; c0 , r1 , s0 , s1 , t0 , t1 ) : c0 , s0 , t0 , u1 , v1 , w1 ∈R Zn ;
a0 ← hs0 A−c0 ; b0 ← ht0 B −c0 ; a1 ← Au1 hv1 ; b1 ← hw1 ;
c1 ←n c − c0 ; r1 ←n u1 + c1 /x; s1 ←n v1 − c1 y/x; t1 ←n w1 + c1 z},
{(a0 , a1 , b0 , b1 ; c; c0 , r1 , s0 , s1 , t0 , t1 ) : c0 , r1 , s0 , s1 , t0 , t1 ∈R Zn ;
c1 ←n c − c0 ; a0 ← hs0 A−c0 ; b0 ← ht0 B −c0 ;
a1 ← Ar1 hs1 g −c1 ; b1 ← ht1 (B/g)−c1 }.
These distributions are all identical (each conversation occurs exactly with probability 1/n6 ).
(ii) The protocol in Figure S.17 proves knowledge of x, y, z such that A = g x hy and
n−1 n
B = g x hz . The protocol is based on the fact that B x = g x hzx = g x hzx (using Fermat’s
little theorem), which implies that A = g x hy can also be written as A = B x hy−zx . To
exploit these two equations for A, we apply EQ-composition for exponent x. As can be seen
from the proof of special soundness below, this allows us to extract a valid witness provided
x ̸= 0. To enable the extraction of z in case x = 0, however, we use an auxiliary commitment
n−2
C = g x ht , and we extend the EQ-composition for exponent x by adding B = C x hz−tx as
n−1
equation for B, which holds because C x = g x htx = Bhtx−z .
The intuition behind this solution is that C is a Pedersen commitment to the pseudoinverse
x n−2 of x, as xn−2 = 1/x if x ̸= 0 (and xn−2 = 0 if x = 0). This fits nicely with the fact that
B can be viewed as a Pedersen commitment to the value xn−1 ∈ {0, 1}, and that A can be
viewed as a Pedersen commitment to the value xn = x.
Solutions to Exercises 129
Prover Verifier
t, u, v1 , v2 , w ∈R Zn
n−2
C ← g x ht
a1 ← g u hv1
a2 ← B u hv2
C, a1 , a2 , b
b ← C u hw −−−−−−−−− →
r ←n u + cx c c ∈R Zn
−−−−−−−−−−
←
r1 ←n v1 + cy
r2 ←n v2 + c(y − zx)
r, r1 , r2 , s ?
s ←n w + c(z − tx) −−−−−−−−−− →− g r hr1 = a1 Ac
?
B r hr2 = a2 Ac
?
C r hs = bB c
n−1
Completeness. We have, using that B x = g x hzx and C x = g x htx :
g r hr1 = a1 Ac , B r hr2 = a2 Ac , C r hs = bB c
′ ′ ′ ′ ′ ′ ′ ′ ′
g r hr1 = a1 Ac , B r hr2 = a2 Ac , C r hs = bB c
′ ′ ′ ′ ′ ′ ′ ′ ′
⇒ g r−r hr1 −r1 = Ac−c , B r−r hr2 −r2 = Ac−c , C r−r hs−s = B c−c
′ ′
r−r ′ r1 −r1 r−r ′ r2 −r2 r−r ′ s−s′
⇔ A = g c−c′ h c−c′ , A = B c−c′ h c−c′ , B = C c−c′ h c−c′ .
We set x = (r − r′ )/(c − c′ ) and y = (r1 − r1′ )/(c − c′ ) such that A = g x hy . To extract z such
n−1 ′
that B = g x hz we distinguish two cases. If x ̸= 0, then xn−1 = 1. Since A = B x hy with
′ ′ ′
y ′ = (r2 − r2′ )/(c − c′ ), we have B x = Ah−y = g x hy−y . Hence, B = g 1 h(y−y )/x , so we set
z = (y −y ′ )/x in this case. If x = 0, then xn−1 = 0 as well, and we set z = (s−s′ )/(c−c′ ) such
that B = C 0 hz = g 0 hz . In both cases, witness (x, y, z) satisfies relation Rneq0 with (A, B).
These distributions are identical (each conversation occurs exactly with probability 1/n5 ).
Note that the protocol in part (i) is slightly more complicated than the protocol in part (ii)
(compare Figures S.16 and S.17). Especially, when commitment C also happens to be part of
the common input for prover and verifier (next to commitments A and B), the performance
of the second protocol will be superior.
5.4.1
(i) Completeness follows easily:
For special soundness, let (a; c; r) and (a; c′ ; r′ ) be two accepting conversations, with
c ̸= c′ . Then we have:
′ ′
g r = ac−F (a) h, g r = ac −F (a) h
′ ′
⇒ g r−r = ac−c
r−r ′
⇔ a = g c−c′ .
′
r+(F (a)−c) r−r
Then also h = g r aF (a)−c = g c−c′ , so the witness is obtained as x = r + (F (a) −
c)(r − r′ )/(c − c′ ).
As for honest-verifier zero-knowledgeness, we first note that the conversations with an
honest verifier are distributed as follows:
Note that r = x exactly when c = F (a), which we need to simulate without knowledge
of x. We can do so, however, by first generating r ∈R Zn and then decide what to do:
n u ∈ Z∗ ; a ← g u ; c ← F (a), if g r = h
R n
(a; c; r) : r ∈R Zn ; ′ .
c′ ∈R Z∗n ; a ← (g r /h)1/c ; c ←n c′ + F (a), if g r ̸= h
Both distributions contain the same conversations, each of which occurs with probability
1/n(n − 1). In particular c = F (a) (and at the same time r = x) occurs with probability
1/n, in both cases.
(ii) The noninteractive version of this protocol will set c ← H(a), where H denotes a random
oracle. By setting H = F , one sees that r = x will always hold, hence the secret value
x is leaked entirely.
5.4.2 The following forgery can be found by keeping things as simple as possible:
Prover Verifier
u1 ∈R Zn
a1 ← g u1
m
ci , ri ∈R Zn
ai ← g ri h−c
i
i
i=2
(ai )m
i=1
−−−−−−−−−− →
−
c ∈R Zn
c
−−−−−−−−−−
←
c1 ←n c − c2 − · · · − cm
r1 ←n u1 + c1 x
(ci , ri )m
i=1
−−−−−−−−−− →−
?
1 + · · · + cm =n c
c
? m
g ri = ai hci i
i=1
t1 = (c − α)(1 + t0 /α),
α2 + (t0 + t1 − c)α − t0 c = 0
About 50% of the time, this equation will have two solutions for α in Zn . Namely, when the
discriminant ∆ = (t0 + t1 − c)2 + 4t0 c is a quadratic residue modulo n. Also, β ̸∈ {0, 1} will
hold in general, hence we do not know a witness for B of the required form.
5.4.3 Without loss of generality, suppose that the prover knows x = logg h1 . As in OR-
composition, the prover will execute an instance of Schnorr’s protocol for h1 ; for the remaining
hi ’s the prover will use honest-verifier simulations. This time the challenges c1 , . . . , cm are
required to sum up to the challenge c given by the verifier. The details of the protocol are
given in Figure S.18.
Prover Verifier
u1 , u2 ∈R Zn
a11 ← g u1
a12 ← hu0 1
a11 , a12 , a2
a2 ← g u2 −−−−−−−−−→ −
c ∈R Zn
c
−−−−−−−−−−
←
r1 ←n u1 + cu
r , r2 ?
r2 ←n u2 + cx −−−−1−−− −−
→ g r1 = a11 Ac
?
hr01 = a12 (B/h1 )c
?
g r2 = a2 hc1
{((ai )m m m u1 ri −ci m
i=1 ; c; (ci , ri )i=1 ) : u1 , (ci , ri )i=2 ∈R Zn ; a1 ← g ; (ai ← g hi )i=2 ;
c1 ←n c − c2 − · · · − cm ; r1 ←n u1 + c1 x},
m−1
{((ai )m m m
i=1 ; c; (ci , ri )i=1 ) : (ci )i=1 , (ri )i=1 ∈R Zn ; cm ←n c − c1 − · · · − cm−1 ;
(ai ← g ri h−c i m
i )i=1 }.
These distributions are identical (uniform distribution on all accepting conversations, each
one occurring with a probability of 1/n2m−1 ).
Special soundness. Given accepting conversation (a11 , a12 , a2 ; c; r1 , r2 ) and accepting con-
versation (a11 , a12 , a2 ; c′ ; r1′ , r2′ ) with c ̸= c′ , we have:
(
g r1 = a11 Ac , hr01 = a12 (B/h1 )c , g r2 = a2 hc1 ,
r1′ c′ r1′ c′ ′ ′
g = a11 A , h0 = a12 (B/h1 ) , g r2 = a2 hc1
′ ′ r −r1′ ′ ′ ′
⇒ g r1 −r1 = Ac−c , h01 = (B/h1 )c−c , g r2 −r2 = hc−c
1
′ ′
r1 −r1 ′
r1 −r1 r2 −r2
c−c′ c−c′ c−c′
⇒ A=g , B/h1 = h0 , h1 = g .
r1 − r1′ r2 − r2′
u= , x= .
c − c′ c − c′
These distributions are identical provided (A, B, h0 , h1 ) ∈ LR1′ , cf. Definition 5.1, which means
in this case that there exist u, x ∈ Zn such that A = g u , B = hu0 g x , and h1 = g x . Otherwise,
the simulated conversations are clearly accepting.
(ii) The relation R2′ = {(A, B, h0 , h1 , h2 ; u, x) : A = g u , B = hu0 g x , (h1 = g x ∨ h2 = g x )} can be
obtained as R2′ = R1,1′ ∪ R′ , where R′
1,2
′ ′
1,1 is essentially the same as R1 and R1,2 is essentially
′
the same as R1 but with h1 replaced by h2 . So, we can combine two instances of the protocol
for R1′ using OR-composition to obtain a protocol for R2′ . The resulting protocol is a special
case (m = 2) of the protocol for arbitrary m, see part (iii) of this exercise.
(iii) To handle the general case, we use the generalization of OR-composition treated in
Exercise 5.4.3. Thus we combine m instances of the protocol for R1′ , where the ith instance
uses hi instead of h1 , 1 ≤ i ≤ m. The protocol is given in Figure S.20, for the case that
x = logg h1 .
Completeness. Suppose the prover uses x = logg h1 . It follows directly from the protocol
r
that c1 + · · · + cm = c and also that for all i, 2 ≤ i ≤ m, we have g r1,i = a11,i Aci , h01,i =
c r c
a12,i (B/hi ) i , and g 2,i = a2,i hi i . Furthermore, we check that for the remaining case i = 1
that
g r1,1 = g u1,1 +c1 u = g u1,1 (g u )c1 = a11,1 Ac1 ,
r u +c1 u u
h01,1 = h0 1,1 = h0 1,1 (hu0 )c1 = a12,1 (B/h1 )c1 ,
Prover Verifier
u1,1 , u2,1 ∈R Zn
a11,1 ← g u1,1
u
a12,1 ← h0 1,1
a2,1 ← g u2,1
m
ci , r1,i , r2,i ∈R Zn
a11,i ← g r1,i A−ci
r
a12,i ← h01,i (B/hi )−ci
a2,i ← g r2,i h−c i
i
i=2
(a11,i , a12,i , a2,i )m
i=1
−
−−−−−−−−−−−−−− →−
c ∈R Zn
c
−−−−−−− −−−−−−−
←
c1 ←n c − c2 − · · · − cm
r1,1 ←n u1,1 + c1 u
r2,1 ←n u2,1 + c1 x
(ci , r1,i , r2,i )m
i=1 ?
−−−−−−−−−−−−−−→ − c1 + · · · + cm =n c
? m
g r1,i = a11,i Aci
r1,i ?
h0 = a12,i (B/hi )ci
?
g r2,i = a2,i hci i i=1
′ , using x = log h
FIGURE S.20: Σ-protocol for relation Rm g 1
.
r
g r2,i = a2,i hci i ,
(
g r1,i = a11,i Aci , h01,i = a12,i (B/hi )ci ,
′
′ ′ r1,i ′ ′ c′
g r1,i = a11,i Aci , h0 = a12,i (B/hi )ci , g r2,i = a2,i hi i
′
′ ′ r1,i −r1,i ′ ′ c −c′i
⇒ g r1,i −r1,i = Aci −ci , h0 = (B/hi )ci −ci , g r2,i −r2,i = hi i
′ ′
r1,i −r1,i ′
r1,i −r1,i r2,i −r2,i
ci −c′ ci −c′ ci −c′
⇒ A=g i , B/hi = h0 i
, hi = g i .
′
r1,i − r1,i ′
r2,i − r2,i
u= , x= .
ci − c′i ci − c′i
′ is satisfied.
Clearly, A = g u , B = hu0 g x , and hi = g x , which implies that relation Rm
Solutions to Exercises 135
r i m
a11,i ← g r1,i A−ci ; a12,i ← h01,i (B/hi )−ci ; a2,i ← g r2,i h−c i i=2
;
c1 ←n c − c2 − · · · − cm ; r1,1 ←n u1,1 + c1 u; r2,1 ←n u2,1 + c1 x},
{((a11,i , a12,i , a2,i )m m m
i=1 ; c; (ci , r1,i , r2,i )i=1 ) : c1 , . . . , cm−1 ∈R Zn ; (r1,i , r2,i ∈R Zn )i=1 ;
cm ←n c − c1 − · · · − cm−1 ;
r i m
a11,i ← g r1,i A−ci ; a12,i ← h01,i (B/hi )−ci ; a2,i ← g r2,i h−c i i=1
}.
These distributions are identical provided (A, B, h0 , h1 , . . . , hm ) ∈ LRm
′ , each conversation
occurring with probability 1/n3m−1 : indeed, in both distributions we have that logg a11,1 =
logh0 a12,1 , using that A = g u and B = hu0 h1 holds for the case that x = logg h1 . Otherwise,
the simulated conversations are clearly accepting, as required by Definition 5.1.
6.1.1 Clearly, s2 = u is uniformly distributed. And, since u and s are independent, also
Pr[s1 = 0] = Pr[u = s] = 21 Pr[s = 0] + 12 Pr[s = 1] = 12 , for every distribution of s.
6.2.1 Let (βi,j ) denote the t × t Vandermonde matrix defined by (βi,j ) := (ij ), 1 ≤ i, j ≤ t.
Then, by definition, (βi,j ) and (γj,k ) are each other inverses, and
t t Y
t t
j
Y Y Y
Bji = sk
(g /h) βi,j γj,k
= (g sk /h)δi,k = g si /h,
j=1 j=1 k=1 k=1
where (δi,k ) denotes the t × t identity matrix (so, δi,k is the Kronecker delta). Hence, since
B0 = h and i0 = 1 it follows that Eq. (6.1) holds.
6.2.3 For distribution, the dealer broadcasts commitments Ci = g si1 hsi2 , 1 ≤ i ≤ m, where
si2 ∈R Zn . Each share si = (si1 , si2 ) is sent privately to participant Pi , who checks si by
verifying that Ci = g si1 hsi2 . For reconstruction, each share si contributed by a participant Pi
is checked si1 si2
Pmby verifying that Ci = g h . If all shares are correct, the secret is reconstructed
as s = i=1 si1 .
Noting that the commitments used by the dealer are Pedersen commitments, it follows
that the shares si and hence the secret s are hidden in an information-theoretic way. The
secret remains hidden even if, say, participants
Pm P1 , ..., Pm−1 pool their shares: nothing can
be deduced about the value of s = i=1 si1 (other than what already follows from the a
priori distribution of s) as the only information available on sm1 is the Pedersen commitment
Cm = g sm1 hsm2 , which hides both sm1 and sm2 information-theoretically.
Moreover, since the Pedersen commitments Ci are computationally binding (under the
DL assumption), the dealer and the participants (not knowing logg h) cannot cheat by send-
ing inconsistent shares. Hence, secret s is fixed once the dealer completes the distribution
protocol.
6.3.1 Assuming honest behavior of all parties, an m-out-of-m threshold ElGamal cryptosys-
tem can be implemented as follows.
Encryption. The algorithm remains the same as in the basic ElGamal cryptosystem. Hence,
given public key h and plaintext M ∈ ⟨g⟩, the ciphertext is set to (A, B) = (g u , hu M ),
where u ∈R Zn .
Threshold decryption. The protocol runs as follows. Given ciphertext (A, B), each party
Pi , 1 ≤ i ≤ m, xi
Qmbroadcasts di = A , using its private share xi . The plaintext is recovered
as M = B/ i=1 di .
The security critically depends on the fact that the private key x is never reconstructed in
one place: throughout the DKG protocol and (multiple instances of) the threshold decryption
protocol, the shares xi are only used privately by the respective parties Pi . Under the DL
assumption, the release of the verification keys hi = g xi nor the release of the decryption
shares di = Axi exposes the shares xi .
The ElGamal encryptions are semantically secure (hiding plaintext M completely) under
the DDH assumption. This holds even if all shares xi except Pm−1 one are known.
Q For instance,
if x1 , . . . , xm−1 are known, we can compute Bm = B/A i=1 xi = hu M/ m−1 u
i=1 hi = hm M .
u u
Hence, the problem remains to find M given (A, Bm ) = (g , hm M ), which is as hard as
breaking ElGamal.
Note that the verification keys hi are not used in the threshold decryption protocol because
we have assumed that all parties follow the protocol. See Section 6.3.1 for ways to achieve
security against actively corrupt parties.
7.1.1 Write vi = 1 − vi ∈ {0, 1}. The protocol in Figure S.21 proves knowledge of ui , vi
such that Ai = g ui and Bi = hui g vi with vi ∈ {0, 1}, combining OR-composition w.r.t. vi
as in Exercise 5.3.2(d) with EQ-composition for exponent ui . The protocol is proved to
Solutions to Exercises 137
Prover Verifier
u′vi , cvi , rvi
∈R Zn
′
avi ← g uvi
′
bvi ← huvi
−cv
avi ← g rvi Ai i
bvi ← hrvi (Bi /g vi )−cvi
a0 , b0 , a1 , b1
−−−−−−−−−→ −
c ∈R Zn
c
−−−−−−−−−−
←
cvi ←n c − cvi
rvi ←n u′vi + cvi ui
c0 , c1 , r0 , r1
−−−−−−−−−→ −
?
c0 + c1 =n c
?
g r0 = a0 Aci 0
?
hr0 = b0 Bic0
?
g r1 = a1 Aci 1
?
hr1 = b1 (Bi /g)c1
c0 + c1 = H(g r0 A−c
i
0
, hr0 Bi−c0 , g r1 A−c
i
1
, hr1 (Bi /g)−c1 ; Ai , Bi ).
and
′ c′ ′ ′
g r1 = a1 Aci 1 , hr1 = b1 (Bi /g)c1 , g r1 = a1 Ai 1 , hr1 = b1 (Bi /g)c1
′ c −c′1 ′ ′
⇒ g r1 −r1 = Ai 1 , hr1 −r1 = (Bi /g)c1 −c1 .
138 Solutions to Exercises
These distributions are identical provided logg Ai ∈ {logh Bi , logh (Bi /g)}, cf. Definition 5.1;
furthermore the simulated conversations are accepting in the remaining case, as required.
Rm = {(Am , Bm ; um , vm ) : Am = g um , Bm = Hm
um vm
g , vm ∈ {0, 1}}.
For the subsequent steps, voter Vi , 1 ≤ i < m, provides a Σ-proof for relation Ri :
Ri = {(Ai , Ai+1 , Bi , Bi+1 ; ui , vi , xi ) : hi = g xi , Ai /Ai+1 = g ui ,
Bi /Bi+1 = A−x ui vi
i+1 Hi g , vi ∈ {0, 1}}.
i
7.2.1 Observe that XY = (−1)x+y = (−1)x⊕y = 1−2(x⊕y), where x⊕y = x+y−2xy ∈ {0, 1}
is the xor of bits x and y. Hence, we get:
E(XY ) 12 1
2
E(xy) = E(x) E(y) ,
E(1)
where 12 denotes the multiplicative inverse of 2 modulo n.
Alternatively, we could use E(X), E(Y ) instead of E(x), E(y), as follows:
1
E(XY ) E(1) 4
E(xy) = ,
E(X) E(Y )
1
where 4 denotes the multiplicative inverse of 4 modulo n.
7.3.1 Running x0 and x1 through all values in {0, x, x, 1} (encoded as 00, 01, 10, 11) yields
all Boolean functions on two bits x and y:
0 00 00 OT(0, 0; y) = 0 false 15 11 11 OT(1, 1; y) = 1 true
1 00 01 OT(0, x; y) = x ∧ y and 14 11 10 OT(1, x; y) = x ∧ y nand
2 00 10 OT(0, x; y) = x ⇍ y inhibits 13 11 01 OT(1, x; y) = x ⇐ y implied by
3 00 11 OT(0, 1; y) = y right 12 11 00 OT(1, 0; y) = y right negated
4 01 00 OT(x, 0; y) = x ⇏ y inhibited by 11 10 11 OT(x, 1; y) = x ⇒ y implies
5 01 01 OT(x, x; y) = x left 10 10 10 OT(x, x; y) = x left negated
6 01 10 OT(x, x; y) = x ⊕ y xor 9 10 01 OT(x, x; y) = x ⇔ y equal
7 01 11 OT(x, 1; y) = x ∨ y or 8 10 00 OT(x, 0; y) = x ∨ y nor
As sender in the OT protocol, party A uses its private bit x to set x0 and x1 for the desired
Boolean function. As receiver, party B always uses its private bit y as selection bit, hence
does not even need to know which function is being evaluated.
7.3.2 With the same numbering as in the previous exercise, we express each Boolean function
f (x, y) using at most one secure multiplication:
f (x, y) za zb
0 00 00 0 0 0 false
1 00 01 xy xa ya ⊕ ua ⊕ ub ⊕ xb ya xb yb ⊕ ub ⊕ ua ⊕ xa yb and
2 00 10 xy xa ya ⊕ ua ⊕ ub ⊕ xb ya xb yb ⊕ ub ⊕ ua ⊕ xa yb inhibits
3 00 11 y ya yb right
4 01 00 xy xa ya ⊕ ua ⊕ ub ⊕ xb ya xb yb ⊕ ub ⊕ ua ⊕ xa yb inhibited by
5 01 01 x xa xb left
6 01 10 x⊕y x a ⊕ ya xb ⊕ yb xor
7 01 11 xy xa ya ⊕ ua ⊕ ub ⊕ xb ya xb yb ⊕ ub ⊕ ua ⊕ xa yb or
8 10 00 xy xa ya ⊕ ua ⊕ ub ⊕ xb ya xb yb ⊕ ub ⊕ ua ⊕ xa yb nor
9 10 01 x⊕y x a ⊕ ya xb ⊕ yb equal
10 10 10 x xa xb left negated
11 10 11 xy xa ya ⊕ ua ⊕ ub ⊕ xb ya xb yb ⊕ ub ⊕ ua ⊕ xa yb implies
12 11 00 y ya yb right negated
13 11 01 xy xa ya ⊕ ua ⊕ ub ⊕ xb ya xb yb ⊕ ub ⊕ ua ⊕ xa yb implied by
14 11 10 xy xa ya ⊕ ua ⊕ ub ⊕ xb ya xb yb ⊕ ub ⊕ ua ⊕ xa yb nand
15 11 11 1 1 0 true
140 Solutions to Exercises
Functions like x ⊕ y are computed “locally” by letting parties A and B set shares za and zb
directly using their shares xa , ya and xb , yb , respectively. To negate input bits x and/or y, we
let party A negate its shares xa and/or ya . For the remaining functions like xy we run the
secure multiplication protocol, negating input bits if applicable. Similarly, if the output bit
needs to be negated as for xy it suffices to let party A negate its random bit ua .
7.4.1 Any 2t + 1 shares si = a(i)b(i) do not only determine a(0)b(0) uniquely but also the
complete polynomial s(X) = a(X)b(X), which is of degree at most 2t. The polynomial leaks
much more information about x = a(0) and y = b(0) than just the value of xy = a(0)b(0). For
example, if both a(X) and b(X) are irreducible, then factoring s(X) yields a(X) and b(X)
as the only factors, from which x and y can be recovered uniquely (up to order); if x ̸= y, it
follows that a(X) ̸= b(X), hence there will be one or more parties Pi for which a(i) ̸= b(i),
and any such party can recover x and y uniquely.
7.4.2 The only difference between Pnsecure dot products and secure multiplication is that
each party Pi starts out with si = k=1 ak (i)bk (i) instead of si = a(i)b(i). The subsequent
resharing is the same, and therefore
z = c(0) = j∈Q′ λQ′ ,j cj (0) = j∈Q′ λQ′ ,j sj = j∈Q′ λQ′ ,j nk=1 ak (j)bk (j)
P P P P
7.4.3 Let f (Z) = dk=0 ak (0)Z k and g(Z) = el=0 bl (0)Z l for some polynomials {ak (X)}dk=0
P P
and {bl (X)}el=0 of degree at most t. Each party Pi starts out with shares {ak (i)}dk=0 and
{bl (i)}el=0 , hence Pi may form polynomials fi (Z) = dk=0 ak (i)Z k and gi (Z) = el=0 bl (i)Z l .
P P
The protocol then lets each party Pi compute si (Z) = fi (Z)gi (Z) locally using any (fast) al-
gorithm for polynomial multiplication. For the remainder of the protocol, the parties perform
a coefficientwise resharing of si (Z). Therefore, using the same notation as in the text,
P P P
h(Z) = c(0) = j∈Q′ λQ′ ,j cj (0) = j∈Q′ λQ′ ,j sj (Z) = j∈Q′ λQ′ ,j fj (Z)gj (Z)
= j∈Q′ λQ′ ,j d+e
P P P n
Pd+e P P n
n=0 k+l=n ak (j)bl (j)Z = n=0 k+l=n j∈Q′ λQ′ ,j ak (j)bl (j)Z
= n=0 k+l=n ak (0)bl (0)Z n = d+e
Pd+e P P P k
n=0 k+l=n xk yl Z = f (Z)g(Z),
where the bounds 0 ≤ k ≤ d and 0 ≤ l ≤ e are understood. The coefficients are all reshared
in parallel, requiring one round of communication overall.
x = x0 ∧ y = y0 ⇔ y d = x0 ∧ y = y0 ⇔ (y d )e = xe0 ∧ y = y0 ⇔ y = y0 .
Signer Receiver
(d = 1/e mod ϕ(N )) (t1 e1 + t2 e2 = 1)
u ∈R Z∗N
y ←N H(M1 )e2 H(M2 )e1 /ue
y
−−−−−−−−−−
←
x ←N y d
x S ←N xu
−−−−−−−−−−→
−
S1 ←N H(M1 )t1 H(M2 )−t2 S t2 e2
S2 ←N S/S1
8.2.2 Since e1 and e2 are relatively prime, we can use the extended Euclidean algorithm to
compute integers t1 , t2 such that t1 e1 + t2 e2 = 1. These numbers can be stored publicly. The
receiver uses t1 and t2 to compute S1 as shown in Figure S.22.
To prove why this method works, first note that we have for S:
using that t2 e2 = 1 − t1 e1 .
Therefore we have for S1 :
S1e1 = (H(M1 )t1 H(M2 )−t2 S t2 e2 )e1 = (H(M1 )t1 e1 H(M2 )−t2 e1 S t2 e1 e2 ) = H(M1 ),
8.3.1 First, we note that g r = ahc holds and therefore that (a; c; r) = (a0 ; c0 ; r0 ) is equivalent
to a = a0 ∧ c = c0 , as g r0 = a0 hc0 holds as well. Similarly, since a′ = ag s h−t = g r+s h−c−t =
′ ′
g r h−c and c′ = H(a′ ; M ), we have that (a′ ; c′ ; r′ ) = (a′0 ; c′0 ; r0′ ) is equivalent to r′ = r0′ , using
′ ′
that c′0 = H(a′0 ; M ) and g r0 = a′0 hc0 . Thus, we have:
Signer Receiver
(h = g1x1 g2x2 )
u1 , u2 ∈R Zn
a ← g1u1 g2u2 a s1 , s2 , t ∈R Zn
−−−−−−−−−→
−
a′ ← ag1s1 g2s2 h−t
c′ ← H(a′ ; M )
c c ←n c′ − t
−−−−−−−−−−
←
r1 ←n u1 + cx1
r , r2
r2 ←n u2 + cx2 −−−−1−−− −−
→
r1′ ←n r1 + s1
r2′ ←n r2 + s2
r′ r′ ? ′
g11 g22 = a′ hc
Signer Receiver
(x = y 1/e mod N )
u ∈R Z∗N
a ←N ue a s ∈R Z∗N
−−−−−−−−−→
−
t ∈R Ze
a ←N a se y −t
′
c′ ← H(a′ ; M )
c c ←e c′ − t
−−−−−−−−−−
←
r ←N uxc
r
−−−−−−−−−→
− ′
r′ ←N r s y ⌊(c −t)/e⌋
? ′
r′e =N a′ y c
8.3.2 To construct a blind signature protocol based on Okamoto’s Σ-protocol of Figure 4.5,
we combine a conversation (a; c; r1 , r2 ) with a simulated conversation (g1s1 g2s2 h−t ; t; s1 , s2 ) to
obtain a blinded conversation (a′ ; c′ ; r1′ , r2′ ) = (ag1s1 g2s2 h−t ; c + t; r1 + s1 , r2 + s2 ). This results
in the protocol of Figure S.23.
Completeness is easily checked:
r′ r′ ′ ′
g11 g22 = g1r1 +s1 g2r2 +s2 = ahc g1s1 g2s2 = ag1s1 g2s2 hc −t = a′ hc .
Perfect unlinkability can be proved in the same way as for the Schnorr-based protocol, cf.
Exercise 8.3.1.
Note that for c′ we have to reduce c + t modulo e. However, the exponent of y is not reduced
′
modulo e, and therefore we need to add the correction factor y ⌊(c −t)/e⌋ in the computation
of r′ . This results in the protocol of Figure S.24.
Completeness can now be checked as follows:
e ′ ′ ′ ′ ′ ′
r′ = (r s y ⌊(c −t)/e⌋ )e = a y c se y ⌊(c −t)/e⌋e = a se y (c −t) mod e+⌊(c −t)/e⌋e = a se y c −t = a′ y c .
using that c′ − t = ⌊(c′ − t)/e⌋e + (c′ − t) mod e holds over the integers.
Perfect unlinkability can be proved in the same way as for the Schnorr-based protocol, cf.
Exercise 8.3.1.
Bibliography
[BCJ+ 05] E. Biham, R. Chen, A. Joux, P. Carribault, C. Lemuet, and W. Jalby. Collisions
of SHA-0 and reduced SHA-1. In Advances in Cryptology—EUROCRYPT ’05,
volume 3494 of LNCS, pages 36–57. Springer, 2005.
[BDF98] D. Boneh, G. Durfee, and Y. Frankel. An attack on RSA given a small fraction of
the private key bits. In Advances in Cryptology—ASIACRYPT ’98, volume 1514
of LNCS, pages 25–34. Springer, 1998.
144
Bibliography 145
[BM03] C. Boyd and A. Mathuria. Protocols for Authentication and Key Establishment.
Springer, 2003.
[BR93] M. Bellare and P. Rogaway. Random oracles are practical: A paradigm for design-
ing efficient protocols. In 1st ACM Conference on Computer and Communications
Security, Fairfax, pages 62–73. ACM, 1993.
[Bra93] S. Brands. An efficient off-line electronic cash system based on the representation
problem. Report CS-R9323, Centrum voor Wiskunde en Informatica, Amsterdam,
March 1993.
[CD98] R. Cramer and I. Damgård. Zero-knowledge proofs for finite field arithmetic,
or: Can zero-knowledge be for free? In Advances in Cryptology—CRYPTO ’98,
volume 1462 of LNCS, pages 424–441. Springer, 1998.
[CDN01] R. Cramer, I. Damgård, and J.B. Nielsen. Multiparty computation from threshold
homomorphic encryption. In Advances in Cryptology—EUROCRYPT ’01, volume
2045 of LNCS, pages 280–300. Springer, 2001.
[CH10] O. Catrina and S. de Hoogh. Improved primitives for secure multiparty inte-
ger computation. In Security and Cryptography for Networks: 7th International
Conference (SCN 2010), volume 6280 of LNCS, pages 182–199. Springer, 2010.
[Cha83] D. Chaum. Blind signatures for untraceable payments. In D. Chaum, R.L. Rivest,
and A.T. Sherman, editors, Advances in Cryptology—CRYPTO ’82, pages 199–
203, New York, 1983. Plenum Press.
[Cha88] D. Chaum. Blind signature systems. U.S. Patent #4,759,063, 1988. Issued on
July 19, 1988, filed on August 22, 1983.
[CK88] C. Crépeau and J. Kilian. Achieving oblivious transfer using weakened security
assumptions. In Proc. 29th IEEE Symposium on Foundations of Computer Science
(FOCS ’88), pages 42–52. IEEE Computer Society, 1988.
[Cra97] R. Cramer. Modular Design of Secure yet Practical Cryptographic Protocols. PhD
thesis, Universiteit van Amsterdam, Netherlands, 1997.
[FMR96] M. J. Fischer, S. Micali, and C. Rackoff. A secure protocol for the oblivious
transfer (extended abstract). Journal of Cryptology, 9(3):191–195, 1996.
[FPS20] G. Fuchsbauer, A. Plouviez, and Y. Seurin. Blind Schnorr signatures and signed
ElGamal encryption in the algebraic group model. In Advances in Cryptology—
EUROCRYPT ’20, volume 12106 of LNCS, pages 63–95. Springer, 2020.
[FS87] A. Fiat and A. Shamir. How to prove yourself: Practical solutions to identification
and signature problems. In Advances in Cryptology—CRYPTO ’86, volume 263
of LNCS, pages 186–194. Springer, 1987.
[FS90] U. Feige and A. Shamir. Witness indistinguishable and witness hiding protocols.
In Proc. 22nd Symposium on Theory of Computing (STOC ’90), pages 416–426.
ACM, 1990.
[GMW87] O. Goldreich, S. Micali, and A. Wigderson. How to play any mental game -
or - a completeness theorem for protocols with honest majority. In Proc. 19th
Symposium on Theory of Computing (STOC ’87), pages 218–229. ACM, 1987.
[GMW91] O. Goldreich, S. Micali, and A. Wigderson. Proofs that yield nothing but their
validity or all languages in NP have zero-knowledge proof systems. Journal of
the ACM, 38(1):691–729, 1991. Preliminary version in 27th IEEE Symposium on
Foundations of Computer Science (FOCS’ 86), pages 174–187, 1986.
[GRR98] R. Gennaro, M. O. Rabin, and T. Rabin. Simplified VSS and fast-track multiparty
computations with applications to threshold cryptography. In 17th annual ACM
symposium on Principles of Distributed Computing (PODC ’98), pages 101–111.
ACM, 1998.
[GV88] O. Goldreich and R. Vainish. How to solve any protocol problem–an efficiency
improvement. In Advances in Cryptology—CRYPTO ’87, volume 293 of LNCS,
pages 73–86. Springer, 1988.
[HMZ+ 14] Z. Hao, Y. Mao, S. Zhong, L. E. Li, H. Yao, and N. Yu. Toward wireless security
without computational assumptions—Oblivious transfer based on wireless channel
characteristics. IEEE Transactions on Computers, 63(6):1580–1593, 2014.
[IR01] G. Itkis and L. Reyzin. Forward-secure signatures with optimal signing and ver-
ifying. In Advances in Cryptology—CRYPTO ’01, volume 2139 of LNCS, pages
332–354. Springer, 2001.
[Jak02] M. Jakobsson. Fractal hash sequence representation and traversal. In Proc. IEEE
International Symposium on Information Theory (ISIT ’02), page 437. IEEE,
2002. Full version eprint.iacr.org/2002/001.
[Oka93] T. Okamoto. Provably secure and practical identification schemes and correspond-
ing signature schemes. In Advances in Cryptology—CRYPTO ’92, volume 740 of
LNCS, pages 31–53. Springer, 1993.
[OO90] T. Okamoto and K. Ohta. Divertible zero knowledge interactive proofs and com-
mutative random self-reducibility. In Advances in Cryptology—EUROCRYPT ’89,
volume 434 of LNCS, pages 134–149. Springer, 1990.
[PS00] D. Pointcheval and J. Stern. Security arguments for digital signatures and blind
signatures. Journal of Cryptology, 13(3):361–396, 2000.
[Rab81] M. Rabin. How to exchange secrets by oblivious transfer. Technical Memo TR-81,
Aiken Computation Laboratory, Harvard University, 1981.
[RAD78] R. Rivest, L. Adleman, and M. Dertouzos. On data banks and privacy homomor-
phisms. In Foundations of Secure Computation, pages 169–177. Academic Press,
1978.
[RSA78] R. L. Rivest, A. Shamir, and L. Adleman. A method for obtaining digital signa-
tures and public-key cryptosystems. Communications of the ACM, 21(2):120–126,
1978. Reprinted in 1983 in 26(1):96–99.
[SBK+ 17] M. Stevens, E. Bursztein, P. Karpman, A. Albertini, and Y. Markov. The first
collision for full SHA-1. In Advances in Cryptology—CRYPTO ’17, volume 10401
of LNCS, pages 570–596. Springer, 2017. See also shattered.io.
[Sch69] V. Schemmel. Ueber relative primzahlen. Journal für die reine und angewandte
Mathematik, 70:191–192, 1869.
[Sch97] B. Schoenmakers. Basic security of the eCash payment system. In State of the Art
in Applied Cryptography, volume 1528 of LNCS, pages 338–352. Springer, 1997.
Correct version at berry.win.tue.nl/papers/cosic.pdf.
[Sch10a] M. Schakenbos. Secure distributed error-correction. Master’s thesis, Math & CS,
TU Eindhoven, Netherlands, 2010.
[Sch16] B. Schoenmakers. Explicit optimal binary pebbling for one-way hash chain re-
versal. In Financial Cryptography 2016, volume 9603 of LNCS, pages 299–320.
Springer, 2016. See also berry.win.tue.nl/pebbling/.
[Sch17] B. Schoenmakers. Binary pebbling algorithms for in-place reversal of one-way hash
chains. Nieuw Archief voor Wiskunde serie 5, 18(3):199–204, September 2017.
[Sho99] V. Shoup. On formal models for secure key exchange. Report RZ 3120, IBM
Research, Zurich, April 1999. See also, updated paper (version 4, November 15,
1999), available at shoup.net/papers/skey.pdf.
[Szy04] M. Szydlo. Merkle tree traversal in log space and time. In Advances in
Cryptology—EUROCRYPT ’04, volume 3027 of LNCS, pages 541–554. Springer,
2004.
[TW87] M. Tompa and H. Woll. Random self-reducibility and zero knowledge interactive
proofs of possession. In Proc. 28th IEEE Symposium on Foundations of Computer
Science (FOCS ’87), pages 472–482. IEEE Computer Society, 1987.
[WY05] X. Wang and H. Yu. How to break MD5 and other hash functions. In Advances
in Cryptology—EUROCRYPT ’05, volume 3494 of LNCS, pages 19–35. Springer,
2005.
[Yao82a] A. Yao. Protocols for secure computations. In Proc. 23rd IEEE Symposium on
Foundations of Computer Science (FOCS ’82), pages 160–164. IEEE Computer
Society, 1982.
[Yao82b] A. Yao. Theory and applications of trapdoor functions. In Proc. 23rd IEEE
Symposium on Foundations of Computer Science (FOCS ’82), pages 80–91. IEEE
Computer Society, 1982.
[Yao86] A. Yao. How to generate and exchange secrets. In Proc. 27th IEEE Symposium on
Foundations of Computer Science (FOCS ’86), pages 162–167. IEEE Computer
Society, 1986.