Next Article in Journal
Proof of Principle for Direct Reconstruction of Qualitative Depth Information from Turbid Media by a Single Hyper Spectral Image
Next Article in Special Issue
Federated Compressed Learning Edge Computing Framework with Ensuring Data Privacy for PM2.5 Prediction in Smart City Sensing Applications
Previous Article in Journal
Validation of Scolioscan Air-Portable Radiation-Free Three-Dimensional Ultrasound Imaging Assessment System for Scoliosis
Previous Article in Special Issue
Decentralized Trusted Data Sharing Management on Internet of Vehicle Edge Computing (IoVEC) Networks Using Consortium Blockchain
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

Acceleration of Inner-Pairing Product Operation for Secure Biometric Verification †

Department of Electrical and Computer Engineering, Inha University, Incheon 22212, Korea
*
Author to whom correspondence should be addressed.
This paper is an extended version of our paper published in the poster session of WISA 2020, “Seong-Yun Jeon; Mun-Kyu Lee. Poster: Acceleration of Pairing Product Operation Using Precomputation”, where we have presented a Fixed-Q product method. In this paper, we provide a full description of this method, and present a facial verification application to demonstrate the feasibility of the proposed method. A part of this paper also appeared in the Master’s Thesis, “Seong-Yun Jeon. Acceleration of Pairing Operation for Performance Improvement of Functional Encryption” in Korean.
Sensors 2021, 21(8), 2859; https://doi.org/10.3390/s21082859
Submission received: 10 February 2021 / Revised: 6 April 2021 / Accepted: 11 April 2021 / Published: 19 April 2021
(This article belongs to the Special Issue Selected Papers from WISA 2020)

Abstract

:
With the recent advances in mobile technologies, biometric verification is being adopted in many smart devices as a means for authenticating their owners. As biometric data leakage may cause stringent privacy issues, many proposals have been offered to guarantee the security of stored biometric data, i.e., biometric template. One of the most promising solutions is the use of a remote server that stores the template in an encrypted form and performs a biometric comparison on the ciphertext domain, using recently proposed functional encryption (FE) techniques. However, the drawback of this approach is that considerable computation is required for the inner-pairing product operation used for the decryption procedure of the underlying FE, which is performed in the authentication phase. In this paper, we propose an enhanced method to accelerate the inner-pairing product computation and apply it to expedite the decryption operation of FE and for faster remote biometric verification. The following two important observations are the basis for our improvement—one of the two arguments for the decryption operation does not frequently change over authentication sessions, and we only need to evaluate the product of multiple pairings, rather than individual pairings. From the results of our experiments, the proposed method reduces the time required to compute an inner-pairing product by 30.7%, compared to the previous best method. With this improvement, the time required for biometric verification is expected to decrease by up to 10.0%, compared to a naive method.

1. Introduction

Biometric recognition is the automated recognition of individuals based on their biological and behavioral characteristics. Biometric recognition has two types [1]: biometric identification and biometric verification. Biometric identification is a process that searches against a biometric enrolment database to find and return the biometric reference identifier(s) attributable to a single user. Conversely, biometric verification is a process that confirms a biometric claim through biometric comparison. In a biometric verification system, a user can make a biometric claim to a biometric characteristic examiner. When a user claims that he or she is the source of a specified biometric reference, the examiner may verify this claim by performing a biometric comparison. With the recent advances in mobile technologies, biometric verification is being adopted in many smart devices as a tool for authenticating their owners. This technique is used not only to unlock devices but also permit users to run security-critical applications, such as financial services [2].
For biometric verification, the biometric data of a user should be stored first during biometric enrolment. The stored biometric data are referred to as a biometric reference, and they are stored using a data structure called a biometric template [1]. However, biometric characteristics are unique and unchangeable; this implies that leakage of these characteristics may cause more critical privacy issues than the compromise of existing passwords and personal identification numbers (PINs). Furthermore, users’ biometric templates are often compromised, especially for mobile devices [3]. Therefore, a biometric verification method that ensures the security of the biometric template must be developed [4,5].
Several proposals are available in the literature to secure biometric templates without additional hardware support such as ARM Trust Zone [6] and Apple Secure Enclave [7]. First, there are methods to convert biometric data using noninvertible transforms, such as cancelable biometrics [8,9] and fuzzy commitment [10]. However, these methods have a problem of decreasing recognition accuracy owing to the conversion process. In addition, there are many cases where one-way transformations are analyzed and inverted successfully [11,12,13].
There are also biometric key generation techniques for biometric template protection [14,15,16]. Using these methods, a unique and high-entropy key can be generated from the user’s biometric input on the fly. These methods have a very desirable property that the user’s biometric template does not need to be stored in the device. However, to achieve both goals of providing a sufficient level of recognition rate and effectively generating biometric keys, these methods require additional tools. For example, the electrocardiogram-based biometric key generation method in [14] requires for helper data to be stored. According to [16], the use of helper data is not desirable. The electroencephalography (EEG)-based method in [15] requires high-bandwidth data with more than 60 channels. It was pointed out in [17] that in most commercially available EEG devices, less than 20 channels are provided. The fingerprint-based biometric key generation method in [16] requires an additional device such as a smart card. On the contrary, if a remote server is available, storing the biometric template on the remote server outside the device is another option for biometric verification without the need for additional tools or performance degradation [18,19,20,21]. In these methods, the server functions as a secure repository. This approach is also suitable when a user wants to be granted access to a particular remote service using an authentication server (e.g., online banking). However, this approach can raise another privacy issue because the remote server can learn the user’s biometric characteristics. In other words, an honest-but-curious server may try to recover the user’s biometric features using the user’s stored template. In addition, attackers who intrude into the server may obtain the biometric features of the legitimate user. These features may be used to impersonate the legitimate user in another system [19,20,21]. Therefore, an encryption scheme that encrypts biometric data and makes the server examine the similarity in encrypted data is necessary for a privacy-preserving biometric verification.
Meanwhile, functional encryption (FE) is an encryption scheme in which possessing a secret key allows one to obtain only the result of f ( x ) from a ciphertext E ( x ) , but not learn any information about the data x, where the secret key is related to the function f and the ciphertext E ( x ) is the encryption of data x. Hence, FE is considered a suitable scheme for constructing a privacy-preserving biometric verification system [22,23,24]. As FE requires considerable computation, extensive research has been conducted to make FE more practical, particularly when the evaluated function is an inner product of a plaintext vector x with a vector y encoded in the function f [25,26,27,28,29]. Kim et al. proposed a practical inner product FE scheme with a function-hiding property, which implies that not only x but also y remain hidden [22]. They also provided a reference code implemented in Python and evaluated the required durations for main operations, such as key generation, encryption, and decryption. According to their measurement, the dominant operations took up to several seconds on a desktop PC, and this indicates that FE may guarantee a practical level of performance. Kim et al.’s scheme is very suitable as a base scheme for a privacy-preserving biometric verification system, but its decryption operation requires an inner-pairing product operation [22], which is its most time-consuming part. An inner-pairing product is the product of multiple pairings, and its inputs are two vectors comprising points on a certain elliptic curve [30]. There are several optimization techniques for the inner-pairing product [31,32,33,34]. Scott suggested to share underlying operations for multiple pairings [31] and the validity of this approach was verified in [32,33]. Costello et al. proposed to apply precomputation to accelerate pairing operations [34].
In this paper, we propose an improved method for accelerating inner-pairing product computation by combining the shared computation techniques and precomputation. The experimental results indicate that the proposed method reduces the time required to compute an inner-pairing product by up to 30.7%. To cope with the situation where the memory is not sufficient to store all the precomputed data, we also propose an adaptive method that can adjust the number of elements to be precomputed and stored. According to our analysis, the performance of the proposed method can be fine-tuned adaptively according to the storage capacity. Furthermore, we demonstrate that the proposed method is suitable for application to a remote biometric verification system using FE, where one of the two inputs to the inner-pairing product operation is not frequently changed. Using the proposed method, we can assume that the performance of biometric verification will be enhanced by 9.0–10.0%.

1.1. Related Works

In 2005, Scott proposed three ideas to optimize the inner-pairing product computation for Tate pairing by sharing the common operations among the pairings [31]. In 2006, Granger et al. showed that Scott’s method can also be applied to the inner-pairing product for Ate pairing [32]. In 2015, Zavattoni et al. proposed an optimized method to compute the products of optimal Ate pairings on the BN curve [33]. Meanwhile, in 2010, Costello et al. proposed a precomputation method to accelerate pairing computation when one argument of the pairing is fixed [34]. The more times the pairing is called, the more gain is obtained in the execution time, at the small expense of memory to store the precomputed elements. Recently, the pairing operations are being adopted as a crucial operation for many applications, such as privacy-preserving applications [35,36] and non-interactive zero-knowledge proofs [37,38].
There have been various research results in the literature for secure remote biometric verification [39,40,41,42,43,44,45,46,47,48]. In 2016, Cheon et al. proposed a homomorphic encryption (HE)-based protocol to support encrypted Hamming distance computation required for iris recognition [40]. In the same year, Im et al. [41] proposed an HE-based protocol to support encrypted Euclidean distance computation for palm print authentication [49]. In 2018, Gunasinghe and Bertino proposed a secure face verification protocol based on zero-knowledge proof of knowledge (ZKPK). To perform their protocol, a trusted execution environment (TEE) should be equipped on the device. In the same year, Droandi et al. [48] proposed a multi-party computation-based biometric matching protocol using SPDZ protocol [50]. Although their protocol was very fast, it required a high communication cost for preprocessing. In 2020, Im et al. proposed a secure face verification system that guarantees a real-time authentication performance on a smartphone [2]. They evaluated the performance of their system with two experiments; (1) an experiment involving 30 users in a real-world environment and (2) an experiment using the public face datasets CFP [51] and ORL [52]. In this paper, we consider the data presented in [2] as the criteria to evaluate the performance of the proposed method, since the result in [2] is one of the most up-to-date practical works in the literature of privacy-preserving biometric authentication. A more extensive survey of FE-based privacy-preserving applications can be found in [35].

