The present invention relates to a technique for performing computation with data encrypted.
Homomorphic encryption is a cryptographic technique capable of computing with data encrypted. Recently, while the use of cloud services is becoming widespread, it is conceivable to store data in the cloud after encrypting the data, due to concerns about cracking and reliability of the cloud. Homomorphic encryption is a technique that enables cloud services to be used without compromising safety, because computations can be performed on encrypted data without decryption.
An encryption technique that enables flexible control of a decryptor in accordance with specified conditions in order to improve the convenience of homomorphic encryption is attribute-based homomorphic encryption. In the attribute-based homomorphic encryption, a ciphertext is related to a certain attribute, a decryption key is related to a certain decryption permission condition, and a correct plaintext can be obtained only when a ciphertext is decrypted with such a key having an attribute satisfying the decryption permission condition.
Non Patent Literature 1 describes the first method of the attribute-based homomorphic encryption. In the method described in Non Patent Literature 1, there is a problem that homomorphic computation can be performed only between ciphertexts related to a same attribute.
Non Patent Literature 2 describes a method of the attribute-based homomorphic encryption that solves the problem of Non Patent Literature 1.
Non Patent Literature 2 illustrates a configuration of two encryption techniques called single target attribute-based homomorphic encryption and multiple target attribute-based homomorphic encryption. The single target attribute-based homomorphic encryption is an encryption method that can perform homomorphic computation for a certain decryption permission condition as long as both ciphertexts are related to an attribute satisfying the condition. The multiple target attribute-based homomorphic encryption is an encryption method that can perform homomorphic computation for a plurality of decryption permission conditions as long as both ciphertexts are related to an attribute satisfying any of conditions.
Non Patent Literature 1: C. Gentry, A. Sahai, and B. Waters. “Homomorphic Encryption from Learning with Errors: Conceptually-Simpler, Asymptotically-Faster, Attribute-Based”. In CRYPTO 2013, pages 75-92, 2013.
Non Patent Literature 2: Z. Brakerski, D. Cash, R. Tsabary, and H. Wee. “Targeted Homomorphic Attribute Based Encryption”. In TCC 2016-B, pages 330-360, 2016.
Non Patent Literature 3: C. Peikert, and S. Shiehian “Multi-Key FHE from LWE, revisited” 2016.
In the multiple target attribute-based homomorphic encryption illustrated in Non Patent Literature 2, a ciphertext Y obtained by performing homomorphic computation on a ciphertext X subject to computation is associated with a set F of decryption permission conditions that enable decryption of the ciphertext X subject to computation. In a case of performing homomorphic computation again with a different ciphertext Z before homomorphic computation with use of the ciphertext Y, homomorphic computation cannot be performed unless a decryption permission condition of the ciphertext Z is included in the set F of decryption permission conditions associated with the ciphertext Y.
Therefore, depending on decryption conditions of the ciphertexts X, Y, and Z, it is necessary to collect all the ciphertexts X, Y, and Z in advance and perform homomorphic computation at the same time. Therefore, for example, in performing homomorphic computation on encrypted time series data, an enormous storage capacity is required for collecting and holding all the time series data to be used for computation in advance.
It is an object of the present invention to enable flexible homomorphic computation.
A homomorphic computation device according to the present invention includes:
a ciphertext acquisition unit to acquire a ciphertext ct including an encryption element C in which a plaintext μ is set, an encryption element Cx in which an attribute x is set, and an encryption element F in which the plaintext μ is set, the encryption element F being not to be decrypted with a decryption key skf corresponding to a policy f satisfied by the attribute x;
a policy acquisition unit to acquire a policy set F that is a set of policies;
a ciphertext conversion unit to convert the ciphertext et into a ciphertext ct˜ by converting, with the encryption element F, the encryption element C included in the ciphertext ct acquired by the ciphertext acquisition unit into an encryption element C˜ that can be decrypted with a decryption key skF corresponding to the policy set F acquired by the policy acquisition unit; and
a homomorphic computation unit to perform homomorphic computation g on the ciphertext ct˜ converted by the ciphertext conversion unit, to generate a ciphertext ct*.
In the present invention, an encryption element C is converted into an encryption element C˜ with use of an encryption element F. This makes it possible to perform homomorphic computation without associating an element in the encryption element C with a policy set F. Therefore, it becomes possible to perform flexible homomorphic computation again by using a ciphertext ct* as an input.
***Description of Configuration***
With reference to
The encryption system 10 includes a key generation device 20, an encryption device 30, a homomorphic computation device 40, and a decryption device 50.
The key generation device 20, the encryption device 30, the homomorphic computation device 40, and the decryption device 50 are connected via a network 60. As a specific example, the network 60 is the Internet. The network 60 may be another type of network such as a local area network (LAN).
With reference to
The key generation device 20 is a computer.
The key generation device 20 includes hardware of a processor 21, a memory 22, a storage 23, and a communication interface 24. The processor 21 is connected to other pieces of hardware via a signal line, and controls these other pieces of hardware.
The key generation device 20 includes an acquisition unit 211, a master key generation unit 212, a decryption key generation unit 213, and an output unit 214, as functional components. Functions of the acquisition unit 211, the master key generation unit 212, the decryption key generation unit 213, and the output unit 214 are realized by software.
The storage 23 stores a program for realizing functions of the acquisition unit 211, the master key generation unit 212, the decryption key generation unit 213, and the output unit 214. This program is read into the memory 22 by the processor 21 and executed by the processor 21. Thus, functions of the acquisition unit 211, the master key generation unit 212, the decryption key generation unit 213, and the output unit 214 are realized.
In addition, the storage 23 realizes a function of a master key storage unit 231.
With reference to
The encryption device 30 is a computer.
The encryption device 30 includes hardware of a processor 31, a memory 32, a storage 33, and a communication interface 34. The processor 31 is connected to other pieces of hardware via a signal line, and controls these other pieces of hardware.
The encryption device 30 includes an acquisition unit 311, an encryption unit 312, and an output unit 313, as functional components. Functions of the acquisition unit 311, the encryption unit 312, and the output unit 313 are realized by software.
The storage 33 stores a program for realizing functions of the acquisition unit 311, the encryption unit 312, and the output unit 313. This program is read into the memory 32 by the processor 31 and executed by the processor 31. Thus, functions of the acquisition unit 311, the encryption unit 312, and the output unit 313 are realized.
In addition, the storage 33 realizes a function of a public parameter storage unit 331.
With reference to
The homomorphic computation device 40 is a computer.
The homomorphic computation device 40 includes hardware of a processor 41, a memory 42, a storage 43, and a communication interface 44. The processor 41 is connected to other pieces of hardware via a signal line, and controls these other pieces of hardware.
The homomorphic computation device 40 includes an acquisition unit 411, a ciphertext conversion unit 412, a homomorphic computation unit 413, and an output unit 414, as functional components. The acquisition unit 411 includes a public parameter acquisition unit 415, a ciphertext acquisition unit 416, a policy acquisition unit 417, and a computation acquisition unit 418. Functions of the acquisition unit 411, the ciphertext conversion unit 412, the homomorphic computation unit 413, the output unit 414, the public parameter acquisition unit 415, the ciphertext acquisition unit 416, the policy acquisition unit 417, and the computation acquisition unit 418 are realized by software.
The storage 43 stores a program for realizing functions of the acquisition unit 411, the ciphertext conversion unit 412, the homomorphic computation unit 413, the output unit 414, the public parameter acquisition unit 415, the ciphertext acquisition unit 416, the policy acquisition unit 417, and the computation acquisition unit 418. This program is read into the memory 42 by the processor 41 and executed by the processor 41. Thus, functions of the acquisition unit 411, the ciphertext conversion unit 412, the homomorphic computation unit 413, the output unit 414, the public parameter acquisition unit 415, the ciphertext acquisition unit 416, the policy acquisition unit 417, and the computation acquisition unit 418 are realized.
In addition, the storage 43 realizes functions of a public parameter storage unit 431 and a ciphertext storage unit 432.
With reference to
The decryption device 50 is a computer.
The decryption device 50 includes hardware of a processor 51, a memory 52, a storage 53, and a communication interface 54. The processor 51 is connected to other pieces of hardware via a signal line, and controls these other pieces of hardware.
The decryption device 50 includes an acquisition unit 511, a decryption unit 512, and an output unit 513, as functional components. Functions of the acquisition unit 511, the decryption unit 512, and the output unit 513 are realized by software.
The storage 53 stores a program for realizing functions of the acquisition unit 511, the decryption unit 512, and the output unit 513. This program is read into the memory 52 by the processor 51 and executed by the processor 51. Thus, functions of the acquisition unit 511, the decryption unit 512, and the output unit 513 are realized.
In addition, the storage 53 realizes functions of a key storage unit 531, a condition storage unit 532, and a result storage unit 533.
The processors 21, 31, 41, and 51 are integrated circuits (ICs) that perform computation processing. As a specific example, the processors 21, 31, 41, and 51 are a central processing unit (CPU), a digital signal processor (DSP), or a graphics processing unit (GPU).
The memories 22, 32, 42, and 52 are storage devices that temporarily store data. As a specific example, the memories 22, 32, 42, and 52 are a static random access memory (SRAM) or a dynamic random access memory (DRAM).
The storages 23, 33, 43, and 53 are storage devices that store data. As a specific example, the storages 23, 33, 43, and 53 are a hard disk drive (HDD). In addition, the storages 23, 33, 43, and 53 may be a portable storage medium such as a secure digital (SD, registered trademark) memory card, a compact flash (CF), a NAND flash, a flexible disk, an optical disk, a compact disk, a Blu-Ray (registered trademark) disk, or a digital versatile disk (DVD).
The communication interfaces 24, 34, 44, and 54 are interfaces to communicate with external devices. As a specific example, the communication interfaces 24, 34, 44, and 54 are ports of Ethernet (registered trademark), a universal serial bus (USB), or a high-definition multimedia interface (HDMI, registered trademark).
In
***Description of Operation***
With reference to
The operation of the encryption system 10 according to the first embodiment corresponds to an encryption method according to the first embodiment. Further, the operation corresponds to processing of an encryption program according to the first embodiment.
The operation of the encryption system 10 is divided into Setup processing, KeyGen processing, Enc processing, Eval processing, and Dec processing.
In the following description, the description is made focusing on parts different from the contents described in Non Patent Literature 2, and some explanation is omitted since parts same as the contents described in Non Patent Literature 2 are contents already known.
Reference symbols in the following description will be described.
n, q, and χ are parameters in a learning with errors (LWE) problem. The LWE problem is a known problem. A decisional LWE problem (DLWE problem) is defined as follows.
<DLWE Problem>
Suppose that λ is a security parameter, n=n (λ) and q=q (λ) are integers, and χ=χ (λ) is probability distribution on an integer Z. The problem of DLWEn,q,χ is that (A, sTA+eT) and (A, uT) are computationally indistinguishable when Formula 11 holds for all m=poly(n).
A←qn×m, s←qn, e←χm, u←qm [Formula 11]
m, N, M, and gT are as represented in Formula 12.
m=O(n log q),
n:=┌log q┐,
M:=(m+N+1)┌log q┐,
g
T:=(1,2, . . . , 2┌log q┐) [Formula 12]
For any x ∈Zq, y represented in Formula 13 is a vector that satisfies Formula 14.
y:=g
−1(x) ∈{0,1}┌log q┐ [Formula 13]
y,g=x ∈q [Formula 14]
For any natural numbers n and m, In is a unit matrix of n rows and n columns, and 0n×m is a matrix of n rows and m columns with all elements 0. For any i ∈[n], ei ∈{0, 1}n is a standard basis vector in which n-th element is 1 and others are 0. Note that i ∈[n] means i=1, . . . n.
F ⊆{0, 1}L→{0, 1} is a class of a policy that can be calculated by Boolean circuit of a depth dF. G ⊆{0, 1}*→{0, 1} is a class of computation that can be calculated by Boolean circuit of a depth dG.
With reference to
The Setup processing is mainly executed by the key generation device 20 at a time of initial setting or the like of the encryption system 10. The Setup processing according to the first embodiment corresponds to a master key generation method and processing of a master key generation program according to the first embodiment.
(Step S11: Acquisition Process)
The acquisition unit 211 of the key generation device 20 acquires the parameters λ, L, dF, and dG.
Specifically, the acquisition unit 211 accepts the parameters λ, L, dF, and dG inputted by an administrator or the like of the encryption system 10, via the communication interface 24. The acquisition unit 211 writes the accepted parameters λ, L, dF, and dG into the memory 22.
(Step S12: Master Key Generation Process)
The master key generation unit 212 of the key generation device 20 generates a pair of a public parameter pp and a master secret key msk.
Specifically, the master key generation unit 212 generates a pair (A, Aτ0−1) of a matrix A and a trapdoor Aτ0−1, as represented in Formula 15.
The TrapGen algorithm is described in Non Patent Literature 2. Here, the matrix A is a matrix represented in Formula 16, and the trapdoor Aτ0−1 is an algorithm represented in Formula 17.
A ∈qn×m [Formula 16]
A
τ0
−1(u)=x,
Ax=u [Formula 17]
The master key generation unit 212 generates matrices B, B0, B1, . . . , BL and defines B→x, as represented in Formula 18.
The master key generation unit 212 generates a vector v and a seed σ of pseudo random function (PRF) as represented in Formula 19.
The PRF.Gen algorithm is described in Non Patent Literature 2.
The master key generation unit 212 sets (A, B0, B→x, B, v) as the public parameter pp, and (Aτ)−1, σ) as the master secret key msk. The master key generation unit 212 writes the public parameter pp into the memory 22, and writes the public parameter pp and the master secret key msk into the master key storage unit 231.
(Step S13: Output Process)
The output unit 214 of the key generation device 20 outputs the public parameter pp.
Specifically, the output unit 214 reads the public parameter pp from the memory 22. Then, the output unit 214 transmits the public parameter pp to the encryption device 30, the homomorphic computation device 40, and the decryption device 50 via the communication interface 24.
(Step S14: Public Parameter Acquisition Process)
The acquisition unit 311 of the encryption device 30, the public parameter acquisition unit 415 of the homomorphic computation device 40, and the acquisition unit 511 of the decryption device 50 acquire the public parameter pp.
Specifically, the acquisition unit 311 receives the public parameter pp transmitted by the output unit 214, via the communication interface 34. The acquisition unit 311 writes the received public parameter pp into the public parameter storage unit 331.
Further, the public parameter acquisition unit 415 of the homomorphic computation device 40 receives the public parameter pp transmitted by the output unit 214, via the communication interface 44. The public parameter acquisition unit 415 writes the received public parameter pp into the public parameter storage unit 431.
In addition, the acquisition unit 511 of the decryption device 50 receives the public parameter pp transmitted by the output unit 214, via the communication interface 54. The acquisition unit 511 writes the received public parameter pp into the key storage unit 531.
That is, the key generation device 20 executes the Setup algorithm represented in Formula 20 to generate the public parameter pp and the master secret key msk.
With reference to
The KeyGen processing is mainly executed by the key generation device 20 in generating a new decryption key skf. The KeyGen processing according to the first embodiment corresponds to a decryption key generation method and processing of a decryption key generation program according to the first embodiment.
(Step S21: Decryption Key Request Process)
The acquisition unit 511 of the decryption device 50 requests the key generation device 20 to generate the decryption key skf.
Specifically, the acquisition unit 511 accepts a policy f indicating a decryption permission condition inputted by a user or the like of the decryption device 50. For the policy f, for example, an attribute of the user is set. Then, the acquisition unit 511 transmits the inputted policy f to the key generation device 20, and requests generation of the decryption key skf associated with the policy f.
The acquisition unit 511 writes the policy f transmitted when the generation of the decryption key skf is requested, into the condition storage unit 532.
(Step S22: Acquisition Process)
The acquisition unit 211 of the key generation device 20 acquires the policy f.
Specifically, the acquisition unit 211 receives the policy f transmitted from the decryption device 50, via the communication interface 24. The acquisition unit 211 writes the received policy f into the memory 22.
(Step S23: Decryption Key Generation Process)
The decryption key generation unit 213 of the key generation device 20 generates the decryption key skf associated with the policy f.
Specifically, the decryption key generation unit 213 reads the policy f from the memory 22, and reads the public parameter pp and the master secret key msk from the master key storage unit 231. The decryption key generation unit 213 calculates a matrix Bf as represented in Formula 21.
B
f:=Eval(f, B→x) [Formula 21]
The Eval algorithm is described in Non Patent Literature 2.
The decryption key generation unit 213 queries to a random oracle, to obtain a matrix r′f=O(A, f) ∈{0, 1}N. That is, the decryption key generation unit 213 generates the random matrix r′f. The decryption key generation unit 213 generates a matrix rf as represented in Formula 22.
Here, τ is as represented in Formula 23.
τ=O(m·NL·(N+1)d)τ0 [Formula 23]
At this time, since the trapdoor Aτ0−1 is an algorithm represented in Formula 17, Formula 24 is established.
The decryption key generation unit 213 writes the matrix rf into the memory 22, as the decryption key skf.
(Step S24: Output Process)
The output unit 214 of the key generation device 20 outputs the decryption key skf.
Specifically, the output unit 214 reads the decryption key skf from the memory 22. Then, the output unit 214 transmits the decryption key skf to the decryption device 50 via the communication interface 24.
(Step S25: Decryption Key Acquisition Process)
The acquisition unit 511 of the decryption device 50 acquires the decryption key skf.
Specifically, the acquisition unit 511 receives the decryption key skf transmitted by the output unit 214, via the communication interface 54. The acquisition unit 511 writes the received decryption key skf into the key storage unit 531.
That is, the key generation device 20 executes the KeyGen algorithm represented in Formula 25 to generate the decryption key skf.
With reference to
The Enc processing is mainly executed by the encryption device 30 in generating a ciphertext ct. The Enc processing according to the first embodiment corresponds to an encryption method and processing of an encryption program according to the first embodiment.
(Step S31: Acquisition Process)
The acquisition unit 311 of the encryption device 30 acquires a plaintext μ and an attribute x.
Specifically, the acquisition unit 311 accepts the plaintext μ and the attribute x inputted by a user or the like of the encryption device 30, via the communication interface 34. The plaintext μ is a message to be transmitted after being encrypted, and is the plaintext μ ∈{0, 1}. The attribute x is an attribute associated with a ciphertext and is an attribute x ∈{0, 1}L. The acquisition unit 311 writes the plaintext μ and the attribute x into the memory 32.
(Step S32: Encryption Process)
The encryption unit 312 of the encryption device 30 generates the ciphertext ct obtained by encrypting the plaintextμ with the attribute x set.
Specifically, the encryption unit 312 reads the public parameter pp from the public parameter storage unit 331 and reads the plaintext μ and the attribute x from the memory 32. The encryption unit 312 generates a matrix S, a matrix EA, and an error vector ev as represented in Formula 26.
The encryption unit 312 generates a matrix Ri,j for each integer i of i ∈{0, 1, . . . , L} and each integer j of j ∈[M] as represented in Formula 27.
The encryption unit 312 generates a matrix Ei[j] for each integer i of i ∈{0, 1, . . . , L} and each integer j of j ∈[M] as represented in Formula 28. Here, Ei[j] and EA [j] represent j-th columns of the matrix Eiand the matrix EA, respectively.
Ei[j]:=Ri,jTEA[j] [Formula 28]
The encryption unit 312 generates a matrix C as represented in Formula 29, and generates a matrix Cx as represented in Formula 30.
The matrix C is set with the plaintext and is configured to be decryptable with the decryption key skf corresponding to the policy f satisfied by the attribute x.
Here, Formula 31 indicates a tensor product.
⊗ [Formula 31]
Further, Formula 32 holds.
{right arrow over (G)}:=I
m+N+1
⊗g
T [Formula 32]
The encryption unit 312 generates a matrix R and a matrix EF as represented in Formula 33.
The encryption unit 312 generates a matrix F as represented in Formula 34.
As represented in Formula 34, the plaintext μ and the matrix R that is a random number are set for the matrix F. The matrix F includes a matrix B instead of a matrix B0 included in the matrix, and is configured not to be decrypted by the decryption key skf corresponding to the policy f satisfied by the attribute x.
As represented in Formula 35, the encryption unit 312 generates a matrix E(k)A, a vector e(k)v, and a matrix R(k)i,j for each integer i of i ∈{0, 1, . . . , L}, each integer j of j ∈[M], and each integer k of k ∈[N].
The encryption unit 312 generates a vector E(k)i and a matrix E(k) as represented in Formula 36. Here, E(k)i [j] and the matrix E(k)A [j] represent j-th columns of the matrix E(k)i and the matrix E(k)A, respectively.
E
i
(k)[i]:=(Ri,j(k))TEA(k)[j],
E
(k):=[(EA(k))T∥(E0(k))T∥ev(k)]T [Formula 36]
The encryption unit 312 generates matrices S(1), . . . , S(N) as represented in
Formula 37.
The encryption unit 312 generates a matrix D as represented in Formula 38, and generates a matrix D(k)x as represented in Formula 39.
That is, in the matrix D, the matrix R that is a random number included in the matrix F is encrypted.
The encryption unit 312 writes, into the memory 32, the ciphertext ct having the attribute x, the matrix C, the matrix Cx, the matrix F, the matrix D, and the matrix D(k)x for each integer k of k ∈[N], as encryption elements. That is, the ciphertext ct includes: the matrix C that is an encryption element in which the plaintext μ is set; the matrix Cx that is an encryption element in which the attribute x is set; the matrix F that is an encryption element not to be decrypted by the decryption key skf corresponding to the policy f satisfied by the attribute x, and in which the plaintext μ and the matrix R that is a random number are set; and the matrix D that is an encryption element in which the matrix R that is a random number is encrypted.
(Step S33: Output Process)
The output unit 313 of the encryption device 30 outputs the ciphertext ct.
Specifically, the output unit 313 reads the ciphertext ct from the memory 32. Then, the output unit 313 transmits the ciphertext ct to the homomorphic computation device 40 via the communication interface 34.
(Step S34: Ciphertext Acquisition Process)
The ciphertext acquisition unit 416 of the homomorphic computation device 40 receives the ciphertext ct transmitted by the output unit 313, via the communication interface 44. The ciphertext acquisition unit 416 writes the received ciphertext ct into the ciphertext storage unit 432.
That is, the encryption device 30 executes the Enc algorithm represented in Formulas 40 to 41, to generate the ciphertext ct.
With reference to
The Eval processing is executed by the homomorphic computation device 40 in performing homomorphic computation on the ciphertext et. The Eval processing according to the first embodiment corresponds to a homomorphic computation method and processing of a homomorphic computation program according to the first embodiment.
(Step S41: Ciphertext Acquisition Process)
The ciphertext acquisition unit 416 acquires ciphertexts ct(1), . . . , ct(k) subject to computation. Here, k is an integer of 1 or more.
Specifically, the ciphertext acquisition unit 416 reads the ciphertexts ct(1), . . . , ct(k) specified by a user or the like of the homomorphic computation device 40, via the communication interface 44 from the ciphertext storage unit 432. The ciphertext acquisition unit 416 writes the read ciphertexts ct(1), . . . , ct(k) into the memory 42.
(Step S42: Policy Acquisition Process)
The policy acquisition unit 417 of the homomorphic computation device 40 acquires a policy set F:={f1, . . . , fd}, which is a set of policies. Here, d is an integer of 1 or more.
Specifically, the policy acquisition unit 417 accepts the policy set F inputted by a user or the like of the homomorphic computation device 40, via the communication interface 44. The policy acquisition unit 417 writes the accepted policy set F into the memory 42.
Note that, in order to perform homomorphic computation, a ciphertext ct(i) for each integer i of i=1, . . . , k read out in step S41 needs to satisfy any of f1, . . . , fd included in the policy set F. In other words, it is necessary for the ciphertext ct(i) for each integer i of i=1, . . . , k to be decryptable with the decryption key skf associated with any of f1, . . . , fd. That is, assuming that an attribute that has been set for the ciphertext ct(i) for each integer i of i=1, . . . , k is an attribute xi, fj(xi)=0 needs to be satisfied for a certain j ∈[d], for each integer i of i=1, . . . , k.
(Step S43: Computation Acquisition Process)
The computation acquisition unit 418 of the homomorphic computation device 40 acquires homomorphic computation g to be executed.
Specifically, the computation acquisition unit 418 accepts the homomorphic computation g inputted by a user or the like of the homomorphic computation device 40, via the communication interface 44. The computation acquisition unit 418 writes the accepted homomorphic computation g into the memory 42.
(Step S44: Ciphertext Conversion Process)
The ciphertext conversion unit 412 of the homomorphic computation device 40 converts the ciphertext ct(i) for each integer i of i=1, . . . , k into a ciphertext ct(1)˜:=(C˜, F˜, D˜).
Specifically, the ciphertext conversion unit 412 first executes an Apply algorithm and then executes an Expansion algorithm on the ciphertext ct(i) for each integer i of i=1, . . . , k as a target. However, the Apply algorithm is executed only for the ciphertext ct(i) that has never been subjected to homomorphic computation. That is, the Apply algorithm is executed in a case where the ciphertext ct(i) is generated by the encryption device 30 and is the ciphertext ct outputted in step S33 of
Here, to simplify the expression, the target ciphertext ct(i) is written as a ciphertext ct, and the ciphertext ct(i)˜ obtained by converting the ciphertext ct(i) is written as a ciphertext ct˜. Further, a policy fj satisfied by the target ciphertext ct(i) is written as a policy f.
The Apply algorithm will be described.
The ciphertext conversion unit 412 calculates a matrix H as represented in Formula 42.
H:=EvRelation(f, x, {right arrow over (B)}x) [Formula 42]
The EvRelation algorithm is described in Non Patent Literature 2.
The ciphertext conversion unit 412 generates a matrix Cf: =HTCx. The ciphertext conversion unit 412 generates a matrix Ĉf as represented in Formula 43.
For each integer i of i ∈[k], the ciphertext conversion unit 412 generates a matrix D(i)f as represented in Formula 44.
D
f
(i)
:=H
T
D
x
(i) [Formula 44]
The ciphertext conversion unit 412 generates a matrix Df as represented in Formula 45.
D
f[0M×m∥(Df(1))T⊕0M∥ . . . ∥0M×m∥(Df(N))T∥0M]T [Formula 45]
The ciphertext conversion unit 412 generates a matrix D̂f: =Df+D.
That is, the ciphertext conversion unit 412 executes the Apply algorithm represented in Formula 46.
The Expansion algorithm will be described.
Here, when the target ciphertext ct(i) is the ciphertext ct*:=(C*, F*, D*) outputted in step S46 to be described later, Ĉf:=C*, F:=F*, and D̂f:=D* are set.
The ciphertext conversion unit 412 sets the matrix F as a matrix F˜ as it is.
The ciphertext conversion unit 412 generates a matrix D˜ as represented in Formula 47.
The ciphertext conversion unit 412 generates a matrix C˜ as represented in Formula 48.
Here, a matrix X is as represented in Formula 49.
X:=(s ⊗In′)·D̂f [Formula 49]
Further, a matrix s is as represented in Formula 50.
s:=(In⊗g−T)((Bf+B0−B)r′f) ∈{0,1}N [Formula 50]
Note that the vector r′f ∈{0, 1}N is a vector obtained by querying f to a random oracle. That is, the vector r′f is a random vector. Further, Bf is as represented in Formula 21.
The ciphertext conversion unit 412 writes the ciphertext ct˜:=(C˜, F˜, D˜) into the memory 42.
That is, the ciphertext conversion unit 412 executes the Expansion algorithm represented in Formula 51.
(Step S45: Homomorphic Computation Process)
The homomorphic computation unit 413 of the homomorphic computation device 40 executes the homomorphic computation g on the ciphertext ct(i)˜ for each integer i of i=1, . . . , k, to generate the ciphertext ct*:=(C*, F*, D*).
Specifically, the homomorphic computation unit 413 reads the ciphertext ct(i)˜ for each integer i of i=1, . . . k. Then, with the ciphertext ct(i)˜ for each integer i of i=1, . . . , k as an input, the homomorphic computation unit 413 executes the homomorphic computation g in accordance with the homomorphic computation method described in “3.2 Homomorphic Operations” of Non Patent Literature 3, to generate the ciphertext ct*. The homomorphic computation unit 413 writes the generated ciphertext ct* into the memory 42.
As a specific example, a case of performing homomorphic addition on two ciphertexts ct(1)˜:=(C1, F1, D1) and ct(2)˜:=(C2, F2, D2) will be described. In this case, the homomorphic computation unit 413 calculates each encryption element such as C*:=C1+C2, F*:=F1+F2, and D*:=D1+D2.
Further, as a specific example, a case of performing homomorphic multiplication on two ciphertexts ct(1)˜:=(C1, F1, D1) and ct(2)˜:=(C2, F2, D2) will be described. In this case, the homomorphic computation unit 413 calculates each encryption element as represented in Formula 52.
C*:=C
1·(In′, ⊗g−T)(C2),
F*:=F
1·(Im+N+1⊗g−T)(F2),
D*:=D
1·(Im+N+1⊗g−T)(F2)+(IN⊗C1)·(In′N⊗g−T)(D2) [Formula 52]
(Step S46: Output Process)
The output unit 414 of the homomorphic computation device 40 outputs the ciphertext ct*.
Specifically, the output unit 414 reads the ciphertext ct* from the memory 42. Then, the output unit 414 writes the ciphertext ct* into the ciphertext storage unit 432.
That is, the homomorphic computation device 40 executes the Evaluation algorithm represented in Formula 53 to generate the ciphertext ct*.
Note that the H.Op algorithm is a computation algorithm of homomorphic computation described in Non Patent Literature 3.
With reference to
The Dec processing is mainly executed by the decryption device 50 in decrypting the ciphertext ct. The Dec processing according to the first embodiment corresponds to a decryption method and processing of a decryption program according to the first embodiment.
(Step S51: Acquisition Process)
The acquisition unit 511 of the decryption device 50 acquires a ciphertext ct(F):=(ĈF, F, D̂F) to be decrypted.
Specifically, the acquisition unit 511 transmits an acquisition request for the ciphertext ct(F) to the homomorphic computation device 40 via the communication interface 54. Upon receiving the acquisition request, the output unit 414 of the homomorphic computation device 40 reads the requested ciphertext ct(F) from the ciphertext storage unit 432. At this time, in a case where the ciphertext ct(F) is the ciphertext et outputted in step S33 of
The ciphertext ct(F) means that it is a ciphertext that can be decrypted by the decryption keys skf1, . . . , skfd associated with the policy set F:={f1, . . . , fd}.
(Step S52: Decryption Process)
The decryption unit 512 of decryption device 50 decrypts the ciphertext ct(F) with decryption key skf1:=skfd:=rfd, to calculate a value μ˜.
Specifically, the decryption unit 512 acquires a matrix r′fj:=O(A, fj) by querying to a random oracle for each integer j of j ∈[d]. The decryption unit 512 concatenates the decryption key skfj for each integer j of j ∈[d] as represented in Formula 54, to generate a decryption key rFT.
rFT:=[rf1T∥r′f1T∥1∥ . . . ∥rfdT∥r′fdT∥1] [Formula 54]
The decryption unit 512 calculates a vector c as represented in Formula 55.
c:=rFTĈF [Formula 54]
The decryption unit 512 calculates the value μ˜ as represented in Formula 56.
{tilde over (μ)}:=cT·(Id(m+N+1)⊗g−T)(u) [Formula 56]
Here, the vector u is as represented in Formula 57.
u
T:=(0, . . . , 0, └q/2┘) ∈1×d(m+N+1) [Formula 57]
(Step S53: Output Process)
The output unit 513 of the decryption device 50 outputs 0 when an absolute value of the value μ˜ is less than q/4, or otherwise outputs 1.
That is, the decryption device 50 executes a Dec algorithm represented in
Formula 58, to decrypt the ciphertext ct(F).
Dec(ct(F):=(ĈF, F, D̂F), skf1, . . . , skfd)
r′
fj
:=O(A, fj) for j=1, . . . , d,
rFTL=[rf1T∥r′f1T∥1∥ . . . ∥rfdT∥r′fdT∥1],
c:=rFTĈF,
u
T:=(0, . . . , 0, └q/2┘) ∈1×d(m+N+1),
{tilde over (μ)}:=cT·(Id(m+N+1)⊗g−T)(u) [Formula 58]
return if |{tilde over (μ)}|<q/4 then 0, otherwise 1.
***Effect of First Embodiment***
As described above, in the encryption system 10 according to the first embodiment, the matrix C that is an encryption element is converted into the matrix C˜ that is an encryption element, by using the encryption element F. This makes it possible to perform homomorphic computation without associating an element in the encryption element C with the policy set F. Therefore, it becomes possible to perform flexible homomorphic computation again by using the ciphertext ct* as an input.
The reason why the effect of enabling flexible homomorphic computation again with the ciphertext ct* as an input is obtained will be described.
Suppose that a ciphertext ct(f):=(Ĉf, F, D̂f) is obtained as a result of execution of the Apply algorithm described in step S44 of
At this time, the ciphertext ct(f) satisfies relationships (1) to (3) represented in Formula 59 for a decryption key t ∈Zqm−N+1 and a small random matrix R ∈Zqn×M.
Suppose that the ciphertext ct˜:=(C˜, F˜, D˜) is obtained as a result of execution of the Expansion algorithm described in step S44 of
The matrix F becomes the matrix F˜ as it is. Therefore, the random matrix R becomes the random matrix R˜ as it is. Therefore, the relationship represented in (2) of Formula 59 is satisfied.
The matrix ID˜ is generated as represented in Formula 47. At this time, the relationship represented in Formula 60 is established.
Therefore, the relationship of (3) of Formula 59 is satisfied.
The matrix C˜ is generated as represented in Formula 48. At this time, with a configuration of the matrix X, the relationship of Formula 61 is established.
Therefore, the relationship of Formula 62 is established.
As a result, the relationship of Formula 63 is established, and the relationship of (1) of Formula 59 is satisfied.
{tilde over (t)}TĈ≈μ({tilde over (t)}T ⊗gT) [Formula 63]
Suppose that the ciphertext ct*:=(C*, F*, D*) is obtained as a result of execution of the homomorphic computation g described in step S45 of
That is, the ciphertext ct* obtained as a result of execution of the homomorphic computation g holds the relationship satisfied by the ciphertext ct(f) obtained as a result of execution of the Apply algorithm with the ciphertext ct generated by the encryption device 30 as an input. Therefore, a state of satisfying this relationship can be obtained even when the Expansion algorithm is executed with the ciphertext ct* obtained as a result of execution of the homomorphic computation g as an input, instead of the ciphertext ct generated by the encryption device 30. As a result, flexible homomorphic computation can also be performed for the ciphertext ct* obtained as a result of execution of the homomorphic computation g, similarly to the ciphertext ct generated by the encryption device 30.
That is, in step S44 of
That is, the ciphertext conversion unit 412 converts the matrix C that is an encryption element in which the plaintext μ is set, and the matrix Cx that is an encryption element in which the attribute x is set, by using the matrix F that is an encryption element not to be decrypted with the decryption key skf corresponding to the policy f satisfied by the attribute x and in which the plaintext μ and the matrix R that is a random number are set, and using the matrix D that is an encryption element in which the matrix R that is a random number is encrypted. In this way, by using the matrix F and the matrix D, the ciphertext conversion unit 412 makes it possible to perform the homomorphic computation while maintaining the relationship established between the ciphertext, and the decryption key and a random number R.
***Other Configuration***
<Modification 1>
In the first embodiment, the functional components of the key generation device 20, the encryption device 30, the homomorphic computation device 40, and the decryption device 50 are realized by software. However, as Modification 1, the functional components may be realized by hardware. With regard to Modification 1, points different from the first embodiment will be described.
With reference to
In a case where a function is realized by hardware, the key generation device 20 includes a processing circuit 25, instead of the processor 21, the memory 22, and the storage 23. The processing circuit 25 is a dedicated electronic circuit to realize functional components of the key generation device 20 and functions of the memory 22 and the storage 23.
With reference to
In a case where a function is realized by hardware, the encryption device 30 includes a processing circuit 35, instead of the processor 31, the memory 32, and the storage 33. The processing circuit 35 is a dedicated electronic circuit to realize functional components of the encryption device 30 and functions of the memory 32 and the storage 33.
Referring to
In a case where a function is realized by hardware, the homomorphic computation device 40 includes a processing circuit 45, instead of the processor 41, the memory 42, and the storage 43. The processing circuit 45 is a dedicated electronic circuit to realize functional components of the homomorphic computation device 40 and functions of the memory 42 and the storage 43.
With reference to
In a case where a function is realized by hardware, the decryption device 50 includes a processing circuit 55, instead of the processor 51, the memory 52, and the storage 53. The processing circuit 55 is a dedicated electronic circuit to realize functional components of the decryption device 50 and functions of the memory 52 and the storage 53.
For the processing circuits 25, 35, 45, and 55, a single circuit, a composite circuit, a programmed processor, a parallel programmed processor, a logic IC, a gate array (GA), an application specific integrated circuit (ASIC), or a field-programmable gate array (FPGA) is assumed.
A function of each functional component of the key generation device 20 may be realized by one processing circuit 25, or a function of each functional component may be distributed to a plurality of processing circuits 25, to be realized. Similarly, for each of the encryption device 30, the homomorphic computation device 40, and the decryption device 50, a function of each functional component may be realized by one processing circuit 35, 45, or 55, or a function of each functional component may be distributed to a plurality of processing circuits 35, 45, or 55, to be realized.
<Modification 2>
In Modification 2, some function may be realized by hardware, and other function may be realized by software. That is, in each functional component, some function may be realized by hardware, and other function may be realized by software.
The processors 21, 31, 41, and 51, the memories 22, 32, 42, and 52, the storages 23, 33, 43, and 53, and the processing circuits 25, 35, 45, and 55 are collectively referred to as “processing circuitry”. That is, a function of each functional component is realized by the processing circuitry.
***Description of Notation***
When A is a random variable value or distribution, Formula 64 represents random selection of y from A in accordance with distribution of A. That is, in Formula 64, y is a random number.
When A is a set, Formula 65 represents uniform selection of y from A. That is, in Formula 65, y is a uniform random number.
Formula 66 represents that y is a set defined by z, or that y is a set into which z is assigned.
y:=z [Formula 66]
When a is a constant, Formula 67 represents that a machine (algorithm) A outputs a for an input x.
A(x)→a
Zq represents a group of integers of an order q. Further, y ∈Zqv indicates that y is a vector with v elements on Zq. Further, y ∈Zqv×w indicates that y is a matrix of v rows and w columns with elements on Zq.
10: encryption system, 20: key generation device, 21: processor, 22: memory, 23: storage, 24: communication interface, 25: processing circuit, 211: acquisition unit, 212: master key generation unit, 213: decryption key generation unit, 214: output unit, 231: master key storage unit, 30: encryption device, 31: processor, 32: memory, 33: storage, 34: communication interface, 35: processing circuit, 311: acquisition unit, 312: encryption unit, 313: output unit, 331: public parameter storage unit, 40: homomorphic computation device, 41: processor, 42: memory, 43: storage, 44: communication interface, 45: processing circuit, 411: acquisition unit, 412: ciphertext conversion unit, 413: homomorphic computation unit, 414: output unit, 415: public parameter acquisition unit, 416: ciphertext acquisition unit, 417: policy acquisition unit, 418: computation acquisition unit, 431: public parameter storage unit, 432: ciphertext storage unit, 50: decryption device, 51: processor, 52: memory, 53: storage, 54: communication interface, 55: processing circuit, 511: acquisition unit, 512: decryption unit, 513: output unit, 531: key storage unit, 532: condition storage unit, 533: result storage unit, λ: security parameter, pp: public parameter, msk: master secret key, skf: decryption key, μ: plaintext, x: attribute, ct, ct(F), ct˜, ct*: ciphertext, F: policy set, g: homomorphic computation.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/JP2017/001589 | 1/18/2017 | WO | 00 |