Cryptographic system, cryptographic method, and cryptographic program

Information

  • Patent Grant
  • 9407438
  • Patent Number
    9,407,438
  • Date Filed
    Friday, March 1, 2013
    11 years ago
  • Date Issued
    Tuesday, August 2, 2016
    8 years ago
Abstract
The present invention aims to allow for addition of an attribute category without reissuing a public parameter. A cryptographic system 10 uses an indexing technique in dual system encryption in dual pairing vector spaces. Specifically, for a transmission-side vector tj for index j, the cryptographic system 10 sets information J assigned to the index j in advance as a coefficient of a predetermined basis vector. For a reception-side vector for index j′ corresponding to the index j, the cryptographic system 10 sets information J′ having an inner-product of 0 with the information J as a coefficient of a basis vector corresponding to the predetermined basis vector.
Description
TECHNICAL FIELD

The present invention relates to a cryptographic system that allows for addition of an attribute category without reissuing a public parameter.


BACKGROUND ART

Non-Patent Literature 29 describes a functional encryption scheme.


CITATION LIST
Non-Patent Literature



  • Non-Patent Literature 1: Beimel, A., Secure schemes for secret sharing and key distribution. PhD Thesis, Israel Institute of Technology, Technion, Haifa, Israel, 1996.

  • Non-Patent Literature 2: Bethencourt, J., Sahai, A., Waters, B.: Ciphertext-policy attribute-based encryption. In: 2007 IEEE Symposium on Security and Privacy, pp. 321-334. IEEE Press (2007)

  • Non-Patent Literature 3: Boneh, D., Boyen, X.: Efficient selective-ID secure identity based encryption without random oracles. In: Cachin, C., Camenisch, J. (eds.) EUROCRYPT 2004. LNCS, vol. 3027, pp. 223-238. Springer Heidelberg (2004)

  • Non-Patent Literature 4: Boneh, D., Boyen, X.: Secure identity based encryption without random oracles. In: Franklin, M. K. (ed.) CRYPTO 2004. LNCS, vol. 3152, pp. 443-459. Springer Heidelberg (2004)

  • Non-Patent Literature 5: Boneh, D., Boyen, X., Goh, E.: Hierarchical identity based encryption with constant size ciphertext. In: Cramer, R. (ed.) EUROCRYPT 2005. LNCS, vol. 3494, pp. 440-456. Springer Heidelberg (2005)

  • Non-Patent Literature 6: Boneh, D., Boyen, X., Shacham, H.: Short group signatures. In: Franklin, M. (ed.) CRYPTO 2004. LNCS, vol. 3152, pp. 41-55. Springer, Heidelberg (2004)

  • Non-Patent Literature 7: Boneh, D., Franklin, M.: Identity-based encryption from the Weil pairing. In: Kilian, J. (ed.) CRYPTO 2001. LNCS, vol. 2139, pp. 213-229. Springer Heidelberg (2001)

  • Non-Patent Literature 8: Boneh, D., Hamburg, M.: Generalized identity based and broadcast encryption scheme. In: Pieprzyk, J. (ed.) ASIACRYPT 2008. LNCS, vol. 5350, pp. 455-470. Springer Heidelberg (2008)

  • Non-Patent Literature 9: Boneh, D., Katz, J., Improved efficiency for CCA-secure cryptosystems built using identity based encryption. RSA-CT 2005, LNCS, Springer Verlag (2005)

  • Non-Patent Literature 10: Boneh, D., Waters, B.: Conjunctive, subset, and range queries on encrypted data. In: Vadhan, S. P. (ed.) TCC 2007. LNCS, vol. 4392, pp. 535-554. Springer Heidelberg (2007)

  • Non-Patent Literature 11: Boyen, X., Waters, B.: Anonymous hierarchical identity-based encryption (without random oracles). In: Dwork, C. (ed.) CRYPTO 2006. LNCS, vol. 4117, pp. 290-307. Springer Heidelberg (2006)

  • Non-Patent Literature 12: Canetti, R., Halevi S., Katz J.: Chosen-ciphertext security from identity-based encryption. EUROCRYPT 2004, LNCS, Springer Heidelberg (2004)

  • Non-Patent Literature 13: Chase, M.: Multi-authority attribute based encryption. TCC, LNCS, pp. 515-534, Springer Heidelberg (2007).

  • Non-Patent Literature 14: Chase, M. and Chow, S.: Improving privacy and security in multi-authority attribute-based encryption, ACM Conference on Computer and Communications Security, pp. 121-130, ACM (2009).

  • Non-Patent Literature 15: Cocks, C.: An identity based encryption scheme based on quadratic residues. In: Honary, B. (ed.) IMA Int. Conf LNCS, vol. 2260, pp. 360-363. Springer Heidelberg (2001)

  • Non-Patent Literature 16: Gentry, C.: Practical identity-based encryption without random oracles. In: Vaudenay, S. (ed.) EUROCRYPT 2006. LNCS, vol. 4004, pp. 445-464. Springer Heidelberg (2006)

  • Non-Patent Literature 17: Gentry, C., Halevi, S.: Hierarchical identity-based encryption with polynomially many levels. In: Reingold, O. (ed.) TCC 2009. LNCS, vol. 5444, pp. 437-456. Springer Heidelberg (2009)

  • Non-Patent Literature 18: Gentry, C., Silverberg, A.: Hierarchical ID-based cryptography. In: Zheng, Y. (ed.) ASIACRYPT 2002. LNCS, vol. 2501, pp. 548-566. Springer Heidelberg (2002)

  • Non-Patent Literature 19: Goyal, V., Pandey, O., Sahai, A., Waters, B.: Attribute-based encryption for fine-grained access control of encrypted data. In: ACM Conference on Computer and Communication Security 2006, pp. 89-98, ACM (2006)

  • Non-Patent Literature 20: Katz, J., Sahai, A., Waters, B.: Predicate encryption supporting disjunctions, polynomial equations, and inner products. In: Smart, N. P. (ed.) EUROCRYPT 2008. LNCS, vol. 4965, pp. 146-162. Springer Heidelberg (2008)

  • Non-Patent Literature 21: Lewko, A., Okamoto, T., Sahai, A., Takashima, K., Waters, B.: Fully secure functional encryption: Attribute based encryption and (hierarchical) inner product encryption, EUROCRYPT 2010. LNCS, Springer Heidelberg (2010)

  • Non-Patent Literature 22: Lewko, A. B., Waters, B.: New techniques for dual system encryption and fully secure HIBE with short ciphertexts. In: Micciancio, D. (ed.) TCC 2010. LNCS, vol. 5978, pp. 455-479. Springer Heidelberg (2010)

  • Non-Patent Literature 23: Lewko, A. B., Waters, B.: Decentralizing Attribute-Based Encryption, the proceedings of Eurocrypt 2011, LNCS, Springer Heidelberg (2011).

  • Non-Patent Literature 24: Lewko, A. B., Waters, B.: Unbounded HIBE and attribute-based encryption, the proceedings of Eurocrypt 2011, LNCS, Springer Heidelberg (2011).

  • Non-Patent Literature 25: H. Lin, Z. Cao, X. Liang, and J. Shao.: Secure threshold multi authority attribute based encryption without a central authority, INDOCRYPT, LNCS, vol. 5365, pp. 426-436, Springer Heidelberg (2008).

  • Non-Patent Literature 26: S. M{umlaut over ( )}uller, S. Katzenbeisser, and C. Eckert.; On multi-authority ciphertext-policy attribute-based encryption, Bull. Korean Math Soc. 46, No. 4, pp. 803-819 (2009).

  • Non-Patent Literature 27: Okamoto, T., Takashima, K.: Homomorphic encryption and signatures from vector decomposition. In: Galbraith, S. D., Paterson, K. G. (eds.) Pairing 2008. LNCS, vol. 5209, pp. 57-74, Springer Heidelberg (2008)

  • Non-Patent Literature 28: Okamoto, T., Takashima, K.: Hierarchical predicate encryption for inner-products, In: ASIACRYPT 2009, Springer Heidelberg (2009)

  • Non-Patent Literature 29: Okamoto, T., Takashima, K.: Fully secure functional encryption with general relations from the decisional linear assumption. In: Rabin, T. (ed.) CRYPTO 2010. LNCS, vol. 6223, pp. 191-208. Springer Heidelberg (2010). Full version is available at http://eprint.iacr.org/2010/563

  • Non-Patent Literature 30: Okamoto, T., Takashima, K.: Efficient attribute-based signatures for non-monotone predicates in the standard model, In: PKC 2011, Springer Heidelberg (2011)

  • Non-Patent Literature 31: Okamoto, T., Takashima, K.: Decentralized Attribute-Based Signatures http://eprint.iacr.org/2011/701

  • Non-Patent Literature 32: Ostrovsky, R., Sahai, A., Waters, B.: Attribute-based encryption with non-monotonic access structures. In: ACM Conference on Computer and Communication Security 2007, pp. 195-203, ACM (2007)

  • Non-Patent Literature 33: Pirretti, M., Traynor, P., McDaniel, P., Waters, B.: Secure attribute-based systems. In: ACM Conference on Computer and Communication Security 2006, pp. 99-112, ACM, (2006)

  • Non-Patent Literature 34: Sahai, A., Waters, B.: Fuzzy identity-based encryption. In: Cramer, R. (ed.) EUROCRYPT 2005. LNCS, vol. 3494, pp. 457-473. Springer Heidelberg (2005)

  • Non-Patent Literature 35: Shi, E., Waters, B.: Delegating capability in predicate encryption systems. In: Aceto, L., Damgård, I., Goldberg, L. A., Halldørsson, M. M., Ingølfsdøttir, A., Walukiewicz, I. (eds.) ICALP (2) 2008. LNCS, vol. 5126, pp. 560-578. Springer Heidelberg (2008)

  • Non-Patent Literature 36: Waters, B.: Efficient identity based encryption without random oracles. Eurocrypt 2005, LNCS, vol. 3152, pp. 443-459. Springer Verlag, (2005)

  • Non-Patent Literature 37: Waters, B.: Ciphertext-policy attribute-based encryption: an expressive, efficient, and provably secure realization. ePrint, IACR, http://eprint.iacr.org/2008/290

  • Non-Patent Literature 38: Waters, B.: Dual system encryption: realizing fully secure IBE and HIBE under simple assumptions. In: Halevi, S. (ed.) CRYPTO 2009. LNCS, vol. 5677, pp. 619-636. Springer Heidelberg (2009)



SUMMARY OF INVENTION
Technical Problem

In the functional encryption scheme described in Non-Patent Literature 29, a pair of a basis Bt and a basis B*t is required for each attribute category. When an attribute category is to be added, a new pair of a basis Bt and a basis B*t needs to be generated. This makes it necessary to reissue a public parameter because the basis Bt is included in the public parameter.


It is an object of the present invention to allow for addition of an attribute category without reissuing a public parameter.


Solution to Problem

A cryptographic system according to the present invention is configured to perform a process using a predetermined basis B and a predetermined basis B*, and the cryptographic system includes:


a transmission device configured to generate a transmission-side vector tj for at least one index j out of a plurality of indices j, the transmission-side vector tj being a vector in which information J assigned in advance to the index j is set as a coefficient of a predetermined basis vector bindex of the basis B, and a parameter Φj for the index j is set as a coefficient of another basis vector batt of the basis B; and


a reception device configured to use a reception-side vector rj′ for at least one index j′ out of a plurality of indices j′, the reception-side vector rj′ being a vector in which information J′ having an inner-product of 0 with the information J assigned in advance to the index j corresponding to the index j′ is set as a coefficient of a basis vector b*index of the basis B* corresponding to the basis vector bindex, and a parameter Ψj′ for the index j′ is set as a coefficient of a basis vector b*att of the basis B* corresponding to the basis vector batt, and compute a product of pairing operations on corresponding pairs of the basis vectors of the transmission-side vector tj for the index j and the reception-side vector rj′ for the index j′ corresponding to the index j.


Advantageous Effects of Invention

In a cryptographic system according to the present invention, information J which is assigned in advance to index j is set in a transmission-side vector tj, and information J′ having an inner-product of 0 with the information J is set in a reception-side vector rj′. With this arrangement, a basis B and a basis B* can be used commonly for all attribute categories with security maintained, thus eliminating the need for using a basis Bt and a basis B*t for each category. As a result, when an attribute category is to be added, there is no need to newly generate a basis Bt and a basis B*t, thus allowing for addition of an attribute category without reissuing a public parameter.





BRIEF DESCRIPTION OF DRAWINGS


FIG. 1 is an explanatory drawing of a matrix M^;



FIG. 2 is an explanatory drawing of a matrix Mδ;



FIG. 3 is an explanatory drawing of s0;



FIG. 4 is an explanatory drawing of s{right arrow over (0)}T;



FIG. 5 is a configuration diagram of a cryptographic system 10 that implements a KP-FE scheme according to Embodiment 2;



FIG. 6 is a configuration diagram of a key generation device 100 according to Embodiment 2;



FIG. 7 is a configuration diagram of an encryption device 200 according to Embodiment 2;



FIG. 8 is a configuration diagram of a decryption device 300 according to Embodiment 2;



FIG. 9 is a flowchart illustrating the process of a Setup algorithm according to Embodiment 2;



FIG. 10 is a flowchart illustrating the process of a KeyGen algorithm according to Embodiment 2;



FIG. 11 is a flowchart illustrating the process of an Enc algorithm according to Embodiment 2;



FIG. 12 is a flowchart illustrating the process of a Dec algorithm according to Embodiment 2;



FIG. 13 is a configuration diagram of a cryptographic system 10 that implements a CP-FE scheme according to Embodiment 3;



FIG. 14 is a configuration diagram of a key generation device 100 according to Embodiment 3;



FIG. 15 is a configuration diagram of an encryption device 200 according to Embodiment 3;



FIG. 16 is a configuration diagram of a decryption device 300 according to Embodiment 3;



FIG. 17 is a flowchart illustrating the process of a KeyGen algorithm according to Embodiment 3;



FIG. 18 is a flowchart illustrating the process of an Enc algorithm according to Embodiment 3;



FIG. 19 is a flowchart illustrating the process of a Dec algorithm according to Embodiment 3;



FIG. 20 is a configuration diagram of a cryptographic system 10 that implements an HIPE scheme according to Embodiment 4;



FIG. 21 is a configuration diagram of a key generation device 100 according to Embodiment 4;



FIG. 22 is a configuration diagram of an encryption device 200 according to Embodiment 4;



FIG. 23 is a configuration diagram of a decryption device 300 according to Embodiment 4;



FIG. 24 is a configuration diagram of a key delegation device 400 according to Embodiment 4;



FIG. 25 is a flowchart illustrating the process of a Setup algorithm according to Embodiment 4;



FIG. 26 is a flowchart illustrating the process of a KeyGen algorithm according to Embodiment 4;



FIG. 27 is a flowchart illustrating the process of an Enc algorithm according to Embodiment 4;



FIG. 28 is a flowchart illustrating the process of a Dec algorithm according to Embodiment 4;



FIG. 29 is a flowchart illustrating the process of a DelegateL algorithm according to Embodiment 4;



FIG. 30 is a configuration diagram of a cryptographic system 10 that implements a signature scheme according to Embodiment 5;



FIG. 31 is a configuration diagram of a key generation device 100 according to Embodiment 5;



FIG. 32 is a configuration diagram of a signature device 500 according to Embodiment 5;



FIG. 33 is a configuration diagram of a verification device 600 according to Embodiment 5;



FIG. 34 is a flowchart illustrating the process of a Setup algorithm according to Embodiment 5;



FIG. 35 is a flowchart illustrating the process of a KeyGen algorithm according to Embodiment 5;



FIG. 36 is a flowchart illustrating the process of a Sig algorithm according to Embodiment 5;



FIG. 37 is a flowchart illustrating the process of a Ver algorithm according to Embodiment 5;



FIG. 38 is an explanatory drawing of multi-authority;



FIG. 39 is an explanatory drawing of a functional encryption scheme that allows for addition of an attribute category in a case of multi-authority; and



FIG. 40 is a diagram illustrating an example of a hardware configuration of the key generation device 100, the encryption device 200, the decryption device 300, the key delegation device 400, the signature device 500, and the verification device 600.





DESCRIPTION OF EMBODIMENTS

Embodiments of the present invention will be described hereinafter with reference to the accompanying drawings.


In the following description, a processing device is a CPU 911 or the like to be described later. A storage device is a ROM 913, a RAM 914, a magnetic disk 920 or the like to be described later. A communication device is a communication board 915 or the like to be described later. An input device is a keyboard 902, the communication board 915 or the like to be described later. That is, the processing device, the storage device, the communication device, and the input device are hardware.


Notations to be used in the following description will be described.


When A is a random variable or distribution, Formula 101 denotes that y is randomly selected from A according to the distribution of A. That is, y is a random number in Formula 101.









y



R


A




[

Formula





101

]







When A is a set, Formula 102 denotes that y is uniformly selected from A. That is, y is a uniform random number in Formula 102.









y



U


A




[

Formula





102

]







Formula 103 denotes that y is a set defined or substituted by z.

y:=z  [Formula 103]


When a is a fixed value, Formula 104 denotes that a machine (algorithm) A outputs a on input x.

A(x)→a  [Formula 104]
For example,
A(x)→1


Formula 105, namely Fq, denotes a finite field of order q.

custom characterq  [Formula 105]


A vector symbol denotes a vector representation over the finite field Fq, as indicated in Formula 106.