1.2. Contributions

In this paper, we propose a method for accelerating inner-pairing product computation by combining the shared computation techniques and precomputation. To be precise, our contributions are as follows:
  • We propose a new algorithm that accelerates inner-pairing product computation when one of the two input vectors are fixed. For each element in this fixed vector, we apply the precomputation method that was originally proposed for a single pairing in [34]. In addition, we reduce the overall computational complexity by sharing overlapping operations for multiple pairings, as in [31].
  • To handle the situation where the memory is not sufficient to store all the precomputed data for all vector elements, we also propose an adaptive method that can adjust the number of precomputed elements. Therefore, the performance of the proposed method can be fine-tuned adaptively by selectively storing the precomputed elements according to the storage capacity.
  • We demonstrate that the proposed method can significantly accelerate the FE-based biometric verification process. In particular, we exploit the fact that the values related to a biometric template can be precomputed when registered as the template is stored once and repeatedly used without any change.

2. Preliminaries

2.1. Remote Biometric Verification System

In this study, we focus on biometric verification among the two types of biometric recognition. A biometric characteristic examiner can use a remote biometric verification system to authenticate users. Figure 1 shows the generic structure of the remote biometric verification system [1]. For better understanding, we will explain the structure with a facial verification system as an example. The system consists of a client for the user and a remote server for the biometric characteristic examiner. We can consider a smartphone as a typical example of the client. The following are the steps required to register a user’s biometric data.
  • A user presents a biometric characteristic to a biosensor in a biometric capture subsystem, and the subsystem runs its biometric capture process to acquire a biometric sample. For facial verification, the user’s smartphone camera takes a picture of the user’s face. In addition to the biometric capture process, a biometric acquisition process is performed when required. The biometric acquisition process includes segmentation, quality control, and other preprocessing steps. For facial verification, various image processing techniques, such as face detection, alignment and frontalization, can be applied.
  • A client passes the biometric sample to the feature extraction module. The module attempts to extract a biometric feature from the biometric sample. For face verification, deep neural networks are frequently used [53,54].
  • The client performs biometric enrolment. To be precise, the client sends the extracted biometric feature to the server, and the server stores the biometric feature as a biometric reference to a biometric enrolment database. In the database, biometric references are managed using a data structure referred to as a biometric template.
In the authentication phase, the client performs the biometric capture and feature extraction processes, which are the same as the first and second steps of the above biometric registration phase. Then, the client sends the extracted biometric feature as the biometric claim to be used for verification. The server delivers the biometric feature from the client to its verifying module. This claimed feature is referred to as a biometric probe. The module loads the biometric reference (i.e., the stored biometric template) of the claimant for biometric comparison. Biometric comparison is the similarity estimation between the biometric reference and the biometric probe. For example, if the biometric feature is represented as a vector, the similarity can be estimated by computing either the Hamming or Euclidean distance between the two feature vectors. Based on the result of biometric comparison (i.e., the comparison score) and a decision policy including a threshold, whether the biometric probe and biometric reference have the same biometric source is determined. If this is affirmative, the server accepts the claimant as an authenticated user.
However, as explained in the introduction, the above approach can be a threat to user’s privacy, because the server may try to recover the user’s biometric features from the stored template. Section 2.4 will briefly explain the countermeasure against this threat using functional encryption.

2.2. Barreto—Naehrig Curve (BN Curve)

If a non-supersingular elliptic curve over F p contains a subgroup whose embedding degree k is not substantially large, it is called a pairing-friendly curve. In other words, computations in the field F p k are feasible. Barreto and Naehrig presented a method to construct pairing-friendly elliptic curves of prime order and embedding degree k = 12 [55], whose curve form is E ( F p ) : y 2 = x 3 + b , with b 0 . For non-zero t, they parameterized the order n of the elliptic curve group and the characteristic p as follows:
n = 36 t 4 + 36 t 3 + 18 t 2 + 6 t + 1
p = 36 t 4 + 36 t 3 + 24 t 2 + 6 t + 1
The order of a point P E is the least non-zero integer r such that [ r ] P = , where [ r ] P is the sum of r terms equal to P [56]. Therefore, the fact that n is a prime implicitly indicates that r is equal to n, and r is also prime.

2.3. Pairing

2.3.1. Cryptographic Pairing

Pairing is defined as a map e : G 1 × G 2 G T for additive groups G 1 , G 2 and a multiplicative group G T [57]. The orders of G 1 , G 2 , and G T are the prime number r. The identity elements of these groups are denoted by 0 G 1 , 0 G 2 , and 1 G T , respectively. Furthermore, the pairing should have the following two properties:
  • Bilinearity For all g 1 G 1 , g 2 G 2 , and a , b Z r ,
    e ( [ a ] g 1 , [ b ] g 2 ) = e ( g 1 , g 2 ) a b .
  • Non-degeneracy For g 1 0 G 1 , g 2 0 G 2
    e ( g 1 , g 2 ) 1 G T .
In addition to the above two mathematical properties, cryptographic pairing requires the following property [57]:
  • Computability The map e can be efficiently computed.
The most efficient cryptographic pairings are constructed using an elliptic curve E, which is defined over a finite field F q . Specifically, G 1 and G 2 are subgroups of the rational points of an elliptic curve E defined over an extension F q k of F q . Furthermore, G T is the group ( F q k * , × ) , where the group law is given by the field multiplication on F q k . We define the tuple ( r , G 1 , G 2 , G T , g 1 , g 2 , e ) as a bilinear environment of cryptographic pairing.
An inner-pairing product e p r o d is defined by the following equation for two vectors P = ( P 1 , P 2 , , P d ) G 1 d and Q = ( Q 1 , Q 2 , , Q d ) G 2 d :
e p r o d ( P , Q ) = j = 1 d e ( P j , Q j )

2.3.2. Miller’s Algorithm and Final Exponentiation

The Weil pairing was first introduced by André Weil in 1940 [58]. It plays an important role in the theoretical study of the arithmetic of elliptic curves and Abelian varieties [58]. Miller presented an algorithm in 2004 that efficiently computes Weil pairing, which is the first practical pairing computation method [59]. Since then, most pairings, including Weil Pairing, have been designed based on Miller’s algorithm for efficient operation. The basic Miller’s algorithm takes a pair of elements of the elliptic curve subgroups G 1 and G 2 , both of whose orders are the prime order r, and repeats a series of processes as much as the bit length m of r. This loop is referred to a Miller loop. For any point U, V on the elliptic curve and the element X G 1 , Y G 2 , line equation L U , V ( X , Y ) is defined as the equation of the line passing through U and V, whereas tangent equation T U ( X , Y ) is defined as the tangent to the point U. Miller’s algorithm includes multiplication and squaring operations on G T , addition and multiplication operations on G 1 or G 2 , and evaluation of the line and tangent equations. Miller’s algorithm is used to compute not only Weil pairing but also many other cryptographic pairings, such as the Tate pairing or Tate variant pairings [60,61]. Thus, a special operation referred to as final exponentiation is performed to force the result of the Miller loop to be a unique value for the multiplicative group G T [57]. In other words, final exponentiation must be performed after the Miller loop to obtain the correct operation result.

2.3.3. Optimal Ate Pairing on the BN Curve

The Ate pairing [62,63] and its variations [64,65,66] are simply optimized versions of the Tate pairing using Frobenius endomorphism [67]. In 2008, Vercauteren proposed optimal pairings and optimized the Miller loop of Ate pairing, which uses Frobenius endomorphism on a pairing-friendly elliptic curve [67]. In 2010, Beuchat et al. presented an implementation for the optimal Ate pairing of [67] on the BN curve [68]. They reported that the performance of Ate pairing is optimized by setting t of the BN curve as 2 62 2 54 + 2 44 . Algorithm 1 represents the algorithm for calculating the optimal Ate pairing [68], where π ( Q ) is the Frobenius map of Q and π 2 ( Q ) = ( π · π ) ( Q ) .
Algorithm 1 Optimal Ate pairing on the BN curve.
Input:  s = 6 t + 2 , m = the bit length of s, P G 1 , Q G 2
Output:  e ( P , Q )
1:
Write s in signed binary form, s = i = 0 m 1 s [ i ] 2 i with s [ i ] { 1 , 0 , 1 }
2:
T Q , f 1
3:
for i m 2 down to 0 do
4:
     f f 2 · L T , T ( P ) , T 2 T
5:
    if s [ i ] = 1 then
6:
         f f · L T , Q ( P ) , T T + Q
7:
    else if s [ i ] = 1 then
8:
         f f · L T , Q ( P ) , T T Q
9:
    end if
10:
end for
11:
R π ( Q ) , f f · L T , R ( P ) , T T + R
12:
R π 2 ( Q ) , f f · L T , R ( P ) , T T R
13:
f f ( p 12 1 ) / r
14:
returnf

2.4. Function-Hiding Inner Product Encryption

