The present disclosure generally relates to fuzzy extraction (FE), and particularly, to hardware implementation of computational fuzzy extractors.
To ensure confidentiality and privacy of users and their associated data in internet of things (IoT), different security protocols may be required that rely on at least a few cryptographic secret/private keys. Secure storage and management of such keys may be very expensive or impractical for many IoT devices. In addition, considering distributed and remote structures of IoT end-nodes, pre-stored secret keys may be extractable by employing physical attacks to device memories.
In order to overcome issues related to secure key-management, many studies have suggested employing user or device biometrics for authentication. User biometrics such as fingerprints and iris are unique to each user and may be utilized for both identification and authentication. On devices, physical unclonable functions (PUFs) may act as an almost perfect biometric source unique to each device.
The fuzzy extractor (FE) concept has been disclosed as a function that may extract cryptographically random and reproducible secure keys from noisy biometric inputs with some loss of entropy. Thus, FEs may be employed in different scenarios where secret key storage may not be available. Such scenarios include constrained resources and limited power/energy consumption, high-security level forbidding secret key storage, and preserving users' privacy. Generally, FE schemes include two phases of generation and reproduction. A generation phase may be executed once during a manufacturing process and may produce a pair of challenge and response from a biometric input such. On the other hand, a reproduction phase may regenerate the same response given helper and biometric data from a same source (with some noise threshold).
Different authentication methods have been disclosed based on traditional FE schemes. However, these methods include software calculations that may be vulnerable to since software based attacks that may break system integrity and exploit biometric sources. Furthermore, the security of traditional FE schemes may be based on information-theoretic setting which may result in large amount of entropy loss. Therefore, traditional FE schemes may require large helper data and assume different characteristics on a biometric source such as independent and identically distributed (i.i.d) data.
There is, therefore, a need for a hardware-based authentication scheme that may be robust against different kinds of attacks. There is further a need for a system for authentication that may consume low hardware resources such as area and power consumption.
This summary is intended to provide an overview of the subject matter of this patent, and is not intended to identify essential elements or key elements of the subject matter, nor is it intended to be used to determine the scope of the claimed implementations. The proper scope of this patent may be ascertained from the claims set forth below in view of the detailed description below and the drawings.
In one general aspect, the present disclosure describes an exemplary logic circuit for biometric authentication based on learning parity with noise. An exemplary logic circuit may include a sensor. An exemplary sensor may be configured to acquire a biometric signal. An exemplary logic circuit may be configured to generate a response signal from the biometric signal by implementing a finite state machine (FSM).
An exemplary FSM may include ten states. An exemplary first state may include generation of an idle output. An exemplary second state may include generation of a reliable index vector from the biometric signal. In an exemplary embodiment, each bit of the reliable index vector may include a respective confidence of a respective bit of the biometric signal. An exemplary third state may include extraction of a subset index vector from the reliable index vector.
An exemplary fourth state may include generation of a modulo 2 addition vector by performing an XOR operation on each of a plurality of selected bit pairs. In an exemplary embodiment, each of the plurality of selected bit pairs may include a first selected bit and a second selected bit. An exemplary first selected bit may be extracted from a respective bit of a helper data according to a respective non-zero bit of the subset index vector. An exemplary second selected bit may be extracted from the biometric signal according to the respective non-zero bit.
An exemplary fifth state may include generation of a primary hash vector from a transposed inverse public key. An exemplary transposed inverse public key may include a primary square matrix. In an exemplary embodiment, generation of the primary hash vector may include sequentially applying a hashing function on each row of the primary square matrix. An exemplary primary square matrix may include a transpose of an inverse of a truncated square matrix. An exemplary truncated square matrix may be extracted from a public key according to the subset index vector. An exemplary public key may include an m×n matrix.
An exemplary sixth state may include verification of the public key. In an exemplary embodiment, the verification of the public key may include obtaining a digestion of the public key by sequentially applying the hashing function on each row of the m×n matrix and comparing the digestion with a pre-stored digestion that may be obtained by applying the hashing function on an original public key.
An exemplary seventh state may include verification of the transposed inverse public key based on the primary hash vector simultaneously with the verification of the public key. In an exemplary embodiment, verification of the transposed inverse public key may include generation of a secondary hash vector from a reloaded inverse public key responsive to applying the hashing function on a kth row of the m×n matrix and a kth element of the subset index vector being non-zero where 1≤k≤m. An exemplary a reloaded inverse public key may include a secondary square matrix. In an exemplary embodiment, generation of the secondary hash vector may include sequentially applying the hashing function on each row of the secondary square matrix. In an exemplary embodiment, verification of the transposed inverse public key may further include comparing the secondary hash vector with the primary hash vector and comparing a multiplication result of the secondary square matrix and the kth row of the m×n matrix with a jth row of an n×n identity matrix where 1≤j≤n responsive to the secondary hash vector being equal to the primary hash vector. Exemplary kth row and jth row may be associated with a jth non-zero element of the subset index vector I″.
An exemplary eighth state may include generation of a secret key by multiplying the inverse of the truncated square matrix by the modulo 2 addition vector. An exemplary ninth state may include verification of the secret key.
An exemplary tenth state may include generation of the response signal by applying the hashing function on a public vector according to the secret key. In an exemplary embodiment, each respective bit of the public vector may be extracted from the helper data according to a respective non-zero bit of the subset index vector.
In an exemplary embodiment, the logic circuit may include a control unit. An exemplary control unit may be configured to transition the FSM from the first state to the second state responsive to the biometric signal being acquired by the sensor. An exemplary control unit may be further configured to transition the FSM from the second state to the third state responsive to the reliable index vector being generated. An exemplary control unit may be further configured to transition the FSM from the third state to the fourth state responsive to the subset index vector being extracted. An exemplary control unit may be further configured to transition the FSM from the fourth state to the fifth state responsive to the modulo 2 addition vector being generated. An exemplary control unit may be further configured to transition the FSM from the fifth state to the sixth state responsive to the primary hash vector being generated. An exemplary control unit may be further configured to transition the FSM from the sixth state to the seventh state responsive to applying the hashing function to the kth row of the m×n matrix and the kth element of the subset index vector being non-zero. An exemplary control unit may be further configured to transition the FSM from the sixth state to the first state responsive to a failure of the verification of the public key. An exemplary control unit may be further configured to transition the FSM from the seventh state to the sixth state responsive to a success of the verification of the transposed inverse public key and transition the FSM from the seventh state to the first state responsive to a failure of the verification of the transposed inverse public key. An exemplary control unit may be further configured to transition the FSM from the sixth state to the eighth state responsive to a success of the verification of the public key. An exemplary control unit may be further configured to transition the FSM from the eighth state to the ninth state responsive to the secret key being generated. An exemplary control unit may be further configured to transition the FSM from the ninth state to the eighth state responsive to an ith successive failure of the verification of the secret key where i<n+1 and transition the FSM from the ninth state to the first state responsive to an (n+1)th successive failure of the verification of the secret key. An exemplary control unit may be further configured to transition the FSM from the ninth state to the tenth state responsive to a success of the verification of the secret key. An exemplary control unit may be further configured to transition the FSM from the tenth state to the first state responsive to the response signal being generated.
An exemplary logic circuit may further include a first shift register, a second shift register, an XOR gate, a third shift register, and a first n-bit register. An exemplary first shift register may be configured to store the helper data and generate a first shifted bit by shifting the helper data one bit per clock cycle. An exemplary second shift register may be coupled to the sensor and may be configured to receive the biometric signal from the sensor and generate a second shifted bit by shifting the biometric signal one bit per clock cycle. An exemplary XOR gate may be configured to perform an XOR operation on the first shifted bit and the second shifted bit. An exemplary third shift register may be configured to store the subset index vector and generate a third shifted bit by shifting the subset index vector one bit per clock cycle. An exemplary first n-bit register may include an enable input. An exemplary enable input may be configured to receive the third shifted bit and generate each respective bit of the modulo 2 addition vector by loading an output of the XOR gate to a respective location in the first n-bit register once per clock cycle responsive to the third shifted bit being non-zero.
An exemplary logic circuit may further include a first hash unit and a second n-bit register. An exemplary first hash unit may be configured to sequentially receive each row of the primary square matrix responsive to the FSM being transitioned to the fifth state, generate the primary hash vector by sequentially applying the hashing function on the each row of the primary square matrix, generate the digestion of the public key by sequentially applying the hashing function on each row of the public key responsive to the FSM being transitioned to the sixth state, sequentially receive each row of the secondary square matrix responsive to the FSM being transitioned to the seventh state, and generate the secondary hash vector by sequentially applying the hashing function on the each row of the secondary square matrix. An exemplary second n-bit register may be coupled to the hash unit and may be configured to store the primary hash vector.
An exemplary logic circuit may further include a third n-bit register and a first comparator circuit. In an exemplary embodiment, the third n-bit register may be configured to store the pre-stored digestion. An exemplary first comparator circuit may be configured to compare the secondary hash vector with the primary hash vector responsive to the secondary hash vector being generated by the first hash unit and compare the digestion of the public key with the pre-stored digestion responsive to the digestion of the public key being generated by the first hash unit.
An exemplary logic circuit may further include a fourth n-bit register, a fifth n-bit register, a first plurality of AND gates, a multi-level XOR tree, a fourth shift register, a fifth shift register, and a second comparator circuit. An exemplary fourth n-bit register may be configured to receive the kth row of the m×n matrix responsive to the secondary hash vector being equal to the primary hash vector. An exemplary fifth n-bit register may be configured to sequentially receive each column of the secondary square matrix responsive to the secondary hash vector being equal to the primary hash vector.
In an exemplary embodiment, the first plurality of AND gates may be configured to generate a first n-bit vector by performing a respective bitwise AND operation on each respective bit in the fourth n-bit register and a respective bit in the fifth n-bit register. An exemplary first n-bit vector may be associated with a respective column of the secondary square matrix. An exemplary multi-level XOR tree may be configured to generate a respective bit of the multiplication result by performing a modulo 2 addition on bits of the first n-bit vector. In an exemplary embodiment, the fourth shift register may be coupled to the multi-level XOR tree and may be configured to sequentially receive each respective bit of the multiplication result from the XOR tree at each clock cycle and generate a fourth shifted bit by shifting the multiplication result one pit per clock cycle.
An exemplary fifth shift register may be configured to store the jth row of the n×n identity matrix and generate a fifth shifted bit by circularly shifting the jth row one bit per clock cycle. An exemplary second comparator circuit configured to compare the multiplication result with the jth row by comparing the fourth shifted bit with the fifth shifted bit.
An exemplary logic circuit may further include a sixth n-bit register, a sixth shift register, a second plurality of AND gates, and a plurality of two-input XOR gates. An exemplary sixth n-bit register may be configured to store the secret key. An exemplary sixth shift register may be coupled to the first n-bit register and may be configured to generate a sixth shifted bit by shifting the modulo 2 addition vector one bit per clock cycle.
In an exemplary embodiment, the second plurality of AND gates may be configured to generate a second n-bit vector by performing bitwise AND operations on the sixth shifted bit and each bit of a respective row of the transposed inverse public key at each clock cycle responsive to the FSM being transitioned to the eighth state. In an exemplary embodiment, the plurality of two-input XOR gates may be configured to generate each bit of the secret key by performing a respective bitwise XOR operation once per clock cycle on each bit of the second n-bit vector and a respective bit in the sixth n-bit register. An exemplary plurality of two-input XOR gates may be further configured to load each bit of the secret key to a respective location in the sixth n-bit register.
In an exemplary embodiment, the verification of the secret key may include generation of a hashed secret key by applying the hashing function on the public vector according to the secret key and comparing the hashed secret key with a pre-stored hashed key.
An exemplary logic circuit may further include a second hash unit and a third comparator circuit. An exemplary second hash unit may be configured to generate the hashed secret key by applying the hashing function to the public vector according to the secret key responsive to the FSM being transitioned to the ninth state. An exemplary third comparator circuit may be configured to compare the hashed secret key with the pre-stored hashed key.
An exemplary logic circuit may further include a third hash unit. An exemplary third hash unit may be configured to generate the response signal by applying the hashing function to the public vector according to the secret key responsive to the FSM being transitioned to the tenth state.
Other exemplary systems, methods, features and advantages of the implementations will be, or will become, apparent to one of ordinary skill in the art upon examination of the following figures and detailed description. It is intended that all such additional systems, methods, features and advantages be included within this description and this summary, be within the scope of the implementations, and be protected by the claims herein.
The drawing figures depict one or more implementations in accord with the present teachings, by way of example only, not by way of limitation. In the figures, like reference numerals refer to the same or similar elements.
In the following detailed description, numerous specific details are set forth by way of examples in order to provide a thorough understanding of the relevant teachings. However, it should be apparent that the present teachings may be practiced without such details. In other instances, well known methods, procedures, components, and/or circuitry have been described at a relatively high-level, without detail, in order to avoid unnecessarily obscuring aspects of the present teachings.
The following detailed description is presented to enable a person skilled in the art to make and use the methods and devices disclosed in exemplary embodiments of the present disclosure. For purposes of explanation, specific nomenclature is set forth to provide a thorough understanding of the present disclosure. However, it will be apparent to one skilled in the art that these specific details are not required to practice the disclosed exemplary embodiments. Descriptions of specific exemplary embodiments are provided only as representative examples. Various modifications to the exemplary implementations will be readily apparent to one skilled in the art, and the general principles defined herein may be applied to other implementations and applications without departing from the scope of the present disclosure. The present disclosure is not intended to be limited to the implementations shown, but is to be accorded the widest possible scope consistent with the principles and features disclosed herein.
Herein is disclosed an exemplary logic circuit for biometric authentication based on learning parity with noise. An exemplary logic circuit may implement a finite state machine (FSM). An exemplary FSM may start by loading a biometric signal from a biometric source (such as a fingerprint of a user) and may process the biometric signal through different states to verify and generate appropriate response based on a verification result of the biometric signal. An exemplary FSM may perform only necessary calculations at each state to increase the speed of verification and reduce storage requirements. As a result, an exemplary FSM may perform biometric authentication at a higher speed and may require a less complex hardware compared to traditional biometric authentication schemes. An exemplary logic circuit may implement each state of the FSM utilizing different logic units. By a hardware implementation of biometric authentication, security of an exemplary authentication system may be improved, whereas resource requirement of the authentication process may be decreased.
In an exemplary embodiment, logic circuit 100 may be configured to generate a response signal h0″ from biometric signal e′ by implementing a finite state machine (FSM). In an exemplary embodiment, an FSM may refer to a mathematical model that has a number of states and performs a different action at each state. An exemplary FSM may be transitioned from one state to another based on a specific condition. As a result, an exemplary FSM may accomplish a given task after being transitioned from an initial state to a final state through different middle states.
Referring to
In an exemplary embodiment, second state 204 may include generation of a reliable index vector from biometric signal e′. An exemplary reliable index vector I° may include m bits. In an exemplary embodiment, each bit of reliable index vector I° may include a respective confidence of a respective bit of biometric signal e′. In an exemplary embodiment, confidence may refer to a value which may represent which bits of biometric signal e′ may have lower probability of error. An exemplary logic circuit may include a hardware unit 106 that may be configured to generate reliable index vector I° from biometric signal e′. In an exemplary embodiment, different methods may be utilized for generating confidence values of each bit of reliable index vector I°, such as a method disclosed by Herder et al. in “Trapdoor computational fuzzy extractors and stateless cryptographically-secure physical unclonable functions,” IEEE Transactions on Dependable and Secure Computing, vol. 14, no. 1, pp. 65-82, 2016.
In an exemplary embodiment, control unit 104 may be configured to transition FSM 200 from second state 204 to a third state 206 responsive to reliable index vector I° being generated. As a result, in an exemplary embodiment, control unit 104 may initiate third state 206 when hardware unit 106 that obtains reliable index vector I°. In exemplary embodiment, third state 206 may include extraction of a subset index vector I″ from reliable index vector I°. In exemplary embodiment, subset index vector I″ may include n non-zero bits where n≤m. In exemplary embodiment, subset index vector I″ may be utilized to determine n most reliable rows out of a total number of m rows of an m×n matrix A that may have been randomly generated and utilized as an encryption key for encrypting biometric signal e′. In an exemplary embodiment, a reliable row may refer to a row of matrix A that may be included in an n×n truncated square matrix AI″ extracted from matrix A to obtain a highest statistical success rate of encryption of biometric signal e′ compared to other possibilities. In an exemplary embodiment, matrix A may be referred to as a public key since it may be exposed to public once it is generated.
Referring again to
In an exemplary embodiment, fourth state 208 may include generation of a modulo 2 addition vector (b′⊕e′)I″ by performing an XOR operation on each of a plurality of selected bit pairs. In an exemplary embodiment, each of the plurality of selected bit pairs may include a first selected bit and a second selected bit. An exemplary first selected bit may be extracted from a respective bit of a helper data b′ according to a respective non-zero bit of subset index vector I″. An exemplary second selected bit may be extracted from biometric signal e′ according to the respective non-zero bit.
In further detail regarding fourth state 208, in an exemplary embodiment, modulo 2 addition vector (b′⊕e′)I″ may be obtained by performing a modulo 2 addition on helper data b′ and biometric signal e′ according to non-zero bits of subset index vector I″. In an exemplary embodiment, modulo 2 addition may include bitwise addition (i.e., an XOR operation on each pair of bits) of helper data b′ and biometric signal e′. In an exemplary embodiment, helper data b′ may have a same size as biometric signal e′, i.e., m bits. In an exemplary embodiment, helper data b′ may be a stored version of an original helper data b that may have been calculated from an original secret key s and original biometric signal e according to an operation defined by the following:
b
I
=
A
I
·s
⊕e
I Equation (1)
where bI is an n-bit subset of original helper data b that includes n most reliable bits of original helper data b according to original index vector I, AI is an n×n square matrix that includes n most reliable rows of public key A according to original index vector I, eI is an n-bit subset of original biometric signal e that includes n most reliable bits of origin original biometric signal e according to original index vector I, AI·s is a bitwise multiplication of AI and s, and ⊕ is a modulo 2 addition operator. In an exemplary embodiment, Equation (1) may be used to hide original secret key s (which is randomly generated) by employing public key A and original biometric signal e. In an exemplary embodiment, original helper data b may be obtained by expanding bI to m bits by inserting zeros based on original index vector I. In an exemplary embodiment, original helper data b may be cryptographically random and therefore, may leak no information about original secret key s and original biometric signal e.
To obtain each exemplary selected bit pair (for example, an ith selected bit pair), a corresponding bit (for example, an ith bit) of subset index vector I″ may be checked. If an exemplary ith bit of subset index vector ith is non-zero, an XOR operation may be performed on the first selected bit (for example, an ith bit of helper data b′) and the second selected bit (for example, an ith bit of biometric signal e′) to obtain a corresponding bit of modulo 2 addition vector (b′⊕e′)I″. Since, in an exemplary embodiment, subset index vector I″ may have n non-zero bits, modulo 2 addition vector (b′⊕e′)I″ may have a size of n bits. In other words, in an exemplary embodiment, a jth bit of modulo 2 addition vector (b′⊕e′)I″ may correspond to a jth non-zero bit of subset index vector I″. As a result, in an exemplary embodiment, modulo 2 addition vector (b′⊕e′)I″ may be generated from n most reliable bits of helper data b′ and biometric signal e′, according to subset index vector I″.
To implement fourth state 208, an exemplary logic circuit may further include a first shift register 108, a second shift register 110, an XOR gate 112, a third shift register 114, and a first n-bit register 116. In an exemplary embodiment, a “register” in the present disclosure refers to a hardware unit that stores digital data (i.e., data bits) and a “shift register” may refer to a register that may shift stored bits to a right or left direction at every clock cycle (typically, one bit per clock cycle). In an exemplary embodiment, first shift register 108 may be configured to store helper data b′ and generate a first shifted bit 118 by shifting helper data b′ one bit per clock cycle. In an exemplary embodiment, second shift register 110 may be coupled to sensor 102 and may be configured to receive biometric signal e′ from sensor 102 and generate a second shifted bit 120 by shifting biometric signal e′ one bit per clock cycle. In an exemplary embodiment, XOR gate 112 may be configured to perform an XOR operation on first shifted bit 118 and second shifted bit 120. In an exemplary embodiment, third shift register 114 may be configured to store subset index vector I″ and generate a third shifted bit 122 by shifting subset index vector I″ one bit per clock cycle. In an exemplary embodiment, first n-bit register 116 may include an enable input en. In an exemplary embodiment, enable input en may be configured to receive third shifted bit 122 and generate each respective bit of modulo 2 addition vector (b′⊕e′)I″ by loading an output of XOR gate 112 to a respective location in first n-bit register 116 once per clock cycle responsive to third shifted bit 122 being non-zero 122. In an exemplary embodiment, when third shift register 114 loads the jth non-zero bit of subset index vector I″ to third shifted bit 122, enable input en may be activated. As a result, first n-bit register 116 may receive a result of an XOR operation on first shifted bit 118 and second shifted bit 120. Therefore, in an exemplary embodiment, first shifted bit 118 may be equal to the first selected bit when enable input en is active. In addition, in an exemplary embodiment, second shifted bit 120 may be equal to the second selected bit when enable input en is active. As a result, XOR gate 112 may output the jth bit of modulo 2 addition vector (b′⊕e′)I″ (corresponding to the jth non-zero bit of subset index vector I″) to a jth bit location in first n-bit register 116. In an exemplary embodiment, it may last m clock cycles to shift all bits of subset index vector I″. Therefore, all bits of modulo 2 addition vector (b′⊕e′)I″ may be generated and loaded into first n-bit register 116 after m clock cycles.
In an exemplary embodiment, control unit 104 may be configured to transition FSM 200 from fourth state 208 to a fifth state 210 responsive to modulo 2 addition vector (b′⊕e′)I″ being generated. As a result, in an exemplary embodiment, control unit 104 may initiate fifth state 210 after m clock cycles from the initiation of fourth state 208.
In an exemplary embodiment, fifth state 210 may include generation of a primary hash vector from a transposed inverse public key (AI″−1)T. In an exemplary embodiment, transposed inverse public key (AI″−1)T may include a primary square matrix. In an exemplary embodiment, generation of the primary hash vector may include sequentially applying a hashing function on each row of the primary square matrix. An exemplary primary square matrix may include a transpose of an inverse of a truncated square matrix. An exemplary truncated square matrix AI″ may be extracted from public key A according to subset index vector I″, as described above.
An exemplary primary square matrix may include a transpose of an inverse public key AI″−1 which is an inverse of truncated square matrix AI″ and is used for calculating a secret key s′ according to an operation defined by the following:
s′=
A
I″
−1·(b′⊕e′)I″ Equation (2)
According to Equations (1) and (2), in an exemplary embodiment, secret key s′ may be equal to original secret key s if b′, e′, and I″ are equal to b, e, and I, respectively, and AI″−1 is equal to an inverse of AI. Therefore, in an exemplary embodiment, inverse public key AI″−1 may be loaded from processor 101 to an exemplary logic circuit in fifth state 210 to be verified prior to calculation of secret key s′. To lower the computational complexity of the verification of inverse public key AI″−1, an exemplary logic circuit may acquire transposed inverse public key (AI″−1)T instead of inverse public key AI″−1 in fifth state 210, so that an entire column of inverse public key AI″−1 may be verified at once by loading a corresponding row of transposed inverse public key (AI″−1)T to a hardware register in a single clock cycle.
Referring again to
Referring again to
In an exemplary embodiment, sixth state 212 may include verification of public key A. An exemplary verification of public key A in sixth state 212 may include obtaining a digestion of public key A by sequentially applying the hashing function on each row of the m×n matrix and comparing the digestion with a pre-stored digestion that may be obtained by applying the hashing function on an original public key. In an exemplary embodiment, the original public key may refer to an m×n matrix that may have been initially generated when original biometric signal e was acquired. An exemplary original public key may be equal to public key A if public key A is accurately generated and received by logic circuit 100.
Referring again to
Referring again to
An exemplary logic circuit may further include a third n-bit register 128 and a first comparator circuit 130. In an exemplary embodiment, third n-bit register 128 may be configured to store the pre-stored digestion. In an exemplary embodiment, first comparator circuit 130 may be configured to compare the digestion of public key A with the pre-stored digestion responsive to the digestion of the public key A being generated by first hash unit 124. In an exemplary embodiment, when the digestion of the public key A is generated and stored in temporary register 127 in sixth state 212, control unit 104 may configure a multiplexer 132 through a select line sel1 of multiplexer 132 to load the pre-stored digestion from third n-bit register 128 to a first input 134 of first comparator circuit 130. In an exemplary embodiment, first comparator circuit 130 may then compare the pre-stored digestion with the digestion of the public key A that is loaded from temporary register 127 to a second input 136 of first comparator circuit 130. If the digestion of the public key A is equal to the pre-stored digestion, comparator circuit 130 may output an exemplary valid signal to control unit 104, indicating that verification of public key A is successful.
Referring again to
In an exemplary embodiment, rows of matrix A that are included in truncated square matrix AI″ may be detected in step 314 according to subset index vector I″. In an exemplary embodiment, each non-zero element (for example, the kth element) of subset index vector I″ may indicate the inclusion of a corresponding row (for example, the kth row) of matrix A in truncated square matrix AI″. In an exemplary embodiment, if the kth row of the m×n matrix is included in n×n truncated square matrix AI″, transposed inverse public key (AI″−1)T may be reloaded from processor 101 to logic circuit 100 to verify that an inverse of AI″ is correctly generated by processor 101. In an exemplary embodiment, transposed inverse public key (AI″−1)T may be reloaded row by row to obtain the secondary square matrix. Afterward, in an exemplary embodiment, the secondary hash vector may be generated by sequentially applying the hashing function on each row of the secondary square matrix upon reloading each row of transposed inverse public key (AI″−1)T in step 312.
In an exemplary embodiment, verification of a reloaded version of transposed inverse public key (AI″−1)T in step 312 may further include comparing the secondary hash vector with primary hash vector σ. If, in an exemplary embodiment, the secondary hash vector is different from primary hash vector σ, verification of transposed inverse public key (AI″−1)T may fail and FSM 200 may restart from first state 202. Otherwise, verification process 300 may proceed to step 316 to verify a jth row of AI″ by comparing a multiplication result (i.e., (AI″−1)T×rowk) of the secondary square matrix and the kth row of the m×n matrix with a jth row (IU) of an n×n identity matrix where 1≤j≤n responsive to the secondary hash vector being equal to primary hash vector σ. In an exemplary embodiment, the kth row of the m×n matrix and the jth row of the n×n identity matrix may be associated with a jth non-zero element of the subset index vector I″. In an exemplary embodiment, at each iteration of step 314 in which the kth element of subset index vector I″ is non-zero, the multiplication result may be compared with the jth row of the identity matrix, starting with j=1. If an exemplary multiplication result is equal to the jth row of the identity matrix, j may be incremented by one to examine a next row of AI″ in a next iteration of step 316. Therefore, an exemplary jth non-zero element of subset index vector I″ may be the same as the kth element of subset index vector I″ if the kth element of subset index vector I″ is non-zero. In an exemplary embodiment, verification of rows of AI″ may be repeated until a last row of public key A is loaded (step 318, yes). If an exemplary multiplication result is different from the jth row of the identity matrix in step 316, verification of AI″ (or reloaded matrix (AI″−1)T) may fail, because AI″×AI″−1 may be different from the identity matrix and therefore, an exemplary reloaded matrix AI″−1 may not be considered a correct inverse of matrix AI″. As a result, in an exemplary embodiment, FSM 200 may restart from first state 202. Otherwise, an exemplary verification of transposed inverse public key (AI″−1)T may be successful if all rows of AI″ are successfully verified in step 316.
Referring again to
In an exemplary embodiment, first hash unit 124 may be further configured to sequentially receive each row of the secondary square matrix from processor 101 responsive to FSM 200 being transitioned to seventh state 214 and generate the secondary hash vector by sequentially applying the hashing function on each row of the secondary square matrix. As a result, in an exemplary embodiment, it may take n clock cycles for seventh state 214 to receive and digest all rows of the secondary square matrix after applying the hashing function to each row of public key A that is included in truncated square matrix AI″ in sixth state 212.
In an exemplary embodiment, first comparator circuit 130 may be further configured to implement step 312 of verification process 300 by comparing the secondary hash vector with primary hash vector σ responsive to the secondary hash vector being generated by first hash unit 124. In an exemplary embodiment, when the secondary hash vector is generated and stored in temporary register 127 in seventh state 214, control unit 104 may configure multiplexer 132 through select line sel1 of multiplexer 132 to load primary hash vector σ from second n-bit register 126 to first input 134 of first comparator circuit 130. In an exemplary embodiment, first comparator circuit 130 may then compare primary hash vector σ with the secondary hash vector that is loaded from temporary register 127 to second input 136 of first comparator circuit 130. If the secondary hash vector is equal to primary hash vector σ, comparator circuit 130 may output an exemplary valid signal to control unit 104, indicating that verification of the reloaded inverse public key is successful.
An exemplary logic circuit may further include a fourth n-bit register 138, a fifth n-bit register 140, a first plurality of AND gates 142, a multi-level XOR tree 144, a fourth shift register 146, a fifth shift register 148, and a second comparator circuit 150. To implement step 316 of verification process 300, in an exemplary embodiment, fourth n-bit register 138 may be configured to receive the kth row of m×n matrix A from processor 101 responsive to the secondary hash vector being equal to primary hash vector σ. An exemplary valid signal may configure fourth n-bit register 138 to receive the kth row of matrix A if the secondary hash vector is equal to primary hash vector σ. In an exemplary embodiment, fifth n-bit register 140 may be configured to sequentially receive each row of the secondary square matrix responsive to the secondary hash vector being equal to primary hash vector σ. An exemplary valid signal may configure fifth n-bit register 140 to receive each row of the secondary square matrix if the secondary hash vector is equal to primary hash vector σ.
To implement the multiplication (AI″−1)T×rowk in step 316 of verification process 300, in an exemplary embodiment, first plurality of AND gates 142 may be configured to generate a first n-bit vector Xt by performing a respective bitwise AND operation on each respective bit (for example, a jth bit) in fourth n-bit register 138 and a respective bit (for example, a jth bit) in fifth n-bit register 140. In an exemplary embodiment, first n-bit vector Xt may be associated with a respective row of the secondary square matrix. Each exemplary bit of first n-bit vector Xt may be equal to a bitwise multiplication of a corresponding bit of the kth row of matrix A and a corresponding bit an exemplary row of the secondary square matrix. As a result, in an exemplary embodiment, each row of (AI″−1)T may be convolved with rowk in one clock cycle.
In an exemplary embodiment, fourth shift register 146 may be coupled to multi-level XOR tree 144 and may be configured to sequentially receive each respective bit of the multiplication result from the XOR tree at each clock cycle and generate a fourth shifted bit 152 by shifting the multiplication result one pit per clock cycle. In an exemplary embodiment, fifth shift register 148 may be configured to store the jth row of the n×n identity matrix and generate a fifth shifted bit 154 by circularly shifting the jth row one bit per clock cycle. In an exemplary embodiment, second comparator circuit 150 may be configured to compare the multiplication result with the jth row by comparing fourth shifted bit 152 with fifth shifted bit 154. If, in an exemplary embodiment, the multiplication result is different from the jth row of the n×n identity matrix, verification of the transposed inverse public key (AI″−1)T in step 316 may fail, and consequently, control unit 104 may transition FSM 200 from seventh state 214 to first state 202, so that FSM 200 may restart from its initial state. Otherwise, control unit 104 may transition FSM 200 from seventh state 214 to sixth state 212, so that verification process 300 may proceed to verifying a next row of matrix A.
Referring again to
To implement eighth state 216, an exemplary logic circuit may further include a sixth n-bit register 156, a sixth shift register 158, and a calculation unit 160. In an exemplary embodiment, sixth n-bit register 156 may be configured to store secret key s′. In an exemplary embodiment, sixth shift register 158 may be coupled to first n-bit register 116 and may be configured to generate a sixth shifted bit b′e′[i] by shifting modulo 2 addition vector (b′⊕e′)I″ one bit per clock cycle.
Referring again to
In an exemplary embodiment, each respective bit of public vector bI″′ may be extracted from helper data b′ according to a respective non-zero bit of subset index vector I″. As a result, in an exemplary embodiment, public vector bI″′ may include n most reliable bits of helper data b′ according to subset index vector I″. In an exemplary embodiment, pre-stored hashed key h1′ may have been previously generated by processor 101 by applying the hashing function to bI (defined in Equation (1)) according to original secret key s. Therefore, pre-stored hashed key h1′ may be used for verification of secret key s′ in ninth state 218. If, in an exemplary embodiment, hashed secret key h1″ is equal to pre-stored hashed key h1′, secret key s′ may be considered valid. Otherwise, in an exemplary embodiment, verification of secret key s′ may be considered unsuccessful.
To implement ninth state 218, an exemplary logic circuit may further include a hash-and-compare unit 166.
In an exemplary embodiment, third comparator circuit 170 may be configured to compare hashed secret key h1″ with pre-stored hashed key h1′. If, in an exemplary embodiment, hashed secret key h1″ is different from pre-stored hashed key h1′, FSM 200 may be transitioned back to eighth state 216 to recalculate secret key s′ with one bit-flip in modulo 2 addition vector (b′⊕e′)I″. Therefore, in an exemplary embodiment, control unit 104 may be configured to transition FSM 200 from ninth state 218 to eighth state 216 responsive to an ith successive failure of the verification of secret key s′ where i<n+1. Since, in an exemplary embodiment, there may be n possible bit-flips in modulo 2 addition vector (b′⊕e′)I″, FSM 200 may be successively transitioned from ninth state 218 to eighth state 216 until a number of successive failures of verification of secret key s′ reaches n+1. If none of exemplary bit-flips of (b′⊕e′)I″ leads to a successful verification of secret key s′, secret key s′ may be considered invalid and logic circuit 100 may generate an error signal. As a result, in an exemplary embodiment, control unit 104 may be configured to transition FSM 200 from ninth state 218 to first state 202 responsive to an (n+1)th successive failure of the verification of the secret key s′, so that FSM 200 may restart from an idle state.
Referring again to
To implement tenth state 220, in an exemplary embodiment, hash-and-compare unit 166 may further include a third hash unit 172. In an exemplary embodiment, third hash unit 170 may be configured to generate response signal h0″ by applying the hashing function to public vector bI″′ according to secret key s′ responsive to FSM 200 being transitioned to tenth state 220. In an exemplary embodiment, if hashed secret key h1″ is equal to pre-stored hashed key h1′ (i.e., secret key s′ is verified successfully), third comparator circuit 170 may trigger a buffer circuit 174 that is coupled to third hash unit 172 to pass response signal h0″ as a final output of logic circuit 100. Afterwards, in an exemplary embodiment, control unit 104 may transition FSM 200 from tenth 220 state to first state 202 responsive to response signal h0″ being generated.
In order to differentiate response signal h0″ from hashed secret key h1″ (since they are both generated from public vector bI″′ according to secret key s′), different extra bits may be concatenated to inputs of second hash unit 168 and third hash unit 172. For example, a “1” bit may be concatenated to the input data of second hash unit 168 and a “0” bit may be concatenated to the input data of third hash unit 172. An exemplary concatenation may have to be previously applied to bI for generation of pre-stored hashed key h1′, so that digestion of secret key s′ may be consistent with that of original secret key s.
If programmable logic is used, such logic may execute on a commercially available processing platform or a special purpose device. One ordinary skill in the art may appreciate that an embodiment of the disclosed subject matter can be practiced with various computer system configurations, including multi-core multiprocessor systems, minicomputers, mainframe computers, computers linked or clustered with distributed functions, as well as pervasive or miniature computers that may be embedded into virtually any device.
For instance, a computing device having at least one processor device and a memory may be used to implement the above-described embodiments. A processor device may be a single processor, a plurality of processors, or combinations thereof. Processor devices may have one or more processor “cores.”
An embodiment of the invention is described in terms of this example computer system 400. After reading this description, it will become apparent to a person skilled in the relevant art how to implement the invention using other computer systems and/or computer architectures. Although operations may be described as a sequential process, some of the operations may in fact be performed in parallel, concurrently, and/or in a distributed environment, and with program code stored locally or remotely for access by single or multiprocessor machines. In addition, in some embodiments the order of operations may be rearranged without departing from the spirit of the disclosed subject matter.
Processor device 404 may be a special purpose (e.g., a graphical processing unit) or a general-purpose processor device. As will be appreciated by persons skilled in the relevant art, processor device 404 may also be a single processor in a multi-core/multiprocessor system, such system operating alone, or in a cluster of computing devices operating in a cluster or server farm. Processor device 404 may be connected to a communication infrastructure 406, for example, a bus, message queue, network, or multi-core message-passing scheme.
In an exemplary embodiment, computer system 400 may include a display interface 402, for example a video connector, to transfer data to a display unit 430, for example, a monitor. Computer system 400 may also include a main memory 408, for example, random access memory (RAM), and may also include a secondary memory 410. Secondary memory 410 may include, for example, a hard disk drive 412, and a removable storage drive 414. Removable storage drive 414 may include a floppy disk drive, a magnetic tape drive, an optical disk drive, a flash memory, or the like. Removable storage drive 414 may read from and/or write to a removable storage unit 418 in a well-known manner. Removable storage unit 418 may include a floppy disk, a magnetic tape, an optical disk, etc., which may be read by and written to by removable storage drive 414. As will be appreciated by persons skilled in the relevant art, removable storage unit 418 may include a computer usable storage medium having stored therein computer software and/or data.
In alternative implementations, secondary memory 410 may include other similar means for allowing computer programs or other instructions to be loaded into computer system 400. Such means may include, for example, a removable storage unit 422 and an interface 420. Examples of such means may include a program cartridge and cartridge interface (such as that found in video game devices), a removable memory chip (such as an EPROM, or PROM) and associated socket, and other removable storage units 422 and interfaces 420 which allow software and data to be transferred from removable storage unit 422 to computer system 400.
Computer system 400 may also include a communications interface 424. Communications interface 424 allows software and data to be transferred between computer system 400 and external devices. Communications interface 424 may include a modem, a network interface (such as an Ethernet card), a communications port, a PCMCIA slot and card, or the like. Software and data transferred via communications interface 424 may be in the form of signals, which may be electronic, electromagnetic, optical, or other signals capable of being received by communications interface 424. These signals may be provided to communications interface 424 via a communications path 426. Communications path 426 carries signals and may be implemented using wire or cable, fiber optics, a phone line, a cellular phone link, an RF link or other communications channels.
In this document, the terms “computer program medium” and “computer usable medium” are used to generally refer to media such as removable storage unit 418, removable storage unit 422, and a hard disk installed in hard disk drive 412. Computer program medium and computer usable medium may also refer to memories, such as main memory 408 and secondary memory 410, which may be memory semiconductors (e.g. DRAMs, etc.).
Computer programs (also called computer control logic) are stored in main memory 408 and/or secondary memory 410. Computer programs may also be received via communications interface 424. Such computer programs, when executed, enable computer system 400 to implement different embodiments of the present disclosure as discussed herein. In particular, the computer programs, when executed, enable processor device 404 to implement the processes of the present disclosure, such as the operations in verification process 300 illustrated by flowchart of
Embodiments of the present disclosure also may be directed to computer program products including software stored on any computer useable medium. Such software, when executed in one or more data processing device, causes a data processing device to operate as described herein. An embodiment of the present disclosure may employ any computer useable or readable medium. Examples of computer useable mediums include, but are not limited to, primary storage devices (e.g., any type of random access memory), secondary storage devices (e.g., hard drives, floppy disks, CD ROMS, ZIP disks, tapes, magnetic storage devices, and optical storage devices, MEMS, nanotechnological storage device, etc.).
The embodiments have been described above with the aid of functional building blocks illustrating the implementation of specified functions and relationships thereof. The boundaries of these functional building blocks have been arbitrarily defined herein for the convenience of the description. Alternate boundaries can be defined so long as the specified functions and relationships thereof are appropriately performed.
While the foregoing has described what may be considered to be the best mode and/or other examples, it is understood that various modifications may be made therein and that the subject matter disclosed herein may be implemented in various forms and examples, and that the teachings may be applied in numerous applications, only some of which have been described herein. It is intended by the following claims to claim any and all applications, modifications and variations that fall within the true scope of the present teachings.
Unless otherwise stated, all measurements, values, ratings, positions, magnitudes, sizes, and other specifications that are set forth in this specification, including in the claims that follow, are approximate, not exact. They are intended to have a reasonable range that is consistent with the functions to which they relate and with what is customary in the art to which they pertain.
The scope of protection is limited solely by the claims that now follow. That scope is intended and should be interpreted to be as broad as is consistent with the ordinary meaning of the language that is used in the claims when interpreted in light of this specification and the prosecution history that follows and to encompass all structural and functional equivalents. Notwithstanding, none of the claims are intended to embrace subject matter that fails to satisfy the requirement of Sections 101, 102, or 103 of the Patent Act, nor should they be interpreted in such a way. Any unintended embracement of such subject matter is hereby disclaimed.
Except as stated immediately above, nothing that has been stated or illustrated is intended or should be interpreted to cause a dedication of any component, step, feature, object, benefit, advantage, or equivalent to the public, regardless of whether it is or is not recited in the claims.
It will be understood that the terms and expressions used herein have the ordinary meaning as is accorded to such terms and expressions with respect to their corresponding respective areas of inquiry and study except where specific meanings have otherwise been set forth herein. Relational terms such as first and second and the like may be used solely to distinguish one entity or action from another without necessarily requiring or implying any actual such relationship or order between such entities or actions. The terms “comprises,” “comprising,” or any other variation thereof, are intended to cover a non-exclusive inclusion, such that a process, method, article, or apparatus that comprises a list of elements does not include only those elements but may include other elements not expressly listed or inherent to such process, method, article, or apparatus. An element proceeded by “a” or “an” does not, without further constraints, preclude the existence of additional identical elements in the process, method, article, or apparatus that comprises the element.
The Abstract of the Disclosure is provided to allow the reader to quickly ascertain the nature of the technical disclosure. It is submitted with the understanding that it will not be used to interpret or limit the scope or meaning of the claims. In addition, in the foregoing Detailed Description, it can be seen that various features are grouped together in various implementations. This is for purposes of streamlining the disclosure, and is not to be interpreted as reflecting an intention that the claimed implementations require more features than are expressly recited in each claim. Rather, as the following claims reflect, inventive subject matter lies in less than all features of a single disclosed implementation. Thus, the following claims are hereby incorporated into the Detailed Description, with each claim standing on its own as a separately claimed subject matter.
While various implementations have been described, the description is intended to be exemplary, rather than limiting and it will be apparent to those of ordinary skill in the art that many more implementations and implementations are possible that are within the scope of the implementations. Although many possible combinations of features are shown in the accompanying figures and discussed in this detailed description, many other combinations of the disclosed features are possible. Any feature of any implementation may be used in combination with or substituted for any other feature or element in any other implementation unless specifically restricted. Therefore, it will be understood that any of the features shown and/or discussed in the present disclosure may be implemented together in any suitable combination. Accordingly, the implementations are not to be restricted except in light of the attached claims and their equivalents. Also, various modifications and changes may be made within the scope of the attached claims.
This application is a continuation-in-part of International Patent Application PCT/IB2022/050165, filed on Jan. 11, 2022, and entitled “BIOMETRIC AUTHENTICATION BASED ON LEARNING PARITY WITH NOISE,” which takes priority from U.S. Provisional Patent Application Ser. No. 63/135,759 filed on Jan. 11, 2021, and entitled “LIGHTWEIGHT FUZZY EXTRACTOR BASED ON LPN FOR IOT”, which are all incorporated herein by reference in their entirety.
Number | Date | Country | |
---|---|---|---|
63135759 | Jan 2021 | US |
Number | Date | Country | |
---|---|---|---|
Parent | PCT/IB2022/050165 | Jan 2022 | US |
Child | 17893663 | US |