{right arrow over (x)} denotes
(x1, . . . ,xncustom characterqn  [Formula 106]


Formula 107 denotes that the inner-product, indicated in Formula 109, of two vectors x{right arrow over ( )} and v{right arrow over ( )} indicated in Formula 108.

{right arrow over (x)}·{right arrow over (v)}  [Formula 107]
{right arrow over (x)}=(x1, . . . ,xn),
{right arrow over (v)}=(v1, . . . ,vn)  [Formula 109]
Σi=1nxivi  [Formula 109]


Note that XT denotes the transpose of a matrix X.


When bi (i=1, . . . , n) is an element of a vector of a space V, that is when Formula 110 is established, Formula 111 denotes a subspace generated by Formula 112.

biεcustom character(i=1, . . . ,n)  [Formula 110]
spancustom characterb1, . . . ,bncustom charactercustom character(resp. span custom character{right arrow over (x)}1, . . . ,{right arrow over (x)}ncustom character)  [Formula 111]
b1, . . . ,bn(resp. {right arrow over (x)}1, . . . ,{right arrow over (x)}n)  [Formula 112]


For a basis B and a basis B* indicated in Formula 113, Formula 114 is established.

custom character:=(b1, . . . ,bN),
custom character*:=(b*1, . . . ,b*N)  [Formula 113]
(x1, . . . ,xN)custom character:=Σi=1Nxibi,
(y1, . . . ,yN)custom character:=Σi=1Nyib*i  [Formula 114]


Note that e{right arrow over ( )}j denotes an orthonormal basis vector indicated in Formula 115.
















j

:


(



0











0




j
-
1



,
1
,


0











0




n
-
j




)








𝔽
q
n






for





j



=
1

,





,
n
,




[

Formula





115

]







In the following description, when “Vt” is shown as a subscript or superscript, this Vt denotes Vt. Likewise, when “δi,j” is shown as a superscript, this δi,j denotes δi,j.


When “→” representing a vector is attached to a subscript or superscript, it is meant that this “→” is attached as a superscript to the subscript or superscript.


In the following description, processes of cryptographic primitives include not only a narrowly-defined cryptographic process for keeping information secure from a third party, but also include a signature process. The processes of the cryptographic primitives include a key generation process, an encryption process, a decryption process, a key delegation process, a signature process, and a verification process.


Embodiment 1

This embodiment describes a basic concept for implementing the processes of the cryptographic primitives to be described in the following embodiments that allow for addition of an attribute category without reissuing a public parameter.


First, addition of an attribute category will be described.


Second, a functional encryption scheme and a basic construction of the functional encryption scheme will be briefly described.


Third, a key technique for realizing addition of an attribute category without reissuing a public parameter will be described.


Fourth, a space having a rich mathematical structure called “dual pairing vector spaces (DPVS)” which is a space for implementing the functional encryption scheme will be described.


Fifth, a concept for implementing the functional encryption scheme will be described. Here, “span program”, “inner-product of attribute information and access structure”, and “secret distribution scheme (secret sharing scheme)” will be described.


<1. Addition of an Attribute Category>


An attribute category is a classification of an attribute of each user, such as belonging organization, belonging department, position in company, age, and gender.


The processes of the cryptographic primitives to be described in the following embodiments realize access control based on the user's attribute. For example, with a narrowly-defined cryptographic process for securing information from a third party, whether or not the user can decrypt a ciphertext is controlled based on the user's attribute.


Generally, attribute categories used for access control are determined in advance at the design stage of a system. However, there may be a case where the operational rules of the system are changed at a later stage, necessitating addition of an attribute category used for access control.


For example, suppose that a cryptographic system is constructed on the assumption that the system is to be used only within Company A. In this case, it is assumed that the attribute categories to be used are, for example, belonging department, position in company, and individual ID. However, suppose that the operational rules are changed at a later stage so that the cryptographic system is used not only in Company A but also in associated companies of Company A. In this case, belonging company needs to be newly set as an attribute category to be used.


If the attribute categories used for access control are specified by a public parameter, adding an attribute category at a later stage requires that the public parameter be reissued and redistributed to each user. For this reason, an attribute category cannot be easily added at a later stage, and an operational mode that was not taken into consideration at the design stage of the system cannot be flexibly adopted.


Therefore, it is important to allow for addition of an attribute category without reissuing a public parameter.


<2. Functional Encryption Scheme>


The functional encryption scheme is an encryption scheme that provides more sophisticated and flexible relations between an encryption key ek and a decryption key dk.


According to the functional encryption scheme, a parameter Φ and a parameter Ψ are set in the encryption key ek and the decryption key dk, respectively. The decryption key dk can decrypt a ciphertext encrypted with the encryption key ek if and only if a relation R (Φ, Ψ) holds.


The functional encryption scheme includes an attribute-based encryption scheme and an 1D-based encryption scheme.


The construction of the functional encryption scheme will be briefly described.


The functional encryption scheme consists of four algorithms: Setup, KeyGen, Enc, and Dec.


(Setup)


A Setup algorithm is an algorithm that outputs a public parameter pk and a master key sk.


(KeyGen)


A KeyGen algorithm is an algorithm that takes as input the public parameter pk, the master key sk, and a parameter Ψ, and outputs a decryption key skΨ.


(Enc)


An Enc algorithm is an algorithm that takes as input the public parameter pk, a parameter Φ, and a message m, and outputs a ciphertext ctΦ.


(Dec)


A Dec algorithm is an algorithm that takes as input the public parameter pk, the decryption key skΨ, and the ciphertext ctΦ, and outputs the message m or a distinguished symbol ⊥.


The ciphertext ctΦ can be decrypted with the decryption key skΨ to obtain the message m if and only if the parameter Ψ and the parameter Φ satisfy the relation R (if R(Φ, Ψ) holds).


Generally, the Setup algorithm is executed only once at system setup. The KeyGen algorithm is executed each time a decryption key skΨ of a user is to be generated. The Enc algorithm is executed each time a message m is to be encrypted. The Dec algorithm is executed each time a ciphertext ctΦ is to be decrypted.


<3. Key Technique>


The key technique for realizing addition of an attribute category without reissuing a public parameter is to apply an indexing technique to dual system encryption in the dual pairing vector spaces.


In the dual system encryption in the dual pairing vector spaces, a pair of dual bases, a basis B and a basis B*, are randomly generated. Then, a part of the basis B (basis B^) is used as a public parameter.


In the functional encryption scheme described in Non-Patent Literature 29, a basis B^1, . . . , and a basis B^d are generated as a public parameter. One attribute category is assigned to each basis B^t corresponding to each integer t=1, . . . , d. That is, d pieces of attribute categories can be handled.


As is evident from the fact that the basis B^1, . . . , and the basis B^d are used as the public parameter, the public parameter needs to be reissued to add a basis B^, that is, to increase the value of d, at a later stage. In other words, the value of d is bounded by the public parameter.


In the functional encryption scheme to be described in the following embodiments, a basis B^ is generated as a public parameter. Two-dimensional index vectors, σt(1, t) and μi(t, −1), corresponding to each integer t=1, . . . , d are set in a ciphertext c and a secret key k*, respectively, such that one attribute category is assigned to each integer t. That is, d pieces of attribute categories can be handled.


Note here that the public parameter includes the basis B^ but not the index vectors. Hence, when index vectors are to be added at a later stage to increase the value of d, there is no need to reissue the public parameter. In other words, the value of d is not bounded by the public parameter.


<4. Dual Pairing Vector Spaces>


First, symmetric bilinear pairing groups will be described.


Symmetric bilinear pairing groups (q, G, GT, g, e) are a tuple of a prime q, a cyclic additive group G of order q, a cyclic multiplicative group GT of order q, g≠0εG, and a polynomial-time computable nondegenerate bilinear pairing e:G×G→GT. The nondegenerate bilinear pairing signifies e(sg, tg)=e(g, g)st, and e(g, g)≠1.


In the following description, let Gbpg be an algorithm that takes as input 1λ and outputs values of a parameter paramG:=(q, G, GT, g, e) of bilinear pairing groups with a security parameter λ.


Dual pairing vector spaces will now be described.


Dual pairing vector spaces (q, V, GT, A, e) can be constructed by a direct product of the symmetric bilinear pairing groups (paramG:=(q, G, GT, g, e)). The dual pairing vector spaces (q, V, GT, A, e) are a tuple of a prime q, an N-dimensional vector space V over Fq indicated in Formula 116, a cyclic group GT of order q, and a canonical basis A:=(a1, . . . , aN) of the space V, and have the following operations (1) and (2), where ai is as indicated in Formula 117.









𝕍
:=


𝔾
×

×
𝔾



N






[

Formula





116

]







a
i

:=

(



0
,





,
0




i
-
1



,
g
,


0
,





,
0




N
-
i




)





[

Formula





117

]







Operation (1): Nondegenerate Bilinear Pairing


A pairing in the space V is defined by Formula 118.

e(x,y):=Πi=1Ne(Gi,Hicustom characterT  [Formula 118]
where
(G1, . . . ,GN):=custom character,
(H1, . . . ,HN):=custom character


This is nondegenerate bilinear, that is, e(sx, ty)=e(x, y)st and if e(x, y)=1 for all yεV, then x=0. For all i and j, e(ai, aj)=e(g, g)δi,j, where δi,j=1 if i=j, and δi,j=0 if i≠j, and e(g, g)≠1εGT.


Operation (2): Distortion Maps


Linear transformations φi,j on the space V indicated in Formula 119 can achieve Formula 120.











If







ϕ

i
,
j




(

a
j

)



=


a
i






and









k

j

,


then







ϕ

i
,
j




(

a
k

)



=
0.






[

Formula





119

]









ϕ

i
,
j




(
x
)


:=

(



0
,





,
0




i
-
1



,

g
j

,


0
,





,
0




N
-
i




)













where




(


g
1

,








g
N



)

:=
x





[

Formula





120

]







The linear transformations φi,j will be called distortion maps.


In the following description, let Gdpvs be an algorithm that takes as input 1λ (λε natural number), Nε natural number, and values of a parameter paramG:=(q, G, GT, g, e) of bilinear pairing groups, and outputs values of a parameter paramV:=(q, V, GT, A, e) of dual pairing vector spaces with a security parameter λ and an N-dimensional space V.


Description will be directed herein to a case where the dual pairing vector spaces are constructed using the above-described symmetric bilinear pairing groups. The dual pairing vector spaces can also be constructed using asymmetric bilinear pairing groups. The following description can easily be adapted to a case where the dual pairing vector spaces are constructed using asymmetric bilinear pairing groups.


<5. Concept for Implementing Functional Encryption>


<5-1. Span Program>



FIG. 1 is an explanatory drawing of a matrix M^.


Let {p1, . . . , pn} be a set of variables. M^:=(M, ρ) is a labeled matrix. The matrix M is an (L rows×r columns) matrix over Fq, and ρ is a label of rows of the matrix M and is related to one of literals {p1, . . . ,pn, custom characterp1, . . . , custom characterpn}. Alabel ρi (i=1, . . . L) of each row of M is related to one of the literals. That is, ρ: {1, . . . , L}→{p1, . . . , pn, custom characterp1, . . . , custom characterpn}.


For every input sequence δε{0, 1}n, a submatrix Mδ of the matrix M is defined. The matrix Mδ is a submatrix consisting of those rows of the matrix M the labels ρ of which are related to a value “1” by the input sequence δ. That is, the matrix Mδ is a submatrix consisting of the rows of the matrix M which are related to pi such that δi=1 and the rows of the matrix M which are related to custom characterpi such that δi=0.



FIG. 2 is an explanatory drawing of the matrix Mδ. In FIG. 2, note that n=7, L=6, and r=5. That is, the set of variables is {p1, . . . , p7}, and the matrix M is a (6 rows×5 columns) matrix. In FIG. 2, assume that the labels ρ are related such that ρ1 is related to custom characterp2, ρ2 to p1, ρ3 to p4, ρ4 to custom characterp5, ρ5 to custom characterp3, and ρ6 to p5.


Assume that in an input sequence δε{0, 1}7, δ1=1, δ2=0, δ3=1, δ4=0, δ5=0, δ6=1, and δ7=1. In this case, a submatrix consisting of the rows of the matrix M which are related to literals (p1, p3, p6, p7, custom characterp2, custom characterp4, custom characterp5) surrounded by broken lines is the matrix Mδ. That is, the submatrix consisting of the first row (M1), second row (M2), and fourth row (M4) of the matrix M is the matrix Mδ.


In other words, when map γ:{1, . . . , L}→{0, 1} is [ρ(j)=pi]^[δi=1] or [ρ(j)=custom characterpi]custom characteri=0], then γ(j)=1; otherwise γ(j)=0. In this case, Mδ:=(Mj)δ(j)=1. Note that Mj is the j-th row of the matrix M.


That is, in FIG. 2, map γ(j)=1 (j=1, 2, 4), and map γ(j)=0 (j=3, 5, 6). Hence, (Mj)γ(j)=1 is M1, M2, and M4, and the matrix Mδ.


More specifically, whether or not the j-th row of the matrix M is included in the matrix Mδ is determined by whether the value of the map γ(j) is “0” or “1”.


The span program M^ accepts an input sequence δ if and only if 1{right arrow over ( )}εspan<Mδ>, and rejects the input sequence δ otherwise. That is, the span program M^ accepts the input sequence δ if and only if linear combination of the rows of the matrix Mδ which are obtained from the matrix M^ by the input sequence δ gives 1{right arrow over ( )}. 1{right arrow over ( )} is a row vector which has a value “1” in each element.


For example, in FIG. 2, the span program M^ accepts the input sequence δ if and only if linear combination of the respective rows of the matrix Mδ consisting of the 1st, 2nd, and 4th rows of the matrix M gives 1{right arrow over ( )}. That is, if there exist α1, α2, and α4 with which α1(M1)+α2(M2)+α4(M4)={right arrow over (1)}, the span program M^ accepts the input sequence δ.


The span program is called monotone if its labels ρ are related to only positive literals {p1, . . . , pn}. The span program is called non-monotone if its labels ρ are related to the literals {p1, . . . , pn, custom characterp1, . . . , custom characterpn}. It is assumed herein that the span program is non-monotone. An access structure (non-monotone access structure) is constituted using the non-monotone span program. Briefly, an access structure controls access to encryption, that is, it controls whether a ciphertext is to be decrypted or not.


As will be described in detail later, the span program being non-monotone, instead of being monotone, allows for a wider range of applications of the functional encryption scheme constituted using the span program.


<5-2. Inner-Product of Attribute Information and Access Structure>


The above-described map γ(j) is computed using the inner-product of attribute information. That is, the inner-product of attribute information is used to determine which row of the matrix M is to be included in the matrix Mδ.


Ut (t=1, . . . , d and Ut⊂{0, 1}*) is a sub-universe and a set of attributes. Each Ut includes identification information (t) of the sub-universe and an n-dimensional vector (v{right arrow over ( )}). That is, Ut is (t, v{right arrow over ( )}), where to tε{1, . . . , d} and v{right arrow over ( )}εFqn.


Let Ut:=(t, v{right arrow over ( )}) be a variable p of the span program M^:=(M, ρ). That is, p:=(t, v{right arrow over ( )}). Let the span program M^:=(M, ρ) having the variable (p:=(t, v{right arrow over ( )}), (t′, v{right arrow over ( )}′), . . . ) be an access structure S.


That is, the access structure S:=(M, ρ) and ρ:{1, . . . , L}→{(t, v{right arrow over ( )}), (t′, v{right arrow over ( )}′), . . . , custom character(t, v{right arrow over ( )}), custom character(t′, v{right arrow over ( )}′), . . . }.


Let Γ be a set of attributes. That is, Γ:={(t, x{right arrow over ( )}t)|x{right arrow over ( )}tεFqn, 1≦t≦d}.


When Γ is given to the access structure S, map γ: {1, . . . , L}→{0, 1} for the span program M^:=(M, ρ) is defined as follows. For each integer i=1, . . . , L, set γ(j)=1 if [ρ(i)=(t, v{right arrow over ( )}i)]custom character[(t, x{right arrow over ( )}t)εΓ]custom character[v{right arrow over ( )}i·x{right arrow over ( )}t=0] or [ρ(i)=custom character(t, v{right arrow over ( )}i)]custom character[(t, x{right arrow over ( )}t)εΓ]^[v{right arrow over ( )}i·x{right arrow over ( )}t≠0]. Set γ(j)=0 otherwise. custom character


That is, the map γ is computed based on the inner-product of the attribute information v{right arrow over ( )} and x{right arrow over ( )}. As described above, which row of the matrix M is to be included in the matrix Mδ is determined by the map γ. More specifically, which row of the matrix M is to be included in the matrix Mδ is determined by the inner-product of the attribute information v{right arrow over ( )} and x{right arrow over ( )}. The access structure S:=(M, ρ) accepts Γ if and only if 1{right arrow over ( )}εspan<(Mi)γ(i)=1>.


<5-3. Secret Distribution Scheme>


A secret distribution scheme for the access structure S:=(M, ρ) will be described.


The secret distribution scheme is distributing secret information to render it nonsense distributed information. For example, secret information s is distributed into 10 pieces to generate 10 pieces of distributed information. Each of the 10 pieces of distributed information does not have information on the secret information s. Hence, even when one of the pieces of distributed information is obtained, no information can be obtained on the secret information s. On the other hand, if all of the 10 pieces of distributed information are obtained, the secret information s can be recovered.


Another secret distribution scheme is also available according to which the secret information s can be recovered if some (for example, 8 pieces) of distributed information can be obtained, without obtaining all of the 10 pieces of distributed information. A case like this where the secret information s can be recovered using 8 pieces out of 10 pieces of distributed information will be called 8-out-of-10. That is, a case where the secret information s can be recovered using t pieces out of n pieces of distributed information will be called t-out-of-n. This t will be called a threshold.


Still another secret distribution scheme is available according to which when 10 pieces of distributed information d1, . . . , d10 are generated, the secret information s can be recovered with 8 pieces of distributed information d1, . . . , d8, but the secret information s cannot be recovered with 8 pieces of distributed information d3, . . . , d10. In other words, secret distribution schemes include a scheme according to which whether or not the secret information s can be recovered is controlled not only by the number of pieces of distributed information obtained, but also the combination of distributed information obtained.



FIG. 3 is an explanatory drawing of s0. FIG. 4 is an explanatory drawing of s{right arrow over ( )}T.


Let a matrix M be an (L rows×r columns) matrix. Let f{right arrow over ( )}T be a column vector indicated in Formula 121.











f


T

:=



(


f
1

,








f
r



)

T




U



𝔽
q
r






[

Formula





121

]







Let s0 indicated in Formula 122 be secret information to be shared.

s0:={right arrow over (1)}·{right arrow over (f)}T:=Σk=1rfk  [Formula 122]


Let s{right arrow over ( )}T indicated in Formula 123 be a vector of L pieces of distributed information of s0.

{right arrow over (s)}T:=(s1, . . . sL)T:=M·{right arrow over (f)}T  [Formula 123]


Let the distributed information si belong to ρ(i).


If the access structure S:=(M, ρ) accepts Γ, that is, 1{right arrow over ( )}ε span<(Mi)γ(i)=1> for γ: {1, . . . , L}→{0, 1}, then there exist constants {αi εFq|iεI} such that I{iε{1, . . . , L}|γ(i)═1}.


This is obvious from the explanation about the example of FIG. 2 that if there exist α1, α2, and α4 with which α1(M1)+α2(M2)+α4(M4)=1{right arrow over ( )}, the span program M^ accepts the input sequence δ. That is, if the span program M^ accepts the input sequence δ when there exist α1, α2, and α4 with which α1(M1)+α2(M2)+α4(M4)=1{right arrow over ( )}, then there exist α1, α2, and α4 with which α1(M1)+α2(M2)+α4(M4)=1{right arrow over ( )}.


Note Formula 124.

ΣiεIαisi:=s0  [Formula 124]

    • Note that the constants {αi} can be computed in time polynomial in the size of the matrix M.


With the functional encryption scheme according to the following embodiments, an access structure is constructed by applying the inner-product predicate and the secret distribution scheme to the span program, as described above. Therefore, access control can be designed flexibly by designing the matrix M in the span program and the attribute information x and the attribute information v (predicate information) in the inner-product predicate. That is, access control can be designed very flexibly. Designing of the matrix M corresponds to designing of conditions such as a threshold of the secret distribution scheme.


For example, the attribute-based encryption scheme described above corresponds to a case where designing of the inner-product predicate is limited to a certain condition in the access structure in the functional encryption scheme according to the following embodiments. That is, when compared to the access structure in the functional encryption scheme according to the following embodiments, the access structure in the attribute-based encryption scheme has a lower flexibility in access control design because it lacks the flexibility in designing the attribute information x and the attribute information v (predicate information) in the inner-product predicate. More specifically, the attribute-based encryption scheme corresponds to a case where attribute information {x{right arrow over ( )}t}tε{1, . . . , d} and {v{right arrow over ( )}t}tε{1, . . . , d} are limited to two-dimensional vectors for the equality relation, for example, x{right arrow over ( )}t:=(1, xt) and v{right arrow over ( )}t:=(vt, −1).


An inner-product predicate encryption scheme corresponds to a case where designing of the matrix M in the span program is limited to a certain condition in the access structure in the functional encryption scheme according to the following embodiments. That is, when compared to the access structure in the functional encryption scheme according to the following embodiments, the access structure in the inner-product predicate encryption scheme has a lower flexibility in access control design because it lacks the flexibility in designing the matrix M in the span program. More specifically, the inner-product predicate encryption scheme corresponds to a case where the secret distribution scheme is limited to 1-out-of-1 (or d-out-of-d).


In particular, the access structure in the functional encryption scheme according to the following embodiments constitutes a non-monotone access structure that uses a non-monotone span program. Thus, the flexibility in access control designing improves.


More specifically, since the non-monotone span program includes a negative literal (custom characterp), a negative condition can be set. For example, assume that First Company includes four departments, A, B, C, and D. Assume that access control is to be performed such that only users belonging to departments other than department B of First Company are capable of access (capable of decryption). In this case, if a negative condition cannot be set, a condition that “the user belongs to any one of departments A, C, and D of First Company” must be set. On the other hand, if a negative condition can be set, a condition that “the user is an employee of First Company and belongs to a department other than department B” can be set. In other words, since a negative condition can be set, natural condition setting is possible. Although the number of departments is small in this case, this scheme is very effective in a case where the number of departments is large.


Embodiment 2

This embodiment describes a narrowly-defined cryptographic processing scheme. In particular, this embodiment describes a key-policy functional encryption (KP-FE) scheme.


Note that key-policy means that a policy, namely an access structure, is embedded in a decryption key.


First, the construction of the KP-FE scheme will be described.


Second, the configuration of a cryptographic system 10 that implements the KP-FE scheme will be described.


Third, the KP-FE scheme will be described in detail.


<1. Construction of KP-FE Scheme>


The KP-FE scheme consists of four algorithms: Setup, KeyGen, Enc, and Dec.


(Setup)


A Setup algorithm is a probabilistic algorithm that takes as input a security parameter λ, and outputs a public parameter pk and a master key sk.


(KeyGen)


A KeyGen algorithm is a probabilistic algorithm that takes as input an access structure S:=(M, ρ), the public parameter pk, and the master key sk, and outputs a decryption key skS.


(Enc)


An Enc algorithm is a probabilistic algorithm that takes as input a message m, an attribute set Γ:={(t, x{right arrow over ( )}t)|x{right arrow over ( )}tεFqn, 1≦t≦d}, and the public parameter pk, and outputs a ciphertext ctΓ.


(Dec)


A Dec algorithm is an algorithm that takes as input the ciphertext ctΓ encrypted under the attribute set Γ, the decryption key skS for the access structure S, and the public parameter pk, and outputs the message m or a distinguished symbol ⊥.


<2. Configuration of Cryptographic System 10 that Implements KP-FE Scheme>



FIG. 5 is a configuration diagram of the cryptographic system 10 that implements the KP-FE scheme according to Embodiment 2.


The cryptographic system 10 includes a key generation device 100, an encryption device 200, and a decryption device 300.


The key generation device 100 executes the Setup algorithm taking as input a security parameter λ, and thus generates a public parameter pk and a master key sk. Then, the key generation device 100 publishes the generated public parameter pk. The key generation device 100 also executes the KeyGen algorithm taking as input an access structure S, and thus generates a decryption key skS, and distributes the decryption key skS to the decryption device 300 in secrecy.


The encryption device 200 executes the Enc algorithm taking as input a message m, an attribute set Γ, and the public parameter pk, and thus generates a ciphertext ctΓ. The encryption device 200 transmits the generated ciphertext ctΓ to the decryption device 300.


The decryption device 300 executes the Dec algorithm taking as input the public parameter pk, the decryption key skS, and the ciphertext ctΓ, and thus outputs the message m or a distinguished symbol ⊥.


<3. KP-FE Scheme in Detail>


With reference to FIGS. 6 to 12, the KP-FE scheme will be described, and the function and operation of the cryptographic system 10 that implements the KP-FE scheme will be described.



FIG. 6 is a configuration diagram of the key generation device 100 according to Embodiment 2. FIG. 7 is a configuration diagram of the encryption device 200 according to Embodiment 2. FIG. 8 is a configuration diagram of the decryption device 300 according to Embodiment 2.



FIGS. 9 and 10 show flowcharts illustrating the operation of the key generation device 100. FIG. 9 is a flowchart illustrating the process of the Setup algorithm, and FIG. 10 is a flowchart illustrating the process of the KeyGen algorithm. FIG. 11 is a flowchart illustrating the operation of the encryption device 200 and illustrating the process of the Enc algorithm. FIG. 12 is a flowchart illustrating the operation of the decryption device 300 and illustrating the process of the Dec algorithm.


In the following description, it is assumed that xt,1:=1.


The function and operation of the key generation device 100 will be described.


The key generation device 100 includes a master key generation unit 110, a master key storage unit 120, an information input unit 130, a decryption key generation unit 140, and a key distribution unit 150. The decryption key generation unit 140 includes an f vector generation unit 141, an s vector generation unit 142, a random number generation unit 143, and a key element generation unit 144.


First, with reference to FIG. 9, the process of the Setup algorithm will be described.


(S101: Orthonormal Basis Generation Step)


Using the processing device, the master key generation unit 110 computes Formula 125, and thus generates a parameter param, a basis B0 and a basis B*0, and a basis B1 (basis B) and a basis B*1 (basis B*).









[

Formula





125

]











input






1
λ





(
1
)







param
𝔾

:=


(

q
,
𝔾
,

𝔾
T

,
g
,
e

)




R




𝒢
bpg



(

1
λ

)







(
2
)








ψ



U



𝔽
q
x


,






N
0

:=

1
+

u
0

+
1
+

w
0

+

z
0



,


N
1

:=

2
+
n
+
u
+
w
+
z











The





process






(
4
)






through






(
8
)






is





executed





for





each





t

=
0

,
1.





(
3
)







param

𝕍
t


:=


(

q
,

𝕍
t

,

𝔾
T

,

𝔸
t

,
e

)

:=


𝒢
dpvs



(


1
λ

,

N
t

,

param
𝔾


)







(
4
)







X
t

:=



(

χ

t
,
i
,
j


)


i
,

j
=
1

,









,

N
t






U



GL


(


N
t

,

𝔽
q


)







(
5
)







X
t
*

:=



(

ϑ

t
,
i
,
j


)


i
,

j
=
1

,









,

N
t



:=

ψ
·


(

X
t
T

)


-
1








(
6
)








b

t
,
i


:=



(


χ



t
,
i


)


𝔸
t


=





j
=
1


N
t





χ

t
,
i
,
j




a

t
,
j







for





i


=
1



,





,

N
t

,






𝔹
t

:=

(


b

t
,
1


,





,

b

t
,

N
t




)






(
7
)








b

t
,
i

*

:=



(


ϑ



t
,
i


)


𝔸
t


=



(



j
=
1


N
t


)



ϑ

t
,
i
,
j




a

t
,
j







for





i

=
1



,





,

N
t

,






𝔹
t
*

:=

(


b

t
,
1

*

,





,

b

t
,

N
t


*


)






(
8
)








g
T

:=


e


(

g
,
g

)



ψ


,

param
:=

(



{

param

𝕍
t


}



t
=
0

,
1


,

g
T


)






(
9
)







That is, the master key generation unit 110 executes the following process.


(1) Using the input device, the master key generation unit 110 takes as input a security parameter λ(1λ).


(2) Using the processing device, the master key generation unit 110 executes the algorithm Gbpg taking as input the security parameter λ (1λ) inputted in (1), and thus generates values of a parameter paramG:=(q, G, GT, g, e) of bilinear pairing groups.


(3) Using the processing device, the master key generation unit 110 generates a random number w, and sets 1+u0+1+w0+z0 in N0 and 2+n+u+w+z in N1, where n is an integer of 1 or more and u0, w0, z0, u, w, and z are integers of 0 or more.


Then, the master key generation unit 110 executes the following process (4) through (8) for each t=0, 1.


(4) Using the processing device, the master key generation unit 110 executes the algorithm Gdpvs taking as input the security parameter λ (1λ) inputted in (1), Nt set in (3), and the values of paramG:=(q, G, GT, g, e) generated in (2), and thus generates values of a parameter paramVt:=(q, Vt, GT, At, e) of dual pairing vector spaces.


(5) Using the processing device, the master key generation unit 110 takes as input Nt set in (3) and Fq, and randomly generates a linear transformation Xt:=(χt,i,j)i,j. Note that GL stands for general linear. In other words, GL is a general linear group, a set of square matrices with nonzero determinants, and a group under multiplication. Note that (χt,i,j)i,j denotes a matrix concerning the suffixes i and j of the matrix χt,i,j, where i, j=1, . . . , Nt.


(6) Using the processing device and based on the random number ψ and the linear transformation Xt, the master key generation unit 110 generates (vt,i,j)i,j:=ψ·(XtT)−1. Like (χt,i,j)i,j, (vt,i,j)i,j denotes a matrix concerning the suffixes i and j of the matrix vt,i,j, where i, j=1, . . . , Nt.


(7) Using the processing device and based on the linear transformation Xt generated in (5), the master key generation unit 110 generates a basis Bt from the orthonormal basis At generated in (4). Note that x{right arrow over ( )}t,i indicates the i-th row of the linear transformation Xt.


(8) Using the processing device and based on (vt,i,j)i,j generated in (6), the master key generation unit 110 generates a basis B*t from the orthonormal basis At generated in (4). Note that v{right arrow over ( )}t,i indicates the i-th row of the linear transformation X*t.


(9) Using the processing device, the master key generation unit 110 sets e(g, g)ψ in gT. The master key generation unit 110 also sets {paramVt}t=0,1 generated in (4) and gT in param.


In brief, in (S101), the master key generation unit 110 executes an algorithm Gob indicated in Formula 126, and thus generates param, the basis B0 and the basis B*0, and the basis B1 (basis B) and the basis B*1 (basis B*).











[

Formula





126

]











𝒢
ob



(

1
λ

)


:

param
𝔾


:=


(

q
,
𝔾
,

𝔾
T

,
g
,
e

)




R




𝒢
bpg



(

1
λ

)




,





ψ



U



𝔽
q
x


,


N
0

:=

1
+

u
0

+
1
+

w
0

+

z
0



,






N
1

:=

2
+
n
+
u
+
w
+
z


,


for





t

=
0

,
1
,






param

𝕍
t


:


(

q
,

𝕍
t

,

𝔾
T

,

𝔸
t

,
e

)

:


𝒢
dpvs



(


1
λ

,

N
t

,

param
𝔾


)




,






X
t

:=



(

χ

t
,
i
,
j


)


i
,

j
=
1

,





,

N
t






U



GL


(


N
t

,

𝔽
q


)












X
t
*

:=



(

ϑ

t
,
i
,
j


)


i
,

j
=
1

,









,

N
t



:=

ψ
·


(

X
t
T

)


-
1





,
hereafter









χ



t
,
i







and







ϑ



t
,
i







denote





the






i-th






rows





of






X
t






and






X
t
*














for





i

=
1

,

,

N
t

,
respectively
,






b

t
,
i


:=



(


χ



t
,
i


)


𝔸
t


=





j
=
1


N
t





χ

t
,
i
,
j




a

t
,
j







for





i


=
1



,

,

N
t










𝔹
t

:=

(


b

t
,
1


,





,

b

t
,

N
t




)


,


b

t
,
i

*

:=



(


ϑ



t
,
i


)


𝔸
t


=




j
=
1


N
t





ϑ

t
,
i
,
j




a

t
,
j



















for





i

=
1

,

,

N
t

,


B
t
*

:=

(


b

t
,
1

*

,





,

b

t
,

N
t


*


)


,


g
T

:=


e


(

g
,
g

)


ψ


,





param
:=

(



{

param

𝕍
t


}



t
=
0

,
1


,

g
T


)


,

return







(

param
,

𝔹
t

,

𝔹
t
*


)

.






In the following description, for simplicity, the basis B1 and the basis B*1 will be described as the basis B and the basis B*.


(S102: Public Parameter Generation Step)


Using the processing device, the master key generation unit 110 generates a subbasis B^0 of the basis B0 and a subbasis B^ of the basis B, as indicated in Formula 127, the bases B0 and B having been generated in (S101).

custom character0:=(b0,1,b0,1+u0+1,b0,1+u0+1+w0+1, . . . ,b0,1+u0+1+w0+z0),
custom character:=(b1, . . . ,b2+n,b2+n+u+w+1, . . . ,b2+n+u+w+z)  [Formula 127]


The master key generation unit 110 generates a public parameter pk by putting together the generated subbasis B^0 and subbasis B^, the security parameter λ(1λ) inputted in (S101), and param generated in (S101).


(S103: Master Key Generation Step)


Using the processing device, the master key generation unit 110 generates a subbasis B^*0 of the basis B*0 and a subspace B^* of the basis B*, as indicated in Formula 128, the bases B*0 and B^* having been generated in (S101).

custom character*0:=(b*0,1,b*0,1+u0+1,b*0,1+u0+1+1, . . . ,b*0,1+u0+1+w0),
custom character*:=(b*1, . . . ,b*2+n,b*2+n+u+1, . . . ,b*2+n+u+w)  [Formula 128]


The master key generation unit 110 generates a master key sk which is constituted by the generated subbasis B^*0 and subbasis B^*.


(S104: Master Key Storage Step)


The master key storage unit 120 stores the parameter pk generated in (S102) in the storage device. The master key storage unit 120 also stores the master key sk generated in (S103) in the storage device.


In brief, in (S101) through (S103), the key generation device 100 executes the Setup algorithm indicated in Formula 129, and thus generates the public parameter pk and the master key sk. In (S104), the key generation device 100 stores the generated public parameter pk and master key sk in the storage device.


The public parameter is published, for example, via the network, and is made available for the encryption device 200 and the decryption device 300.















Setup






(

1
λ

)



:














(

param
,

(


0

,

0
*


)

,

(

,

*


)


)




R




ob



(

1
λ

)



,







^

0

:=

(


b

0
,
1


,

b

0
,

1
+

u
0

+
1



,

b

0
,

1
+

u
0

+
1
+

w
0

+
1



,





,

b

0
,

1
+

u
0

+
1
+

w
0

+

z
0





)


,






^

:=

(


b
1

,





,

b

2
+
n


,

b

2
+
n
+
u
+
w
+
1


,





,

b

2
+
n
+
u
+
w
+
z



)


,







^

0
*

:=

(


b

0
,
1

*

,

b

0
,

1
+

u
0

+
1



,

b

0
,

1
+

u
0

+
1
+
1



,





,

b

0
,

1
+

u
0

+
1
+

w
0





)


,







^

*

:=

(


b
1
*

,





,

b

2
+
n

*

,

b

2
+
n
+
u
+
1


,





,

b

2
+
n
+
u
+
w

*


)


,










return





pk

:=

(


1
λ

,
param
,


^

0

,

^


)


,

sk
:=


(



^

0
*

,


^

*


)

.








[

Formula





129

]







With reference to FIG. 10, the process of the KeyGen algorithm will be described.


(S201: Information Input Step)


Using the input device, the information input unit 130 takes as input the above-described access structure S:=(M, ρ). Note that the matrix M of the access structure S is to be set according to the conditions of a system to be implemented. Note also that attribute information of the user of a decryption key skS is set in ρ of the access structure S, for example.


(S202: f Vector Generation Step)


Using the processing device, the f vector generation unit 141 randomly generates a vector {right arrow over (f)} having r pieces of elements, as indicated in Formula 130.










f





U



q
r





[

Formula





130

]







(S203: s Vector Generation Step)


Using the processing device and based on the (L rows×r columns) matrix M included in the access structure S inputted in (S201) and the vector {right arrow over (f)} generated in (S202), the s vector generation unit 142 generates a vector {right arrow over (s)}T:=(s1, . . . , sL)T, as indicated in Formula 131.

{right arrow over (s)}T:=(s1, . . . ,sL)T:=M·{right arrow over (f)}T  [Formula 131]


Using the processing device and based on the vector {right arrow over (f)} generated in (S202), the s vector generation unit 142 also generates a value s0, as indicated in Formula 132.

s0:={right arrow over (1)}·{right arrow over (f)}T  [Formula 132]


(S204: Random Number Generation Step)


Using the processing device, the random number generation unit 143 generates random numbers, as indicated in Formula 133.












η


0

:=


(


η

0
,
1


,





,

η

0
,

w
0




)




U



q

w
0




,





μ
i

,


θ
i




U



q


,







η


i

:=



(


η

i
,
1


,





,

η

i
,
w



)




U




q
w






for





i


=
1


,





,
L




[

Formula





133

]







(S205: Key Element Generation Step)


Using the processing device, the key element generation unit 144 generates an element k*0 of the decryption key skS, as indicated in Formula 134.










k
0
*

:=


(


-

s
0


,


0

u
0





u
0



,
1
,



η


0




w
0



,


0

z
0





z
0



,

)


0
*






[

Formula





134

]







As described above, for the basis B and the basis B* indicated in Formula 113, Formula 114 is established. Thus, Formula 134 means that −s0 is set as the coefficient of a basis vector b*0,1 of the basis B*0, 0 is set as the coefficient of basis vectors b*0,1+1, . . . , b*0,1+u, 1 is set as the coefficient of a basis vector b*0,1+u0+1, η0,1, . . . , η0,w0 are respectively set as the coefficient of basis vectors b*0,1+u0+1+1, . . . , b0,1+u0+1+w0, and 0 is set as the coefficient of basis vectors b*0,1+u0+1+w0+1, . . . , b*0,1+u0+1+w0+z0, where u0, w0, and z0 respectively denote u0, w0, and z0.


Using the processing device, the key element generation unit 144 also generates an element k*i of the decryption key skS for each integer i=1, . . . , L, as indicated in Formula 135.











for





i

=
1

,





,
L
,






if






ρ


(
i
)



=

(

t
,


v


i


)


,






k
i
*

:=


(






u
i



(

t
,

-
1

,

)


,



s
i




e


1


+


θ
i




v


i












2
+
n











0
u

,



u







η


i

,



w





0
z



z



)


*



,






if






ρ


(
i
)



=



(

t
,


v


i


)



,






k
i
*

:=


(






u
i



(

t
,

-
1

,

)


,


s
i




v


i


,









2
+
n











0
u

,



u







η


i

,



w





0
z



z



)


*







[

Formula





135

]







That is, like Formula 134, the meaning of Formula 135 is as explained below. When ρ(i) is a positive set (t, v{right arrow over ( )}i), pit is set as the coefficient of a basis vector b*1 of the basis B*, −μi is set as the coefficient of a basis vector b*2, siivi,1 is set as the coefficient of a basis vector b*2+1, θivi,2, . . . , θivi,n are respectively set as the coefficient of basis vectors b*2+2, . . . , b*2+n, 0 is set as the coefficient of basis vectors b*2+n+1, . . . , b*2+n+u, ηi,1, . . . , ηi,w are respectively set as the coefficient of basis vectors b*2+n+u+1, . . . , b*2+n+u+w, and 0 is set as the coefficient of basis vectors b*2+n+u+w+1, . . . , b*2+n+u+w+z.


On the other hand, when ρ(i) is a negative set custom character(t, v{right arrow over ( )}i), it is set as the coefficient of the basis vector b*1 of the basis B*, −μi is set as the coefficient of the basis vector b*2, sivi,1, . . . , sivi,n are respectively set as the coefficient of the basis vectors b*2+1, . . . , b*2+n, 0 is set as the coefficient of the basis vectors b*2+n+1, . . . , b*2+n+u, ηi,1, . . . , ηi,w are respectively set as the coefficient of the basis vectors b*2+n+u+1, . . . , b*2+n+u+w, and 0 is set as the coefficient of the basis vectors b*2+n+u+w+1, . . . , b*2+n+u+w+z.


(S206: Key Distribution Step)


Using the communication device and via the network, for example, the key distribution unit 150 distributes the decryption key skS having, as elements, the access structure S inputted in (S201) and k*0, k*1, . . . , and k*L generated in (S205) to the decryption device 300 in secrecy. As a matter of course, the decryption key skS may be distributed to the decryption device 300 by another method.


In brief, in (S201) through (S205), the key generation device 100 executes the KeyGen algorithm indicated in Formula 136, and thus generates the decryption key skS. In (S206), the key generation device 100 distributes the generated decryption key skS to the decryption device 300.











KeyGen


(

pk
,
sk
,

:=

(

M
,
ρ

)



)




:










f





U



q
r


,






s
0

:=


1


·


f


T



,



s


T

:=



(


s
1

,





,

s
L


)

T

:=

M
·


f


T




,







η


0




U



q

w
0



,






k
0
*

:=


(


-

s
0


,


0

u
0





u
0



,
1
,



η


0




w
0



,


0

z
0





z
0



,

)


0
*



,






for





i

=
1

,





,
L
,

μ
i

,


θ
i




U



q


,



η


i




U



q
w


,






if






ρ


(
i
)



=

(

t
,


v


i


)


,






k
i
*

:=


(






u
i



(

t
,

-
1

,

)


,



s
i




e


1


+


θ
i




v


i












2
+
n











0
u

,



u







η


i

,



w





0
z



z



)


*



,






if





ρ


(
i
)


=



(

t
,


v


i


)



,






k
i
*

:=


(






u
i



(

t
,

-
1

,

)


,


s
i




v


i











2
+
n











0
u

,



u







η


i

,



w





0
z



z



)


*



,






return






sk


:=


(

,

k
0
*

,

k
1
*

,





,

k
L
*


)

.







[

Formula





136

]







The function and operation of the encryption device 200 will be described.


The encryption device 200 includes a public parameter acquisition unit 210, an information input unit 220, a cipher data generation unit 230, and a data transmission unit 240. The cipher data generation unit 230 includes a random number generation unit 231 and a cipher element generation unit 232.


With reference to FIG. 11, the process of the Enc algorithm will be described.


(S301: Public Parameter Acquisition Step)


Using the communication device and via the network, for example, the public parameter acquisition unit 210 obtains the public parameter pk generated by the key generation device 100.


(S302: Information Input Step)


Using the input device, the information input unit 220 takes as input a message m to be transmitted to the decryption device 300. Using the input device, the information input unit 220 also takes as input an attribute set Γ:={(t, x{right arrow over ( )}t:=(xt,1, . . . , xt,nεFqn))|1≦t≦d}. Note that t may be at least some integers from 1 to d, instead of being all of integers from 1 to d. Note that information on the attributes of the user capable of decryption is set in the attribute set Γ, for example.


(S303: Random Number Generation Step)


Using the processing device, the random number generation unit 231 generates random numbers, as indicated in Formula 137.









ω
,

ζ



U



q


,



φ


0

:=


(


φ

0
,
1


,





,

φ

0
,

z
0




)




U



q

z
0




,






σ
t




U



q


,







φ


0

:=



(


φ

t
,
1


,





,

φ

t
,
z



)




U




q
z






for






(

t
,


x


t


)




Γ






[

Formula





137

]







(S304: Cipher Element Generation Step)


Using the processing device, the cipher element generation unit 232 generates an element c0 of a ciphertext ctΓ, as indicated in Formula 138.










c
0

:=


(

ω
,




0

u
0


,




u
0




ζ

,




0

w
0


,




w
0







φ


0




z
0





)


0






[

Formula





138

]







Using the processing device, the cipher element generation unit 232 also generates an element ct of the ciphertext ctΓ for each integer t included in the attribute information Γ, as indicated in Formula 139.










c
t

:=


(





σ
t



(

1
,
t

)


,

ω







x


t


,




2
+
n







0
u

,




u
0







0
w

,




w
0







φ


t




z
0




)






[

Formula





139

]







Using the processing device, the cipher element generation unit 232 also generates an element cd+1 of the ciphertext ctΓ, as indicated in Formula 140.

cd+1:=gTζm  [Formula 140]


(S305: Data Transmission Step)


Using the communication device and via the network, for example, the data transmission unit 240 transmits the ciphertext ctΓ having, as elements, the attribute set Γ inputted in (S302) and c0, ct, and cd+1 generated in (S304) to the decryption device 300. As a matter of course, the ciphertext ctΓ may be transmitted to the decryption device 300 by another method.


In brief, in (S301) through (S304), the encryption device 200 executes the Enc algorithm indicated in Formula 141, and thus generates the ciphertext ctΓ. In (S305), the encryption device 200 transmits the generated ciphertext ctΓ to the decryption device 300.











[

Formula





141

]








Enc
(

pk
,
m
,

Γ
:=

{

(

t
,


x
t

:=



(


x

t
,
1


,





,

x

t
,
n



)




q
n


\


{
0
}





1

t

d




)

}



)



:







ω
,

ζ



U



q


,



φ


0




U



q

z
0



,






c
0

:=


(

ω
,




0

u
0


,




u
0




ζ

,




0

w
0


,




w
0







φ


0




z
0





)


0



,


c

d
+
1


:=


g
T
ζ


m


,






for






(

t
,


x


t


)



Γ

,


σ
t




U



q


,



φ


t




U



q
z


,






c
t

:=


(





σ
t



(

1
,
t

)


,

ω







x


t


,




2
+
n







0
u

,




u
0







0
w

,




w
0







φ


t




z
0




)



,






return






ct
Γ


:=


(

Γ
,

c
0

,


{

c
t

}



(

t
,


x


t


)


Γ


,

c

d
+
1



)

.






The function and operation of the decryption device 300 will be described.


The decryption device 300 includes a decryption key acquisition unit 310, a data receiving unit 320, a span program computation unit 330, a complementary coefficient computation unit 340, a pairing operation unit 350, and a message computation unit 360.


With reference to FIG. 12, the process of the Dec algorithm will be described.


(S401: Decryption Key Acquisition Step)


Using the communication device and via the network, for example, the decryption key acquisition unit 310 obtains the decryption key skS:=(S, k*0, k*1, . . . , k*L) distributed by the key generation device 100. The decryption key acquisition unit 310 also obtains the public parameter pk generated by the key generation device 100.


(S402: Data Reception Step)


Using the communication device and via the network, for example, the data receiving unit 320 receives the ciphertext ctΓ transmitted by the encryption device 200.


(S403: Span Program Computation Step)


Using the processing device, the span program computation unit 330 checks whether or not the access structure S included in the decryption key skS obtained in (S401) accepts Γ included in the ciphertext ctΓ received in (S402). The method for checking whether or not the access structure S accepts Γ is the same as that described in “5. Concept for implementing functional encryption in Embodiment 1”.


If the access structure S accepts Γ (accept in S403), the span program computation unit 330 advances the process to (S404). If the access structure S rejects Γ (reject in S403), the span program computation unit 330 determines that the ciphertext ctΓ cannot be decrypted with the decryption key skS, and ends the process.


(S404: Complementary Coefficient Computation Step)


Using the processing device, the complementary coefficient computation unit 340 computes I and a constant (complementary coefficient) {αi}iε1 such that Formula 142 is satisfied.

{right arrow over (1)}=ΣiεIαiMi, where Mi is the i-th row of M,
and I{iε{1, . . . ,L}|[ρ(i)=(t,{right arrow over (v)}i)custom character(t,{right arrow over (x)}t)εΓcustom character{right arrow over (v)}i·{right arrow over (x)}t=0]
custom character[ρ(i)=custom character(t,{right arrow over (v)}i)custom character(t,{right arrow over (x)}t)εΓcustom character{right arrow over (v)}i·{right arrow over (x)}t≠0]}  [Formula 142]


(S405: Pairing Operation Step)


Using the processing device, the pairing operation unit 350 computes Formula 143, and thus generates a session key K=gTζ.









K
:=


e


(


c
0

,

k
0
*


)








i


I


ρ


(
i
)




=

(

t
,


v


i


)













e


(


c
t

,

k
i
*


)




α
i







i


I


ρ


(
i
)




=



(

t
,


v


i


)














e


(


c
t

,

k
i
*


)





α
i

/

(



v


i

·


x


t


)











[

Formula





143

]







As indicated in Formula 144, the key K=gTζ can be obtained by computing Formula 143.











e


(


c
0

,

k
0
*


)


·





i


I


ρ


(
i
)




=

(

t
,


v


i


)













e


(


c
t

,

k
i
*


)





α
i

·





i


I


ρ


(
i
)




=



(

t
,


v


i


)














e


(


c
t

,

k
i
*


)





α
i

/

(



v


i

·


x


i


)








=



g
T



-
ω







s
0


+
ζ








i


I


ρ


(
i
)




=

(

t
,


v


i


)













g
T

ω






α
i



s
i









i


I


ρ


(
i
)




=



(

t
,


v


i


)













g
T

ω






α
i




s
i



(



v


i

·


x


i


)




(



v


i

·


x


i


)







=


g
T


ω


(


-

s
0


+




i

I












α
i



s
i




)


+
ζ


+


g
T
ζ

.







[

Formula





144

]







(S406: Message Computation Step)


Using the processing device, the message computation unit 360 computes m′=cd+1/K, and thus generates a message m′ (=m). Note that cd+1 is gTζm, as indicated in Formula 142, and that K is gTζ. Hence, the message m can be obtained by computing m′=cd+1/K.


In brief, in (S401) through (S406), the decryption device 300 executes the Dec algorithm indicated in Formula 145, and thus generates the message m′ (=m).













Dec


(

pk
,


sk

:=

(

,

k
1
*

,





,

k
L
*


)


,


ct
Γ

:=

(

Γ
,


{

c
t

}




x


t


Γ


,

c

d
+
1



)



)




:













If






:=



(

M
,
ρ

)






accepts





Γ

:=

{

(

t
,


x


t


)

}




,









then





compute





I





and







{

α
i

}


i

I







such





that














1


=




i

I












α
i



M
i




,








where













M
i






is





the





i


-


th





row





of





M

,








and







I


{

i



{

1
,





,
L

}







[








ρ


(
i
)


=




(

t
,


v


i


)



(

t
,


x


t


)





Γ



v


i


·


x


t



=
0


]



[




ρ


(
i
)


=





(

t
,


v


i


)



(

t
,


x


t


)






Γ



v


i


·


x


t



0




]

}







K

:=


e


(


c
0

,

k
0
*


)








i


I


ρ


(
i
)




=

(

t
,


v


i


)













e


(


c
t

,

k
i
*


)




α
i







i


I


ρ


(
i
)




=

(

t
,


v


i


)













e


(


c
t

,

k
i
*


)





α
i

/

(



v


i

·


x


t


)








,










return






m



:=


c

d
+
1


/

K
.















[

Formula





145

]







As described above, in the cryptographic system 10 according to Embodiment 2, μit and −μi are respectively set as the coefficient of the basis vectors b*1 and b*2 for the element k*i of the decryption key skS. In the cryptographic system 10, σt and σtt are respectively set as the coefficient of the basis vectors b1 and b2 for the element ct of the ciphertext ctΓ.


Because of these arrangements, when a pairing operation is performed on the element k*i and the element ct for the corresponding index t, an inner-product of 0 is obtained for portions constituted by the basis vectors b*1 and b*2 and the basis vectors b1 and b2, which are thus canceled out. That is, when a pairing operation is performed on the element k*i and the element ct for the corresponding index t, the index parts that are set as the coefficients of the basis vectors (portions constituted by the basis vectors b*1 and b*2 and the basis vectors b1 and b2) are canceled out, and a result of the pairing operation for the remaining portions can be obtained.


In the cryptographic system 10 according to Embodiment 2, the index parts are provided, so that the bases that are used for every attribute category can be constructed as the common bases (basis B and basis B*). As a result, only the basis B and the basis B* need to be included in a public parameter, eliminating the need for reissuing the public parameter when an attribute category is to be added at a later stage.


In the cryptographic system 10 according to Embodiment 2, the public parameter and the master secret key are of smaller sizes compared with those in the functional encryption scheme described in Non-Patent Literature 29. Therefore, calculations using the public parameter and the master secret key can be performed efficiently.


For the index parts, it is required that 0 be obtained as a result of an inner-product operation of the index parts. Therefore, although the 2-dimensional index parts, namely the basis vectors b*1 and b*2 and the basis vectors b1 and b2, are employed in the above description, the index parts are not limited to 2-dimensional and may be 3-dimensional or higher-dimensional. The values assigned to the index parts are not limited to those described above, and a different assignment arrangement may be employed.


The functional encryption scheme has been described above. As indicated in Formula 146 through Formula 149, however, the functional encryption scheme described above can be modified into an attribute-based encryption scheme. Note that N0 is 1+1+1+1+1=5 and N1 is 2+2+8+2+2=16 in Formula 146 through Formula 149. That is, u0=1, w0=1, z0=1, n=2, u=8, w=2, and z=2. Even in this case, security can be proven.











[

Formula





146

]












Setup






(

1
λ

)



:















(

param
,

(


0

,

0
*


)

,

(

,

*


)


)




R




ob



(

1
λ

)



,


/

*
N


=


16
*

/






^

0



:=

(


b

0
,
1


,

b

0
,
3


,

b

0
,
5



)



,


^

:=

(


b
1

,





,

b
4

,

b
15

,

b
16


)


,







^

0
*

:=

(


b

0
,
1


,

b

0
,
3


,

b

0
,
4



)


,



^

*

:=

(


b
1
*

,





,

b

4
*


,

b
13
*

,

b
14
*


)


,










return





pk

:=

(


1
λ

,
param
,


^

0

,

^


)


,

sk
:=



(



^

0
*

,


^

*


)

.









ob




(

1
λ

)



:











:=


(

q
,
,

T

,
g
,
e

)




R




bpg



(

1
λ

)




,









ψ



U



q
x


,










N
0

:=
5

,


N
1

:=
16

,










for





t

=
0

,
1
,





:=


(

q
,

t

,

T

,

t

,
e

)

:=


dpvs



(


1
λ

,

N
t

,

)




,










X
t

:=



(

χ

t
,
i
,
j


)


i
,

j
=
1

,





,

N
t






U



GL


(


N
t

,

q


)




,










X
t
*

:=



(

ϑ

t
,
i
,
j


)


i
,

j
=
1

,





,

N
t



:=

ψ
·


(

X
t
T

)


-
1





,








hereafter
,


χ



t
,
i













and







ϑ



t
,
i







denote





the





i


-


th





rows





of






X
t



















and






X
t
*






for





i

=
1

,





,

N
t

,
respectively
,










b

t
,
i


:=



(


χ



t
,
i


)


t


=





j
=
1


N
t









χ

t
,
i
,
j




a

t
,
j







for





i


=
1



,





,

N
t

,










t

:=

(


b

t
,
1


,





,

b

t
,

N
t




)


,










b

t
,
i

*

:=



(


ϑ



t
,
i


)


t


=





j
=
1


N
t









ϑ

t
,
i
,
j




a

t
,
j







for





i


=
1



,





,

N
t

,










t
*

:=

(


b

t
,
1

*

,





,

b

t
,

N
t


*


)


,










g
T

:=


e


(

g
,
g

)



ψ


,

param
:=

(



{
}



t
=
0

,
1


,

g
T


)


,










return


(

param
,
,

*


)


.









[

Formula





147

]















KeyGen


(

pk
,
sk
,

:=

(

M
,
ρ

)



)




:















f





U



q
r


,


s
0

:=


1


·


f


T



,



s


T

:=



(


s
1

,





,

s
L


)

T

:=

M
·


f


T




,










η
0




U



q


,


k
0
*

:=


(


-

s
0


,
0
,
1
,

η
0

,
0

)


0
*



,


for





i

=
1

,





,
L
,









μ
i

,

θ
i

,

η

i
,
1


,


η

i
,
2





U



q


,










if






ρ


(
i
)



=

(

t
,

v
i


)


,






k
i
*

:=



(






u
i



(

t
,

-
1

,

)


,


s
i

+


θ
i



v
i


-

θ
i










4










0
8

,



8






η

i
,
1


,

η

i
,
2


,



2





0
2



2



)






*



,










if






ρ


(
i
)



=



(

t
,

v
i


)



,










k
i
*

:=


(






u
i



(

t
,

-
1

,

)


,


s
i



(


v
i

,

-
1


)


,








4










0
8

,



8






η

i
,
1


,

η

i
,
2


,



2





0
2



2



)


*



,










return






sk


:=


(

,

k
0
*

,

k
1
*

,





,

k
L
*


)

.









[

Formula





148

]
















Enc


(

pk
,
m
,

Γ
:=

{


(

t
,

x
t


)



1

t

d


}



)




:













ω
,
ζ
,


φ
0




U



q


,


c
0

:=


(

ω
,
0
,
ζ
,
0
,

φ
0


)


0



,


c

d
+
1


:=


g
T
ζ


m


,










for


(

t
,

x
t


)



Γ

,

σ
t

,

φ

t
,
1


,


φ

t
,
2





U



q


,










c
t

=


(





σ
i



(

1
,
t

)


,

ω


(

1
,

x
t


)


,



4






0
8

,



8






0
2

,



2






φ

t
,
1


,

φ

t
,
2





2



)



,










return






ct
Γ


:=


(

Γ
,

c
0

,


{

c
t

}



(

t
,

x
t


)


Γ


,

c

d
+
1



)

.









[

Formula





149

]
















Dec


(

pk
,


sk

:=

(

,

k
1
*

,





,

k
L
*


)


,










ct
Γ

:=

(





Γ
,


{

c
t

}



x
t


Γ


,

c

d
+
1



)



)




:















If






:=



(

M
,
ρ

)






accepts





Γ

:=

{

(

t
,

x
t


)

}



,










then





compute





I





and







{

α
i

}


i

I







such





that






1



=




i

I












α
i



M
i




,









where






M
i






is





the





i


-


th





row





of





M

,
and







I


{


i



{

1
,





,
L

}








[






ρ


(
i
)


=



(

t
,

v
i


)



(

t
,

x
t


)



Γ


]



[






ρ


(
i
)


=





(

t
,

v
i


)



(

t
,

x
t


)





Γ


v
i




x
t





]



}



,





K
:=


e


(


c
0

,

k
0
*


)


·





i


I


ρ


(
i
)




=

(

t
,

v
i


)













e


(


c
t

,

k
i
*


)




α
i







i


I


ρ


(
i
)




=



(

t
,

v
i


)














e


(


c
t

,

k
i
*


)





α
i

/

(


v
i

·

x
i


)








,










return






m



:=


c

d
+
1


/

K
.









Embodiment 3

Like Embodiment 2, this embodiment describes a narrowly-defined cryptographic processing scheme. In particular, this embodiment describes a ciphertext-policy functional encryption (CP-FE) scheme.


Note that cipher-text policy means that a policy, namely an access structure, is embedded in a ciphertext.


First, the construction of the CP-FE scheme will be described.


Second, the configuration of a cryptographic system 10 that implements the CP-FE scheme will be described.


Third, the CP-FE scheme will be described in detail.


<1. Construction of CP-FE Scheme>


The CP-FE scheme consists of four algorithms: Setup, KeyGen, Enc, and Dec.


(Setup)


A Setup algorithm is a probabilistic algorithm that takes as input a security parameter λ, and outputs a public parameter pk and a master key sk.


(KeyGen)


A KeyGen algorithm is a probabilistic algorithm that takes as input an attribute set Γ:={(t, x{right arrow over ( )}t)|x{right arrow over ( )}tεFqn, 1≦t≦d}, the public parameter pk, and the master key sk, and outputs a decryption key skΓ.


(Enc)


An Enc algorithm is a probabilistic algorithm that takes as input a message m, an access structure S:=(M, ρ), and the public parameter pk, and outputs a ciphertext ctS.


(Dec)


A Dec algorithm is an algorithm that takes as input the ciphertext ctS encrypted under the access structure S, the decryption key skΓ for the attribute set Γ, and the public parameter pk, and outputs the message m or a distinguished symbol ⊥.


<2. Configuration of Cryptographic System 10 that Implements CP-FE Scheme>



FIG. 13 is a configuration diagram of the cryptographic system 10 that implements the CP-FE scheme according to Embodiment 3.


The cryptographic system 10 includes a key generation device 100, an encryption device 200, and a decryption device 300.


The key generation device 100 executes the Setup algorithm taking as input a security parameter λ, and thus generates a public parameter pk and a master key sk. Then, the key generation device 100 publishes the generated public parameter pk. The key generation device 100 also executes the KeyGen algorithm taking as input an attribute set Γ, and thus generates a decryption key skΓ, and distributes the decryption key skΓ to the decryption device 300 in secrecy.


The encryption device 200 executes the Enc algorithm taking as input a message m, an access structure S, and the public parameter pk, and thus generates a ciphertext ctS. The encryption device 200 transmits the generated ciphertext ctS to the decryption device 300.


The decryption device 300 executes the Dec algorithm taking as input the public parameter pk, the decryption key skS, and the ciphertext ctS, and outputs the message m or a distinguished symbol ⊥.


<3. CP-FE Scheme in Detail>


With reference to FIGS. 14 to 19, the CP-FE scheme will be described, and the function and operation of the cryptographic system 10 that implements the CP-FE scheme will be described.



FIG. 14 is a configuration diagram of the key generation device 100 according to Embodiment 3. FIG. 15 is a configuration diagram of the encryption device 200 according to Embodiment 3. FIG. 16 is a configuration diagram of the decryption device 300 according to Embodiment 3.



FIG. 17 is a flowchart illustrating the operation of the key generation device 100 and illustrating the process of the KeyGen algorithm. FIG. 18 is a flowchart illustrating the operation of the encryption device 200 and illustrating the process of the Enc algorithm. FIG. 19 is a flowchart illustrating the operation of the decryption device 300 and illustrating the process of the Dec algorithm.


In the following description, it is assumed that xt,1:=1.


The process of the Setup algorithm is the same as the process described in Embodiment 2, and thus will not be described.


The function and operation of the key generation device 100 will be described.


The key generation device 100 includes a master key generation unit 110, a master key storage unit 120, an information input unit 130, a decryption key generation unit 140, and a key distribution unit 150. The decryption key generation unit 140 includes a random number generation unit 143 and a key element generation unit 144.


With reference to FIG. 17, the process of the KeyGen algorithm will be described.


(S501: Information Input Step)


Using the input device, the information input unit 130 takes as input an attribute set Γ:={(t, x{right arrow over ( )}t:=(xt,1, . . . , xt,nεFqn)) 1≦t≦d}. Note that attribute information of the user of a decryption key skΓ is set in the attribute set Γ, for example.


(S502: Random Number Generation Step)


Using the processing device, the random number generation unit 143 generates random numbers, as indicated in Formula 150.















ω



U



q


,



φ


0

:=


(


φ

0
,
1


,





,

φ

0
,

w
0




)




U



q

w
0




,






σ
t




U



q


,



φ


t

:=



(


φ

t
,
1


,





,

φ

t
,
w



)




U




q
w






for






(

t
,


x


t


)




Γ







[

Formula





150

]







(S503: Key Element Generation Step)


Using the processing device, the key element generation unit 144 generates an element k*0 of the decryption key skΓ, as indicated in Formula 151.










k
0
*

:=


(

ω
,




0

u
0


,




u
0




1

,





φ


0

,




w
0







0

z
0


,




z
0





)


𝔹
0
*






[

Formula





151

]







Using the processing device, the key element generation unit 144 also generates an element k*t of the decryption key skΓ for each integer t included in the attribute set Γ, as indicated in Formula 152.










k
t
*

:=


(





σ
t



(

1
,
t

)


,

ω








x



t


,




2
+
n











0
u

,



u







φ


t

,



w





0
z



z



)


𝔹
*






[

Formula





152

]







(S504: Key Distribution Step)


Using the communication device and via the network, for example, the key distribution unit 150 distributes the decryption key skΓ having, as elements, the attribute set Γ inputted in (S501) and k*0 and k*t generated in (S503) to the decryption device 300 in secrecy. As a matter of course, the decryption key skΓ may be distributed to the decryption device 300 by another method.


In brief, in (S501) through (S503), the key generation device 100 executes the KeyGen algorithm indicated in Formula 153, and thus generates the decryption key skΓ. In (S504), the key generation device 100 distributes the generated decryption key skΓ to the decryption device 300.











KeyGen


(

pk
,
sk
,

Γ
:=

{


(

t
,



x


t

:=


(


x

1
,
t


,





,

x

t
,
n



)




𝔽
q
n


\


{

0


}





)

|

1

t

d


}



)




:













ω



U



𝔽
q


,



φ


0




U



𝔽
q

w
0



,










k
0
*

:=


(

ω
,




0

u
0


,




u
0




1

,





φ


0

,




w
0







0

z
0


,




z
0





)


𝔹
0
*



,










for






(

t
,


x


t


)



Γ

,


σ
t




U



𝔽
q


,



φ


t




U



𝔽
q
w


,










k
t
*

:=


(





σ
t



(

1
,
t

)


,

ω








x



t


,




2
+
n







0
u

,



u







φ


t

,



w





0
z



z



)


𝔹
*



,










return






sk
Γ


:=


(

Γ
,

k
0
*

,


{

k
t
*

}



(

t
,


x


t


)


Γ



)

.







[

Formula





153

]







The function and operation of the encryption device 200 will be described.


The encryption device 200 includes a public parameter acquisition unit 210, an information input unit 220, a cipher data generation unit 230, and a data transmission unit 240. The cipher data generation unit 230 includes a random number generation unit 231, a cipher element generation unit 232, an f vector generation unit 233, and an s vector generation unit 234.


With reference to FIG. 18, the process of the Enc algorithm will be described.


(S601: Public Parameter Acquisition Step)


Using the communication device and via the network, for example, the public parameter acquisition unit 210 obtains the public parameter pk generated by the key generation device 100.


(S602: Information Input Step)


Using the input device, the information input unit 220 takes as input an access structure S:=(M, ρ). Note that the access structure S is to be set according to the conditions of a system to be implemented. Note also that attribute information of the user capable of decryption is set in ρ of the access structure S, for example.


Using the input device, the information input unit 220 also takes as input a message m to be transmitted to the decryption device 300.


(S603: f Vector Generation Step)


Using the processing device, the f vector generation unit 233 randomly generates a vector f{right arrow over ( )} having r pieces of elements, as indicated in Formula 154.










f





U



𝔽
q
r





[

Formula





154

]







(S604: s Vector Generation Step)


Using the processing device and based on an (L rows×r columns) matrix M included in the access structure S inputted in (S602) and the vector f{right arrow over ( )} generated in (S603), the s vector generation unit 234 generates a vector s{right arrow over ( )}T:=(s1, . . . , sL)T, as indicated in Formula 155.

{right arrow over (s)}T:=(s1, . . . ,sL)T:=M·{right arrow over (f)}T  [Formula 155]


Using the processing device and based on the vector f{right arrow over ( )} generated in (S603), the s vector generation unit 234 also generates a value s0, as indicated in Formula 156.

s0:={right arrow over (1)}·{right arrow over (f)}T  [Formula 156]


(S605: Random Number Generation Step)


Using the processing device, the random number generation unit 231 generates random numbers, as indicated in Formula 157.











ζ



U



𝔽
q


,



η


0

:=


(


η

0
,
1


,





,

η

0
,

z
0




)




U



𝔽
q

z
0




,






for





i

=
1

,





,
L









if






ρ


(
i
)



=

(

t
,


v


i


)


,

μ
i

,


θ
i




U



𝔽
q


,







η


i

:=


(


η

i
,
1


,





,

η

i
,
z



)




U



𝔽
q
z



,






if






ρ


(
i
)



=



(

t
,


v


i


)



,

μ
i

,



U



𝔽
q


,







η


i

:=


(


η

i
,
1


,





,

η

i
,
z



)




U



𝔽
q
z








[

Formula





157

]







(S606: Cipher Element Generation Step)


Using the processing device, the cipher element generation unit 232 generates an element c0 of cipher data c, as indicated in Formula 158.










c
0

:=


(


-

s
0


,




0

u
0


,




u
0




ζ

,




0

w
0


,




w
0







η


0




z
0





)


𝔹
0






[

Formula





158

]







Using the processing device, the cipher element generation unit 232 also generates an element ci of the cipher data c for each integer i=1, . . . , L, as indicated in Formula 159.











for





i

=
1

,





,
L
,






if






ρ


(
i
)



=

(

t
,


v


i


)


,






c
i

:=


(





μ
i



(

t
,

-
1


)


,



s
i




e


1


+


θ
i




v


i



,




2
+
n







0
u

,



u






0
w

,



w






η


i



z



)

𝔹


,






if






ρ


(
i
)



=



(

t
,


v


i


)



,






c
i

:=


(





μ
i



(

t
,

-
1


)


,


s
i




v


i


,




2
+
n







0
u

,



u






0
w

,



w






η


i



z



)

𝔹






[

Formula





159

]







Using the processing device, the cipher element generation unit 232 also generates an element cd+1 of the cipher data c, as indicated in Formula 160.

cd+1:=gTζm  [Formula 160]


(S607: Data Transmission Step)


Using the communication device and via the network, for example, the data transmission unit 240 transmits a ciphertext ctS having, as elements, the access structure S inputted in (S602) and c0, c1, . . . , cL, and cd+1 generated in (S606) to the decryption device 300. As a matter of course, the ciphertext ctS may be transmitted to the decryption device 300 by another method.


In brief, in (S601) through (S606), the encryption device 200 executes the Enc algorithm indicated in Formula 161, and thus generates the ciphertext ctS. In (S607), the encryption device 200 transmits the generated ciphertext ctS to the decryption device 300.











Enc


(

pk
,
m
,

𝕊
:=

(

M
,
ρ

)



)




:









f



U



𝔽
q
r


,






s
0

:=


1


·


f


T



,



s


T

:=



(


s
1

,





,

s
L


)

T

:=

M
·


f


T




,





ζ



U



𝔽
q


,



η


0




U



𝔽
q

z
0



,






c
0

:=


(


-

s
0


,




0

u
0


,




u
0




ζ

,




0

w
0


,




w
0








η


0

,




z
0





)


𝔹
0



,






for





i

-
1

,





,
L
,






if






ρ


(
i
)



=

(

t
,


v


i


)


,

μ
i

,


θ
i




U



𝔽
q


,



η


i




U



𝔽
q
z


,






c
i

:=


(





μ
i



(

t
,

-
1


)


,



s
i




e


1


+


θ
i




v


i



,




2
+
n







0
u

,



u






0
w

,



w






η


i



z



)

𝔹


,






if






ρ


(
i
)



=



(

t
,


v


i


)



,


μ
i




U



𝔽
q


,



η


i




U



𝔽
q
z


,






c
i

:=


(





μ
i



(

t
,

-
1


)


,


s
i




v


1


,




2
+
n







0
u

,



u






0
w

,



w






η


i



z



)

𝔹


,






c

d
+
1


:=


g
T
ζ


m


,






return






ct
𝕊


:=


(

𝕊
,

c
0

,

c
1

,





,

c
L

,

c

d
+
1



)

.







[

Formula





161

]







The function and operation of the decryption device 300 will be described.


The decryption device 300 includes a decryption key acquisition unit 310, a data receiving unit 320, a span program computation unit 330, a complementary coefficient computation unit 340, a pairing operation unit 350, and a message computation unit 360.


With reference to FIG. 15, the process of the Dec algorithm will be described.


(S701: Decryption Key Acquisition Step)


Using the communication device and via the network, for example, the decryption key acquisition unit 310 obtains the decryption key skΓ distributed by the key generation device 100. The decryption key acquisition unit 310 also obtains the public parameter pk generated by the key generation device 100.


(S702: Data Reception Step)


Using the communication device and via the network, for example, the data receiving unit 320 receives the ciphertext ctS transmitted by the encryption device 200.


(S703: Span Program Computation Step)


Using the processing device, the span program computation unit 330 checks whether or not the access structure S included in the ciphertext ctS obtained in (S702) accepts Γ included in the decryption key skΓ received in (S701). The method for checking whether or not the access structure S accepts Γ is the same as that described in “5. Concept for implementing functional encryption in Embodiment 1”.


If the access structure S accepts Γ (accept in S703), the span program computation unit 330 advances the process to (S704). If the access structure S rejects Γ (reject in S703), the span program computation unit 330 determines that the ciphertext ctS cannot be decrypted with the decryption key skΓ and ends the process.


(S704) through (S706) are substantially the same as (S404) through (S406) in Embodiment 2 shown in FIG. 12.


In brief, in (S701) through (S706), the encryption device 200 executes the Dec algorithm indicated in Formula 162, and thus generates the message m′ (=m).











Dec


(

pk
,


sk
Γ

:=

(

Γ
,

k
0
*

,


{

k
t
*

}



(

t
,


x


t


)


Γ



)


,


ct
𝕊

:=

(

𝕊
,

c
0

,

c
1

,





,

c
L

,

c

d
+
1



)



)




:














If





𝕊

:=



(

M
,
ρ

)






accepts





Γ

:=

{

(

t
,


x


t


)

}



,









then





compute





I





and







{

α
i

}


i

I







such





that










1


=




i

I





α
i



M
i




,

where






M
i






is





the






i-th






row





of





M

,
and








I



{


i


{

1
,





,
L

}


|






[






ρ


(
i
)


=




(

t
,


v


i


)



(

t
,


x


i


)





Γ



v


i


·


x


i



=
0


]



[






ρ


(
i
)


=





(

t
,


v


i


)



(

t
,


x


i


)









v


i

·


x


i




0




]



}

.




K


:=



e


(


c
0

,

k
0
*


)








i


I


ρ


(
i
)




=

(

t
,


v


i


)










e


(


c
i

,

k
t
*


)




α
i







i


I


ρ


(
i
)




=



(

t
,


v


i


)







e


(


c
i

,

k
t
*


)





α
i

/

(



v


i

-


x


t


)











return






m







:=


c

d
+
1


/

K
.








[

Formula





162

]







As described above, as in the cryptographic system 10 according to Embodiment 2, in the cryptographic system 10 according to Embodiment 3, the index parts are provided, so that the bases that are used for every attribute category can be constructed as the common bases (basis B and basis B*). As a result, only the basis B and the basis B* need to be included in a public parameter, eliminating the need for reissuing the public parameter when an attribute category is to be added at a later stage.


As in Embodiment 2, for the index parts, it is required that 0 be obtained as a result of an inner-product operation of the index parts. Therefore, although the 2-dimensional index parts, namely the basis vectors b*1 and b*2 and the basis vectors b1 and b2, are employed in the above description, the index parts are not limited to 2-dimensional and may be 3-dimensional or higher-dimensional. The values assigned to the index parts are not limited to those described above, and a different assignment arrangement may be employed.


The functional encryption scheme has been described above. As indicated in Formula 163 through Formula 167, however, the functional encryption scheme can be modified into an attribute-based encryption scheme. Note that N0 is 1+1+1+1+1=5 and N1 is 2+2+8+2+2=16 in Formula 163 through Formula 167. That is, u0=1, w0=1, z0=1, n=2, u=8, w=2, and z=2. Even in this case, security can be proven.











Setup


(

1
λ

)


:






(

param
,

(


𝔹
0

,

𝔹
0
*


)

,

(

𝔹
,

𝔹
*


)


)




R




𝒢
ob



(

1
λ

)




,










/

*
N


=


16
*

/










𝔹
^

0



:=

(


b

0
,
1


,

b

0
,
3


,

b

0
,
5



)



,










𝔹
^

:=

(


b
1

,





,

b
4

,

b
15

,

b
16


)


,











𝔹
^

0
*

:=

(


b

0
,
1

*

,

b

0
,
3

*

,

b

0
,
4

*


)


,











𝔹
^

*

:=

(


b
1
*

,





,

b
4
*

,

b
13
*

,

b
14
*


)


,









pk
:=

(


1
λ

,
param
,


𝔹
^

0

,

𝔹
^


)


,

sk
:=

(



𝔹
^

0
*

,


𝔹
^

*


)


,









return





pk

,

sk
.





[

Formula





163

]










𝒢
ob



(

1
λ

)


:





param
𝔾


:=


(

q
,
𝔾
,

𝔾
T

,
g
,
e

)




R




𝒢
bpg



(

1
λ

)




,









ψ



U



𝔽
q
x


,










N
0

:=
5

,


N
1

:=
16

,










for





t

=
0

,
1
,














param

𝕍
t


:=


(

q
,

𝕍
t

,

𝔾
T

,

𝔸
t

,
e

)

:=


𝒢
dpvs



(


1
λ

,

N
t

,

param
𝔾


)




,










X
t

:=



(

χ

t
,
i
,
j


)


i
,

j
=
1

,





,

N
t






U



GL


(


N
t

,

𝔽
q


)




,










X
t
*

:=



(

ϑ

t
,
i
,
j


)


i
,

j
=
1

,





,

N
t



:=

ψ
·


(

X
t
T

)


-
1





,
hereafter
,


χ



t
,
i













and







ϑ



t
,
i







denote





the






i-th






rows





of






X
t






and


















X
t
*






for





i

=
1

,





,

N
t

,
respectively
,














b

t
,
i


:=



(


χ



t
,
i


)


𝔸
t


=






N
t



j
=
1









χ

t
,
i
,
j




a

t
,
j







for





i


=
1



,





,

N
t

,










𝔹
t

:=

(


b

t
,
1


,





,

b

t
,

N
t




)


,






b

t
,
i

*

:=



(


ϑ



t
,
i


)


𝔸
t


=





j
=
1


N
t









ϑ

t
,
i
,
j




a

t
,
j







for





i


=
1



,





,

N
t

,










𝔹
t

:=

(


b

t
,
1

*

,





,

b

t
,

N
t


*


)


,










g
T

:=


e


(

g
,
g

)


ψ


,

param
:=

(



{

param

V
t


}



t
=
0

,
1


,

g
T


)


,









return







(

param
,
𝔹
,

𝔹
*


)

.




















KeyGen


(

pk
,
sk
,

Γ
:=

{


(

t
,

x
t


)



1

t

d


}



)




:












ω
,


φ
0




U



𝔽
q


,










k
0
*

:=


(

ω
,
0
,
1
,

φ
0

,
0

)


𝔹
0
*



,










for






(

t
,

x
t


)



Γ

,

σ
t

,

φ

t
,
1


,

φ

t
,
2


,



U



𝔽
q


,










k
t
*

:=


(





σ
t



(

1
,
t

)


,

ω


(

1
,

x
t


)


,



4






0
8

,



8






φ

t
,
1


,

φ

t
,
2


,



2





0
2



2



)


B
*



,










return






sk
Γ


:=


(

Γ
,

k
0
*

,


{

k
t
*

}



(

t
,

x
t


)


Γ



)

.








[

Formula





164

]
















Enc


(

pk
,
m
,

𝕊
:=

(

M
,
ρ

)



)


:










f





U



𝔽
q
r



,


s
0

:=


1


·


f


T



,











s


T

:=



(


s
1

,





,

s
L


)

T

:=

M
·


f


T




,
ζ
,


η
0




U



𝔽
q


,














c
0

:=


(


-

s
0


,
0
,
ζ
,
0
,

η
0


)


𝔹
0



,








[

Formula





165

]













for





i

=
1

,





,
L
,










if






ρ


(
i
)



=

(

t
,

v
i


)


,

μ
i

,

θ
i

,

η

i
,
1


,


η

i
,
2





U



𝔽
q


,










c
i

:=


(





μ
i



(

t
,

-
1


)


,


s
i

+


θ
i



v
i



,

-

θ
i





4






0
8

,



8






0
2

,



2






η

i
,
1


,

η

i
,
2





2



)

𝔹


,










if






ρ


(
i
)



=



(

t
,

v
i


)



,

μ
i

,

η

i
,
1


,


η

i
,
2





U



𝔽
q


,










c
i

:=


(





μ
i



(

t
,

-
1


)


,


s
i



(


v
i

,

-
1


)


,



4






0
8

,



8






0
2

,



2






η

i
,
1


,

η

i
,
2





2



)

𝔹


,










c

d
+
1


:=


g
T
ζ


m


,










return






ct
𝕊


:=


(

𝕊
,

c
0

,

c
1

,





,

c
L

,

c

d
+
1



)

.
















Dec


(

pk
,


sk
Γ

:=

(

Γ
,

k
0
*

,


{

k
t
*

}



(

t
,

x
t


)


Γ



)


,


ct
𝕊

:=

(

𝕊
,

c
0

,

c
1

,





,

c
L

,

c

d
+
1



)



)




:














If





𝕊

:=



(

M
,
ρ

)






accepts





Γ

:=

{

(

t
,

x
t


)

}



,









then





compute





I





and







{

α
i

}


i

I







such





that










1


=




i

I





α
i



M
i




,

where






M
i






is





the






i-th












row





of





M

,
and





[

Formula





166

]







I



{


i


{

1
,





,
L

}





[






ρ


(
i
)


=




(

t
,

v
i


)



(

t
,

x
t


)




Γ


v
i



=

x
t



]







[






ρ


(
i
)


=





(

t
,

v
i


)



(

t
,

x
t


)





Γ


v
i




x
t





]



}

.




K


:=



e


(


c
0

,

k
0
*


)








i


I


ρ


(
i
)




=

(

t
,

v
i


)










e


(


c
i

,

k
t
*


)




α
i







i


I


ρ


(
i
)




=



(

t
,

v
i


)







e


(


c
i

,

k
t
*


)





α
i

/


α
i



(


v
i

-

x
i


)












return






m







:=


c

d
+
1


/

K
.















In Embodiment 2, the KP-FE scheme has been described. In Embodiment 3, the CP-FE scheme has been described. As with these schemes, the unified-policy (UP-FE) scheme described in Non-Patent Literature 30 may be constructed such that there is no need to reissue a public parameter when an attribute category is to be added.


Embodiment 4

Like Embodiments 2 and 3, this embodiment describes a narrowly-defined cryptographic processing scheme. In particular, this embodiment describes a hierarchical inner-product predicate encryption (HIPE) scheme.


The HIPE scheme is an inner-product predicate encryption scheme which is capable of delegation. Delegation means that a user who has a higher-level key generates a lower-level key having more limited capabilities than the user's (higher-level) key. The limited capabilities mean that the lower-level key can decrypt only some of ciphertexts that can be decrypted with the higher-level key. As explained in Embodiment 1, the inner-product predicate encryption scheme corresponds to a case where the design of the access structure in the functional encryption scheme is limited.


The HIPE scheme includes a first scheme which is efficient, and a second scheme which is less efficient than the first scheme, but guarantees security of even attribute information that is set in a ciphertext (see Non-Patent Literature 29). Here, as an example of the second scheme, a scheme which allows for addition of an attribute category without reissuing a public parameter will be described. However, by making similar modifications to the algorithms described in Non-Patent Literature 29, the first scheme can also be constructed to allow for addition of an attribute category without reissuing a public parameter.


First, the construction of the HIPE scheme will be described.


Second, the configuration of a cryptographic system 10 that implements the HIPE scheme will be described.


Third, the HIPE scheme will be described in detail.


<1. Construction of HIPE Scheme>


The HIPE scheme consists of five algorithms: Setup, KeyGen, Enc, Dec, and DelegateL.


(Setup)


A Setup algorithm is a probabilistic algorithm that takes as input a security parameter 1λ, and outputs a master public key pk and a master secret key sk. The master secret key sk is a top-level key.


(KeyGen)


A KeyGen algorithm is a probabilistic algorithm that takes as input the master public key pk, the master secret key sk, and predicate information (v{right arrow over ( )}1, . . . , v{right arrow over ( )}L) (1≦L≦d), and outputs an L-th-level secret key skL.


(Enc)


An Enc algorithm is a probabilistic algorithm that takes as input the master public key pk, attribute information (x{right arrow over ( )}1, . . . , x{right arrow over ( )}h) (1≦h≦d), and a message m, and outputs a ciphertext ct.


(Dec)


A Dec algorithm is a probabilistic algorithm that takes as input the master public key pk, the L-th-level secret key skL, and the ciphertext ct, and outputs the message m or a distinguished symbol ⊥.


(DelegateL)


DelegateL is a probabilistic algorithm that takes as input the master public key pk, the L-th-level secret key skL, and (L+1)-th level predicate information v{right arrow over ( )}L+1 (L+1≦d), and outputs an (L+1)-th-level secret key skL+1. That is, the DelegateL algorithm outputs a lower-level secret key.


<2. Configuration of Cryptographic System 10 that Implements HIPE Scheme>



FIG. 20 is a configuration diagram of the cryptographic system 10 that implements the HIPE scheme according to Embodiment 4.


The cryptographic system 10 includes a key generation device 100, an encryption device 200, a decryption device 300, and a key delegation device 400. It is assumed in the following description that the decryption device 300 includes the key delegation device 400. However, the key delegation device 400 may be provided separately from the decryption device 300.


The key generation device 100 executes the Setup algorithm taking as input a security parameter λ, and thus generates a master public key pk and a master secret key sk. Then, the key generation device 100 publishes the generated master public key pk. The key generation device 100 also executes the KeyGen algorithm taking as input the master public key pk, the master secret key sk, and predicate information (v{right arrow over ( )}1, . . . , v{right arrow over ( )}L) (1≦L≦d), and thus generates an L-th-level secret key skL, and distributes the L-th-level secret key skL to the L-th level decryption device 300 in secrecy.


The encryption device 200 executes the Enc algorithm taking as input the master public key pk, attribute information (x{right arrow over ( )}1, . . . , x{right arrow over ( )}h) (1≦h≦d), and a message m, and thus generates a ciphertext ct. The encryption device 200 transmits the generated ciphertext ct to the decryption device 300.


The decryption device 300 executes the Dec algorithm taking as input the master public key pk, the L-th-level secret key skL, and the ciphertext ct, and outputs the message m or a distinguished symbol 1.


The key delegation device 400 executes the DelegateL algorithm taking as input the master public key pk, the L-th-level secret key skL, and (L+1)-th-level predicate information v{right arrow over ( )}L+1 (L+1≦d), and thus generates an (L+1)-th-level secret key skL+1, and distributes the (L+1)-th-level secret key skL+1 to the (L+1)-th-level decryption device 300 in secrecy.


<3. HIPE Scheme in Detail>


With reference to FIGS. 21 to 29, the HIPE scheme and the operation and function of the cryptographic system 10 that implements the HIPE scheme according to Embodiment 4 will be described.



FIG. 21 is a configuration diagram of the key generation device 100 according to Embodiment 4. FIG. 22 is a configuration diagram of the encryption device 200 according to Embodiment 4. FIG. 23 is a configuration diagram of the decryption device 300 according to Embodiment 4. FIG. 24 is a configuration diagram of the key delegation device 400 according to Embodiment 4.



FIGS. 25 and 26 show flowcharts illustrating the operation of the key generation device 100. FIG. 25 is a flowchart illustrating the process of the Setup algorithm. FIG. 26 is a flowchart illustrating the process of the KeyGen algorithm. FIG. 27 is a flowchart illustrating the operation of the encryption device 200 and illustrating the process of the Enc algorithm. FIG. 28 is a flowchart illustrating the operation of the decryption device 300 and illustrating the process of the Dec algorithm. FIG. 29 is a flowchart illustrating the operation of the key delegation device 400 and illustrating the process of the DelegateL algorithm.


The function and operation of the key generation device 100 will be described.


The key generation device 100 includes a master key generation unit 110, a master key storage unit 120, an information input unit 130, a decryption key generation unit 140, and a key distribution unit 150. The decryption key generation unit 140 includes a random number generation unit 143, a key element generation unit 144, a randomizing element generation unit 145, and a delegation element generation unit 146.


With reference to FIG. 25, the process of the Setup algorithm will be described.


S801 is substantially the same as (S101) in Embodiment 2 shown in FIG. 9.


(S802: Public Parameter Generation Step)


Using the processing device, the master key generation unit 110 generates a subbasis B^0 of the basis B0, a subbasis B^ of the basis B, a subbasis B^0,pk of the basis B*0, and a subbasis B^*pk of the basis B*, as indicated in Formula 167, the bases B0, B^, B, and B*0 having been generated in (S801).

custom character0:=(b0,1,b0,1+u0+1,b0,1+u0+1+w0+1, . . . ,b0,1+u0+1+w0+z0),
custom character:=(b1, . . . ,b2+n,b2+n+u+w+1, . . . ,b2+n+u+w+z),
custom character*0,pk=b*0,1+u0+1+1, . . . ,b0,1+u0+1+w0,
custom character*pk:=(b*1,b*2,b*2+n+u+1, . . . ,b*2+n+u+w)  [Formula 167]


The master key generation unit 110 generates a public parameter pk by putting together the generated subbasis B^0, subbasis B^, subbasis B^*0,pk, and subbasis B^*pk, the security parameter λ(1λ) inputted in (S801), and param generated in (S801).


(S803: Master Key Generation Step)


Using the processing device, the master key generation unit 110 generates a subbasis B^*0,sk of the basis B*0 and a subbasis B^*sk of the basis B*, as indicated in Formula 168, the bases B*0 and B* having been generated in (S801).

custom character*0,sk:=(b*0,1,b*0,1+u0+1),
custom character*sk=(b*2+1, . . . ,b*2+n)  [Formula 168]


The master key generation unit 110 generates a master key sk which is constituted by the generated subbasis B^*0 and subbasis B^*.


(S804: Master Key Storage Step)


The master key storage unit 120 stores the public parameter pk generated in (S802) in the storage device. The master key storage unit 120 also stores the master key sk generated in (S803) in the storage device.


In brief, in (S801) through (S803), the key generation device 100 executes the Setup algorithm indicated in Formula 169, and thus generates the public parameter pk and the master key sk. In (S804), the key generation device 100 stores the generated public parameter pk and master key sk in the storage device.


The public parameter is published via the network, for example, and is made available for the encryption device 200 and the decryption device 300.











Setup


(

1
λ

)




:








(

param
,

(


𝔹
0

,

𝔹
0
*


)

,

(

𝔹
,

𝔹
*


)


)




R




𝒢
ob



(

1
λ

)




,







𝔹
^

0

:=

(


b

0
,
1


,

b

0
,

1
+

u
0

+
1



,

b

0
,

1
+

u
0

+
1
+

w
0

+
1



,





,

b

0
,

1
+

u
0

+
1
+

w
0

+

z
0





)


,






𝔹
^

:=

(


b
1

,





,

b

2
+
n


,

b

2
+
n
+
u
+
w
+
1


,





,

b

2
+
n
+
u
+
w
+
z



)


,











𝔹
^


0
,

p





k


*

:=

b

0
,

1
+

u
0

+
1
+
1


*


,





,

b

0
,

1
+

u
0

+
1
+

w
0




,











𝔹
^


0
,
sk

*

:=

(


b

0
,
1

*

,

b

0
,

1
+

u
0

+
1


*


)


,











𝔹
^


p





k

*

:=

(


b
1
*

,

b
2
*

,

b

2
+
n
+
u
+
1

*

,





,

b

2
+
n
+
u
+
w

*


)


,











𝔹
^

sk
*

:=

(


b

2
+
1

*

,





,

b

2
+
n

*


)


,










return





pk

:=

(


1
λ

,
param
,


𝔹
^

0

,

𝔹
^

,


𝔹
^


0
,
pk

*

,


𝔹
^

pk
*


)


,









sk
:=


(



𝔹
^


0
,
sk

*

,


𝔹
^

sk
*


)

.











[

Formula





169

]







With reference to FIG. 26, the process of the KeyGen algorithm to be executed by the key generation device 100 will be described.


(S901: Information Input Step)


Using the input device, the information input unit 130 takes as input predicate information (v{right arrow over ( )}1, . . . , v{right arrow over ( )}L). Note that v{right arrow over ( )}i:=vi,1, . . . , vi,n for each integer i=1, . . . , L. Note that the attribute of the user of the key is input as the predicate information.


(S902: Random Number Generation Step)


Using the processing device, the random number generation unit 143 generates random numbers, as indicated in Formula 170.












for





j

=
1

,





,


2

L

;

τ
=

L
+
1



,





,

d
;

i
=
1


,





,

n
;












ψ
,

μ

dec
,
t


,

μ

ran
,
1
,
j
,
t


,

s

dec
,
t


,

s

ran
,
1
,
j
,
t


,









θ

dec
,
t


,




θ

ran
,
1
,
j
,
t





U



𝔽
q







for





t

=
1

,





,
L
,









μ

del
,

(

τ
,
ι

)

,
t


,

μ

ran
,
2
,
τ
,
ι


,

s

del
,

(

τ
,
ι

)

,
t


,

s

ran
,
2
,
τ
,
ι


,





θ

del
,

(

τ
,
ι

)

,
t


,




θ

ran
,
2
,
τ
,
t





U



𝔽
q







for





t

=
1

,





,

L
+
1

,











η
->


dec
,
0


:=

η

dec
,
0
,
1



,





,

η

dec
,
0
,

w
0



,











η
->


ran
,
1
,
j
,
0


:=

η

ran
,
1
,
j
,
0
,
1



,





,

η

ran
,
1
,
j
,
0
,

w
0



,











η
->


del
,

(

τ
,
ι

)

,
0


:=

η

del
,

(

τ
,
ι

)

,
0
,
1



,





,

η

del
,

(

τ
,
ι

)

,
0
,

w
0



,







η
->


ran
,
2
,
τ
,
0


:=

η

ran
,
2
,
τ
,
0
,
1



,





,


η

ran
,
2
,
τ
,
0
,

w
0






U



𝔽
q

w
0



,











η
->


dec
,
t


:=

η

dec
,
t
,
1



,





,

η

dec
,
t
,
w


,







η
->


ran
,
1
,
j
,
t


:=

η

ran
,
1
,
j
,
t
,
1



,





,




η

ran
,
1
,
j
,
t
,
w





U



𝔽
q
w







for





t

=
1

,

,
L
,











η
->


del
,

(

τ
,
ι

)

,
t


:=

η

del
,

(

τ
,
ι

)

,
t
,
1



,





,

η

del
,

(

τ
,
ι

)

,
t
,
w


,







η
->


ran
,
2
,
τ
,
ι


:=

η

ran
,
2
,
τ
,
t
,
1



,





,








η

ran
,
2
,
τ
,
t
,
w





U



𝔽
q
w







for





t

=
1

,





,

L
+
1






[

Formula





170

]







The random number generation unit 143 also sets sdec,0, sran,1,j,0, sran,2,τ,0, and sdel,(τ,ι),0, as indicated in Formula 171.

sdec,0:=Σt=1Lsdec,t,
sran,1,j,0:=Σt=1Lsran,1,j,t,
sran,2,τ,0:=Σt=1L+1sran,2,τ,t,
sdel,(τ,ι),0:=Σt=1L+1sdel,(τ,ι),t,  [Formula 171]


(S903: Key Element Generation Step)


Using the processing device, the key element generation unit 144 generates a key element k*L,dec which is an element of the decryption key skL, as indicated in Formula 172.

k*L,dec:=((−sdec,0,0u0,1,{right arrow over (η)}dec,0,0z0)custom character*0),
dec,t(t,−1),sdec,t{right arrow over (e)}1dec,t{right arrow over (v)}t,0u,{right arrow over (η)}dec,t,0z)custom character*
:t=1, . . . ,L)  [Formula 172]