Inner product encryption (IPE) is an FE whose function f is the inner product of the input vector x with the vector y encoded in the function f. That is, IPE performs f ( x ) = x , y , by using a secret key associated with vector y and the ciphertext associated with vector x as inputs.
Meanwhile, if the FE guarantees that the data associated with its function f remain hidden as well as x , we confirm that an FE has a function-hiding property. For example, the associated data may be vector y for IPE, and a privacy-preserving biometric verification system using IPE should be equipped with the function-hiding property as the biometric data should be securely handled both in the registration and authentication phases [69].
Hereinafter, we use I P E , a function-hiding IPE with practical performance proposed by Kim et al. [22]. For λ N , d N , and the range of the inner product S, the function-hiding IPE is defined as I P E = ( I P E . S e t u p , I P E . K e y G e n , I P E . E n c r y p t , I P E . D e c r y p t ) , where each operation is defined as follows:
  • I P E . S e t u p ( 1 λ , S )
    • Select a bilinear environment ( r , G 1 , G 2 , G T , g 1 , g 2 , e ) according to the security parameter λ .
    • Choose a matrix B GL d ( Z r ) , where GL d ( Z r ) refers to a group of d × d square matrix, where each element belongs to the finite field Z r and an inverse matrix exists.
    • Compute B det ( B ) · ( B 1 ) .
    • Output the public parameter p p = ( G 1 , G 2 , G T , r , e , S ) and the master secret key m s k = ( p p , g 1 , g 2 , B , B ) .
  • I P E . K e y G e n ( m s k , y )
    • Choose a uniformly random element α R Z r .
    • Using the master key m s k and the vector y Z r d , output the secret key s k = ( K 1 , K 2 ) = ( [ α · det ( B ) ] g 1 , [ α · y · B ] g 1 ) , s.t. K 2 G 1 d .
  • I P E . E n c r y p t ( m s k , x )
    • Choose a uniformly random element β R Z r
    • Using the master key m s k and the vector x Z r d , output the ciphertext c t = ( C 1 , C 2 ) = ( [ β ] g 2 , [ β · x · B ] g 2 ) , s.t. C 2 G 2 d .
  • I P E . D e c r y p t ( p p , s k , c t )
    • Using the public parameter p p , the secret s k = ( K 1 , K 2 ) , and the ciphertext c t = ( C 1 , C 2 ) , compute D 1 = e ( K 1 , C 1 ) and D 2 = e p r o d ( K 2 , C 2 ) .
    • Find a solution z for D 1 z = D 2 If this z exists, it satisfies z = x , y . Output z if it exists; otherwise, output ⊥, indicating that a solution does not exist.
In this study, we use I P E to construct a privacy-preserving biometric verification system. The two vectors x and y are encoded to ensure that they represent the biometric probe and biometric reference, respectively. Furthermore, the authors of [22] suggested methods to encode a biometric feature vector to either x or y; thus, the Hamming and the Euclidean distance between two biometric feature vectors can be calculated using the inner product x , y . Using this method, we can encrypt all biometric data transmitted to the server as well as the stored biometric template. The biometric comparison is performed on the encrypted biometric data. However, the comparison score is output as a plain value to ensure that the verification module can decide regarding the authenticity of the claimant. In summary, a biometric verification system that keeps all biometric data from leaking the biometric characteristics even during the biometric comparison can be constructed using I P E .

3. Existing Optimization Techniques for Computing Pairing

The inner-pairing product can be performed in a naive manner to calculate e ( P j , Q j ) for all j and multiply them all. We call this approach the Naive method. However, this native method can be improved based on two directions of research. We briefly review them in this section.

3.1. Optimal Ate Pairing Product on the BN Curve

In 2005, Scott proposed three ideas to optimize the Naive method for Tate pairing [31].
  • In the case of a modular multiplicative inverse operation, a simultaneous inversion operation [70] can be applied.
  • During the computation of Miller’s algorithm, the squaring operation on G T (e.g., in line 4 of Algorithm 1) can be shared.
  • The final exponentiation operation can be shared.
In 2006, Robert Granger et al. reported that the performance of inner-pairing product computation for Ate pairings can be improved by applying the second and third ideas [32]. In 2015, Eric Zavattoni et al. implemented an optimized method to compute the products of optimal Ate pairings on the BN curve, which we call the Product method in this paper [33].
Algorithm 2 demonstrates how the Product method is computed in the bilinear environment of Section 2.3.3.

3.2. Fixed Argument Pairings

In 2010, Costello et al. proposed a method to compute a pairing using precomputation when one argument of the pairing is fixed [34]. Algorithm 3 demonstrates the application of precomputation to Q for the optimal Ate pairing, adopting the method in [34] when Q G 2 is fixed. Algorithm 4 presents the pairing computation procedure when P and Q are given as inputs, where Q is a precomputed tuple based on Q. The main idea of this precomputation-based method is that the line and the tangent equation in the Miller loop of the optimal Ate pairing can be precomputed with only Q without P to obtain the gradient λ and constant c of the equations. π can also be computed in advance with only Q. Thus, it is also included in precomputation.
During online computation of the pairing, the precomputed Q , rather than Q, is applied to the linear equation, tangent equation, and π . The Fixed-Q method refers to an inner-pairing product method that replaces the individual pairing of the Naive method to the online computation of Fixed-Q pairing.
Algorithm 2 Products of optimal Ate pairings on the BN curve (Product method).
Input:  s = 6 t + 2 , m = the bit length of s, P j G 1 , Q j G 2 , where j is 1 , , d
Output:  e p r o d ( P , Q )
1:
Write s in signed binary form, s = i = 0 m 1 s [ i ] 2 i with s [ i ] { 1 , 0 , 1 }
2:
f 1
3:
for j 1 tondo
4:
     T j Q j
5:
end for
6:
for i m 2 down to 0 do
7:
     f f 2
8:
    for j 1 to d do
9:
         f f · L T j , T j ( P j ) , T j [ 2 ] T j
10:
        if s [ i ] = 1 then
11:
            f f · L T j , Q j ( P j ) , T j T j + Q j
12:
        else if s [ i ] = 1 then
13:
            f f · L T j , Q j ( P j ) , T j T j Q j
14:
        end if
15:
    end for
16:
end for
17:
for j 1 toddo
18:
     R π ( Q j ) , f f · L T j , R ( P j ) , T j T j + R
19:
     R π 2 ( Q j ) , f f · L T j , R ( P j ) , T j T j R
20:
end for
21:
f f ( p 12 1 ) / r
22:
returnf
Algorithm 3 Fixed-Q precomputation.
Input:  s = 6 t + 2 , m = the bit length of s, Q G 2
Output:  Q = ( G D B L , G A D D , π Q , π 2 Q )
1:
Write s in signed binary form, s = i = 0 m 1 s [ i ] 2 i with s [ i ] { 1 , 0 , 1 }
2:
T Q , G D B L { } , G A D D { }
3:
for i m 2 down to 0 do
4:
    Compute λ and c , such that y Q + λ x Q + c is the line tangent to T
5:
     T [ 2 ] T
6:
    Append ( λ , c ) to G D B L
7:
    if s [ i ] = 1 then
8:
         Compute λ and c , such that y Q + λ x Q + c is the line joining T and Q
9:
          T T + Q
10:
        Append ( λ , c ) to G A D D
11:
    else if s [ i ] = 1 then
12:
        Compute λ and c , such that y Q + λ x Q + c is the line joining T and Q
13:
         T T Q
14:
        Append ( λ , c ) to G A D D
15:
    end if
16:
end for
17:
R π ( Q )
18:
Compute λ and c , such that y R + λ x R + c is the line joining T and R
19:
π Q ( λ , c )
20:
R π 2 ( Q )
21:
Compute λ and c , such that y R + λ x R + c is the line joining T and R
22:
π 2 Q ( λ , c )
23:
Q ( G D B L , G A D D , π Q , π 2 Q )
24:
return Q
Algorithm 4 Fixed-Q pairing.
Input:  s = 6 t + 2 , m = the bit length of s , P G 1 , Q = ( G D B L , G A D D , π Q , π 2 Q ) (the precomputation tuple for Q, where Q G 2 )
Output:  e ( P , Q )
1:
Write s in signed binary form, s = i = 0 m 1 s [ i ] 2 i with s [ i ] { 1 , 0 , 1 }
2:
f 1 , c n t 1
3:
for i m 2 down to 0 do
4:
     λ , c G D B L [ i ]
5:
    Compute g ( y P + λ x P + c )
6:
     f f 2 · g
7:
    if s [ i ] 0 then
8:
          λ , c G A D D [ c n t ]
9:
         Compute g ( y P + λ x P + c )
10:
         c n t c n t + 1
11:
         f f · g
12:
    end if
13:
end for
14:
λ , c π Q
15:
Compute g ( y P + λ x P + c )
16:
f f · g
17:
λ , c π 2 Q
18:
Compute g ( y P + λ x P + c )
19:
f f · g
20:
f f ( p 12 1 ) / r
21:
returnf

4. Proposed Method

In this section, we present our proposed method to efficiently compute an inner-pairing product. The proposed method combines two previous approaches and adopts both precomputation and shared computation techniques. We call our method the Fixed-Q Product method. This method is a revised version of the method presented in the preliminary version of this paper [71] and the Master’s Thesis of the first author [72].
Algorithm 5 presents the detailed procedure of the Fixed-Q Product method. In the input of the Fixed-Q Product method, Q is used instead of Q , unlike the Product method. In other words, all elements of Q in Algorithm 2 are now used to obtain Q using the Fixed-Q precomputation (Algorithm 3) in advance.
We initialize a few variables in lines 1–5 of Algorithm 5 prior to performing the Miller loop. The parameter s is expanded as a signed binary form. The variable f for accumulating the products of the pairings is set to 1, and all elements of the array c n t for G A D D are initialized to 1.
After initialization, the Miller loop runs in lines 6–20 of Algorithm 5. Unlike in a single pairing, the Miller loop has the form of a nested loop as it computes multiple pairings. In the case of the Naive method, the inside loop should have been executed many times, depending on the number of inputs d. The nested loop structure of Algorithm 5 is the same as that of the Product method to share the squaring operation. In other words, the code of lines 7–19 is repeated by the length of s by using i. In each iteration of this outer loop, lines 9–18 are repeated based on the number of inputs d using j in the inside loop. Through application of this nested loop, the proposed method can improve the performance of the Fixed-Q method similar to how the Product method improves the Naive method. Furthermore, we can describe the effect of our method in the aspect of the amount of online computation. In other words, unlike the Product method, the proposed method performs the Fixed-Q pairing using Q j in the code of lines 9–18. To support this improvement, each array element c n t [ j ] plays the role of the variable c n t of Algorithm 4.
Algorithm 5 Fixed-Q Product method.
Input:  s = 6 t + 2 , m = the bit length of s, P = { ( P 1 , , P d ) P j G 1 } , Q = { ( Q 1 , , Q d ) Q j is the precomputation tuple for Q j G 2 }
Output:  e p r o d ( P , Q )
1:
Write s in signed binary form, s = i = 0 m 1 s [ i ] 2 i with s [ i ] { 1 , 0 , 1 }
2:
f 1
3:
for j 1 toddo
4:
     c n t [ j ] 1
