The present invention relates to a technique to perform computation using a result of computation performed on another apparatus.
Decryption of a ciphertext encrypted using an encryption scheme such as public key cryptography or common key cryptography requires a particular decryption key (see Non-patent literature 1, for example). In one of existing methods for a first apparatus that does not have a decryption key to obtain a result of decryption of a ciphertext, a second apparatus that has a decryption key provides the decryption key to the first apparatus and the first apparatus uses the decryption key to decrypt the ciphertext. In another existing method for the first apparatus to obtain a result of decryption of a ciphertext, the first apparatus provides the ciphertext to the second apparatus and the second apparatus decrypts the ciphertext and provides the result of decryption to the first apparatus.
However, in the method in which the second apparatus provides a decryption key to the first apparatus, the decryption key needs to be taken out from the second apparatus to the outside, which poses security concerns. On the other hand, in the method in which the first apparatus provides a ciphertext to the second apparatus and the second apparatus decrypts the ciphertext, the first apparatus cannot verify the validity of decryption performed by the second apparatus. These problems can be generalized to other processing besides decryption. That is, there was not a technique for the second apparatus to provide only a computing capability to the first apparatus without leaking secrete information so that the first apparatus uses the computing capability to correctly perform computations.
According to the present invention, a computing apparatus outputs first input information τ1 and second input information τ2 that are elements of a group H and correspond to a ciphertext x, a capability providing apparatus uses the first input information τ1 to correctly compute f(τ1) with a probability greater than a certain probability to provide the result of the computation as first output information z1 and uses the second input information τ2 to correctly compute f(τ2) with a probability greater than a certain probability to provide the result of the computation as second output information z2, the computing apparatus generates a computation result u=f(x)bx1 from the first output information z1 and generates a computation result v=f(x)ax2 from the second output information z2 and, when the computation results u and v satisfy ua=vb, outputs ub′va′ for integers a′ and b′ that satisfy a′a+b′b=1, where G and H are groups, f(x) is a decryption function for decrypting the ciphertext x which is an element of the group H with a particular decryption key to obtain an element of the group G, X1 and X2 are random variables having values in the group G, x1 is a realization of the random variable X1, x2 is a realization of the random variable X2, and a and b are natural numbers relatively prime to each other.
According to the present invention, the capability providing apparatus provides only a computing capability to the computing apparatus without leaking secret information and the computing apparatus can use the computing capability to correctly perform computations.
Embodiments of the present invention will be described below with reference to drawings.
A first embodiment of the present invention will be described.
<Configuration>
As illustrated in
As illustrated in
As illustrated in
<Processes>
Processes of this embodiment will be described below. For the processes, let G and H be groups (for example commutative groups), f(x) be a decryption function for decrypting a ciphertext x, which is an element of the group H, with a particular decryption key s to obtain an element of the group G, generators of the groups G and H be μg and μh, respectively, X1 and X2 be random variables having values in the group G, x1 be a realization of the random variable X1, and x2 be a realization of the random variable X2. It is assumed here that a plurality of pairs of natural numbers a, b that are relatively prime to each other (a, b) are stored in the natural number storage 1101 of the computing apparatus 11. The term “natural number” means an integer greater than or equal to 0. Let I be a set of pairs of relatively prime natural numbers that are less than the order of the group G, then it can be considered that pairs (a, b) of natural numbers a, b corresponding to a subset S of I are stored in the natural number storage 1101. It is also assumed that a particular decryption key s is stored in the key storage 1204 of the capability providing apparatus 12 in a secure manner. Processes of the computing apparatus 11 are performed under the control of the controller 1113 and processes of the capability providing apparatus 12 are performed under the control of the controller 1205.
As illustrated in
The integer computing unit 1103 uses the sent pair of natural numbers (a, b) to compute integers a′, b′ that satisfy the relation a′a+b′b=1. Since the natural numbers a and b are relatively prime to each other, the integers a′ and b′ that satisfy the relation a′a+b′b=1 definitely exist. Information on the pair of natural numbers (a′, b′) is sent to the final output unit 1112 (step S1101).
The controller 1113 set t=1 (step S1102).
The input information providing unit 1104 generates and outputs first input information τ1 and second input information τ2 which are elements of the group H and each of which corresponds to the input ciphertext x. Preferably, each of the first input information τ1 and the second input information τ2 is information whose relation with the ciphertext x is scrambled. This enables the computing apparatus 11 to conceal the ciphertext x from the capability providing apparatus 12. Preferably, the first input information τ1 of this embodiment further corresponds to the natural number b selected by the natural number selecting unit 1102 and the second input information τ2 further corresponds to the natural number a selected by the natural number selecting unit 1102. This enables the computing apparatus 11 to evaluate the decryption capability provided by the capability providing apparatus 12 with a high degree of accuracy (step S1103).
As exemplified in
The first output information computing unit 1201 uses the first input information τ1 and the decryption key s stored in the key storage 1204 to correctly compute f(τ1) with a probability greater than a certain probability and sets the result of the computation as first output information z1 (step S1201). The second output information computing unit 1202 uses the second input information τ2 and the decryption key s stored in the key storage 1204 to correctly compute f(τ2) with a probability greater than a certain probability and sets the result of the computation as second output information z2 (step S1202). Note that the “certain probability” is a probability less than 100%. An example of the “certain probability” is a nonnegligible probability and an example of the “nonnegligible probability” is a probability greater than or equal to 1/ψ(k), where ψ(k) is a polynomial that is a weakly increasing function (non-decreasing function) for a security parameter k. That is, the first output information computing unit 1201 and the second output information computing unit 1202 output computation results that have an intentional or unintentional error. In other words, the result of the computation by the first output information computing unit 1201 may or may not be f(τ1) and the result of the computation by the second output information computing unit 1202 may or may not be f(τ2).
The first output information computing unit 1201 outputs the first output information z1 and the second output information computing unit 1202 outputs the second output information z2 (step S1203).
Returning to
The first computing unit 1105 generates a computation result u=f(x)bx1 from the first output information z1. Here, generating (computing) f(x)bx1 means computing a value of a formula defined as f(x)bx1. Any intermediate computation method may be used, provided that the value of the formula f(x)bx1 can be eventually computed. The same applies to computations of the other formulae that appear herein. In the first embodiment, a computation defined at a group is expressed multiplicatively. That is, “αb” for αεG means that a computation defined at the group G is applied b times to α and “α1α2” for α1, α2εG means that a computation defined at the group G is performed on operands α1 and α2 (the same applies to second to fifth embodiments described later). The result u of the computation is sent to the first power computing unit 1106 (step S1105).
The first power computing unit 1106 computes u′=ua. The pair of the result u of the computation and u′ computed on the basis of the result of the computation, (u, u′), is stored in the first list storage 1107 (step S1106).
The determining unit 1111 determines whether or not there is one that satisfies u′=v′ among the pairs (u, u′) stored in the first list storage 1107 and the pairs (v, v′) stored in the second list storage 1110 (step S1107). If no pair (v, v′) is stored in the second list storage 1110, the process at step S1107 is omitted and a process at step S1108 is performed. If there is one that satisfies u′=v′, the process proceeds to step S1114; if there is not one that satisfies u′=v′, the process proceeds to step S1108.
At step S1108, the second computing unit 1108 generates a computation result v=f(x)ax2 from the second output information z2. The result v of the computation is sent to the second power computing unit 1109 (step S1108).
The second power computing unit 1109 computes v′=vb. The pair (v, v′) of the result v of the computation and v′ computed on the basis of the computation result is stored in the second list storage 1110 (step S1109).
The determining unit 1111 determines whether or not there is one that satisfies u′=v′ among the pairs (u, u′) stored in the first list storage 1107 and the pairs (v, v′) stored in the second list storage 1110 (step S1110). If there is one that satisfies u′=v′, the process proceeds to step S1114. If there is not one that satisfies u′=v′, the process proceeds to step S1111.
At step S1111, the controller 1113 determines whether or not t=Tmax (step S1111). Here, Tmax is a predetermined natural number. If t=Tmax, the controller 1113 outputs information indicating that the computation is impossible, for example the symbol “⊥” (step S1113) and the process ends. If not t=Tmax, the controller 1113 increments t by 1, that is, sets t=t+1 (step S1112) and the process returns to step S1103.
The information indicating the computation is impossible (the symbol “⊥” in this example) means that the level of reliability that the capability providing apparatus 12 correctly performs computation is lower than a criterion defined by Tmax. In other words, the capability providing apparatus 12 was unable to perform a correct computation in Tmax trials.
At step S1114, the final output unit 1112 uses u and v that correspond to u′ and v′ that are determined to satisfy u′=v′ to calculate and output ub′va′ (step S1114). The ub′va′ thus computed will be a result f(x) of decryption of the ciphertext x with the particular decryption key s with a high probability (the reason why ub′va′=f(x) with a high probability will be described later). Therefore, the process described above is repeated multiple times and the value obtained with the highest frequency among the values obtained at step S1114 can be provided as the result of decryption. As will be described, ub′va′=f(x) can result with an overwhelming probability, depending on settings. In that case, the value obtained at step S1114 can be directly provided as the result of decryption.
<<Reason why ub′va′=f(x) with a High Probability>>
Let X be a random variable having a value in the group G. For wεG, an entity that returns wx′ corresponding to a sample x′ according to the random variable X in response to each request is called a sampler having an error X for w.
For wεG, an entity that returns wax′ corresponding to a sample x′ according to a random variable X whenever a natural number a is given is called a randomizable sampler having an error X for w. The randomizable sampler functions as the sampler if used with a=1.
The combination of the input information providing unit 1104, the first output information computing unit 1201 and the first computing unit 1105 of this embodiment is a randomizable sampler having an error X1 for f(x) (referred to as the “first randomizable sampler”) and the combination of the input information providing unit 1104, the second output information computing unit 1202 and the second computing unit 1108 is a randomizable sampler having an error X2 for f(x) (referred to as the “second randomizable sampler”).
The inventor has found that if u′=v′ holds, that is, if ua=vb holds, it is highly probable that the first randomizable sampler has correctly computed u=f(x)b and the second randomizable sampler has correctly computed v=f(x)a (x1 and x2 are identity elements eg of the group G). For simplicity of explanation, this will be proven in a fifth embodiment.
When the first randomizable sampler correctly computes u=f(x)b and the second randomizable sampler correctly computes v=f(x)a (when x1 and x2 are identity elements eg of the group G), then ub′va′ (f(x)bx1)b′(f(x)ax2)a′=(f(x)beg)b′(f(x)aeg)a′=f(x)bb′egb′f(x)aa′ega′=f(x)(bb′+aa′)=f(x).
For (q1, q2)εI, a function πi is defined by πi(q1, q2)=qi for each of i=1, 2. Let L=min (#π1(S), #π2(S)), where #• is the order of a set •. If the group G is a cyclic group or a group whose order is difficult to compute, it can be expected that the probability that an output other than “⊥” of the computing apparatus 11 is not f(x) is at most approximately Tmax2L/#S within a negligible error. If L/#S is a negligible quantity and Tmax is a quantity approximately equal to a polynomial order, the computing apparatus 11 outputs a correct f(x) with an overwhelming probability. An example of S that results in a negligible quantity of L/#S is S={(1, d)|dε[2, |G|−1]}, for example.
A proxy computing system of a second embodiment is an example that embodies the first randomizable sampler and the second randomizable sampler described above. The following description will focus on differences from the first embodiment and repeated description of commonalities with the first embodiment will be omitted. In the following description, elements labeled with the same reference numerals have the same functions and the steps labeled with the same reference numerals represent the same processes.
<Configuration>
As illustrated in
As illustrated in
As illustrated in
<Processes>
Processes of this embodiment will be described below. In the second embodiment, a decryption function f(x) is a homomorphic function, a group H is a cyclic group, and a generator of the group H is μh the order of the group H is KH, and ν=f(μh). The rest of the assumptions are the same as those in the first embodiment, except that the computing apparatus 11 is replaced with the computing apparatus 21 and the capability providing apparatus 12 is replaced with the capability providing apparatus 22.
As illustrated in
<<Process at Step S2103>>
The input information providing unit 2104 of the computing apparatus 21 (
The first random number generator 2104a (
The second random number generator 2104c generates a uniform random number r2 that is a natural number greater than or equal to 0 and less than KII. The generated random number r2 is sent to the second input information computing unit 2104d and the second computing unit 2108 (step S2103c). The second input information computing unit 2104d uses the input random number r2, the ciphertext x, and a natural number a to compute second input information τ2=μhr2xa (step S2103d).
The first input information computing unit 2104b and the second input information computing unit 2104d output the first input information τ1 and the second input information τ2 thus generated (step S2103e). Note that the first input information τ1 and the second input information τ2 in this embodiment are information whose relation with the ciphertext x is scrambled using random numbers r1, r2, respectively. This enables the computing apparatus 21 to conceal the ciphertext x from the capability providing apparatus 22. The first input information τ1 of this embodiment further corresponds to the natural number b selected by the natural number selecting unit 1102 and the second input information τ2 further corresponds to the natural number a selected by the natural number selecting unit 1102. This enables the computing apparatus 21 to evaluate the decryption capability provided by the capability providing apparatus 22 with a high degree of accuracy.
<<Processes at Steps S2200 Through S2203>>
As illustrated in
The first output information computing unit 2201 uses the first input information τ1=μhr1xb and a decryption key s stored in the key storage 1204 to correctly compute f(μhr1xb) with a probability greater than a certain probability and sets the result of the computation as first output information z1. The result of the computation may or may not be correct. That is, the result of the computation by the first output information computing unit 2201 may or may not be f(μhr1xb) step S2201).
The second output information computing unit 2202 uses the second input information τ2=μhr2xa and the decryption key s stored in the key storage 1204 to correctly compute f(μhr2xa) with a probability greater than a certain probability and sets the result of the computation as second output information z2. The result of the computation may or may not be correct. That is, the result of the computation by the second output information computing unit 2202 may or may not be f(μhr2xa) (step S2202). The first output information computing unit 2201 outputs the first output information z1 and the second output information computing unit 2202 outputs the second output information z2 (step S2203).
<<Processes at Steps S2104 and S2105>>
Returning to
The first computing unit 2105 uses the input random number r1 and the first output information z1 to compute z1ν−1 and sets the result of the computation as u. The result u of the computation is sent to the first power computing unit 1106. Here, u=z1ν−r1=f(x)bx1. That is, z1ν−r1 is an output of a randomizable sampler having an error X1 for f(x). The reason will be described later (step S2105).
<<Process at Step S2108>>
The second computing unit 2108 uses the input random number r2 and the second output information z2 to compute z2ν−r2 and sets the result of the computation as v. The result v of the computation is sent to the second power computing unit 1109. Here, v=z2ν−r2=f(x)ax2. That is, z2ν−r2 is an output of a randomizable sampler having an error X2 for f(x). The reason will be described later (step S2108).
<<Reason why z1ν−r1 and z2ν−r2 are Outputs of Randomizable Samplers Having Errors X1 and X2, Respectively, for f(x)>>
Let c be a natural number, R and R′ be random numbers, and B(μhRxc) be the result of computation performed by the capability providing apparatus 22 using μhRxc. That is, the results of computations that the first output information computing unit 2201 and the second output information computing unit 2202 return to the computing apparatus 21 are z=B(μhRxc). A random variable X that has a value in the group G is defined as X=B(μhR′)f(μhR′)−1.
Then, zν−R=B(μhRxc)f(μh)−R=Xf(μhRxc)f(μh)−R=Xf(μh)Rf(x)cf(μh)−R=f(x)cX. That is, zν−R is an output of a randomizable sampler having an error X for f(x).
The expansion of formula given above uses the properties such that X=B(μhR′)f(μhR′)−1=B(μhRxc)f(μhRxc)−1 and that B(μhRxc)=Xf(μhRxc). The properties are based on the fact that the function f(x) is a homomorphic function and R and R′ are random numbers.
Therefore, considering that a and b are natural numbers and r1 and r2 are random numbers, z1ν−r1 and z2ν−r2 are, likewise, outputs of randomizable samplers having errors X1 and X2, respectively, for f(x).
A third embodiment is a variation of the second embodiment and computes a value of u or v by using samplers described above when a=1 or b=1. The amounts of computations performed by samplers are in general smaller than the amounts of computations by randomizable samplers. Using samplers instead of randomizable samplers for computations when a=1 or b=1 can reduce the amounts of computations by a proxy computing system. The following description will focus on differences from the first and second embodiments and repeated description of commonalities with the first and second embodiments will be omitted.
<Configuration>
As illustrated in
As illustrated in
As illustrated in
<Processes>
Processes of this embodiment will be described below. Differences from the second embodiment will be described.
As illustrated in
<<Process at Step S3103>>
The input information providing unit 3104 of the computing apparatus 31 (
A process at step S3103 of this embodiment will be described below with reference to
The controller 1113 (
Determination is made by the controller 1113 as to whether b is equal to 1 (step S3103a). If it is determined that b≠1, the processes at steps S2103a and 2103b described above are performed and the process proceeds to step S3103g.
On the other hand, if it is determined at step S3103a that b=1, the third random number generator 3104e generates a random number r3 that is a natural number greater than or equal to 0 and less than KH. The generated random number r3 is sent to the third input information computing unit 3104f and the third computing unit 3109 (step S3103b). The third input information computing unit 3104f uses the input random number r3 and a ciphertext x to compute xr3 and sets xr3 as first input information τ1 (step S3103c). Then the process proceeds to step S3103g.
At step S3103g, determination is made by the controller 1113 as to whether a is equal to 1 (step S3103g). If it is determined that a≠1, the processes at steps S2103c and S2103d described above are performed.
On the other hand, if it is determined at step S3103g that a=1, the third random number generator 3104e generates a random number r3 that is a natural number greater than or equal to 0 and less than KH. The generated random number r3 is sent to the third input information computing unit 3104f (step S3103h). The third input information computing unit 3104f uses the input random number r3 and the ciphertext x to compute xr3 and sets xr3 as second input information τ2 (step S3103i).
The first input information computing unit 2104b, the second input information computing unit 2104d, and the third input information computing unit 3104f output the first input information τ1 and the second input information τ2 thus generated along with information on the corresponding natural numbers (a, b) (step S3103e). Note that the first input information τ1 and the second input information τ2 in this embodiment are information whose relation with the ciphertext x is scrambled using random numbers r1, r2 and r3. This enables the computing apparatus 31 to conceal the ciphertext x from the capability providing apparatus 32.
<<Processes at S3200 Through S3203 and S3205 Through S3209>>
Processes at S3200 through S3203 and S3205 through S3209 of this embodiment will be described below with reference to
The controller 1205 (
Under the control of the controller 1205, the first input information τ1=μhr1xb when b≠1 is input in the first output information computing unit 2201 of the capability providing apparatus 32 (
Determination is made by the controller 1113 as to whether b is equal to 1 (step S3205). If it is determined that b≠1, the process at step S2201 described above is performed. Then, determination is made by the controller 1113 as to whether a is equal to 1 (step S3208). If it is determined that a≠1, the process at step S2202 described above is performed and then the process proceeds to step S3203.
On the other hand, if it is determined at step S3208 that a=1, the third output information computing unit 3203 uses the second input information τ2=xr3 to correctly compute f(xr3) with a probability greater than a certain probability and sets the obtained result of the computation as third output information z3. The result of the computation may or may not be correct. That is, the result of the computation by the third output information computing unit 3203 may or may not be f(xr3) (step S3209). Then the process proceeds to step S3203.
If it is determined at step S3205 that b=1, the third output information computing unit 3203 uses the first input information τ1=xr3 to correctly compute f(xr3) with a probability greater than a certain probability and sets the obtained result of the computation as third output information z3. The result of the computation may or may not be correct. That is, the result of the computation by the third output information computing unit 3203 may or may not be f(xr3) (step S3206).
Then, determination is made by the controller 1113 as to whether a is equal to 1 (step S3207). If it is determined that a=1, the process proceeds to step S3203; if it is determined that a≠1, the process proceeds to step S2202.
At step S3203, the first output information computing unit 2201, which has generated the first output information z1, outputs the first output information z1, the second output information computing unit 2202, which has generated the second output information z2, outputs the second output information z2, and the third output information computing unit 3202, which has generated the third output information z3, outputs the third output information z3 (step S3203).
<<Processes at Steps S3104 and S3105>>
Returning to
If b≠1, the first computing unit 2105 performs the process at step S2105 described above to generate u; if b=1, the third computing unit 3109 computes z31/r3 and sets the result of the computation as u. The result u of the computation is sent to the first power computing unit 1106. Here, if b=1, then u=z31/r3=f(x)x3. That is, z31/r3 serves as a sampler having an error X3 for f(x). The reason will be described later (step S3105).
<<Process at Step S3108>>
If a≠1, the second computing unit 2108 performs the process at S2108 described above to generate v; if a=1, the third computing unit 3109 computes z31/r3 and sets the result of the computation as v. The result v of the computation is sent to the second power computing unit 1109. Here, if a=1, then v=z31/r3=f(x)x3. That is, z31/r3 serves as a sampler having an error X3 for f(x). The reason will be described later (step S3108).
Note that if z31/r3, that is, the radical root of z3, is hard to compute, u and/or v may be calculated as follows. The third computing unit 3109 may store each pair of random number r3 and z3 computed on the basis of the random number r3 in a storage, not depicted, in sequence as (α1, β1), (α2, β2), . . . , (αm, (βm), . . . . Here, m is a natural number. The third computing unit 3109 may compute γ1, γ2, . . . , γm that satisfies γ1α1+γ2α2+ . . . +γmαm=1 when the least common multiple of α1, α2, . . . , αm is 1, where γ1, γ2, . . . , γm are integers. The third computing unit 3109 may then use the resulting γ1, γ2, . . . , γm to compute Πi=1mβiγi=β1γ1β2γ2 . . . βmγm and may set the results of the computation as u and/or v.
<<Reason why z31/r3 Serves as a Sampler Having an Error X3 for f(x)>>
Let R be a random number and B(xR) be the result of computation performed by the capability providing apparatus 32 using xR. That is, let z=B(xR) be the results of computations returned by the first output information computing unit 2201, the second output information computing unit 2202, and the third output information computing unit 3203 to the computing apparatus 31. Furthermore, a random variable X having a value in the group G is defined as X=B(xR)1/Rf(x)−1.
Then, z1/R=B(xR)1/R=Xf(x)=f(x)X. That is, z1/R serves as a sampler having an error X for f(x).
The expansion of formula given above uses the properties such that X=B(xR)1/Rf(xR)−1 and that B(xR)1/R=Xf(xR). The properties are based on the fact that R is a random number.
Therefore, considering that r3 is a random number, z1/R serves as a sampler having an error X3 for f(x) likewise.
A proxy computing system of a fourth embodiment is another example that embodies the first and second randomizable samplers described above. Specifically, the proxy computing system embodies an example of first and second randomizable samplers in the case where H=G×G, the decryption function f(x) is a decryption function of ElGamal encryption, that is, f(c1, c2)=c1c2−s for a decryption key s and a ciphertext x=(c1, c2). The following description will focus on differences from the first embodiment and repeated description of commonalities with the first embodiment will be omitted.
As illustrated in
As illustrated in
As illustrated in
<Processes>
Processes of this embodiment will be described below. In the fourth embodiment, it is assumed that a group H is the direct product group G×G of a group G, the group G is a cyclic group, a ciphertext x=(c1, c2)εH, f(c1, c2) is a homomorphic function, a generator of the group G is μg, the order of the group G is KG, a pair of a ciphertext (V, W)εH and a text f(V, W)=Y εG decrypted from the ciphertext for the same decryption key s is preset in the computing apparatus 41 and the capability providing apparatus 42, and the computing apparatus 41 and the capability providing apparatus 42 can use the pair.
As illustrated in
<<Process at Step S4103>>
The input information providing unit 4104 of the computing apparatus 41 (
The fourth random number generator 4104a (
The fourth input information computing unit 4104ca uses a natural number b selected by the natural number selecting unit 1102, c2 included in the ciphertext x, and the random number r4 to compute fourth input information c2bWr4 (step S4103c). The fifth input information computing unit 4104cb uses the natural number b selected by the natural number selecting unit 1102, c1 included in the ciphertext x, and random numbers r4 and r5 to compute fifth input information c1bVr4μgr5 (step S4103d).
The sixth random number generator 4104d generates a uniform random number r6 that is a natural number greater than or equal to 0 and less than KG. The generated random number r6 is sent to the sixth input information computing unit 4104fa, the seventh input information computing unit 4104fb, and the second computing unit 4108 (step S4103e). The seventh random number generator 4104e generates a uniform random number r7 that is a natural number greater than or equal to 0 and less than KG. The generated random number r7 is sent to the sixth input information computing unit 4104fa and the second computing unit 4108 (step S4103f).
The sixth input information computing unit 4104fa uses a natural number a selected by the natural number electing unit 1102, c2 included in the ciphertext x, and the random number r6 to compute sixth input information c2aWr6 (step S4103g). The seventh input information computing unit 4104fb uses the natural number a selected by the natural number selecting unit 1102, c1 included in the ciphertext x, and the random number r7 to compute seventh input information c1aVr6μgr7 (step S4103h).
The first input information computing unit 4104c outputs the fourth input information c2bWr4 and the fifth input information c1bVr4μgr5 generated as described above as first input information τ1=(c2bWr4, c1bVr4μgr5). The second input information computing unit 4104f outputs the sixth input information c2aWr6 and the seventh input information c1aVr6Ξgr7 generated as described above as second input information τ2=(c2aWr6, c1aVr6μgr7 (step S4103i).
<<Processes at Steps S4200 Through S4203>>
As illustrated in
The first output information computing unit 4201 uses the first input information τ1=(c2bWr4, c1bVr4μgr5) and the decryption key s stored in the key storage 1204 to correctly compute f(c1bVr4μgr5, c2bWr4) with a probability greater than a certain probability and sets the result of the computation as first output information z1. The result of the computation may or may not be correct. That is, the result of the computation by the first output information computing unit 4201 may or may not be f(c1bVr4μgr5, c2bWr4) (step S4201).
The second output information computing unit 4202 can correctly compute f(c1aVr6μgr7, c2aWr6) with a probability greater than a certain probability by using the second input information τ2=(c2aWr6, c1aVr6μgr7) and the decryption key s stored in the key storage 1204 and sets the result of the computation as second output information z2. The result of the computation may or may not be correct. That is, the result of the computation by the second output information computing unit 4202 may or may not be f(c1aVr6μgr7, c2aWr6) step S4202). The first output information computing unit 4201 outputs the first output information z1 and the second output information computing unit 4202 outputs the second output information z2 (step S4203).
<<Processes at Steps S4104 and S4105>>
Returning to
The first computing unit 4105 uses the input first output information z1 and random numbers r4 and r5 to compute z1Y−r4μg−r5 and sets the result of the computation as u (step S4105). The result u of the computation is sent to the first power computing unit 1106. Here, u=z1Y−r4μg−r5=f(c1, c2)bx1. That is, z1Y−r4μg−r5 is an output of a randomizable sampler having an error X1 for f(c1, c2). The reason will be described later.
<<Process at Step S4108>>
The second computing unit 4108 uses the input second output information z2 and random numbers r6 and r7 to compute z2Y−r6μg−r7 and sets the result of the computation as v. The result v of the computation is sent to the second power computing unit 1109. Here, v=z2Y−r6μg−r7=f(c1, c2)ax2. That is, z2Y−r6μ−r7 is an output of a randomizable sampler having an error X2 for f(c1, c2). The reason will be described later.
<<Reason why z1Y−r4μg−r5 and z2Y−r6μg−r7 are Outputs of Randomizable Samplers Having Errors X1 and X2, Respectively, for f(c1, c2)>>
Let c be a natural number, R1, R2, R1′ and R2′ be random numbers, and B(c1cVR1μgR2, c2cWR1) be the result of computation performed by the capability providing apparatus 42 using c1cVR1μgR2 and c2cWR1. That is, the first output information computing unit 4201 and the second output information computing unit 4202 return z=B(c1cVR1μgR2, c2cWR1) as the results of computations to the computing apparatus 41. Furthermore, a random variable X having a value in a group G is defined as X=B(VR1′μgR2′, WR1′)f(VR1′μgR2′, WR1′)−1.
Here, zY−R1μg−R2=B(c1cVR1μgR2, c2cVR1)Y−R1μg−R2=Xf(c1cVR1μgR2, c2cWR1)Y−R1μg−R2=Xf(c1, c2)cf(V, W)R1f(μg, eg)R2Y−R1μg−R2=Xf(c1, c2)cYR1μgR2Y−R1μg−R2=f(c1, c2)cX. That is, zY−R1μg−R2 is an output of a randomizable sampler having an error X for f(x). Note that eg is an identity element of the group G.
The expansion of formula given above uses the properties such that X=B(VR1′μgR2′, WR1′)f(VR1′μgR2′, WR1′)−1=B(c1cVR1μgR2, c2cWR1)f(c1cVR1μgR2, c2cWR1) and that B(c1cVR1μgR2, c2cWR1)=Xf(c1cVR1μgR2, c2cWR1). The properties are based on the fact that R1, R2, R1′ and R2′ are random numbers.
Therefore, considering that a and b are natural numbers and r4, r5, r6 and r7 are random numbers, z1Y−r4μg−r5 and z2Y−r6μg−r7 are, likewise, outputs of randomizable samplers having errors X1 and X2, respectively, for f(c1, c2).
In the embodiments described above, a plurality of pairs (a, b) of natural numbers a and b that are relatively prime to each other are stored in the natural number storage 1101 of the computing apparatus and the pairs (a, b) are used to perform the processes. However, one of a and b may be a constant. For example, a may be fixed at 1 or b may be fixed at 1. In other words, one of the first randomizable sampler and the second randomizable sampler may be replaced with a sampler. If one of a and b is a constant, the process for selecting the constant a or b is unnecessary, the constant a or b is not input in the processing units and each processing units can treat it as a constant in computations. If a or b set as a constant is equal to 1, f(x)=ub′Va′ can be obtained as f(x)=v or f(x)=u without using a′ or b′.
A fifth embodiment is an example of such a variation, in which b is fixed at 1 and the second randomizable sampler is replaced with a sampler. The following description will focus on differences from the first embodiment. Specific examples of the first randomizable sampler and the sampler are similar to those described in the second to fourth embodiments and therefore description of the first randomizable sampler and the sampler will be omitted.
<Configuration>
As illustrated in
As illustrated in
As illustrated in
<Processes>
Processes of this embodiment will be described below. For the processes, let G and H be groups (for example commutative groups), f(x) be a decryption function for decrypting a ciphertext x, which is an element of the group H, with a particular decryption key s to obtain an element of the group G, generators of the groups G and H be μg and μh, respectively, X1 and X2 be random variables having values in the group G, x1 be a realization of the random variable X1, and x2 be a realization of the random variable X2. It is assumed here that a plurality of natural numbers a are stored in the natural number storage 5101 of the computing apparatus 51.
As illustrated in
The controller 1113 sets t=1 (step S1102).
The input information providing unit 5104 generates and outputs first input information τ1 and second input information τ2 which are elements of the group H and each of which corresponds to an input ciphertext x. Preferably, the first input information τ1 and the second input information τ2 are information whose relation with the ciphertext x is scrambled. This enables the computing apparatus 51 to conceal the ciphertext x from the capability providing apparatus 52. Preferably, the second input information τ2 of this embodiment further corresponds to the natural number a selected by the natural number selecting unit 5102. This enables the computing apparatus 51 to evaluate the decryption capability provided by the capability providing apparatus 52 with a high degree of accuracy (step S5103). A specific example of the pair of the first input information τ1 and the second input information τ2 is a pair of first input information τ1 and the second input information τ2 of any of the second to fourth embodiments when b=1.
As illustrated in
The first output information computing unit 5201 uses the first input information τ1 and the decryption key s stored in the key storage 1204 to correctly compute f(τ1) with a probability greater than a certain probability and sets the result of the computation as first output information z1 (step S5201). The second output information computing unit 5202 uses the second input information τ2 and the decryption key s stored in the key storage 1204 to correctly compute f(τ2) with a probability greater than a certain probability and sets the result of the computation as second output information z2 (step S5202). That is, the first output information computing unit 5201 and the second output information computing unit 5202 output computation results that have an intentional or unintentional error. In other words, the result of the computation by the first output information computing unit 5201 may or may not be f(τ1) and the result of the computation by the second output information computing unit 5202 may or may not be f(τ2). A specific example of the pair of the first output information z1 and the second output information z2 is a pair of first output information z1 and the second output information z2 of any of the second to fourth embodiments when b=1.
The first output information computing unit 5201 outputs the first output information z1 and the second output information computing unit 5202 outputs the second output information z2 (step S5203).
Returning to
The first computing unit 5105 generates a computation result u=f(x)x1 from the first output information z1. A specific example of the computation result u is a result u of computation of any of the second to fourth embodiments when b=1. The result u of the computation is sent to the first power computing unit 1106 (step S5105).
The first power computing unit 1106 computes u′=ua. The pair of the result u of the computation and u′ computed on the basis of the result of the computation, (u, u′), is stored in the first list storage 1107 (step S1106).
The second computing unit 5108 generates a computation result v=f(x)ax2 from the second output information z2. A specific example of the result v of the computation is a result v of the computation of any of the second to fourth embodiments. The result v of the computation is stored in the second list storage 5110 (step S5108).
The determining unit 5111 determines whether or not there is one that satisfies u′=v among the pairs (u, u′) stored in the first list storage 1107 and v stored in the second list storage 5110 (step S5110). If there is one that satisfies u′=v, the process proceeds to step S5114; if there is not one that satisfies u′=v, the process proceeds to step S1111.
At step S1111, the controller 1113 determines whether or not t=Tmax (step S1111). Here, Tmax is a predetermined natural number. If t Tmax, the controller 1113 outputs information indicating that the computation is impossible, for example the symbol “⊥” (step S1113), then the process ends. If not t=Tmax, the controller 1113 increments t by 1, that is, sets t=t+1 (step S1112), then the process returns to step S5103.
At step S5114, the final output unit 1112 outputs u corresponding to u′ that has been determined to satisfy u′=v (step S5114). The obtained u is equivalent to ub′va′ when b=1 in the first to fourth embodiments. That is, u thus obtained can be a result f(x) of decryption of the ciphertext x with a particular decryption key s with a high probability. Therefore, the process described above is repeated multiple times and the value that has most frequently obtained among the values obtained at step S5114 can be chosen as the decryption result. As will be described later, u=f(x) can result with an overwhelming probability, depending on settings. In that case, the value obtained at step S5114 can be directly provided as a result of decryption.
<<Reason why Decryption Result f(x) can be Obtained>>
The reason why a decryption result f(x) can be obtained on the computing apparatus 51 of this embodiment will be described below. Terms required for the description will be defined first.
Black-Box:
A black-box F(τ) of f(τ) is a processing unit that takes an input of τεH and outputs zεG. In this embodiment, each of the first output information computing unit 5201 and the second output information computing unit 5202 is equivalent to the black box F(τ) for the decryption function f(τ). A black-box F(τ) that satisfies z=f(τ) for an element τεUH arbitrarily selected from a group H and z=F(τ) with a probability greater than δ (0<δ≦1), that is, a black-box F(τ) for f(τ) that satisfies
Pr[z=f(τ)|τεUH,z=F(τ)]>δ (1)
is called a δ-reliable black-box F(τ) for f(τ). Here, δ is a positive value and is equivalent to the “certain probability” stated above.
Self-Corrector:
A self-corrector CF(x) is a processing unit that takes an input of xεH, performs computation by using a black-box F(τ) for f(τ), and outputs jεG∪⊥. In this embodiment, the computing apparatus 51 is equivalent to the self-corrector CF(x).
Almost Self-Corrector:
Assume that a self-corrector CF(x) that takes an input of xεH and uses a δ-reliable black-box F(τ) for f(τ) to perform computation outputs a correct value j=f(x) with a probability sufficiently greater than the provability with which the self-corrector CF(x) outputs an incorrect value j≠f(x).
That is, assume that a self-corrector CF(x) satisfies
Pr[j=f(x)|j=CF(x),j≠⊥]>Pr[j≠f(x)|j=CF(x),j≠⊥]+Δ (2)
Here, Δ is a certain positive value (0<Δ<1). If this is the case, the self-corrector CF(x) is called an almost self-corrector. For example, for a certain positive value Δ′ (0<Δ′<1), if a self-corrector CF(x) satisfies
Pr[j=f(x)|j=CF(x)]>(⅓)+Δ′
Pr[j=⊥|j=CF(x)]<⅓
Pr[j≠f(x) and j≠⊥|j=CF(x)]<⅓,
then the self-corrector CF(x) is an almost self-corrector. Examples of Δ′ include Δ′= 1/12 and Δ′=⅓.
Robust Self-Corrector:
Assume that a self-corrector CF(x) that takes an input of xεH and uses a δ-reliable black-box F(τ) for f(τ) outputs a correct value j=f(x) or j=⊥ with an overwhelming probability. That is, assume that for a negligible error ξ (0≦ξ<1), a self-corrector CF(x) satisfies
Pr[j=f(x) or j=⊥|j=CF(x)]>1−ξ (3)
If this is the case, the self-corrector CF(x) is called a robust self-corrector. An example of the negligible error ξ is a function vale ξ(k) of a security parameter k. An example of the function value ξ(k) is a function value ξ(k) such that {ξ(k)p(k)} converges to 0 for a sufficiently large k, where p(k) is an arbitrary polynomial. Specific examples of the function value ξ(k) include ξ(k)=2−k and ξ(k)=2−√k.
A robust self-corrector can be constructed from an almost self-corrector. Specifically, a robust self-corrector can be constructed by executing an almost self-constructor multiple times for the same x and selecting the most frequently output value, except ⊥, as j. For example, an almost self-corrector is executed O(log(1/ξ)) times for the same x and the value most frequently output is selected as j to construct robust self-corrector. Here, O(•) represents O notation.
Pseudo-Free Action:
An Upper Bound of the Probability
Pr[αa=β and α≠eg|aεuΩ,αεX1,βεX2] (4)
of satisfying αa=β for all possible X1 and X2 is called a pseudo-free indicator of a pair (G, Ω) and is represented as P(G, Ω), where G is a group, Ω is a set of natural numbers Ω={0, . . . , M} (M is a natural number greater than or equal to 1), α and β are realizations αεX1 (α≠eg) and βεX2 of random variables X1 and X2 that have values in the group G, and aεΩ. If a certain negligible function ζ(k) exists and
P(G,Ω)<ζ(k) (5),
then a computation defined by the pair (G, Ω) is called a pseudo-free action. Note that a computation defined by a group is expressed multiplicatively in the fifth embodiment. That is, “αa” for αεG means that a computation defined at the group G is applied a times to α. An example of the negligible function ζ(k) is such that {ζ(k)p(k)} converges to 0 for a sufficiently large k, where p(k) is an arbitrary polynomial. Specific examples of the function ζ(k) include ζ(k)=2−k and ζ(k)=2−√k. For example, if the probability of Formula (4) is less than O(2−k) for a security parameter k, a computation defined by the pair (G, Ω) is a pseudo-free action. For example, if the number of the elements |Ω·α| of a set Ω·α={a(α)|aεΩ} exceeds 2k for any αεG where α≠eg, a computation defined by the pair (G, Ω) can be a pseudo-free action. There are many such examples. For example, if the group G is a residue group Z/pZ modulo prime p, the prime p is the order of 2k, the set Ω={0, . . . , p−2}, a(α) is αaεZ/pZ, and α≠eg, then Ω·α={αa|a=0, . . . , p−2}={eg, α1, . . . , αp-2} and |Ω·α|=p−1. If a certain constant C exists and k is sufficiently large, |Ω·α|>C2k is satisfied because the prime p is the order of 2k. Here, the probability of Formula (4) is less than C−12−k and a computation defined by such pair (G, Ω) is a pseudo-free action.
δγ-Reliable Randomizable Sampler:
A randomizable sampler that whenever a natural number a is given, uses the δ-reliable black-box F(τ) for f(τ) and returns wax′ corresponding to a sample x′ that depends on a random number X for wεG and in which the probability that wax′=wa is greater than δγ (γ is a positive constant), that is,
Pr[wax′=wa]>δγ (6)
is satisfied, is called a δγ-reliable randomizable sampler. The combination of the input information providing unit 5104, the second output information computing unit 5202, and the second computing unit 5108 of this embodiment is a δγ-reliable randomizable sampler for w=f(x).
The definitions given above will be used to describe the reason why a decryption result f(x) can be obtained by using the computing apparatus 51 of this embodiment.
At step S5110 of this embodiment, determination is made as to whether u′=v, that is, whether ua=v. Since the combination of the input information providing unit 5104, the second output information computing unit 5202, and the second computing unit 5108 of this embodiment is a δγ-reliable randomizable sampler (Formula (6)), ua=v holds (Yes at step S5110) with an asymptotically large probability if Tmax is greater than a certain value determined by k, δ and γ. For example, Markov's inequality shows that if Tmax≧4/δγ, the probability that ua=v holds (Yes at step S5110) is greater than ½.
Since u=f(x)x1 and v=f(x)ax2 in this embodiment, x1a=x2 holds if ua=v holds. x1a=x2 holds if x1=x2=eg or x1≠eg. If x1=x2=eg, then u=f(x) and therefore u output at step S5114 is a correct decryption result f(x). On the other hand, if x1≠eg, then u≠f(x) and therefore u output at step S5114 is not a correct decryption result f(x).
If a computation defined by a pair (G, Ω) of a group G and a set Ω to which a natural number a belongs is a pseudo-free action or Tmax2P(G, Ω) is asymptotically small for a pseudo-free index P(G, Ω), the probability that x1≠eg (Formula (4)) when ua=v is asymptotically small. Accordingly, the probability that x1=eg when ua=v is asymptotically large. Therefore, if a computation defined by a pair (G, Ω) is a pseudo-free action or Tmax2P(G, Ω) is asymptotically small, the probability that an incorrect decryption result f(x) is output when ua=v is sufficiently smaller than the probability that a correct decryption result f(x) is output when ua=v. In this case, it can be said that the computing apparatus 51 is an almost self-corrector (see Formula (2)). Therefore, a robust self-corrector can be constructed from the computing apparatus 51 as described above and a correct decryption result f(x) can be obtained with an overwhelming probability. If a computation defined by (G, Ω) is a pseudo-free action, the probability that an incorrect decryption result f(x) is output when ua=v is also negligible. In that case, the computing apparatus 51 outputs a correct decryption result f(x) or ⊥ with an overwhelming probability.
Note that “η(k′) is asymptotically small” means that k0 is determined for an arbitrary constant ρ and the function value η(k′) for any k′ that satisfies k0<k′ for k0 is less than ρ. An example of k′ is a security parameter k.
“η(k′) is asymptotically large” means that k0 is determined for an arbitrary constant ρ and the function value 1−η(k′) for any k′ that satisfies k0<k′ for k0 is less than ρ.
<<δγ-Reliable Randomizable Sampler and Security>>
Consider the following attack.
This attack is possible if the probability distribution Da=wax′w−a of an error of wax′ output from the randomizable sampler for a given natural number a depends on the natural number a. For example, if tampering is made so that v output from the second computing unit 5108 is f(x)ax1a, then ua=v always holds regardless of the value of x1. Therefore, it is desirable that the probability distribution Da=wax′w−a of an error of wax′ output from the randomizable sampler for a given natural number a do not depend on the natural number a.
Alternatively, it is desirable that the randomizable sampler be such that a probability distribution D that has a value in a group G that cannot be distinguished from the probability distribution Da=wax′w−a of an error of wax′ for any element aε∀Ω of a set Ω exists (the probability distribution Da and the probability distribution D are statistically close to each other). Note that the probability distribution D does not depend on a natural number a. That the probability distribution Da and the probability distribution D cannot be distinguished from each other means that the probability distribution Da and the probability distribution D cannot be distinguished from each other by a polynomial time algorithm. For example, if
ΣgεG|Pr[gεD]−Pr[gεDa]|<ζ (7)
is satisfied for negligible ζ (0≦ζ1), the probability distribution Da and the probability distribution D cannot be distinguished from each other by the polynomial time algorithm. An example of negligible ζ is a function value ζ(k) of the security parameter k. An example of the function value ζ(k) is a function value such that {ζ(k)p(k)} converges to 0 for a sufficiently large k, where p(k) is an arbitrary polynomial. Specific examples of the function ζ(k) include ζ(k)=2−k and ζ(k)=2−√k. These facts also apply to the first to fourth embodiments which use natural numbers a and b.
A sixth embodiment is a mode in which the present invention is applied to decryption of the GHV encryption scheme (see Reference literature 1 “C, Genrty, S. Halevi and V. Vaikuntanathan, ‘A Simple BGNType Cryptosystem from LWE,’ Advances in Cryptology—EUROCRYPT 2010, LNCS 6110, pp. 506-522, Springer-Verlag, 2010”, for example), which is a type of lattice-based cryptography. The following description will focus on differences from the embodiments described above.
<Configuration>
As illustrated in
As illustrated in
As illustrated in
As illustrated in
<Processes>
Processes of this embodiment will be described below. In this embodiment, let GM be a set of ι×ι matrices, HM be a set of ι×ι matrices, MX1 and MX2 be random variables having values in the set GM, Mx1 be a realization of the random variable MX1, Mx2 be a realization of the random variable MX2, and aM be an element of the set HM. In this embodiment, PK be a ι×κ matrix which is an encryption key (public key), SK be a decryption key (secret key) which is a ι×ι matrix that satisfies PK·SK=0, CM be a κ×ι matrix, NM be a ι×ι matrix, UM be a ι×ι unit matrix, PT be a plaintext PTεGM which is an element of the set GM, xM be a ciphertext xMεHM which is an element of the set HM, ENCM be an encryption function for encrypting the plaintext PT which is an element of the set GM to obtain the ciphertext xMεHM, and fM(xM) be a decryption function for decrypting the ciphertext xMεHM with a particular decryption key SK to obtain the plaintext PT which is an element of the set GM. The decryption function fM(xM) is a homomorphic function. For example, let GM be a set of ι×ι matrices (Z/2Z)ι×ι, HM be a set of ι×ι matrices (Z/qZ)ι×ι, the encryption key PK be a t×K matrix (Z/qZ)ι×κ, the decryption key SK be a ι×ι matrix (Z/qZ)ι×ι, CM be a randomly selected κ×t matrix (Z/qZ)κ×ι, NM be a ι×ι matrix (Z/qZ)ι×ι according to a Gaussian distribution, UM be a ι×ι unit matrix (Z/2Z)ι×ι, the encryption function ENCM (PT) be PK·CM+2·NM+PT(mod q), and the decryption function fM(xM) be SK−1{SK·xM·SKT(mod q)}(SKT)−1(mod 2). Here, κ, ι and q are positive integers, •T is the transposed matrix of •, and (Z/qZ)κ×ι is a matrix of κ rows and ι columns having members of a factor ring Z/qZ modulo q as elements. In the sixth embodiment, the product between matrices α1 and α2 is written as α1·α2 and the sum of matrices α1 and α2 is written as α1+α2. A matrix that is equal to the each element of a matrix α by a natural number β is written as β·α.
It is assumed in this embodiment that a plurality of matrices aMεHM are stored in the matrix storage 6101 of the computing apparatus 61 (
The controller 1113 sets t=1 (step S1102).
The input information providing unit 6104 generates and outputs first input information Mτ1 and second input information Mτ2 which are elements of the set HM and each of which corresponds to an input ciphertext xM. Preferably, the first input information Mτ1 and the second input information Mτ2 are information whose relation with the ciphertext xM is scrambled. This enables the computing apparatus 61 to conceal the ciphertext xM from the capability providing apparatus 62. The second input information Mτ2 further corresponds to an element aM. This enables the computing apparatus 61 to evaluate the decryption capability provided by the capability providing apparatus 62 with a high degree of accuracy (step S6103). A specific example of step S6103 will be described below with reference to
[Specific Example of Step S6103]
The first random matrix selecting unit 6104a of the input information providing unit 6104 (
The third random matrix selecting unit 6104f uniformly randomly selects an element MR2 of the set GM. The selected MR2 is sent to the third encryption unit 6104h and the second computing unit 6108 (step S6103f). The fourth random matrix selecting unit 6104g selects random matrices CM21 and CM22ε(Z/qZ)κ×ι of κ×ι. The selected CM21 and CM22 are sent to the second input information computing unit 6104j (step S6103g). The third encryption unit 6104h uses the public key PK to generate a third ciphertext CR2=PK·CM+2·NM+MR2(mod q) which is a ciphertext ENCM(MR2) of MR2. The third ciphertext CR2 is sent to the second input information computing unit 6104j (step S6103h). Matrix aM is input in the fourth encryption unit 6104i. The fourth encryption unit 6104i uses the public key PK to generate a fourth ciphertext Ca=PK·CM+2·NM+aM(mod q) which is a ciphertext ENCM(aM) of the matrix aM. The fourth ciphertext Ca is sent to the second input information computing unit 6104j (step S6103i). The second input information computing unit 6104j further takes an input of the ciphertext xM. The second input information computing unit 6104j obtains and outputs (xM·Ca+CR2)+PK·CM21+2·NM+CM22T·PKT as second input information Mτ2. The second input information computing unit 6104j may compute Re(Cx) where Cx=xM·Ca+CR2 to generate the second input information Mτ2 or may compute Re(Cx) where Cx=Ca·xM+CR2 to generate the second input information Mτ2 ((step S6103j)/end of description of [Specific example of step S6103]).
As illustrated in
The first output information computing unit 6201 uses the first input information Mτ1 and the decryption key SK stored in the key storage 6204 to correctly compute fM(Mτ1)=SK−1{SK·Mτ1·SKT(mod q)}(SKT)−1(mod 2) with a probability greater than a certain probability and sets the obtained result of the computation as first output information Mz1 (step S6201). The second output information computing unit 6202 uses the second input information Mτ2 and the decryption key SK stored in the key storage 6204 to correctly compute fM(Mτ2)=SK−1{SK·Mτ2·SKT(mod q)}(SKT)−1(mod 2) with a probability greater than a certain probability and sets the obtained result of the computation as second output information Mz2 (step S6202). That is, the first output information computing unit 6201 and the second output information computing unit 6202 outputs computation results that have an intentional or unintentional error. In other words, the result of the computation by the first output information computing unit 6201 may or may not be fM(Mτ1) and the result of the computation by the second output information computing unit 6202 may or may not be fM(Mτ2).
The first output information computing unit 6201 outputs the first output information Mz1 and the second output information computing unit 6202 outputs the second output information Mz2 (step S6203).
Returning to
The first computing unit 5105 uses the first output information Mz1 to compute Mz1−MR1 and sets the result of the computation as uM. The result uM of the computation is sent to the matrix product computing unit 6106. Here, uM=Mz1−MR1=fM(xM)+Mx1. That is, uM serves as a sampler having an error MX1 for fM(xM). The reason will be described later (step S6105).
The matrix product computing unit 6106 obtains uM′=uM·aM. Note that the matrix product computing unit 6106 may compute uM·aM to obtain uM′ or may compute aM·uM to obtain uM′. The pair (uM, uM′) of the result uM of the computation and uM′ computed on the basis of the result of the computation is stored in the first list storage 6107 (step S6106).
The second computing unit 6108 uses the second output information Mz2 to compute Mz2−MR2 and sets the result of the computation as vM. The result vM of the computation is stored in the second list storage 6110. Here, vM=Mz2−MR2=fM(xM)·aM+MX2. That is, vM is an output of a randomizable sampler having an error MX2 for fM(xM). The reason will be described later (step S6108).
The determining unit 6111 determines whether or not there is one that satisfies uM′=vM among the pairs (uM, uM′) stored in the first list storage 6107 and vM stored in the second list storage 6110 (step S6110). If there is one that satisfies uM′=vM, the process proceeds to step S6114; if there is not one that satisfies uM′=vM, the process proceeds to step S1111.
At step S1111, the controller 1113 determines whether or not t=Tmax (step S1111). Here, Tmax is a predetermined natural number. If t=Tmax, the controller 1113 outputs information indicating that the computation is impossible, for example, the symbol “⊥” (step S1113), then the process ends. If not t=Tmax, the controller 1113 increments t by 1, that is, sets t=t+1 (step S1112), then the process returns to step S6103.
At step S6114, the final output unit 6112 outputs uM corresponding to uM′ that has been determined to satisfy uM′=vM (step S6114). The uM thus obtained can be a decryption result fM(xM) resulting from decrypting the ciphertext xM with the decryption key SK with a high probability (the reason will be described later). Therefore, the process described above is repeated multiple times and the value most frequently obtained among the values obtained at step S6114 can be chosen as the decryption result. Depending on settings, uM=fM(xM) can result with an overwhelming probability. In that case, the value obtained at step S6114 can be directly provided as the result of decryption.
<<Reason why Mz1−MR1 and Mz2−MR2 are Outputs of a Sampler and Randomizable Sampler that have Errors MX1 and MX2, Respectively, for fM(xM)>>
Because of the homomorphy of fM(xM), fM(xM·Ca+CR2)=fM(xM)·fM(Ca)+fM(CR2)=fM(xM)·aM+MR2 is satisfied, fM(xM)·aM=fM(xM·Ca+CR2)−MR2=fM(Mτ2)−MR2 is satisfied, and MR2=fM(Mτ2)−fM(xM)·aM is satisfied. Therefore, letting Mz2=FM(Mτ2), then Mz2−MR2=FM(Mτ2)−fM(Mτ2)+fM(xM)·aM=fM(xM)·aM+{FM(Mτ2)−fM(Mτ2)} is satisfied. Because of the uniform randomness of CM21, CM22 and MR2 corresponding to Mτ2, Mz2−MR2 is statistically close to fM(xM)·aM+Mx2. Here, Mx2 is a realization of the random variable MX2=FM(ENCM(MU2))−MU2 (MU2 uniformly randomly distributes on GM). Therefore, Mz2−MR2 is an output of a randomizable sampler having an error MX2 for fM(xM).
Likewise, fM(xM·CUM+CR1)=fM(xM)·fM(CUM)+fM(CR1)=fM(xM)·UM+MR1 is satisfied, fM(xM)=fM(xM·CUM+CR1)−MR1=fM(Mτ1)−MR1 is satisfied, and MR1=fM(Mτ1)−fM(xM) is satisfied. Therefore, letting Mz1=FM(Mτ1), then Mz1−MR1=FM(Mτ1)−fM(Mτ1)+fM(xM)=fM(xM)+{FM(Mτ1)−fM(Mτ1)} is satisfied. Because of the uniform randomness of CM11, CM12 and MR1 corresponding to Mτ1, Mz1−MR1 is statistically close to fM(xM)+Mx1. Here, Mx1 is a realization of the random variable MX1=FM(ENCM(MU1))−MU1 (MU1 uniformly randomly distributes on GM). Therefore, the above-described configuration which outputs Mz1−MR1 serves as a sampler having an error MX1 for fM(xM).
<<Reason why Decryption Result fM(xM) can be Obtained>>
For the same reason described in the section <<Reason why decryption result f(x) can be obtained>> in the fifth embodiment, a correct decryption result fM(xM) can be obtained in the sixth embodiment as well. However, since the sixth embodiment deals with matrices, G and H in the section <<Reason why decryption result f(x) can be obtained>> in the fifth embodiment are replaced with GM and HM, f(x) is replaced with fM(xM), τ is replaced with Mτ, F(τ) is replaced with FM(Mτ), z is replaced with Mz, x is replaced with xM, X1 and X2 are replaced with MX1 and MX2, x1 and x2 are replaced with Mx1 and Mx2, eg is replaced with a unit matrix Meg of ι×ι, and multiplicative expressions are replaced with additive expressions (for example αβγ is replaced with α·β+γ). Furthermore, “pseudo-free action” in the sixth embodiment is defined as follows.
Pseudo-Free Action:
An Upper Bound of the Probability
Pr[αM·aM and αM≠Meg|aMεUΩM,αMεMX1,βMεMX2]
of satisfying αM·aM=βM for all possible MX1 and MX2 is called a pseudo-free indicator of a pair (GM, ΩM) and is represented as P(GM, ΩM), where GM is a matrix, ΩM is a set of matrices ΩM={0M, . . . , MM}, αM and βM are realizations αMεMX1 (αM≠Meg) and βMεMX2 of random variables MX1 and MX2 on GM, and aMεΩM. If a certain negligible function ζ(k) exists and
P(GM,ΩM)<ζ(k)
then a computation defined by the pair (GM, ΩM) is called a pseudo-free action.
[Variations of First to Sixth Embodiments]
As has been described above, the capability providing apparatus provides first output information z1 and second output information z2 to the computing apparatus without providing a decryption key and the computing apparatus outputs ub′va′ in the embodiments described above. The probability of ub′va′ being the decryption value of the ciphertext x is high. Thus, the capability providing apparatus can provide the decryption capability to the computing apparatus without providing a decryption key.
Note that the present invention is not limited to the embodiments described above. For example, the random variables X1, X2 and X3 may be the same or different. Similarly, the random variables MX1 and MX2 may be the same or different.
Each of the first random number generator, the second random number generator, the third random number generator, the fourth random number generator, the fifth random number generator, the sixth random number generator and the seventh random number generator generates uniform random numbers to achieve the highest security of the proxy computing system. However, if the level of security required is not so high, at least some of the first random number generator, the second random number generator, the third random number generator, the fourth random number generator, the fifth random number generator, the sixth random number generator and the seventh random number generator may generate random numbers that are not uniform random numbers. Similarly, a non-uniform random matrix may be selected in the sixth embodiment instead of uniformly randomly selecting a matrix. While it is desirable from the computational efficiency point of view that random numbers which are natural numbers greater than or equal to 0 and less than KH or random numbers that are natural numbers greater than or equal to 0 and less than KG be selected as in the embodiments described above, random numbers that are natural numbers greater than or equal to KH or KG may be selected instead.
The process of the capability providing apparatus may be performed multiple times each time the computing apparatus provides first input information τ1 and second input information τ2 which are elements of a group H and correspond to the same a and b to the capability providing apparatus. This enables the computing apparatus to obtain a plurality of pieces of first output information z1, second output information z2, and third output information z3 each time the computing apparatus provides first input information τ1 and the second input information τ2 to the capability providing apparatus. Consequently, the number of exchanges and the amount of communication between the computing apparatus and the capability providing apparatus can be reduced. The same applies to the first input information Mτ1 and the second input information Mτ2 of the sixth embodiment.
The computing apparatus may provide a plurality of pieces of first input information τ1 and second input information τ2 to the capability providing apparatus at once and may obtain a plurality of pieces of corresponding first output information z1, second output information z2 and third output information z3 at once. This can reduce the number of exchanges between the computing apparatus and the capability providing apparatus. The same applies to the first input information Mτ1 and the second input information Mτ2 of the sixth embodiment.
Check may be made to see whether u and v obtained at the first computing unit and the second computing unit of any of the first to fifth embodiments are elements of the group G. If u and v are elements of the group G, the process described above may be continued; if u or v is not an element of the group G, information indicating that the computation is impossible, for example, the symbol “⊥” may be output. Similarly, check may be made to see whether uM and vM obtained at the first computing unit and the second computing unit of the sixth embodiment is an element of GM. If uM and vM are elements of GM, the process described above may be continued; if uM or GM is not an element of GM, information indicating that the computation is impossible, for example, the symbol “⊥” may be output.
The units of the computing apparatus may exchange data among them directly or through a memory, which is not depicted. Similarly, the units of the capability providing apparatus may exchange data among them directly or through a memory, which is not depicted.
Furthermore, the processes described above may be performed in time sequence as described, or may be performed in parallel with one another or individually, depending on the throughput of the apparatuses that performs the processes or as needed. It would be understood that other modifications can be made without departing from the spirit of the present invention.
A seventh embodiment of the present invention will be described.
<Configuration>
As illustrated in
As illustrated in
As illustrated in
As illustrated in
<Processes>
Processes of this embodiment will be described below. For the processes, let Gι and Hι be groups (for example commutative groups), ω be an integer greater than or equal to 2, ι=1, . . . , ω, fι(λι) be a decryption function for decrypting a ciphertext λι which is an element of the group Hι with a particular decryption key sι to obtain an element of the group Gι, generators of the groups Gι and Hι be μι,g and μι,h, respectively, Xι,1 and Xι,2 be random variables having values in the group Gι, xι,1 be a realization of the random variable Xι,1, and xι,2 be a realization of the random variable Xι,2. Note that ω in this embodiment is a constant. It is assumed here that a plurality of pairs of natural numbers a(ι) and b(ι) that are relatively prime to each other (a(ι), b(ι)) are stored in the natural number storage 11101 of the computing apparatus 111. The term “natural number” means an integer greater than or equal to 0. Let Iι be a set of pairs of relatively prime natural numbers that are less than the order of the group Gι, then it can be considered that pairs (a(ι), b(ι)) of natural numbers a(ι) and b(ι) corresponding to a subset Sι of Iι are stored in the natural number storage 11101. It is also assumed that a particular decryption key sι is stored in the key storage 12104 of the capability providing apparatus 112-ι in a secure manner. It is assumed that encryption keys pk1, . . . , pkΓ corresponding to the decryption keys s1, . . . , sΓ, respectively, are stored in the key storage 11305 of the decryption control apparatus 113. Examples of the decryption keys sι and encryption keys pkι are secret keys and public keys of public key cryptography. Processes of the computing apparatus 111 are performed under the control of the controller 11113, processes of the capability providing apparatus 112-ι are performed under the control of the controller 11205-ι, and processes of the decryption control apparatus 113 are performed under the control of the controller 11304.
<Encryption Process>
As illustrated in
<<Example 1 of Shares>>
Shares sha1, . . . , shaω are generated so that a bit combination value sha1| . . . |shaω of the ω shares sha1, . . . shaω is the message mes.
<<Example 2 of Shars>>
Shares sha1, . . . , shaω are generated so that the exclusive OR of the ω shares sha1, . . . , sharω is the message mes.
<<Example 3 of Shars>>
The message mes is secret-shared by a secret sharing scheme such as Shamir's secret sharing to generate shares sha1, . . . , shaω (End of description of examples of the method for generating shares).
Then, the encryption unit 11306 encrypts the share shaι with an encryption key pkι to generate a ciphertext λι for each of ι=1, . . . , ω. The generated ciphertexts λ1, . . . , λω are stored in the ciphertext storage 11301 (step S11303).
Then, the ciphertexts λ1, . . . , λω stored in the ciphertext storage 11301 are output from the output unit 11301 and input in the computing apparatus 111 (
<Decryption Process>
A decryption process for decrypting a ciphertext λι according to this embodiment will be described with reference to
First, the natural number selecting unit 11102 of the computing apparatus 111 (
The integer computing unit 11103 uses the sent pair of natural numbers (a(ι), b(ι)) to compute integers a′(ι) and b′(ι) that satisfy the relation a′(ι)a(ι)+b′(ι)b(ι)=1. Since the natural numbers a(ι) and b(ι) are relatively prime to each other, the integers a′(ι) and b′(ι) that satisfy the relation a′(ι)a(ι)+b′(ι)b(ι)=1 definitely exist. Methods for computing such integers are well known. For example, a well-known algorithm such as the extended Euclidean algorithm may be used to compute the integers a′(ι) and b′(ι). Information on the pair of natural numbers (a′(ι), b′(ι)) is sent to the final output unit 11112 (step S11101).
The controller 11113 sets tι=1 (step S11102).
The input information providing unit 11104 of the computing apparatus 111 generates and outputs first input information τι,1 and second input information τι,2 which are elements of a group Hι and each of which corresponds to the input ciphertext λι. Preferably, the first input information τι,1 and the second input information τι,2 are information whose relation with the ciphertext λι is scrambled. This enables the computing apparatus 111 to conceal the ciphertext λι from the capability providing apparatus 112-ι. Preferably, the first input information τι,1 of this embodiment further corresponds to the natural number b(ι) selected by the natural number selecting unit 11102 and the second input information τι,2 further corresponds to the natural number a(ι) selected by the natural number selecting unit 11102. This enables the computing apparatus 111 to evaluate the decryption capability provided by the capability providing apparatus 112-ι with a high degree of accuracy (step S11103).
As illustrated in
The first output information computing unit 11201 uses the first input information τι,1 and the decryption key sι stored in the key storage 11204-ι to correctly compute fι(τι,1) with a probability greater than a certain probability and sets the result of the computation as first output information zι,1 (step S11201). The second output information computing unit 11202-ι uses the second input information τι,2 and the decryption key sι stored in the key storage 11204-ι to correctly computes fι(τι,2) with a probability greater than a certain probability and sets the result of the computation as second output information zι,2 (step S11202). Note that the “certain probability” is a probability less than 100%. An example of the “certain probability” is a nonnegligible probability and an example of the “nonnegligible probability” is a probability greater than or equal to 1/ψ(k), where ψ(k) is a polynomial that is a weakly increasing function (non-decreasing function) for a security parameter k. That is, the first output information computing unit 11201-ι and the second output information computing unit 11202-ι can output computation results that have an intentional or unintentional error. In other words, the result of the computation by the first output information computing unit 11201-ι may or may not be fι(τι,1) and the result of the computation by the second output information computing unit 11202-ι may or may not be fι(τι,2). The first output information computing unit 11201-ι outputs the first output information zι,1 and the second output information computing unit 11202-ι outputs the second output information zι,2 (step S11203).
Returning to
The first computing unit 11105 generates computation result uι=fι(λι)b(ι)xι,1 from the first output information zι,1. Here, generating (computing) fι(λι)b(ι)xι,1 means computing a value of a formula defined as fι(λι)b(ι)xι,1. Any intermediate computation method may be used, provided that the value of the formula fι(λι)b(ι)xι,1 can eventually be computed. The same applies to computations of the other formulae that appear herein. The result uι of the computation is sent to the first power computing unit 11106 (step S11105).
The first power computing unit 11106 computes uι′=uιa(ι). The pair of the result uι of the computation and uι′ computed on the basis of the result of the computation, (uι, uι′), is stored in the first list storage 11107 (step S11106).
The determining unit 11111 determines whether or not there is a pair that satisfies uι′=vι′ among the pairs (uι, uι′) stored in the first list storage 11107 and the pairs (vι, vι′) stored in the second list storage 11110 (step S11107). If no pair (vι, vι′) is stored in the second list storage 11110, the process at step S11107 is omitted and the process at step S11108 is performed. If there is a pair that satisfies uι′=vι′, the process proceeds to step S11114; if there is not a pair that satisfies uι′=vι′, the process proceeds to step S11108.
At step S11108, the second computing unit 11108 generates a computation result vι=fι(λι)a(ι)xι,2 from the second output information zι,2. The result vι of the computation is sent to the second power computing unit 11109 (step S11108).
The second power computing unit 11109 computes vι′=vιb(ι). The pair of the result vι of the computation and vι′ computed on the basis of the computation result, (vι, vι′), is stored in the second list storage 11110 (step S11109).
The determining unit 11111 determines whether or not there is a pair that satisfies uι′=vι′ among the pairs (uι, uι′) stored in the first list storage 11107 and the pairs (vι, vι′) stored in the second list storage 11110 (step S11110). If there is a pair that satisfies uι′=vι′, the process proceeds to step S11114. If there is not a pair that satisfies uι′=vι′, the process proceeds to step S11111.
At step S11111, the controller 11113 determines whether or not tι=Tι (step S11111). Here, Tι is a predetermined natural number. If tι=Tι, the final output unit 11112 outputs information indicating that the computation is impossible, for example the symbol “⊥” (step S11113) and the process ends. If not tι=Tι, the controller 11113 increments tι by 1, that is, sets tι=tι+1 (sets tι+1 as a new tι) (step S11112) and the process returns to step S11103.
The information indicating the computation is impossible (the symbol “⊥” in this example) means that the reliability that the capability providing apparatus 112-ι correctly performs computation is lower than a criterion defined by Tι. In other words, it means that the capability providing apparatus 112-ι was unable to perform a correct computation in Tι trials.
At step S11114, the final output unit 11112 uses uι and vι that correspond to uι′ and vι′ that are determined to satisfy uι′=vι′ to calculate and output uιb′(ι)vιa′(ι) (step S11114). The uιb′(ι)vιa′(ι) thus computed will be a result fι(λι) of decryption of the ciphertext λι with the particular decryption key sι with a high probability (the reason why uιb′(ι)vιa′(ι)=fι(λι) with a high probability will be described later). Therefore, the process described above is repeated multiple times and the value obtained with the highest frequency among the values obtained at step S11114 can be provided as the result of decryption fι(λ). As will be described later, uιb′(ι)vιa′(ι)=fι(λι) can result with an overwhelming probability, depending on settings. In that case, the value obtained at step S11114 can be directly provided as the result of decryption fι(λι).
The decryption results fι(λι) obtained by performing the process described above on each of ι=1, . . . , ω are input in the recovering unit 11100. The recovering unit 11100 uses fι(λι)=uιb′(ι)vιa′(ι) for each ι=1, . . . , ω to perform a recovering process for obtaining a recovered value that can be recovered only if all of decrypted values that can be obtained by decrypting a ciphertext λι for each ι=1, . . . , ω with the decryption key sι are obtained. For example, if the shares have been generated by <<Example 1 of shares>> described above, the recovering unit 11100 generates a bit combination value f1(λ1)| . . . |fω(λω) as the recovered value mes′. For example if the shares have been generated by <<Example 2 of shares>> described above, the recovering unit 11100 generates the exclusive OR of the decryption results f1(λ1), . . . , fω(λω) as the recovered value mes′. For example, if the shares have been generated by <<Example 3 of shares>> described above, the recovering unit 11100 generates the recovered value mes′ from the decryption results f1(λ1), . . . , fω(λω) by using a recovering method corresponding to the secret sharing scheme.
If all of the decryption results f1(λ1), . . . , fω(λω) are correct, the recovered value mes′ obtained by the recovering unit 11100 is equal to the message mes. On the other hand, if all of the decryption results fι(λι), fω(λω) are incorrect, the probability that the recovered value mes′ obtained by the recovering unit 11100 is equal to the message mes is negligibly small.
<<Reason why uιb′(ι)vιa′(ι)=fι(λι) with High Probability>>
For simplicity of notation, ι is omitted in the following description.
Let X be a random variable having a value in the group G. For wεG, an entity that returns wx′ corresponding to a sample x′ according to the random variable X in response to each request is called a sampler having an error X for w.
For wεG, an entity that returns wax′ corresponding to a sample x′ according to a random variable X whenever a natural number a is given is called a randomizable sampler having an error X for w. The randomizable sampler functions as the sampler if used with a=1.
The combination of the input information providing unit 11104, the first output information computing unit 11201 and the first computing unit 11105 of this embodiment is a randomizable sampler having an error X1 for f(λ) (referred to as the “first randomizable sampler”) and the combination of the input information providing unit 11104, the second output information computing unit 11202 and the second computing unit 11108 is a randomizable sampler having an error X2 for f(λ) (referred to as the “second randomizable sampler”).
The inventor has found that if u′=v′ holds, that is, if ua=vb holds, it is highly probable that the first randomizable sampler has correctly computed u=f(λ)b and the second randomizable sampler has correctly computed v=f(λ)a (x1 and x2 are identity elements eg of the group G). For simplicity of explanation, this will be proven in an eleventh embodiment.
When the first randomizable sampler correctly computes u=f(λ)b and the second randomizable sampler correctly computes v=f(λ)a (when x1 and x2 are identity elements eg of the group G), then ub′va′=(f(λ)bx1)b′(f(λ)ax2)a′=(f(λ)beg)b′(f(λ)aeg)a′=(f(λ)bb′egb′f(λ)aa′ega′=f(λ)(bb′+aa′)=f(λ).
For (q1, q2)εI, a function πi is defined by πi(q1, q2)=qi for each of i=1, 2. Let L=min (#π1(S), #π2(S)), where #• is the order of a set •. If the group G is a cyclic group or a group whose order is difficult to compute, it can be expected that the probability that an output other than “⊥” of the computing apparatus 111 is not f(λ) is at most approximately T2L/#S within a negligible error. If L/#S is a negligible quantity and T is a quantity approximately equal to an polynomial order, the computing apparatus 111 outputs a correct fι(λ) with an overwhelming probability. An example of S that results in a negligible quantity of L/#S is S={(1, d)|dε[2, |G|−1]}.
<Decryption Control Process>
A decryption control process of this embodiment will be described below.
When the decryption control apparatus 113 controls the decryption process performed by the computing apparatus 111, the decryption control apparatus 113 outputs a decryption control instruction that controls the decryption process of the computing apparatus 111 to all of the capability providing apparatuses 112-ι. The capability providing apparatuses 112-ι in which the decryption control instruction is input controls whether to output both of first output information zι,1 and second output information zι,2 according to the input decryption control instruction. The computing apparatus 111 cannot decrypt the ciphertext λι unless the first output information zι,1 and second output information zι,2 are provided. Therefore, the decryption capability of the computing apparatus 111 can be controlled by controlling whether or not to output both of the first output information zι,1 and second output information zι,2. Exemplary methods for controlling the decryption process will be described below.
<<Example 1 of Method for Controlling Decryption Process>>
In example 1 of the method for controlling the decryption process, decryption control instructions include a decryption restricting instruction com1-ι for restricting the decryption capability of the computing apparatus 111. When the decryption restricting instruction com1-ι is input in the controller 11205-ι of the capability providing apparatus 112-ι, the controller 11205-ι prevents output of both of the first output information zι,1 and the second output information zι,2.
To restrict the decryption capability of the computing apparatus 111, the control instruction unit 11302 of the decryption control apparatus 113 (
The controller 11205-ι of the capability providing apparatus 112-ι (
In the decryption restriction mode, the controller 11205-ι prevents the first output information computing unit 11201-ι from outputting first output information zι,1 and also prevents the second output information computing unit 11202-ι from outputting second output information zι,2. An example of control to prevent output of the first output information zι,1 and/or the second output information zι,2 is control to prevent output of the first output information zι,1 and the second output information zι,2 without preventing generation of the output information zι,1 and/or the second output information zι,2. Another example of control to prevent output of the first output information zι,1 and/or the second output information zι,2 is control to causing the first output information computing unit 11201-ι and the second output information computing unit 11202-ι to output dummy information instead of the first output information zι,1 and/or the second output information zι,2. Note that an example of the dummy information is a random number or other information that is independent of the ciphertexts λι. Another example of control to prevent output of the first output information zι,1 and/or the second output information zι,2 is control to prevent generation of the first output information zι,1 and the second output information zι,2. If control to prevent generation of the first output information zι,1 and the second output information zι,2 is performed, information required for generating the first output information zι,1 and the second output information zι,2 may optionally be nullified or removed. For example, the decryption key sι stored in the key storage 11204-ι may optionally be nullified or removed.
If output of both of the first output information zι,1 and the second output information zι,2 is prevented, the capability providing apparatus 112-ι outputs neither of the first output information zι,1 and the second output information zι,2 at step S11203. Accordingly, the computing apparatus 111 can obtain neither of the first output information zι,1 and the second output information zι,2 at step S11104 and cannot compute computation results uι and vι. Therefore a correct decryption result fι(λ) cannot be obtained. If correct decryption results fι(λ) cannot be obtained for all ι, the probability that a recovered value mes′ obtained by the recovering unit 11100 will be equal to the message mes is negligibly small. Thus, the decryption capability of the computing apparatus 111 can be restricted.
<<Example 2 of Method for Controlling Decryption Process>>
In example 2 of the method for controlling the decryption process, the decryption control instructions include a decryption permitting instruction com2-ι for removing restriction on the decryption capability of the computing apparatus 111. When the decryption permitting instruction com2-ι is input in the controller 11205-ι of the capability providing apparatus 112-ι, the controller 11205-ι permits output of at least one of the first output information zι,1 and the second output information zι,2. Example 2 of the method for controlling the decryption process is performed when, for example, output of the first output information zι,1 and the second output information zι,2 is to be permitted again after output of both of first output information zι,1 and second output information zι,2 is prevented by example 1 of the method for controlling the decryption process. In that case, if information required for generating the first output information zι,1 and/or the second output information zι,2 has been nullified or removed, the decryption permitting instruction com2-ι may include the information and the information may be re-set in the capability providing apparatus 112-ι. Example 2 of the method for controlling the decryption process may also be performed to permit output of the first output information zι,1 and the second output information zι,2 when, for example, output of both of the first output information zι,1 and the second output information zι,2 is prevented in an initial state.
To remove restriction on the decryption capability of the computing apparatus 111, the control instruction unit 11302 of the decryption control apparatus 113 (
The controller 11205-ι of the capability providing apparatus 112-ι (
If output of both of the first output information zι,1 and the second output information zι,2 is permitted, the capability providing apparatus 112-ι outputs both of the first output information zι,1 and the second output information zι,2 at step S11203. Accordingly, the computing apparatus 111 can obtain both of the first output information zι,1 and the second output information zι,2 at step S11104 and can compute uι or vι as a computation result. Therefore a correct decryption result can be obtained with a high probability. Thus, the restriction on the decryption capability of the computing apparatus 111 can be removed.
<<Example 3 of Method for Controlling Decryption Process>>
In examples 1 and 2 of the method for controlling the decryption process, each decryption control instruction corresponds to any one of ι (corresponds to the decryption function fι) and the controller 11205-ι of the capability providing apparatus 112-ι controls whether to output all of the first output information zι,1 and the second output information zι,2 that correspond to the decryption control instruction (corresponds to the decryption function fι corresponding to the decryption control instruction). However, a decryption control instruction may correspond to a plurality of t and the controller 11205-ι of the capability providing apparatus 112-ι may control whether to output the first output information zι,1 and the second output information zι,2 corresponding to the decryption control instruction.
A proxy computing system of an eighth embodiment is an example that embodies the first randomizable sampler and the second randomizable sampler described above. The following description will focus on differences from the seventh embodiment and repeated description of commonalities with the seventh embodiment, including the decryption control process, will be omitted. In the following description, elements labeled with the same reference numerals have the same functions and the steps labeled with the same reference numerals represent the same processes.
<Configuration>
As illustrated in
As illustrated in
As illustrated in
<Decryption Process>
A decryption process of this embodiment will be described below. In the eighth embodiment, a decryption function fι is a homomorphic function, a group H is a cyclic group, and a generator of the group H is μι,h, the order of the group H is Kι,H, and νι=fι(μι,h). An example of cryptography in which the decryption function fι is a homomorphic function is RSA cryptography. The rest of the assumptions are the same as those in the seventh embodiment, except that the computing apparatus 111 is replaced with the computing apparatus 121 and the capability providing apparatuses 112-1, . . . , 112-Γ are replaced with the capability providing apparatuses 122-1, . . . , 122-Γ.
As illustrated in
<<Process at Step S12103>>
The input information providing unit 12104 of the computing apparatus 121 (
The first random number generator 12104a (
The second random number generator 12104c generates a uniform random number r(ι, 2) that is a natural number greater than or equal to 0 and less than Kι,H. The generated random number r(ι, 2) is sent to the second input information computing unit 12104d and the second computing unit 12108 (step S12103c). The second input information computing unit 12104d uses the input random number r(ι, 2), the ciphertext λι, and a natural number a(ι) to compute second input information τι,2=μι,hr(ι,2)λιa(ι) (step S12103d).
The first input information computing unit 12104b and the second input information computing unit 12104d output the first input information τι,1 and the second input information τι,2 thus generated (step S12103e). Note that the first input information τι,1 and the second input information τι,2 in this embodiment are information whose relation with the ciphertext λι is scrambled by using random numbers r(ι, 1) and r(ι, 2), respectively. This enables the computing apparatus 121 to conceal the ciphertext λι from the capability providing apparatus 122-ι. The first input information τι,1 in this embodiment further corresponds to the natural number b(ι) selected by the natural number selecting unit 11102 and the second input information τι,2 further corresponds to the natural number a(ι) selected by the natural number selecting unit 11102. This enables the computing apparatus 121 to evaluate the decryption capability provided by the capability providing apparatus 122-ι with a high degree of accuracy.
<<Processes at Steps S12200 Through S12203>>
As illustrated in
The first output information computing unit 12201-ι uses the first input information τι,1=μι,hr(ι,1)λιb(ι) and a decryption key sι stored in the key storage 11204-ι to correctly compute fι(μι,hr(ι,1)λιb(ι)) with a probability greater than a certain probability and sets the result of the computation as first output information zι,1. The result of the computation may or may not be correct. That is, the result of the computation by the first output information computing unit 12201-ι may or may not be fι(μι,hr(ι,1)λιb(ι)) (step S12201).
The second output information computing unit 12202-ι uses the second input information τι,2=μι,hr(ι,2)λιa(ι) and the decryption key sι stored in the key storage 11204-ι to correctly compute fι(λι,hr(ι,2)λιa(ι)) with a probability greater than a certain probability and provides the result of the computation as second output information zι,2. The result of the computation may or may not be correct. That is, the result of the computation by the second output information computing unit 12202-ι may or may not be fι(μι,hr(ι,2)λιa(ι)) (step S12202).
The first output information computing unit 12201-ι outputs the first output information zι,1 and the second output information computing unit 12202-ι outputs the second output information zι,2 (step S12203).
<<Processes at Steps S12104 and S12105>>
Returning to
The first computing unit 12105 uses the input random number r(η, 1) and the first output information zι,1 to compute zι,1νη−r(ι,1) and sets the result of the computation as uι. The result uι of the computation is sent to the first power computing unit 11106. Here, uι=zι,1νι−r(ι,1)=fι(λι)b(ι)xι,1. That is, zι,1νι−r(ι,1) is an output of a randomizable sampler having an error Xι,1 for fι(λι). The reason will be described later (step S12105).
<<Process at Step S12108>>
The second computing unit 12108 uses the input random number r(ι, 2) and the second output information zι,2 to compute zι,2νι−r(ι,2) and sets the result of the computation as vι. The result vι of the computation is sent to the second power computing unit 11109. Here, vι=zι,2νι−r(ι,2)fι(λι)a(ι)xι,2. That is, zι,2νι−r(ι,2) is an output of a randomizable sampler having an error λι,2 for fι(λι). The reason will be described later (step S12108).
<<Reason why zι,1νι−r(ι,1) and zι,2νι−r(ι,2) are Outputs of Randomizable Samplers Having Errors Xι,1 and Xι,2, Respectively, for fι(λι)>>
Let c be a natural number, R be a random number, and B(μhRλc) be the result of computation performed by the capability providing apparatus 122 using μhRλc. That is, the results of computations that the first output information computing unit 12201-ι and the second output information computing unit 12202-ι return to the computing apparatus 121 are z=B(μhRλc). A random variable X that has a value in the group G is defined as X=B(μhR′)f(μhR′)−1.
Then, zν−R=B(μhRλc)f(μh)−R=Xf(μhRλc)f(μh)−R=Xf(μh)Rf(λ)cf(μh)−R=f(λ)cX. That is, zν−R is an output of a randomizable sampler having an error X for f(λ).
The expansion of formula given above uses the properties such that X=B(μhR′)f(μhR′)−1=B(μhRλc)f(μhRλc)−1 and that B(μhRλc)=Xf(μhRλc). The properties are based on the fact that the function fι is a homomorphic function and R is a random number.
Therefore, considering that a(ι) and b(ι) are natural numbers and r(ι, 1) and r(ι, 2) are random numbers, zι,1νι−r(ι,1) and zι,2νι−r(ι,2) are, likewise, outputs of randomizable samplers having errors Xι,1 and Xι,2, respectively, for fι(λι).
A ninth embodiment is a variation of the eighth embodiment and computes a value of uι or vι by using samplers described above when a(ι)=1 or b(ι)=1. The amounts of computation performed by samplers in general are smaller than randomizable samplers. Using samplers instead of randomizable samplers for computations when a(ι)=1 or b(ι)=1 can reduce the amount of computation by the proxy computing system. The following description will focus on differences from the seventh and eighth embodiments and repeated description of commonalities with the seventh and eighth embodiments, including the decryption control process, will be omitted.
<Configuration>
As illustrated in
As illustrated in
As illustrated in
<Decryption Process>
A decryption process of this embodiment will be described below. Differences from the eighth embodiment will be described.
As illustrated in
<<Process at Step S13103>>
The input information providing unit 13104 of the computing apparatus 131 (
A process at S13103 of this embodiment will be described below with reference to
The controller 11113 (
Determination is made by the controller 11113 as to whether b is equal to 1 (step S13103a). If it is determined that b≠1, the processes at steps S12103a and 12103b described above are performed and the process proceeds to step S13103g.
On the other hand, if it is determined at step S13103a that b(ι)=1, the third random number generator 13104e generates a random number r(ι 3) that is a natural number greater than or equal to 0 and less than Kι,II. The generated random number r(ι, 3) is sent to the third input information computing unit 13104f and the third computing unit 13109 (step S13103b). The third input information computing unit 13104f uses the input random number r(ι, 3) and the ciphertext λι to compute λιr(ι,3) and sets it as first input information τι,1 (step S13103c). Then the process proceeds to step S13103g.
At step S13103g, determination is made by the controller 11113 as to whether a(ι) is equal to 1 (step S13103g). If it is determined that a(ι)≠1, the processes at steps S12103c and S12103d described above are performed.
On the other hand, if it is determined at step S13103g that a(ι)=1, the third random number generator 3104e generates a random number r(ι, 3) that is a natural number greater than or equal to 0 and less than Kι,H. The generated random number r(ι, 3) is sent to the third input information computing unit 13104f (step S13103h). The third input information computing unit 13104f uses the input random number r(ι, 3) and the ciphertext λι to compute λιr(ι,3) and sets it as second input information τι,2 (step S13103i).
The first input information computing unit 12104b, the second input information computing unit 12104d, and the third input information computing unit 13104f output the first input information τι,1 and the second input information τι,2 thus generated along with information on corresponding natural numbers (a(ι), b(ι)) (step S13103e). Note that the first input information τι,1 and the second input information τι,2 in this embodiment are information whose relation with the ciphertext λι is scrambled by using the random numbers r(ι, 1), r(ι, 2), and r(ι, 3), respectively. This enables the computing apparatus 131 to conceal the ciphertext λι from the capability providing apparatus 132-ι.
<<Processes at S12200 Through S12203 and S13205 Through S13209>>
Processes at S12200 through S12203 and S13205 through S13209 of this embodiment will be described below with reference to
The controller 11205-ι (
Under the control of the controller 11205-ι, the first input information τι,1=μι,hr(ι,1)λιb(ι) when b(ι)≠1 is input in the first output information computing unit 12201-ι of the capability providing apparatus 132-ι (
Determination is made by the controller 11113 as to whether b(ι) is equal to 1 (step S13205). If it is determined that b(ι)≠1, the process at step S12201 described above is performed. Then, determination is made by the controller 11113 as to whether a(ι) is equal to 1 (step S13208). If it is determined that a(ι)≠1, the process at step S12202 described above is performed and then the process proceeds to step S13203.
On the other hand, if it is determined at step S13208 that a(ι)=1, the third output information computing unit 13203-ι uses the second input information τι,2=λιr(ι,3) to correctly compute fι(λιr(ι,3)) with a probability greater than a certain probability and sets the obtained result of the computation as third output information zι,3. The result of the computation may or may not be correct. That is, the result of the computation by the third output information computing unit 13203-ι may or may not be fι(λιr(ι,3)) (step S13209). Then the process proceeds to step S13203.
If it is determined at step S13205 that b(ι)=1, the third output information computing unit 13203-ι uses the second input information τι,1=λιr ι,3) to correctly compute fι(λιr(ι,3)) with a probability greater than a certain probability and sets the obtained result of the computation as third output information zι,3. The result of the computation may or may not be correct. That is, the result of the computation by the third output information computing unit 13203-ι may or may not be fι(λιr(ι,3)) (step S13206).
Then, determination is made by the controller 11113 as to whether a(ι) is equal to 1 (step S13207). If it is determined that a(ι)=1, the process proceeds to step S13203; if it is determined a(ι)≠1, the process proceeds to step S12202.
At step S13203, the first output information computing unit 12201-ι, which has generated the first output information zι,1, outputs the first output information zι,1, the second output information computing unit 12202-ι, which has generated the second output information zι,2, outputs the second output information zι,2, and the third output information computing unit 13203-ι, which has generated the third output information zι,3, outputs the third output information zι,3 (step S13203).
<<Processes at Steps S13104 and S13105>>
Returning to
If b(ι)≠1, the first computing unit 12105 performs the process at step S12105 described above to generate uι; if b(ι)=1, the third computing unit 13109 computes zι,31/r(ι,3) and sets the result of the computation as uι. The result uι of the computation is sent to the first power computing unit 11106. Here, if b(ι)=1, then uι=zι,31/r(ι,3)=fι(λι)xι,3. That is, zι,31/r(ι,3) serves as a sampler having an error Xι,3 for fι(λι). The reason will be described later (step S13105).
<<Process at Step S13108>>
If a(ι)≠1, the second computing unit 12108 performs the process at step S12108 to generate vι; if a(ι)=1, the third computing unit 13109 computes zι,31/r(ι,3) and sets the result of the computation as vι. The result vι of the computation is sent to the second power computing unit 11109. Here, if a(ι)=1, then vι=zι,31/r(ι,3)=fι(λι)xι,3. That is, zι,31/r(ι,3) serves as a sampler having an error Xι,3 for fι(λι). The reason will be described later (step S13108).
Note that if zι,31/r(ι,3), that is, the radical root of zι,3, is hard to compute, uι and/or vι may be calculated as follows. The third computing unit 13109 may store each pair of the random number r(ι, 3) and zι,3 computed on the basis of the random number r(ι, 3) in a storage, not depicted, in sequence as (α1, β1), (α2, β2), . . . , (αm(ι), βm(ι), . . . . Here, m(ι) is a natural number greater than or equal to 1. The third computing unit 13109 may compute γ1, γ2, . . . , γm(ι) that satisfies γ1α1+γ2α2+ . . . +γm(ι)αm(ι)=1 if the least common multiple of α1, α2, . . . , αm(ι) is 1, where γ1, γ2, . . . , γm(ι) are integers. The third computing unit 13109 then may use the resulting γ1, γ2, . . . , γm(ι) to compute Πi=1m(ι)βiγi=β1γ1β2γ2 . . . βm(ι)γm(ι) and may set the results of the computation as uι and/or vι. Note that when a notation αβγ is used herein in this way, βγ represents βγ, namely β with subscript γ, where α is a first letter, β is a second letter, and γ is a number.
<<Reason why zι,31/r(ι,3) Serves as a Sampler Having an Error Xι,3 for fι(λι)>>
Let R and R′ be random numbers and B(λR) be the result of computation performed by the capability providing apparatus 132-ι by using λR. That is, let z=B(xR) be the results of computations returned by the first output information computing unit 12201-ι, the second output information computing unit 12202-ι, and the third output information computing unit 13203-ι to the computing apparatus 131. Furthermore, a random variable X having a value in the group G is defined as X=B(λR)1/Rf(λ)−1.
Then z1/R=B(λR)1/R=Xf(λ)=f(λ)X. That is, z1/R serves as a sampler having an error X for f(λ).
The expansion of formula given above uses the properties such that X=B(λR)1/Rf(λR)−1 and that B(λR)1/R=Xf(λR). The properties are based on the fact that R and R′ are random numbers.
Therefore, considering that r(ι, 3) is a random number, zι,31/r(ι,3) serves as a sampler having an error Xι,3 for fι(λι), likewise.
A proxy computing system of a tenth embodiment is another example that embodies the first and second randomizable samplers described above. Specifically, the proxy computing system embodies an example of the first and second randomizable samplers in the case where Hι=Gι×Gι and the decryption function fι is a decryption function of ElGamal encryption, that is, fι(cι,1, cι,2)=cι,1·cι,2−sι for a decryption key sι and a ciphertext λι=(cι,1, cι,2). The following description will focus on differences from the seventh embodiment and repeated description of commonalities with the seventh embodiment, including the decryption control process, will be omitted.
As illustrated in
As illustrated in
As illustrated in
<Decryption Process>
A decryption process of this embodiment will be described below. In the tenth embodiment, it is assumed that a group Hι is the direct product group Gι×Gι of a group Gι, the group Gι is a cyclic group, a ciphertext λι=(cι,1, cι,2)εHι, fι(cι,1, cι,2) is a homomorphic function, a generator of the group Gι is μι, g, the order of the group Gι is Kι,G, a pair of a ciphertext (Vι, Wι)ιHι and a decrypted text fι(Vι, Wι)=YιεGι decrypted from the ciphertext for the same decryption key sι is preset in the computing apparatus 141 and the capability providing apparatus 142-ι, and the computing apparatus 141 and the capability providing apparatus 142-ι can use the pair.
As illustrated in
<<Process at Step S14103>>
The input information providing unit 14104 of the computing apparatus 141 (
The fourth random number generator 14104a (
The fourth input information computing unit 14104ca uses a natural number b(ι) selected by the natural number selecting unit 11102, cι,2 included in the ciphertext λι, and the random number r(ι, 4) to compute fourth input information cι,2b(ι)Wιr(ι,4) (step S14103c). The fifth input information computing unit 14104cb uses the natural number b(ι) selected by the natural number selecting unit 11102, cι,1 included in the ciphertext λι, and random numbers r(ι, 4) and r(ι, 5) to compute fifth input information cι,1b(ι)Vιr(ι,4)μι,gr(ι,5) (step S14103d).
The sixth random number generator 14104d generates a uniform random number r(ι, 6) that is a natural number greater than or equal to 0 and less than Kι,G. The generated random number r(ι, 6) is sent to the sixth input information computing unit 14104fa, the seventh input information computing unit 14104fb, and the second computing unit 14108 (step S14103e). The seventh random number generator 14104e generates a uniform random number r(ι 7) that is a natural number greater than or equal to 0 and less than Kι,G. The generated random number r(ι, 7) is sent to the seventh input information computing unit 14104fb and the second computing unit 14108 (step S14103f).
The sixth input information computing unit 14104fa uses a natural number a(ι) selected by the natural number selecting unit 11102, cι,2 included in the ciphertext λι, and the random number r(ι, 6) to compute sixth input information cι,2a(ι)Wιr(ι,6) (step S14103g). The seventh input information computing unit 14104fb uses a natural number a(ι) selected by the natural number selecting unit 11102, cι,1 included in the ciphertext λι, and the random numbers r(ι, 6) and r(i, 7) to compute seventh input information cι,1a(ι)Vι(ι,6)μι,gr(ι,7) (step S14103h).
The first input information computing unit 14104c outputs the fourth input information cι,2b(ι)Wιr(ι,4) and the fifth input information cι,1b(ι)Vιr(ι,4)μι,gr(ι,5) generated as described above as first input information τι,1=(cι,2b(ι)Wιr(ι,4), cι,1b(ι)Vιr(ι,4)μι,gr(ι,5)). The second input information computing unit 14104f outputs the sixth input information cι,2a(ι)Wιr(ι,6) and the seventh input information cι,1a(ι)Vιr(ι,6)μι,gr(ι,7) generated as described above as second input information τι,2=(cι,2a(ι)Wιr(ι,6), cι,1a(ι)Vιr(ι,6)μι,gr(ι,7)) (step S14103i).
<<Processes at Steps S14200 Through S14203>>
As illustrated in
The first output information computing unit 14201-ι uses the first input information τι,1=(cι,2b(ι)Wιr(ι,4), cι,1b(ι)Vιr(ι,4)μι,g(ι,5)) and the decryption key sι stored in the key storage 11204-ι to correctly compute fι(cι,1b(ι)Vιr(ι,4)μι,gr(ι,5), cι,2b(ι)Wιr(ι,4)) with a probability greater than a certain probability and sets the result of the computation as first output information zι,1. The result of the computation may or may not be correct. That is, the result of the computation by the first output information computing unit 14201-ι may or may not be fι(cι,1b(ι)Vιr(ι,4)μι,gr(ι,5), cι,2b(ι)Wιr(ι,4)) (step S14201).
The second output information computing unit 14202-ι can correctly compute fι(Cι,1a(ι)Vιr(ι,6)μι,gr(ι,7), cι,2a(ι)Wιr(ι,6)) with a probability greater than a certain probability by using the second input information τι,2=(cι,2a(ι)Wιr(ι,6), cι,1a(ι)Vιr(ι,6)μι,gr(ι,7)) and the decryption key sι stored in the key storage 11204-ι and provides the result of the computation as second input information zι,2. The result of the computation may or may not be correct. That is, the result of the computation by the second output information computing unit 14202-ι may or may not be fι(cι,1a(ι)Vιr(ι,6)Vι,gr(ι,7), cι,2a(ι)Wιr(ι,6)) (step S14202).
The first output information computing unit 14201-ι outputs the first output information zι,1 and the second output information computing unit 14202-ι outputs the second output information zι,2 (step S14203).
<<Processes at Steps S14104 and S14105>>
Returning to
The first computing unit 14105 uses the input first output information zι,1 and the random numbers r(ι, 4) and r(ι, 5) to compute zι,1Yι−r(ι,4)μι,g−r(ι,5) and sets the result of the computation as uι (step S14105). The result uι of the computation is sent to the first power computing unit 11106. Here, uι=zι,1Yι−r(ι,4)μι,g−r(ι,5)=fι(cι,1, cι,2)b(ι)xι,1. That is, zι,1 Yι−r(ι,4)μι,g−r(ι,5) is an output of a randomizable sampler having an error Xι,1 for fι(cι,1, cι,2). The reason will be described later.
<<Process at Step S14108>>
The second computing unit 14108 uses the input second output information zι,2 and the random numbers r(ι, 6) and r(ι, 7) to compute zι,2Yι−r(ι,6)μι,g−r(ι,7) and sets the result of the computation as vι. The result vι of the computation is sent to the second power computing unit 11109. Here, vι=zι,2Yι−r(ι,6)μι,g−r(ι,7)=fι(cι,1, cι,2)a(ι)xι,2. That is, zι,2Yι−r(ι,6)μι,g−r(ι,7) is an output of a randomizable sampler having an error Xι,2 for fι(cι,1, cι,2). The reason will be described later.
<<Reason why zι,1Y−r(ι,4)μι,g−r(ι,5) and zι,2Y−r(ι,6)μι,g−r(ι,7) are Outputs of Randomizable Samplers Having Errors Xι,1 and Xι,2, Respectively, for (cι,1, cι,2)>>
Let c be a natural number, R1, R2, R1′ and R2′ be random numbers, and B(c1cVR1μgR2, c2cWR1) be the result of computation performed by the capability providing apparatus 142-ι by using c1cVR1μgR2 and c2cWR1. That is, and the first output information computing unit 14201-ι and the second output information computing unit 14202-ι return z=B(c1cVR1μgR2, c2cWR1) as the results of computations to the computing apparatus 141. A random variable X having a value in a group G is defined as X=B(VR1′μgR2′, WR1′)f(VR1′μgR2′, WR1′)−1.
Then, zY−R1μg−R2=B(c1cVR1μgR2, c2cWR1)Y−R1μg−R2=Xf(c1cVR1μgR2, c2cWR1)Y−R1μg−R2=Xf(c1, c2)cf(V, W)R1f(μg, eg)R2Y−R1μg−R2=Xf(c1, c2)cYR1μgR2Y−R1μg−R2=f(c1, c2)cX. That is, zY−R1μg−R2 is an output of a randomizable sampler having an error X for f(x). Note that eg is an identity element of the group G.
The expansion of formula given above uses the properties such that X=B(VR1′)μgR2′, WR1′)f(VR1′μgR2′, WR1′)−1=B(c1cVR1μgR2, c2cWR1)f(c1cVR1μgR2, c2cWR1) and that B(c1cVR1μgR2, c2cWR1)=Xf(c1cVR1μgR2, c2cWR1). The properties are based on the fact that R1, R2, R1′ and R2′ are random numbers.
Therefore, considering that a(ι) and b(ι) are natural numbers and r(ι, 4), r(ι, 5), r(ι, 6) and r(ι, 7) are random numbers, zι,1Yι−r(ι,4)μι,g−r(ι,5) and zι,2Yι−r(ι,6)μι,g−r(ι,7) are outputs of randomizable samplers having errors Xι,1 and Xι,2, respectively, for fι(cι,1, cι,2).
In the seventh to tenth embodiments described above, a plurality of pairs (a(ι), b(ι)) of natural numbers a(ι) and b(ι) that are relatively prime to each other are stored in the natural number storage 11101 of the computing apparatus and these pairs (a(ι), b(ι)) are used to perform processes. However, one of a(ι) and b(ι) may be a constant. For example, a(ι) may be fixed at 1 or b(ι) may be fixed at 1. Which of natural number a(ι) and b(ι) is a constant may be varied depending on ι. In other words, one of the first randomizable sampler and the second randomizable sampler may be replaced with a sampler. If one of a(ι) and b(ι) is a constant, the need for the process for selecting the constant a(ι) or b(ι) is eliminated, the constant a(ι) or b(ι) is not input in the processing units and the processing units can treat it as a constant to perform computations. If a(ι) or b(ι) set as a constant is equal to 1, fι(λι)=uιb′(ι)vιa′(ι) can be obtained as fι(λι)=vι or fι(λι)=uι without using a′(ι) or b′(ι).
An eleventh embodiment is an example of such a variation, in which b(ι) is fixed at 1 and the second randomizable sampler is replaced with a sampler. The following description will focus on differences from the seventh embodiment and description of commonalities with the seventh embodiment, including the decryption control process, will be omitted. Specific examples of the first randomizable sampler and the sampler are similar to those described in the eighth to tenth embodiments and therefore description of the first randomizable sampler and the sampler will be omitted.
<Configuration>
As illustrated in
As illustrated in
As illustrated in
<Decryption Process>
A decryption process of this embodiment will be described below. For the decryption process, let Gι and Hι be groups (for example commutative groups), fι(λι) be a decryption function for decrypting a ciphertext λι, which is an element of the group Hι, with a particular decryption key sι to obtain an element of the group Gι, generators of the groups Gι and Hι be μι,g and μι,h, respectively, Xι,1 and Xι,2 be random variables having values in the group Gι, xι,1 be a realization of the random variable Xι,1 and xι,2 be a realization of the random variable Xι,2. It is assumed here that a plurality of natural numbers a(ι) are stored in the natural number storage 15101 of the computing apparatus 151.
As illustrated in
The controller 11113 sets tι=1 (step S11102).
The input information providing unit 15104 generates and outputs first input information τι,1 and second input information τι,2 each of which corresponds to the input ciphertext λι. Preferably, the first input information τι,1 and the second input information τι,2 are information whose relation with the ciphertext λι is scrambled. This enables the computing apparatus 151 to conceal the ciphertext λι from the capability providing apparatus 152-ι. Preferably, the second input information τι,2 of this embodiment further corresponds to the natural number a(ι) selected by the natural number selecting unit 15102. This enables the computing apparatus 151 to evaluate the decryption capability provided by the capability providing apparatus 152-ι with a high degree of accuracy (step S15103). A specific example of the pair of the first input information τι,1 and the second input information τι,2 is a pair of first input information τι,1 and the second input information τι,2 of any of the eighth to tenth embodiments when b(ι)=1.
As illustrated in
The first output information computing unit 15201-ι uses the first input information τι,1 and the decryption key sι stored in the key storage 11204-ι to correctly compute fι(τι,1) with a probability greater than a certain probability and sets the result of the computation as first output information zι,1 (step S15201). The second output information computing unit 15202-ι uses the second input information τι,2 and the decryption key sι stored in the key storage 11204-ι to correctly compute fι(τι,2) with a probability greater than a certain probability and sets the result of the computation as second output information zι,2 (step S15202). That is, the first output information computing unit 15201-ι and the second output information computing unit 15202-ι output computation results that have an intentional or unintentional error. In other words, the result of the computation by the first output information computing unit 15201-ι may or may not be fι(τι,1) and the result of the computation by the second output information computing unit 15202-ι may or may not be fι(τι,2). A specific example of the pair of the first output information zι,1 and the second output information zι,2 is a pair of first output information zι,1 and the second output information zι,2 of any of the eighth to tenth embodiments when b(ι)=1.
The first output information computing unit 15201-ι outputs the first output information zι,1 and the second output information computing unit 15202-ι outputs the second output information zι,2 (step S15203).
Returning to
The first computing unit 15105 generates a computation result uι=fι(λι)xι,1 from the first output information zι,1. A specific example of the computation result uι is a result uι of computation of any of the eighth to tenth embodiments when b(ι)=1. The computation result uι is sent to the first power computing unit 11106 (step S15105).
The first power computing unit 11106 computes uι′=uιa(ι). The pair of the result uι of the computation and uι′ computed on the basis of the result of the computation, (uι, uι′), is stored in the first list storage 11107 (step S11106).
The second computing unit 15108 generates a computation result vι=fι(λι)a(ι)xι,2 from the second output information zι,2. A specific example of the result vι of the computation is a result vι of the computation in any of the eighth to tenth embodiments. The result vι of the computation is stored in the second list storage 15110 (step S15108).
The determining unit 15111 determines whether or not there is one that satisfies uι′=vι among the pairs (uι, uι′) stored in the first list storage 11107 and vι stored in the second list storage 15110 (step S15110). If there is one that satisfies uι′=vι, the process proceeds to step S15114; if there is not one that satisfies uι′=vι, the process proceeds to step S11111.
At step S11111, the controller 11113 determines whether or not tι=Tι (step S11111). Here, Tι is a predetermined natural number. If tι=Tι, the final output unit 15112 outputs information indicating that the computation is impossible, for example, the symbol “⊥” (step S11113), then the process ends. If not tι=Tι, the controller 11113 increments tι by 1, that is, sets tι=tι+1 (step S11112), then the process returns to step S15103.
At step S15114, the final output unit 15112 outputs uι corresponding to uι′ determined to satisfy uι′=vι (step S15114). The obtained uι is equivalent to uιb′(ι)vιa′(ι) in the seventh to tenth embodiments when b(ι)=1. That is, uι thus obtained can be the decryption result fι(λι) resulting from decrypting the ciphertext λι with the particular decryption key sι with a high probability. Therefore, the process described above is repeated multiple times and the value that has most frequently obtained among the values obtained at step S15114 can be chosen as the decryption result fι(λι). As will be described later, uι=fι(λι) can result with an overwhelming probability, depending on settings. In that case, the value obtained at step S15114 can be directly provided as a result of decryption fι(λι). The rest of the process is as described in the seventh embodiment.
<<Reason why Decryption Result fι(λι) can be Obtained>>
The reason why a decryption result fι(kι) can be obtained on the computing apparatus 151 of this embodiment will be described below. For simplicity of notation, ι will be omitted in the following description. Terms required for the description will be defined first.
Black-Box:
A black-box F(τ) of f(τ) is a processing unit that takes an input of τεH and outputs zεG. In this embodiment, each of the first output information computing unit 15201 and the second output information computing unit 15202 is equivalent to the black box F(τ) for the decryption function f(τ). A black-box F(τ) that satisfies z=f(τ) for an element τεUH arbitrarily selected from a group H and z=F(τ) with a probability greater than δ (0<δ≦1), that is, a black-box F(τ) for f(τ) that satisfies
Pr[z=f(τ)|τεUH,z=F(τ)]>δ (8)
is called a δ-reliable black-box F(τ) for f(τ). Here, δ is a positive value and is equivalent to the “certain probability” stated above.
Self-Corrector
A self-corrector CF(λ) is a processing unit that takes an input of λεH, performs computation by using a black-box F(τ) for f(τ), and outputs jεG∪⊥. In this embodiment, the computing apparatus 151 is equivalent to the self-corrector CF(λ).
Almost Self-Corrector:
Assume that a self-corrector CF(λ) that takes an input of λεH and uses a δ-reliable black-box F(τ) for f(τ) to perform computation outputs a correct value j=f(λ) with a probability sufficiently greater than the provability with which the self-corrector CF(λ) outputs an incorrect value j≠f(λ).
That is, assume that a self-corrector CF(λ) satisfies
Pr[j=f(λ)|j=CF(λ),j≠⊥]>Pr[j≠f(λ)|j=CF(λ),j≠⊥]+Δ (9)
Here, Δ is a certain positive value (0<Δ<1). If this is the case, the self-corrector CF(λ) is called an almost self-corrector. For example, for a certain positive value Δ′ (0<Δ′<1), if a self-corrector CF(λ) satisfies
Pr[j=f(λ)|j=CF(λ)]>(⅓)+Δ′
Pr[j=⊥|j=CF(λ)]<⅓
Pr[j≠f(λ) and j≠⊥|j=CF(λ)]<⅓,
then the self-corrector CF(λ) is an almost self-corrector. Examples of Δ′ include Δ′= 1/12 and Δ′=⅓.
Robust Self-Corrector:
Assume that a self-corrector CF(λ) that takes an input of λεH and uses a δ-reliable black-box F(τ) for f(τ) outputs a correct value j=f(λ) or j=⊥ with an overwhelming probability. That is, assume that for a negligible error ξ (0≦ξ<1), a self-corrector CF(λ) satisfies
Pr[j=f(λ) or j=⊥|j=CF(λ)]>1−ξ (10)
If this is the case, the self-corrector CF(λ) is called a robust self-corrector. An example of the negligible error ξ is a function vale ξ(k) of a security parameter k. An example of the function value ξ(k) is a function value ξ(k) such that {ξ(k)p(k)} converges to 0 for a sufficiently large k, where p(k) is an arbitrary polynomial. Specific examples of the function value ξ(k) include ξ(k)=2−k and ξ(k)=2−√k.
A robust self-corrector can be constructed from an almost self-corrector. Specifically, a robust self-corrector can be constructed by executing an almost self-corrector multiple times for the same λ and selecting the most frequently output value, except ⊥, as j. For example, an almost self-corrector is executed O(log(1/ξ)) times for the same λ and the value most frequently output is selected as j, thereby a robust self-corrector can be constructed. Here, O(•) represents O notation.
Pseudo-Free Action:
An upper bound of the probability
Pr[αa=β and α≠eg|aεUΩ,αεX1,βεX2] (11)
of satisfying αa=β for all possible X1 and X2 is called a pseudo-free indicator of a pair (G, Ω) and is represented as P(G, Ω), where G is a group, Ω is a set of natural numbers Ω={0, . . . , M} (M is a natural number greater than or equal to 1), α and β are realizations αεX1 (α≠eg) and βεX2 of random variables X1 and X2 that have values in the group G, and aεΩ. If a certain negligible function ζ(k) exists and
P(G,Ω)<ζ(k) (12),
then a computation defined by the pair (G, Ω) is called a pseudo-free action. Note that “αa” means that a computation defined at the group G is applied a times to α. An example of the negligible function ζ(k) is such that {ζ(k)p(k)} converges to 0 for a sufficiently large k, where p(k) is an arbitrary polynomial. Specific examples of the function ζ(k) include ζ(k)=2−k and ζ(k)=2−√k. For example, if the probability of Formula (11) is less than O(2−k) for a security parameter k, a computation defined by the pair (G, Ω) is a pseudo-free action. For example, if the number of the elements |Ω·α| of a set Ω·α={a(α)|aεΩ} exceeds 2k for any ∀αεG where α≠eg, a computation defined by the pair (G, Ω) is a pseudo-free action. Note that a(α) represents the result of a given computation on a and α. There are many such examples. For example, if the group G is a residue group Z/pZ modulo prime p, the prime p is the order of 2k, the set Ω={0, . . . , p−2}, a(α) is αaεZ/pZ, and α≠eg, then Ω·α={αa|a=0, . . . , p−2}={eg, α1, . . . , αp-2} and |Ω·α|=p−1. If a certain constant C exists and k is sufficiently large, |Ω·α|>C2k is satisfied because the prime p is the order of 2k. Here, the probability of Formula (11) is less than C−12−k and a computation defined by such pair (G, Ω) is a pseudo-free action.
δγ-Reliable Randomizable Sampler:
A randomizable sampler that whenever a natural number a is given, uses the δ-reliable black-box F(τ) for f(τ) and returns wax′ corresponding to a sample x′ that depends on a random variable X for wεG and in which the probability that wax′=wa is greater than δγ (γ is a positive constant), that is,
Pr[wax′=wa]>δγ (13)
is satisfied, is called a δγ-reliable randomizable sampler. The combination of the input information providing unit 15104, the second output information computing unit 15202, and the second computing unit 15108 of this embodiment is a δγ-reliable randomizable sampler for w=f(λ).
The definitions given above will be used to describe the reason why a decryption result f(λ) can be obtained by using the computing apparatus 151 of this embodiment.
At step S15110 of this embodiment, determination is made as to whether u′=vι that is, whether ua=v. Since the combination of the input information providing unit 15104, the second output information computing unit 15202, and the second computing unit 15108 of this embodiment is a δγ-reliable randomizable sampler (Formula (13)), ua=v holds (Yes at step S15110) with an asymptotically large probability if T is greater than a certain value determined by k, δ and γ. For example, Markov's inequality shows that if T≧4/δγ, the probability that ua=v holds (Yes at step S15110) is greater than ½.
Since u=f(λ)x1 and v=f(λ)ax2 in this embodiment, x1a=x2 holds if ua=v holds. x1a=x2 holds if x1=x2=eg or x≠eg. If x1=x2=eg, then u=f(λ) and therefore u output at step S15114 is a correct decryption result f(λ). On the other hand, if x1≠eg, then u≠f(λ) and therefore u output at step S15114 is not a correct decryption result f(λ).
If an computation defined by a pair (G, Ω) of a group G and a set Ω to which a natural number a belongs is a pseudo-free action or T2P(G, Ω) is asymptotically small for a pseudo-free index P(G, Ω), the probability that x1≠eg (Formula (11)) when ua=v is asymptotically small. Accordingly, the probability that x1=eg when ua=v is asymptotically large. Therefore, if a computation defined by a pair (G, Ω) is a pseudo-free action or T2P(G, Ω) is asymptotically small, the probability that an incorrect decryption result f(λ) is output when ua=v is sufficiently smaller than the probability that a correct decryption result f(λ) is output when ua=v. In this case, it can be said that the computing apparatus 151 is an almost self-corrector (see Formula (9)). Therefore, a robust self-corrector can be constructed from the computing apparatus 151 as described above and a correct decryption result f(λ) can be obtained with an overwhelming probability. If a computation defined by (G, Ω) is a pseudo-free action, the probability that an incorrect decryption result f(λ) is output when ua=v is also negligible. In that case, the computing apparatus 151 outputs a correct decryption result f(λ) or ⊥ with an overwhelming probability.
Note that “η(k′) is asymptotically small” means that k0 is determined for an arbitrary constant ρ and the function value η(k′) for any k′ that satisfies k0<k′ for k0 is less than ρ. An example of k′ is a security parameter k.
“η(k) is asymptotically large” means that k0 is determined for an arbitrary constant ρ and the function value 1−η(k′) for any k′ that satisfies k0<k′ for k0 is less than ρ.
Note that the proof given above also proves that “if u′=v′ holds, it is highly probable that the first randomizable sampler has correctly computed u=f(λ)b and the second randomizable sampler has correctly computed v=f(λ)a (x1 and x2 are identity elements eg of the group G)” stated in the seventh embodiment, as can be seen by replacing a with a/b.
<<δγ-Reliable Randomizable Sampler and Security>>
Consider the following attack.
Such an attack is possible if the probability distribution Da=wax′w−a of an error of wax′ output from the randomizable sampler for a given natural number a depends on the natural number a. For example, if tampering is made so that v output from the second computing unit 15108 is f(λ)ax1a, always ua=v holds regardless of the value of x1. Therefore, it is desirable that the probability distribution Da=wax′w−a of an error of wax′ output from the randomizable sampler for a given natural number a do not depend on the natural number a.
Alternatively, it is desirable that the randomizable sampler be such that a probability distribution D that has a value in a group G that cannot be distinguished from the probability distribution Da=wax′w−a of an error of wax′ for any element aε∀Ω of a set Ω exists (the probability distribution Da and the probability distribution D are statistically close to each other). Note that the probability distribution D does not depend on a natural number a. That the probability distribution Da and the probability distribution D cannot be distinguished from each other means that the probability distribution Da and the probability distribution D cannot be distinguished from each other by a polynomial time algorithm. For example, if
ΣgεG|Pr[gεD]−Pr[gεDa]|<ζ (14)
is satisfied for negligible ζ (0≦ζ1), the probability distribution Da and the probability distribution D cannot be distinguished from each other by the polynomial time algorithm. An example of negligible ζ is a function value ζ(k) of the security parameter k. An example of the function value ζ(k) is a function value such that {ζ(k)p(k)} converges to 0 for a sufficiently large k, where p(k) is an arbitrary polynomial. Specific examples of the function ζ(k) include ζ(k)=2−k and ζ(k)=2−√k. These facts also apply to the seventh to tenth embodiments which use natural numbers a and b.
[Variations of Seventh to Eleventh Embodiment]
In the seventh to eleventh embodiments, when the first output information zι,1 and the second output information zι,2 are provided to the computing apparatus, the computing apparatus can output uιb′(ι)vιa′(ι) with a certain probability. uιb′(ι)vιa′(ι) will be the decryption value of the ciphertext λι. On the other hand, if neither of the first output information zι,1 and the second output information zι,2 is provided to the computing apparatus, the computing apparatus cannot obtain the decryption value of the ciphertext λι.
The capability providing apparatus in any of the seventh to eleventh embodiment can control whether or not to output both of the first output information zι,1 and second output information zι,2 to control the ciphertext decryption capability of the computing apparatus without providing a decryption key to the computing apparatus.
The present invention is not limited to the embodiments described above. For example, while ω is an integer greater than or equal to 2 in the embodiments described above, ω may be 1. That is, a configuration in which only one capability providing apparatus exists may be used. In that case, the computing apparatus does not need to include a recovering unit and may directly output a value output from the final output unit. For example, the system of any of the first to fifth embodiments described above may further include a decryption control apparatus, the decryption control apparatus may output a decryption control instruction for controlling the decryption process of the computing apparatus to the capability providing apparatus, and the capability providing apparatus may control whether or not to output both of first output information z1 and second output information z2 from the first output information computing unit and the second output information computing unit according to the decryption control instruction. For example, the system of the sixth embodiment described above may further include a decryption control apparatus, the decryption control apparatus may output a decryption control instruction for controlling the decryption process of the computing apparatus to the capability providing apparatus, and the capability providing apparatus may control whether or not to output first output information Mz1 and second output information Mz2 from the first output information computing unit and the second output information computing unit according to the decryption control instruction.
Random variables Xι,1, Xι,2 and Xι,3 may or may not be the same.
Each of the first random number generator, the second random number generator, the third random number generator, the fourth random number generator, the fifth random number generator, the sixth random number generator and the seventh random number generator generates uniform random numbers to increase the security of the proxy computing system. However, if the level of security required is not so high, at least some of the first random number generator, second random number generator, the third random number generator, the fourth random number generator, the fifth random number generator, the sixth random number generator and the seventh random number generator may generate random numbers that are not uniform random numbers. While it is desirable from the computational efficiency point of view that random numbers that are natural numbers greater than or equal to 0 and less than Kι,H or random numbers that are natural numbers greater than or equal to 0 and less than Kι,G be selected as in the embodiments described above, random numbers that are natural numbers greater than or equal to Kι,H or Kι,G may be selected instead.
The process of the capability providing apparatus may be performed multiple times each time the computing apparatus provides first input information τι,1 and second input information τι,2 corresponding to the same a(ι) and b(ι) to the capability providing apparatus. This enables the computing apparatus to obtain a plurality of pieces of first output information zι,1, second output information zι,2, and third output information zι,3 each time the computing apparatus provides first input information τι,1, and the second input information τι,2 to the capability providing apparatus. Consequently, the number of exchanges and the amount of communication between the computing apparatus and the capability providing apparatus can be reduced.
The computing apparatus may provide a plurality of pieces of the first input information τι,1 and the second input information τι,2 to the capability providing apparatus at once and may obtain a plurality of pieces of corresponding first output information zι,1, second output information zι,2 and third output information zι,3 at once. This can reduce the number of exchanges between the computing apparatus and the capability providing apparatus.
While ω in the embodiments is a constant, ω may be a variable, provided that a value of ω can be shared in the proxy computing system.
The units of the computing apparatus may exchange data directly or through a memory, which is not depicted. Similarly, the units of the capability providing apparatus may exchange data directly or through a memory, which is not depicted.
Check may be made to see whether uι and vι obtained at the first computing unit and the second computing unit of any of the embodiments are elements of the group Gι. If they are elements of the group Gι, the process described above may be continued; if uι or vι is not an element of the group Gι, information indicating that the computation is impossible, for example the symbol “⊥”, may be output.
Furthermore, the processes described above may be performed not only in time sequence as is written or may be performed in parallel with one another or individually, depending on the throughput of the apparatuses that perform the processes or requirements. A plurality of capability providing apparatus may be configured in a single apparatus. It would be understood that other modifications can be made without departing from the spirit of the present invention.
A twelfth embodiment of the present invention will be described. In this embodiment, Φ computing apparatuses (Φ is an integer greater than or equal to 2) shares one capability providing apparatus to perform computations and the capability providing apparatus receives payment for the capability. However, this does not limit the present invention and Φ computing apparatuses may share a plurality of capability providing apparatuses to perform computations.
<Configuration>
As illustrated in
In this embodiment, the capability providing apparatus 212 provides the capability of computing a function fφ that maps elements of a group Hφ to elements of a group Gφ (the computing capability) to each computing apparatus 211-φ. Each computing apparatus 211-φ pays the capability providing apparatus 212 for the capability. The computing apparatus 211-φ uses the provided capability to compute an element fφ(xφ) of the group Gφ that corresponds to an element xφ of the group Hφ.
As illustrated in
As illustrated in
<Assumptions for Processes>
Let Gφ, Hφ be groups (for example commutative groups), Xφ,1 and Xφ,2 be random variables having values in the group Gφ, xφ,1 be a realization of the random variable Xφ,1, xφ,2 be a realization of the random variable Xφ,2, fφ be a function that maps an element of the group Hφ to an element of the group Gφ, and a(φ) and b(φ) be natural numbers that are relatively prime to each other. Specific examples of fφ include an encryption function, a decryption function, a re-encryption function, an image processing function, and a speech processing function. Gφ may be equal to Hφ or Gφ may be unequal to Hφ. All of the groups Gφ (φ=1, . . . , Φ) may be the same or at least some groups Gφ′ may differ from the other groups Gφ, where φ′≠φ. All of the groups Hφ (φ=1, . . . , Φ) may be the same or at some groups Hφ′ may differ from the other groups Hφ, where φ′≠φ. In the following description, computations on the groups Gφ and Hφ are multiplicatively expressed. a(φ) and b(φ) are natural numbers that are relatively prime to each other. The term “natural number” refers to an integer greater than or equal to 0. A set whose members are elements fφ(Mφ)a(φ)b(φ) of the group Gφ that correspond to elements Mφ of the group Hφ is referred to as a “class CLφ(Mφ) corresponding to elements Mφ”. Here, CLφ(Mφ) and CLφ′(Mφ′) (φ′≠φ) are classes different from each other. If a function fφ(Mφ) is an injective function for an element Mφ, only one member belongs to the class CLφ(Mφ) corresponding to the same element Mφ for a pair of a(φ) and b(φ). If only one member belongs to the class CLφ(Mφ) corresponding to the same element Mφ for each pair of a(φ) and b(φ), that two values belong to the class CLφ(Mφ) corresponding to the same Mφ is equivalent to that the two values are equal to each other. That is, if the function fφ(Mφ) is a injective function for the element Mφ, determination as to whether two values belong to the class CLφ(Mφ) corresponding to the same element Mφ or not can be made by determining whether the two values are equal to each other or not. On the other hand, if the function fφ(Mφ) is not an injective function for the element Mφ (for example if the function fφ is an encryption function of probabilistic encryption such as ElGamal encryption), a plurality of members belong to the class CLφ(Mφ) corresponding to the same element Mφ for the pair of a(φ) and b(φ) because a plurality of ciphertexts correspond to a pair of a plaintext and an encryption key.
It is assumed here that a plurality of pairs (a(φ), b(φ)) of natural numbers a(φ) and b(φ) are stored in the natural number storage 21101-φ of each computing apparatus 211-φ (
<Processes>
Processes performed by the computing apparatus 211-φ by using the capability providing apparatus 212 will be described. The processes may be performed by any one of the computing apparatuses 211-φ occupying the capability providing apparatus 212 for a certain period of time or may be performed concurrently by a plurality of computing apparatuses 211-φ accessing the capability providing apparatus 212.
An element xφ of the group Hφ is input in the input information providing unit 21104-φ of a computing apparatus 211-φ (
As illustrated in
The integer computing unit 21103-φ uses the sent pair of natural numbers (a(φ), b(φ)) to computer integers a′(φ) and b′(φ) that satisfy the relation a′(φ)a(φ)+b′(φ)b(φ)=1. Since the natural numbers a(φ) and (φ) are relatively prime to each other, the integers a′(φ) and b′(φ) that satisfy the relation a′(φ)a(φ)+b′(φ)b(φ)=1 definitely exist. Methods for computing such integers are well known. For example, a well-known algorithm such as the extended Euclidean algorithm may be used to compute the integers a′(φ) and b′(φ). Information on the pair of natural numbers (a′(φ), b′(φ)) is sent to the final output unit 21112-φ (step S21101).
The controller 21113-φ sets t=1 (step S21102).
The input information providing unit 21104-φ generates and outputs first input information τφ,1 and second input information τφ,2 each of which corresponds to the input element xφ. Preferably, the first input information τφ,1 and the second input information τφ,2 are information whose relation with the element xφ is scrambled. This enables the computing apparatus 211-φ to conceal the element xφ from the capability providing apparatus 212. Preferably, the first input information τφ,1 of this embodiment further corresponds to the natural number b(φ) selected by the natural number selecting unit 21102-φ and the second input information τφ,2 further corresponds to the natural number a(φ) selected by the natural number selecting unit 21102-φ. This enables the computing apparatus 211-φ to evaluate the computation capability provided by the capability providing apparatus 212 with a high degree of accuracy (step S21103).
As illustrated in
The first output information computing unit 21201 uses the first input information τφ,1 to correctly compute fφ(τφ,1) with a probability greater than a certain probability and sets the obtained result of the computation as first output information zφ,1 (step S21201). The second output information computing unit 21202 uses the second input information τφ,2 to correctly computes fφ(τφ,2) with a probability greater than a certain probability and sets the obtained result of the computation as second output information zφ,2 (step S21202). Note that the “certain probability” is a probability less than 100%. An example of the “certain probability” is a nonnegligible probability and an example of the “nonnegligible probability” is a probability greater than or equal to 1/ψ(k), where ψ(k) is a polynomial that is a weakly increasing function (non-decreasing function) for a security parameter k. That is, the first output information computing unit 21201 and the second output information computing unit 21202 can output computation results that have an intentional or unintentional error. In other words, the result of the computation by the first output information computing unit 21201 may or may not be fφ(τφ,1) and the result of the computation by the second output information computing unit 21202 may or may not be fφ(τφ,2). The first output information computing unit 21201 outputs the first output information zφ,1 and the second output information computing unit 21202 outputs the second output information zφ,2 (step S21203).
Returning to
The first computing unit 21105-φ generates computation result uφ=fφ(xφ)b(φ)xφ,1 from the first output information zφ,1. Here, generating (computing) fφ(xφ)b(φ)xφ,1 means computing a value of a formula defined as fφ(xφ)b(φ)xφ,1. Any intermediate computation method may be used that can eventually compute the value of the formula fφ(xφ)b(φ)xφ,1. The same applies to computations of the other formulae that appear herein. The result uφ of the computation is sent to the first power computing unit 21106-φ (step S21105).
The first power computing unit 21106-φ computes uφ′=uφa(φ). The pair of the result uφ of the computation and uφ′ computed on the basis of the result of the computation, (uφ, uφ′), is stored in the first list storage 21107-φ (step S21106).
The determining unit 21111-φ determines whether or not there is a pair of uφ′ and vφ′ that belong to a class CLφ(Mφ) corresponding to the same element Mφ among the pairs (uφ, uφ′) stored in the first list storage 21107-φ and the pairs (vφ, vφ′) stored in the second list storage 21110-φ. Whether Mφ=xφ does not need to be determined (The same applies to the following determinations.). In other words, the determining unit 21111-φ determines whether there is a pair of uφ′ and vφ′ that belong to the class CLφ(Mφ) corresponding to the same element Mφ. For example, if the function fφ(Mφ) is an injective function for the element Mφ, the determining unit 21111-φ determines whether or not uφ′=vφ′ (step S21107). If a pair (vφ, vφ′) is not stored in the second list storage 21110-φ, the process at step S21107 is omitted and the process at step S21108 is performed. If there is a pair of uφ′ and vφ′ that belong to the class CLφ(Mφ) corresponding to the same element Mφ, the process proceeds to step S21114. If there is not a pair of uφ′ and vφ′ that belong to the class CLφ(Mφ) corresponding to the same element Mφ, the process proceeds to step S21108.
At step S21108, the second computing unit 21108-φ generates a computation result vφ=fφ(xφ)a(φ)xφ,2 from the second output information zφ,2. The result vφ of the computation is sent to the second power computing unit 21109-φ (step S21108).
The second power computing unit 21109-φ computes vφ′=vφb(φ). The pair of the result vφ of the computation and vφ′ computed on the basis of the computation result, (vφ, vφ′), is stored in the second list storage 21110-φ (step S21109).
The determining unit 21111-φ determines whether or not there is a pair of uφ′ and vφ′ that belong to a class CLφ(Mφ) corresponding to the same element Mφ among the pairs (uφ, uφ′) stored in the first list storage 21107-φ and the pairs (vφ, vφ′) stored in the second list storage 21110-φ. For example, if the function fφ(Mφ) is an injective function for the element Mφ, the determining unit 21111-φ determines whether or not uφ′=vφ′ (step S21110). If there is a pair of uφ′ and vφ′ that belong to the class CLφ(Mφ) corresponding to the same element Mφ, the process proceeds to step S21114. If there is not a pair of uφ′ and vφ′ that belong to the class CLφ(Mφ) corresponding to the same element Mφ, the process proceeds to step S21111.
At step S21111, the controller 21113-φ determines whether or not t=T (step S21111). Here, T is a predetermined natural number. T may have the same value for all of φ or the value of T in the self-correction process for φ and the value of T in the self-correction process for φ′ (φ′≠φ, φ′=1, . . . , Φ) may be different. If t=T, the final output unit 21112-φ outputs information indicating that the computation is impossible, for example the symbol “⊥” (step S21113) and the process ends. If not t=T, the controller 21113-φ increments t by 1, that is, sets t=t+1 (sets t+1 as a new t) (step S21112) and the process returns to step S21103.
The information indicating that the computation is impossible (the symbol “⊥” in this example) means that the reliability that the capability providing apparatus 212 correctly performs computation is lower than a criterion defined by T. In other words, the capability providing apparatus 212 was unable to perform a correct computation in T trials.
At step S21114, the final output unit 21112-φ uses uφ and vφ that correspond to the pair of uφ′ and vφ′ that are determined to belong to the class CLφ(Mφ) corresponding to the same element Mφ to calculate and output uφb′(φ)vφa′(φ), and then the process ends (step S21114).
The uφb′(φ)vφa′(φ) thus computed is equal to fφ(xφ)εGφ with a high probability (the reason why uφb′(φ)vφa′(φ)=fφ(xφ) with a high probability will be described later). Therefore, uφb′(φ)vφa′(φ)=fφ(xφ) results with a given reliability (such as a probability) or greater by repeating at least the process for φ described above multiple times and selecting the value uφb′(φ)vφa′(φ) obtained with the highest frequency among the values obtained at step S21114. As will be described later, uφb′(φ)vφa′(φ)=fφ(xφ) can result with an overwhelming probability, depending on settings. This also holds true even if the capability providing apparatus 212 does not necessarily return a correct response. Therefore, the computing apparatus 211-φ does not perform verification for confirming the validity of the capability providing apparatus 212. Even if a process performed between another computing apparatus 211-φ′ (φ′≠φ) and the capability providing apparatus 212 affects the process performed between the computing apparatus 211-φ and the capability providing apparatus 212, the computing apparatus 211-φ can obtain a correct computation result fφ(xφ) if the capability providing apparatus 212 returns a correct solution with a probability greater than a certain probability.
<<Reason why uφb′(φ)vφa′(φ)=fφ(xφ) with High Probability>>
Let Xφ be a random variable having a value in the group Gφ. For wφεGφ, an entity that returns wφxφ′ corresponding to a sample xφ′ according to a random variable Xφ in response to each request is called a sampler having an error Xφ for wφ.
For wφεGφ, an entity that returns wφa′(φ)xφ′ corresponding to a sample xφ′ according to a random variable Xφ whenever a natural number a(φ) is given is called a randomizable sampler having an error Xφ for wφ. The randomizable sampler functions as a sampler if used with a(φ)=1.
The combination of the input information providing unit 21104-φ, the first output information computing unit 21201 and the first computing unit 21105-φ of this embodiment is a randomizable sampler having an error Xφ,1 for fφ(xφ) (referred to as the “first randomizable sampler”) and the combination of the input information providing unit 21104-φ, the second output information computing unit 21202 and the second computing unit 21108-φ is a randomizable sampler having an error Xφ,2 for fφ(xφ) (referred to as the “second randomizable sampler”).
The inventor has found that if uφ′ and vφ′ belong to the class CLφ(Mφ) corresponding to the same element Mφ, it is highly probable that the first randomizable sampler has correctly computed uφ=fφ(xφ)b(φ) and the second randomizable sampler have correctly computed vφ=fφ(xφ)a(φ) (xφ,1 and xφ,2 are identity elements eφ,g of the group Gφ). For simplicity of explanation, this will be proven in an eighteenth embodiment.
When the first randomizable sampler correctly computes uφ=fφ(xφ)b(φ) and the second randomizable sampler correctly computes vφ=fφ(xφ)b(φ) (when xφ,1 and xφ,2 are identity elements eφg of the group Gφ), then uφb′(φ)=(fφ(xφ)b(φ)xφ,1)b′(φ)=(fφ(xφ)b(φ)eφ,g)b′(φ)=fφ(xφ)b(φ)b′(φ) and vφa′(φ)=(fφ(xφ)a(φ)xφ,2)a′(φ)=(fφ(xφ)a(φ)eφ,g)a′(φ)=fφ(xφ)a(φ)a′(φ). Therefore, if the function fφ(Mφ) is an injective function for the element Mφ, then uφb′(φ)vφa′(φ)=fφ(xφ)(b(φ)b′(φ)+a(φ)a′(φ))=fφ(xφ). On the other hand, if the function fφ(Mφ) is not an injective function for the element Mφ but if a homomorphic function, then uφb′(φ)vφa′(φ)=fφ(xφ)(b(φ)b′(φ)+a(φ)a′(φ))=fφ(xφ).
For (q1, q2)εI, a function πi is defined as πi(q1, q2)=qi for each of i=1, 2. Let L=min (#π1(S), #π2(S)), where #• is the order of a set •. If the group Gφ is a cyclic group or a group whose order is difficult to compute, it can be expected that the probability that an output of the computing apparatus 211-φ other than “⊥” is not fφ(xφ) is at most approximately T2L/#S within a negligible error. If L/#S is a negligible quantity and T is a quantity approximately equal to a polynomial order, the computing apparatus 211-φ outputs a correct fφ(xφ) with an overwhelming probability. An example of S that results in a negligible quantity of L/#S is S={(1, d)|dε[2, |Gφ|−1]}.
A proxy computing system of an thirteenth embodiment is an example that embodies the first randomizable sampler and the second randomizable sampler described above. The following description will focus on differences from the twelfth embodiment and repeated description of commonalities with the twelfth embodiment will be omitted. In the following description, elements labeled with the same reference numerals have the same functions and the steps labeled with the same reference numerals represent the same processes.
<Configuration>
As illustrated in
As illustrated in
As illustrated in
<Assumptions for Processes>
In the thirteenth embodiment, a function fφ is a homomorphic function, a group Hφ is a cyclic group, a generator of the group Hφ is μφ,h, the order of the group Hφ is Kφ,H, and νφ=fφ(μφ,h). The rest of the assumptions are the same as those in the twelfth embodiment, except that the computing apparatus 211-φ is replaced with the computing apparatus 221-φ and the capability providing apparatus 212 is replaced with the capability providing apparatuses 222.
<Process>
As illustrated in
<<Process at Step S22103>>
The input information providing unit 22104-φ of the computing apparatus 221-φ (
The first random number generator 22104a-φ (
The second random number generator 22104c-φ generates a uniform random number r(φ, 2) that is a natural number greater than or equal to 0 and less than Kφ,H. The generated random number r(φ, 2) is sent to the second input information computing unit 22104d-φ and the second computing unit 22108-φ (step S22103c). The second input information computing unit 22104d-φ uses the input random number r(φ, 2), the element xφ, and a natural number a(φ) to compute second input information τφ,2=μφ,hr(φ,2)xφa(φ) (step S22103d).
The first input information computing unit 22104b-φ and the second input information computing unit 22104d-φ output the first input information τφ,1 and the second input information τφ,2 thus generated (step S22103e). Note that the first input information τφ,1 and the second input information τφ,2 of this embodiment are information whose relation with the element xφ is scrambled using random numbers r(φ, 1) and r(φ, 2), respectively. This enables the computing apparatus 221-φ to conceal the element xφ from the capability providing apparatus 222. The first input information τφ,1 of this embodiment further corresponds to the natural number b(φ) selected by the natural number selecting unit 21102-φ and the second input information τφ,2 further corresponds to the natural number a(φ) selected by the natural number selecting unit 21102-φ. This enables the computing apparatus 221-φ to evaluate the computing capability provided by the capability providing apparatus 222 with a high degree of accuracy.
<<Processes at Steps S22200 Through S22203>>
As illustrated in
The first output information computing unit 22201 uses the first input information τφ,1=μφ,hr(φ,1)xφb(φ) to correctly compute fφ(μφ,hr(φ,1)xφb(φ)) with a probability greater than a certain probability and sets the obtained result of the computation as first output information zφ,1. The result of the computation may or may not be correct. That is, the result of the computation by the first output information computing unit 22201 may or may not be fφ(μφ,hr(φ,1)xφb(φ)) (step S22201).
The second output information computing unit 22202 uses the second input information τφ,2=μφ,hr(φ,2)xφa(φ) to correctly compute fφ(μφ,hr(φ,2)xφa(φ)) with a probability greater than a certain probability and sets the obtained result of the computation as second output information zφ,2. The result of the computation may or may not be correct. That is, the result of computation by the second output information computing unit 22202 may or may not be fφ(μφ,hr(φ,2)xφa(φ)) (step S22202).
The first output information computing unit 22201 outputs the first output information zφ,1 and the second output information computing unit 22202 outputs the second output information zφ,2 (step S22203).
<<Processes at Steps S22104 and S22105>>
Returning to
The first computing unit 22105-φ uses the input random number r(φ, 1) and the first output information zφ,1 to compute zφ,1νφ−r(φ,1) and sets the result of the computation as uφ. The result uφ of the computation is sent to the first power computing unit 21106-φ. Here, uφ=zφ,1νφ−r(φ,1)=fφ(xφ)b(φ)xφ,1. That is, zφ,1νφ−r(φ,1) is an output of a randomizable sampler having an error Xφ,1 for fφ(xφ). The reason will be described later (step S22105).
<<Process at Step S22108>>
The second computing unit 22108-φ uses the input random number r(φ, 2) and the second output information zφ,2 to compute zφ,2νφ−r(φ,2) and sets the result of the computation as vφ. The result vφ of the computation is sent to the second power computing unit 21109-φ. Here, vφ=zφ,2νφ−r(φ,2)=fφ(xφ)a(φ)xφ,2. That is, zφ,2νφ−r(φ,2) is an output of a randomizable sampler having an error Xφ,2 for fφ(xφ). The reason will be described later (step S22108).
<<Reason why zφ,1νφ−r(φ,1) and zφ,2νφ−r(φ,2) are Outputs of Randomizable Samplers Having Errors Xφ,1 and Xφ,2, Respectively, for fφ(xφ)>>
Let c be a natural number, R and R′ be random numbers, and B(μφ,hRxφc) be the result of computation performed by the capability providing apparatus 222 using μφ,hRxφc. That is, the results of computations that the first output information computing unit 22201 and the second output information computing unit 22202 return to the computing apparatus 221-φ are zφ=B(μφ,hRxφc). A random variable Xφ that has a value in the group Gφ is defined as Xφ=B(μφ,hR′)fφ(μφ,hR′)−1.
Then, zφνφ−R=B(μφ,hRxφc)f(μφ,h)−R=Xφfφ(μφ,hRxφc)fφ(μφ,h)−R=Xφfφ(μφ,h)Rfφ(xφ)cfφ(μφ,h)−R=fφ(xφ)cXφ. That is, zφνφ−R is an output of a randomizable sampler having an error Xφ for fφ(xφ).
The expansion of formula given above uses the properties such that Xφ=B(μφ,hR′)fφ(μφ,hR′)−1=B(μφ,hRxφc)fφ(μφ,hRxφc)−1 and that B(μφ,hRxφc)=Xφfφ(μφ,hRxφc). The properties are based on the fact that the function fφ is a homomorphic function and R and R′ are random numbers.
Therefore, considering that a(φ) and b(φ) are natural numbers and r(φ, 1) and r(φ, 2) are random numbers, zφ,1ν−r(φ,1) and zφ,2ν−r(φ,2) are, likewise, outputs of randomizable samplers having errors Xφ,1 and Xφ,2, respectively, for fφ(xφ).
A fourteenth embodiment is a variation of the thirteenth embodiment and computes a value of uφ or vφ by using samplers described above when a(φ)=1 or b(φ)=1. The amounts of computations performed by samplers in general are smaller than the amounts of computations by randomizable samplers. Using samplers instead of randomizable samplers for computations when a(φ)=1 or b(φ)=1 can reduce the amounts of computations by the proxy computing system. The following description will focus on differences from the twelfth and thirteenth embodiments and repeated description of commonalities with the twelfth and thirteenth embodiments will be omitted.
<Configuration>
As illustrated in
As illustrated in
As illustrated in
<Processes>
Processes of this embodiment will be described below. What follows is a description of differences from the thirteenth embodiment.
As illustrated in
<<Process at Step S23103>>
The input information providing unit 23104-φ of the computing apparatus 231-φ (
A process at S23103 of this embodiment will be described below with reference to
The controller 21113-φ (
Determination is made by the controller 21113-φ as to whether b(φ) is equal to 1 (step S23103a). If it is determined that b(φ)≠1, the processes at steps S22103a and 22103b described above are performed and the process proceeds to step S23103g.
On the other hand, if it is determined at step S23103a that b(φ)=1, the third random number generator 23104e-φ generates a random number r(φ, 3) that is a natural number greater than or equal to 0 and less than Kφ,H. The generated random number r(φ,3) is sent to the third input information computing unit 23104f-φ and the third computing unit 23109-φ (step S23103b). The third input information computing unit 23104f-φ uses the input random number r(φ, 3) and the element xφ to compute xφr(φ,3) and sets it as first input information τφ,1 (step S23103c). Then the process proceeds to step S23103g.
At step S23103g, determination is made by the controller 21113a-φ as to whether a(φ) is equal to 1 (step S23103g). If it is determined that a(φ)≠1, the processes at steps S22103c and S22103d described above are performed.
On the other hand, if it is determined at step S23103g that a(φ)=1, the third random number generator 23104e-φ generates a random number r(φ, 3) that is a natural number greater than or equal to 0 and less than Kφ,H. The generated random number r(φ, 3) is sent to the third input information computing unit 23104f-φ (step S23103h). The third input information computing unit 23104f-φ uses the input random number r(φ, 3) and the element xφ to compute xφr(φ,3) and sets it as second input information τφ,2 (step S23103i).
The first input information computing unit 22104b-φ, the second input information computing unit 22104d-φ, and the third input information computing unit 23104f-φ output the first input information τφ,1 and the second input information τφ,2 thus generated along with information on the corresponding natural numbers (a(φ), b(φ)) (step S23103e). Note that the first input information τφ,1 and the second input information τφ,2 in this embodiment are information whose relation with the element xφ is scrambled using the random numbers r(φ, 1), r(φ, 2) and r(3, φ). This enables the computing apparatus 231-φ to conceal the element xφ from the capability providing apparatus 232.
<<Processes at S22200 Through S22203 and S23205 Through S23209>>
Processes at S22200 through S22203 and S23205 through S23209 of this embodiment will be described below with reference to
The controller 21205 (
Under the control of the controller 21205, the first input information τφ,1=μφ,hr(φ,1)xφb(φ) when b(φ)≠1 is input in the first output information computing unit 22201 of the capability providing apparatus 232 (
Determination is made by the controller 21113-φ as to whether b(φ) is equal to 1 (step S23205). If it is determined that b(φ)≠1, the process at step S22201 described above is performed. Then, determination is made by the controller 21113-φ as to whether a(φ) is equal to 1 (step S23208). If it is determined that a(φ)≠1, the process at step S22202 described above is performed and then the process proceeds to step S23203.
On the other hand, if it is determined at step S23208 that a(φ)=1, the third output information computing unit 23203 uses the second input information τφ,2=xφr(φ,3) to correctly compute fφ(xφr(φ,3)) with a probability greater than a certain probability and sets the obtained result of the computation as third output information zφ,3. The result of the computation may or may not be correct. That is, the result of the computation by the third output information computing unit 23203 may or may not be fφ(xφr(φ,3)) (step S23209). Then the process proceeds to step S23203.
If it is determined at step S23205 that b(φ)=1, the third output information computing unit 23203 uses the second input information τφ,1=xφr(φ,3) to correctly compute fφ(xφr(φ,3)) with a probability greater than a certain probability and sets the obtained result of the computation as third output information zφ,3. The result of the computation may or may not be correct. That is, the result of the computation by the third output information computing unit 23203 may or may not be fφ(xφr(φ,3)) (step S23206).
Then, determination is made by the controller 21113-φ as to whether a(φ) is equal to 1 (step S23207). If it is determined that a(φ)=1, the process proceeds to step S23203; if it is determined a(φ)≠1, the process proceeds to step S22202.
At step S23203, the first output information computing unit 22201, which has generated the first output information zφ,1, outputs the first output information zφ,1, the second output information computing unit 22202, which has generated the second output information zφ,2, outputs the second output information zφ,2, and the third output information computing unit 23202, which has generated the third output information zφ,3, outputs the third output information zφ,3 (step S23203).
<<Processes at Steps S23104 and S23105>>
Returning to
If b(φ)≠1, the first computing unit 22105-φ performs the process at step S22105 described above to generate uφ; if b(φ)=1, the third computing unit 23109-φ computes zφ,31/r(φ,3) and sets the result of the computation as uφ. The computation result uφ is sent to the first power computing unit 21106-φ. Here, if b(φ)=1, then uφ=zφ31/r(φ,3)=fφ(xφ)xφ,3. That is, zφ,31/r(φ,3) serves as a sampler having an error Xφ,3 for fφ(xφ). The reason will be described later (step S23105).
<<Process at Step S23108>>
If a(φ)≠1, the second computing unit 22108-φ performs the process at step S22108 described above to generate vφ; if a(φ)=1, the third computing unit 23109-φ computes zφ,31/r(φ,3) and sets the result of the computation as vφ. The computation result vφ is sent to the second power computing unit 21109-φ. Here, if a(φ)=1, then vφ=zφ,31/r(φ,3)=fφ(xφ)xφ,3. That is, zφ,31/r(φ,3) serves as a sampler having an error Xφ,3 for fφ(xφ). The reason will be described later (step S23108).
Note that if zφ,31/r(φ,3), that is, the radical root of zφ,3, is hard to compute, uφ and/or vφ may be calculated as follows. The third computing unit 23109-φ may store each pair of a random number r(φ, 3) and zφ,3 computed on the basis of that random number r(φ, 3) in a storage, not depicted, in sequence as (α1, β1), . . . , (α2, β2), . . . , (αm, βm), . . . , where m is a natural number. The third computing unit 23109-φ may compute γ1, γ2, . . . , γm that satisfy γ1α1+γ2α2+ . . . +γmαm=1 when the least common multiple of α1, α2, . . . , αm is 1, where γ1, γ2, . . . , γm are integers. The third computing unit 32109-φ may then use the resulting γ1, γ2, . . . , γm to compute Πi=1mβiγi=β1γ1β2γ2 . . . βmγm and may set the results of the computation as uφ and/or vφ.
<<Reason why zφ,31/r(φ,3) Serves as a Sampler Having an Error Xφ,3 for fφ)(xφ)>>
Let R be a random number and B(xφR) be the result of computation performed by the capability providing apparatus 232 using xφR. That is, let zφ=B(xφR) be computation results returned by the first output information computing unit 22201, the second output information computing unit 22202, and the third output information computing unit 23203 to the computing apparatus 231-φ. Furthermore, a random variable Xφ having a value in the group Gφ is defined as Xφ=B(xφR)1/Rfφ(xφ)−1.
Then, zφ1/R=B(xφR)1/R=Xφfφ(xφ)=fφ(xφ)Xφ. That is, zφ1/R serves as a sampler having an error Xφ for fφ(xφ).
The expansion of formula given above uses the properties such that Xφ=B(xφR)1/Rfφ(xφR)−1 and that B(xφR)1/R=Xφfφ(xφR). The properties are based on the fact that R is a random number.
Therefore, considering that r(φ, 3) is a random number, zφ1/R serves as a sampler having an error Xφ,3 for fφ(xφ), likewise.
A proxy computing system of a fifteenth embodiment is another example that embodies the first and second randomizable samplers described above. Specifically, in this embodiment, fφ(xφ) is a function for converting an element xφ=Cφ,1(y(φ,1), mφ) of a group Hφ which is a first ciphertext to a second ciphertext fφ(xφ)=Cφ,2(y(φ,2), mφ) which is an element of a group Gφ. Here, the first ciphertext Cφ,1(y(φ, 1), mφ) is a ciphertext obtained by encrypting a plaintext mφ with a first encryption key y(φ, 1) according to a first encryption scheme ENCφ,1 and the second ciphertext Cφ,2(y(φ, 2), mφ) is a ciphertext obtained by encrypting the plaintext mφ with a second encryption key y(φ, 2) according to a second encryption scheme ENCφ,2. The second encryption scheme ENCφ,2 is the ElGamal encryption and the function fφ(xφ) is a homomorphic function. The first encryption scheme ENCφ,1 may be any encryption scheme; the first encryption scheme ENCφ,1 may be probabilistic encryption such as the ElGamal encryption or may be deterministic encryption such as RSA encryption.
The following description will focus on differences from the twelfth embodiment and repeated description of commonalities with the twelfth embodiment will be omitted.
As illustrated in
As illustrated in
As illustrated in
<Assumptions for Processes>
In the fifteenth embodiment, the group Gφ is the direct product group Gφ,1×Gφ,2 of cyclic groups Gφ,1 and Gφ,2, μφ,g1 is a generator of the group Gφ,1, μφ,g2 is a generator of the group Gφ,2, the second encryption key y(φ, 2) is μφ,g2s(φ,2), an element Cφ,2(y(φ, 2), mφ) is (μφ,g1r(φ), mφy(φ, 2)r(φ))εGφ,1×Gφ,2, r(φ) is an integer random number, a value uφa(φ) is (cφ,1u, cφ,2u)εGφ,1×Gφ,2, and a value vφb(φ) is (cφ,1v, cφ,2v)εGφ,1×Gφ,2. Gφ,1 may be equal to Gφ,2 or may be unequal to Gφ,2. The first encryption scheme ENCφ,1 may be any encryption scheme as stated above. If the first encryption scheme ENCφ,1 is the ElGamal encryption, the group Hφ is the direct product group Hφ,1×Hφ,2 of cyclic groups Hφ,1 and Hφ,2, r′(φ) is an integer random number, μφ,h1 is a generator of the group Hφ,1, μφ,h2 is a generator of the group Hφ,2, the first encryption key y(φ, 1) is μφ,h2s(φ,1), the first ciphertext Cφ,1(y(φ, 1), mφ) is (μφ,h1r′(φ), mφy(φ, 1)r′(φ))εHφ,1×Hφ,2. Hφ,1 may be equal to Hφ,2 or may be unequal to Hφ,2.
Note that if A=(α1, α2)εGφ,1×Gφ,2, B=(β1, β2)εGφ,1× Gφ,2, and ε is a natural number, then Aε represents (α1ε, α2ε), A−ε represents (α1−ε, α2−ε, and AB represents (α1β1, α2β2). Similarly, if ε is a natural number, A=(α1, α2)εHφ,1×Hφ,2, and B=(β1, β2)εHφ,1×Hφ,2, then Aε represents (α1ε, α2ε), A−ε represents (α1−ε, α2−ε), and AB represents (α1β1, α2β2). eφ(α, β) is a bilinear map that gives an element of a cyclic group Gφ,T for (α, β)εGφ,1× Gφ,2. Examples of the bilinear map include functions and algorithms for performing pairing computations such as Weil pairing and Tate pairing (see Reference literature 2: Alfred J. Menezes, “ELLIPTIC CURVE PUBLIC KEY CRYPTOSYSTEMS”, KLUWER ACADEMIC PUBLISHERS, ISBN 0-7923-9368-6, pp. 61-81 and Reference literature 3: RFC 5091, “Identity-Based Cryptography Standard (IBCS)#1”, Supersingular Curve Implementations of the BF and BB1 Cryptosystems, for example).
<Processes>
As illustrated in
<<Process at Step S24103>>
The input information providing unit 24104-φ of the computing apparatus 241-φ (
The first random number generator 24104a-φ (
The first input information computing unit 24104b-φ uses a natural number b(φ) selected by the natural number selecting unit 21102-φ, the element xφ, the element hrφ,1, and the first encryption key y(φ, 1) to compute xφb(φ)Cφ,1(y(φ, 1), hrφ,1) as first input information τφ,1 (step S24103b).
The second random number generator 24104c-φ generates an arbitrary element hrφ,2εHφ of the group Hφ. In this embodiment an element hrφ,2 is randomly and uniformly selected from the group Hφ (uniform random number). The generated element hrφ,2 is sent to the second input information computing unit 24104d-φ and the second computing unit 24108-φ (step S24103c).
The second input information computing unit 24104b-φ uses a natural number a(φ) selected by the natural number selecting unit 21102-φ, the element xφ, the element hrφ,2, and the first encryption key y(φ, 1) to compute xφa(φ)Cφ,1(y(φ, 1), hrφ,2) as second input information τφ,2 (step S24103d).
The first input information computing unit 24104b-φ outputs the first input information τφ,1=xφb(φ)Cφ,1(y(φ, 1), hrφ,1) computed as described above. The second input information computing unit 24104d-φ outputs the second input information τφ,2=xφa(φ)Cφ,1(y(φ, 1), hrφ,2) computed as described above (step S24103e).
<<Processes at Steps S24200 Through S24203>>
As illustrated in
The first output information computing unit 24201 uses the first input information τφ,2=xφb(φ)Cφ,1(y(φ, 1), hrφ,1), a first decryption key s(φ, 1) corresponding to the first encryption key y(φ, 1), and the second encryption key y(φ, 2) to correctly compute fφ(xφb(φ)Cφ,1(y(φ, 1), hrφ,1)) with a probability greater than a certain probability and sets the result of the computation as first output information zφ,1. The result of the computation may or may not be correct. That is, the result of the computation by the first output information computing unit 24201 may or may not be fφ(xφb(φ)Cφ,1(y(φ, 1), hrφ,1)) (step S24201).
Note that the function fφ in this embodiment is a homomorphic function for encrypting a value that can be obtained by decrypting a ciphertext with the first decryption key s(φ, 1) according to the first encryption scheme ENCφ,1 with the second encryption key y(φ, 2) according to the ElGamal encryption. For example, if both of the first encryption scheme ENCφ,1 and the second encryption scheme ENCφ,2 are the ElGamal encryption, the function fφ is a homomorphic function for encrypting a value that can be obtained by decrypting a ciphertext with the first decryption key s(φ, 1) according to the ElGamal encryption with the second encryption key y(φ, 2) according to the ElGamal encryption.
The second output information computing unit 24202 can use the second input information τφ,2=xφa(φ)Cφ,1(y(φ, 1), hrφ,2), the first decryption key s(φ, 1), and the second encryption key y(φ, 2) to correctly compute fφ(xφa(φ)Cφ,1(y(φ, 1), hrφ,2)) with a probability greater than a certain probability and sets the result of the computation as second output information zφ,2. The result of the computation may or may not be correct. That is, the result of the computation by the second output information computing unit 24202 may or may not be fφ(xφa(φ)Cφ,1(y(φ, 1), hrφ,2)) (step S24202).
The first output information computing unit 24201 outputs the first output information zφ,1 and the second output information computing unit 24202 outputs the second output information zφ,2 (step S24203).
<<Processes at Steps S24104 and S24105>>
Returning to
The first computing unit 24105-φ uses the input first output information zφ,1, the element hrφ,1, and the second encryption key y(φ, 2) to compute zφ,1(Cφ,2(y(φ, 2), hrφ,1))−1 and sets the result of the computation as uφ (step S24105). The result uφ of the computation is sent to the first power computing unit 21106-φ. Here, uφ=zφ,1(Cφ,2(y(φ, 2), hrφ,1))−1=fφ(xφ)b(φ)xφ,1. That is, zφ,1(Cφ,2(y(φ, 2), hrφ,1))−1 is an output of a randomizable sampler having an error Xφ,1 for fφ(xφ). The reason will be described later.
<<Process at Step S24108>>
The second computing unit 24108-φ uses the input second output information zφ,2, the element hrφ,2, and the second encryption key y(φ, 2) to compute zφ,2(Cφ,2(y(φ, 2), hrφ,2))−1 and sets the result of the computation as vφ. The result vφ of the computation is sent to the second power computing unit 21109-φ. Here, vφ=zφ,2(Cφ,2(y(φ, 2), hrφ,2))−1=fφ(xφ)a(φ)xφ,2. That is, zφ,2(Cφ,2(y(φ, 2), hrφ,2))−1 is an output of a randomizable sampler having an error Xφ,2 for fφ(xφ). The reason will be described later.
<<Process at Step S24107>>
The determining unit 24111-φ determines whether or not there is a pair of uφ′ and vφ′ that belong to a class CLφ(Mφ) corresponding to the same element Mφ, among the pairs (uφ, uφ′) stored in the first list storage 21107-φ and the pairs (vφ, vφ′) stored in the second list storage 21110-φ. The determining unit 24111-φ of this embodiment determines whether or not there is a pair that satisfies the relation eφ(μφ,g1, cφ,2u)/eφ(cφ,1u, y(φ,2))=eφ(μφ,g1, cφ,2v)/eφ(cφ,1v, y(φ, 2)) for uφ′=(cφ,1u, cφ,2u) and vφ′=(cφ,1v, cφ,2v) (step S24107). The reason why the determination as to whether uφ′ and vφ′ belong to the class CLφ(Mφ) corresponding to the same element Mφ can be made by determining whether uφ′ and vφ′ satisfy the relation will be described later.
If a pair (vφ, vφ′) is not stored in the second list storage 21110-φ, a process at step S21108 is performed without performing the process at step S24107. If there is a pair of uφ′ and vφ′ that belong to the class CLφ(Mφ) corresponding to the same element Mφ (if there is a pair of uφ′ and vφ′ that satisfy the relation given above), the process proceeds to step S21114. If there is not a pair of uφ′ and vφ′ that belong to the class CLφ)(Mφ) corresponding to the same element Mφ, the process proceeds to step S24108.
<<Process at Step S24110>>
The determining unit 24111-φ determines whether there is a pair of uφ′ and vφ′ that belong to a class CLφ(Mφ) corresponding to the same element Mφ among the pairs (uφ, uφ′) stored in the first list storage 21107-φ and the pairs (vφ, vφ′) stored in the second list storage 24110-φ. The determining unit 24111-φ of this embodiment determines whether there is a pair that satisfies the relation eφ(μφ,g1, cφ,2u)/eφ(cφ,1u, y(φ, 2))=eφ,g1, cφ,2v)/eφ(cφ,1v, y(φ, 2)) for uφ′=(cφ,1u, cφ,2u) and vφ′=(cφ,1v, cφ,2v) (step S24110). If there is a pair of uφ′ and vφ; that belong the class CLφ(Mφ) corresponding to the same element Mφ), the process proceeds to step S21114. If there is not a pair of uφ′ and vφ′ that belong to the class CLφ(Mφ) corresponding to the same element Mφ, the process proceeds to step S21111.
Note that using special groups Gφ,1, Gφ,2 and the bilinear map eφ can allow only a permitted person to cause the computing apparatus 241-φ to perform the processes of steps S24107 and S24110. Details of this will be described later.
<<Reason why zφ,1(Cφ,2(y(φ, 2), hrφ,1))−1 and zφ,2(Cφ,2(y(φ, 2), hr(φ2))−1 are Outputs of Randomizable Samplers Having Errors Xφ,1 and Xφ,2, Respectively, for fφ(xφ)>>
Suppose that an arbitrary element hrφ,1 is fixed, then the relation given below holds for a probability distribution over a probability space of random numbers r(φ) in elements Cφ,2(y(φ, 2), mφ)=(μφ,g1r(φ), mφy(φ, 2)r(φ)):
where [ψ1]=[ψ2] means that ψ1 is equal to ψ2 as probability distributions over probability spaces of random numbers r. Dφ,1(s(φ, 1), xφ) represents a function for decrypting elements xφ with the first decryption key s(φ, 1) according to a first encryption scheme ENCφ,1. It is assumed that hrφ,2′=Dφ,1(s(φ, 1), xφ)a(φ)hrφ,2.
Therefore, assuming that both of the random number r(φ) and the uniform random element grφ on the group Gφ, are probability spaces and a random variable having a value in the group Gφ, is Xφ,2=fφ(Cφ,2(y(φ, 1), hrφ,2′))Cφ,2(y(φ, 2), hrφ,2′)−1, then the relation given below holds for xφ,2εXφ,2:
Likewise, the relation zφ,1(Cφ,2(y(φ, 2), hrφ,1))−1=fφ(xφ)b(φ)xφ,1 holds for xφ,1εXφ,1. Therefore, zφ,1(Cφ,2(y(φ, 2), hrφ,1))−1 and zφ,2(Cφ,2(y(φ, 2), hrφ,2))−1 are outputs of randomizable samples having errors Xφ,1 and Xφ,2, respectively, for fφ(xφ).
<<Why Determining Whether Relation eφ(μφ,g1, cφ,2u)/eφ(cφ,1u, (y(φ, 2))=eφ(μφ,g1, cφ,2v)/eφ(cφ,1v, y(φ, 2)) is Satisfied can Determine Whether uφ′ and vφ′ Belong to Class CLφ(Mφ) Corresponding to the Same Mφ>>
Assume that uφ′ and vφ′ belong to a class CLφ(Mφ) corresponding to the same element Mφ=xφ. Then, it is highly probable that the first randomizable sampler has correctly computed uφ=f(xφ)b(φ) and that the second randomizable sampler has correctly computed vφ=fφ(xφ)a(φ) (that is, xφ,1 and xφ,2 are identity elements eφ,g of the group Gφ). Accordingly, it is highly probable that uφ′=(μφ,g1r″(φ)), mφy(φ, 2)r″(φ) and vφ′=(μφ,g1r′″(φ), mφy(φ, 2)r′″(φ)), where r″(φ) and r′″(φ) are values that are determined by a pair of a random number component of ElGamal encryption and a natural number selected by the natural number selecting unit 21102-φ. Then, from the properties of the bilinear map eφ, it is highly probable for uφ′=(cφ,1u, cφ,2u), the following is satisfied:
For vφ′=(cφ,1v, cφ,2v), it is highly probable that the following is satisfied:
Therefore, if uφ′ and vφ′ belong to the class CLφ(Mφ) corresponding to the same element Mφ, it is highly probable that the relation eφ(μφ,g1, cφ,2u)/eφ(cφ,1u, y(φ, 2))=eφ(μφ,g1, cφ,2v)/eφ(cφ,1vy(φ, 2)) is satisfied.
Next, assume that uφ′ and vφ′ belong to classes corresponding to different elements. That is, uφ′ belongs a class CLφ(mφ, u) corresponding to an element mφ,u and vφ′ belongs to a class CLφ(mφ, v) corresponding to an element mφ,v (mφ,v≠mφ,u). Then, uφ′=(μφ,g1r″(φ), mφ,uy(φ, 2)r″(φ)xφ,1 and vφ′=(μφ,g1r′″(φ), mφ,vy(φ, 2)r′″(φ))xφ,2. Accordingly, eφ(μφ,g1, cφ,2u)/eφ(cφ,1u, y(φ, 2))=eφ(μφ,g1, mφ,u)xφ,1 is satisfied for uφ′=(cφ,1u, cφ,2u) and eφ(μφ,g1, cφ,2v)/eφ(cφ,1v, y(φ, 2))=eφ(μφ,g1, mφ,v)xφ,2 is satisfied for vφ′=(cφ,1v, cφ,2v). Therefore, if uφ′ and vφ′ belong to classes corresponding to different elements, it is highly probable that the relation eφ(μφ,g1, cφ,2u)/eφ(cφ,1u, y(φ, 2))≠eφ(μφ,g1, cφ,2v)/eφ(cφ,1v, y(φ, 2)) is satisfied.
<<Special Groups Gφ,1, Gφ,2 and Bilinear Map eφ>>
Setting the following restriction on the constructions of groups Gφ,1, Gφ,2 and the bilinear map eφ can allow only a permitted person to cause the computing apparatus 241-φ to perform the processes of steps S24107 and S24110. Details of this will be described below.
In this special example, Nφ is the composite number of primes ωφ and primes ιφ, groups Gφ,1 and Gφ,2 are subgroups consisting of points on a first elliptic curve Eφ,1 defined on a factor ring Z/NφZ modulo composite number Nφ, Gφ,1ω and Gφ,2ω are subgroups consisting of points on a second elliptic curve Eφ,2 defined on a factor ring Z/ωφZ modulo prime ωφ, Gφ,1ι and Gφ,2ι are subgroups consisting of points on a third elliptic curve Eφ,3 defined on a factor ring Z/ιφZ modulo prime ιφ, eφ(α, β) is a bilinear map that yields an element of a cyclic group Gφ,T for (α, β)εGφ,1×Gφ,2, eφ,ω(αω, βω) is a second bilinear map that yields an element of a cyclic group Gφ,Tω for (αω, βω) εGφ,1ω×Gφ,2ω, eφ,ι(αι, βι) is a third bilinear map that yields an element of a cyclic group Gφ,Tι for (αι, βι)εGφ,1ι×Gφ,2ι, HMφ is an isomorphism map that maps a point on the first elliptic curve Eφ,1 to a point on the second elliptic curve Eφ,2, and a point on the third elliptic curve Eφ,3, and HMφ−1 is the inverse map of the isomorphism map HMφ.
In this example, the bilinear map eφ(α, β) is defined on the first elliptic curve Eφ,1 defined on the factor ring Z/NφZ. However, there is not a known method for computing the bilinear map eφ(α, β) defined on an elliptic curve defined on a factor ring in polynomial time nor a method for constructing a bilinear map eφ(α, β) defined on an elliptic curve defined on a factor ring that can be computed in polynomial time (Reference literature 4: Alexander W. Dent and Steven D. Galbraith, “Hidden Pairings and Trapdoor DDH Groups,” ANTS 2006, LNCS 4076, pp. 436-451, 2006). In such a setting, the determining unit 24111 cannot determine whether or not the relation eφ(μφ,g1, cφ,2u)/eφ(cφ,1u, y(φ, 2))=eφ(μφ,g1, cφ,2v)/eφ(cφ,1v, y(φ, 2)) is satisfied by directly computing the bilinear map eφ on the factor ring Z/NφZ.
On the other hand, as for eφ,ω(αω, βω) and eφι(αι, βι) defined on elliptic curves defined on residual fields Z/ωφZ and Z/ιφZ, there are pairings such as Weil pairing and Tate pairing which can be computed in polynomial time (see Reference literatures 2 and 3, for example). Algorithms for computing such eφ,ω(αω, βω) and eφ,ι(αι, βι) in polynomial time, such as Miller's algorithm, are well known (Reference literature 5: V. S. Miller, “Short Programs for functions on Curves,” 1986, Internet <http://crypto.standford.edu/miller/miller.pdf>). Furthermore, methods for constructing elliptic curves and cyclic groups for efficiently computing such eφ,ω(αω, βω) and eφ,ι(αι, βι) are also well known (See, for example, Reference literatures 3 and 6: A Miyaji, M. Nakabayashi, S. Takano, “New explicit conditions of elliptic curve Traces for FR-Reduction,” IEICE Trans. Fundamentals, vol. E84-A, no. 05, pp. 1234-1243, May 2001″, Reference literature 7: P. S. L. M. Barreto, B. Lynn, M. Scott, “Constructing elliptic curves with prescribed embedding degrees,” Proc. SCN 2002, LNCS 2576, pp. 257-267, Springer-Verlag, 2003”, Reference literature 8: R. Dupont, A. Enge, F. Morain, “Building curves with arbitrary small MOV degree over finite prime fields,” http://eprintiacr.org/2002/094).
It is well known that, based on the Chinese remainder theorem, there is an isomorphic map that maps from a factor ring Z/NφZ modulo composite number Nφ (Nφ=ωφ·ιφ) to the direct product of a residue field Z/ωφZ and a residue field Z/ιφZ, and that there is an isomorphic map that maps from the direct map of a residue field Z/ωφZ and a residue field Z/ιφZ to a factor ring Z/NφZ (Reference literature 9: Johannes Buchmann “Introduction to Cryptography”, Springer Verlag Tokyo, (2001/07), ISBN-10: 4431708669 ISBN-13, pp. 52-56). That is, there are an isomorphic map HMφ that maps a point on the first elliptic curve Eφ,1 to a point on the second elliptic curve Eφ,2 and a point on the third elliptic curve Eφ,3, and its inverse map HMφ−1. To take an example, an isomorphic map that maps an element κ mod Nφ of a factor ring Z/NφZ to an element κ mod ωφ of a residue field Z/ωφZ and an element κ mod ιφ of a residue field Z/ιφZ can be HMφ and a map that maps an element κω mod ωφ of a residue field Z/ωφZ and an element κι mod ιφ, of a residue field Z/ιφZ to a an element κωιφιφ′+κιωφωφ′ mod Nφ of factor ring Z/NφZ can be HMφ−1. Here, ωφ′ and ιφ′ are natural numbers that satisfy ωφωφ′+ιφιφ′=1. Such ωφ′ and ιφ′ can be easily generated by using the extended Euclidean algorithm. From the relation ωφωφ′+ιφιφ=1, application of HMφ to κωιφιφ′+κιωφωφ′ mod N yields
κφιφιφ′+κιωφωφ′ mod ωφ=κωιφιφ′ mod ω=κω(1−ωφωφ′)mod ωφ=κω)mod ωφεZ/ωφZ
κφιφιφ′+κιωφωφ′ mod ιφ=κιωφωφ′ mod ιφ=κι(1−ιφιφ′)mod ιφ=κι mod ιφεZ/ιφZ
Thus, it can be seen that the mapping in this example is between HMφ and HMφ−1.
Therefore, if values resulting from factorization of the composite number Nφ into primes are given, that is, values of primes ωφ and ιφ are given, the determining unit 24111 can compute the bilinear map eφ(α, β) on the first elliptic curve Eφ,1 defined on the factor ring Z/NφZ by performing the following process of steps A to D.
(Step A) The determining unit 24111 uses the isomorphic map HMφ to map a point αεGφ,1 on the first elliptic curve Eφ,1 defined on the factor ring Z/NφZ to a point θω(α)εGφ,1ω on the second elliptic curve Eφ,2 defined on the residue field Z/ωφZ and a point θι(α)εGφ,1ι on the third elliptic curve Eφ,3 defined on the residue field Z/ιφZ.
(Step B) The determining unit 24111 uses the isomorphic map HMφ to map a point βεGφ,2 on the first elliptic curve Eφ,1 defined on the factor ring Z/NφZ to a point θ107 (β)εGφ,2ω on the second elliptic curve Eφ,2 defined on the residue field Z/ωφZ and a point θι(β)εGφ,2ι on the third elliptic curve Eφ,3 defined on the residue field Z/ιφZ.
(Step C) The determining unit 24111 obtains eφ,ω(θω)(α), θω(β)) and eφ,ι(θι(α), θι(β)) on the second elliptic curve Eφ,2 and the third elliptic curve Eφ,3.
(Step D) The determining unit 24111 applies the inverse map HMφ−1 to the obtained results of the computations eφ,ω(θω(α), θω(β)) and eφ,ι(θι(α), θι(β)) to obtain a value eφ(α, β).
Thus, if values of primes ωφ and ιφ, are given, the determining unit 24111 can compute eφ(μφ,g1, cφ,2u), eφ(cφ,1u, y(φ, 2)), eφ(μφ,g1, cφ,2v), and eφ(cφ,1v, y(φ, 2)) by following steps A through D to determine whether or not the relation eφ(μφ,g1, cφ,2u)/eφ(cφ,1u, y(φ, 2))=eφ(μφ,g1, cφ,2v)/eφ(cφ,1v, y(φ, 2)) is satisfied.
On the other hand, no method for factorizing a large composite number Nφ into primes in polynomial time is known. Therefore, in this setting, the determining unit 24111 to which at least one of the primes ωφ and ιφ is not given cannot determine whether or not the relation eφ(μφ,g1, cφ,2u)/eφ(cφ,1u, y(φ, 2))=eφ(μφ,g1, cφ,2v)/eφ(cφ,1v, y(φ, 2)) is satisfied.
Using the special groups Gφ,1, Gφ,2 and the bilinear map eφ described above can allow only a person who knows at least one of the primes ωφ and ιφ to cause the computing apparatus 241-φ to perform the processes of steps S24107 and S24110.
A proxy computing system of a sixteenth embodiment is another example that embodies the first randomizable sampler and the second randomizable sampler described above. Specifically, the proxy computing system embodies an example of the first randomizable sampler and the second randomizable sampler in which Hφ is the direct product Gφ×Gφ of groups Gφ which are cyclic groups, a function fφ(xφ) is a decryption function of the ElGamal encryption, that is, fφ(cφ,1, cφ,2)=cφ,1cφ,2−s(φ) for an element xφ=(cφ,1, cφ,2) which is a ciphertext and a decryption key s(φ). The following description will focus on differences from the twelfth embodiment and description of commonalities with the twelfth embodiment will be omitted.
As illustrated in
As illustrated in
As illustrated in
<Processes>
Processes of this embodiment will be described below. In the sixteenth embodiment, it is assumed that a group Hφ=Gφ×Gφ, an element xφ=cφ,1, cφ,2)εHφ, fφ(cφ,1, cφ,2) is a homomorphic function, a generator of the group Gφ is μφ,g, the order of the group Gφ is Kφ,G, a pair of a ciphertext (Vφ, Wφ)εHφ and a decrypted text fφ(Vφ, Wφ)=YφεGφ decrypted from the ciphertext for the same decryption key s(φ) is preset in the computing apparatus 251-φ and the capability providing apparatus 252, and the computing apparatus 251-φ and the capability providing apparatus 252 can use the pair.
As illustrated in
<<Process at Step S25103>>
The input information providing unit 25104-φ of the computing apparatus 251-φ (
The fourth random number generator 25104a-φ (
The fourth input information computing unit 25104ca-φ uses a natural number b(φ) selected by the natural number selecting unit 21102-φ, cφ,2 included in the element xφ, and the random number r(φ, 4) to compute fourth input information cφ,2b(φ)Wr(φ,4) (step S25103c). The fifth input information computing unit 25104cb-φ uses the natural number b(φ) selected by the natural number selecting unit 21102-φ, cφ,1 included in the element xφ, and random numbers r(φ, 4) and r(φ 5) to compute fifth input information cφ,1b(φ)Vr(φ,4)μφ,gr(φ,5) (step S25103d).
The sixth random number generator 25104d-φ generates a uniform random number r(φ, 6) that is a natural number greater than or equal to 0 and less than Kφ,G. The generated random number r(φ, 6) is sent to the sixth input information computing unit 25104fa-φ, the seventh input information computing unit 25104fb-φ, and the second computing unit 25108-φ (step S25103e). The seventh random number generator 25104e-φ generates a uniform random number r(φ, 7) that is a natural number greater than or equal to 0 and less than Kφ,G. The generated random number r(φ, 7) is sent to the seventh input information computing unit 25104fb-φ and the second computing unit 25108-φ (step S25103f).
The sixth input information computing unit 25104fa-φ uses a natural number a(φ) selected by the natural number selecting unit 21102-φ, cφ,2 included in the element xφ, and the random number r(φ, 6) to compute sixth input information cφ,2a(φ)Wr(φ,6) (step S25103g). The seventh input information computing unit 25104fb-φ uses the natural number a(φ) selected by the natural number selecting unit 21102-φ, cφ,1 included in the element xφ, and the random numbers r(φ, 6) and r(φ, 7) to compute seventh input information cφ,1a(φ)Vr(φ,6)μgr(φ,7) (step S25103h).
The first input information computing unit 25104c-φ outputs the fourth input information cφ,2b(φ)Wr(φ,4) and the fifth input information cφ,1b(φ)Vφr(φ,4)μφ,gr(φ,5) generated as described above as first input information τφ,1=(cφ,2b(φ)Wφr(φ,4), cφ,1b(φ)Vφr(φ,4)μφ,gr(φ,5)). The second input information computing unit 25104f-φ outputs the sixth input information cφ,2a(φ)Wr(φ,6) and the seventh input information cφ,1a(φ)Vφr(φ,6)μφ,gr(φ,7) generated as described above as second input information τφ,2=(cφ,2a(φ)Wφr(φ,6), cφ,1a(φ)Vφr(φ,6)μφ,gr(φ,7)) (step S25103i).
<<Processes at Steps S25200 Through S25203>>
As illustrated in
The first output information computing unit 25201 uses the first input information τφ,1=(cφ,2b(φ)Wφr(φ,4), cφ,1b(φ)Vφr(φ,4)μφ,gr(φ,5)) and the decryption key s(φ) to correctly compute fφ(cφ,1b(φ)Vφr(φ,4)μφ,gr(φ,5), cφ,2b(φ)Wφr(φ,4)) with a probability greater than a certain probability and sets the result of the computation as first output information zφ,1. The result of the computation may or may not be correct. That is, the result of the computation by the first output information computing unit 25201 may or may not be fφ(cφ,1b(φ)Vφr(φ,4)μφ,gr(φ,5), cφ,2b(φ)Wφr(φ,4)) (step S25201).
The second output information computing unit 25202 can use the second input information τφ,2=(cφ,2a(φ)Wφr(φ,6), cφ,1a(φ)Vφr(φ,6)μφ,gr(φ,7)) and the decryption key s(φ) to correctly compute fφ(cφ,1a(φ)Vφr(φ,6)μφ,gr(φ,7), cφ,2a(φ)Wφr(φ,6)) with a probability greater than a certain probability and sets the result of the computation as second output information zφ,2. The result of the computation may or may not be correct. That is, the result of the computation by the second output information computing unit 25202 may or may not be fφ(cφ,1a(φ)Vφr(φ,6)μφ,gr(φ,7), cφ,2a(φ)Wφr(φ,6)) (step S25202).
The first output information computing unit 25201 outputs the first output information zφ,1 and the second output information computing unit 25202 outputs the second output information zφ,2 (step S25203).
<<Processes at Steps S25104 and S25105>>
Returning to
The first computing unit 25105-φ uses the input first output information zφ,1 and the random numbers r(φ, 4) and r(φ, 5) to compute zφ,1 Y−r(φ,4)μφ,g−r(φ,5) and sets the result of the computation as uφ (step S25105). The result uφ of the computation is sent to the first power computing unit 21106-φ. Here, uφ=zφ,4Yφ−r(φ,4)μφ,g−r(φ,5)=fφ(cφ,1, cφ,2)b(φ)xφ,1. That is, zφ,4Yφ−r(φ,4)μφ,g−r(φ,5) is an output of a randomizable sampler having an error Xφ,1 for fφ(cφ,1, cφ,2). The reason will be described later.
<<Process at Step S25108>>
The second computing unit 25108-φ uses the input second output information zφ,2 and the random numbers r(φ,6) and r(φ,7) to compute zφ,2Yφ−r(φ,6)μφ,g−r(φ,7) and sets the result of the computation as vφ. The result vφ of the computation is sent to the second power computing unit 21109-φ. Here, vφ=zφ,5Yφ−r(φ,6)μφ,g−r(φ,7)=fφ(cφ,1, cφ,2)a(φ)xφ,2. That is, zφ,5Yφ−r(φ,6)μφ,g−r(φ,7) is an output of a randomizable sampler having an error Xφ,2 for fφ(cφ,1, cφ,2). The reason will be described later.
<<Reason why zφ,4Yφ−r(φ,4)μφ,g−r(φ,5) and zφ,5Yφ−r(φ,6)μφ,g−r(φ,7) are outputs of Randomizable Samplers Having Errors Xφ,1 and Xφ,2, Respectively, for fφ(cφ,1, cφ,2)>>
Let c be a natural number, R1, R2, R1′ and R2′ be random numbers, and B(cφ,1cVφR1μφ,gR2, cφ,2cWφR1) be the result of computation performed by the capability providing apparatus 252 using cφ,1cVφR1μφ,gR2 and cφ,2cWφR1. That is, the first output information computing unit 25201 and the second output information computing unit 25202 return zφ=B(cφ,1cVφR1μφ,gR2, cφ,2cWφR1) as the results of computations to the computing apparatus 251-φ. Furthermore, a random variable Xφ having a value in a group Gφ is defined as Xφ=B(VφR1′μφ,gR2′, WφR1′)fφ)(VφR1′μφ,gR2′, WφR1′)−1.
Here, zφYφ−R1μφ,g−R2=B(cφ,1cVφR1μφ,gR2, cφ,2cWφR1)Yφ−R1μφ,g−R2=Xφfφ(cφ,1cVφR1μφ,gR2, cφ,2cWφR1)Yφ−R1 μφ,g−R2=Xφfφ(cφ,1, cφ,2)cfφ(Vφ, Wφ)R1fφ(μφ,g, eφ,g)R2Yφ−R1μφ,g−R2=Xφfφ(cφ,1, cφ,2)cYφR1 μφ,gR2Yφ−R1μφ,g−R2=fφ(cφ,1, cφ,2)cCφ. That is, zφYφ−R1μφ,g−R2 is an output of a randomizable sampler having an error Xφ for fφ(xφ). Note that eφ,g is an identity element of the group Gφ.
The expansion of formula given above uses the properties such that Xφ=B(VφR1′μφ,gR2′, WφR1′)fφ(VφR1′μφ,gR2′, WφR1′)−1=B(cφ,1cVφR1μφ,gR2, cφ2cWφR1)fφ(cφ,1cVφR1μφ,gR2, cφ,2cWφR1) and that B(cφ,1cVφR1μφ,gR2, cφ,2cWR1)=Xφfφ(cφ,1cVφR1μφ,gR2, cφ,2cWφR1). The properties are based on the fact that R1, R2, R1′ and R2′ are random numbers.
Therefore, considering that a(φ) and b(φ) are natural numbers and r(φ, 4), r(φ, 5), r(φ, 6), and r(φ, 7) are random numbers, zφ,4Yφ−r(φ,4)μφ,g−r(φ,5) and zφ,5Yφ−r(φ,6)μφ,g−r(φ,7) are, likewise, outputs of randomizable samplers having errors Xφ,1 and Xφ,2, respectively, for fφ(cφ,1, cφ,2).
A proxy computing system of a seventeenth embodiment is another example that embodies the first randomizable sampler and the second randomizable sampler described above. Specifically, the proxy computing system embodies an example of a first randomizable sampler and a second randomizable sampler in which a group Hφ is the direct product H1,φ×H2,φ of cyclic groups H1,φ and H2,φ, a generator of the cyclic group H1,φ is η1,φ, a generator of the cyclic group H2,φ is η2,φ, fφ is a bilinear map that maps a pair of an element of the cyclic group H1,φ and an element of the cyclic group H2,φ to an element of a cyclic group Gφ, an element xφ of a cyclic group λ2,φ is a pair of an element λ1,φ of the cyclic group H1,φ and an element λ2,φ of the cyclic group H2,φ, and Ωφ=fφ(η1,φ, η2,φ). Examples of the bilinear map include functions and algorithms for computing pairings such as Weil pairing and Tate pairing. The following description will focus on differences from the twelfth embodiment and repeated description of commonalities with the twelfth embodiment will be omitted.
As illustrated in
As illustrated in
As illustrated in
<Processes>
Processes of this embodiment will be described below. In the seventeenth embodiment, it is assumed that a group Hφ is the direct product H1,φ×H2,φ of cyclic groups H1,φ and H2,φ, a generator of the cyclic group H1,φ is η1,φ, a generator of the cyclic group H2,φ is η2,φ, fφ is a bilinear map that maps a pair of an element of the cyclic group H1,φ and an element of the cyclic group H2,φ to an element of a cyclic group Gφ, and an element xφ of a group Hφ is a pair of an element λ1,φ of the cyclic group H1,φ and an element λ2,φ of the cyclic group H2,φ, Ωφ=fφ(η1,φ, η2,φ). Here, Ωφ=fφ(η1,φ, η2,φ) is computed beforehand.
As illustrated in
<<Process at Step S27103>>
The input information providing unit 27104-φ of the computing apparatus 271-φ (
The first random number generator 27104a-φ (
The first input information computing unit 27104b-φ uses a natural number b(φ) selected by the natural number selecting unit 21102-φ, the input value xφ=(λ1,φ, λ2,φ), generators η1,φ and η2,φ, and random numbers r(φ, 11), r(φ, 12), r(φ, 13), r(φ, 14), r(φ, 15), and r(φ, 16) to compute (λ1,φη1,φr(φ,11)·r(φ,12), λ2,φb(φ)η2,φr(φ,13)·(φ,14)), (η1,φr(φ,11), λ2,φ−b(φ)·r(φ,12)η2,φr(φ,15)) and (η1,φ−r(φ,14)η1,φr(φ,16), η2,φr(φ,13)) as first input information τφ,1 (steps S27103b through S27103d).
The second random number generator 27104c-φ (
The second input information computing unit 27104d-φ uses a natural number a(φ) selected by the natural number selecting unit 21102-φ, the input value xφ=(λ1,φ, λ2,φ), the generators η1,φ and η2,φ, and the random numbers r(φ, 21), r(φ, 22), r(φ, 23), r(φ,24), r(φ, 25) and r(φ, 26) to compute (λ1,φλ1,φr(φ,21)·r(φ,22), λ2,φa(φ)η2,φr(φ,23)·r(φ,24)), (η1,φr(φ,21), λ2,φ−a(φ)·r(φ,22)η2,φr(φ,25)) and (λ1,φ−r(φ,24)η1,φr(φ,26), η2,φr(φ,23)) as second input information τφ,2 (steps S27103f through S27103h).
The first input information computing unit 27104b-φ outputs (λ1,φη1,φr(φ,11)·r(φ,12), λ2,φb(φ)η2,φr(φ,13)·r(φ,14)), (η1,φr(φ,11), λ2,φ−b(φ)·r(φ,12)η2,φr(φ,15)), and (λ1,φ−r(φ,14)η1,φr(φ,16), η2,φr(φ,13)) as the first input information τφ,1. The second input information computing unit 27104d-φ outputs (λ1,φη1,φr(φ,21)·r(φ,22), λ2,φa(φ)η2,φr(φ,23)·r(φ,24)), (η1,φr(φ,21), λ2,φ−a(φ)·r(φ,22)η2,φr(φ,25)) and (λ1,φ−r(φ,24)η1,φr(φ,26), η2,φr(φ,23)) as the second input information τφ,2 (step S27103i).
<<Processes at Steps S27200 Through S27203>>
As illustrated in
The first output information computing unit 27201 uses the first input information τφ,1 to correctly compute fφ(λ1,φη1,φr(φ,11)·r(φ,12), λ2,φb(φ)η2,φr(φ,13)·(φ,14)), fφ(η1,φr(φ,11), λ2,φ−b(φ)·r(φ,12)η2φr(φ,15)), and fφ(λ1,φ−r(φ,14)η1,φr(φ,16), η2,φr(φ,13)) with a probability greater than a certain probability and sets the obtained results of the computations, φφ,1,1, zφ,1,2 and zφ,1,3, as first output information zφ,1. The results of the computations may or may not be correct (step S27201).
The second output information computing unit 27202 uses the second input information τφ,2 to correctly compute fφ(λ1,φη1,φr(φ,21)·r(φ,22), λ2,φa(φ)η2,φr(φ,23)·r(φ,24)), fφ(η1,φr(φ,21), λ2,φ−a(φ)·r(φ,22)η2,φr(φ,25)) and fφ(λ1,φ−r(φ,24)η1,φr(φ,26), η2,φr(φ,23)) with a probability greater than a certain probability and sets the obtained results of the computations, zφ,2,1, zφ,2,2 and zφ,2,3, as second output information zφ,2. The results of the computations may or may not be correct (step S27202). The first output information computing unit 27201 outputs the first output information zφ,1 and the second output information computing unit 27202 outputs the second output information zφ,2 (step S27203).
<Processes at Steps S27104 and S27105>>
Returning to
The first computing unit 27105-φ uses the input first output information zφ,1=zφ,1,1, zφ,1,2, zφ,1,3) and the random numbers r(φ, 11), r(φ, 12), r(φ, 13), r(φ,14), r(φ, 15), and r(φ, 16) to compute uφ=zφ,1,1zφ,1,2zφ,1,3Ωφ−r(φ,11)·r(φ,12)·r(φ,13)·r(φ,14)−r(φ,11)·r(φ,15)−r(φ,13)·r(φ,16) to obtain the result uφ of the computation (step S27105). The result uφ of the computation is sent to the first power computing unit 21106-φ. Here, uφ=fφ(λ1,φ, λ2,φ)b(φ)xφ,1. That is, zφ,1,1zφ,1,2zφ,1,3Ωφ−r(φ,11)·r(φ,12)·r(φ,13)·r(φ,14)−r(φ,11)·r(φ,15)−r(φ,13)·r(φ,16) is an output of a randomizable sampler having an error Xφ,1 for fφ(λ1,φ, λ2,φ). The reason will be described later.
<<Process at Step S27108>>
The second computing unit 27108-φ uses the input second output information zφ,2=(zφ,2,1, zφ,2,2, zφ,2,3) and the random numbers r(φ, 21), r(φ, 22), r(φ, 23), r(φ,24), r(φ, 25), and r(φ, 26) to compute vφ=zφ,2,1zφ,2,2zφ,2,3Ωφ−r(φ,21)·r(φ,22)·r(φ,23)·r(φ,24)−r(φ,21)·r(φ,25)−r(φ,23)·r(φ,26) to obtain the result vφ of the computation. The result vφ of the computation is sent to the second power computing unit 21109-φ. Here, vφ=fφ(λ1,φ, λ2,φ)a(φ)xφ,2. That is, zφ,2,1zφ,2,2zφ,2,3Ωφ−r(φ,21)·r(φ,22)·r(φ,23)·r(φ,24)−r(φ,21)·r(φ,25)−r(φ,23)·r(φ,26) is an output of a randomizable sampler having an error Xφ,2 for fφ(λ1,φ, λ2,φ). The reason will be described later.
<<Processes at Steps S27107 and S27110>>
At steps S27107 and S27110, the determining unit 27111-φ determines whether uφ′=vφ′. If it is determined at step S27107 that uφ′=vφ′, the process proceeds to step S21114; otherwise, the process proceeds to step S27108. If it is determined at step S27110 that uφ′=vφ′, the process proceeds to step S21114; otherwise, the process proceeds to step S21111.
<<Reason why zφ,1,1zφ,1,2zφ,1,3Ωφ−r(φ,11)·r(φ,12)·r(φ,13)·r(φ,14)−r(φ,11)·r(φ,15)−r(φ,13)·r(φ,16) and zφ,2,1zφ,2,2zφ,2,3Ωφ−r(φ,21)·r(φ,22)·r(φ,23)·r(φ,24)−r(φ,21)·r(φ,25)−r(φ,23)·r(φ,26) are Output of Randomizable Samplers Having Errors Xφ,1, and Xφ,2, Respectively, for fφ(λ1,φ, λ2,φ)>>
Because of the bilinearity of fφ, the following relation holds for vφ.
Here, zφ,2,1′=zφ,2,1fφ(λ1,φη1,φr(φ,21)·r(φ,22), λ2,φa(φ)η2,φr(φ,23)·r(φ,24))−1, zφ,2,2′=zφ,2,2fφ(η1,φr(φ,21), λ2,φ−a(φ)·r(φ,22)η2,φr(φ,25))−1, and zφ,2,3′=zφ,2,3fφ(λ1,φ−r(φ,24)η1,φr(φ,26), η2,φr(φ,23))−1 are satisfied.
Each of zφ,2,1′, zφ,2,2′ and zφ,2,3′ is statistically close to a probability distribution that is independent of a(φ). Accordingly, a probability distribution formed by vφfφ(λ1,φ, λ2,φ)−a(φ) is statistically close to a certain probability distribution Xφ,2 that is independent of a(φ). Therefore, vφ is an output of a randomizable sampler having an error Xφ,2 for fφ(λ1,φ, λ2,φ). Similarly, uφ is an output of a randomizable sampler having an error Xφ,1 for fφ(λ1,φ, λ2,φ).
In the embodiments described above, a plurality of pairs (a(φ), b(φ)) of natural numbers a(φ) and b(φ) that are relatively prime to each other are stored in the natural number storage 21101-φ of the computing apparatus and the pairs (a(φ), b(φ)) are used to perform the processes. However, one of a(φ) and b(φ) may be a constant. For example, a(φ) may be fixed at 1 or b(φ) may be fixed at 1. In other words, one of the first randomizable sampler and the second randomizable sampler may be replaced with a sampler. If one of a(φ) and b(φ) is a constant, the process for selecting the constant a(φ) or b(φ) is unnecessary, a(φ) or b(φ) as a constant is not input in the processing units, and the processing units can treat it as a constant in computations. If a(φ) or b(φ) as a constant is equal to 1, fφ(xφ)=uφb′(φ)vφa′(φ) can be obtained as fφ(xφ)=vφ or fφ(xφ)=uφ without using a′(φ) or b′(φ).
An eighteenth embodiment is an example of such a variation, in which b(φ) is fixed at 1 and the second randomizable sampler is replaced with a sampler. The following description will focus on differences from the twelfth embodiment. Specific examples of the first randomizable sampler and the sampler are similar to those described in the thirteenth to seventeenth embodiments and therefore description of the first randomizable sampler and the sampler will be omitted.
<Configuration>
As illustrated in
As illustrated in
As illustrated in
<Assumptions for Processes>
No natural number b(φ) is stored in the natural number storage 26101-φ of the computing apparatus 261-φ and only a plurality of natural numbers a(φ) are stored. The rest of the assumptions are the same as those in any of the twelfth to seventeenth embodiments.
<Processes>
As illustrated in
The controller 21113-φ sets t=1 (step S21102).
The input information providing unit 26104-φ generates and outputs first input information τφ,1 and second input information τφ,2 each of that corresponds to an input element xφ. Preferably, the first input information τφ,1 and the second input information τφ,2 are information whose relation with the element xφ is scrambled. This enables the computing apparatus 261-φ to conceal the element xφ from the capability providing apparatus 262. Preferably, the second input information τφ,2 of this embodiment further corresponds to the natural number a(φ) selected by the natural number selecting unit 26102-φ. This enables the computing apparatus 261-φ to evaluate the computation capability provided by the capability providing apparatus 262 with a high degree of accuracy (step S26103). A specific example of a pair of the first input information τφ,1 and the second input information τφ,2 is a pair of first input information and second input information τφ,2 when b(φ)=1 in any of the thirteenth to seventeenth embodiments.
As illustrated in
The first output information computing unit 26201 uses the first input information τφ,1 to correctly compute fφ(τφ,1) with a probability greater than a certain probability and sets the obtained result of the computation as first output information zφ,1 (step S26201). The second output information computing unit 26202 uses the second input information φ,2 to correctly compute fφ(τφ,2) with a probability greater than a certain probability and sets the obtained result of the computation as second output information zφ,2 (step S26202). That is, the first output information computing unit 26201 and the second output information computing unit 26202 can output computation results that have an intentional or unintentional error. In other words, the result of the computation by the first output information computing unit 26201 may or may not be fφ(τφ,1) and the result of the computation by the second output information computing unit 26202 may or may not be fφ(τφ,2). A specific example of a pair of the first output information zφ,1 and the second output information zφ,2 is a pair of first output information zφ,1 and second output information zφ,2 when b(φ)=1 in any of the thirteenth to seventeenth embodiments.
The first output information computing unit 26201 outputs the first output information zφ,1 and the second output information computing unit 26202 outputs the second output information zφ,2 (step S26203).
Returning to
The first computing unit 26105-φ generates a computation result uφ=fφ(xφ)xφ,1 from the first output information zφ,1. A specific example of the result uφ of the computation is the result uφ of the computation in any of the thirteenth to seventeenth embodiments when b(φ)=1. The result uφ of the computation is sent to the first power computing unit 21106-φ (step S26105).
The first power computing unit 21106-φ computes uφ′=uφa(φ). The pair of the result uφ of the computation and uφ′ computed on the basis of the result of the computation, (uφ, uφ′), is stored in the first list storage 21107-φ (step S21106).
The second computing unit 26108-φ generates a computation result vφ=fφ(xφ)a(φ)xφ,2 from the second output information zφ,2. A specific example of the result vφ of the computation is the result vφ of the computation in any of the thirteenth to seventeenth embodiments. The result vφ of the computation is stored in the second list storage 26110-φ (step S26108).
The determining unit 26111-φ determines whether or not there is a pair of uφ′ and vφ that belong to a class CLφ(Mφ) corresponding to the same element Mφ among the pairs (uφ, uφ′) stored in the first list storage 21107-φ and vφ stored in the second list storage 26110-φ as in any of the twelfth to seventeenth embodiments (step S26110). If there is a pair of uφ′ and vφ that belong to the class CLφ(Mφ) corresponding to the same Mφ, the process proceeds to step S26114. If there is not a pair of uφ′ and vφ that belong to the class CLφ(Mφ) corresponding to the same element Mφ, the process proceeds to step S21111.
At step S21111, the controller 21113-φ determines whether or not t=T (step S21111). T is a predetermined natural number. If t=T, the controller 21113-φ outputs information indicating that the computation is impossible, for example the symbol “⊥” (step S21113) and the process ends. If not t=T, the controller 21113-φ increments t by 1, that is, sets t=t+1 (step S21112) and the process returns to step S26103.
At step S26114, the final output unit 21112-φ outputs uφ corresponding to uφ′ included in the pair of uφ′ and vφ determined to belong to the class CLφ(Mφ) corresponding to the same element Mφ (step S26114). The uφ thus obtained corresponds to uφb′(φ)vφa′(φ) in the twelfth to seventeenth embodiments when b(φ)=1. That is, uφ thus obtained can be fφ(xφ) with a high probability. Therefore, a predetermined reliability that the selected uφ is equal to fφ(xφ) or higher can be achieved by repeating at least the process described above multiple times and selecting the value uφ obtained with the highest frequency among the values obtained at step S26114. As will be described, uφ=fφ(xφ) can result with an overwhelming probability, depending on settings.
<<Reason why fφ(xφ) can be Obtained>>
The reason why a decryption result fφ(xφ) can be obtained on the computing apparatus 261-φ of this embodiment will be describe below. Terms required for the description will be defined first.
Black-Box:
A black-box Fφ(τφ) of fφ(τφ) is a processing unit that takes an input of τφεHφ and outputs zφεGφ. In this embodiment, each of the first output information computing unit 26201 and the second output information computing unit 26202 is equivalent to the black box Fφ(τφ) for the decryption function fφ(τφ). A black-box Fφ(τφ) that satisfies zφ=fφ(τφ) for elements τφεUHφ and zφ=Fφ(τφ) arbitrarily selected from a group Hφ with a probability greater than δ (0<δ≦1), that is, a black-box Fφ(τφ) for fφ(τφ) that satisfies
Pr[zφ=fφ(τφ)|τφεUHφ,zφ=Fφ(τφ)]>δ (15)
is called the δ-reliable black-box Fφ(τφ) for fφ(τφ). Here, δ is a positive value and is equivalent to the “certain probability” mentioned above.
Self-Corrector:
A self-corrector CF(xφ) is a processing unit that takes an input of xφ, εHφ, performs computation by using a black-box Fφ(τφ) for fφ(τφ) and outputs jεG∪⊥. In this embodiment, the computing apparatus 261-φ is equivalent to the self-corrector CF(xφ).
Almost Self-Corrector:
Assume that a self-corrector CF(xφ) that takes an input of xφεHφ and uses the δ-reliable black-box Fφ(τφ) for fφ(τφ) outputs a correct value j=fφ(xφ) with a probability sufficiently greater than the provability with which the self-corrector CF(xφ) outputs an incorrect value j≠fφ(xφ). That is, assume that a self-corrector CF(xφ) satisfies
Pr[j=fφ(xφ)|j=CF(xφ),j≠⊥]>Pr[j≠fφ(xφ)|j=CF(xφ),j≠⊥]+Δ (16)
Here, Δ is a certain positive value (0<Δ<1). If this is the case, the self-corrector CF(xφ) is called an almost self-corrector. For example, for a certain positive value Δ′ (0<Δ′<1), if a self-corrector CF(xφ) satisfies
Pr[j=fφ(xφ)|j=CF(xφ)]>(⅓)+Δ′
Pr[j=⊥|j=CF(xφ)]<⅓
Pr[j≠fφ(xφ) and j≠⊥|j=CF(xφ)]<⅓,
then the self-corrector CF(xφ) is an almost self-corrector. Examples of Δ′ include Δ′= 1/12 and Δ′=⅓.
Robust Self-Corrector:
Assume that a self-corrector CF(xφ) that takes an input of xφεH and uses a δ-reliable black-box Fφ(τφ) for fφ(xφ) to output a correct value j=fφ(xφ) or j=⊥ with an overwhelming probability. That is, assume that for a negligible error ξ (0≦ξ<1), a self-corrector CF(xφ) satisfies
Pr[j=fφ(xφ) or j=⊥|j=CF(xφ)]>1−ξ (17)
If this is the case, the self-corrector CF(xφ) is called a robust self-corrector. An example of the negligible error ξ is a function vale ξ(k) of a security parameter k. An example of the function value ξ(k) is a function value ξ(k) such that {ξ(k)p(k)} converges to 0 for a sufficiently large k, where p(k) is an arbitrary polynomial. Specific examples of the function value ξ(k) include ξ(k)=2−k and ξ(k)=2−√k.
A robust self-corrector can be constructed from an almost self-corrector. Specifically, a robust self-corrector can be constructed by executing an almost self-constructor multiple times for the same x and selecting the most frequently output value, except ⊥, as j. For example, an almost self-corrector is executed O(log(1/ξ)) times for the same x and the value most frequently output is selected as j, thereby a robust self-corrector can be constructed. Here, O(•) represents O notation.
Pseudo-Free Action:
An upper bound of the probability
Pr[αφa(φ)=βφ and αφ≠eφ,g|a(φ)εUΩ,αφεXφ,1,βφεXφ,2] (18)
of satisfying αφa(φ)=βφ for all possible Xφ,1 and Xφ,2 is called a pseudo-free indicator of a pair (Gφ, Ωφ) and is represented as P(Gφ, Ωφ), where Gφ is a group Gφ, Ωφ is a set of natural numbers Ωφ={0, . . . , Mφ} (Mφ is a natural number greater than or equal to 1), αφ and βφ are realizations αφεXφ,1 (αφ≠eφ,g) and βφεXφ,2 of random variables Xφ,1 and Xφ,2 that have values in the group Gφ, and a(φ)εΩφ. If a certain negligible function ζ(k) exists and
P(Gφ,Ωφ)<ζ(k) (19),
then a computation defined by the pair (Gφ, Ωφ) is called a pseudo-free action. Note that “αφa(φ)” means that a computation defined on the group Gφ is applied a(φ) times to aφ. An example of the negligible function ζ(k) is such that {ζ(k)p(k)} converges to 0 for a sufficiently large k, where p(k) is an arbitrary polynomial. Specific examples of the function ζ(k) include ζ(k)=2−k and ζ(k)=2−√k. For example, if the probability of Formula (18) is less than O(2−k) for a security parameter k, a computation defined by the pair (Gφ, Ωφ) is a pseudo-free action. For example, if the number of the elements |Ωφ·αφ| of a set Ωφ·αφ={a(φ)(αφ)|a(φ)εΩφ} exceeds 2k for any αφεGφ where αφ≠eφ,g, a computation defined by the pair (Gφ, Ωφ) is a pseudo-free action. Note that a(φ)(αφ) represents the result of a given computation on a(φ) and αφ. There are many such examples. For example, if the group Gφ is a residue group Z/pZ modulo prime p, the prime p is the order of 2k, the set Ωφ={0, . . . , p−2}, a(φ)(αφ) is αφa(φ)εZ/pZ, and αφ≠eφ,g, then Ωφ·αφ={αφa(φ)|a(φ)=0, . . . , p−2}={eφ,g, αφ1, . . . , αφp-2} and |Ωφ·αφ|=p−1. If a certain constant C exists and k is sufficiently large, |Ωφ·αφ|>C2k is satisfied because the prime p is the order of 2k. Here, the probability of Formula (18) is less than C−12−k and a computation defined by such pair (Gφ, Ωφ) is a pseudo-free action.
δγ-Reliable Randomizable Sampler:
A randomizable sampler that whenever a natural number a(φ) is given, uses the black-box Fφ(τφ) for δ-reliable fφ(τφ) and returns wφa(φ)xφ′ corresponding to a sample xφ′ that depends on a random variable Xφ for wφεGφ, where the probability that wφa(φ)xφ′=wφa(φ) is greater than δγ (γ is a positive constant), that is,
Pr[wφa(φ)xφ′=wφa(φ)]>δγ (20)
is satisfied, is called a δγ-reliable randomizable sampler. The combination of the input information providing unit 26104-φ, the second output information computing unit 26202, and the second computing unit 26108-φ of this embodiment is a δγ-reliable randomizable sampler for wφ=fφ(xφ).
The definitions given above will be used to describe the reason why fφ(xφ) can be obtained on the computing apparatus 261-φ. At step S26110 of this embodiment, determination is made as to whether there is a pair of uφ′ and vφ that belong to a class corresponding to the same element, that is, whether there is a pair of uφa(φ) and vφ that belong to a class corresponding to the same element. Since the combination of the input information providing unit 26104-φ, the second output information computing unit 26202, and the second computing unit 26108-φ is a δγ-reliable randomizable sampler (Formula (20)), uφa(φ) and vφ belong to a class CLφ(Mφ) corresponding to the same element Mφ with an asymptotically large probability if T is a large value greater than a certain value determined by k, δ and γ (Yes at step S26110). For example, Markov's inequality can be used to show that if T≧4/δγ, the probability that uφa(φ) and vφ belong to a class corresponding to the same element (Yes at step S26110) is greater than ½.
Since uφ=fφ(xφ)xφ,1 and vφ=fφ(xφ)a(φ)xφ,2 in this embodiment, uφa(φ)=vφ is satisfied and xφ,1a(φ)=xφ,2 holds if the determination at step S26110 is yes, provided that the function fφ(xφ) is an injective function for the element xφ. Even where the function fφ(xφ) is not an injective function for an element xφ, xφ,1a(φ)=xφ,2 holds if the determination at step S26110 is yes, provided that fφ(xφ) is a homomorphic function.
xφ,1a(φ)=xφ,2 holds if xφ,1=xφ,2=eφ,g or xφ,1≠eφ,g. If xφ,1=xφ,2=eφ,g, then uφ=fφ(xφ) and therefore uφ output at step S26114 is a correct decryption result fφ(xφ). On the other hand, if xφ,1≠eφ,g, then uφ≠fφ(xφ) and therefore uφ output at step S26114 is not a correct decryption result fφ(xφ).
If an computation defined by a pair (Gφ, Ωφ) of a group Gφ and a set Ωφ to which a natural number a(φ) belongs is pseudo-free action or T2P(Gφ, Ωφ) is asymptotically small for a pseudo-free index P(Gφ, Ωφ), the probability that xφ,1≠eφ,g when xφ,1a(φ)=xφ,2 (Formula (18)) is asymptotically small. Accordingly, the probability that xφ,1=eφ,g when xφ,1a(φ)=xφ,2 is asymptotically large. Therefore, if an computation defined by a pair (Gφ, Ωφ) is a pseudo-free action or T2P(Gφ, Ωφ) is asymptotically small, the probability that an incorrect decryption result fφ(xφ) is output when uφa(φ) and vφ belong to the class CLφ(Mφ) corresponding to the same element Mφ is sufficiently smaller than the probability that a correct decryption result fφ(xφ) is output when uφa(φ) and vφ belong to the class CLφ(Mφ) corresponding to the same element Mφ. In this case, it can be said that the computing apparatus 261-φ is an almost self-corrector (see Formula (16)). Therefore, a robust self-corrector can be constructed from the computing apparatus 261-φ as described above and a correct decryption result fφ(xφ) can be obtained with an overwhelming probability. If a computation defined by (GM, Ωφ) is a pseudo-free action, the probability that an incorrect decryption result fφ(xφ) is output when uφa(φ) and vφ belong to the class CLφ(Mφ) corresponding to the same element Mφ is also negligible. In that case, the computing apparatus 261-φ outputs a correct decryption result fφ(xφ) or ⊥ with an overwhelming probability.
Note that “η(k′) is asymptotically small” means that k0 is determined for an arbitrary constant ρ and the function value η(k′) for any k′ that satisfies k0<k′ for k0 is less than ρ. An example of k′ is a security parameter k. “η(k′) is asymptotically large” means that k0 is determined for an arbitrary constant ρ and the function value 1−η(k′) for any k′ that satisfies k0<k′ for k0 is less than ρ.
The proof given above also proves that “if uφ′ and vφ′ belong to the class CLφ(Mφ) corresponding to the same element Mφ, it is highly probable that the first randomizable sampler has correctly computed uφ=fφ(xφ)b(φ) and the second randomizable sampler has correctly computed vφ=fφ(xφ)a(φ) (xφ,1 and xφ,2 are identity elements eφ,g of the group Gφ)” stated in the twelfth embodiment, as can be seen by replacing a(φ) with a(φ)/b(φ).
<<δγ-Reliable Randomizable Sampler and Security>>
Consider the following attack.
Such an attack is possible if the probability distribution Da=wφa(φ)xφ′wφ−a(φ) of an error of output from the randomizable sampler for a given natural number a(φ) depends on the natural number a(φ). For example, if tampering is made so that vφ output from the second computing unit 26108-φ is fφ(xφ)a(φ)xφ,1a(φ), always uφa(φ)=vφ holds and it is determined that uφa(φ) and vφ belong to the class CLφ(Mφ) corresponding to the same Mφ regardless of the value of xφ,1. Therefore it is desirable that the probability distribution Da=wφa(φ)xφ′wφ−a(φ) of an error of wφa(φ)xφ′ output from the randomizable sampler for a given natural number a(φ) do not depend on the natural number a(φ).
Alternatively, it is desirable that the randomizable sampler be such that there is a probability distribution D that has a value in a group Gφ and is indistinguishable from the probability distribution Da=wφa(φ)xφ′wφ−a(φ) of an error of wφa(φ)xφ′ for any element a(φ)ε∀Ωφ of a set Ωφ (the probability distribution Da and the probability distribution D are statistically close to each other). Note that the probability distribution D is not dependent on the natural number a(φ). That the probability distribution Da and the probability distribution D are indistinguishable from each other means that the probability distribution Da and the probability distribution D cannot be distinguished from each other by a polynomial time algorithm. For example, if
ΣgεG|Pr[gεD]−Pr[gεDa]|<ζ (21)
is satisfied for negligible ζ (0≦ζ1), the probability distribution Da and the probability distribution D cannot be distinguished from each other by a polynomial time algorithm. An example of negligible ζ is a function value ζ(k) of the security parameter k. An example of the function value ζ(k) is a function value such that {ζ(k)p(k)} converges to 0 for a sufficiently large k where p(k) is an arbitrary polynomial. Specific examples of the function ζ(k) include ζ(k)=2−k and ζ(k)=2−√k. These also apply to the twelfth to seventeenth embodiments which use natural numbers a(φ) and b(φ).
[Variations of the Twelfth to Eighteenth Embodiments]
In a variation of the twelfth to eighteenth embodiments, even though it is not guaranteed that the capability providing apparatus always performs correct computations, a value uφb′(φ)vφa′(φ) obtained on each of the computing apparatuses φ will be fφ(xφ) with a high probability when the capability providing apparatus correctly computes fφ(τφ,1) and fφ(τφ,2) with a probability greater than a certain probability. Therefore, each of the computing apparatuses φ can cause the capability providing apparatus to perform a computation without performing authentication and can obtain a correct result of the computation (for example, the result of decryption of a ciphertext) by using the result of the computation.
The present invention is not limited to the embodiments described above. For example, random variables Xφ,1, Xφ,2 and Xφ,3 may or may not be the same.
Each of the random number generators generates uniform random numbers to increase the security of the proxy computing system to the highest level. However, if the level of security required is not so high, at least some of the random number generators may generate random numbers that are not uniform random numbers. While it is desirable from the computational efficiency point of view that random natural numbers selected are natural numbers greater than or equal to 0 and less than Kφ,H or natural numbers greater than or equal to 0 and less than or equal to 2μ(k)+k in the embodiments described above, random numbers that are natural numbers greater than or equal to Kφ,II or natural numbers greater than 2μ(k)+k may be selected instead. Here, μ is a function of k. For example, μ may be the length of an element of the group Hφ as a bit string.
The process of the capability providing apparatus may be performed multiple times each time the computing apparatus provides first input information τφ,1 and second input information τφ,2 corresponding to the same a(φ) and b(φ) to the capability providing apparatus. This enables the computing apparatus to obtain a plurality of pieces of first output information zφ,1, second output information zφ,2, and third output information zφ,3 each time the computing apparatus provides first input information τφ,1, and second input information τφ,2 to the capability providing apparatus. Consequently, the number of exchanges and the amount of communication between the computing apparatus and the capability providing apparatus can be reduced.
The computing apparatus may provide a plurality of pieces of the first input information τφ,1 and the second input information τφ,2 to the capability providing apparatus at once and may obtain a plurality of pieces of corresponding first output information zφ,1, second output information zφ,2 and third output information zφ,3 at once. This can reduce the number of exchanges between the computing apparatus and the capability providing apparatus.
The units of the computing apparatus may exchange data directly or through a memory, which is not depicted. Similarly, the units of the capability providing apparatus may exchange data directly or through a memory, which is not depicted.
Check may be made to see whether uφ and vφ obtained at the first computing unit and the second computing unit of any of the embodiments are elements of the group Gφ. They are elements of the group Gφ the process described above may be continued; if uφ or vφ is not an element of the group Gφ, information indicating that the computation is impossible, for example the symbol “⊥”, may be output.
Furthermore, the processes described above may be performed not only in time sequence as is written or may be performed in parallel with one another or individually, depending on the throughput of the apparatuses that perform the processes or requirements. It would be understood that other modifications can be made without departing from the spirit of the present invention.
If any of the configurations described above is implemented by a computer, the processes of the functions the apparatuses need to include are described by a program. The processes of the functions are implemented on the computer by executing the program on the computer. The program describing the processes can be recorded on a computer-readable recording medium. An example of the computer-readable recording medium is a non-transitory recording medium. Examples of such a recording medium include a magnetic recording device, an optical disc, a magneto-optical recording medium, and a semiconductor memory.
The program is distributed by selling, transferring, or lending a portable recording medium on which the program is recorded, such as a DVD or a CD-ROM. The program may be stored on a storage device of a server computer and transferred from the server computer to other computers over a network, thereby distributing the program.
A computer that executes the program first stores the program recorded on a portable recording medium or transferred from a server computer into a storage device of the computer. When the computer executes the processes, the computer reads the program stored on the recording medium of the computer and executes the processes according to the read program. In another mode of execution of the program, the computer may read the program directly from a portable recording medium and execute the processes according to the program or may execute the processes according to the program each time the program is transferred from the server computer to the computer. Alternatively, the processes may be executed using a so-called ASP (Application Service Provider) service in which the program is not transferred from a server computer to the computer but process functions are implemented by instructions to execute the program and acquisition of the results of the execution. Note that the program in this mode encompasses information that is provided for processing by an electronic computer and is equivalent to the program (such as data that is not direct commands to a computer but has the nature that defines processing of the computer).
While the apparatuses are configured by causing a computer to execute a predetermined program in the embodiments described above, at least some of the processes may be implemented by hardware.
As has been described above, each of the computing apparatuses of the embodiments are capable of obtaining a correct result of computation by using the computation capability provided by the capability providing apparatus even if the capability providing apparatus is in a condition where the capability providing apparatus does not always perform a correct process. Accordingly, the computing apparatus does not need to perform verification for confirming the validity of the capability providing apparatus. Furthermore, if a plurality of computing apparatuses share the capability providing apparatus, the computing apparatuses can obtain a correct result of computation.
Such a proxy computing system can be used in, for example, volunteer-based distributed computing, P2P computing services, computing services paid for with payments for advertisements, computing services that are provided as network services or public infrastructures, and network services that are substitutes for computing packages licensed in the form of libraries.
Number | Date | Country | Kind |
---|---|---|---|
2010-239342 | Oct 2010 | JP | national |
2011-005899 | Jan 2011 | JP | national |
2011-077779 | Mar 2011 | JP | national |
2011-088002 | Apr 2011 | JP | national |
The present application is a divisional application of and claims the benefit of priority under 35 U.S.C. §120 to U.S. application Ser. No. 13/881,111, filed Jul. 9, 2013, the entire contents of which is hereby incorporated herein by reference and which is a national stage of International Application No. PCT/JP2011/074546, filed Oct. 25, 2011, which is based upon and claims the benefit of priority under 35 U.S.C. §119 to prior Japanese Patent Applications No. 2010-239342, filed Oct. 26, 2010; No. 2011-005899, filed Jan. 14, 2011; No. 2011-077779, filed Mar. 31, 2011; and No. 2011-088002, filed Apr. 12, 2011, the entire contents of each of which is hereby incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
6509728 | Uchino | Jan 2003 | B1 |
7707420 | Little | Apr 2010 | B1 |
8949614 | Jernigan, IV | Feb 2015 | B1 |
9037623 | Yamamoto | May 2015 | B2 |
20070169179 | Narad | Jul 2007 | A1 |
20090080658 | Waters | Mar 2009 | A1 |
20090129600 | Brickell | May 2009 | A1 |
20100070768 | Furukawa | Mar 2010 | A1 |
20100082973 | Brickell | Apr 2010 | A1 |
20100098253 | Delerablee | Apr 2010 | A1 |
20100329454 | Takashima | Dec 2010 | A1 |
20110194698 | Asano | Aug 2011 | A1 |
20110200186 | Ghouti | Aug 2011 | A1 |
20120323981 | Yamamoto | Dec 2012 | A1 |
20130318360 | Yamamoto | Nov 2013 | A1 |
20150358162 | Kobayashi | Dec 2015 | A1 |
Number | Date | Country |
---|---|---|
2 525 341 | Nov 2012 | EP |
Entry |
---|
Elgamal, T., “A Public Key Cryptosystem and a signature scheme based on Discrete Logarithms”, IEEE Transactions on Information Theory V. IT-31, No. 4 or Crypto, vol. 84, pp. 10-18, (1985). |
Gentry, C., “A Simple BGN-type Cryptosystem from LWE”, Advances in Cryptology-Eurocrypt, Total 16 Pages, (2010). |
Extended European Search Report dated Dec. 13, 2016 in patent application No. 11836267.2. |
Menezes, A. J., “Elliptic Curve Public Key Cryptosystems”, Kluwer Academic Publishers, ISBN, Total 15 Pages, (1993). |
Boyen, X. et al., “Identity Based Cryptography Standard (IBCS) #1: Supersingular Curve Implementations of the BF and BB1 Cryptosystems”, Network Working Group, pp. 1-63, (Dec. 2007). |
Dent, A. W., “Hidden Pairings and Trapdoor DDH Groups”, ANTS, LNCS 4076, Total 17 Pages, (2006). |
Miller, V., “Short Programs for functions on Curves”, URL: http://crypto.stanford.edu/miller/miller/pdf, pp. 2-7, (May 6, 1986). |
Miyaji, A., et al.,“New Explicit Conditions of Elliptic Curve Traces for FR-Reduction,” IEICE Trans. Fundamentals., vol. E84-A, No. 5, pp. 1234-1243, (May 2001). |
Barreto, P. S. L. M., et al., “Constructing Elliptic Curves with Prescribed Embedding Degrees,” SCN 2002, LNCS 2576, pp. 257-267, (2003). |
Dupont, R., et al., “Building curves with arbitrary small MOV degree over finite prime fields”, URL: http://eprint.iacr.org/2002/094/, pp. 1-13, (Jul. 18, 2002). |
Buchmann, J., “Introduction to Cryptography”, Springer Verlag, pp. 52-56, (Jul. 2001) (with partial English translation). |
International Search Report dated Nov. 22, 2011 in PCT/JP11/074546 Filed Oct. 25, 2011. |
Supplementary Partial European Search Report dated Sep. 9, 2016 in Patent Application 11836267.2. |
Go Yamamoto, et al., “On Self-Correctors for Homomorphic Functions” SCIS 2010, The 2010 Symposium on Cryptography and Information Security, XP008172377, Jan. 19, 2010, pp. 1-6. |
Yevgeniy Dodis, et al., “Chosen-Ciphertext Security of Multiple Encryption” Theory of cryptography: Second Theory of Cryptography Conference, XP047029371, Feb. 10, 2005, pp. 188-209. |
Marcos Kiwi, et al., “Exact and Approximate Testing/Correcting of Algebraic Functions: A Survey” Correct System Design, Springer International Publishing, vol. 2292, XP055290782, Jan. 1, 2002, pp. 30-83. |
Number | Date | Country | |
---|---|---|---|
20170104582 A1 | Apr 2017 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13881111 | US | |
Child | 15389080 | US |