(S904: First Randomizing Element Generation Step)


Using the processing device, the randomizing element generation unit 145 generates a first randomizing element k*L,ran,1,j which is an element of the decryption key skL, for each integer j=1, . . . , 2L, as indicated in Formula 173.

k*L,ran,1,j:=((−sran,1,j,0,0u0,0,{right arrow over (η)}ran,1,j,0,0z0)custom character*0,
ran,1,j,t(t,−1),sran,1,j,t{right arrow over (e)}1ran,1,j,t{right arrow over (v)}t,0u,
{right arrow over (η)}ran,1,j,t,0z)custom character*:t=1, . . . ,L)  [Formula 173]


(S905: Second Randomizing Element Generation Step)


Using the processing device, the randomizing element generation unit 145 generates a second randomizing element k*L,ran,2,τ which is an element of the decryption key skL, for each integer τ=L+1, . . . , d, as indicated in Formula 174.

k*L,ran,2,τ:=((−sran,2,τ,0,0u0,0,{right arrow over (η)}ran,2,τ,0,0z0)custom character*0,
ran,2,τ,t(t,−1),sran,2,τ,t{right arrow over (e)}1ran,2,τ,t{right arrow over (v)}t,0u,
{right arrow over (η)}ran,2,τ,t,0z)custom character*:t=1, . . . ,L,
ran,2,τ,L+1(τ,−1),sran,2,τ,L+1{right arrow over (e)}1,0u,{right arrow over (η)}ran,2,τ,L+1,0z)custom character*)  [Formula 174]


