Verifiable random function
From Wikipedia, the free encyclopedia
The concept of a verifiable random function in cryptography was introduced by Micali, Rabin, and Vadhan.[1] It is a pseudo-random function that provides publicly verifiable proofs of its outputs' correctness. Given an input value x, the owner of the secret key SK can compute the function value y = FSK(x) and the proof pSK(x). Using the proof and the public key, everyone can check that the value y = FSK(x) was indeed computed correctly, yet this information cannot be used to find the secret key.
The original construction was rather inefficient. Recently, an efficient and practical verifiable random function was proposed by Yevgeniy Dodis and Aleksandr Yampolskiy. In their construction,
where e(·,·) is a bilinear map. To verify whether FSK(x) was computed correctly or not, one can check if e(gxPK,pSK(x)) = e(g,g).
The proof of security relies on a new decisional bilinear Diffie-Hellman inversion assumption, which asks given as input to distinguish R = e(g,g)1 / x from random.
[edit] References
- ^ Micali, Silvio; Rabin, Michael O.; Vadhan, Salil P. (1999). "Verifiable random functions". Proceedings of the 40th IEEE Symposium on Foundations of Computer Science, 120–130.