46

How to Share a Secret (1979)

Adi Shamir

As computers were networked and information was spread around and communicated, secrecy and privacy began to assume dimensions that had not been significant in a world of stored paper documents and centralized data banks. Playful metaphors—this paper is based on a problem posed in a 1968 mathematics book—assumed grave significance in the world of networked information. Advances in cryptography (chapters 42 and 45) held out the promise (not yet mathematically verified) that ordinary people might communicate confidentially at a distance, confident that their secret communication could not be compromised without an unrealistically large level of computational effort. This paper, by contrast, describes a protocol for sharing a secret among parties who must, to a degree that can be stipulated, cooperate in order to recover it—in such a way that it is provably impossible for a smaller cabal of the parties to expose the secret, even by devoting unlimited resources to the effort. The field of secret sharing initiated with this one short contribution has now grown to include many thousands of papers.

We met Adi Shamir (b. 1952) in chapter 45 as one of the authors of the RSA public-key cryptosystem. This paper starts by posing an apparently impossible challenge, and lays out a beautiful, short solution using only high school mathematics. It is practically a problem about distributed computer systems, yet mentions nothing about computer technology itself. Computer science exploded in the 1980s, and the field remains full of simply stated problems like this one, begging for elegant solutions.


46.1    Introduction

LIU (1968) considers the following problem: Eleven scientists are working on a secret project. They wish to lock up the documents in a cabinet so that the cabinet can be opened if and only if six or more of the scientists are present. What is the smallest number of locks needed? What is the smallest number of keys to the locks each scientist must carry?

It is not hard to show that the minimal solution uses 462 locks and 252 keys per scientist. These numbers are clearly impractical, and they become exponentially worse when the number of scientists increases. In this paper we generalize the problem to one in which the secret is some data D (e.g., the safe combination) and in which nonmechanical solutions (which manipulate this data) are also allowed. Our goal is to divide D into n pieces D1, , Dn in such a way that:

1. knowledge of any k or more Di pieces makes D easily computable;

2. knowledge of any k − 1 or fewer Di pieces leaves D completely undetermined (in the sense that all its possible values are equally likely).

Such a scheme is called a (k, n) threshold scheme. Efficient threshold schemes can be very helpful in the management of cryptographic keys. In order to protect data we can encrypt it, but in order to protect the encryption key we need a different method (further encryptions change the problem rather than solve it). The most secure key management scheme keeps the key in a single, well-guarded location (a computer, a human brain, or a safe). This scheme is highly unreliable since a single misfortune (a computer breakdown, sudden death, or sabotage) can make the information inaccessible. An obvious solution is to store multiple copies of the key at different locations, but this increases the danger of security breaches (computer penetration, betrayal, or human errors). By using a (k, n) threshold scheme with n = 2k − 1 we get a very robust key management scheme: We can recover the original key even when n/2 = k − 1 of the n pieces are destroyed, but our opponents cannot reconstruct the key even when security breaches expose n/2 = k − 1 of the remaining k pieces.

In other applications the tradeoff is not between secrecy and reliability, but between safety and convenience of use. Consider, for example, a company that digitally signs all its checks (Rivest et al., 1978). If each executive is given a copy of the company’s secret signature key, the system is convenient but easy to misuse. If the cooperation of all the company’s executives is necessary in order to sign each check, the system is safe but inconvenient. The standard solution requires at least three signatures per check, and it is easy to implement with a (3, n) threshold scheme. Each executive is given a small magnetic card with one Di piece, and the company’s signature generating device accepts any three of them in order to generate (and later destroy) a temporary copy of the actual signature key D. The device does not contain any secret information and thus it need not be protected against inspection. An unfaithful executive must have at least two accomplices in order to forge the company’s signature in this scheme.

Threshold schemes are ideally suited to applications in which a group of mutually suspicious individuals with conflicting interests must cooperate. Ideally we would like the cooperation to be based on mutual consent, but the veto power this mechanism gives to each member can paralyze the activities of the group. By properly choosing the k and n parameters we can give any sufficiently large majority the authority to take some action while giving any sufficiently large minority the power to block it.

46.2    A Simple (k, n) Threshold Scheme

Our scheme is based on polynomial interpolation: given k points in the 2-dimensional plane (x1, y1), , (xk, yk) with distinct xi’s, there is one and only one polynomial q(x) of degree k − 1 such that q(xi) = yi for all i. Without loss of generality, we can assume that the data D is (or can be made) a number. To divide it into pieces Di, we pick a random k − 1 degree polynomial q(x) = a0 + a1x + ak−1xk−1 in which a0 = D, and evaluate:

Given any subset of k of these Di values (together with their identifying indices), we can find the coefficients of q(x) by interpolation, and then evaluate D = q(0). Knowledge of just k − 1 of these values, on the other hand, does not suffice in order to calculate D.

To make this claim more precise, we use modular arithmetic instead of real arithmetic. The set of integers modulo a prime number p forms a field in which interpolation is possible. Given an integer valued data D, we pick a prime p which is bigger than both D and n. The coefficients a1, , ak−1 in q(x) are randomly chosen from a uniform distribution over the integers in [0, p), and the values D1, , Dn are computed modulo p.

Let us now assume that k − 1 of these n pieces are revealed to an opponent. For each candidate value D′ in [0, p) he can construct one and only one polynomial q′(x) of degree k − 1 such that q′(0) = D′ and q′(i) = Di for the k − 1 given arguments. By construction, these p possible polynomials are equally likely, and thus there is absolutely nothing the opponent can deduce about the real value of D.

Efficient O(n log2 n) algorithms for polynomial evaluation and interpolation are discussed in Aho et al. (1974) and Knuth (1997b), but even the straightforward quadratic algorithms are fast enough for practical key management schemes. If the number D is long, it is advisable to break it into shorter blocks of bits (which are handled separately) in order to avoid multiprecision arithmetic operations. The blocks cannot be arbitrarily short, since the smallest usable value of p is n + 1 (there must be at least n + 1 distinct arguments in [0, p) to evaluate q(x) at). However, this is not a severe limitation since sixteen bit modulus (which can be handled by a cheap sixteen bit arithmetic unit) suffices for applications with up to 64,000 Di pieces.

Some of the useful properties of this (k, n) threshold scheme (when compared to the mechanical locks and keys solutions) are:

1. The size of each piece does not exceed the size of the original data.

2. When k is kept fixed, Di pieces can be dynamically added or deleted (e.g., when executives join or leave the company) without affecting the other Di pieces. (A piece is deleted only when a leaving executive makes it completely inaccessible, even to himself.)

3. It is easy to change the Di pieces without changing the original data D—all we need is a new polynomial q(x) with the same free term. A frequent change of this type can greatly enhance security since the pieces exposed by security breaches cannot be accumulated unless all of them are values of the same edition of the q(x) polynomial.

4. By using tuples of polynomial values as Di pieces, we can get a hierarchical scheme in which the number of pieces needed to determine D depends on their importance. For example, if we give the company’s president three values of q(x), each vice-president two values of q(x), and each executive one value of q(x), then a (3, n) threshold scheme enables checks to be signed either by any three executives, or by any two executives one of whom is a vice-president, or by the president alone.

The polynomials can be replaced by any other collection of functions which are easy to evaluate and to interpolate. A different (and somewhat less efficient) threshold scheme was recently developed by G. R. Blakley (1979).

  1. Reprinted from Shamir (1979), with permission from the Association for Computing Machinery.