(S906: Delegation Element Generation Step)


Using the processing device, the delegation element generation unit 146 generates a delegation element k*L,del,(τ,ι) which is an element of the decryption key skL, for each integer τ=L+1, . . . , d, and each integer ι=1, 2 with respect to each integer τ, as indicated in Formula 175.

k*L,del,(τ,ι):=((−sdel,(τ,ι),0,0u0,0,{right arrow over (η)}del,(τ,ι),0,0z0)custom character*0,
del,(τ,ι),t(t,−1),sdel,(τ,ι),t{right arrow over (e)}1del,(τ,ι),t{right arrow over (v)}t,0u,
{right arrow over (η)}del,(τ,ι),t,0z)custom character*:t=1, . . . ,L,
del,(τ,ι),L+1(τ,−1),sdel,(τ,ι),L+1{right arrow over (e)}1+ψ{right arrow over (e)}t,0u,
{right arrow over (η)}del,(τ,2),L+1,0z)custom character*)  [Formula 175]


(S907: Key Distribution Step)


Using the communication device and via the network, for example, the key distribution unit 150 distributes the decryption key skL having, as elements, the key element k*L,dec, the first randomizing element k*L,ran,1,j, the second randomizing element k*L,ran,2,τ, and the delegation element k*L,del,(τ,ι) to the decryption device 300 in secrecy. As a matter of course, the decryption key skL may be distributed to the decryption device 300 by another method.