5:
end for
6:
for i m 2 down to 0 do
7:
     f f 2
8:
    for j 1 to d do
9:
         G D B L , G A D D Q j
10:
         λ , c G D B L [ i ]
11:
        Compute g ( y P + λ x P + c )
12:
         f f · g
13:
        if s [ i ] 0 then
14:
            λ , c G A D D [ c n t [ j ] ]
15:
           Compute g ( y P + λ x P + c )
16:
            c n t [ j ] c n t [ j ] + 1
17:
            f f · g
18:
        end if
19:
    end for
20:
end for
21:
for j 1 toddo
22:
     π Q , ( π ) Q 2 Q j
23:
     λ , c π Q
24:
    Compute g ( y P + λ x P + c )
25:
     f f · g
26:
     λ , c ( π ) 2 Q
27:
    Compute g ( y P + λ x P + c )
28:
     f f · g
29:
end for
30:
f f ( p 12 1 ) / r
31:
returnf
The Frobenius map and final exponentiation should be applied to the optimal Ate pairing after the Miller loop. As the operation of the Frobenius map is only related to Q, all the Frobenius maps of individual pairings can be included in the Fixed-Q precomputation. Therefore, we apply the precomputed Frobenius maps to the proposed method by using π Q and ( π ) Q 2 from Q j in lines 21–29. As mentioned in Section 3.1, the final exponentiation is a shareable operation. Thus, the final exponentiation can be performed only once after the Miller loop (in line 30).
It should be noted that the speedup of the proposed method is obtained at the expense of additional memory to store Q . The exact amount of memory required to store the d tuples Q 1 , , Q d of Q will be analyzed in the next section. To handle the situation where the memory budget is very tight, we propose an adaptive method that adjusts the number of precomputed tuples according to the storage capacity. Algorithm 6 is this modified version for the situation where only the memory for k ( d ) precomputed tuples is available. Without loss of generality, we assume that only the precomputed tuples Q 1 , , Q k are given. Therefore, Algorithm 6 takes as input these tuples as well as Q k + 1 , , Q d , the field elements for the non-precomputed portion. Algorithm 6 can be viewed as the combination of Algorithm 5 and Algorithm 2. Its main loop is the same as that of Algorithm 5. However, it has lines 6–8, lines 23–30, and lines 41–44, i.e., the routines to handle the operations corresponding to non-precomputed elements. By adjusting the parameter k, the algorithm can be adapted to the current memory capacity. That is, Algorithm 6 has a time-memory trade-off. The relation between the number of precomputed tuples and the speed will be precisely analyzed in the next section.
Algorithm 6 Adaptive method.
Input:  s = 6 t + 2 , m = the bit length of s, P = { ( P 1 , , P d ) P j G 1 } , Q = { ( Q 1 , , Q k , Q k + 1 , , Q d ) Q j is the precomputation tuple for Q j G 2 , 1 < k d }
Output:  e p r o d ( P , Q )
1:
Write s in signed binary form, s = i = 0 m 1 s [ i ] 2 i with s [ i ] { 1 , 0 , 1 }
2:
f 1
3:
for j 1 tokdo
4:
     c n t [ j ] 1
5:
end for
6:
for j k + 1 toddo
7:
     T j Q j
8:
end for
9:
for i m 2 down to 0 do
10:
     f f 2
11:
    for j 1 to k do
12:
         G D B L , G A D D Q j
13:
         λ , c G D B L [ i ]
14:
        Compute g ( y P + λ x P + c )
15:
         f f · g
16:
        if s [ i ] 0 then
17:
            λ , c G A D D [ c n t [ j ] ]
18:
           Compute g ( y P + λ x P + c )
19:
            c n t [ j ] c n t [ j ] + 1
20:
            f f · g
21:
        end if
22:
    end for
23:
    for j k + 1 to d do
24:
         f f · L T j , T j ( P j ) , T j [ 2 ] T j
25:
        if s [ i ] = 1 then
26:
            f f · L T j , Q j ( P j ) , T j T j + Q j
27:
        else if s [ i ] = 1 then
28:
            f f · L T j , Q j ( P j ) , T j T j Q j
29:
        end if
30:
    end for
31:
end for
32:
for j 1 tokdo
33:
     π Q , ( π ) Q 2 Q j
34:
     λ , c π Q
35:
    Compute g ( y P + λ x P + c )
36:
     f f · g
37:
     λ , c ( π ) 2 Q
38:
    Compute g ( y P + λ x P + c )
39:
     f f · g
40:
end for
41:
for j k + 1 toddo
42:
     R π ( Q j ) , f f · L T j , R ( P j ) , T j T j + R
43:
     R π 2 ( Q j ) , f f · L T j , R ( P j ) , T j T j R
44:
end for
45:
f f ( p 12 1 ) / r
46:
returnf

5. Performance Analysis

5.1. Theoretical Analysis

In this subsection, we analyze the expected amount of computation and storage required for the Naive, Product, Fixed-Q, and the proposed Fixed-Q Product methods. First, we denote the total amount of computation required for the basic optimal Ate pairing algorithm (Algorithm 1) and the Fixed-Q pairing algorithm (Algorithm 4) as C b a s i c and C f i x e d , respectively. As explained in Section 3.2, C f i x e d is significantly smaller than C b a s i c . We also denote the amount of computation required for a squaring operation on G T and the final exponentiation as C s q r and C f i n , respectively. Subsequently, the amount of computation required to compute an inner-pairing product (5) of two d-dimensional vectors can be expressed as follows:
  • Naive method
    C b a s i c × d
  • Product method
    ( C b a s i c C s q r C f i n ) × d + C s q r + C f i n
  • Fixed-Q method
    C f i x e d × d
  • Fixed-Q Product method (proposed)
    ( C f i x e d C s q r C f i n ) × d + C s q r + C f i n
Noticeably, the computational costs of all methods are represented as linear functions in d. However, comparing (6) and (7), we can observe that the term C s q r + C f i n was moved from the slope to the constant intercept part, thus, significantly reducing the slope. The same relation holds between (8) and (9). In particular, the cost reduction of the proposed method over the Fixed-Q method (and that of the Product method over the Naive method) is ( d 1 ) ( C s q r + C f i n ) . Consequently, the proposed method is expected to be the fastest among the four methods when d 2 .
The amount of computation for the Fixed-Q method and the proposed method is reduced at the expense of memory to store the precomputed elements. In other words, a time-memory trade-off occurs. To estimate the additional memory required for storing the precomputed elements, we expressed the bit length of the data structure Q that represents the precomputation table. Q is a tuple composed of ( G D B L , G A D D , π Q , π 2 Q ) . According to Algorithm 3, G D B L and G A D D are the arrays with their elements in F p × F p . Whenever the code of line 6 in Algorithm 3 is run, the number of elements in the G D B L array is, thus, increased by one, and this line is repeated by m 1 times. Thereafter, G D B L will contain m 1 elements in F p × F p . The codes of line 10 and 14 also increase the length of G A D D by one. However, these lines are executed only when the corresponding element s [ i ] in the signed binary representation of s is non-zero. For given t = 2 62 2 52 + 2 44 , the number of non-zero terms in the signed binary representation of s is exactly seven. Therefore, G A D D will finally contain seven elements in F p × F p . Finally, the codes of lines 19 and 22 are executed once for π Q and π 2 Q . Therefore, π Q , π 2 Q F p × F p . As m, the bit length of s = 6 t + 2 , is 65, we can observe that Q ( F p × F p ) ( m 1 ) + 7 + 2 = ( F p × F p ) 73 , and the bit length of Q can be expressed as 73 × 2 × l = 146 l , where l denotes the bit length of prime p. In other words, 146 l bits are additionally required to store the precomputed data Q in Algorithm 3 and use it in Algorithm 4. For Algorithm 5, we need d tables Q 1 , , Q d , requiring 146 d l bits of the precomputation storage.

5.2. Experimental Results

