The present invention relates to predicate encryption.
Non-Patent Literature 1 describes a predicate encryption scheme using predicates of arithmetic branching programs (ABP). This predicate encryption scheme is a scheme that allows a wide range of predicates.
The security of the predicate encryption scheme described in Non-Patent Literature 1 is not adaptive security that is practical. Therefore, there is concern about whether the security of this predicate encryption scheme is maintained when it is actually used.
It is an object of the present invention to make it possible to realize a predicate encryption scheme that allows a wide range of predicates as with the predicate encryption scheme described in Non-Patent Literature 1 and also allows security to be enhanced.
A decryption device according to the present invention includes
a ciphertext acquisition unit to acquire a ciphertext in which one of a predicate vector of arithmetic branching programs (ABP) and an attribute vector is set over a basis B of the basis B and a basis B*, which are dual bases in dual vector spaces;
a decryption key acquisition unit to acquire a decryption key in which the other one of the predicate vector and the attribute vector is set over the basis B*; and
a decryption unit to decrypt the ciphertext by performing a pairing operation on the ciphertext acquired by the ciphertext acquisition unit and the decryption key acquired by the decryption key acquisition unit.
In the present invention, a ciphertext is decrypted by performing a pairing operation on the ciphertext in which one of a predicate vector of ABP and an attribute vector is set over a basis B and a decryption key in which the other one is set over a basis B*, the basis B and the basis B* being dual bases in dual vector spaces. This makes it possible to realize a predicate encryption scheme that allows a wide range of predicates and also allows security to be enhanced.
***Notations***
Notations to be used in the following description will be described.
Formula 101 denotes a security parameter, and 1λ represents encoding of unary code.
λ∈ [Formula 101]
Formula 102 denotes a finite field modulo q. Formula 102 will be written as a field Fq or simply as Fq.
q for any prime q∈ [Formula 102]
For Formula 103, Formula 104 is defined.
d∈,
c∈∪{0}(c<d) [Formula 103]
[d]={1, . . . ,d},
[c,d]={c, . . . ,d} [Formula 104]
Formula 105 denotes a process of uniformly sampling an element z from a set Z.
#Z denotes the size or cardinality of the set Z.
For a probabilistic algorithm U, Π=U(Θ;Φ) denotes output of the algorithm U on input Θ with content Φ of a random tape. Formula 106 denotes a process of sampling Π from the output distribution of the algorithm U on input Θ with a uniform random tape.
For a deterministic algorithm V, Π=V(Θ) denotes output of the algorithm V on input Θ.
It is assumed that each algorithm is given the unary representation 1λ of the security parameter λ as input without any explicit indication of the input when it is clear from the context.
For Formula 107, Formula 108 denotes a vector indicated in Formula 109. Formula 108 will be written as v→.
q,d∈ [Formula 107]
{right arrow over (v)} [Formula 108]
(v1, . . . ,vd)∈qd
where vi∈q for all i∈d [Formula 109]
An all zero vector in a field Fqd will be written as indicated in Formula 110.
{right arrow over (0)}d [Formula 110]
For two vectors indicated in Formula 111, Formula 112 denotes the inner product of the vector v→ and the vector w→. That is, Formula 112 denotes Formula 113.
{right arrow over (v)},{right arrow over (w)}∈qd [Formula 111]
{right arrow over (v)}·{right arrow over (w)} [Formula 112]
Formula 114 denotes a multiplicative cyclic group. Formula 114 will be written as a group G or simply as G.
[Formula 114]
For the group G and a generator g of the group G, v denotes a d-dimensional vector of group elements. That is, this is expressed in Formula 115.
v=(gv
where {right arrow over (v)}=(v1, . . . ,vd)∈qd [Formula 115]
Formula 116 denotes a d-dimensional vector of group elements indicated in Formula 117. Formula 118 denotes an identity element of the group G.
1d [Formula 116]
1 [Formula 118]
M=(mi,k) denotes a matrix with entries mi,k ∈Fq. MT denotes a transpose of the matrix M. Note that det(M) denotes a determinant of the matrix M. In describing matrices, I denotes an identity matrix, and 0 denotes a zero matrix. GL(d, Fq) denotes a set of all d×d invertible matrices in Fqd×d.
***Preliminaries***
Definitions of terms and the like to be used in the following description will be described.
In a first embodiment, a partially-hiding predicate encryption (PHPE) scheme using (ABP∘IP) predicates encompassing predicates of ABP and inner-product predicates will be described.
<PHPE>
PHPE is predicate encryption (PE) that partially conceals attributes. In the following description, an attribute vector x→ and an attribute vector z→ are given, and the attribute vector x→ is a public attribute vector to be published and the attribute vector z→ is a secret attribute vector to be kept secret.
<ABP>
A branching program (BP) Γ is defined by five elements indicated in Formula 119.
Γ=(,,V0,V1,ϕ) [Formula 119]
Formula 120 denotes a set of vertices, and Formula 121 denotes a set of edges. Formula 120 will be written simply as V, and Formula 121 will be written simply as E.
[Formula 120]
[Formula 121]
(V, E) is a directed acyclic graph. V0 and V1∈V are special vertices called a source and a sink respectively, and φ is a labeling function for edges in E.
An ABP Γ over a finite field Fq computes a function f indicated in Formula 122.
f:qd→q for some d∈ [Formula 122]
Note that the labeling function φ assigned to each edge in E is a degree one polynomial function in one variable with coefficients in Fq or a constant in Fq. Let p be a set of all paths from the source V0 to the sink V1 in the ABP Γ. The output of the function f computed by the ABP Γ on some input v→=(v1, . . . , vd)∈Fqd is defined as indicated in Formula 123.
Formula 124 denotes an evaluation value of a function φ(E) at v→.
E∈,ϕ(E)|{right arrow over (v)} [Formula 124]
The following content is presented in Non-Patent Literature 2.
When ABP Γ=(V, E, V0, V1, φ) computing a function f is given, it is possible to efficiently and deterministically compute a function L mapping input v→∈Fqd to a (#V−1)×(#V−1) matrix L(v→) over Fq. The following (1) to (3) hold:
Specifically, the matrix L is obtained by removing the column corresponding to V0 and the row corresponding to V1 from a matrix AΓ−I, where the matrix AΓ is an adjacency matrix for Γ and I is an identity matrix.
Note that there exists a linear-time algorithm that converts any Boolean formula, Boolean branching program, or arithmetic formula to an ABP.
<Function Family F(q,n′,m)ABP∘IP>
A function family F(q,n′,m)ABP∘IP is a function family supported by the PHPE scheme according to the first embodiment.
The function family F(q,n′,m)ABP∘IP is parameterized by a prime q and natural numbers n′ and n, and contains a function f indicated in Formula 125.
The function f is ζf(x→,ζz→)=ζf(x→,z→) for ∈Fq and (x→,z→)∈Fqn′×Fqn.
The function f realized by the ABP Γ is constructed as described below.
First, all the source vertices of ABP{Γj}j∈[n] are merged into a single vertex, and the merged single vertex is designated as the source vertex of the ABP Γ. Next, a new sink vertex for the ABP Γ is generated. For each integer j of j∈[n], the sink vertex of the ABP Γj is connected to the new sink vertex with a directed edge labeled with zj. Note that the size of the ABP Γ computing the function f is m+n+1, where 1 corresponds to the sink vertex of the ABP Γ, n corresponds to the number of edges directed to the sink vertex, and m corresponds to other vertices in the ABP Γ.
The ABP F is modified to an ABP Γ′ in which each vertex has only one outgoing edge having a label of degree one. Specifically, the ABP Γ is modified to the ABP Γ′ by replacing each edge E in the ABP Γ with a pair of edges labeled 1 and φ(E), where φ is the labeling function of the ABP Γ. The size of the ABP Γ′ is also m+n+1.
<ABP∘IP Predicate>
An ABP∘IP predicate family RABP∘IP is as indicated in Formula 126.
That is, if 0 is obtained when the vector x→ and the vector z→ are input to the function f, the ABP∘IP predicate family RABP∘IP outputs 1 when the function f, the vector x→, and the vector z→ are input. If 0 is not obtained when the vector x→ and the vector z→ are input to the function f, the ABP∘IP predicate family RABP∘IP outputs 0 when the function f, the vector x→, and the vector z→ are input.
<Partial GarBlig (PGB) Algorithm>
A PGB algorithm (PGB(f; r→)) is a probabilistic polynomial-time algorithm that takes as input a function f∈F(q,n′,n)ABP∘IP and uses randomness r→∈Fqm+n−1 and outputs a set of constants ({σj}j∈[n], {αj′,γj′}j′∈[m])∈Fqn×(Fq2)m along with a function ρ: [m]→[n′]. Together with x→∈Fqn′ and z→∈Fqn, these constants specify n+m shares ({zj+σj}j∈[n], {αj′zρ(j′)+γj′}j′∈[m]).
Note that m+n+1 is the number of vertices in the ABP computing the function f and ρ is deterministically derived from the function f.
The PGB algorithm has the following properties (1) to (3):
<Bilinear Group>
Note that paramG, which is a bilinear group, indicated in Formula 127 includes a prime q, cyclic multiplicative groups G1, G2, and GT of order q, a generator g1 of the group G1, a generator g2 of the group G2, and a bilinear map e indicated in Formula 128.
params=(q,1,2,T,g1,g2,e) [Formula 127]
e:1×2→T [Formula 128]
The bilinear map e has the following two properties of bilinearity and non-degeneracy:
(Bilinearity)
Formula 129 holds.
e(g1δ,g2{circumflex over (δ)})=e(g1,g2)δ{circumflex over (δ)} for all δ,{circumflex over (δ)}∈q [Formula 129]
(Non-Degeneracy)
Formula 130 holds. Note that Formula 131 denotes an identity element of the group GT.
e(g1,g2)≠1
1
In the following description, let GBPG( ) be a bilinear group generation algorithm. That is, GBPG is an algorithm that generates paramG.
<Dual Pairing Vector Spaces (hereinafter, DPVS)>
Note that paramV, which is DPVS, indicated in Formula 132 is formed by the direct product of paramG, which is a bilinear group, and paramV includes a prime q, a d-dimensional vector space Vt=Gtd over Fq, for t∈[2], under vector addition and scalar multiplication defined for each element, a canonical basis At of the vector space Vt, for t∈[2], indicated in Formula 133, and a pairing operation e indicated in Formula 134.
params=(q,1,2,T,1,2,e)
The map e in paramV has the following two properties of bilinearity and non-degeneracy:
(Bilinearity)
Formula 135 holds.
e(δv,{circumflex over (δ)}w)=e(v,w)δ{circumflex over (δ)} for all δ,{circumflex over (δ)}∈q,v∈1,w∈2 [Formula 135]
(Non-Degeneracy)
Formula 136 holds.
If e(v,w)=1
For a basis w of the vector space Vt indicated in Formula 137 and a vector v→∈Fqd, Formula 138 denotes a vector of the vector space Vt formed by a linear combination of the elements of the basis W and the elements of the vector v→. That is, Formula 138 denotes Formula 139.
={w(1), . . . ,w(d)} of t for t∈[2] [Formula 137]
({right arrow over (v)}) [Formula 138]
For a vector v∈Vt and a matrix M=(mi,k)∈Fqd×d, vM denotes a d-dimensional vector indicated in Formula 140.
In the following description, let GDPVS(1λ, d) be a DPVS generation algorithm. That is, GDPVS is an algorithm that takes as input a unary encoded security parameter 1λ and a natural number d indicating a dimension, and generates paramV.
***Description of Configurations***
<Construction of PHPE>
In the first embodiment, a key-policy (KP)-PHPE scheme will be described. KP signifies that information for access control is set in a decryption key.
In particular, in the first embodiment, the KP-PHPE scheme in an attribute-only mode will be described. The attribute-only mode signifies that no payload is included in a ciphertext. That is, the attribute-only mode signifies that no message to be encrypted is included in a ciphertext. Note that a method for modifying the KP-PHPE scheme in the attribute-only mode to the KP-PHPE scheme of a version in which a payload is included in a ciphertext is obvious to those skilled in the art and can be easily realized.
The KP-PHPE scheme includes a PHPE.Setup algorithm, a PHPE.Encrypt algorithm, a PHPE.KeyGen algorithm, and a PHPE.Decrypt algorithm.
The PHPE.Setup algorithm takes as input a security parameter λ, a length n′ of a public attribute vector, and a length n of a secret attribute vector, and outputs a public parameter MPK and a master secret key MSK.
The PHPE.Encrypt algorithm takes as input the public parameter MPK, a public attribute vector x→∈Fqn′, and a secret attribute vector z→∈Fqn, and outputs a ciphertext CT.
The PHPE.KeyGen algorithm takes as input the public parameter MPK, the master secret key MSK, and a function f∈F(q,n′,n)ABP∘IP, and outputs a decryption key SK(f).
The PHPE.Decrypt algorithm takes as input the public parameter MPK, the decryption key SK(f) for the function f∈F(q,n′,n)ABP∘IP, and the ciphertext CT, and outputs 1 or 0.
<Configuration of Cryptographic System 1>
Referring to
The cryptographic system 1 includes a setup device 10, an encryption device 20, a key generation device 30, and a decryption device 40. The setup device 10, the encryption device 20, the key generation device 30, and the decryption device 40 are computers. The setup device 10, the encryption device 20, the key generation device 30, and the decryption device 40 are connected via a network.
Referring to
The setup device 10 is a computer to execute the PHPE.Setup algorithm.
The setup device 10 includes hardware of a processor 11, a memory 12, a storage 13, and a communication interface 14. The processor 11 is connected with the other hardware components via signal lines and controls the other hardware components.
The setup device 10 includes, as functional components, an acceptance unit 111, a master key generation unit 112, and a transmission unit 113. The functions of the functional components of the setup device 10 are realized by software.
The storage 13 stores programs for realizing the functions of the functional components of the setup device 10. These programs are loaded into the memory 12 by the processor 11 and executed by the processor 11. This realizes the functions of the functional components of the setup device 10.
Referring to
The encryption device 20 is a computer to execute the PHPE.Encrypt algorithm.
The encryption device 20 includes hardware of a processor 21, a memory 22, a storage 23, and a communication interface 24. The processor 21 is connected with the other hardware components via signal lines and controls the other hardware components.
The encryption device 20 includes, as functional components, a master key acquisition unit 211, a vector acquisition unit 212, an encryption unit 213, and a transmission unit 214. The functions of the functional components of the encryption device 20 are realized by software.
The storage 23 stores programs for realizing the functions of the functional components of the encryption device 20. These programs are loaded into the memory 22 by the processor 21 and executed by the processor 21. This realizes the functions of the functional components of the encryption device 20.
Referring to
The key generation device 30 is a computer to execute the PHPE.KeyGen algorithm.
The key generation device 30 includes hardware of a processor 31, a memory 32, a storage 33, and a communication interface 34. The processor 31 is connected with the other hardware components via signal lines and controls the other hardware components.
The key generation device 30 includes, as functional components, a master key acquisition unit 311, a function acquisition unit 312, a PGB computation unit 313, a key generation unit 314, and a transmission unit 315. The functions of the functional components of the key generation device 30 are realized by software.
The storage 33 stores programs for realizing the functions of the functional components of the key generation device 30. These programs are loaded into the memory 32 by the processor 31 and executed by the processor 31. This realizes the functions of the functional components of the key generation device 30.
Referring to
The decryption device 40 is a computer to execute the PHPE.Decrypt algorithm.
The decryption device 40 includes hardware of a processor 41, a memory 42, a storage 43, and a communication interface 44. The processor 41 is connected with the other hardware components via signal lines and controls the other hardware components.
The decryption device 40 includes, as functional components, a master key acquisition unit 411, a ciphertext acquisition unit 412, a decryption key acquisition unit 413, and a decryption unit 414. The decryption unit 414 includes a cofactor computation unit 415, a pairing operation unit 416, and an output value computation unit 417. The functions of the functional components of the decryption device 40 are realized by software.
The storage 43 stores programs for realizing the functions of the functional components of the decryption device 40. These programs are loaded into the memory 42 by the processor 41 and executed by the processor 41. This realizes the functions of the functional components of the decryption device 40.
Each of the processors 11, 21, 31, and 41 is an integrated circuit (IC) that performs processing. As a specific example, each of the processors 11, 21, 31, and 41 is a central processing unit (CPU), a digital signal processor (DSP), or a graphics processing unit (GPU).
Each of the memories 12, 22, 32, and 42 is a storage device to temporarily store data. As a specific example, each of the memories 12, 22, 32, and 42 is a static random access memory (SRAM) or a dynamic random access memory (DRAM).
Each of the storages 13, 23, 33, and 43 is a storage device to store data. As a specific example, each of the storages 13, 23, 33, and 43 is a hard disk drive (HDD). Alternatively, each of the storages 13, 23, 33, and 43 may be a portable recording medium such as a Secure Digital (SD, registered trademark) memory card, CompactFlash (CF, registered trademark), a NAND flash, a flexible disk, an optical disc, a compact disc, a Blu-ray (registered trademark) disc, or a digital versatile disc (DVD).
Each of the communication interfaces 14, 24, 34, and 44 is an interface for communicating with external devices. As a specific example, each of the communication interfaces 14, 24, 34, and 44 is an Ethernet (registered trademark) port, a Universal Serial Bus (USB) port, or a High-Definition Multimedia Interface (HDMI, registered trademark) port.
Referring to
The operation of the cryptographic system 1 according to the first embodiment corresponds to a cryptographic method according to the first embodiment. The operation of the cryptographic system 1 according to the first embodiment also corresponds to processes of a cryptographic program according to the first embodiment.
Referring to
The operation of the setup device 10 according to the first embodiment corresponds to a setup method according to the first embodiment. The operation of the setup device 10 according to the first embodiment also corresponds to processes of a setup program according to the first embodiment.
(Step S11: Acceptance Process)
The acceptance unit 111 accepts input of a security parameter λ, a length n′ of a public attribute vector, and a length n of a secret attribute vector. Both the length n′ of the public attribute vector and the length n of the secret attribute vector are integers of 1 or more.
Specifically, the acceptance unit 111 accepts, via the communication interface 14, the security parameter 1λ input by a user of the setup device 10. The acceptance unit 111 writes the security parameter 1λ in the memory 12.
(Step S12: Basis Generation Process)
The master key generation unit 112 generates params and orthonormal dual bases {Bι, B*ι}ι∈[n′+n], using as input the security parameter λ, the length n′ of the public attribute vector, and the length n of the secret attribute vector accepted in step S11.
Specifically, the master key generation unit 112 retrieves the security parameter λ, the length n′ of the public attribute vector, and the length n of the secret attribute vector from the memory 12. The master key generation unit 112 generates params and the dual bases {Bι, B*ι}ι∈[n′+n] by executing an algorithm GOB indicated in Formula 141, where N=n′+n, d0=0, and d1, . . . , dN=9. The master key generation unit 112 writes params and the dual bases {Bι, B*ι}ι∈[n′+n] in the memory 12.
(Step S13: Master Key Generation Process)
The master key generation unit 112 generates a public parameter MPK and a master secret key MSK, using params and the dual bases {Bι, B*ι}ι∈[n′+n] generated in step S12.
Specifically, the master key generation unit 112 retrieves params and the dual bases {Bι, B*ι}ι∈[n′+n] from the memory 12. The master key generation unit 112 generates a partial basis B{circumflex over ( )}ι and a partial basis B{circumflex over ( )}*ι, for each integer ι of ι∈[n′+n], as indicated in Formula 142.
for ι∈[n′+n]
ι={b(ι,1),b(ι,2),b(ι,9)},*ι={b*(ι,1),b*(ι,2),b*(ι,7),b*(ι,8)} [Formula 142]
The master key generation unit 112 sets params and the partial basis B{circumflex over ( )}ι for each integer ι of ι∈[n′+n] as the public parameter MPK. The master key generation unit 112 sets the partial basis B{circumflex over ( )}*ι for each integer ι of ι∈[n′+n] as the master secret key MSK. The master key generation unit 112 writes the public parameter MPK and the master secret key MSK in the memory 12.
(Step S14: Transmission Process)
The transmission unit 113 publishes the public parameter MPK generated in step S13. Specifically, the transmission unit 113 retrieves the public parameter MPK from the memory 12. The transmission unit 113 publishes the public parameter MPK by a method such as transmitting it to a server for publication. This allows the encryption device 20, the key generation device 30, and the decryption device 40 to acquire the public parameter MPK.
The transmission unit 113 transmits the master secret key MSK generated in step S13 to the key generation device 30 in secrecy. Specifically, the transmission unit 113 retrieves the master secret key MSK from the memory 12. The transmission unit 113 encrypts the master secret key MSK with an existing encryption scheme and then transmits the master secret key MSK to the key generation device 30.
That is, the setup device 10 executes the PHPE.Setup algorithm indicated in Formula 143.
Referring to
The operation of the encryption device 20 according to the first embodiment corresponds to an encryption method according to the first embodiment. The operation of the encryption device 20 according to the first embodiment also corresponds to processes of an encryption program according to the first embodiment.
(Step S21: Master Key Acquisition Process)
The master key acquisition unit 211 acquires the public parameter MPK generated by the setup device 10.
Specifically, the master key acquisition unit 211 acquires, via the communication interface 24, the public parameter MPK that is published. The master key acquisition unit 211 writes the public parameter MPK in the memory 22.
(Step S22: Vector Acquisition Process)
The vector acquisition unit 212 acquires a public attribute vector x→∈Fqn′ and a secret attribute vector z→∈Fqn.
Specifically, the vector acquisition unit 212 acquires, via the communication interface 24, the public attribute vector x→ and the secret attribute vector z→ that are input by a user of the encryption device 20. The vector acquisition unit 212 writes the public attribute vector x→ and the secret attribute vector z→ in the memory 22.
(Step S23: Encryption Process)
The encryption unit 213 generates a ciphertext CT, using the public parameter MPK acquired in step S21 and the public attribute vector x→ and the secret attribute vector z→ acquired in step S22.
Specifically, the encryption unit 213 generates the ciphertext CT as described below.
First, the encryption unit 213 samples a value ω, as indicated in Formula 144.
Next, the encryption unit 213 samples a value φ′ι′ and generates an element c′(ι′), for each integer ι′ of ι′∈[n′], as indicated in Formula 145.
The encryption unit 213 samples a value φι and generates an element c(ι), for each integer ι of ι∈[n], as indicated in Formula 146.
Then, the encryption unit 213 sets the public attribute vector x→, the element c′(ι′) for each integer ι′ of ι′∈[n′], and the element c(ι) for each integer ι of ι∈[n] as the ciphertext CT. The encryption unit 213 writes the ciphertext CT in the memory 22.
In the first embodiment, the ciphertext CT includes the element c′(ι′) in which the public attribute vector x→ is set and the element c(ι) in which the secret attribute vector z→ is set, over a basis B of the basis B and a basis B*, which are dual bases in dual vector spaces.
(Step S24: Transmission Process)
The transmission unit 214 transmits the ciphertext CT generated in step S23 to the decryption device 40.
Specifically, the transmission unit 214 retrieves the ciphertext CT from the memory 22. The transmission unit 214 transmits the ciphertext CT to the decryption device 40 via the communication interface 24.
That is, the encryption device 20 executes the PHPE.Encrypt algorithm indicated in Formula 147.
Referring to
The operation of the key generation device 30 according to the first embodiment corresponds to a key generation method according to the first embodiment. The operation of the key generation device 30 according to the first embodiment also corresponds to processes of a key generation program according to the first embodiment.
(Step S31: Master Key Acquisition Process)
The master key acquisition unit 311 acquires the public parameter MPK and the master secret key MSK that are generated by the setup device 10.
Specifically, the master key acquisition unit 311 acquires, via the communication interface 34, the public parameter MPK that is published, and acquires the master secret key MSK transmitted by the setup device 10. The master key acquisition unit 311 writes the public parameter MPK and the master secret key MSK in the memory 32.
(Step S32: Function Acquisition Process)
The function acquisition unit 312 acquires a function f∈F(q,n′,n)ABP∘IP.
Specifically, the function acquisition unit 312 acquires, via the communication interface 34, the function f input by a user of the key generation device 30. The function acquisition unit 312 writes the function fin the memory 32.
(Step S33: PGB Computation Process)
The PGB computation unit 313 computes a set of constants ({σj}j∈[n], {αj′, γj′}j′∈[m])∈Fqn×(Fq2)m for specifying shares and a function ρ: [m]→[n′] by executing the PGB algorithm, using as input the function f acquired in step S32, as indicated in Formula 148.
Referring to
(Step S331: Matrix Representation L Generation Process)
Let Γ′ denote an ABP computing the function f. The ABP Γ′ has m+n+1 vertices, and a variable zj is set only in edges leading into the sink vertex. Every vertex has only one outgoing edge.
The PGB computation unit 313 computes a matrix representation L∈Fq(m+n)×(m+n) representing the ABP Γ′. As described above, the matrix L is obtained by removing the column corresponding to V0 and the row corresponding to V1 from the matrix AΓ′−I, where the matrix AΓ is the adjacency matrix for Γ and I is the identity matrix.
Then, the following (1) to (4) hold.
(Step S332: Function ρ Generation Process)
The PGB computation unit 313 generates the function ρ: [m]→[n′] by setting ρ(j′)=ι′ if the variable xι′ is included in the j′th row of the matrix representation L, for each integer j′ of j′∈[m]. The PGB computation unit 313 writes the function ρ in the memory 32.
(Step S333: Constant Computation Process)
The PGB computation unit 313 chooses a vector r→, as indicated in Formula 149.
The PGB computation unit 313 computes a set of constants ({σj}j∈[n], {αj′,γj′}j′∈[m])∈Fqn×(Fq2)m, using the matrix representation L generated in step S331 and the vector r→, as indicated in Formula 150.
By this, the set of constants ({σj}j∈[n], {αj′,γj′}j′∈[m]) is generated. The PGB computation unit 313 writes the set of constants ({σj}j∈[n], {αj′,γj′}j′∈[m]) in the memory 32. The set of constants ({σj}j∈[n], {αj′,γj′}j′∈[m]) is referred to as a predicate vector of the ABP.
(Step S34: Key Generation Process)
The key generation unit 314 generates a decryption key SK(f), using the public parameter MPK and the master secret key MSK acquired in step S31, the function f acquired in step S32, and the set of constants ({σj}j∈[n], {αj′,γj′}j′∈[m]) generated in step S33.
Specifically, the key generation unit 314 generates the decryption key SK(f) as described below.
First, the key generation unit 314 samples a value ζ, as indicated in Formula 151.
Next, the key generation unit 314 samples κ→′(j′) and generates an element k′(j′), for each integer j′ of j′∈[m], as indicated in Formula 152.
The key generation unit 314 samples κ→(j) and generates an element k(j), for each integer j of j∈[n], as indicated in Formula 153.
Then, the key generation unit 314 sets the function f, the element k′(j′) for each integer j′ of j′∈[m], and the element k(j) for each integer j of j∈[n] as the decryption key SK(f). The key generation unit 314 writes the decryption key SK(f) in the memory 32.
In the first embodiment, the decryption key SK(f) includes the element k′(j′) and the element k(j) in which the predicate vector of ABP is set, over the basis B* of the basis B and the basis B*, which are dual bases in dual vector spaces.
(Step S35: Transmission Process)
The transmission unit 315 transmits the decryption key SK(f) generated in step S34 to the decryption device 40 in secrecy.
Specifically, the transmission unit 315 retrieves the decryption key SK(f) from the memory 32. The transmission unit 315 encrypts the decryption key SK(f) with an existing encryption scheme and then transmits the decryption key SK(f) to the decryption device 40 via the communication interface 34.
That is, the key generation device 30 executes the PHPE.KeyGen algorithm indicated in Formula 154.
Referring to
The operation of the decryption device 40 according to the first embodiment corresponds to a decryption method according to the first embodiment. The operation of the decryption device 40 according to the first embodiment also corresponds to processes of a decryption program according to the first embodiment.
(Step S41: Public Key Acquisition Process)
The master key acquisition unit 411 acquires the public parameter MPK generated by the setup device 10.
Specifically, the master key acquisition unit 411 acquires, via the communication interface 44, the public parameter MPK that is published. The master key acquisition unit 411 writes the public parameter MPK in the memory 42.
(Step S42: Ciphertext Acquisition Process)
The ciphertext acquisition unit 412 acquires the ciphertext CT generated by the encryption device 20.
Specifically, the ciphertext acquisition unit 412 acquires, via the communication interface 44, the ciphertext CT transmitted by the encryption device 20. The ciphertext acquisition unit 412 writes the ciphertext CT in the memory 42.
(Step S43: Decryption key acquisition process)
The decryption key acquisition unit 413 acquires the decryption key SK(f) generated by the key generation device 30.
Specifically, the decryption key acquisition unit 413 acquires, via the communication interface 44, the decryption key SK(f) transmitted by the key generation device 30. The decryption key acquisition unit 413 writes the decryption key SK(f) in the memory 42.
(Step S44: Decryption Process)
The decryption unit 414 decrypts the ciphertext CT by performing a pairing operation on the ciphertext CT acquired in step S42 and the decryption key SK(f) acquired in step S43.
Referring to
(Step S441: Cofactor Computation Process)
The cofactor computation unit 415 computes a set of coefficients (({Ωj}j∈[n], {Ω′j′}j′∈[m])∈Fqn×Fqn′ by executing the REC algorithm, using as input the function f included in the decryption key SK(f) and the public attribute vector x→ included in the ciphertext CT, as indicated in Formula 155.
({Ωj}j∈[n],{Ω′j′}j′∈[m])=REC(f,
Specifically, the cofactor computation unit 415 generates a matrix representation L of the function f and a function ρ, as in the processes of steps S331 to S332 of
The cofactor computation unit 415 writes the set of coefficients (({Ωj}j∈[n], {Ω′j′}j′∈[m]) in the memory 42.
(Step S442: Pairing Operation Process)
The pairing operation unit 416 performs a pairing operation on an element c′(ρ(j′)) and an element k′(j′) to compute an operation value Λ′j′, for each integer j′ of j′∈[m], as indicated in Formula 156. Note that the function ρ is the function generated in step S441.
Λ′j′=e(c′(ρ(j′)),k′(j′)) for j′∈[m] [Formula 156]
The pairing operation unit 416 performs a pairing operation on an element c(j) and an element k(j) to compute an operation value Λj, for each integer j of j∈[n], as indicated in Formula 157.
Λj=e(c(j),k(j)) for j∈[n] [Formula 157]
The pairing operation unit 416 writes the operation value Λ′j′ and the operation value Λj in the memory 42.
(Step S443: Output Value Computation Process)
The output value computation unit 417 retrieves the set of coefficients (({Ωj}j∈[n], {Ω′j}j′∈[m]) computed in step S441 and the operation value Λ′j′ and the operation value Λj computed in step S442 from the memory 42. The output value computation unit 417 computes an operation value Λ, as indicated in Formula 158.
The output value computation unit 417 outputs 1 as an output value if Λ is the identity element of the group GT, and outputs 0 as an output value otherwise.
That is, the decryption device 40 executes the PHPE.Decrypt algorithm indicated in Formula 159.
The operation value Λ′j′ and the operation value Λj are as indicated in Formula 160.
Λ′j′=gTω(α
Λj=gTω(ζz
The operation value Λ is as indicated in Formula 161.
Λ=gTωζf({right arrow over (x)},{right arrow over (z)}) [Formula 161]
Therefore, except when ω=0 or ζ=0, Formula 162 holds if RABP∘IP(f,(x→, z→))=1, that is, f(x→,z→)=0, and Formula 163 holds if RABP∘IP(f,(x→,z→))≠1, that is, f(x→,z→)≠0.
Λ=1
Λ≠1
The reason why Formula 161 holds will be described.
As indicated in Formula 164, for any z→,f(x→,z→) can be computed by concatenating the sets of coefficients (({Ωj}j∈[n], {Ω′j′}j′∈[m]) and ({zj+σj}j∈[n], {αj′zρ(j′)+γj′}j′∈[m]).
Note that Formula 164 corresponds to computing det(L′(x→,z→)). A matrix representation L′ is a matrix representation obtained by replacing the last column in the matrix representation L with Formula 165.
(α1xρ(1)+γ1, . . . ,αmxρ(m)+γm,z1+σ1, . . . ,zn+σn)T [Formula 165]
Therefore, Formula 166 holds and it can be known that Formula 164 holds.
Note that r→=(r1, . . . , rm+n−1)∈Fqm+n−1 is the randomness used by the PBG when generating the set of constants ({σj}j∈[n], {αj′,γj′}j′∈[m]).
Then, Formula 167 holds.
This is because the first m entries of the last column are 0's so that Formula 168 holds.
Therefore, Formula 169 holds.
***Effects of First Embodiment***
As described above, in the cryptographic system 1 according to the first embodiment, a ciphertext is decrypted by performing a pairing operation on the ciphertext in which an attribute vector is set over a basis B and a decryption key in which a predicate vector of ABP is set over a basis B*, the basis B and the basis B* being dual bases in dual vector spaces. This makes it possible to realize a predicate encryption scheme that allows a wide range of predicates and also allows security to be enhanced.
***Other Configurations***
<First Variation>
In the first embodiment, the KP-PHPE scheme has been described. The KP-PHPE scheme described in the first embodiment can be converted into a Cipher-Policy (CP)-PHPE scheme. CP signifies that information for access control is set in a ciphertext. The information for access control in the first embodiment is the function f and the set of constants ({σj}j∈[n], {αj′, γj′}j′∈[m]).
Accordingly, in the case of the CP-PHPE scheme, in the PHPE.Encrypt algorithm, a set of constants ({σj}j∈[n], {αj′,γj′}j′∈[m]) is generated by executing the PGB algorithm, using as input a function f. In the PHPE.Encrypt algorithm, an element c′(j′) and an element c(j) in which a set of constants ({σj}j∈[n], {αj′,γj′}j′∈[m]) is set, which correspond to the element k′(j′) and the element k(j) in the first embodiment, are generated. Then, the function f, the element c′(j′), and the element c(j) are set as a ciphertext CT.
In the case of the CP-PHPE scheme, in the PHPE.KeyGen algorithm, an element k′(ι′) in which a public attribute vector x→ is set, which corresponds to the element c′(ι′) in the first embodiment, is generated, and an element k(ι) in which a secret attribute vector z→ is set, which corresponds to the element c(ι) in the first embodiment, is generated. Then, the public attribute vector x→, the element k′(ι′), and the element k(ι) are set as a decryption key SK(f).
<Second Variation>
In the first embodiment, the basis Bι and the basis B*ι are generated for each integer ι of ι∈[n′+n]. Then, a different basis is used for each element of the public attribute vector x→ and the secret attribute vector z→. However, by using an indexing technique, the PHPE scheme can be realized using only one pair of dual bases, the basis B and the basis B*. This can make the scheme unbounded.
Specifically, for example, two dimensions are added to the dimensions of the basis B and the basis B*. Then, using the added two dimensions, indices according to the elements of the public attribute vector x→ and the secret attribute vector z→ are set in the element c′(ι′) and the element c(ι) of the ciphertext CT and the element k′(j′) and the element k(j) of the decryption key SK(f). At this time, the indices are set in the element c′(ι′) and the element c(ι) of the ciphertext CT and the element k′(j′) and the element k(j) of the decryption key SK(f) such that performing a pairing operation results in a value of 0 between the added two dimensions.
<Third Variation>
In the first embodiment, the functional components are realized by software. However, as a third variation, the functional components may be realized by hardware. With regard to this third variation, differences from the first embodiment will be described.
Referring to
When the functional components are realized by hardware, the setup device 10 includes an electronic circuit 15 in place of the processor 11, the memory 12, and the storage 13. The electronic circuit 15 is a dedicated circuit that realizes the functions of the functional components, the memory 12, and the storage 13.
Referring to
When the functional components are realized by hardware, the encryption device 20 includes an electronic circuit 25 in place of the processor 21, the memory 22, and the storage 23. The electronic circuit 25 is a dedicated circuit that realizes the functions of the functional components, the memory 22, and the storage 23.
Referring to
When the functional components are realized by hardware, the key generation device 30 includes an electronic circuit 35 in place of the processor 31, the memory 32, and the storage 33. The electronic circuit 35 is a dedicated circuit that realizes the functions of the functional components, the memory 32, and the storage 33.
Referring to
When the functional components are realized by hardware, the decryption device 40 includes an electronic circuit 45 in place of the processor 41, the memory 42, and the storage 43. The electronic circuit 45 is a dedicated circuit that realizes the functions of the functional components, the memory 42, and the storage 43.
Each of the electronic circuits 15, 25, 35, and 45 is assumed to be 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).
The respective functional components may be realized by one electronic circuit 15, one electronic circuit 25, one electronic circuit 35, and one electronic circuit 45, or the respective functional components may be distributed among and realized by a plurality of electronic circuits 15, a plurality of electronic circuits 25, a plurality of electronic circuits 35, and a plurality of electronic circuits 45.
<Fourth Variation>
As a fourth variation, some of the functional components may be realized by hardware, and the rest of the functional components may be realized by software.
Each of the processors 11, 21, 31, 41, the memories 12, 22, 32, 42, the storages 13, 23, 33, 43, and the electronic circuits 15, 25, 35, 45 is referred to as processing circuitry. That is, the functions of the functional components are realized by the processing circuitry.
In a second embodiment, a Key-Encapsulation Mechanism (KEM) scheme converted from the PHPE scheme described in the first embodiment will be described. In the second embodiment, differences from the first embodiment will be described, and description of the same portions will be omitted.
***Description of Configurations***
<Construction of KEM Version PHPE>
In the second embodiment, a KEM version KP-PHPE scheme will be described.
The KEM version KP-PHPE scheme includes a PHPE.Setup algorithm, a PHPE.Encrypt algorithm, a PHPE.KeyGen algorithm, and a PHPE.Decrypt algorithm.
The PHPE.Setup algorithm takes as input a security parameter λ, a length n′ of a public attribute vector, and a length n of a secret attribute vector, and outputs a public parameter MPK and a master secret key MSK.
The PHPE.Encrypt algorithm takes as input the public parameter MPK, a public attribute vector x→∈Fqn′, and a secret attribute vector z→∈Fqn, and outputs a ciphertext CT and a session key KEM.
The PHPE.KeyGen algorithm takes as input the public parameter MPK, the master secret key MSK, and a function f∈F(q,n′,n)ABP∘IP, and outputs a decryption key SK(f).
The PHPE.Decrypt algorithm takes as input the public parameter MPK, a pair of the function f∈F(q,n′,n)ABP∘IP and the decryption key SK(f) for the function f, and a pair of the public attribute vector x→ and the ciphertext CT concerning the public attribute vector x→, and outputs a session key˜.
***Description of Operation***
Referring to
The operation of the cryptographic system 1 according to the second embodiment corresponds to a cryptographic method according to the second embodiment. The operation of the cryptographic system 1 according to the second embodiment also corresponds to processes of a cryptographic program according to the second embodiment.
Referring to
The operation of the setup device 10 according to the second embodiment corresponds to a setup method according to the second embodiment. The operation of the setup device 10 according to the second embodiment also corresponds to processes of a setup program according to the second embodiment.
The processes of steps S11 and S14 are the same as those in the first embodiment.
(Step S12: Basis Generation Process)
The master key generation unit 112 generates params and orthonormal dual bases {Bι, B*ι}ι∈[0,n′+n], using as input the security parameter λ, the length n′ of the public attribute vector, and the length n of the secret attribute vector accepted in step S11.
Specifically, the master key generation unit 112 generates params and the dual bases {Bι, B*ι}ι∈[n′+n] by executing the same algorithm GOB as that in the first embodiment, where N=n′+n+1, d0=6, and d1, . . . , dN=9. Differences from the first embodiment are N=n′+n+1 and d0=6.
(Step S13: Master Key Generation Process)
The master key generation unit 112 generates a public parameter MPK and a master secret key MSK, using params and the dual bases {Bι, B*ι}ι∈[0,n′+n] generated in step S12.
Specifically, the master key generation unit 112 generates a partial basis B{circumflex over ( )}0 and a partial basis B{circumflex over ( )}*0, as indicated in Formula 170, and generates a partial basis B{circumflex over ( )}ι and a partial basis B{circumflex over ( )}*ι, for each integer ι of ι∈[n′+n], as indicated in Formula 171.
0={b(0,1),b(0,4),b(0,6)},*0={b*(0,1),b*(0,4),b*(0,5)} [Formula 170]
for ι∈[n′+n]
ι={b(ι,1),b(ι,2),b(ι,9)},*ι={b*(ι,1),b*(ι,2),b*(ι,7),b*(ι,8)} [Formula 171]
The master key generation unit 112 sets params and the partial basis B{circumflex over ( )}ι for each integer ι of ι∈[0, n′+n] as the public parameter MPK. The master key generation unit 112 sets the partial basis B{circumflex over ( )}*ι for each integer ι of ι∈[0, n′+n] as the master secret key MSK.
That is, the setup device 10 execute the PHPE.Setup algorithm indicated in Formula 172.
Referring to
The operation of the encryption device 20 according to the second embodiment corresponds to an encryption method according to the second embodiment. The operation of the encryption device 20 according to the second embodiment also corresponds to processes of an encryption program according to the second embodiment.
The processes other than step S23 are the same as those in the first embodiment.
(Step S23: Encryption Process)
The encryption unit 213 generates a ciphertext CT, using the public parameter MPK acquired in step S21 as well as the public attribute vector x→ and the secret attribute vector z→ acquired in step S22.
Specifically, the encryption unit 213 generates the ciphertext CT as described below.
First, the encryption unit 213 samples values ω, ξ, and φ′0, as indicated in Formula 173.
Next, the encryption unit 213 generates an element c′(0), as indicated in Formula 174.
c′(0)=(ω,
The encryption unit 213 sets gTξ as a session key KEM. Furthermore, the encryption unit 213 generates an element c′(ι′) for each integer ι′ of ι′∈[n′] and generates an element c(ι) for each integer ι of ι∈[n], as in the first embodiment.
Then, the encryption unit 213 sets the public attribute vector x→, the element c′(0), the element c′(ι′) for each integer ι′ of ι′[n′], and the element c(ι) for each integer ι of ι∈[n] as the ciphertext CT.
That is, the encryption device 20 executes the PHPE.Encrypt algorithm indicated in Formula 175.
Referring to
The operation of the key generation device 30 according to the second embodiment corresponds to a key generation method according to the second embodiment. The operation of the key generation device 30 according to the second embodiment also corresponds to processes of a key generation program according to the second embodiment.
The processes other than step S34 are the same as those in the first embodiment.
(Step S34: Key Generation Process)
The key generation unit 314 generates a decryption key SK(f), using the public parameter MPK and the master secret key MSK acquired in step S31, the function f acquired in step S32, and the set of constants ({σj}j∈[n], {αj′,γj′}j′∈[m]) generated in step S33.
Specifically, the key generation unit 314 generates the decryption key SK(f) as described below.
First, the key generation unit 314 samples values r0, κ′0, and ζ, as indicated in Formula 176.
Next, the key generation unit 314 generates an element k′(0), as indicated in Formula 177.
k′(0)=(−r0,{right arrow over (0)}2,1,κ′0,0)*
The key generation unit 314 generates an element k′(j′) for each integer j′ of j′∈[m], as indicated in Formula 178, and generates an element k(j) for each integer j of j∈[n], as indicated in Formula 179.
Then, the key generation unit 314 sets the function f, the element β′j′ for each integer j′ of j′∈[m], the element βj for each integer j of j∈[n], the element k′(0), the element k′(j′) for each integer j′ of j′∈[m], and the element k(j) for each integer j of j∈[n] as the decryption key SK(f).
That is, the key generation device 30 executes the PHPE.KeyGen algorithm indicated in Formula 180.
Referring to
The operation of the decryption device 40 according to the second embodiment corresponds to a decryption method according to the second embodiment. The operation of the decryption device 40 according to the second embodiment also corresponds to processes of a decryption program according to the second embodiment.
The processes other than step S44 are the same as those in the first embodiment.
(Step S44: Decryption Process)
The decryption unit 414 decrypts the ciphertext CT by performing a pairing operation on the ciphertext CT acquired in step S42 and the decryption key SK(f) acquired in step S43.
Referring to
The process of step S441 is the same as that in the first embodiment.
(Step S442: Pairing Operation Process)
The pairing operation unit 416 performs a pairing operation on the element c′(0) and the element k′(0) to compute an operation value Λ′0, as indicated in Formula 181.
Λ′0=e(c′(0),k′(0)) [Formula 181]
The pairing operation unit 416 computes an operation value Λ′j′ for each integer j′ of j′∈[m] and computes an operation value Λj for each integer j of j∈[n], as in the first embodiment.
The pairing operation unit 416 writes the operation value Λ′0, the operation value Λ′j′, and the operation value Λj in the memory 42.
(Step S443: Output Value Computation Process)
The output value computation unit 417 retrieves the set of coefficients (({Ωj}j∈[n], {Ω′j′}j′∈[m]) computed in step S441 as well as the operation value Λ′0, the operation value Λ′j, and the operation value Λj computed in step S442 from the memory 42. The output value computation unit 417 computes an operation value Λ, as indicated in Formula 182.
The output value computation unit 417 computes a session key KEM˜, as indicated in Formula 183.
KEM˜=ΛΛ′0 [Formula 183]
That is, the decryption device 40 executes the PHPE.Decrypt algorithm indicated in Formula 184.
The operation value Λ′0, the operation value Λ′j, and the operation value Λj are as indicated in Formula 185.
Λ′0=gT−ωr
Λ′j′=gTω(α
Λj=gTω(ζz
The operation value Λ is as indicated in Formula 186.
Λ=gT[ωζf({right arrow over (x)},{right arrow over (z)})+ωr
Therefore, if RABP∘IP(f,(x→,z→))=1, that is, f(x→,z→)=0, then Formula 187 holds.
Λ=gTωr
Therefore, KEM˜=gTξ=KEM. Note that if RABP∘IP(f,(x→,z→))≠1, that is, f(x→,z→)≠0, then Formula 187 does not hold and thus KEM˜≠gTξ=KEM.
***Effects of Second Embodiment***
As described above, the cryptographic system 1 according to the second embodiment realizes a KEM scheme by converting the PHPE scheme described in the first embodiment. This makes it possible to realize a KEM scheme that allows a wide range of predicates and also allows security to be enhanced.
***Other Configurations***
<Fifth Variation>
In the second embodiment, the KEM scheme is constructed by converting the KP-PHPE method. By applying similar modifications, a KEM scheme can also be constructed by converting the CP-PHPE scheme described in the first variation.
<Sixth Variation>
By using the indexing technique as described in the second variation, the KEM scheme described in the second embodiment can also be realized using only one pair of dual bases, the basis B and the basis B*.
1: cryptographic system, 10: setup device, 11: processor, 12: memory, 13: storage, 14: communication interface, 15: electronic circuit, 111: acceptance unit, 112: master key generation unit, 113: transmission unit, 20: encryption device, 21: processor, 22: memory, 23: storage, 24: communication interface, 25: electronic circuit, 211: master key acquisition unit, 212: vector acquisition unit, 213: encryption unit, 214: transmission unit, 30: key generation device, 31: processor, 32: memory, 33: storage, 34: communication interface, 35: electronic circuit, 311: master key acquisition unit, 312: function acquisition unit, 313: PGB computation unit, 314: key generation unit, 315: transmission unit, 40: decryption device, 41: processor, 42: memory, 43: storage, 44: communication interface, 45: electronic circuit, 411: master key acquisition unit, 412: ciphertext acquisition unit, 413: decryption key acquisition unit, 414: decryption unit, 415: cofactor computation unit, 416: pairing operation unit, 417: output value computation unit
Number | Date | Country | Kind |
---|---|---|---|
2018-188781 | Oct 2018 | JP | national |
This application is a Continuation of PCT International Application No. PCT/JP2019/031129, filed on Aug. 7, 2019, which claims priority under 35 U.S.C. 119(a) to Patent Application No. 2018-188781, filed in Japan on Oct. 4, 2018, all of which are hereby expressly incorporated by reference into the present application.
Number | Date | Country |
---|---|---|
WO-2016132547 | Aug 2016 | WO |
Entry |
---|
Kawai, “Master Key Updatable Attribute-Based Encryption on the Dual Pairing Vector Space”, Mitsubishi Electric, 2016, pp. 1-5. (Year: 2016). |
Okamoto, “Fully Secure Unbounded Inner-Product and Attribute-Based Encryption”, Proceedings of the 18th 1-90international conference on The Theory and Application of Cryptology and Information Security, 2012, pp. 1-90. (Year: 2012). |
Datta et al., “Adaptively Simulation-Secure Attribute-Hiding Predicate Encryption”, Cryptology ePrint Archive, Report 2018/1093, [online], Nov. 12, 2018, pp. 1-63, total 65 pages. |
International Search Report for PCT/JP2019/031129 dated Oct. 21, 2019. |
Ishai et al., “Partial Garbling Schemes and Their Applications”, In: J. Esparza et al., (Eds.): ICALP 2014, Part I, Lncs 8572, total 23 pages. |
Ishai et al., “Perfect Constant-Round Secure Computation via Perfect Randomizing Polynomials”, In: International Colloquium on Automata, Languages and Programming, ICALP 2002, Springer (2002), pp. 244-256, total 17 pages. |
Okamoto et al., “Adaptively Attribute-Hiding (Hierarchical) Inner Product Encryption”, Cryptology ePrint Archive: Report 2011/543, http://eprint.iacr.org/2011/543, 2011, total 40 pages. |
Wee, “Attribute-Hiding Predicate Encryption in Bilinear Groups, Revisited”, In: Y. Kalai and L. Reyzin (Eds.): TCC 2017, Part I, LNCS, vol. 10677, Springer, Heidelberg, 2017, pp. 206-233, total 30 pages. |
Number | Date | Country | |
---|---|---|---|
20210234676 A1 | Jul 2021 | US |
Number | Date | Country | |
---|---|---|---|
Parent | PCT/JP2019/031129 | Aug 2019 | US |
Child | 17207087 | US |