In brief, in (S901) through (S906), the key generation device 100 executes the KeyGen algorithm indicated in Formula 176 and Formula 177, and thus generates the decryption key skL. In (S907), the key generation device 100 distributes the generated decryption key skL to the decryption device 300.
















KeyGen


(

pk
,
sk
,


(




v



1
,





,


v


L


)





𝔽
q
n




×

𝔽
q
n




)




:










for





j

=
1

,





,


2

L

;

τ
=

L
+
1



,





,

d
;

t
=
1


,





,

n
;












ψ
,

μ

dec
,
t


,

μ

ran
,
1
,
j
,
t


,

s

dec
,
t


,

s

ran
,
1
,
j
,
t


,









θ

dec
,
t


,




θ

ran
,
1
,
j
,
t





U



𝔽
q







for





t

=
1

,





,
L
,









μ

del
,

(

τ
,
ι

)

,
t


,

μ

ran
,
2
,
τ
,
t


,

s

del
,

(

τ
,
ι

)

,
t


,

s

ran
,
2
,
τ
,
t


,









θ

del
,

(

τ
,
ι

)

,
t


,




θ

ran
,
2
,
τ
,
t





U



𝔽
q







for





t

=
1

,





,

L
+
1

,






[

Formula





176

]













s

dec
,
0


:=




t
=
1

L







s

dec
,
t




,


s

del
,

(

τ
,
ι

)

,
0


:=




t
=
1


L
+
1








s

del
,

(

τ
,
ι

)

,
t




,










s

ran
,
1
,
j
,
0


:=




t
=
1

L







s

ran
,
1
,
j
,
t




,


s

ran
,
2
,
τ
,
0


:=




t
=
1


L
+
1








s

ran
,
2
,
τ
,
ι




,










η



dec
,
0


,


η



ran
,
1
,
j
,
0


,


η



del
,

(

τ
,
ι

)

,
0


,



η



ran
,
2
,
τ
,
0





U



𝔽
q

w
0



,










η



dec
,
t


,





η



ran
,
1
,
j
,
t





U



𝔽
q
w







for





t

=
1

,





,
L
,










η



del
,

(

τ
,
ι

)

,
t


,





η



ran
,
2
,
τ
,
t





U



𝔽
q
w







for





t

=
1

,





,

L
+
1

,
















k

L
,
dec

*

:=



(



(


-

s

dec
,
0



,

0

u
0


,
1
,


η



dec
,
0


,

0

z
0



)


𝔹
0
*


,



(



μ

dec
,
t




(

t
,

-
1


)


,



s

dec
,
t





e


1


+


θ

dec
,
t





v


t



,

0
u

,


η



dec
,
t


,

0
z


)


B
*




:














t

=
1


,





,
L

)

,




[

Formula





177

]







k

L
,
del
,

(

τ
,
ι

)


*

:=

(



(


-

s

del
,

(

τ
,
ι

)

,
0



,

0

u
0


,
0
,


η



del
,

(

τ
,
ι

)

,
0


,

0

z
0



)


𝔹
0
*


,

(



μ

del
,

(

τ
,
ι

)

,
t




(

t
,

-
1


)


,



s

del
,

(

τ
,
ι

)

,
t





e


1


+


θ

del
,

(

τ
,
ι

)

,
t





v


t



,

0
u

,








η



del
,

(

τ
,
ι

)

,
t


,

0
z


)


B
*


:
t

=
1

,





,
L
,







(



μ

del
,

(

τ
,
ι

)

,

L
+
1





(

τ
,

-
1


)


,



s

del
,

(

τ
,
1

)

,

L
+
1






e


1


+

ψ



e


ι



,

0
u

,


η



del
,

(

τ
,
2

)

,

L
+
1



,




0
z

)


𝔹
*



)







k

L
,
ran
,
1
,
j

*


:=

(



(


-

s

ran
,
1
,
j
,
0



,

0

u
0


,
0
,


η



ran
,
1
,
j
,
0


,

0

z
0



)


𝔹
0
*


,

(



μ

ran
,
1
,
j
,
t




(

t
,

-
1


)


,



s

ran
,
1
,
j
,
t





e


1


+


θ

ran
,
1
,
j
,
t





v


t



,

0
u

,


η



ran
,
1
,
j
,
t


,






0
z

)


𝔹
*


:
t

=
1

,





,
L

)

,



















k

L
,
ran
,
2
,
τ

*

:=

(



(


-

s

ran
,
2
,
τ
,
0



,

0

u
0


,
0
,


η



ran
,
2
,
τ
,
0


,

0

z
0



)


𝔹
0
*


,

(



μ

ran
,
2
,
τ
,
t




(

t
,

-
1


)


,



s

ran
,
2
,
τ
,
ι





e


1


+


θ

ran
,
2
,
τ
,
ι





v


t



,

0
u

,


η



ran
,
2
,
τ
,
ι


,






0
z

)


𝔹
*


:
t

=
1

,





,
L
,


(



μ

ran
,
2
,
τ
,

L
+
1





(

τ
,

-
1


)


,


s

ran
,
2
,
τ
,

L
+
1






e


1


,

0
u

,


η



ran
,
2
,
τ
,

L
+
1



,

0
z


)


B
*



)

,










sk
L

:=


k

L
,
dec
,

*




{

k

L
,
del
,

(

τ
,
ι

)


*

}



τ
=

L
+
1


,









,

d
;

ι
=
1


,
2




,










{


k

L
,
ran
,
1
,
j

*

,

k

L
,
ran
,
2
,
ι

*


}




j
=
1

,









,


2

L

;

τ
=

L
+
1



,









,
d

)


,









return







sk
L

.
















The function and operation of the encryption device 200 will be described.


The encryption device 200 includes a public parameter acquisition unit 210, an information input unit 220, a cipher data generation unit 230, and a data transmission unit 240. The cipher data generation unit 230 includes a random number generation unit 231 and a cipher element generation unit 232.


With reference to FIG. 27, the process of the Enc algorithm to be executed by the encryption device 200 will be described.


(S1001: Master Public Key Acquisition Step)


Using the communication device and via the network, for example, the public parameter acquisition unit 210 obtains the master public key pk generated by the key generation device 100.


(S1002: Information Input Step)


Using the input device, the information input unit 220 takes as input attribute information (x{right arrow over ( )}1, . . . , x{right arrow over ( )}L), where x{right arrow over ( )}i:=xi,1, . . . , xi,L for each integer i=1, . . . , L. Note that the attribute of a person capable of decrypting an encrypted message is input as the attribute information.


Using the input device, the information input unit 220 also takes as input a message m to be encrypted.


(S1003: Random Number Generation Step)


Using the processing device, the random number generation unit 231 generates random numbers, as indicated in Formula 178.














ω
,

ζ



U



𝔽
q


,



φ


0

:=

φ

0
,
1



,





,


φ

0
,

z
0






U



𝔽
q

z
0



,







φ


t

:=

φ

t
,
1



,





,


φ

t
,
z





U



𝔽
q
z


,




σ
t




U



𝔽
q







for





t

=
1

,





,
L





[

Formula





178

]







(S1004: Cipher Element c1 Generation Step)


Using the processing device, the cipher element generation unit 232 generates a cipher element c1 which is an element of a ciphertext ct, as indicated in Formula 179.

c1:=((ω,0u0,ζ,0w0,{right arrow over (φ)}0)custom character0,(σt(1,t),ω{right arrow over (x)}t,0u,0w,{right arrow over (φ)}t)custom character:t=1, . . . ,L)  [Formula 179]


(S1005: Cipher Element c2 Generation Step)


Using the processing device, the cipher element generation unit 232 generates a cipher element c2 which is an element of the ciphertext ct, as indicated in Formula 180.

c2:=gTζm−  [Formula 180]


(S1006: Data Transmission Step)


Using the communication device and via the network, for example, the data transmission unit 240 transmits the ciphertext ct including the cipher element c1 and the cipher element c2 to the decryption device 300. As a matter of course, the ciphertext ct may be transmitted to the decryption device 300 by another method.


In brief, in (S1001) through (S1005), the encryption device 200 executes the Enc algorithm indicated in Formula 181, and thus generates the ciphertext ct. In (S1006), the encryption device 200 transmits the generated ciphertext ct to the decryption device 300.
















Enc


(

pk
,

m


𝔾
T


,


(



x


1

,





,


x


L


)




𝔽
q
n

×

×

𝔽
q
n




)




:












ω
,

ζ



U



𝔽
q


,



φ


0




U



𝔽
q

z
0



,










for





t

=
1

,





,
L
,











φ


t




U



𝔽
q
z


,


σ
t




U



𝔽
q


,






c
1

:=

(



(

ω
,

0

u
0


,
ζ
,

0

w
0


,


φ


0


)


𝔹
0


,




(



σ
t



(

1
,
t

)


,

ω







x


t


,

0
u

,

0
w

,


φ


t


)

𝔹



:






t

=
1

,





,
L

)


,










c
2

:=


g
T
ζ


m


,

ct
:=

(


c
1

,

c
2


)


,









return






ct
.








[

Formula





181

]







The function and operation of the decryption device 300 will be described.


The decryption device 300 includes a decryption key acquisition unit 310, a data receiving unit 320, a pairing operation unit 350, and a message computation unit 360.


With reference to FIG. 28, the process of the Dec algorithm to be executed by the decryption device 300 will be described.


(S1101: Decryption Key Acquisition Step)


Using the communication device and via the network, for example, the decryption key acquisition unit 310 obtains the decryption key skL. The decryption key acquisition unit 310 also obtains the public parameter pk generated by the key generation device 100.


(S1102: Data Reception Step)


Using the communication device and via the network, for example, the data receiving unit 320 receives the ciphertext ct transmitted by the encryption device 200.


(S1103: Pairing Operation Step)


Using the processing device, the pairing operation unit 350 performs a pairing operation indicated in Formula 182, and thus computes a session key K=gTζ.

e(c1,k*L,dec)  [Formula 182]


(S1104: Message Computation Step)


Using the processing device, the message computation unit 360 computes a message m′ (=m) by dividing the cipher element c2 by the session key K.


In brief, in (S1101) through (S1104), the decryption device 300 executes the Dec algorithm indicated in Formula 183, and thus computes the message m′ (=m).

Dec(pk,k*L,dec,ct):
m′:=c2/e(c1,k*L,dec),
return m′.  [Formula 183]


The function and operation of the key delegation device 400 will be described.


The key delegation device 400 includes a decryption key acquisition unit 410, an information input unit 420, a delegation key generation unit 430, and a key distribution unit 440. The delegation key generation unit 430 includes a random number generation unit 431, a lower-level key element generation unit 432, a lower-level randomizing element generation unit 433, and a lower-level delegation element generation unit 434.


With reference to FIG. 29, the process of the DelegateL algorithm to be executed by the key delegation device 400 will be described.


(S1201: Decryption Key Acquisition Step)


Using the communication device and via the network, for example, the decryption key acquisition unit 410 obtains the decryption key skL. The decryption key acquisition unit 410 also obtains the public parameter pk generated by the key generation device 100.


(S1202: Information Input Step)


Using the input device, the information input unit 420 takes as input predicate information v{right arrow over ( )}L+1:=(vL+1,i (i=1, . . . , nL+1)). Note that the attribute of a person to whom the key is to be delegated is input as the predicate information.


(S1203: Random Number Generation Step)


Using the processing device, the random number generation unit 431 generates random numbers, as indicated in Formula 184.














for












j


=
1

,





,


2


(

L
+
1

)


;













τ
=

L
+
2


,





,

d
;

ι
=
1


,





,

n
;













μ

del
,

(

τ
,
ι

)




,

μ

ran
,
2
,
τ



,

ϕ

del
,

(

τ
,
ι

)



,

ϕ

ran
,
2
,
τ


,


ψ





U



q


,





p
dec
*

,

p

del
,

(

τ
,
ι

)


*

,

p

ran
,
1
,

j



*

,


p

ran
,
2
,
τ

*




R




CoreDel
L



(

pk
,

sk
L

,

v

L
+
1



)



,








where













CoreDel
L



(

pk
,

sk
L

,

v

L
+
1



)




:













μ
t


,
ξ
,


α
j




U



q












for











t
=
1

,





,


L
+
1

;













j
=
1

,





,


2

L

+
1

,








return









p
*

:=





t
=
1


L
+
1






μ
t




(


tb
1
*

-

b
2
*


)




t




+

ξ


(





i
=
1

n



v

L
+
1



,

k
L
*

,

del


(


L
+
1

,
i

)



)


+




j
=
1


2

L





α
j



k

L
,
ran
,
1
,
j

*



+


α


2

L

+
1




k

L
,
ran
,
2
,

L
+
1


*




,





r
dec
*

,



r

ran
,
1
,

j



*




U


span







(


b

0
,

1
+

u
0

+
1
+
1


*

,





,

b

0
,

1
+

u
0

+
1
+

w
0



*


)



0



,



{


(


b

2
+
n
+
u
+
1

*

,





,

b

2
+
n
+
u
+
w

*


)



t



}


t

=
1

,





,

L
+
1





,





r

del
,

(

τ
,
ι

)


*

,



r

ran
,
2
,
τ

*




U


span






(


b

0
,

1
+

u
0

+
1
+
1


*

,





,


b

0
,

1
+

u
0

+
1
+

w
0



*



0



,



{


(


b

2
+
n
+
u
+
1

*

,





,

b

2
+
n
+
u
+
w

*


)



t



}


t

=
1

,





,

L
+
1




,









[

Formula





184

]







(S1204: Lower-Level Key Element Generation Step)


Using the processing device, the lower-level key element generation unit 432 generates a lower-level key element k*L+1,dec which is an element of a delegation key skL+1, as indicated in Formula 185.

k*L+1,dec:=k*L,dec+p*dec+r*dec  [Formula 185]


(S1205: First Lower-Level Randomizing Element Generation Step)


Using the processing device, the lower-level randomizing element generation unit 433 generates a first lower-level randomizing element k*L+1,ran,1,j′ which is an element of the delegation key skL+1, for each integer j′=1, . . . , 2(L+1), as indicated in Formula 186.

k*L+1,ran,1,j′:=p*ran,1,j′+r*ran,1,j′  [Formula 186]


(S1206: Second Lower-Level Randomizing Element Generation Step)


Using the processing device, the lower-level randomizing element generation unit 433 generates a second lower-level randomizing element k*L+1,ran,2,τ which is an element of the delegation key skL+1, for each integer τ=L+2, . . . , d, as indicated in Formula 187.

k*L+1,ran,2,τ:=p*ran,2,τ+μ′ran,2,τb*1−b*2)(τ)
ran,2,τk*L,ran,2,τ+r*ran,2,τ  [Formula 187]


(S1207: Lower-Level Delegation Element Generation Step)


Using the processing device, the lower-level delegation element generation unit 434 generates a lower-level delegation element k*L+1,del,(τ,ι) which is an element of the delegation key skL+1, for each integer τ=L+2, . . . , d and each integer ι=1, . . . , n with respect to each integer z, as indicated in Formula 188.

k*L+1,del(τ,ι):=p*del(τ,ι)+μ′del(τ,ι)b*1−b*2)(τ)
del,(τ,ι)k*L,ran,2,τ+ψ′k*L,del(τ,ι)+r*del(τ,ι)  [Formula 188]


(S1208: Key Distribution Step)


Using the communication device and via the network, for example, the key distribution unit 150 distributes the delegation key skL+1 (lower-level decryption key) having, as elements, the lower-level key element k*L+1,dec, the first lower-level randomizing element k*L+1,ran,1,j′, the second lower-level randomizing element k*L+1,ran,2,τ, and the lower-level delegation element k*L+1,del,(τ,ι) to the lower-level decryption device 300 in secrecy. As a matter of course, the delegation key skL+1 may be distributed to the lower-level decryption device 300 by another method.