To verify the performance improvement, we implemented the proposed method as well as the three previous methods, and then we compared their performance in terms of execution time and memory usage. This experiment was conducted on a desktop PC with an Intel(R) Core(TM) i7-7700 CPU @ 3.60GHz, 16GB memory, and Ubuntu Desktop 16.04 LTS. The program was written in C++. In particular, GMP 6.1.2 [73], MCL 1.05 [74], and NTL 11.3.2 [75] libraries were applied for algebraic operations.
According to the theoretical analysis in Section 5.1, the amount of computation for each method can be expressed as a linear equation in the number d of the input pairs. The slope of the linear equation and the value of the y-intercept can be estimated by measuring the execution times of the component operations. Therefore, we measured the durations required for a squaring operation and final exponentiation and as those for pairing operations. Table 1 presents the result of this measurement. The figures in Table 1 are the average of the execution times in 10,000 executions with a random input for each operation, and the unit of execution time is 10 6 CPU clocks (Mclk).
Using the measured data, we estimated the slopes and y-intercepts in the linear Equations (6)–(9) in the previous subsection. The cost of the squaring operation C s q r can be estimated as m × (the execution time for a single squaring operation), where m (i.e., the bit length of s = 6 t + 2 ) is calculated as 65 given that t = 2 62 2 54 + 2 44 for the optimal Ate pairing. Consequently, we obtained the following expressions for the execution times of the four inner-pairing product methods, which are also summarized in Table 2:
  • Naive method:
    C N a i v e = 1.595 d
  • Product method:
    C P r o d = ( 1.595 0.008 × 65 0.629 ) d + 0.008 × 65 + 0.629 = 0.464 d + 1.131
  • Fixed-Q method:
    C F i x e d Q = 1.411 d
  • Fixed-Q Product method (proposed):
    C F i x e d Q P r o d = ( 1.411 0.008 × 65 0.629 ) d + 0.008 × 65 + 0.629 = 0.280 d + 1.131
We also verified the validity of the expressions given above by directly measuring the execution times of the inner-pairing product computation. Furthermore, we measured these execution times, increasing d from 10 to 1000 by 10. For each combination, we measured the execution time of each method 1000 times. Figure 2 presents the average execution times of the four inner product methods. Certainly, the execution times of the four methods increase almost linearly with d. Figure 3 presents the relative ratio of the execution time of each method to that of the Naive method. We can observe that the ratio remains as a constant for each method, except the region for small d, where the influences of constant terms in (7) and (9) are non-negligible. Please note that the amounts of computation in the Naive and Fixed-Q methods (Equations (6) and (8)) are proportional to d, but those in the Product and Fixed-Q Product methods are not exactly proportional to d. However, when d gets sufficiently large, the constant terms in (7) and (9) almost do not affect the overall performance, and (7) and (9) become almost proportional to d. For this region with sufficiently large d, the relative ratio of the execution time is essentially the ratio of the slopes. For example, the ratio of the Fixed-Q Product method over the Naive method is approximately ( C f i x e d C s q r C f i n ) / ( C b a s i c ) for large d, whereas it is originally ( ( C f i x e d C s q r C f i n ) d + ( C s q r + C f i n ) ) / ( C b a s i c d ) . This explains the slightly bent portions in the curves for the Product and Fixed-Q Product methods in Figure 3.
In other words, four horizontal lines are almost parallel to the d-axis. The constant ratios are 0.881, 0.381, and 0.264 for the Fixed-Q, Product, and proposed methods, respectively. This implies that the proposed method improves the performance of the Naive, Fixed-Q, and Product methods by 3.8, 3.3, and 1.4 times, respectively. If we compare the proposed method with the best previous method, Product, we see that the proposed method reduces the execution time of the Product method by 1 0.264 / 0.381 30.7 % .
The amount of storage space required for each method was also measured and analyzed. The software module used in this study uses a 256-bit data type to express an element in F p . Each element in G 1 is a point on an elliptic curve defined over F p . Therefore, it is composed of two elements in F p to represent x and y coordinates. Each element in G 2 is a point on an elliptic curve defined over an extension field. Therefore, it is composed of four elements in F p . Subsequently, the sizes of the data structures to handle the elements in G 1 and G 2 are 512 ( = 2 × 256 ) and 1024 ( = 4 × 256 ) bits, respectively. The data structure for a precomputation table Q consumes 146 × 256 = 37 , 376 bits. When an inner-pairing product is computed with two d-dimensional vectors using the proposed method, 37 , 376 d bits are required for the precomputation table. For example, considering that d = 130 , which is a typical value for our biometric verification application, this amount corresponds to only 0.6 MB. As explained in Section 4, only a subset of precomputed elements may be computed if the storage is not sufficient. Figure 4 demonstrates the time-memory trade-off of Algorithm 6 for various values of k when d = 130 . The x-axis represents the amount of available memory. k varies from 0 to 130. When k = 130 , approximately 0.6 MB is required. As the graph shows, the execution time of Algorithm 6 linearly decreases according to the increase in the amount of memory.
Finally, we verify whether the Fixed-Q and Fixed-Q Product methods consume additional communication bandwidth for the transmission of the precomputation tables. When the inner-pairing product operation is applied to privacy-preserving remote biometric verification, this operation is performed by the receiver (i.e., by the remote authentication server) to conduct I P E . D e c r y p t with two input vectors P = ( P 1 , P 2 , , P d ) G 1 d and Q = ( Q 1 , Q 2 , , Q d ) G 2 d . The second vector, Q , is related to the stored biometric template. Therefore, it is transmitted in the registration phase, and the required precomputation can be conducted on the server side. In other words, Algorithm 3 is performed for each element in Q by the server. Therefore, additional communication bandwidth is not required.

6. Application

As explained in Section 2.4, if FE is applied to a remote biometric verification system, the client may encrypt and securely transmit the user’s biometric data, the server may store the encrypted biometric template, and the biometric comparison may be performed while all biometric data remain encrypted. In this section, we construct a simple facial verification system using I P E and describe how the FE can be applied to a remote biometric verification system, following the idea presented in [22]. We also demonstrate that the proposed method significantly improves the facial verification performance. For biometric comparison, the server uses Euclidean distance as the metric for the similarity between two feature vectors, which is the most widely used approach in biometric authentication. Furthermore, a vector encoding method proposed by Kim [22] is adopted to perform this comparison in the ciphertext domain. When two d-dimensional feature vectors x and y are given as a biometric reference and biometric probe, respectively, the similarity score is defined as x y 2 (i.e., the square of the Euclidean distance between x and y ). To compute x y 2 using I P E , the following three operations are defined:
  • E n c o d e X ( m s k , x )
    • Construct a ( d + 2 ) -dimensional vector x = ( x 2 , 2 x 1 , 2 x 2 , , 2 x d , 1 ) from x = ( x 1 , , x d ) .
    • Output c t = I P E . E n c r y p t ( m s k , x ) .
  • E n c o d e Y ( m s k , y )
    • Construct a ( d + 2 ) -dimensional vector y = ( 1 , y 1 , y 2 , , y d , y 2 ) from y = ( y 1 , , y d ) .
    • Output s k = I P E . K e y G e n ( m s k , y ) .
  • E u c l i d ( p p , s k , c t )
    • Calculate z = I P E . D e c r y p t ( p p , s k , c t ) .
    • Output z. (z satisfies z = x , y = ( x 2 2 x 1 y 1 2 x 2 y 2 2 x d y d + y 2 ) = ( x 2 2 x , y + y 2 ) = x y 2 ) .
In our biometric verification system, I P E . E n c r y p t (i.e., E n c o d e X ) will be used to protect the biometric template in the registration phase. Meanwhile, I P E . K e y G e n (i.e., E n c o d e Y ) will be used to protect the biometric probe of the claimant in the authentication phase. We might have used the IPE functions in other ways (i.e., I P E . K e y G e n for registration and I P E . E n c r y p t for authentication). However, we made the above choice owing to the following reason: the stored biometric template does not change frequently after registration, whereas the biometric probe for authentication changes every session. Thus, applying precomputation to the stored template is suitable. According to Algorithm 5, the precomputation is only applicable to the second argument of e p r o d ( P , Q ) , that is, Q , whose elements are from G 2 . According to the description of I P E in Section 2.4, this Q should be C 2 , which is computed by I P E . E n c r y p t .
Figure 5 shows the simple facial verification system that uses the above three operations. E n c o d e X and E n c o d e Y are performed by the client. Meanwhile, E u c l i d is performed by the server and includes an inner-pairing product for I P E . D e c r y p t . In other words, if the inner-pairing product can be accelerated, we can also improve the performance of E u c l i d .
As shown in Figure 5, the client transmits a user’s encrypted feature vector as a biometric reference to the server, and then the server stores the encrypted vector as a biometric template in the registration phase. Using the proposed method, the server can perform the Fixed-Q precomputation on all the elements of the biometric template and use the precomputed data to accelerate the inner-pairing product computation in E u c l i d .
To estimate the effect of the proposed method in the performance of a remote biometric verification system, we emulated a remote facial verification system where the client comprises an image processing module that processes the face image and produces a feature vector, and a cryptographic module for the E n c o d e X and E n c o d e Y operations. The server performs the biometric comparison using a cryptographic module implementing the E u c l i d operation. We did not actually implement the image processing module, but emulated the one provided in [2]. We brought a part of the experimental results for image processing time in [2], and actually measured the durations for I P E operations. Combining both data, we estimated the overall time for biometric verification. To measure the times for I P E operations, we used the same mobile device and PC as used in [2]. Table 3 presents our experimental results. The face image processing column covers the entire image processing procedure, i.e., from biometric capture and acquisition process and feature extraction. In [2], four datasets were provided—Auto, Guide, CFP, and ORL. Each dataset uses 128-dimensional feature vectors in common. Therefore, we measured the performance of E n c o d e Y with 128-dimensional feature vectors. However, we did not compare the performance of E n c o d e X as it is called only once for registration. In particular, we measured the performance of E u c l i d by dividing it into two parts, Pairing and DLP. Pairing is the part that consists of a single pairing operation for D 1 and e p r o d for D 2 in I P E . D e c r y p t . For comparison, we measured the performance of the inner-pairing product, e p r o d , using the proposed and Naive methods. DLP is the part that finds a solution to the discrete logarithm problem D 1 z = D 2 . The total execution time for authentication comprises face image processing, E n c o d e Y , and E u c l i d , and presents the data when the Naive method and the proposed method are applied. The last column provides the ratio of reduced time over the Naive method (i.e., ( 1 T o t a l ( p r o p o s e d ) T o t a l ( N a i v e ) ) × 100 %). From Table 3, the proposed Fixed-Q Product method reduces the time for E u c l i d operation by 1 15.66 + 120.30 58.86 + 120.30 × 100 % = 24.1% compared to the Naive method, and the overall authentication time is also expected to be reduced by 9.0–10.0%. Regarding the required memory, note that approximately 0.6 MB of precomputation memory should be available to fully exploit Algorithm 5 when a 128-dimensional feature vector is used, i.e., d = 130 . If multiple users are registered to the authentication server, the amount of required memory will be proportional to the number of registered users. For example, 600 MB is required to store the precomputation data for 1000 users. However, if we use Algorithm 6, we may permit more users, slightly degrading the authentication speed.

