In cryptography, the unbalanced oil and vinegar (UOV) scheme is a modified version of the oil and vinegar scheme designed by J. Patarin. Both are digital signature protocols. They are forms of multivariate cryptography. The security of this signature scheme is based on an NP-hard mathematical problem. To create and validate signatures, a minimal quadratic equation system must be solved. Solving equations with variables is NP-hard. While the problem is easy if is either much much larger or much much smaller than,[1] importantly for cryptographic purposes, the problem is thought to be difficult in the average case when and are nearly equal, even when using a quantum computer. Multiple signature schemes have been devised based on multivariate equations with the goal of achieving quantum resistance.
A significant drawback with UOV is that the key size can be large. Typically, the number of variables, is chosen to be double, the number of equations. Encoding the coefficients of all these equations in the key requires considerable space, at least 200 kilobytes for a system that would offer security comparable to the Digital Signature Algorithm or Elliptic Curve Digital Signature Algorithm.
A signature scheme has a signing key, which is kept private, and a verification key, which is publicly revealed. For instance, in signature schemes based on RSA the keys are both exponents. In the UOV scheme, and in every other multivariate signature scheme the keys are more complex.
The mathematical problem is to solve
m
n
To use a mathematical problem for cryptography, it must be modified. The computing of the
n
T
S
\acute{P}
T
y
y1,y2,...,yn
S
The third secret element
\acute{P}
To create a valid signature, the following equations system has to be solved
Here the
y=(y1,y2,\ldots,ym)
x=(x1,x2,\ldots,xn)
To sign a given
y
T
y1,y2,\ldots,ym
The next steps sign a given message
y
x
\gammaijk,λijk,\xiij,\acute{\xi}ij,\deltai
\acute{a}j
ai
The vinegar and oil variables build the pre-signature
A=(a1,\ldots,an,\acute{a}1,\ldots,\acute{a}v)
A
S
x=S-1(A)
The system of equations becomes linear if the vinegar variables are fixed – no oil variable is multiplied with another oil variable in the equation. Therefore, the oil variables can be computed easily using, for example, a Gaussian reduction algorithm. The signature creation is itself fast and computationally easy.
The signature is transmitted to the communication partner. Validation of the signature is performed with the help of the public key, which is an equations system.
This system of equations is a slightly modified version of the system needed for signature creation. It is modified so that an attacker cannot get information about the secret coefficients and the special formatting of the oil and vinegar variables. Every equation of the public key has to be solved to validate the signature. The input is the signature itself. If every result
yi
A primary advantage is that the mathematical problem to be solved in the algorithm is quantum-resistant. When a quantum computer is built that can factor large composite numbers using Shor's Algorithm, this will break commercial signature schemes like RSA or ElGamal that rely upon the discrete logarithm problem being unsolvable. UOV may remain secure because no algorithm is known to give quantum computer a great advantage in solving multivariate systems of equations.
The second advantage is that the operations used in the equations are relatively simple. Signatures get created and validated only with addition and multiplication of "small" values, making this signature viable for low-resource hardware as found in smart cards.
A disadvantage is that UOV uses very long key-lengths, with the public key involving the entire system of
m
The Rainbow cryptosystem is based on UOV and is one of three finalists in the NIST competition for a post-quantum digital signature standard, though significant concerns have recently been brought to light regarding its security as proposed in the NIST competition. A new MinRank attack against Rainbow was discovered, which reduces the security of the proposed Rainbow instantiation to a level below the requirements set out by NIST.[2] Beullens discovered a new attack in 2022, which recovers the private key for the Rainbow L1 parameterset in a weekend.[3] UOV itself is not affected by this attack.