In brief, in (S1201) through (S1207), the key delegation device 400 executes the DelegateL algorithm indicated in Formula 189, and thus generates the delegation key skL+1. In (S1208), the key delegation device 400 distributes the generated delegation key skL+1 to the lower-level decryption device 300.

















Delegate
L



(

pk
,

sk
L

,


v



L
+
1



)




:











for












j


=
1

,





,


2


(

L
+
1

)


;













τ
=

L
+
2


,





,

d
;

ι
=
1


,





,

n
;













μ

del
,

(

τ
,
ι

)




,

μ

ran
,
2
,
τ



,

ϕ

del
,

(

τ
,
ι

)



,

ϕ

ran
,
2
,
τ


,


ψ





U



q


,





p
dec
*

,

p

del
,

(

τ
,
ι

)


*

,

p

ran
,
1
,

j



*

,



p

ran
,
2
,
τ

*




R



CoreDel
L




(

pk
,

sk
L

,

v

L
+
1



)


,








where













CoreDel
L



(

pk
,

sk
L

,

v

L
+
1



)




:













μ
t


,
ξ
,


α
j




U



q












for











t
=
1

,





,


L
+
1

;













j
=
1

,





,


2

L

+
1

,








return









p
*

:=





t
=
1


L
+
1





μ
t





(


tb
1
*

-

b
2
*


)



t





+

ξ


(





i
=
1

n



v

L
+
1



,

k

L
,

del


(


L
+
1

,
i

)



*


)


+




j
=
1


2

L





α
j



k

L
,
ran
,
1
,
j

*



+


α


2

L

+
1




k

L
,
ran
,
2
,

L
+
1


*




,





r
dec
*

,



r

ran
,
1
,

j



*




U


span







(


b

0
,

1
+

u
0

+
1
+
1


*

,





,

b

0
,

1
+

u
0

+
1
+

w
0



*


)



0



,


{


(


b

2
+
n
+
u
+
1

*

,





,

b

2
+
n
+
u
+
w

*


)



t



}



t
=
1

,





,

L
+
1







,





r

del
,

(

τ
,
ι

)


*

,



r

ran
,
2
,
τ

*




U


span







(


b

0
,

1
+

u
0

+
1
+
1


*

,





,

b

0
,

1
+

u
0

+
1
+

w
0



*


)



0



,


{


(


b

2
+
n
+
u
+
1

*

,





,

b

2
+
n
+
u
+
w

*


)



t



}



t
=
1

,





,

L
+
1

,
τ






,










k


L
+
1

,
dec

*

:=


k

L
,
dec

*

+

p
dec
*

+

r
dec
*



,






k


L
+
1

,

dec


(

τ
,
ι

)



*

:=


p

del


(

τ
,
ι

)


*

+



μ

del


(

τ
,
ι

)


*



(


τ






b
1
*


-

b
2
*


)



(
τ
)


+


ϕ

del
,

(

τ
,
ι

)





k

L
,
ran
,
2
,
τ

*


+


ψ




k

L
,

del


(

τ
,
ι

)



*


+

r

del


(

τ
,
ι

)


*



,










k


L
+
1

,
ran
,

1


j




*

:=


p

ran
,
1
,

j



*

+

r

ran
,
1
,

j



*



,






k


L
+
1

,
ran
,
2
,
τ

*

:=


p

ran
,
2
,
τ

*

+



μ

ran
,
2
,
τ

*



(


τ






b
1
*


-

b
2
*


)



(
τ
)


+


ϕ

ran
,
2
,
τ




k

L
,
ran
,
2
,
τ

*


+

r

ran
,
2
,
τ

*



,






sk

L
+
1


:=

(


k


L
+
1

,
dec

*

,


{

k


L
+
1

,

del


(

τ
,
ι

)



*

}



τ
=

L
+
2


,





,

d
;

ι
=
1


,
2


,


{


k

L
,
ran
,
1
,

j



*

,

k

L
,
ran
,
2
,
τ

*


}




j


=
1

,





,


2


(

L
+
1

)


;

τ
=

L
+
2



,





,
d



)


,








return












sk

L
+
1


.











[

Formula





189

]







As described above, as in the cryptographic systems 10 according to Embodiments 2 and 3, in the cryptographic system 10 according to Embodiment 4, the index parts are provided, so that the bases that are used for every attribute category can be constructed as the common bases (basis B and basis B*). As a result, only the basis B and the basis B* need to be included in a public parameter, eliminating the need for reissuing the public parameter when an attribute category is to be added at a later stage.


As in Embodiments 2 and 3, for the index parts, it is required that 0 be obtained as a result of an inner-product operation of the index parts. Therefore, although the 2-dimensional index parts, namely the basis vectors b*1 and b*2 and the basis vectors b1 and b2, are employed in the above description, the index parts are not limited to 2-dimensional and may be 3-dimensional or higher-dimensional. The values assigned to the index parts are not limited to those described above, and a different assignment arrangement may be employed.


The HIPE scheme based on the functional encryption scheme has been described above. As indicated in Formula 190 through Formula 195, however, the scheme can be modified into an HIPE scheme based on the attribute-based encryption scheme. Note that N0 is 1+1+1+1+1=5, and N1 is 2+2+8+2+2=16 in Formula 190 through Formula 195. That is, u0=1, w0=1, z0=1, n=2, u=8, w=2, and z=2. Even in this case, security can be proven.



















Setup


(

1
λ

)




:














(

param
,

(


0

,

0
*


)

,

(

,

*


)


)




R




𝒢
ob



(

1
λ

)



,












0

:=

^



(


b

0
,
1


,

b

0
,
3


,

b

0
,
5



)


,










^

:=

(


b
1

,





,

b
4

,

b
15

,

b
16


)


,











^


0
,
pk

*

:=

b

0
,
4

*


,



^


0
,
sk

*

:=

(


b

0
,
1

*

,

b

0
,
3

*


)


,
















^

pk
*

:=

(


b
1
*

,

b
2
*

,

b
13
*

,

b
14
*


)


,



^

sk
*

:=

(


b
3
*

,

b
4
*


)


,








return








[

Formula





190

]









pk
:=

(


1
λ

,
param
,




0

,

^



^


,


^


0
,
pk

*

,


^

pk
0


)


,

sk
:=



(



^


0
,
sk

*

,


^

sk
*


)

.










𝒢
ob



(

1
λ

)





:















:=


(

q
,
,

T

,
g
,
e

)




R




𝒢
bpg



(

1
λ

)




,

ψ



R



q
×


,










N
0

:=
5

,










N
1

:=
16

,








for












t
=
0

,
1
,



















:=


(

q
,

t

,

T

,

t

,
e

)

:=


𝒢
dpvs



(


1
λ

,

N
t

,

)




,










X
t

:=



(

χ

t
,
i
,
j


)


i
,

j
=
1

,





,

N
t






U



GL


(


N
t

,

q


)




,










X
t
*

:=



(

ϑ

t
,
i
,
j


)


i
,

j
=
1

,





,

N
t



:=

ψ
·


(

X
t
T

)


-
1





,








hereafter
,










χ



t
,
i












and












ϑ



t
,
i







denote





the





i


-


th





rows





of






X
t






and






X
t
*











for











i
=
1

,





,

N
t

,








respectively
,










b

t
,
i


:=



(


χ



t
,
i


)


t


=




j
=
1


N
t





χ

t
,
i
,
j




a

t
,
j























for











i
=
1

,





,

N
t

,






t

:=

(


b

t
,
1


,





,

b
t

,

N
t


)


,










b

t
,
i

*

:=



(


ϑ



t
,
i


)


t


=




j
=
1


N
t





ϑ

t
,
i
,
j




a

t
,
j
















for











i
=
1

,





,

N
t

,






t
*

:=

(


b

t
,
1

*

,





,

b

t
,

N
t


*


)


,










g
T

:=


e


(

g
,
g

)


ψ


,









param
:=

(



{
}



t
=
0

,
1


,

g
T


)


,








return












(

param
,
,

*


)

.




















KeyGen


(

pk
,
sk
,


(


v
1

,





,

v
L


)



q
L



)




:











for











j
=
1

,





,


2

L

;













τ
=

L
+
1


,





,

d
;













ι
=
1

,

2
;












ψ
,

μ

dec
,
t


,

μ

ran
,
1
,
j
,
t


,

s

dec
,
t


,

s

ran
,
1
,
j
,
t


,









θ

dec
,
t


,


θ

ran
,
1
,
j
,
t





U



q












for











t
=
1

,





,
L
,









μ

del
,

(

τ
,
ι

)

,
t


,

μ

ran
,
2
,
τ
,
ι


,

s

del
,

(

τ
,
ι

)

,
t


,

s

ran
,
2
,
τ
,
t


,









θ

del
,

(

τ
,
ι

)

,
t


,


θ

ran
,
2
,
τ
,
t





U



q












for











t
=
1

,





,

L
+
1

,






[

Formula





191

]














s

dec
,
0


:=




t
=
1

L



s

dec
,
t




,


s

del
,

(

τ
,
ι

)

,
0


:=




t
=
1

L



s

del
,

(

τ
,
ι

)

,
t




,










s

ran
,
1
,
j
,
0


:=




t
=
1

L



s

ran
,
1
,
j
,
t




,


s

ran
,
2
,
τ
,
0


:=




t
=
1


L
+
1




s

ran
,
2
,
τ
,
t




,










η



dec
,
t


,



η



ran
,
1
,
j
,
t





U



q
2












for











t
=
0

,





,
L
,










η



del
,

(

t
,
ι

)

,
t


,



η



ran
,
2
,
τ
,
t





U



q
2












for











t
=
0

,





,

L
+
1

,

















k

L
,
dec

*

:=

(



(


-

s

dec
,
0



,
0
,
1
,

η

dec
,
0


,
0

)


0
*


,




(



μ

dec
,
t




(

t
,

-
1


)


,


s

dec
,
t


+


θ

dec
,
t




v
t



,

-

θ

dec
,
t



,

0
8

,


η



dec
,
t


,

0
2


)


*




:


t

=
1

,





,
L

)


,






k

L
,

del


(

τ
,
ι

)



*

:=


(




(


-

s

del
,

(

τ
,
ι

)

,
0



,
0
,
0
,

η

del
,

(

τ
,
ι

)

,
0


,
0

)



0
*



(





μ

del
,

(

τ
,
ι

)

,
t




(

t
,

-
1


)




s

del
,

(

τ
,
ι

)

,
t



+


θ

del
,

(

τ
,
ι

)

,
t




v
t



,

-

θ


del


(

τ
,
ι

)


,
t



,

0
8

,


η



del
,

(

τ
,
ι

)

,
t


,

0
2


)



*



:






t

=
1

,





,
L
,


(



μ

del
,

(

τ
,
ι

)

,

L
+
1





(

τ
,

-
1


)


,

π

del
,

(

τ
,
ι

)

,

L
+
1

,
1


,

π

del
,

(

τ
,
ι

)

,

L
+
1

,
2


,

0
8

,


η



del
,

(

τ
,
2

)

,

L
+
1



,

0
2


)



η

del
,

(

τ
,
2

)

,

L
+
1




,

0
2


)



*




)











where
,






(


π

del
,

(

τ
,
ι

)

,

L
+
1

,
ι


,

π

del
,

(

τ
,
ι

)

,

L
+
1

,
2



)

:=