Security Analysis

To show that our FE-based facial verification system manages and processes the biometric information in a secure and privacy-compliant manner, we evaluate our system based on the requirements of biometric information protection, i.e., irreversibility, unlinkability, renewability, and performance [76,77].
  • Irreversibility: the irreversibility of our system depends on the security of I P E . Please note that the template is not stored in the client device. Therefore, the only concern is the possibility of template recovery on the server side. However, the I P E guarantees that the server cannot learn any information about the stored ciphertext, except its inner product with another ciphertext. Therefore, the encrypted biometric information is protected by I P E .
  • Unlinkability: Our procedure for template encryption, i.e., I P E . E n c r y p t , involves a uniformly random component β . Consequently, it may produce completely different ciphertexts even when the same biometric information is encrypted. Therefore, it is not possible to link two or more biometric templates encrypted using I P E .
  • Renewability: Every call to the template encryption procedure I P E . E n c r y p t generates a completely different ciphertext even for the same user using a random parameter β . Therefore, it can create multiple, independently transformed biometric templates.
  • Performance: According to the ISO/IEC 19795-1 standard [77], we consider the biometric accuracy as a criterion of performance. It is straightforward that the accuracy of the proposed system is exactly the same as that of the underlying biometric verification system, because the proposed system does not revise the feature extraction process. It only encrypts the extracted features. Therefore, the biometric similarity score computed from c t = E n c o d e X ( m s k , x ) and s k = E n c o d e Y ( m s k , y ) is exactly the same as that computed from the original x and y .
Finally, we remark that the biometric information is still protected even when the precomputation on the biometric template is applied to the system. According to Algorithm 3, precomputation is performed only using s , m , and Q, where s and m are publicly known parameters. Q ( Q j in later algorithms) is an element in the encrypted biometric template vector. Therefore, when the server performs Algorithm 3 for precomputation, it does not obtain any additional information about the feature value encoded in the template. Consequently, whether the server performs the precomputation or not does not affect the security of the system. The same holds for the case where the server is compromised by an attacker.

7. Discussion

In this paper, we proposed a method to accelerate the inner-pairing product operation for secure biometric verification. The proposed Fixed-Q Product method is a method that optimizes inner-pairing product computation by applying precomputation. We also applied the new inner-pairing product method to design a secure biometric verification system. To verify the feasibility of the proposed method, we emulated a simple facial verification system comprising a client and a server. Our analysis results indicate that the new inner-pairing product method accelerates biometric authentication. However, the proposed method has a time-memory trade-off. The reduction in the amount of computation for the proposed method is obtained at the expense of memory to store the precomputed elements. Although the new method requires more memory than the previous methods, the amount of the additional memory is not considerable. Moreover, there are no changes in the bandwidth requirement for communication as the precomputation is performed on the server side. Furthermore, we also provide the adaptive method where the amount of precomputed elements is parameterized. Therefore, a server can choose to apply the proposed method by itself while a client is not aware of it. In other words, selectively tuning the performance of the system is possible.
We remark that noise may affect the security and performance of a biometric authentication system [78]. Therefore, we consider the effect of noise on the proposed method. First, note that the proposed system does not revise the feature extraction procedure, but it only encrypts the extracted features. Therefore, the noise-robustness of the underlying system is maintained even after applying our method, if only the integrity of a transmitted or stored ciphertext is guaranteed. On the contrary, if a ciphertext is modified, the server will be able to notice this change immediately, because the modification of even a single bit will make the data invalid. The probability that a modified element becomes a valid field element constituting a ciphertext is almost zero. In summary, the proposed method does not affect the noise-robustness of a biometric authentication system.
Finally, the proposed method is suitable not only for remote biometric verification systems but also for any FE-based privacy-preserving applications where the evaluated function is an inner product and one of the two inputs of the inner product is entered offline [35,36]. Furthermore, the proposed method can be applied not only to FE-based systems but also to the other systems involving inner-pairing products, such as non-interactive zero-knowledge proofs [37,38].

Author Contributions

Conceptualization, M.-K.L.; Software, S.-Y.J.; Writing—original draft, S.-Y.J.; Writing—review & editing, M.-K.L. All authors have read and agreed to the published version of the manuscript.

Funding

This work was supported in part by the National Research Foundation of Korea (NRF) Grant funded by the Korean Government (MSIT) under Grant 2020R1A2C2013089, and in part by the Inha University Research Grant (2020).

Institutional Review Board Statement

Not applicable.

Informed Consent Statement

Not applicable.

Conflicts of Interest

The authors declare no conflict of interest.

Abbreviations

The following abbreviations are used in this manuscript:
FEFunctional encryption
PINPersonal identification number
EEGElectroencephalography
HEHomomorphic encryption
ZKPKZero-knowledge proof of knowledge
TEETrusted execution environment
BN curveBarreto-Naehrig curve
IPEInner product encryption