{




(



s

del
,



(

τ
,
1

)


L

+
1



+
ψ

,
0

)






if





ι

=
1

,






(


s

del
,

(

τ
,
2

)

,

L
+
1



,
ψ

)






if





ι

=
2

,











[

Formula





192

]









k

L
,
ran
,
1
,
j

*

:=

(



(


-

s

ran
,
1
,
j
,
0



,
0
,
0
,

η

ran
,
1
,
j
,
0


,
0

)


0
*


,



(



μ

ran
,
1
,
j
,
t




(

t
,

-
1


)


,


s

ran
,
1
,
j
,
t


+


θ

ran
,
1
,
j
,
t




v
t



,

-

θ

ran
,
1
,
j
,
t



,

0
8

,


η



ran
,
1
,
j
,
t


,

0
2


)



*



:






t

=
1

,





,
L

)


,






k

L
,
ran
,
2
,
τ

*

:=

(



(


-

s

ran
,
2
,
τ
,
0



,
0
,
0
,

η

ran
,
2
,
τ
,
0


,
0

)


0
*


,



(



μ

ran
,
2
,
τ
,
t




(

t
,

-
1


)


,


s

ran
,
2
,
τ
,
t


+


θ

ran
,
2
,
τ
,
t




v
t



,

-

θ

ran
,
2
,
τ
,
t



,

0
8

,


η



ran
,
2
,
τ
,
t


,

0
2


)



*



:






t

=
1

,





,
L
,


(



μ

ran
,
2
,
τ
,

L
+
1





(

τ
,

-
1


)


,

s

ran
,
2
,
τ
,

L
+
1



,
0
,

0
8

,


η



ran
,
2
,
τ
,

L
+
1



,

0
2


)



*



)


,






sk
L

:=

(


k

L
,
dec

*

,


{

k

L
,

del


(

τ
,
ι

)



*

}



τ
=

L
+
1


,





,

d
;

ι
=
1


,
2


,


{


k

L
,
ran
,
1
,
j

*

,

k

L
,
ran
,
2
,
τ

*


}



j
=
1

,





,


2

L

;

τ
=

L
+
1



,





,
d



)


,








return












sk
L

.



















Enc


(

pk
,

m


T


,


(


x
1

,





,

x
L


)



q
L



)




:












ω
,
ζ
,

φ
0

,

φ

t
,
1


,

φ

t
,
2


,


σ
t




U



q












for











t
=
1

,





,
L
,






c
1

:=

(



(

ω
,
0
,
ζ
,
0
,

φ
0


)


0


,




(




σ
1



(

1
,
t

)




ω


(

1
,

x
t


)



,

0
8

,

0
2

,

φ

t
,
1


,

φ

t
,
2



)




:






t

=
1

,





,
L

)


,










c
2

:=


g
T
ζ


m


,









ct
:=

(


c
1

,

c
2


)


,









return






ct
.








[

Formula





193

]













Dec


(

pk
,


k

L
,
dec
,

*


ct


)




:














m


:=


c
2

/

e


(


c
1

,

k

L
,
dec

*


)




,









return







m


.








[

Formula





194

]














Delegate
L



(

pk
,

sk
L

,

v

L
+
1



)




:











for












j


=
1

,





,


2


(

L
+
1

)


;













τ
=

L
+
2


,





,

d
;

ι
=
1


,

2
;













μ

del
,

(

τ
,
ι

)




,

μ

ran
,
2
,
τ



,

ϕ

del
,

(

τ
,
ι

)



,

ϕ

ran
,
2
,
τ


,


ψ





U



q


,





p
dec
*

,

p

del
,

(

τ
,
ι

)


*

,

p

ran
,
1
,

j



*

,



p

ran
,
2
,
τ

*




R



CoreDel
L




(

pk
,

sk
L

,

v

L
+
1



)


,








where













CoreDel
L



(

pk
,

sk
L

,

v

L
+
1



)




:













μ
t


,
ξ
,


α
j




U



q












for











t
=
1

,





,


L
+
1

;













j
=
1

,





,


2

L

+
1

,








return






[

Formula





195

]








p
*

:=





t
=
1


L
+
1





μ
t





(


tb
1
*

-

b
2
*


)



t





+

ξ


(



v

L
+
1




k

L
,

del


(


L
+
1

,
1

)



*


-

k

L
,

del


(


L
+
1

,
2

)



*


)


+




j
=
1


2

L





α
j



k

L
,
ran
,
1
,
j

*



+


α


2

L

+
1




k

L
,
ran
,
2
,

L
+
1


*




,





r
dec
*

,



r

ran
,
1
,

j



*




U


span







(

b

0
,
4

*

)



0



,


{



(

b
13
*

)



t







,


(

b
14
*

)



t




}



t
=
1

,

,

L
+
1







,





r

del
,

(

τ
,
ι

)


*

,



r

ran
,
2
,
τ

*




U


span







(

b

0
,
4

*

)



0



,


{



(

b
13
*

)



t







,


(

b
14
*

)



t




}



t
=
1

,

,

L
+
1

,
τ






,










k


L
+
1

,
dec

*

:=


k

L
,
dec

*

+

p
dec
*

+

r
dec
*



,














k


L
+
1

,

dec


(

τ
,
ι

)



*

:=


p

del


(

τ
,
ι

)


*

+



μ

del


(

τ
,
ι

)






(


τ






b
1
*


-

b
2
*


)



(
τ
)


+


ϕ

del
,

(

τ
,
ι

)





k

L
,
ran
,
2
,
τ

*


+


ψ




k

L
,

del


(

τ
,
ι

)



*


+

r

del


(

τ
,
ι

)


*



,










k


L
+
1

,
ran
,

1


j




*

:=


p

ran
,
1
,

j



*

+

r

ran
,
1
,

j



*



,






k


L
+
1

,
ran
,
2
,
τ

*

:=


p

ran
,
2
,
τ

*

+



μ

ran
,
2
,
τ

*



(


τ






b
1
*


-

b
2
*


)



(
τ
)


+


ϕ

ran
,
2
,
τ




k

L
,
ran
,
2
,
τ

*


+

r

ran
,
2
,
τ

*



,






sk

L
+
1


:=

(


k


L
+
1

,
dec

*

,


{

k


L
+
1

,

del


(

τ
,
ι

)



*

}



τ
=

L
+
2


,





,

d
;

ι
=
1


,
2


,


{


k

L
,
ran
,
1
,

j



*

,

k

L
,
ran
,
2
,
τ

*


}




j


=
1

,





,


2


(

L
+
1

)


;

τ
=

L
+
2



,





,
d



)


,








return












sk

L
+
1


.













Embodiment 5

This embodiment describes a signature scheme. In particular, this embodiment describes a signature scheme based on the CP-FE scheme described in Embodiment 3.


First, the construction of the signature scheme will be described.


Second, the configuration of a cryptographic system 10 that implements the signature scheme will be described.


Third, the signature scheme will be described in detail.


<1. Construction of Signature Scheme>


The signature scheme consists of four algorithms: Setup, KeyGen, Sig, and Ver.


(Setup)


A Setup algorithm is a probabilistic algorithm that takes as input a security parameter λ, and outputs a public parameter pk and a master key sk.


(KeyGen)


A KeyGen algorithm is a probabilistic algorithm that takes as input an attribute set Γ:={(t, x{right arrow over ( )}t)|x{right arrow over ( )}tεFqn, 1≦t≦d}, the public parameter pk, and the master key sk, and outputs a signature key skΓ.


(Sig)


A Sig algorithm is a probabilistic algorithm that takes as input a message m, the signature key skΓ, an access structure S:=(M, ρ), and the public parameter pk, and outputs signature data sig.


(Ver)


A Ver algorithm is an algorithm that takes as input the message m, the access structure S:=(M, ρ), the signature data sig, and the public parameter pk, and outputs a value “1” indicating success of verification of the signature, or a value “0” indicating failure of verification of the signature.


<2. Configuration of Cryptographic System 10 that Implements Signature Scheme>



FIG. 30 is a configuration diagram of the cryptographic system 10 that implements the signature scheme according to Embodiment 5.


The cryptographic system 10 includes a key generation device 100, a signature device 500, and a verification device 600.


The key generation device 100 executes the Setup algorithm taking as input a security parameter λ, and thus generates a public parameter pk and a master key sk. Then, the key generation device 100 publishes the generated public parameter pk. The key generation device 100 also executes the KeyGen algorithm taking as input an attribute set Γ, and thus generates a signature key skΓ, and distributes the signature key skΓ to the signature device 500 in secrecy.


The signature device 500 executes the Sig algorithm taking as input a message m, an access structure S, the public parameter pk, and the signature key skΓ, and thus generates signature information s{right arrow over ( )}*. The signature device 500 transmits the generated signature information s{right arrow over ( )}*, the message m, and the access structure S to the verification device 600.


The verification device 600 executes the Ver algorithm taking as input the signature information s{right arrow over ( )}*, the message m, the access structure S, and the public parameter pk, and outputs a value “1” or a value “0”.


<3. Signature Scheme in Detail>


With reference to FIGS. 31 to 37, the signature scheme will be described, and the function and operation of the cryptographic system 10 that implements the signature scheme will be described.



FIG. 31 is a configuration diagram of the key generation device 100 according to Embodiment 5. FIG. 32 is a configuration diagram of the signature device 500 according to Embodiment 5. FIG. 33 is a configuration diagram of the verification device 600 according to Embodiment 5.



FIGS. 34 and 35 show flowcharts illustrating the operation of the key generation device 100. FIG. 34 is a flowchart illustrating the process of the Setup algorithm. FIG. 35 is a flowchart illustrating the process of the KeyGen algorithm. FIG. 36 is a flowchart illustrating the operation of the signature device 500 and illustrating the process of the Sig algorithm. FIG. 37 is a flowchart illustrating the operation of the verification device 600 and illustrating the process of the Ver algorithm.


In the following description, H:=(KHλ, Hhkλ,D) is a collision resistant hash function (see Non-Patent Literature 30). A collision resistant hash function is a hash function for which it is difficult to find two inputs that hash to the same output.


Specifically, a collision resistant hash function family H associated with the algorithm Gbpg and a polynomial poly(λ) specify two items:


1. A family of key spaces is indexed by λ. Each such key space is a probability space on bit strings denoted by KHλ. There must exist a probabilistic polynomial-time algorithm whose output distribution on input 1λ is equal to KHλ.


2. A family of hash functions is indexed by λ, hk randomly selected from KHλ, and D:={0, 1}poly(λ), where each such function Hhkλ,D maps an element of D to an element of Fqx with q being the first element of output paramG of algorithm Gbpg(1λ). There must exist a deterministic polynomial-time algorithm that outputs Hhkλ,D(d) on input 1λ, hk, and dεD.


The function and operation of the key generation device 100 will be described.


The key generation device 100 includes a master key generation unit 110, a master key storage unit 120, an information input unit 130, a decryption key generation unit 140, and a key distribution unit 150. The decryption key generation unit 140 includes a random number generation unit 143 and a key element generation unit 144.


With reference to FIG. 34, the process of the Setup algorithm will be described.


(S1301) is basically the same as (S101) in Embodiment 2 shown in FIG. 9. There are differences, however, in that the process of (4) through (8) is executed for t=0, 1, and d+1 and that N0 is 1+u0+w0+z0. Note that Nd+1 is 2+ud+1+wd+1+zd+1 and that ud+1, wd+1, and zd+1 are integers of 1 or more.


(S1302: Hash Key Generation Step)


Using the processing device, the master key generation unit 110 computes Formula 196, and thus generates a hash key hk randomly.









hk



R



KH
λ





[

Formula





196

]







(S1303: Public Parameter Generation Step)


Using the processing device, the master key generation unit 110 generates a subbasis B^0 of the basis B0, a subbasis B^ of the basis B, a subbasis B^d+1 of the basis Bd+1, a subbasis B^*0 of the basis B*0, a subbasis B^* of the basis B*, and a subbasis B^*d+1 of the basis B*d+1, as indicated in Formula 197, the bases B0, B, Bd+1, B*0, B^*, and B*d+1 having been generated in (S1301).

custom character0:=(b0,1,b0,1+u0+w0+1, . . . ,b0,1+u0+w0+z0)
custom character:=(b1, . . . ,b2+n,b2+n+u+w+1, . . . ,b2+n+u+w+z),
custom characterd+1:=(bd+1,1,bd+1,2,bd+1,2+ud+1+wd+1+1, . . . ,bd+1,2+ud+1+wd+1+zd+1)
custom character*0:=(b*0,1+u0+1, . . . ,b0,1+u0+w0),
custom character*:=(b*1, . . . ,b2+n,b2+n+u+1, . . . ,b2+n+u+w),
custom character*d+1:=(b*d+1,1,b*d+1,2,b*d+1,2+ud+1+1, . . . ,b*d+1,2+ud+1+wd+1)  [Formula 197]


The master key generation unit 110 generates a public parameter pk by putting together the generated subbasis B^0, subbasis B^, subbasis B^d+1, subbasis B^*0, subbasis B^*, and subbasis B^*d+1, the security parameter λ(1λ) inputted in (S1301), param generated in (S1301), and the hash key hk generated in (S1302).


(S1304: Master Key Generation Step)


The master key generation unit 110 generates a master key sk which is constituted by a basis vector b*0,1 of the basis B^*0.


(S1305: Master Key Storage Step)


The master key storage unit 120 stores the public parameter pk generated in (S1303) in the storage device. The master key storage unit 120 also stores the master key sk generated in (S1304) in the storage device.


In brief, in (S1301) through (S1304), the key generation device 100 executes the Setup algorithm indicated in Formula 198, and thus generates the public parameter pk and the master key sk. In (S1305), the key generation device 100 stores the generated public parameter pk and master key sk in the storage device.


The public parameter is published via the network, for example, and is made available for the signature device 500 and the verification device 600.















Setup


(

1
λ

)













hk



R



KH
λ


,






(

param
,

(


0

,

0
*


)

,

(

,

*


)

,

(



d
+
1


,


d
+
1

*


)


)




R




𝒢
ob



(

1
λ

)



,












0

:=

^



(


b

0
,
1


,

b

0
,

1
+

u
0

+

w
0

+
1



,





,

b

0
,

1
+

u
0

+

w
0

+

z
0





)


,











:=

^



(


b
1

,





,

b

2
+
n


,

b

2
+
n
+
u
+
w
+
1


,





,

b

2
+
n
+
u
+
w
+
z



)


,













d
+
1


:=

^



(


b


d
+
1

,
1


,

b


d
+
1

,
2


,

b


d
+
1

,

2
+

u

d
+
1


+

w

d
+
1


+
1



,

,

b


d
+
1

,

2
+

u

d
+
1


+

w

d
+
1


+

z

d
+
1






)


,













0
*

:=


^



(


b

0
,

1
+

u
0

+
1


*

,





,

b

0
,

1
+

u
0

+

w
0





)


,












*

:=

^



(


b
1
*

,





,

b

2
+
n

*

,

b

2
+
n
+
u
+
1

*

,





,

b

2
+
n
+
u
+
w

*


)


,









d
+
1

*

:=

^



(


b


d
+
1

,
1

*

,

b


d
+
1

,
2

*

,

b


d
+
1

,

2
+

u

d
+
1


+
1


*

,





,

b


d
+
1

,

2
+

u

d
+
1


+

w

d
+
1




*


)


,









sk
:=

b

0
,
1

*


,





pk
:=



(


1
λ

,
hk
,
param
,


0

^

,

^

,



d
+
1


^

,


0
*

^

,




*

,

^





d
+
1

*

^



)

.








return






sk


,

pk
.







[

Formula





198

]







With reference to FIG. 35, the process of the KeyGen algorithm will be described.


(S1401: Information Input Step)


Using the input device, the information input unit 130 takes as input an attribute set Γ:={(t, x{right arrow over ( )}t:=(xt,1, . . . , xt,nεFqn))|1≦t≦d}. Note that attribute information of the user of a signature key skΓ is set in the attribute set Γ, for example.


(S1402: Random Number Generation Step)


Using the processing device, the random number generation unit 143 generates random numbers, as indicated in Formula 199.











δ



U



q
×


,







φ


0

:=

φ

0
,
1



,





,


φ

0
,

w
0






U



q

w
0



,







φ


t

:=

φ

t
,
1



,





,


φ

t
,
w





U



q
w








for







t
=
1

,





,
d
,







φ




d
+
1

,
1


:=

φ


d
+
1

,
1
,
1



,





,


φ


d
+
1

,
1
,

w

d
+
1







U



q

w

d
+
1




,







φ




d
+
1

,
2


:=

φ


d
+
1

,
2
,
1



,





,


φ


d
+
1

,
2
,

w

d
+
1







U



q

w

d
+
1




,





[

Formula





199

]







(S1403: Key Element Generation Step)


Using the processing device, the key element generation unit 144 generates an element k*0 of the signature key skΓ, as indicated in Formula 200.










k
0
*

:=


(

δ
,


0

u
0





u
0



,



φ


0




w
0



,


0

z
0





z
0




)


0
*






[

Formula





200

]







Using the processing device, the key element generation unit 144 also generates an element k*t of the signature key skΓ for each integer t included in the attribute set Γ, as indicated in Formula 201.











k
t
*

:=


(




δ


(

1
,
t

)


,


δ






x
t








2
+
n



,


0
u



u


,




φ


t



w





0
z



z




)


*










for




(

t
,


x


t


)


Γ





[

Formula





201

]







Using the processing device, the key element generation unit 144 also generates elements k*d+1 and k*d+2 of the signature key skΓ, as indicated in Formula 202.











k


d
+
1

,
1

*

:=


(



δ


(

1
,
0

)




2


,




0

u

d
+
1



,




u

d
+
1









φ




d
+
1

,
1


,




w

d
+
1







0

z

d
+
1






z

d
+
1






)



d
+
1

*



,






k


d
+
1

,
2

*

:=


(



δ


(

0
,
1

)




2


,




0

u

d
+
1



,




u

d
+
1









φ




d
+
1

,
2


,




w

d
+
1







0

z

d
+
1






z

d
+
1






)



d
+
1

*







[

Formula





202

]







(S1404: Key Distribution Step)


Using the communication device and via the network, for example, the key distribution unit 150 distributes the signature key skΓ having, as elements, the attribute set Γ inputted in (S1401) and k*0, k*t, k*d+1, and k*d+2 generated in (S1403) to the signature device 500 in secrecy. As a matter of course, the signature key skΓ may be distributed to the signature device 500 by another method.


In brief, in (S1401) through (S1403), the key generation device 100 executes the KeyGen algorithm indicated in Formula 203, and thus generates the signature key skΓ. In (S1404), the key generation device 100 distributes the generated signature key skΓ to the signature device 500.










KeyGen


(

pk
,
sk
,

Γ
:=

{


(

t
,



x


t

:=


(


x

t
,
1


,





,

x

t
,
n



)




q
n


\


{

0


}





)



1

t

d


}



)













δ



U



q
×


,











φ


0




U



q

w
0



,











φ


t




U



q
w












for











t
=
1

,





,
d
,










φ




d
+
1

,
1


,



φ




d
+
1

,
2





U



q

w

d
+
1




,










k
0
*

:=


(

δ
,


0

u
0





u
0



,



φ


0




w
0



,


0

z
0





z
0




)


0
*















k
t
*

:=


(




δ


(

1
,
t

)


,


δ






x
t








2
+
n



,


0
u



u


,




φ


t



w





0
z



z




)


*












for












(

t
,


x


t


)


Γ

,










k


d
+
1

,
1

*

:=


(



δ


(

1
,
0

)




2


,




0

u

d
+
1



,




u

d
+
1









φ




d
+
1

,
1


,




w

d
+
1







0

z

d
+
1






z

d
+
1






)



d
+
1

*



,










k


d
+
1

,
2

*

:=


(



δ


(

0
,
1

)




2


,




0

u

d
+
1



,




u

d
+
1









φ




d
+
1

,
2


,




w

d
+
1







0

z

d
+
1






z

d
+
1






)



d
+
1

*



,





T
:=


{

0
,

(


d
+
1

,
1

)

,

(


d
+
1

,
2

)


}



{


t


1

t

d


,


(

t
,


x


t


)


Γ


}



,








return












sk
Γ

:=


(

Γ
,


{

k
t
*

}


t

T



)

.






[

Formula





203

]







The function and operation of the signature device 500 will be described.


The signature device 500 includes a signature key acquisition unit 510, an information input unit 520, a complementary coefficient computation unit 530, a signature data generation unit 540, and a data transmission unit 550. The signature data generation unit 540 includes a random number generation unit 541 and a signature element generation unit 542.


With reference to FIG. 36, the process of the Sig algorithm will be described.


(S1501: Signature Key Acquisition Step)


Using the communication device and via the network, for example, the signature key acquisition unit 510 obtains the signature key skΓ generated by the key generation device 100. The signature key acquisition unit 510 also obtains the public parameter pk generated by the key generation device 100.


(S1502: Information Input Step)


Using the input device, the information input unit 520 takes as input an access structure S:=(M, ρ). Note that a matrix M of the access structure S is to be set according to the conditions of a system to be implemented.


Using the input device, the information input unit 520 also takes as input a message m to which a signature is to be appended.


(S1503: Span Program Computation Step)


Using the processing device, the complementary coefficient computation unit 530 checks whether or not the access structure S inputted in (S1502) accepts the attribute set Γ included in the signature key skΓ obtained in (S1501).


The method for checking whether or not the access structure accepts the attribute set is the same as that described in “5. Concept for implementing functional encryption in Embodiment 1”.


If the access structure S accepts the attribute set Γ (accept in S1503), the complementary coefficient computation unit 530 advances the process to (S1504). If the access structure S rejects the attribute set Γ (reject in S1503), the complementary coefficient computation unit 530 ends the process.


(S1504: Complementary Coefficient Computation Step)


Using the processing device, the complementary coefficient computation unit 530 computes I and a constant (complementary coefficient) αi for each integer i included in I such that Formula 204 is satisfied.

Σi=IαiMi:={right arrow over (1)}
and I{iε{1, . . . ,L}|[ρ(i)=(t,{right arrow over (v)}i)custom character(t,{right arrow over (x)}t)εΓcustom character{right arrow over (v)}i·{right arrow over (x)}t=0]
custom character[ρ(i)=custom character(t,{right arrow over (v)}i)custom character(t,{right arrow over (x)}t)εΓcustom character{right arrow over (v)}i·{right arrow over (x)}t≠0]}  [Formula 204]


(S1505: Random Number Generation Step)


Using the processing device, the random number generation unit 541 generates random numbers, as indicated in Formula 205.










ξ



U



q
×


,






(

β
i

)




U



{



(


β
1

,





,

β
L


)






i
=
1

L




β
i



M
i




=

0



}






[

Formula





205

]







(S1506: Signature Element Generation Step)


Using the processing device, the signature element generation unit 542 generates a signature element s*0 which is an element of signature data sig, as indicated in Formula 206.

s*0:=ξk*0+r*0  [Formula 206]


Note that r*0 is defined by Formula 207 (see Formula 110 through Formula 112 and explanations thereof).











r
0
*




U


span






b

0
,

1
+

u
0

+
1


*

,





,

b

0
,

1
+

u
0

+

w
0



*








[

Formula





207

]







Using the processing device, the signature element generation unit 542 also generates a signature element s*, which is an element of the signature data sig for each integer i=1, . . . , L, as indicated in Formula 208.

s*i:=γi·ξk*tl=1nyi,l·b*t,l+r*i, for 1≦i≦L  [Formula 208]


Note that r*i is defined by Formula 209.











r
i
*




U


span






b

t
,

2
+
n
+
u
+
1


*

,





,

b

t
,

2
+
n
+
u
+
w


*








[

Formula





209

]







Note that γi and y{right arrow over ( )}i:=yi,i′ (i′=1, . . . , n) are defined by Formula 210.











γ
i

,



y


i

:=


(


y

i
,
1


,

,

y

i
,
n



)






are





defined





as








if








i


I


ρ


(
i
)




=

(

t
,


v


i


)


,






γ
i

:=

α
i


,







y


i




U



{




y


i





y


i

·


v


i



=


0


y

i
,
1



=

β
i



}


,




if









i


I


ρ


(
i
)




=



(

t
,


v


i


)



,






γ
i

:=


α
i




v


i

·


x


i




,







y


i




U



{




y


i





y


i

·


v


i



=

β
i


}


,




if









i


I


ρ


(
i
)




=

(

t
,


v


i


)


,






γ
i

:=
0

,







y


i




U



{




y


i





y


i

·


v


i



=


0


y

i
,
1



=

β
i



}


,




if









i


I


ρ


(
i
)




=



(

t
,


v


i


)



,






γ
i

:=
0

,







y


i




U



{




y


i





y


i

·


v


i



=

β
i


}







[

Formula





210

]







Using the processing device, the signature element generation unit 542 also generates a signature element s*L+1 which is an element of the signature data sig, as indicated in Formula 211.

s*L+1:=ξ(k*d+1,1+Hhkλ,D(mcustom characterk*d+1,2)+r*L+1  [Formula 211]


Note that r*L+1 is defined by Formula 212.











r

L
+
1

*




U


span






b


d
+
1

,

2
+

u

d
+
1


+
1


*

,





,

b


d
+
1

,

2
+

u

d
+
1


+

w

d
+
1




*








[

Formula





212

]







(S1507: Data Transmission Step)


Using the communication device and via the network, for example, the data transmission unit 550 transmits the signature data sig including the signature element s*0, the signature element s*i (i=1, . . . , L), the signature element s*L+1, the message m, and the access structure S:=(M, ρ) to the verification device 600. As a matter of course, the signature data sig may be transmitted to the verification device 600 by another method.


In brief, in (S1501) through (S1506), the signature device 500 executes the Sig algorithm indicated in Formula 213, and thus generates the signature data sig. In (S1507), the signature device 500 transmits the generated signature data sig to the verification device 600.
















Sig


(

pk
,

sk
Γ

,
m
,

:=

(

M
,
ρ

)



)




:














If






:=



(

M
,
ρ

)






accepts





Γ

:=

{

(

t
,


x


t


)

}



,









then





compute





I





and







{

α
i

}


i

I







such





that












i

I












α
i



M
i



:=

1












and







I


{


i


{

1
,





,
L

}





[


ρ


(
i
)


=




(

t
,


v


i


)



(

t
,


x


t


)





Γ



v


i


·


x


t



=
0


]



[


ρ


(
i
)


=





(

t
,


v


i


)



(

t
,


x


t


)






Γ



v


i


·


x


t



0




]



}


,









ξ



U



q
x


,


(

β
i

)




U



{



(


β
1

,





,

β
L


)






i
=
1

L








β
i



M
i




=

0



}


,










s
0
*

:=


ξ






k
0
*


+

r
0
*



,









where











r
0
*




U



span





b

0
,

1
+

u
0

+
1



,





,

b

0
,

1
+

u
0

+

w
0



*







,










s
i
*

:=




γ
i

·
ξ







k
t
*


+




t
=
1

n








y

i
,
t


·

b

t
,
i

*



+

r
i
*



,


for





1


i

L

,









where











r
i
*




U



span





b

t
,

2
+
n
+
u
+
1



,





,

b

t
,

2
+
n
+
u
+
w


*







,









and










γ
i


,



y


i

:=




(


y

i
,
1


,





,

y

i
,
n



)






are





defined





as









if





i



I


ρ


(
i
)




=

(

t
,


v


i


)



,


γ
i

:=

α
i


,











y


i




U



{




y


i





y


i

·


v


i



=


0


y

i
,
1



=

β
i



}


,











if





i



I


ρ


(
i
)




=



(

t
,


v


i


)



,










γ
i

:=


α
i




v


i

·


x


t




,











y


i




U



{




y


i





y


i

·


v


i



=

β
i


}


,











if





i



I


ρ


(
i
)




=

(

t
,


v


i


)


,


γ
i

:=
0

,











y


i




U



{




y


i





y


i

·

v
i



=


0


y

i
,
1



=

β
i



}


,











if





i



I


ρ


(
i
)




=



(

t
,


v


i


)



,










γ
i

:=
0

,



y


i




U



{




y


i





y


i

·


v


i



=

β
i


}


,










s

L
+
1

*

:=

ξ
(



k


d
+
1

,
1

*

+


H
hk

λ
,
D




(

m




)

·

k


d
+
1

,
2

*



)


+

r

L
+
1

*


,










where






r

L
+
1

*





U



span





b


d
+
1

,

2
+

u

d
+
1


+
1



,





,


b


d
+
1

,

2
+

u

d
+
1




*

+

w

d
+
1








,










return







s


*


:=


(


s
0
*

,





,

s

L
+
1

*


)

.











[

Formula





213

]







The function and operation of the verification device 600 will be described.


The verification device 600 includes a public parameter acquisition unit 610, a data receiving unit 620, a verification data generation unit 630, and a pairing operation unit 640. The verification data generation unit 630 includes an f vector generation unit 631, an s vector generation unit 632, a random number generation unit 633, and a verification element generation unit 634.


With reference to FIG. 37, the process of the Ver algorithm will be described.


(S1601: Public Parameter Acquisition Step)


Using the communication device and via the network, for example, the public parameter acquisition unit 610 obtains the public parameter pk generated by the key generation device 100.


(S1602: Signature Data Reception Step)


Using the communication device and via the network, for example, the data receiving unit 620 receives the signature data sig transmitted by the signature device 500.


(S1603: f Vector Generation Step)


Using the processing device, the f vector generation unit 631 randomly generates a vector f{right arrow over ( )} having r pieces of elements, as indicated in Formula 214.










f





U



q
r





[

Formula





214

]







(S1604: s Vector Generation Step)


Using the processing device and based on the (L rows×r columns) matrix M of the access structure S included in the signature data sig received in (S1602) and the vector f{right arrow over ( )} having r pieces of elements generated in (S1603), the s vector generation unit 632 generates a vector s{right arrow over ( )}T, as indicated in Formula 215.

{right arrow over (s)}T:=(s1, . . . ,sL)T:=M·{right arrow over (f)}T  [Formula 215]


Using the processing device and based on the vector f{right arrow over ( )} generated in (S1603), the s vector generation unit 632 also generates a value s0, as indicated in Formula 216. Note that 1{right arrow over ( )} is a vector which has a value 1 in all its elements.

s0:={right arrow over (1)}·{right arrow over (f)}T  [Formula 216]


(S1605: Random Number Generation Step)


Using the processing device, the random number generation unit 633 generates random numbers, as indicated in Formula 217.












η


0

:=

η

0
,
1



,





,


η

0
,

z
0






U



q

z
0



,







η



L
+
1


:=

η


L
+
1

,
1



,





,


η


L
+
1

,

z

d
+
1







U



q

z

d
+
1




,





θ

L
+
1


,


s

L
+
1





U



q


,






for





1


i

L

,






if






ρ


(
i
)



=


(

t
,


v


i


)



μ
i



,






θ
i




U



q


,



η


i




U



q
z


,






if






ρ


(
i
)



=





(

t
,


v


i


)



μ
i





U



q




,



η


i




U



q
z






[

Formula





217

]







(S1606: Verification Element Generation Step)


Using the processing device, the verification element generation unit 634 generates a verification element c0 which is an element of a verification key, as indicated in Formula 218.










c
0

:=


(



-

s
0


-

s

L
+
1



,


0

u
0





u
0



,


0

w
0





w
0



,



η


0




z
0




)



0






[

Formula





218

]







Using the processing device, the verification element generation unit 634 also generates a verification element ci which is an element of the verification key for each integer i=1, . . . , L, as indicated in Formula 219.












for





1


i

L

,






if






ρ


(
i
)



=

(

t
,

v
i


)











if






s
i
*




t


,

return





0










else






c
i


:=


(






μ
i



(

t
,

-
1


)


,



s
i



e
1


+


θ
i



v








2
+
n



i

,


0
u



u


,


0
w



w


,


η




z



)




,






if






ρ


(
i
)



=



(

t
,


v


i


)












if






s
i
*




t


,

return





0









else






c
i


:=


(






μ
i



(

t
,

-
1


)


,


s
i



v







2
+
n



i

,


0
u



u


,


0
w



w


,



η




z


i


)








[

Formula





219

]







Using the processing device, the verification element generation unit 634 also generates a verification element cL+1 which is an element of the verification key, as indicated in Formula 220.











[

Formula





220

]








c

L
+
1


:=


(





s

L
+
1


-


θ

L
+
1





H
hk

λ
,
D


(


m



)


,

θ

L
+
1


,






2





0

u

d
+
1






u

d
+
1





,


0

w

d
+
1






w

d
+
1




,



η



L
+
1





z

d
+
1





)




d
+
1







(S1607: First Pairing Operation Step)


Using the processing device, the pairing operation unit 640 computes a pairing operation e (b0,1, s*0).


If the result of computing the pairing operation e (b0,1, s*0) is a value 1, the pairing operation unit 640 outputs a value 0 indicating failure of verification of the signature and ends the process. If the result of computing the pairing operation e (b0,1, s*0) is other than a value 1, the pairing operation unit 640 advances the process to S1608.


(S1608: Second Pairing Operation Step)


Using the processing device, the pairing operation unit 640 computes a pairing operation indicated in Formula 221.

Πi=0L+1e(ci,s*i)  [Formula 221]


If the result of computing the pairing operation indicated in Formula 221 is a value 1, the pairing operation unit 640 outputs a value 1 indicating success of verification of the signature. If the result is any other value, the pairing operation unit 640 outputs a value 0 indicating failure of verification of the signature.


In brief, in (S1601) through (S1608), the verification device 600 executes the Ver algorithm indicated in Formula 222, and thus verifies the signature data sig.















Ver


(

pk
,
m
,

:=

(

M
,
ρ

)


,


s


*


)














f





U



q
r


,











s


T

:=



(


s
1

,





,

s
L


)

T

:=

M
·


f


T




,










s
0

:=


1


·


f


T



,











η


0




U



q

z
0



,



η



L
+
1





U



q

z

d
+
1




,



θ

L
+
1




s

L
+
1






U



q


,










c
0

:=


(



-

s
0


-

s

L
+
1



,


0

u
0





u
0



,


0

w
0





w
0



,



η


0




z
0




)



0



,










for





1


i

L

,










if





ρ


(
i
)


=

(

t
,


v


i


)


,










if






s
i
*




t


,

return





0

,









else






μ
i


,


θ
i




U



q


,



η


i




U



q
z


,










c
i

:=


(






μ
i



(

t
,

-
1


)


,



s
i



e
1


+


θ
i



v








2
+
n



i

,


0
u



u


,


0
w



w


,


η




z



)




,










if






ρ


(
i
)



=



(

t
,


v


i


)



,










if






s
i
*




t


,

return





0

,










else






μ
i





U



q


,



η


i




U



q
z


,










c
i

:=


(






μ
i



(

t
,

-
1


)


,


s
i



v







2
+
n



i

,


0
u



u


,


0
w



w


,


η




z



)




,






c

L
+
1


:=


(





s

L
+
1


-


θ

L
+
1





H
hk

λ
,
D


(


m



)


,

θ

L
+
1


,






2





0

u

d
+
1






u

d
+
1





,


0

w

d
+
1






w

d
+
1




,



η



L
+
1





z

d
+
1





)




d
+
1

















return





0





if






e


(


b

0
,
1


,

s
0
*


)



=
1

,










return





1





if









i
=
0


L
+
1








e


(


c
i

,

s
i
*


)




=
1

,









return





0






otherwise
.








[

Formula





222

]







As described above, as in the cryptographic systems 10 according to Embodiments 2 to 4, in the cryptographic system 10 according to Embodiment 5, the index parts are provided, so that the bases that are used for every attribute category can be constructed as the common bases (basis B and basis B*). As a result, only the basis B and the basis B* need to be included in a public parameter, eliminating the need for reissuing the public parameter when an attribute category is to be added at a later stage.


As in Embodiments 2 to 4, for the index parts, it is required that 0 be obtained as a result of an inner-product operation of the index parts. Therefore, although the 2-dimensional index parts, namely the basis vectors b*1 and b*2 and the basis vectors b1 and b2, are employed in the above description, the index parts are not limited to 2-dimensional and may be 3-dimensional or higher-dimensional. The values assigned to the index parts are not limited to those described above, and a different assignment arrangement may be employed.


The signature scheme based on the functional encryption scheme has been described above. However, as explained in Embodiment 3 that the functional encryption scheme can be modified into an attribute-based encryption scheme, so the signature scheme based on the functional encryption scheme can be modified into a signature scheme based on the attribute-based encryption scheme.


Embodiment 6

This embodiment describes a multi-authority functional encryption scheme and a multi-authority signature scheme.


Multi-authority signifies the presence of a plurality of authorities who generate the user's decryption key (or signature key).


In an ordinary functional encryption, the security of the whole system depends on one certain party (authority). For example, in the cryptographic system 10 described in Embodiment 2 or 3, the security of the whole system depends on the key generation device 100. If the master secret key sk which is the secret key of the key generation device 100 is compromised, the security of the whole system will be broken.


With the multi-authority scheme, however, even if the security of some authority is broken or the secret key (master key) of some authority is compromised, only part of the system stops functioning, and the remaining portion of the system can function properly.



FIG. 38 is an explanatory drawing of the multi-authority. In FIG. 38, a narrowly-defined cryptographic process is used as an example.


In FIG. 38, a government office manages attributes such as address, telephone number, and age. The police manage attributes such as type of driver's license. Company A manages attributes such as position in Company A and belonging department in Company A. A decryption key 1 associated with the attributes managed by the government office is issued by the government office. A decryption key 2 associated with the attributes managed by the police is issued by the police. A decryption key 3 associated with the attributes managed by Company A is issued by Company A.


A decryptor who decrypts a ciphertext decrypts the ciphertext using a decryption key formed by putting together the decryption keys 1, 2, and 3 issued by the respective authorities such as the government office, the police, and Company A. That is, when seen from the decryptor, a decryption key formed by putting together the decryption keys issued by the respective authorities is the single decryption key issued to him or her.


For example, in a case where the master key of Company A is compromised, although the cryptographic processing system does not function regarding the attributes of Company A, it functions regarding the attributes managed by the other authorities. That is, concerning the attributes managed by Company A there is a risk of decryption by a user having attributes other than the specified attributes. However, concerning attributes other than those managed by Company A, decryption is possible only by a user having the specified attributes.


As is seen from the example of FIG. 38, according to the functional encryption, it is normal that a plurality of authorities are present, and that each authority manages a certain category (subspace) or definition range in the attributes and issues (a part of) a decryption key regarding the attribute of the user in this category.


When any party can serve as an authority and issue (a part of) a decryption key without interacting with the other parties, and each user can obtain (a part of) the decryption key without interacting with the other parties, this scheme is called a decentralized multi-authority scheme.


For example, if a central authority exists, the scheme is not decentralized. A central authority is an authority superior to the other authorities. If the security of the central authority is broken, the security of every authority will be broken.


Non-Patent Literature 31 describes a decentralized multi-authority functional encryption scheme, and Non-Patent Literature 30 describes a non-decentralized multi-authority signature scheme. As in the case of the encryption scheme and the signature scheme described in the above embodiments, the schemes described in Non-Patent Literature 30 and Non-Patent Literature 31 can be constructed such that there is no need to reissue a public parameter when an attribute category is to be added.



FIG. 39 is an explanatory drawing of a functional encryption scheme that allows for addition of an attribute category in a case of multi-authority.


In FIG. 39, as in FIG. 38, a government office manages attributes such as address, telephone number, and age. The police manage attributes such as type of driver's license. Company A manages attributes such as position in Company A and belonging department in Company A. A decryption key 1 associated with the attributes managed by the government office is issued by the government office. A decryption key 2 associated with the attributes managed by the police is issued by the police. A decryption key 3 associated with the attributes managed by Company A is issued by Company A.


Note here that the government office generates a basis B^1 and a basis B^*1 as a public parameter pk and a master secret key sk, respectively. Using the basis B^*1, the government office generates the decryption key 1 concerning the attributes such as address, telephone number, and age. Similarly, the police generate a basis B^2 and a basis B^*2 as a public parameter pk and a master secret key sk, respectively. Using the basis B^*2, the police generate the decryption key 2 concerning the attributes such as type of driver's license. Similarly, Company A generates a basis B^3 and a basis B^*3 as a public parameter pk and a master secret key sk, respectively. Using the basis B^*3, Company A generates the decryption key 3 concerning the attributes such as position in Company A and belonging department in Company A.


A sender generates a ciphertext by setting the attributes such as address, telephone number, and age using the basis B^1, setting the attributes such as type of driver's license using basis B^2, and setting the attributes such as position in Company A and belonging department in Company A using basis B^3. A decryptor decrypts the ciphertext using the decryption keys 1 to 3.


For example, when an attribute category managed by the government office is to be added, the attribute category can be added without reissuing the public parameter pk of the government office.


The functional encryption scheme that allows for addition of an attribute category has been described herein. However, the same concept can basically be applied to the signature scheme adapted from the functional encryption scheme.


Embodiment 7

In the above embodiments, the method for implementing the processes of the cryptographic primitives in the dual vector spaces has been described. In Embodiment 7, a method for implementing the processes of the cryptographic primitives in dual additive groups will be described.


More specifically, in the above embodiments, the processes of the cryptographic primitives are implemented in the cyclic group of the prime order q. When a ring R is expressed using a composite M as indicated in Formula 223, the processes of the cryptographic primitives described in the above embodiments can also be applied to an additive group having the ring R as a coefficient.

custom character:=custom character/Mcustom character  [Formula 223]

where

custom character: an integer; and


M: a composite number


By changing Fq to R in the algorithms described in the above embodiments, the processes of the cryptographic primitives in dual additive groups can be implemented.


From the view point of security proof, in the above embodiments, ρ(i) for each integer i=1, . . . , L may be limited to a positive tuple (t, v{right arrow over ( )}) or negative tuple custom character(t, v{right arrow over ( )}) for respectively different identification information t.


In other words, when ρ(i)=(t, v{right arrow over ( )}) or ρ(i)=custom character(t, v{right arrow over ( )}), let a function {tilde over (ρ)} be map of {1, . . . , L}→{1, . . . , d} such that {tilde over (ρ)}(i)=t. In this case, {tilde over (ρ)} may be limited to injection. Note that ρ(i) is ρ(i) in the access structure S:=(M, ρ(i)) described above.


A hardware configuration of the cryptographic system 10 (the key generation device 100, the encryption device 200, the decryption device 300, the key delegation device 400, the signature device 500, and the verification device 600) according to the embodiments will be described.



FIG. 40 is a diagram showing an example of a hardware configuration of the key generation device 100, the encryption device 200, the decryption device 300, the key delegation device 400, the signature device 500, and the verification device 600.


As shown in FIG. 40, each of the key generation device 100, the encryption device 200, the decryption device 300, the key delegation device 400, the signature device 500, and the verification device 600 includes the CPU 911 (also referred to as a Central Processing Unit, central processing device, processing device, arithmetic device, microprocessor, microcomputer, or processor) that executes programs. The CPU 911 is connected via a bus 912 to the ROM 913, the RAM 914, an LCD 901 (Liquid Crystal Display), the keyboard 902 (K/B), the communication board 915, and the magnetic disk device 920, and controls these hardware devices. In place of the magnetic disk device 920 (fixed disk device), a storage device such as an optical disk device or memory card read/write device may be employed. The magnetic disk device 920 is connected via a predetermined fixed disk interface.


The ROM 913 and the magnetic disk device 920 are examples of a nonvolatile memory. The RAM 914 is an example of a volatile memory. The ROM 913, the RAM 914, and the magnetic disk device 920 are examples of a storage device (memory). The keyboard 902 and the communication board 915 are examples of an input device. The keyboard 902 is an example of a communication device. The LCD 901 is an example of a display device.


The magnetic disk device 920, the ROM 913, or the like stores an operating system 921 (OS), a window system 922, programs 923, and files 924. The programs 923 are executed by the CPU 911, the operating system 921, and the window system 922.


The programs 923 store software and programs that execute the functions described in the above description as the “master key generation unit 110”, the “master key storage unit 120”, the “information input unit 130”, the “decryption key generation unit 140”, the “key distribution unit 150”, the “public parameter acquisition unit 210”, the “information input unit 220”, the “cipher data generation unit 230”, the “data transmission unit 240”, the “decryption key acquisition unit 310”, the “data receiving unit 320”, the “span program computation unit 330”, the “complementary coefficient computation unit 340”, the “pairing operation unit 350”, the “message computation unit 360”, the “decryption key acquisition unit 410”, the “information input unit 420”, the “delegation key generation unit 430”, the “key distribution unit 440”, the “signature key acquisition unit 510”, the “information input unit 520”, the “complementary coefficient computation unit 530”, the “signature data generation unit 540”, the “data transmission unit 550”, the “public parameter acquisition unit 610”, the “data receiving unit 620”, the “verification data generation unit 630”, the “pairing operation unit 640”, and the like. The programs 923 store other programs as well. The programs are read and executed by the CPU 911.


The files 924 store information, data, signal values, variable values, and parameters such as the “public parameter pk”, the “master secret key sk”, the “decryption keys skS and skΓ”, the “ciphertexts ctΓ and ctS”, the “access structure S”, the “attribute information”, and the “message m”, as the items of a “file” and “database”. The “file” and “database” are stored in a recording medium such as a disk or memory. The information, data, signal values, variable values, and parameters stored in the recording medium such as the disk or memory are read out to the main memory or cache memory by the CPU 911 through a read/write circuit, and used for operations of the CPU 911 such as extraction, search, look-up, comparison, calculation, computation, processing, output, printing, and display. The information, data, signal values, variable values, and parameters are temporarily stored in the main memory, cache memory, or buffer memory during the operations of the CPU 911 including extraction, search, look-up, comparison, calculation, computation, processing, output, printing, and display.


The arrows in the flowcharts in the above description mainly indicate input/output of data and signals. The data and signal values are stored in the memory of the RAM 914, the recording medium such as an optical disk, or in an IC chip. The data and signals are transmitted online via a transmission medium such as the bus 912, signal lines, or cables, or via electric waves.


What is described as “unit” in the above description may be “circuit”, “device”, “equipment”, “means”, or “function”, and may also be “step”, “procedure”, or “process”. What is described as “device” may be “circuit”, “equipment”, “means”, or “function”, and may also be “step”, “procedure”, or “process”. What is described as “process” may be “step”. In other words, what is described as “unit” may be realized by firmware stored in the ROM 913. Alternatively, what is described as “unit” may be implemented solely by software, or solely by hardware such as an element, a device, a substrate, or a wiring line, or by a combination of software and firmware, or by a combination including firmware. The firmware and software are stored as programs in the recording medium such as the ROM 913. The programs are read by the CPU 911 and are executed by the CPU 911. That is, each program causes the computer or the like to function as each “unit” described above. Alternatively, each program causes the computer or the like to execute a procedure or a method of each “unit” described above.


REFERENCE SIGNS LIST


10: cryptographic system; 100: key generation device; 110: master key generation unit; 120: master key storage unit; 130: information input unit; 140: decryption key generation unit; 141: f vector generation unit; 142: s vector generation unit; 143: random number generation unit; 144: key element generation unit; 145: randomizing element generation unit; 146: delegation element generation unit; 150: key distribution unit; 200: encryption device; 210: public parameter acquisition unit; 220: information input unit; 230: cipher data generation unit; 231: random number generation unit; 232: cipher element generation unit; 240: data transmission unit; 300: decryption device; 310: decryption key acquisition unit; 320: data receiving unit; 330: span program computation unit; 340: complementary coefficient computation unit; 350: pairing operation unit; 360: message computation unit; 400: key delegation device; 410: decryption key acquisition unit; 420: information input unit; 430: delegation key generation unit; 431: random number generation unit; 432: lower-level key element generation unit; 433: lower-level randomizing element generation unit; 434: lower-level delegation element generation unit; 440: key distribution unit; 500: signature device; 510: signature key acquisition unit; 520: information input unit; 530: complementary coefficient computation unit; 540: signature data generation unit; 541: random number generation unit; 542: signature element generation unit; 550: data transmission unit; 600: verification device; 610: public parameter acquisition unit; 620: data receiving unit; 630: verification data generation unit; 631: f vector generation unit; 632: s vector generation unit; 633: random number generation unit; 634: verification element generation unit; 640: pairing operation unit

Claims
  • 1. A cryptographic system configured to perform a process using a predetermined basis B and a predetermined basis B*, the cryptographic system comprising: a transmission device including circuitry configured to generate a transmission-side vector tj for at least one index j out of a plurality of indices j, the transmission-side vector tj being a vector in which information J assigned in advance to the index j is set as a coefficient of a predetermined basis vector bindex of the basis B, and a parameter Φj for the index j is set as a coefficient of another basis vector batt of the basis B; anda reception device including circuitry configured to use a reception-side vector rj′ for at least one index j′ out of a plurality of indices j′, the reception-side vector rj′ being a vector in which information J′ having an inner-product of 0 with the information J assigned in advance to the index j corresponding to the index j′ is set as a coefficient of a basis vector b*index of the basis B* corresponding to the basis vector bindex, and a parameter Ψj′ for the index j′ is set as a coefficient of a basis vector b*att of the basis B* corresponding to the basis vector batt, and compute a product of pairing operations on corresponding pairs of the basis vectors of the transmission-side vector tj for the index j and the reception-side vector rj′ for the index j′ corresponding to the index j.
  • 2. The cryptographic system according to claim 1, wherein the transmission device is an encryption device that generates a ciphertext ct, and is configured to use an integer t of t=1, . . . , d (d being an integer of 1 or more) as the index j, use attribute information xt for the integer t as the parameter Φj for the index j, and generate the ciphertext ct including as the transmission-side vector tj a cipher vector ct in which information J assigned to the integer t is set as the coefficient of the basis vector bindex and the attribute information xt for the integer t is set as the coefficient of the basis vector batt, for at least one integer t, andwherein the reception device is a decryption device that decrypts the ciphertext ct, and is configured to use an integer i of i=1, . . . , L (L being an integer of 1 or more) as the index j′, use predicate information vi for the integer i as the parameter Ψj′ for the index j′, use as the reception-side vector rj′ a key vector k*i in which information J′ having an inner-product of 0 with the information J assigned to the integer t corresponding to the integer i is set as the coefficient of the basis vector b*index, and predicate information vi for the integer i is set as the coefficient of the basis vector b*att, for each integer i, and compute a product of pairing operations on corresponding pairs of the basis vectors of the key vector k*i for the each integer i and the cipher vector ct for the integer t corresponding to the each integer i.
  • 3. The cryptographic system according to claim 1, wherein the transmission device is an encryption device that generates a ciphertext ct, and is configured to use an integer i of i=1, . . . , L (L being an integer of 1 or more) as the index j, use predicate information vi for the integer i as the parameter Φj for the index j, and generate the ciphertext ct including as the transmission-side vector tj a cipher vector ci in which information J assigned to the integer i is set as the coefficient of the basis vector bindex, and the predicate information vi for the integer i is set as the coefficient of the basis vector batt, for each integer i, andwherein the reception device is a decryption device that decrypts the ciphertext ct, and is configured to use an integer t of t=1, . . . , d (d being an integer of 1 or more) as the index j′, use attribute information xt for the integer t as the parameter Ψj′ for the index j′, use as the reception-side vector rj′ a key vector k*t in which information Y having an inner-product of 0 with the information J assigned to the integer i corresponding to the integer t is set as the coefficient of the basis vector b*index, and attribute information xt for the integer t is set as the coefficient of the basis vector b*att, for at least one integer t, and compute a product of pairing operations on corresponding pairs of the basis vectors of the cipher vector ci for the each integer i and the key vector k*t for the integer t corresponding to the each integer i.
  • 4. The cryptographic system according to claim 1, wherein the transmission device is an encryption device that generates a ciphertext ct, and is configured to use an integer i of i=1, . . . , L (L being an integer of 1 or more) as the index j, use attribute information xi for the integer i as the parameter φj for the index j, and generate the ciphertext ct including as the transmission-side vector tj a cipher vector ci in which information J assigned to the integer i is set as the coefficient of the basis vector bindex, and attribute information xi for the integer i is set as the coefficient of the basis vector batt, for each integer i, andwherein the reception device is a decryption device that decrypts the ciphertext ct, and is configured to use the integer i as the index j′, and use predicate information vi for the integer i as the parameter Ψj′ for the index j′, use as the reception-side vector rj′ a key vector k*i in which information J′ having an inner-product of 0 with the information J assigned to the integer i is set as the coefficient of the basis vector b*index, and predicate information vi for the integer i is set as the coefficient of the basis vector b*att, for each integer i, and compute a product of pairing operations on corresponding pairs of the basis vectors of the key vector k*i and the cipher vector ci for the each integer i.
  • 5. The cryptographic system according to claim 1, wherein the transmission device is a signature device that uenerates signature data sig, and is configured to use an integer t of t=1, . . . , d (d being an integer of 1 or more) as the index j, use attribute information xt for the integer t as the parameter Φj for the index j, use a key vector k*t in which information J assigned to the integer t is set as the coefficient of the basis vector bindex, and attribute information xt for the integer t is set as the coefficient of the basis vector batt, for at least one integer t, and generate the signature data sig including as the transmission-side vector tj a signature element si for each integer i of i=1, . . . , L (L being an integer of 1 or more), including the key vector k*t for the integer t corresponding to the each integer i, andwherein the reception device is a verification device that verifies the signature data sig, and is configured to use the integer i as the index j′, use predicate information vi for the integer i as the parameter Ψj′ for the index j′, use as the reception-side vector rj′ a verification element ci in which, for each integer i, information J′ having an inner-product of 0 with the information J assigned to each integer t corresponding to the each integer i is set as the coefficient of the basis vector b*index, and predicate information vi for the each integer i is set as the coefficient of the basis vector b*att, and compute a product of pairing operations on corresponding pairs of the basis vectors of the signature element si and the verification element ci for the each integer i.
  • 6. The cryptographic system according to claim 2, wherein the cryptographic system is configured to perform the process using a predetermined basis B0 and a predetermined basis B*0, and a predetermined basis B and a predetermined basis B*,wherein the transmission device is configured to generate the ciphertext ct including a cipher vector c0 and a cipher vector ct for at least one integer t of t=1, . . . , d, as indicated in Formula 1, andwherein the reception device is configured to compute Formula 3 for a key vector k*i for each integer i of i=0, . . . , L, as indicated in Formula 2, and the cipher vector ct
  • 7. The cryptographic system according to claim 3, wherein the cryptographic system is configured to perform the process using a predetermined basis B0 and a predetermined basis B*0, and a predetermined basis B and a predetermined basis B*,wherein the transmission device is configured to generate the ciphertext ct including a cipher vector ci for each integer i of i=0, . . . , L, as indicated in Formula 4, andwherein the reception device is configured to compute Formula 6 for a key vector k*0 and a key vector k*t for at least one integer t of t=1, . . . , d, as indicated in Formula 5, and the cipher vector ci
  • 8. The cryptographic system according to claim 4, wherein the cryptographic system is configured to perform the process using a predetermined basis B0 and a predetermined basis B*0, and a predetermined basis B and a predetermined basis B*,wherein the transmission device is configured to generate the ciphertext ct including a cipher vector c1 which is a sum of cipher vectors ci for each integer i of i=0, . . . , L, as indicated in Formula 7, andwherein the reception device is configured to compute a product of pairing operations on the corresponding pairs of the basis vectors of the cipher vector c1 and a key vector k*L,dec which is a sum of key vectors k*i for the each integer i, as indicated in Formula 8 c1:=((ω,0u0,ξ,0w0,{right arrow over (φ)}0)B0, (σt(1,t),ω{right arrow over (x)}t), 0u, 0w,{right arrow over (Φ)}t)B:t=1, . . . , L)  [Formula 7]where{right arrow over (x)}t:=(xt,1, . . . , xt,n),ω,ξ, {right arrow over (φ)}0:=φ0,1, . . . , φ0,z0, σi, {right arrow over (Φ)}t:=φt,1, . . . , φt,z are each random numbers, andu0, w0, z0, u, w, z are each an integer of 0, k*L,dec:=((−sdec,0,0u0,1,{right arrow over (η)}dec,0,0z0)*0,(μdec,t(t,−1),sdec,t{right arrow over (e)}1+θdec,t{right arrow over (v)}t,0u,{right arrow over (η)}dec,t,0z)* :t=1, . . . ,L),  [Formula 108]where{right arrow over (v)}i:=(vi,1, . . . ,vi,n),{right arrow over (η)}dec,0=ηdec,0,1, . . . ηdec,0,w0, μdec,t, θdec,t,are random numbers,{right arrow over (η)}dec,t=ηdec,t,1, . . . ,ηdec,t,w sdec,0:=Σt=1Lsdec,t,n is an integer of 1 or more, andu0, w0, z0, u, w, z are each an integer of 0 or more.
  • 9. The cryptographic system according to claim 5, wherein the cryptographic system is configured to perform the process using a predetermined basis B0 and a predetermined basis B*0, a predetermined basis B and a predetermined basis B*, and a predetermined basis Bd+1 and a predetermined basis B*d+1,wherein the transmission device is configured to generate the signature data sig including a signature element si, as indicated in Formula 10, by using a key vector k*0, a key vector k*t for at least one integer t of t=1, . . . , d, a key vector d+1,1, and a key vector d+1,2, as indicated in Formula 9, andwherein the reception device computes Formula 12 for a verification element ci for the each integer i, as indicated in Formula 11, and the signature element si
  • 10. A cryptographic method for performing a process using a predetermined basis B and a predetermined basis B*, the cryptographic method comprising: generating, by circuitry of a transmission device, a transmission-side vector tj for at least one index j out of a plurality of indices j, the transmission-side vector tj being a vector in which information J assigned in advance to the index j is set as a coefficient of a predetermined basis vector bindex of the basis B, and a parameter Φj for the index j is set as a coefficient of another basis vector batt of the basis B, by a transmission device; andusing, by circuitry of a reception device, a reception-side vector r for at least one index j′ out of a plurality of indices j′, the reception-side vector rj′ being a vector in which information J′ having an inner-product of 0 with the information J assigned in advance to the index j corresponding to the index j′ is set as a coefficient of a basis vector b*index of the basis B* corresponding to the basis vector bindex, and a parameter Ψj′ for the index j′ is set as a coefficient of a basis vector b*att of the basis B* corresponding to the basis vector batt, and computing a product of pairing operations on corresponding pairs of the basis vectors of the transmission-side vector tj for the index j and the reception-side vector rj′ for the index j′ corresponding to the index j, by a reception device.
  • 11. A non-transitory computer-readable medium encoded with non-transitory computer-readable instructions that, when executed by a computer, cause the computer to perform cryptographic processes using a predetermined basis B and a predetermined basis B*, comprising: generating, at a transmission device, a transmission-side vector tj for at least one index j out of a plurality of indices j, the transmission-side vector tj being a vector in which information J assigned in advance to the index j is set as a coefficient of a predetermined basis vector bindex of the basis B, and a parameter Φj for the index j is set as a coefficient of another basis vector batt of the basis B; andusing, at a reception device, a reception-side vector rj′ for at least one index j′ out of a plurality of indices j′, the reception-side vector rj′ being a vector in which information J′ having an inner-product of 0 with the information J assigned in advance to the index j corresponding to the index j′ is set as a coefficient of a basis vector b*index of the basis B* corresponding to the basis vector bindex, and a parameter Ψj′ for the index j′ is set as a coefficient of a basis vector b*att of the basis B* corresponding to the basis vector batt, and computing a product of pairing operations on corresponding pairs of the basis vectors of the transmission-side vector tj for the index j and the reception-side vector rj′ for the index j′ corresponding to the index j.
Priority Claims (1)
Number Date Country Kind
2012-049275 Mar 2012 JP national
PCT Information
Filing Document Filing Date Country Kind
PCT/JP2013/055661 3/1/2013 WO 00
Publishing Document Publishing Date Country Kind
WO2013/133158 9/12/2013 WO A
US Referenced Citations (6)
Number Name Date Kind
7634085 Sahai et al. Dec 2009 B1
20090080658 Waters et al. Mar 2009 A1
20120297201 Matsuda Nov 2012 A1
20130028415 Takashima et al. Jan 2013 A1
20130039489 Takashima et al. Feb 2013 A1
20130114810 Kobayashi et al. May 2013 A1
Foreign Referenced Citations (4)
Number Date Country
2011083678 Jul 2011 WO
2011086687 Jul 2011 WO
2011135895 Nov 2011 WO
2012011575 Jan 2012 WO
Non-Patent Literature Citations (48)
Entry
Predicate Encryption Supporting Disjunctions, Polynomial Equations, and Inner Products, Katz J (on Applicants IDS filed Sep. 24, 2014).
International Search Report Issued May 7, 2013 in PCT/JP13/055661 filed Mar. 1, 2013.
Beimel, A. et al., “Secure Schemes for Secret Sharing and Key Distribution”, Israel Institute of Technology, 1996 (115 pages).
Bethencourt, J. et al., “Ciphertext-Policy Attribute-Based Encryption”, IEEE Press, pp. 321-334 , 2007.
Boneh, D. et al., “Efficient Selective-ID Secure Identity based Encryption Without Random oracles”, EUROCRYPT, vol. 3027, pp. 223-238, 2004.
Boneh, D. et al., “Secure Identity Based Encryption Without Random oracles”, CRYPTO, vol. 3152, pp. 443-459, 2004.
Boneh, D. et al., “Hierarchical Identity Based Encryption with Constant Size Ciphertext”, EUROCRYPT, vol. 3494, pp. 440-456, 2005.
Boneh, D. et al., “Short Group Signatures”, CRYPTO, vol. 3152, pp. 41-55, 2004.
Boneh, D. et al., “Identity-Based Encryption from the Well Pairing”, CRYPTO, vol. 2139, pp. 213-229, 2001.
Boneh, D. et al., “Generalized Identity Based and Broadcast Encryption Schemes”, ASIACRYPT, vol. 5350, pp. 455-470, 2008.
Boneh, D. et al., “Improved Efficiency for CCA-Secure Cryptosystems Built Using Identity-Based Encrytion”, RSA-CT, 2005.
Boneh, D. et al., “Conjunctive, Subset, and Range Queries on Encrypted Data”, TCC, vol. 4392, pp. 535-554, 2007.
Boyen, X. et al., “Anonymous Hierarchical Identity-Based Encryption(Without Random Oracles)”, CRYPTO, vol. 4117 pp. 290-307, 2006.
Canetti, R. et al., “Chosen-Ciphertext Security from Identity-Based Encryption”, EUROCRYPT, 2004.
Chase, M., “Multi-Authority Attribute Based Encryption”, TCC, LNCS, pp. 515-534, 2007.
Chase, M., “Improving Privacy and Security in Multi-Authority Attribute-Based Encryption”, ACM, pp. 121-130, 2009.
Cocks, C., “An Identity Based Encryption Scheme Based on Quadratic Residues”, IMA Int. Conf., vol. 2260, pp. 360-363, 2001.
Gentry, C., “Practical Identity-Based Encryption Without Random Oracles”, EUROCRYPT, vol. 4004, pp. 445-464, 2006.
Gentry, C., “Hierarchical Identity Based Encryption with Polynomially Many Levels”, TCC, vol. 5444, pp. 437-456, 2009.
Gentry, C., et al., “Hierarchical ID-Based Cryptography”, ASIACRYPT, vol. 2501, pp. 548-566, 2002.
Goyal, V., et al., “Attribute-Based Encryption for Fine-Grained Access Control of Encrypted Data”, ACM, pp. 89-98, 2006.
Katz, J., et al., “Predicate Encryption Supporting Disjunctions, Polynomial Equations, and Inner Products”, EUROCRYPT, vol. 4965, pp. 146-162, 2008.
Lewko, A., et al., “Fully Secure Functional Encryption: Attribute-Based Encryption and (Hierarchical) Inner Product Encryption”, EUROCRYPT, 2010 (57 pages).
Lewko, A., et al., “New Techniques for Dual System Encryption and Fully Secure HIBE with Short Ciphertexts ”, TCC, vol. 5978, pp. 455-479, 2010.
Lewko, A. B., et al., “Decentralizing Attribute-Based Encryption”, the proceedings of Eurocrypt, 2011(32 pages).
Lewko, A. B., et al., “Unbounded HIBE and Attribute-Based Encryption”, the proceedings of Eurocrypt, 2011 (20 pages).
Lin, H., et al., “Secure threshold multi attribute based encryption without a central authority”, INDOCRYPT, LNCS, vol. 5365, pp. 426-436, 2008.
Mueller, S., et al., “On Multi-Authority Ciphertext-Policy Attribute-Based Encryption”, Bull. Korean Math. Soc., 46, No. 4, pp. 803-819, 2009.
Okamoto, T., et al., “Homomorphic Encryption and Signatures from Vector Decomposition”, LNCS, vol. 5209, pp. 57-74, 2008.
Okamoto, T., et al., “Hierarchical Predicate Encryption for Inner-Products”, ASIACRYPT, 2009 (21 pages).
Okamoto, T., et al., “Fully Secure Functional Encryption with General Relations from the Decisional Linear Assumption”, CRYPTO, vol. 6223, pp. 191-208, 2010.
Okamoto, T., et al., “Efficient Attribute-Based Signatures for Non-Monotone Predicates in the Standard Model”, PKC, 2011(41 pages).
Okamoto, T., et al., “Decentralized Attribute-Based Signatures”, http://eprint.iacr.org/2011/701(59 pages).
Ostrovsky, R., et al., “Attribute-Based Encryption with Non-Monotonic Access Structures”, ACM, pp. 195-203, 2007.
Pirretti, M., et al., “Secure Attribute-Based Systems”, ACM, pp. 99-112, 2006.
Sahai, A., et al., “Fuzzy Identity-Based Encryption”, EUROCRYPT, vol. 3494, pp. 457-473, 2005.
Shi, E., et al., “Delegating Capabilities in Predicate Encryption Systems”, ICALP (2), LNCS, vol. 5126, pp. 560-578, 2008.
Waters, B., et al., “Efficient Identity-Based Encryption Without Random Oracles”, LNCS, vol. 3152, pp. 443-459, 2005.
Waters, B., et al., “Ciphertext-Policy Attribute-Based Encryption: An Expressive, Efficient, and Provably Secure realization”, ePrint, IACR, http://eprint.iacr.org/2008/290 (30 pages).
Waters, B., et al., “Dual Systems Encryption: Realizing Fully Secure IBE and HIBE under Simple Assumptions”, CRYPTO, vol. 5677, pp. 619-636, 2009.
Okamoto, T., et al., “Adaptively Attribute-Hiding (Hierarchical) Inner Product Encryption”, Cryptology ePrint, 2012 (39 pages).
Okamoto, T., et al., “Achieving Short Ciphertexts or Short Secret-Keys for Adaptively Secure General Inner-Product encryption”, CANS, LNCS 7092, pp. 138-159, 2011.
Boneh, D. et al., “Identity-Based Encryption from the Weil Pairing”, CRYPTO, vol. 2139, pp. 213-229, 2001.
Goyal, V., et al., “Attribute-Base Encryption for Fine-Grained Access Control of Encrypted Data”, ACM, pp. 89-98, 2006.
Lewko, A., et al., “Fully Secure Functional Encryption: Attribute-Based Encryption and (Hierarchical) Inner Product”, EUROCRYPT, 2010 (57 pages).
Lewko, A., et al., “New Techniques for Dual System Encryption and Fully Secure HIBE with Short Ciphertexts”, TCC, vol. 5978, pp. 455-479, 2010.
Mueller, S., et al., “On Multi-Authority Ciphertext-Policy Attribute-Based Encryption ”, Bull. Korean Math. Soc., 46, No. 4, pp. 803-819, 2009.
Okamoto, T., et al., “Hierarchical Predicate Encryption for Inner-Products ”, ASIACRYPT, 2009 (21 pages).
Related Publications (1)
Number Date Country
20150010147 A1 Jan 2015 US