References

  1. Information Technology—Vocabulary—Part 37: Biometrics; Standard, International Organization for Standardization (ISO): Geneva, Switzerland, 2017.
  2. Im, J.H.; Jeon, S.Y.; Lee, M.K. Practical Privacy-Preserving Face Authentication for Smartphones Secure Against Malicious Clients. IEEE Trans. Inf. Forensics Secur. 2020, 15, 2386–2401. [Google Scholar] [CrossRef]
  3. Jo, Y.H.; Jeon, S.Y.; Im, J.H.; Lee, M.K. Security analysis and improvement of fingerprint authentication for smartphones. Mob. Inf. Syst. 2016, 2016, 8973828. [Google Scholar] [CrossRef]
  4. McGoldrick, L.K.; Halámek, J. Recent Advances in Noninvasive Biosensors for Forensics, Biometrics, and Cybersecurity. Sensors 2020, 20, 5974. [Google Scholar] [CrossRef] [PubMed]
  5. Bollella, P.; Katz, E. Biosensors—Recent Advances and Future Challenges. Sensors 2020, 20, 6645. [Google Scholar] [CrossRef]
  6. TrustZone—Arm Developer. Available online: https://developer.arm.com/ip-products/security-ip/trustzone (accessed on 31 January 2021).
  7. Storing Keys in the Secure Enclave. Available online: https://developer.apple.com/documentation/security/certificate_key_and_trust_services/keys/storing_keys_in_the_secure_enclave (accessed on 31 January 2021).
  8. Ratha, N.K.; Connell, J.H.; Bolle, R.M. Enhancing security and privacy in biometrics-based authentication systems. IBM Syst. J. 2001, 40, 614–634. [Google Scholar] [CrossRef]
  9. Ratha, N.K.; Chikkerur, S.; Connell, J.H.; Bolle, R.M. Generating cancelable fingerprint templates. IEEE Trans. Pattern Anal. Mach. Intell. 2007, 29, 561–572. [Google Scholar] [CrossRef] [PubMed]
  10. Juels, A.; Wattenberg, M. A fuzzy commitment scheme. In Proceedings of the 6th ACM Conference on Computer and Communications Security (CCS ’99), Singapore, 1–4 November 1999; pp. 28–36. [Google Scholar]
  11. Quan, F.; Fei, S.; Anni, C.; Feifei, Z. Cracking cancelable fingerprint template of Ratha. In Proceedings of the 2008 International Symposium on Computer Science and Computational Technology (ISCSCT 2008), Shanghai, China, 20–22 December 2008; Volume 2, pp. 572–575. [Google Scholar]
  12. Shin, S.W.; Lee, M.K.; Moon, D.; Moon, K. Dictionary attack on functional transform-based cancelable fingerprint templates. ETRI J. 2009, 31, 628–630. [Google Scholar] [CrossRef]
  13. Nagar, A.; Nandakumar, K.; Jain, A.K. Biometric template transformation: A security analysis. In Proceedings of the Media Forensics and Security II. International Society for Optics and Photonics, San Jose, CA, USA, 27 January 2010; Volume 7541, p. 75410O. [Google Scholar]
  14. Karimian, N.; Guo, Z.; Tehranipoor, M.; Forte, D. Highly reliable key generation from electrocardiogram (ECG). IEEE Trans. Biomed. Eng. 2016, 64, 1400–1411. [Google Scholar] [CrossRef] [PubMed]
  15. Nguyen, D.; Tran, D.; Sharma, D.; Ma, W. On the study of EEG-based cryptographic key generation. Procedia Comput. Sci. 2017, 112, 936–945. [Google Scholar] [CrossRef]
  16. Wang, P.; You, L.; Hu, G.; Hu, L.; Jian, Z.; Xing, C. Biometric key generation based on generated intervals and two-layer error correcting technique. Pattern Recognit. 2021, 111, 107733. [Google Scholar] [CrossRef]
  17. Jalaly Bidgoly, A.; Jalaly Bidgoly, H.; Arezoumand, Z. A survey on methods and challenges in EEG based authentication. Comput. Secur. 2020, 93, 101788. [Google Scholar] [CrossRef]
  18. Boyen, X.; Dodis, Y.; Katz, J.; Ostrovsky, R.; Smith, A. Secure remote authentication using biometric data. In Proceedings of the Annual International Conference on the Theory and Applications of Cryptographic Techniques (Eurocrypt 2005), Aarhus, Denmark, 22 May 2005; pp. 147–163. [Google Scholar]
  19. Bhattasali, T.; Saeed, K.; Chaki, N.; Chaki, R. A survey of security and privacy issues for biometrics based remote authentication in cloud. In Proceedings of the International Conference on Computer Information Systems and Industrial Management (CISIM 2015), Warsaw, Poland, 24 September 2015; pp. 112–121. [Google Scholar]
  20. Bringer, J.; Chabanne, H.; Patey, A. Privacy-preserving biometric identification using secure multiparty computation: An overview and recent trends. IEEE Signal Process. Mag. 2013, 30, 42–52. [Google Scholar] [CrossRef]
  21. Rui, Z.; Yan, Z. A survey on biometric authentication: Toward secure and privacy-preserving identification. IEEE Access 2018, 7, 5994–6009. [Google Scholar] [CrossRef]
  22. Kim, S.; Lewi, K.; Mandal, A.; Montgomery, H.; Roy, A.; Wu, D.J. Function-Hiding Inner Product Encryption is Practical. In Proceedings of the International Conference on Security and Cryptography for Networks (SCN 2018), Amalfi, Italy, 5 September 2018; pp. 544–562. [Google Scholar]
  23. Zhou, K.; Ren, J. PassBio: Privacy-preserving user-centric biometric authentication. IEEE Trans. Inf. Forensics Secur. 2018, 13, 3050–3063. [Google Scholar] [CrossRef] [Green Version]
  24. Lee, J.; Kim, D.; Kim, D.; Song, Y.; Shin, J.; Cheon, J.H. Instant Privacy-Preserving Biometric Authentication for Hamming Distance; Cryptology ePrint Archive, Report 2018/1214; IACR, 2018; Available online: https://eprint.iacr.org/2018/1214 (accessed on 1 April 2021).
  25. Barbosa, M.; Catalano, D.; Soleimanian, A.; Warinschi, B. Efficient Function-Hiding Functional Encryption: From Inner-Products to Orthogonality; Cryptographers’ Track at the RSA Conference (CT-RSA 2019); Springer: Berlin, Germany, 2019; pp. 127–148. [Google Scholar]
  26. Zhao, Q.; Zeng, Q.; Liu, X. Improved Construction for Inner Product Functional Encryption. Secur. Commun. Netw. 2018, 2018, 6561418. [Google Scholar] [CrossRef] [Green Version]
  27. Abdalla, M.; Bourse, F.; De Caro, A.; Pointcheval, D. Simple functional encryption schemes for inner products. In Proceedings of the IACR International Workshop on Public Key Cryptography (PKC 2015), Gaithersburg, MD, USA, 30 March–1 April 2015; pp. 733–751. [Google Scholar]
  28. Datta, P.; Dutta, R.; Mukhopadhyay, S. Functional encryption for inner product with full function privacy. In Proceedings of the IACR International Workshop on Public Key Cryptography (PKC 2016), Taipei, Taiwan, 6–9 March 2016; pp. 164–195. [Google Scholar]
  29. Kim, S.; Kim, J.; Seo, J.H. A new approach to practical function-private inner product encryption. Theor. Comput. Sci. 2019, 783, 22–40. [Google Scholar] [CrossRef]
  30. Bünz, B.; Maller, M.; Mishra, P.; Tyagi, N.; Vesely, P. Proofs for Inner Pairing Products and Applications; Cryptology ePrint Archive, Report 2019/1177; IACR, 2019; Available online: https://eprint.iacr.org/2019/1177 (accessed on 1 April 2021).
  31. Scott, M. Computing the Tate pairing. In Proceedings of the Cryptographers’ Track at the RSA Conference (CT-RSA 2005), San Francisco, CA, USA, 14–18 February 2005; pp. 293–304. [Google Scholar]
  32. Granger, R.; Smart, N.P. On Computing Products of Pairings. IACR Cryptol. EPrint Arch. 2006, 2006, 172. [Google Scholar]
  33. Zavattoni, E.; Perez, L.J.D.; Mitsunari, S.; Sánchez-Ramırez, A.H.; Teruya, T.; Rodríguez-Henríquez, F. Software implementation of an attribute-based encryption scheme. IEEE Trans. Comput. 2014, 64, 1429–1441. [Google Scholar] [CrossRef]
  34. Costello, C.; Stebila, D. Fixed argument pairings. In Proceedings of the International Conference on Cryptology and Information Security in Latin America (Latincrypt 2010), Puebla, Mexico, 8–11 August 2010; pp. 92–108. [Google Scholar]
  35. Im, J.H.; Kwon, H.Y.; Jeon, S.Y.; Lee, M.K. Privacy-Preserving Electricity Billing System Using Functional Encryption. Energies 2019, 12, 1237. [Google Scholar] [CrossRef] [Green Version]
  36. Son, Y.B.; Im, J.H.; Kwon, H.Y.; Jeon, S.Y.; Lee, M.K. Privacy-Preserving Peer-to-Peer Energy Trading in Blockchain-Enabled Smart Grids Using Functional Encryption. Energies 2020, 13, 1321. [Google Scholar] [CrossRef] [Green Version]
  37. Anada, H. Decentralized Multi-authority Anonymous Authentication for Global Identities with Non-interactive Proofs. J. Internet Serv. Inf. Secur. 2020, 10, 23–37. [Google Scholar]
  38. Pop, C.D.; Antal, M.; Cioara, T.; Anghel, I.; Salomie, I. Blockchain and Demand Response: Zero-Knowledge Proofs for Energy Transactions Privacy. Sensors 2020, 20, 5678. [Google Scholar] [CrossRef]
  39. Chun, H.; Elmehdwi, Y.; Li, F.; Bhattacharya, P.; Jiang, W. Outsourceable two-party privacy-preserving biometric authentication. In Proceedings of the 9th ACM Symposium on Information, Computer and Communications Security, Kyoto, Japan, 4–6 June 2014; pp. 401–412. [Google Scholar]
  40. Cheon, J.H.; Chung, H.; Kim, M.; Lee, K.W. Ghostshell: Secure Biometric Authentication Using Integrity-Based Homomorphic Evaluations; Cryptology ePrint Archive, Report 2016/484; IACR, 2016; Available online: https://eprint.iacr.org/2016/484 (accessed on 1 April 2021).
  41. Im, J.; Choi, J.; Nyang, D.; Lee, M. Privacy-Preserving Palm Print Authentication Using Homomorphic Encryption. In Proceedings of the 2nd Int. Conf. Big Data Intell. Comput., Thessaloniki, Greece, 23–25 October 2016; pp. 878–881. [Google Scholar]
  42. Lin, D.; Hilbert, N.; Storer, C.; Jiang, W.; Fan, J. UFace: Your universal password that no one can see. Comput. Secur. 2018, 77, 627–641. [Google Scholar] [CrossRef]
  43. Shahandashti, S.F.; Safavi-Naini, R.; Safa, N.A. Reconciling user privacy and implicit authentication for mobile devices. Comput. Secur. 2015, 53, 215–233. [Google Scholar] [CrossRef]
  44. Šeděnka, J.; Govindarajan, S.; Gasti, P.; Balagani, K.S. Secure outsourced biometric authentication with performance evaluation on smartphones. IEEE Trans. Inf. Forensics Secur. 2015, 10, 384–396. [Google Scholar] [CrossRef]
  45. Gasti, P.; Šeděnka, J.; Yang, Q.; Zhou, G.; Balagani, K.S. Secure, fast, and energy-efficient outsourced authentication for smartphones. IEEE Trans. Inf. Forensics Secur. 2016, 11, 2556–2571. [Google Scholar] [CrossRef]
  46. Abidin, A. On Privacy-Preserving Biometric Authentication. In Proceedings of the Information Security and Cryptology, Beijing, China, 29 November 2017; pp. 169–186. [Google Scholar]
  47. Gunasinghe, H.; Bertino, E. PrivBioMTAuth: Privacy Preserving Biometrics-Based and User Centric Protocol for User Authentication From Mobile Phones. IEEE Trans. Inf. Forensics Secur. 2018, 13, 1042–1057. [Google Scholar] [CrossRef]
  48. Droandi, G.; Barni, M.; Lazzeretti, R.; Pignata, T. SEMBA:SEcure multi-biometric authentication. arXiv 2018, arXiv:abs/1803.10758. [Google Scholar]
  49. Catalano, D.; Fiore, D. Using linearly-homomorphic encryption to evaluate degree-2 functions on encrypted data. In Proceedings of the 22nd ACM SIGSAC Conference on Computer and Communications Security, Denver, CO, USA, 12–16 October 2015; pp. 1518–1529. [Google Scholar]
  50. Damgård, I.; Pastro, V.; Smart, N.; Zakarias, S. Multiparty Computation from Somewhat Homomorphic Encryption. In Proceedings of the CRYPTO 2012, Barbara, CA, USA, 19–23 August 2012; pp. 643–662. [Google Scholar]
  51. Sengupta, S.; Cheng, J.; Castillo, C.; Patel, V.; Chellappa, R.; Jacobs, D. Frontal to Profile Face Verification in the Wild. In Proceedings of the 2016 IEEE Winter Conference on Applications of Computer Vision (WACV), Lake Placid, NY, USA, 7–10 March 2016. [Google Scholar]
  52. The Database of Faces (Formerly ‘The ORL Database of Faces’). Available online: http://cam-orl.co.uk/facedatabase.html (accessed on 1 April 2021).
  53. Taigman, Y.; Yang, M.; Ranzato, M.; Wolf, L. Deepface: Closing the gap to human-level performance in face verification. In Proceedings of the 2014 IEEE Conference on Computer Vision and Pattern Recognition, Columbus, OH, USA, 23–28 June 2014; pp. 1701–1708. [Google Scholar]
  54. He, K.; Zhang, X.; Ren, S.; Sun, J. Deep residual learning for image recognition. In Proceedings of the 2016 IEEE Conference on Computer Vision and Pattern Recognition (CVPR), Las Vegas, NV, USA, 27–30 June 2016; pp. 770–778. [Google Scholar]
  55. Barreto, P.S.; Naehrig, M. Pairing-friendly elliptic curves of prime order. In Proceedings of the International Workshop on Selected Areas in Cryptography (SAC 2005), Kingston, ON, Canada, 11–12 August 2005; pp. 319–331. [Google Scholar]
  56. Aranha, D.F.; Barreto, P.S.; Longa, P.; Ricardini, J.E. The realm of the pairings. In Proceedings of the International Conference on Selected Areas in Cryptography (SAC 2013), Burnaby, BC, Canada, 14–16 August 2013; pp. 3–25. [Google Scholar]
  57. El Mrabet, N.; Joye, M. Guide to Pairing-Based Cryptography; CRC Press: Boca Raton, FL, USA, 2017. [Google Scholar]
  58. Silverman, J.H. The Arithmetic of Elliptic Curves; Springer Science & Business Media: Berlin/Heidelberg, Germany, 2009; Volume 106. [Google Scholar]
  59. Miller, V.S. The Weil pairing, and its efficient calculation. J. Cryptol. 2004, 17, 235–261. [Google Scholar] [CrossRef]
  60. Scott, M.; Benger, N.; Charlemagne, M.; Perez, L.J.D.; Kachisa, E.J. On the final exponentiation for calculating pairings on ordinary elliptic curves. In Proceedings of the International Conference on Pairing-Based Cryptography (Pairing 2009), Palo Alto, CA, USA, 12–14 August 2009; pp. 78–88. [Google Scholar]
  61. Cohen, H.; Frey, G.; Avanzi, R.; Doche, C.; Lange, T.; Nguyen, K.; Vercauteren, F. Handbook of Elliptic and Hyperelliptic Curve Cryptography; CRC Press: Boca Raton, FL, USA, 2005. [Google Scholar]
  62. Granger, R.; Hess, F.; Oyono, R.; Thériault, N.; Vercauteren, F. Ate pairing on hyperelliptic curves. In Proceedings of the Annual International Conference on the Theory and Applications of Cryptographic Techniques (Eurocrypt 2007), Barcelona, Spain, 20–24 May 2007; pp. 430–447. [Google Scholar]
  63. Hess, F.; Smart, N.P.; Vercauteren, F. The eta pairing revisited. IEEE Trans. Inf. Theory 2006, 52, 4595–4602. [Google Scholar] [CrossRef]
  64. Matsuda, S.; Kanayama, N.; Hess, F.; Okamoto, E. Optimised versions of the ate and twisted ate pairings. In Proceedings of the International Conference on Cryptography and Coding (IMACC 2007), Cirencester, UK, 18–20 December 2007; pp. 302–312. [Google Scholar]
  65. Zhao, C.A.; Zhang, F.; Huang, J. A note on the Ate pairing. Int. J. Inf. Secur. 2008, 7, 379–382. [Google Scholar] [CrossRef]
  66. Lee, E.; Lee, H.S.; Park, C.M. Efficient and generalized pairing computation on abelian varieties. IEEE Trans. Inf. Theory 2009, 55, 1793–1803. [Google Scholar] [CrossRef] [Green Version]
  67. Vercauteren, F. Optimal pairings. IEEE Trans. Inf. Theory 2009, 56, 455–461. [Google Scholar] [CrossRef]
  68. Beuchat, J.L.; González-Díaz, J.E.; Mitsunari, S.; Okamoto, E.; Rodríguez-Henríquez, F.; Teruya, T. High-speed software implementation of the optimal ate pairing over Barreto–Naehrig curves. In Proceedings of the International Conference on Pairing-Based Cryptography (Pairing 2010), Yamanaka Hot Spring, Japan, 13–15 December 2010; pp. 21–39. [Google Scholar]
  69. Bishop, A.; Jain, A.; Kowalczyk, L. Function-hiding inner product encryption. In Proceedings of the International Conference on the Theory and Application of Cryptology and Information Security (ASIACRYPT 2015), Auckland, New Zealand, 29 November–3 December 2015; pp. 470–491. [Google Scholar]
  70. Hankerson, D.; Menezes, A.J.; Vanstone, S. Guide to Elliptic Curve Cryptography; Springer Science & Business Media: Berlin/Heidelberg, Germany, 2006. [Google Scholar]
  71. Jeon, S.Y.; Lee, M.K. Poster: Acceleration of Pairing Product Operation Using Precomputation. In Proceedings of the 21st World Conference on Information Security Applications 2020 (WISA 2020), Jeju Island, Korea, 26–28 August 2020; p. 5. [Google Scholar]
  72. Jeon, S.Y. Acceleration of Pairing Operation for Performance Improvement of Functional Encryption. Master’s Thesis, Inha University, Incheon, Korea, 2020. [Google Scholar]
  73. GNU Multiple Precision Arithmetic Library (GMP). Available online: https://gmplib.org/ (accessed on 31 January 2021).
  74. GitHub—Herumi/Mcl: A Portable and Fast Pairing-Based Cryptography Library. Available online: https://github.com/herumi/mcl (accessed on 31 January 2021).
  75. A Library for Doing Number Theory (NTL). Available online: https://www.shoup.net/ntl/ (accessed on 31 January 2021).
  76. Information Technology—Security Techniques—Biometric Information Protection; Standard, International Organization for Standardization (ISO): Geneva, Switzerland, 2011.
  77. Information Technology—Biometric Performance Testing and Reporting—Part 1: Principles and Framework; Standard; International Organization for Standardization (ISO): Geneva, Switzerland, 2006.
  78. Lafkih, M.; Mikram, M.; Ghouzali, S.; El Haziti, M. Evaluation of the Impact of Noise on Biometric Authentication Systems. In Proceedings of the 2019 3rd International Conference on Advances in Artificial Intelligence, Istanbul, Turkey, 26–28 October 2019; pp. 188–192. [Google Scholar]
Figure 1. Generic structure of a remote biometric verification system.
Figure 1. Generic structure of a remote biometric verification system.
Sensors 21 02859 g001
Figure 2. Performance comparison according to the dimension of input for each method.
Figure 2. Performance comparison according to the dimension of input for each method.
Sensors 21 02859 g002
Figure 3. Comparison of the performance ratio of other methods to compute inner-pairing products compared to the Naive method.
Figure 3. Comparison of the performance ratio of other methods to compute inner-pairing products compared to the Naive method.
Sensors 21 02859 g003
Figure 4. Time-memory trade-off of the adaptive method.
Figure 4. Time-memory trade-off of the adaptive method.
Sensors 21 02859 g004
Figure 5. Simple facial verification system that uses I P E with the proposed method.
Figure 5. Simple facial verification system that uses I P E with the proposed method.
Sensors 21 02859 g005
Table 1. Execution times of the operations constituting an inner-pairing product.
Table 1. Execution times of the operations constituting an inner-pairing product.
Operation NameExecution Time (Mclk)
Squaring on G T 0.008
Final exponentiation0.629
Basic optimal Ate pairing (Algorithm 1)1.595
Fixed-Q pairing (Algorithm 4)1.411
Table 2. Execution times of the inner-pairing product computation for various methods.
Table 2. Execution times of the inner-pairing product computation for various methods.
MethodsExpected CostMeasured Cost
Naive C b a s i c × d 1.595 d
Product ( C b a s i c C s q r C f i n ) × d + C s q r + C f i n 0.464 d + 1.131
Fixed-Q C f i x e d × d 1.411 d
Proposed ( C f i x e d C s q r C f i n ) × d + C s q r + C f i n 0.280 d + 1.131
Table 3. Performance improvement in the facial verification system using the proposed method compared to the Naive method (times in ms).
Table 3. Performance improvement in the facial verification system using the proposed method compared to the Naive method (times in ms).
Biometric
Dataset
Face Image
Processing [2]
EncodeYEuclidTotal
(Naive)
Total
(Proposed)
Ratio
Pairing
(Naive)
Pairing
(Proposed)
DLP
Auto193.27106.4758.8615.66120.30478.90435.709.0 %
Guide157.47443.10399.909.7%
CFP150.15435.78392.589.9%
ORL147.33432.96389.7610.0%
Publisher’s Note: MDPI stays neutral with regard to jurisdictional claims in published maps and institutional affiliations.

Share and Cite

MDPI and ACS Style

Jeon, S.-Y.; Lee, M.-K. Acceleration of Inner-Pairing Product Operation for Secure Biometric Verification. Sensors 2021, 21, 2859. https://doi.org/10.3390/s21082859

AMA Style

Jeon S-Y, Lee M-K. Acceleration of Inner-Pairing Product Operation for Secure Biometric Verification. Sensors. 2021; 21(8):2859. https://doi.org/10.3390/s21082859

Chicago/Turabian Style

Jeon, Seong-Yun, and Mun-Kyu Lee. 2021. "Acceleration of Inner-Pairing Product Operation for Secure Biometric Verification" Sensors 21, no. 8: 2859. https://doi.org/10.3390/s21082859

APA Style

Jeon, S.-Y., & Lee, M.-K. (2021). Acceleration of Inner-Pairing Product Operation for Secure Biometric Verification. Sensors, 21(8), 2859. https://doi.org/10.3390/s21082859

Note that from the first issue of 2016, this journal uses article numbers instead of page numbers. See further details here.

Article Metrics

Back to TopTop