[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

EP3373505A1 - Device and method for sharing a matrix for use in a cryptographic protocol - Google Patents

Device and method for sharing a matrix for use in a cryptographic protocol Download PDF

Info

Publication number
EP3373505A1
EP3373505A1 EP17159296.7A EP17159296A EP3373505A1 EP 3373505 A1 EP3373505 A1 EP 3373505A1 EP 17159296 A EP17159296 A EP 17159296A EP 3373505 A1 EP3373505 A1 EP 3373505A1
Authority
EP
European Patent Office
Prior art keywords
matrix
network node
sequence
values
shared
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Withdrawn
Application number
EP17159296.7A
Other languages
German (de)
French (fr)
Inventor
Oscar Garcia-Morchon
Ludovicus Marinus Gerardus Maria Tolhuizen
Ronald Rietman
Sauvik Bhattacharya
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Koninklijke Philips NV
Original Assignee
Koninklijke Philips NV
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Koninklijke Philips NV filed Critical Koninklijke Philips NV
Priority to EP17159296.7A priority Critical patent/EP3373505A1/en
Priority to CN201880029798.9A priority patent/CN110603782B/en
Priority to EP18706753.3A priority patent/EP3593485B1/en
Priority to PCT/EP2018/054731 priority patent/WO2018162272A1/en
Priority to JP2019548404A priority patent/JP7159183B2/en
Priority to US16/490,931 priority patent/US11212098B2/en
Priority to RU2019131369A priority patent/RU2765238C2/en
Publication of EP3373505A1 publication Critical patent/EP3373505A1/en
Withdrawn legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/30Public key, i.e. encryption algorithm being computationally infeasible to invert or user's encryption keys not requiring secrecy
    • H04L9/3093Public key, i.e. encryption algorithm being computationally infeasible to invert or user's encryption keys not requiring secrecy involving Lattices or polynomial equations, e.g. NTRU scheme
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F17/00Digital computing or data processing equipment or methods, specially adapted for specific functions
    • G06F17/10Complex mathematical operations
    • G06F17/16Matrix or vector computation, e.g. matrix-matrix or matrix-vector multiplication, matrix factorization
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F7/00Methods or arrangements for processing data by operating upon the order or content of the data handled
    • G06F7/58Random or pseudo-random number generators
    • G06F7/582Pseudo-random number generators
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/06Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols the encryption apparatus using shift registers or memories for block-wise or stream coding, e.g. DES systems or RC4; Hash functions; Pseudorandom sequence generators
    • H04L9/065Encryption by serially and continuously modifying data stream elements, e.g. stream cipher systems, RC4, SEAL or A5/3
    • H04L9/0656Pseudorandom key sequence combined element-for-element with data sequence, e.g. one-time-pad [OTP] or Vernam's cipher
    • H04L9/0662Pseudorandom key sequence combined element-for-element with data sequence, e.g. one-time-pad [OTP] or Vernam's cipher with particular pseudorandom sequence generator
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/08Key distribution or management, e.g. generation, sharing or updating, of cryptographic keys or passwords
    • H04L9/0816Key establishment, i.e. cryptographic processes or cryptographic protocols whereby a shared secret becomes available to two or more parties, for subsequent use
    • H04L9/0819Key transport or distribution, i.e. key establishment techniques where one party creates or otherwise obtains a secret value, and securely transfers it to the other(s)
    • H04L9/0822Key transport or distribution, i.e. key establishment techniques where one party creates or otherwise obtains a secret value, and securely transfers it to the other(s) using key encryption key
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/08Key distribution or management, e.g. generation, sharing or updating, of cryptographic keys or passwords
    • H04L9/0816Key establishment, i.e. cryptographic processes or cryptographic protocols whereby a shared secret becomes available to two or more parties, for subsequent use
    • H04L9/0838Key agreement, i.e. key establishment technique in which a shared key is derived by parties as a function of information contributed by, or associated with, each of these
    • H04L9/0841Key agreement, i.e. key establishment technique in which a shared key is derived by parties as a function of information contributed by, or associated with, each of these involving Diffie-Hellman or related key agreement protocols
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W12/00Security arrangements; Authentication; Protecting privacy or anonymity
    • H04W12/04Key management, e.g. using generic bootstrapping architecture [GBA]
    • H04W12/047Key management, e.g. using generic bootstrapping architecture [GBA] without using a trusted network node as an anchor
    • H04W12/0471Key exchange

Definitions

  • the invention relates to an electronic network node, an electronic method for an electronic network node configured for a cryptographic protocol based on a shared matrix, a computer readable medium
  • the nodes typically combine the shared matrix with private information of their own.
  • a network node may compute a matrix product between the shared matrix and a private vector or matrix of the network node as part of the cryptographic protocol.
  • noise may be added to the result of the computation, e.g., in the form of a noise vector or matrix that is added to the multiplication result or in the form of rounding or scaling of the result.
  • the result still contains sufficient information on the private key in order to perform useful operations for another node, e.g., signing, encrypting, key agreement, etc., but not sufficient information to recover the private data of the other node.
  • Key reconciliation may be used to correct for the added noise.
  • the starting point of such lattice based cryptography is that both parties, e.g., network nodes 110 and 111 have access to a shared matrix.
  • This matrix is typically selected at random and is quite large.
  • the shared matrix has multiple entries, and each entry has a value.
  • a shared matrix may have dimensions of, say, 500 times 500, or even larger.
  • Entries in the shared matrix are typically modulo a modulus q, which may be, say 2 10 .
  • the shared matrix is often public, and could be transmitted as plain data, clearly, such large amounts of information is problematic, especially given the fact that an important application of cryptographic protocols is expected to be the internet of things, in which resource-restricted nodes operate on data which are to be cryptographically protected.
  • the nodes may form a sensor network.
  • a first way to reduce overhead caused by the requirement that a large matrix is shared between two nodes is to re-use the same matrix many times over.
  • An attacker can perform extensive pre-computations on the shared matrix, if it knows that matrix will be used in a future cryptographic exchange. Examples of such precomputations attack are, e.g., the Logjam attack on finite-field Diffie-Hellman.
  • the attacker would be presented with a fresh lattice problem for each execution; It is thus preferred not to re-use the same matrix.
  • a second way to reduce overhead caused by the large shared matrix is to send a random seed instead of the shared matrix.
  • the random seed is then used to seed a deterministic random number generator, which in turn generates the shared matrix.
  • Many deterministic random number generators are known.
  • Resource-limited devices would need to compute a long time to generated the shared matrix. The problem may be just as bad for a large server that handles many simultaneous computations at the same time.
  • an attacker could cause such a server to perform many random number generations, it would lead to denial-of-service attacks. The attacker could start many connections with the server and abandon them after the server is committed to generating the shared matrix from a random seed.
  • An electronic network node configured for a cryptographic protocol based on a shared matrix is provided that addresses these and other problems.
  • the shared matrix has multiple entries and each entry has a value.
  • the network node will be identified as the first network node, distinguishing it from a second network node with which is communicates.
  • the adjective 'first' and 'second' have no further meaning.
  • the first network node comprises
  • Selection data can be described with much fewer bits than the sequence of values can be. For example, in some embodiments the amount of selection data needed to assign data to a group of entries in the shared matrix is less than 1/100 of the amount of data needed to describe the data itself. If selection data is generated from a random number generator then less data needs to be generated than generating the values in the shared matrix themselves would, regardless of whether this happens at the node that sends selection data or at the node that receives the selection data. Especially for a node, e.g., a server, with many connections to second nodes this makes a substantial difference in operating the network node. Compared to the needed bandwidth for sending the data itself, also a substantial reduction is obtained.
  • a node e.g., a server
  • a node caches the sequence of values and uses it for multiple connections.
  • a node can send or receive a sequence identifier to identify the sequence of values to use.
  • the identifier could, e.g., be a hash over the sequence of values, but in an advantageous embodiment the sequence identifier comprises a random seed from which the sequence of values may be generated.
  • a receiver of a sequence identifier can either retrieve the sequence identifier from a cache memory or can generate the sequence of values.
  • the lattices that an attacker would obtain for different matrices that are shared in this way are different even if the underlying sequence of values is the same. Especially if the number of different lattices is larger, the advantage of the attacker is significantly reduced.
  • the network node is an electronic device.
  • the network node maybe a mobile electronic device, such as a mobile phone.
  • the network node may be a set-top box, smart-card, computer, or the like.
  • a method of sharing a matrix described herein may be applied in a wide range of practical applications.
  • Such practical applications include financial applications, e.g., to share credit card information, privacy enhancing applications, e.g., messaging applications, medial applications, etc.
  • a method according to the invention may be implemented on a computer as a computer implemented method, or in dedicated hardware, or in a combination of both.
  • Executable code for a method according to the invention may be stored on a computer program product.
  • Examples of computer program products include memory devices, optical storage devices, integrated circuits, servers, online software, etc.
  • the computer program product comprises non-transitory program code stored on a computer readable medium for performing a method according to the invention when said program product is executed on a computer.
  • the computer program comprises computer program code adapted to perform all the steps of a method according to the invention when the computer program is run on a computer.
  • the computer program is embodied on a computer readable medium.
  • Another aspect of the invention provides a method of making the computer program available for downloading. This aspect is used when the computer program is uploaded into, e.g., Apple's App Store, Google's Play Store, or Microsoft's Windows Store, and when the computer program is available for downloading from such a store.
  • Apple's App Store e.g., Apple's App Store, Google's Play Store, or Microsoft's Windows Store
  • FIG. 1 schematically shows an example of an embodiment of a cryptographic system 100.
  • Cryptographic system 100 comprises multiple network nodes. Shown in figure 1 are a first network node 110 and a second network node 111. For the most part, nodes 110 and 111 are of the same design, except where they have a sender-receiver relationship.
  • the network nodes in system 100 are configured to execute a cryptographic protocol based on a shared matrix; in particular, first network node 110 and second network node 111 are configured for such a cryptographic protocol. Preferably a fresh shared matrix is used for each execution of the cryptographic protocol.
  • Network node 110 comprises a cryptographic unit 150.
  • Cryptographic unit 150 is arranged to perform a cryptographic protocol using the shared matrix. As pointed out in the background, many such cryptographic protocols exist, and all require a large matrix which is shared between the two parties. Often a matrix product is computed between the shared matrix and a private vector or matrix of the network node as part of the cryptographic protocol.
  • cryptographic unit 150 may comprises a matrix multiplication unit 152 arranged to compute said matrix multiplication.
  • a first example, of a cryptographic protocol using a shared matrix is a key exchange protocol.
  • the first node may be configured to
  • This key agreement protocol is based on the fact that, except for the added noise, S R T AS I is the same for both the first and the second network node.
  • Computing the matrix product between the shared matrix ( A ) and the private key matrix ( S l ) is done modulo a modulus.
  • One of the nodes can compute key reconciliation data and send it to the other node, to ensure both compute the same shared key form the matrix products.
  • a second example, of a lattice based cryptographic protocol is a public key encryption /decryption algorithm.
  • a network node may be configured to
  • noise may be added, e.g. in the form of scaling.
  • a detailed example, of a lattice based public key encryption protocol may be found in the article by J. H. Cheon, D. Kim, J. Lee, Y. Song: “Lizard: Cut off the Tail! Practical Post-Quantum Public-Key Encryption from LWE and LWR " (induced herein by reference).
  • the shared matrix has multiple entries each entry having a value.
  • the shared matrix may be square for convenience, although this is no necessity.
  • the matrix may be a vector, e.g., when one of the dimensions is 1, however most advantages are obtained as both dimensions are large, e.g., when both the number of rows and the number of columns is larger than 50, 100, 500, etc.
  • the first and second network node each comprise a communication interface 120.
  • Communication interface 120 of first network node 110 is arranged for digital communication with second network node 111.
  • Communication interface 120 is arranged to communicate with many of the other nodes in system 100.
  • the communication interfaces maybe arranged for digital communication with the other nodes in the key agreement system. It is not necessary though that all nodes in the system can be reached at all times.
  • Communication interface 120 is arranged for digital communication.
  • the communication interfaces may be arranged to communicate over a computer network.
  • the communication interface may be arranged for wireless, e.g., Wi-Fi, ZigBee, Bluetooth and the like, and/or wired communication, e.g., Ethernet, USB, and the like.
  • the communication between nodes 110 and 111 may also be a combination of wired and wireless connections.
  • the nodes in system 100, including nodes 110 and 111 may comprise an electronic storage that contains a communication identifier, which uniquely identifies the node within system 100.
  • the communication identifier may be included in digital messages exchanged between nodes 110 and 111, e.g., to address the message.
  • the communication identifier may an IP address, a MAC address, and the like.
  • the electronic network nodes are configured for a cryptographic protocol, such as the key exchange or public key encryption protocol examples given above.
  • the cryptographic protocol involves exchanging messages between the nodes 110 and 111 over the communication interfaces 120, and performing computations on, e.g., data received from the other node.
  • the execution of the protocols is implemented in a processor circuit, examples of which are shown below.
  • Figure 1 shows functional units that may be functional units of the processor circuit.
  • figure 1 may be used as a blueprint of a possible functional organization of the processor circuit.
  • the processor circuit is not shown separate from the units in figure 1 .
  • the functional units shown in figure 1 may also be wholly or partially be implemented in computer instructions that are stored at the network nodes and are executable by a microprocessor of the network node.
  • functional units are implemented partially in hardware, e.g., as coprocessors, e.g., crypto coprocessors, and partially in software stored an executed on the network node.
  • Network node 110 comprises a base data manager 130 arranged to obtain a sequence of values for the entries of the shared matrix, the sequence of values being shared with the second network node.
  • Network node 110 also comprises a base data memory 170 arranged for storing the shared sequence of values, e.g., after it has been obtained.
  • the values in the sequence of values may be selected modulo a modulus.
  • the sequence of values is also referred to as the base data, or the base values etc.
  • the sequence of values will be used to fill the shared matrix with. It was an insight of the inventors that a mapping from a sequence of values to the entries of a shared matrix can be transmitted in much fewer bits, or may be computed from much fewer pseudorandom outputs than the sequence of values itself. By varying the way in which the shared matrix is constructed from the sequence of values, a large number of different shared matrices can be obtained from the same base data. Thus, the cryptographic advantages of using a different shared matrix each time, is combined with the low overhead of re-using the same sequence of values.
  • base data manager 130 may obtain base data which is shared with the second network node.
  • base data memory 170 pre-stores the sequence of values.
  • the multiple network nodes in system 100 may be provided with the sequence at some point, e.g., at first use, during manufacture, at a trusted location, etc.
  • the shared sequence of values may be a fixed sequence, for example, fixed in a standard, or the like.
  • base manager 130 has little more to do than to provide access to base data memory 170 in which the sequence of values.
  • base data memory 170 or the part thereof in which the shared sequence of values is stored may be ROM memory.
  • the sequence of values is obtained from a trusted third party.
  • base data manager 130 contacts a trusted third party, e.g., over a computer network, to obtain a new sequence of values.
  • base data manager 130 may be configured to obtain such a new sequence periodically, e.g., once every 30 days, e.g., at the beginning of each new month, etc.
  • base data manager 130 may obtain the shared sequence of values as a random seed.
  • first network node 110 may comprise a deterministic pseudorandom number generator 160.
  • Pseudorandom number generator may be seeded with the random seed and used to compute the sequence of values.
  • the seed maybe obtained from various sources, e.g., preprogrammed, e.g., during manufacture, e.g., received from the second network node, e.g., received from a trusted third party, etc.
  • the selection data may also be generated at the first network node and sent to the second network node.
  • the sequence of values is used for multiple executions of the cryptographic protocol, for example, the sequence of values is used at least twice to construct at least two different shared matrices, shared with the second network node.
  • the sequence of values is shared with multiple network nodes, e.g., each of the multiple network nodes of system 100. The latter is not necessary though, for example, a particular sequence of values may be used just by the first and second network node; for example, the first time the first and second network node interact they may exchange a random seed to generate the sequence of values that is used between them thereafter. Below further embodiments using caching of sequences are described.
  • Pseudorandom number generator 160 may be a fast linear feedback generator such as the Mersenne twister.
  • a cryptographically secure random number generator is however preferred.
  • pseudorandom number generator 160 may satisfy the so-called next-bit test. That is, given the first k b its of a random sequence, there is no polynomial-time algorithm that can predict the ( k + 1)th bit with probability of success non-negligibly better than 50%.
  • cryptographically secure random number generators known, e.g., a block cipher run in counter mode, e.g., the Advanced Encryption Standard in counter mode.
  • a secure random number generator may also be obtained by running a hash function in counter mode, e.g., SHA-256, etc.
  • the Mersenne twister may also be secured, e.g., by basing a pair of cryptographic stream ciphers on output from the Mersenne Twister. Further examples include the Blum-blum-shub generator, Blum-Micali generator, etc.
  • Network node 110 comprises a matrix generation unit 140.
  • Matrix generation unit 140 is arranged to construct the shared matrix ( A ) in accordance with the selection data, setting said multiple entries of the shared matrix to the multiple values assigned by the selection data.
  • the selection data thus describes a mapping between the shared sequence of values and the entries in the shared matrix.
  • the selection data maybe obtained from the second network node e.g., through communication interface 120.
  • the sequence of values is transformed to an actual shared matrix A by the selection data.
  • Generation unit 140 may also determine selection data itself and send the selection data to the second network node. For example, if the selection data comprises tuples, permutations, rotation parameters, and the like as illustrated in the various embodiments, then generation unit 140 could select these at random as generated selection data. The generated selection data may be sent to the second network node. If the selection data is derived from the output of a deterministic random number generator, then the seed of the generator could be sent to the second network node instead.
  • Selection data thus indicates multiple values in the sequence of values and assigns to multiple entries of the shared matrix a value of the sequence of values indicated by the selection data.
  • all entries of the shared matrix receive their value from the sequence of values, however, it is not necessary that each entry receives that value from a location in the sequence of values that is indicated by the selection data; some entries in the shared matrix may receive their value from a fixed location in the sequence of values.
  • Figure 2a schematically shows an example of an embodiment of selection data.
  • the selection data identifies locations in the sequence of values 210, shown are values 221 and 222, that are to be assign to locations in the shared matrix 230, shown are entries 231 and 232.
  • selection data may comprise a sequence of tuples, each tuple comprising an index in the sequence of values and an index in the shared matrix.
  • the sequence of values may be indexed linearly, e.g., counted sequentially, e.g., using the natural numbers.
  • the shared matrix may also be indexed with a single number, e.g., numbered sequentially, but may also be indexed by an x and y coordinate, e.g., indicating a column and row respectively.
  • the selection data may for example comprise ⁇ (4, (2,5)), (7, (3,3)),.... ⁇ to indicate that the value at index 4 in the sequence of values is to be placed at position (2,5) of the shared matrix, etc.
  • the selection data does not comprise the actual values of entries in the shared matrix, instead the actual values of the shared matrix are selected from the sequence of values.
  • the selection data may be supplemented with amendment data.
  • the amendment data may comprise data that indicates how values in the shared matrix are to be changed, e.g., by comprising an increment or decrement, or comprising a new value.
  • Such amendment data may be applied by generation unit 140 as well.
  • Amendment data is considered less advantageous: sending new values requires many bits, and each item in the amendment data influences only a single element of the shared matrix, yet selection data may be specified with only few bits, but may influence a large number of entries of the shared matrix. Small increments/decrements could be specified with fewer bits but they have comparatively little influence on the resulting lattice, and in fact may disappear in the noise added after a matrix multiplication with the shared matrix.
  • the selection data may comprise a permutation.
  • the assignment may then work by permuting the sequence of values according to the permutation and assigning the permuted sequence of values to entries of the shared matrix according to a default assignment.
  • the permutation is denoted as a bijective function ⁇ , that maps from the locations 1 to mn in the sequence of values to entries in the m ⁇ n matrix A , for some default way of numbering the entries in the shared matrix A , e.g. row-wise or column wise, etc.
  • the selection data may comprise a representation of the permutation ⁇ , and the assignment may work by assigning to index i according to the default way of indexing A the value of sequence 210 at location ⁇ ( i ).
  • the permutation may also be used the other way around, for example, the value at index i in the sequence may be assigned to entry ⁇ ( i ) in the matrix.
  • Part of matrix A may correspond with fixed elements of the sequence, so that it is not necessary to fully specify the mapping between sequence 210 and matrix 230, either in tuples or in a permutation. It suffices that there are a sufficient number of different matrices that can be obtained using the selection data.
  • Figure 2b schematically shows a first example of an embodiment of selection data.
  • sequence of values 210 one or more first groups are defined, shown are first groups 241 and 242.
  • matrix 230 one or more second groups are defined, shown are second groups 251 and 252.
  • the mapping between the entries of sequence 210 and the entries of matrix 230 can be restricted to mappings that map elements of a first group to elements of the corresponding second group.
  • the first and second groups can be chosen at random. In figure 2b , the first groups are selected sequentially, but the second groups are selected at random. Other choices are possible.
  • the second groups may be sequential, e.g., rows or columns, etc.
  • mappings that can be indicated by the selection data can be further restricted by restricting the number of allowed mappings.
  • the mapping is a cyclic permutation.
  • Figure 2c schematically shows a first example of an embodiment of selection data.
  • the base data forms a base matrix 260, e.g., the number of elements of the sequence of values is the same as the number of entries in the shared matrix, and may be indexed similarly.
  • the selection data may indicate a shared matrix by defining a permutation on the base matrix.
  • the selection data may indicate a cyclic permutation of a row and/or column of the base matrix by indicting a number of entries over which said row and/or columns is rotated.
  • the selection data may comprise a sequence of numbers, each a number of the sequence indicating a rotation over so many places of a row of the base matrix corresponding to the number.
  • the selection data is information that allows the receiving party to find the changed matrix; e.g., a sequence of numbers, the i-th number of which indicating over how many positions the i-th row matrix of A is rotated; or a sequence of (row index, rotation order) pairs. Using fewer numbers is possible.
  • the amount of data to specify a shared matrix from the base data in the sequence can be much smaller than the amount of data in the shared matrix itself.
  • the part of the selection data that indicates which values in a row of the base matrix go to which location in the shared matrix is 9 bits, which is 9/(512 * 12) ⁇ 1/100 the size of the data in the row.
  • Each of the methods above is capable to generate a large amount of different shared matrices from a single sequence of values. For example, using the system to rotate rows of a base matrix needs only a rotation parameter for 8 rows, to produce (2 9 ) 8 different shared matrices for a random sequence of values 210. Said number (2 9 ) 8 is larger than 2 64 , which one may take as a security parameter. For this example, it is sufficient to send eight pairs of (row index, cyclic permutation order), resulting in just 8*(9+9) bits. If the rows that are to be rotated are predetermined, the needed amount of data is still further reduced to 8*9 bits.
  • Some values in the shared matrix may have default values of the sequence. For example, some rows may always be equal to some predetermined values of the sequence.
  • the selection data may be communicated in at least two different ways.
  • the selection data directly represents which entry of the sequence maps to which entry of the shared matrix. This may be a very efficient way to construct the matrix A. For example, to compute from a parameter in the selection data at least one entry in the sequence of values and at least one entry in the shared matrix may be linear in the parameter. That is the exponent of p occurring in the mapping from the sequence of values to the shared matrix is at most 1.
  • computing a new location for a row modulo the number of entries in a row of the base matrix, or computing the index in a random first or second group is a single computation.
  • a first group in the sequence of values be the entries numbered x ... x + m - 1, we will assume a row of the shared matrix has m elements. Let p be the parameter in the selection data that indicates the number of entries in this group are rotated. Let the second group be the k 'th row of the matrix. The entries in A are numbered row wise starting from zero. The rows are also counted starting from zero. In this case, an entry x + i in the sequence may be mapped to an entry km + (( i + p ) mod m ). The above computation is linear in p .
  • T j is a table, e.g., a look-up table.
  • T j runs over the number of groups.
  • m j m for all j .
  • the number of groups may be equal to the number of rows, but this is not necessary.
  • the tables T j may be rows, e.g., just add the first index of a row as above, but they may also map the first group to more complicated sets.
  • the T j maps to irregular structures.
  • An example would be an independent set of the rook graph of the matrix, (only for square matrices). In fact, the T j may even form a Latin square design.
  • An alternative way to represent the selection is data is as a random seed.
  • deterministic pseudorandom number generator 160 maybe seeded with the random seed, and obtaining from the output of the deterministic pseudorandom number generator an indication of the multiple values in the sequence of values and/or of the multiple entries of the shared matrix.
  • Any of the above ways to represent selection data maybe used together with a seed representation, as one can generate the selection data from the output of the random number generator.
  • selection data may rotate, say, rows 1, 5, 13, 27 and 37 of the base matrix by an amount specified in the selection data.
  • the selection data could directly contain the row or column indices and the rotation amounts, or the selection data could comprise a random seed. In the latter case, the rotation amount maybe taken from the output of random number generator 160.
  • the selection data may be received from second node 111, in which case node 110 constructs the shared matrix from the sequence of values in accordance with the selection data.
  • the node 110 may generate selection data, e.g., randomly, e.g., from a seed, and next send the selection data, either as direct data or as the random seed to the second node.
  • FIG. 3a schematically shows an example of an embodiment of a cryptographic system 300.
  • System 300 comprises a server 310 and multiple clients. Shown are clients 320.1, 320.2 and 320.3. There maybe many more clients.
  • server 310 may be a computer that delivers digital services over a digital network to the clients.
  • server 310 may be a web shop. The clients may use a web browser to browse a website operated by server 310 and order from the web shop. Communication between the server and the clients may be encrypted and/or authenticated.
  • the server and the clients may execute a key exchange protocol.
  • System 300 is organized to reduce overhead associated with computing many different shared matrices for server 310.
  • Server 310 may be organized as first network 110 shown in figure 1 , except that base data memory 170 is arranged as a cache memory arranged to cache a sequence of values ( A 1 , A 2 ) together with a corresponding sequence identifier which identifies said cached sequence of values.
  • Cache memory 170 may store multiple sequences of values with an associated sequence identifier. For example, there maybe two or more base matrices A 1 , A 2 , etc., but this is not necessary.
  • Base data manager 130 is arranged to obtain the sequence by receiving a sequence identifier from the second network node and to verify if a sequence of values corresponding to the received sequence identifier is cached in the cache memory and if such a sequence of values is not cached in the cache matrix, obtaining the sequence of values from the second network node. Obtaining the sequence may be done in any of the ways depicted above.
  • the second network node e.g., a client may then be arranged to send a sequence identifier to the server corresponding to a sequence of values cached in the cache memory.
  • the network node maybe arranged to share the base matrix (A) with the second network node, e.g., by sending the matrix, or a seed to produce the matrix.
  • This arrangement reduces the load on server 310 somewhat, e.g., if communication is performed twice with the same node, or if many nodes use the same sequence of values.
  • the roles are reversed and the base data manager 130 is arranged to a select a sequence identifier for the second network node corresponding to a sequence of values cached in cache memory 170. In this way, the overhead associated with generating the base matrix, e.g., from a random seed is largely avoided at server 310.
  • the selection data that is subsequently exchanged between server 310 and clients and 320 may then use the sequence of values identified by the sequence identifier to construct the shared matrix.
  • the sequence identifier comprises a further random seed.
  • a deterministic pseudorandom number generator is seeded with the further random seed.
  • the sequence of values is obtained from the output of the seeded deterministic pseudorandom number generator.
  • Figure 3b schematically shows an example of an embodiment of a detail of a cryptographic protocol executed between a server 310 and a client 320, e.g., one of the clients shown in figure 3a .
  • a first message 331 sent from client 320 to server 310 comprises a message request. It may comprise additional information such as an identifier for client 320.
  • server 310 sends a second message 332 to client 320.
  • Second message 332 comprises a sequence identifier, e.g., comprising a further random seed.
  • Server 310 has cached the corresponding sequence of values, e.g., after having computed it once from the further random seed.
  • the sequence of values may be in the form of a base matrix.
  • Message 332 may also comprise selection data, generated by server 310.
  • the selection data in message 332 maybe in the form of a random seed, or not.
  • Message 332 may also contain protocol information generated by server 310, which is possible since server 310 at this point has access to the shared matrix. For example, in a key exchange protocol as described above, message 332 could comprise a public key generated for this key exchange execution.
  • client 320 may retrieve the sequence of values from its cache memory, or, if the sequence of values is not present in the cache memory, generate the sequence of values from the further random seed in the sequence identifier.
  • client 320 may construct the shared matrix from the sequence of values and the selection data. Using the constructed shared matrix, client 320 may generate further values in the protocol, and return them with message 333.
  • message 333 may contain a public key generated by client 320 from the shared matrix and a private key of client 320.
  • Message 320 may also contain encrypted information, encrypted with a key derived from its own private key and the public key obtained in message 332.
  • the encrypted data may contain, say, a credit card number of a user of client 320.
  • Server 310 when it receives the message 333 may use the public key and its own private key matrix to obtain the encryption key and decrypt the encrypted data, e.g., to obtain the credit card number.
  • the selection data is not selected, or not only selected, by the server 310 and sent in message 320 but selected, or also selected, by client 320 and sent in message 333 to server 310.
  • the selection data in message 3333 directly determines a mapping between the sequence of values identified by the sequence identifier and the shared matrix, without using a random seed to generate it.
  • each node may specify a permutation of a base matrix.
  • a particular one, say the initiating node of the protocol, may apply his permutation first followed by the permutation of the responding node.
  • the communication interface may be selected from various alternatives.
  • input interface maybe a network interface to a local or wide area network, e.g., the Internet, a storage interface to an internal or external data storage, etc.
  • Base data memory 170 may be implemented as an electronic memory, say a flash memory, or magnetic memory, say hard disk or the like. Base data memory 170 may comprise multiple discrete memories together making up base data memory 170. Base data memory 170 may also be a temporary memory, say a RAM. In the case of a temporary Base data memory 170, Base data memory 170 contains some means to obtain parameters before use, say by obtaining them over an optional network connection (not shown).
  • the device 110 and the 111 each comprise a microprocessor (not separately shown) which executes appropriate software stored at the device 110 and the 111; for example, that software may have been downloaded and/or stored in a corresponding memory, e.g., a volatile memory such as RAM or a non-volatile memory such as Flash (not separately shown).
  • the devices 310 and 320.1-3 may also be equipped with microprocessors and memories (not separately shown).
  • the devices 110 and the 111 may, in whole or in part, be implemented in programmable logic, e.g., as field-programmable gate array (FPGA).
  • FPGA field-programmable gate array
  • Devices 110 and the 111 may be implemented, in whole or in part, as a so-called application-specific integrated circuit (ASIC), i.e. an integrated circuit (IC) customized for their particular use.
  • ASIC application-specific integrated circuit
  • the circuits may be implemented in CMOS, e.g., using a hardware description language such as Verilog,
  • first network node 110 comprises a communication interface circuit, a base data manager circuit, a matrix generation unit circuit, a cryptographic unit circuit, a matrix multiplication unit circuit, a pseudorandom number generator circuit, etc.
  • the device 100 may comprise additional circuits, e.g., a cache circuit, etc.
  • the circuits implement the corresponding units described herein.
  • the circuits may be a processor circuit and storage circuit, the processor circuit executing instructions represented electronically in the storage circuits.
  • a processor circuit may be implemented in a distributed fashion, e.g., as multiple sub-processor circuits.
  • a storage maybe distributed over multiple distributed sub-storages.
  • Part or all of the memory may be an electronic memory, magnetic memory, etc.
  • the storage may have volatile and a non-volatile part.
  • Part of the storage may be read-only.
  • the circuits may also be, FPGA, ASIC or the like.
  • the performance is better since the elements in r are smaller than the elements in A and therefore can be computed faster and more efficiently.
  • the sequence of values may be obtained in a number of ways. For example:
  • the responder makes more sense that the responder publishes the seed since it can often happen that the responder is a server handling many connections.
  • This seed can also be computed by a trusted third party independent of server and client according to any of the above embodiments.
  • the initiator and responder maybe taken as the first and second network node or vice versa.
  • the initiator may be network node that initiates the cryptographic protocol.
  • the initiator may be defined as the network node that uses key reconciliation data, while the responder generates key reconciliation data (key reconciliation data is data used to ensure that both parties arrive at the same share key).
  • Embodiment 4 describes a further embodiment that provides a good trade-off between memory and CPU.
  • the public sequence P can be obtained.
  • the public sequence may, in one embodiment, be specified in an industry standard.
  • it is generated by a server S.
  • a client C wishing to communicate with S receives P , or parameters, e.g. a seed, and a method to compute P from S.
  • P is generated and distributed by a trusted third party (TTP).
  • TTP trusted third party
  • a server may store P and use it for communication with multiple clients.
  • the sequence P may only be valid during a time-period indicated by the TTP.
  • a server S stores all such matrices.
  • a client C selects sequences from TTP that it actually trusts, combines them in some prespecified way, and applies a permutation on this combination. It sends to S the indices of the selected TTPs, and a seed so that S can retrieve said permutation. By combining matrices and permuting entries, S can find the matrix actually used by C.
  • the pseudo random function can be defined as, e.g.:
  • the public-key e.g., LWE
  • the public key is given by a pair (b, A).
  • Matrix A can take a considerable space for storage or alternatively, it may need to be generated dynamically.
  • the advantage is that the storage needs at a server will be much lower and the computational needs also much lower.
  • Method 400 is an electronic method for a first electronic network node configured for a cryptographic protocol based on a shared matrix, e.g., such as network node 110.
  • the shared matrix having multiple entries each entry having a value.
  • Method 400 comprises
  • a method according to the invention may be executed using software, which comprises instructions for causing a processor system to perform method 400.
  • Software may only include those steps taken by a particular sub-entity of the system.
  • the software may be stored in a suitable storage medium, such as a hard disk, a floppy, a memory, an optical disc, etc.
  • the software may be sent as a signal along a wire, or wireless, or using a data network, e.g., the Internet.
  • the software maybe made available for download and/or for remote usage on a server.
  • a method according to the invention may be executed using a bitstream arranged to configure programmable logic, e.g., a field-programmable gate array (FPGA), to perform the method.
  • FPGA field-programmable gate array
  • the invention also extends to computer programs, particularly computer programs on or in a carrier, adapted for putting the invention into practice.
  • the program maybe in the form of source code, object code, a code intermediate source, and object code such as partially compiled form, or in any other form suitable for use in the implementation of the method according to the invention.
  • An embodiment relating to a computer program product comprises computer executable instructions corresponding to each of the processing steps of at least one of the methods set forth. These instructions may be subdivided into subroutines and/or be stored in one or more files that may be linked statically or dynamically.
  • Another embodiment relating to a computer program product comprises computer executable instructions corresponding to each of the means of at least one of the systems and/or products set forth.
  • Figure 5a shows a computer readable medium 1000 having a writable part 1010 comprising a computer program 1020, the computer program 1020 comprising instructions for causing a processor system to perform a method of sharing a matrix, according to an embodiment.
  • the computer program 1020 may be embodied on the computer readable medium 1000 as physical marks or by means of magnetization of the computer readable medium 1000. However, any other suitable embodiment is conceivable as well.
  • the computer readable medium 1000 is shown here as an optical disc, the computer readable medium 1000 may be any suitable computer readable medium, such as a hard disk, solid state memory, flash memory, etc., and may be non-recordable or recordable.
  • the computer program 1020 comprises instructions for causing a processor system to perform said method of sharing a matrix.
  • FIG. 5b shows in a schematic representation of a processor system 1140 according to an embodiment.
  • the processor system comprises one or more integrated circuits 1110.
  • the architecture of the one or more integrated circuits 1110 is schematically shown in Figure 5b .
  • Circuit 1110 comprises a processing unit 1120, e.g., a CPU, for running computer program components to execute a method according to an embodiment and/or implement its modules or units.
  • Circuit 1110 comprises a memory 1122 for storing programming code, data, etc. Part of memory 1122 may be read-only.
  • Circuit 1110 may comprise a communication element 1126, e.g., an antenna, connectors or both, and the like.
  • Circuit 1110 may comprise a dedicated integrated circuit 1124 for performing part or all of the processing defined in the method.
  • Processor 1120, memory 1122, dedicated IC 1124 and communication element 1126 may be connected to each other via an interconnect 1130, say a bus.
  • the processor system 1110 maybe arranged for contact and/or contact-less communication, using an antenna and/or connectors, respectively.
  • the first network node may comprise a processor circuit and a memory circuit, the processor being arranged to execute software stored in the memory circuit.
  • the processor circuit may be an Intel Core i7 processor, ARM Cortex-R8, etc.
  • the processor circuit may be ARM Cortex M0.
  • the memory circuit may be an ROM circuit, or a non-volatile memory, e.g., a flash memory.
  • the memory circuit may be a volatile memory, e.g., an SRAM memory.
  • the device may comprise a non-volatile software interface, e.g., a hard drive, a network interface, etc., arranged for providing the software.
  • any reference signs placed between parentheses shall not be construed as limiting the claim.
  • Use of the verb "comprise” and its conjugations does not exclude the presence of elements or steps other than those stated in a claim.
  • the article "a” or “an” preceding an element does not exclude the presence of a plurality of such elements.
  • the invention may be implemented by means of hardware comprising several distinct elements, and by means of a suitably programmed computer. In the device claim enumerating several means, several of these means may be embodied by one and the same item of hardware. The mere fact that certain measures are recited in mutually different dependent claims does not indicate that a combination of these measures cannot be used to advantage.
  • references in parentheses refer to reference signs in drawings of exemplifying embodiments or to formulas of embodiments, thus increasing the intelligibility of the claim. These references shall not be construed as limiting the claim.

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Security & Cryptography (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Theoretical Computer Science (AREA)
  • Mathematical Analysis (AREA)
  • Mathematical Optimization (AREA)
  • Mathematical Physics (AREA)
  • Pure & Applied Mathematics (AREA)
  • Computational Mathematics (AREA)
  • Algebra (AREA)
  • Computing Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Data Mining & Analysis (AREA)
  • Databases & Information Systems (AREA)
  • Software Systems (AREA)
  • Storage Device Security (AREA)
  • Mobile Radio Communication Systems (AREA)

Abstract

A network node (110) is provided configured for a cryptographic protocol based on a shared matrix. The network node is arranged to construct the shared matrix (A) in accordance with the selection data and a shared sequence of values. Multiple entries of the shared matrix are assigned to multiple values of the sequence of data as assigned by the selection data. The shared matrix is applied in the cryptographic protocol.

Description

    FIELD OF THE INVENTION
  • The invention relates to an electronic network node, an electronic method for an electronic network node configured for a cryptographic protocol based on a shared matrix, a computer readable medium
  • BACKGROUND
  • There exist a number of cryptographic protocols which are based on a matrix shared between the two nodes who execute the protocol. Although the shared matrix is typically public, both parties operate on the shared matrix with data which is private to the party that performs the computation, e.g., using secret information. Attacking such cryptographic protocols leads to lattice based problems, e.g., an attacker is required to solve a lattice problem, such as a shortest vector lattice problem, to attack the protocol. Lattice problems are expected to be quantum safe, and accordingly this is an active area of research.
  • A few of these protocols will be briefly discussed herein as a motivating example. However, in summary, the nodes typically combine the shared matrix with private information of their own. For example, a network node may compute a matrix product between the shared matrix and a private vector or matrix of the network node as part of the cryptographic protocol. For example, noise may be added to the result of the computation, e.g., in the form of a noise vector or matrix that is added to the multiplication result or in the form of rounding or scaling of the result. After adding the noise, the result still contains sufficient information on the private key in order to perform useful operations for another node, e.g., signing, encrypting, key agreement, etc., but not sufficient information to recover the private data of the other node. Key reconciliation may be used to correct for the added noise.
  • The starting point of such lattice based cryptography is that both parties, e.g., network nodes 110 and 111 have access to a shared matrix. This matrix is typically selected at random and is quite large. The shared matrix has multiple entries, and each entry has a value. For example, a shared matrix may have dimensions of, say, 500 times 500, or even larger. In exemplifying computations, we will use a square shared matrix with dimension 512 = 29. Entries in the shared matrix are typically modulo a modulus q, which may be, say 210. Thus, a shared matrix may represent about 29 · 29 · 210 = 228 bits of information.
  • Although the shared matrix is often public, and could be transmitted as plain data, clearly, such large amounts of information is problematic, especially given the fact that an important application of cryptographic protocols is expected to be the internet of things, in which resource-restricted nodes operate on data which are to be cryptographically protected. For example, the nodes may form a sensor network.
  • A first way to reduce overhead caused by the requirement that a large matrix is shared between two nodes is to re-use the same matrix many times over. Unfortunately, this leads to cryptographic problems. An attacker can perform extensive pre-computations on the shared matrix, if it knows that matrix will be used in a future cryptographic exchange. Examples of such precomputations attack are, e.g., the Logjam attack on finite-field Diffie-Hellman. On the other hand, if a fresh shared matrix is used for each execution of the cryptographic protocol, then the attacker would be presented with a fresh lattice problem for each execution; It is thus preferred not to re-use the same matrix.
  • A second way to reduce overhead caused by the large shared matrix is to send a random seed instead of the shared matrix. The random seed is then used to seed a deterministic random number generator, which in turn generates the shared matrix. Many deterministic random number generators are known. Unfortunately, in this way transmission overhead is traded for computational overhead. Resource-limited devices would need to compute a long time to generated the shared matrix. The problem may be just as bad for a large server that handles many simultaneous computations at the same time. Moreover, if an attacker could cause such a server to perform many random number generations, it would lead to denial-of-service attacks. The attacker could start many connections with the server and abandon them after the server is committed to generating the shared matrix from a random seed.
  • SUMMARY OF THE INVENTION
  • An electronic network node configured for a cryptographic protocol based on a shared matrix is provided that addresses these and other problems. The shared matrix has multiple entries and each entry has a value. For ease of reference the network node will be identified as the first network node, distinguishing it from a second network node with which is communicates. The adjective 'first' and 'second' have no further meaning.
  • The first network node comprises
    • a communication interface arranged for digital communication with a second network node,
    • a processor circuit configured to
    • obtain a sequence of values for the entries of the shared matrix, the sequence of values being shared with the second network node,
    • receive selection data from the second network node, or determining selection data and sending the selection data to the second network node, the selection data indicating multiple positions in the sequence of values and assigning to multiple entries of the shared matrix a value of the sequence of values indicated by the selection data,
    • construct the shared matrix in accordance with the selection data, setting said multiple entries of the shared matrix to the multiple values assigned by the selection data,
    • applying the shared matrix in the cryptographic protocol.
  • Selection data can be described with much fewer bits than the sequence of values can be. For example, in some embodiments the amount of selection data needed to assign data to a group of entries in the shared matrix is less than 1/100 of the amount of data needed to describe the data itself. If selection data is generated from a random number generator then less data needs to be generated than generating the values in the shared matrix themselves would, regardless of whether this happens at the node that sends selection data or at the node that receives the selection data. Especially for a node, e.g., a server, with many connections to second nodes this makes a substantial difference in operating the network node. Compared to the needed bandwidth for sending the data itself, also a substantial reduction is obtained.
  • In an embodiment, a node caches the sequence of values and uses it for multiple connections. For example, in an embodiment, a node can send or receive a sequence identifier to identify the sequence of values to use. The identifier could, e.g., be a hash over the sequence of values, but in an advantageous embodiment the sequence identifier comprises a random seed from which the sequence of values may be generated. In this way, a receiver of a sequence identifier can either retrieve the sequence identifier from a cache memory or can generate the sequence of values.
  • The lattices that an attacker would obtain for different matrices that are shared in this way are different even if the underlying sequence of values is the same. Especially if the number of different lattices is larger, the advantage of the attacker is significantly reduced.
  • The network node is an electronic device. The network node maybe a mobile electronic device, such as a mobile phone. The network node may be a set-top box, smart-card, computer, or the like.
  • A method of sharing a matrix described herein may be applied in a wide range of practical applications. Such practical applications include financial applications, e.g., to share credit card information, privacy enhancing applications, e.g., messaging applications, medial applications, etc.
  • A method according to the invention may be implemented on a computer as a computer implemented method, or in dedicated hardware, or in a combination of both. Executable code for a method according to the invention may be stored on a computer program product. Examples of computer program products include memory devices, optical storage devices, integrated circuits, servers, online software, etc. Preferably, the computer program product comprises non-transitory program code stored on a computer readable medium for performing a method according to the invention when said program product is executed on a computer.
  • In a preferred embodiment, the computer program comprises computer program code adapted to perform all the steps of a method according to the invention when the computer program is run on a computer. Preferably, the computer program is embodied on a computer readable medium.
  • Another aspect of the invention provides a method of making the computer program available for downloading. This aspect is used when the computer program is uploaded into, e.g., Apple's App Store, Google's Play Store, or Microsoft's Windows Store, and when the computer program is available for downloading from such a store.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • Further details, aspects, and embodiments of the invention will be described, byway of example only, with reference to the drawings. Elements in the figures are illustrated for simplicity and clarity and have not necessarily been drawn to scale. In the Figures, elements which correspond to elements already described may have the same reference numerals. In the drawings,
    • Figure 1 schematically shows an example of an embodiment of a cryptographic system,
    • Figure 2a, 2b, 2c schematically show examples of an embodiment of selection data,
    • Figure 3a schematically shows an example of an embodiment of a cryptographic system,
    • Figure 3b schematically shows an example of an embodiment of a detail of a cryptographic protocol,
    • Figure 4 schematically shows an example of an embodiment of a method for sharing a matrix,
    • Figure 5a schematically shows a computer readable medium having a writable part comprising a computer program according to an embodiment,
    • Figure 5b schematically shows a representation of a processor system according to an embodiment.
    DETAILED DESCRIPTION OF PREFERRED EMBODIMENTS
  • While this invention is susceptible of embodiment in many different forms, there are shown in the drawings and will herein be described in detail one or more specific embodiments, with the understanding that the present disclosure is to be considered as exemplary of the principles of the invention and not intended to limit the invention to the specific embodiments shown and described.
  • In the following, for the sake of understanding, elements of embodiments are described in operation. However, it will be apparent that the respective elements are arranged to perform the functions being described as performed by them. Further, the invention is not limited to the embodiments, and the invention lies in each and every novel feature or combination of features described herein or recited in mutually different dependent claims.
  • Figure 1 schematically shows an example of an embodiment of a cryptographic system 100. Cryptographic system 100 comprises multiple network nodes. Shown in figure 1 are a first network node 110 and a second network node 111. For the most part, nodes 110 and 111 are of the same design, except where they have a sender-receiver relationship. The network nodes in system 100 are configured to execute a cryptographic protocol based on a shared matrix; in particular, first network node 110 and second network node 111 are configured for such a cryptographic protocol. Preferably a fresh shared matrix is used for each execution of the cryptographic protocol.
  • Network node 110 comprises a cryptographic unit 150. Cryptographic unit 150 is arranged to perform a cryptographic protocol using the shared matrix. As pointed out in the background, many such cryptographic protocols exist, and all require a large matrix which is shared between the two parties. Often a matrix product is computed between the shared matrix and a private vector or matrix of the network node as part of the cryptographic protocol. For example, cryptographic unit 150 may comprises a matrix multiplication unit 152 arranged to compute said matrix multiplication.
  • A first example, of a cryptographic protocol using a shared matrix is a key exchange protocol. For example, the first node may be configured to
    • generate a private key matrix (Sl ),
    • generate a public key matrix (Pl ), said generating comprising at least
      • computing a matrix product between the shared matrix (A) and the private key matrix (Sl ) obtaining a matrix product
    • sending the public key matrix of the first network node to the second network node,
    • receiving a public key matrix (PR ) of the second network node,
    • computing a raw key as a matrix product between the received public key of the second node and the private key matrix of the first network node, wherein the first network node is further configured to compute a shared key from at least the raw key would.
  • By introducing noise during the generation of the public key matrix (Pl ), it is avoided that an attacker could reconstruct the private keys from knowledge of the public keys and the shared key. This key agreement protocol is based on the fact that, except for the added noise, S R T AS I
    Figure imgb0001
    is the same for both the first and the second network node. Computing the matrix product between the shared matrix (A) and the private key matrix (Sl ) is done modulo a modulus. One of the nodes can compute key reconciliation data and send it to the other node, to ensure both compute the same shared key form the matrix products. A more detailed description of a lattice based key agreement protocol is given in the article by J. Bos, C. Costello, L. Ducas, I. Mironov, M. Naehrig, V. Nikolaenko, A. Raghunathan, D. Stebila. "Frodo: Take off the ring! Practical, Quantum-Secure Key Exchange from LWE." (included herein by reference and referred to as 'Frodo'.).
  • A second example, of a lattice based cryptographic protocol is a public key encryption /decryption algorithm. For example, a network node may be configured to
    • obtain a public key of a second network node, said public key comprising the selection data, and a further public key matrix (B), the further public key matrix having been previously obtained from the shared matrix and a private key matrix (S)
    • choose a random vector r, and compute two matrix products (e.g., a' = ATr, b' = BTr) between the random vector (r) and the shared matrix and between the random vector (r) and the further public key matrix,
    • compute an encrypted message from a plain message by adding a blinding vector computed from a first one of the two matrix products, the encrypted message further including decryption information computed from the second one of the two matrix products.
  • Also in this example, noise may be added, e.g. in the form of scaling. A detailed example, of a lattice based public key encryption protocol may be found in the article by J. H. Cheon, D. Kim, J. Lee, Y. Song: "Lizard: Cut off the Tail! Practical Post-Quantum Public-Key Encryption from LWE and LWR" (induced herein by reference).
  • Returning to figure 1. There is thus the problem how to obtain a matrix shared between two nodes. The shared matrix has multiple entries each entry having a value. We will refer to the row and columns of the matrix. In an example, at least one of the number of rows and the number of columns is larger than 50, 100, 500, etc. The shared matrix may be square for convenience, although this is no necessity. The matrix may be a vector, e.g., when one of the dimensions is 1, however most advantages are obtained as both dimensions are large, e.g., when both the number of rows and the number of columns is larger than 50, 100, 500, etc.
  • The first and second network node each comprise a communication interface 120. Communication interface 120 of first network node 110 is arranged for digital communication with second network node 111. Typically, Communication interface 120 is arranged to communicate with many of the other nodes in system 100.
  • The communication interfaces maybe arranged for digital communication with the other nodes in the key agreement system. It is not necessary though that all nodes in the system can be reached at all times. Communication interface 120 is arranged for digital communication. For example, the communication interfaces may be arranged to communicate over a computer network. For example, the communication interface may be arranged for wireless, e.g., Wi-Fi, ZigBee, Bluetooth and the like, and/or wired communication, e.g., Ethernet, USB, and the like. The communication between nodes 110 and 111 may also be a combination of wired and wireless connections. For example, the nodes in system 100, including nodes 110 and 111 may comprise an electronic storage that contains a communication identifier, which uniquely identifies the node within system 100. For example, the communication identifier may be included in digital messages exchanged between nodes 110 and 111, e.g., to address the message. For example, the communication identifier may an IP address, a MAC address, and the like.
  • The electronic network nodes are configured for a cryptographic protocol, such as the key exchange or public key encryption protocol examples given above. The cryptographic protocol involves exchanging messages between the nodes 110 and 111 over the communication interfaces 120, and performing computations on, e.g., data received from the other node. The execution of the protocols is implemented in a processor circuit, examples of which are shown below. Figure 1 shows functional units that may be functional units of the processor circuit. For example, figure 1 may be used as a blueprint of a possible functional organization of the processor circuit. The processor circuit is not shown separate from the units in figure 1. For example, the functional units shown in figure 1 may also be wholly or partially be implemented in computer instructions that are stored at the network nodes and are executable by a microprocessor of the network node. In hybrid embodiments, functional units are implemented partially in hardware, e.g., as coprocessors, e.g., crypto coprocessors, and partially in software stored an executed on the network node.
  • Network node 110 comprises a base data manager 130 arranged to obtain a sequence of values for the entries of the shared matrix, the sequence of values being shared with the second network node. Network node 110 also comprises a base data memory 170 arranged for storing the shared sequence of values, e.g., after it has been obtained.
  • Like the entries in the shared matrix A, the values in the sequence of values may be selected modulo a modulus. The sequence of values is also referred to as the base data, or the base values etc. The sequence of values will be used to fill the shared matrix with. It was an insight of the inventors that a mapping from a sequence of values to the entries of a shared matrix can be transmitted in much fewer bits, or may be computed from much fewer pseudorandom outputs than the sequence of values itself. By varying the way in which the shared matrix is constructed from the sequence of values, a large number of different shared matrices can be obtained from the same base data. Thus, the cryptographic advantages of using a different shared matrix each time, is combined with the low overhead of re-using the same sequence of values.
  • There are a number of ways in which base data manager 130 may obtain base data which is shared with the second network node.
  • In a first example, base data memory 170 pre-stores the sequence of values. For example, the multiple network nodes in system 100 may be provided with the sequence at some point, e.g., at first use, during manufacture, at a trusted location, etc. The shared sequence of values may be a fixed sequence, for example, fixed in a standard, or the like. In this case, base manager 130 has little more to do than to provide access to base data memory 170 in which the sequence of values. Embodiments of this type, base data memory 170 or the part thereof in which the shared sequence of values is stored may be ROM memory.
  • In a second example, the sequence of values is obtained from a trusted third party. For example, periodically, base data manager 130 contacts a trusted third party, e.g., over a computer network, to obtain a new sequence of values. For example, base data manager 130 may be configured to obtain such a new sequence periodically, e.g., once every 30 days, e.g., at the beginning of each new month, etc.
  • To reduce transmission overhead, base data manager 130 may obtain the shared sequence of values as a random seed. For example, first network node 110 may comprise a deterministic pseudorandom number generator 160. Pseudorandom number generator may be seeded with the random seed and used to compute the sequence of values. The seed maybe obtained from various sources, e.g., preprogrammed, e.g., during manufacture, e.g., received from the second network node, e.g., received from a trusted third party, etc. The selection data may also be generated at the first network node and sent to the second network node.
  • The sequence of values is used for multiple executions of the cryptographic protocol, for example, the sequence of values is used at least twice to construct at least two different shared matrices, shared with the second network node. In an embodiment, the sequence of values is shared with multiple network nodes, e.g., each of the multiple network nodes of system 100. The latter is not necessary though, for example, a particular sequence of values may be used just by the first and second network node; for example, the first time the first and second network node interact they may exchange a random seed to generate the sequence of values that is used between them thereafter. Below further embodiments using caching of sequences are described.
  • Pseudorandom number generator 160 may be a fast linear feedback generator such as the Mersenne twister. A cryptographically secure random number generator is however preferred. For example, pseudorandom number generator 160 may satisfy the so-called next-bit test. That is, given the first k b its of a random sequence, there is no polynomial-time algorithm that can predict the (k + 1)th bit with probability of success non-negligibly better than 50%. There are many cryptographically secure random number generators known, e.g., a block cipher run in counter mode, e.g., the Advanced Encryption Standard in counter mode. A secure random number generator may also be obtained by running a hash function in counter mode, e.g., SHA-256, etc. The Mersenne twister may also be secured, e.g., by basing a pair of cryptographic stream ciphers on output from the Mersenne Twister. Further examples include the Blum-blum-shub generator, Blum-Micali generator, etc.
  • Network node 110 comprises a matrix generation unit 140. Matrix generation unit 140 is arranged to construct the shared matrix (A) in accordance with the selection data, setting said multiple entries of the shared matrix to the multiple values assigned by the selection data. The selection data thus describes a mapping between the shared sequence of values and the entries in the shared matrix. The selection data maybe obtained from the second network node e.g., through communication interface 120. The sequence of values is transformed to an actual shared matrix A by the selection data.
  • Generation unit 140 may also determine selection data itself and send the selection data to the second network node. For example, if the selection data comprises tuples, permutations, rotation parameters, and the like as illustrated in the various embodiments, then generation unit 140 could select these at random as generated selection data. The generated selection data may be sent to the second network node. If the selection data is derived from the output of a deterministic random number generator, then the seed of the generator could be sent to the second network node instead.
  • Selection data thus indicates multiple values in the sequence of values and assigns to multiple entries of the shared matrix a value of the sequence of values indicated by the selection data. In an embodiment, all entries of the shared matrix receive their value from the sequence of values, however, it is not necessary that each entry receives that value from a location in the sequence of values that is indicated by the selection data; some entries in the shared matrix may receive their value from a fixed location in the sequence of values. A number of examples, are explained with reference to figures 2a, 2b and 2c.
  • Figure 2a schematically shows an example of an embodiment of selection data. The selection data identifies locations in the sequence of values 210, shown are values 221 and 222, that are to be assign to locations in the shared matrix 230, shown are entries 231 and 232.
  • For example, selection data may comprise a sequence of tuples, each tuple comprising an index in the sequence of values and an index in the shared matrix. For example, the sequence of values may be indexed linearly, e.g., counted sequentially, e.g., using the natural numbers. For example, the shared matrix may also be indexed with a single number, e.g., numbered sequentially, but may also be indexed by an x and y coordinate, e.g., indicating a column and row respectively. The selection data may for example comprise {(4, (2,5)), (7, (3,3)),....} to indicate that the value at index 4 in the sequence of values is to be placed at position (2,5) of the shared matrix, etc. The selection data does not comprise the actual values of entries in the shared matrix, instead the actual values of the shared matrix are selected from the sequence of values. In an embodiment, the selection data may be supplemented with amendment data. For example, the amendment data may comprise data that indicates how values in the shared matrix are to be changed, e.g., by comprising an increment or decrement, or comprising a new value. Such amendment data may be applied by generation unit 140 as well. Amendment data is considered less advantageous: sending new values requires many bits, and each item in the amendment data influences only a single element of the shared matrix, yet selection data may be specified with only few bits, but may influence a large number of entries of the shared matrix. Small increments/decrements could be specified with fewer bits but they have comparatively little influence on the resulting lattice, and in fact may disappear in the noise added after a matrix multiplication with the shared matrix.
  • It may happen that some position (i,j) of the shared matrix does not appear in the selection data. This may be resolved by giving the position a default value, e.g., a predetermined value. This may also be resolved by giving the position a value, from a default location in the sequence of values.
  • For example, the selection data may comprise a permutation. The assignment may then work by permuting the sequence of values according to the permutation and assigning the permuted sequence of values to entries of the shared matrix according to a default assignment. For example, if the permutation is denoted as a bijective function σ, that maps from the locations 1 to mn in the sequence of values to entries in the m × n matrix A, for some default way of numbering the entries in the shared matrix A, e.g. row-wise or column wise, etc. The selection data may comprise a representation of the permutation σ, and the assignment may work by assigning to index i according to the default way of indexing A the value of sequence 210 at location σ(i). The permutation may also be used the other way around, for example, the value at index i in the sequence may be assigned to entry σ(i) in the matrix.
  • Part of matrix A may correspond with fixed elements of the sequence, so that it is not necessary to fully specify the mapping between sequence 210 and matrix 230, either in tuples or in a permutation. It suffices that there are a sufficient number of different matrices that can be obtained using the selection data.
  • Figure 2b schematically shows a first example of an embodiment of selection data. There are various ways to reduce the number of bits needed to specify a mapping between sequence 210 and matrix 230, one of which is illustrated with respect to figure 2b. In sequence of values 210 one or more first groups are defined, shown are first groups 241 and 242. In matrix 230 one or more second groups are defined, shown are second groups 251 and 252. To each first group in sequence 210 there corresponds a second group in matrix 230. The mapping between the entries of sequence 210 and the entries of matrix 230 can be restricted to mappings that map elements of a first group to elements of the corresponding second group. The first and second groups can be chosen at random. In figure 2b, the first groups are selected sequentially, but the second groups are selected at random. Other choices are possible. For example, also the second groups may be sequential, e.g., rows or columns, etc.
  • The mappings that can be indicated by the selection data can be further restricted by restricting the number of allowed mappings. For example, in an example, the mapping is a cyclic permutation.
  • Figure 2c schematically shows a first example of an embodiment of selection data. In this example, the base data forms a base matrix 260, e.g., the number of elements of the sequence of values is the same as the number of entries in the shared matrix, and may be indexed similarly. In this case the selection data may indicate a shared matrix by defining a permutation on the base matrix. For example, the selection data may indicate a cyclic permutation of a row and/or column of the base matrix by indicting a number of entries over which said row and/or columns is rotated. For example, the selection data may comprise a sequence of numbers, each a number of the sequence indicating a rotation over so many places of a row of the base matrix corresponding to the number.
  • In an embodiment, the selection data is information that allows the receiving party to find the changed matrix; e.g., a sequence of numbers, the i-th number of which indicating over how many positions the i-th row matrix of A is rotated; or a sequence of (row index, rotation order) pairs. Using fewer numbers is possible.
  • Note that the amount of data to specify a shared matrix from the base data in the sequence, e.g., in a base matrix can be much smaller than the amount of data in the shared matrix itself. For example, consider figure 2c, for a square matrix of dimension 512 and modulo 2048. Only 9 bits are needed to specify a cyclic permutation on a row, whereas 512* 12 bits are needed to specify the data in the row itself. Thus, in this example, the part of the selection data that indicates which values in a row of the base matrix go to which location in the shared matrix is 9 bits, which is 9/(512 * 12) < 1/100 the size of the data in the row.
  • Each of the methods above is capable to generate a large amount of different shared matrices from a single sequence of values. For example, using the system to rotate rows of a base matrix needs only a rotation parameter for 8 rows, to produce (29)8 different shared matrices for a random sequence of values 210. Said number (29)8 is larger than 264, which one may take as a security parameter. For this example, it is sufficient to send eight pairs of (row index, cyclic permutation order), resulting in just 8*(9+9) bits. If the rows that are to be rotated are predetermined, the needed amount of data is still further reduced to 8*9 bits. However, larger numbers of different matrices A are easily possible using a more parameters in the selection data, e.g., larger than 2128, larger than 2256, etc., using 15 and 29 rotation parameters for 15 and 29 rows or columns respectively. In an embodiment, part of the rotation parameters rotate rows while part of the rotation parameters rotate columns. This has the advantage that the rotation is equally incompatible with matrix multiplications for both nodes, e.g., in situation in which one of the nodes uses a left multiplication and the other a right multiplication. In yet another embodiment, with square matrices, rotations take place over (cyclic) diagonals of the matrix.
  • Some values in the shared matrix may have default values of the sequence. For example, some rows may always be equal to some predetermined values of the sequence.
  • The selection data may be communicated in at least two different ways. In a first option, the selection data directly represents which entry of the sequence maps to which entry of the shared matrix. This may be a very efficient way to construct the matrix A. For example, to compute from a parameter in the selection data at least one entry in the sequence of values and at least one entry in the shared matrix may be linear in the parameter. That is the exponent of p occurring in the mapping from the sequence of values to the shared matrix is at most 1. Using the representations of figures 2b and 2c computing a new location for a row modulo the number of entries in a row of the base matrix, or computing the index in a random first or second group is a single computation.
  • For example, let a first group in the sequence of values be the entries numbered x ... x + m - 1, we will assume a row of the shared matrix has m elements. Let p be the parameter in the selection data that indicates the number of entries in this group are rotated. Let the second group be the k'th row of the matrix. The entries in A are numbered row wise starting from zero. The rows are also counted starting from zero. In this case, an entry x + i in the sequence may be mapped to an entry km + ((i + p) mod m). The above computation is linear in p. We may generalize this mapping such that the i'th element in first group j having mj elements is mapped to Tj ((i + pj ) mod mj ), in which Tj is a table, e.g., a look-up table. Here j runs over the number of groups. In an embodiment, one may take mj = m for all j . The number of groups may be equal to the number of rows, but this is not necessary. For example, one could take a default value, e.g. 0 for some parameters pj . The tables Tj may be rows, e.g., just add the first index of a row as above, but they may also map the first group to more complicated sets. In an embodiment, the Tj maps to irregular structures. An example would be an independent set of the rook graph of the matrix, (only for square matrices). In fact, the Tj may even form a Latin square design.
  • An alternative way to represent the selection is data is as a random seed. For example, deterministic pseudorandom number generator 160 maybe seeded with the random seed, and obtaining from the output of the deterministic pseudorandom number generator an indication of the multiple values in the sequence of values and/or of the multiple entries of the shared matrix. Any of the above ways to represent selection data maybe used together with a seed representation, as one can generate the selection data from the output of the random number generator. For example, in an embodiment, selection data may rotate, say, rows 1, 5, 13, 27 and 37 of the base matrix by an amount specified in the selection data. In this case, the selection data could directly contain the row or column indices and the rotation amounts, or the selection data could comprise a random seed. In the latter case, the rotation amount maybe taken from the output of random number generator 160.
  • Note that in all these example, the selection data may be received from second node 111, in which case node 110 constructs the shared matrix from the sequence of values in accordance with the selection data. Alternatively, the node 110 may generate selection data, e.g., randomly, e.g., from a seed, and next send the selection data, either as direct data or as the random seed to the second node.
  • Figure 3a schematically shows an example of an embodiment of a cryptographic system 300. System 300 comprises a server 310 and multiple clients. Shown are clients 320.1, 320.2 and 320.3. There maybe many more clients. For example, server 310 may be a computer that delivers digital services over a digital network to the clients. For example, server 310 may be a web shop. The clients may use a web browser to browse a website operated by server 310 and order from the web shop. Communication between the server and the clients may be encrypted and/or authenticated. For example, the server and the clients may execute a key exchange protocol. System 300 is organized to reduce overhead associated with computing many different shared matrices for server 310.
  • Server 310 may be organized as first network 110 shown in figure 1, except that base data memory 170 is arranged as a cache memory arranged to cache a sequence of values (A 1,A 2) together with a corresponding sequence identifier which identifies said cached sequence of values. Cache memory 170 may store multiple sequences of values with an associated sequence identifier. For example, there maybe two or more base matrices A 1,A 2, etc., but this is not necessary.
  • Base data manager 130 is arranged to obtain the sequence by receiving a sequence identifier from the second network node and to verify if a sequence of values corresponding to the received sequence identifier is cached in the cache memory and if such a sequence of values is not cached in the cache matrix, obtaining the sequence of values from the second network node. Obtaining the sequence may be done in any of the ways depicted above. In this embodiment, the second network node, e.g., a client may then be arranged to send a sequence identifier to the server corresponding to a sequence of values cached in the cache memory. In an embodiment, if a message is received from the second network node that no base matrix with that identifier is cached by the second network node, the network node maybe arranged to share the base matrix (A) with the second network node, e.g., by sending the matrix, or a seed to produce the matrix.
  • This arrangement reduces the load on server 310 somewhat, e.g., if communication is performed twice with the same node, or if many nodes use the same sequence of values. However, in an embodiment the roles are reversed and the base data manager 130 is arranged to a select a sequence identifier for the second network node corresponding to a sequence of values cached in cache memory 170. In this way, the overhead associated with generating the base matrix, e.g., from a random seed is largely avoided at server 310.
  • The selection data that is subsequently exchanged between server 310 and clients and 320 may then use the sequence of values identified by the sequence identifier to construct the shared matrix.
  • In an embodiment, the sequence identifier comprises a further random seed. A deterministic pseudorandom number generator is seeded with the further random seed. The sequence of values is obtained from the output of the seeded deterministic pseudorandom number generator. By including the further random seed in the sequence identifier, a party that does not have the sequence cached can compute when needed.
  • Some of these options are illustrated in Figure 3b which schematically shows an example of an embodiment of a detail of a cryptographic protocol executed between a server 310 and a client 320, e.g., one of the clients shown in figure 3a.
  • A first message 331 sent from client 320 to server 310 comprises a message request. It may comprise additional information such as an identifier for client 320. In response, server 310 sends a second message 332 to client 320. Second message 332 comprises a sequence identifier, e.g., comprising a further random seed. Server 310 has cached the corresponding sequence of values, e.g., after having computed it once from the further random seed. The sequence of values may be in the form of a base matrix. Message 332 may also comprise selection data, generated by server 310. The selection data in message 332 maybe in the form of a random seed, or not. Message 332 may also contain protocol information generated by server 310, which is possible since server 310 at this point has access to the shared matrix. For example, in a key exchange protocol as described above, message 332 could comprise a public key generated for this key exchange execution. After receiving message 332, client 320 may retrieve the sequence of values from its cache memory, or, if the sequence of values is not present in the cache memory, generate the sequence of values from the further random seed in the sequence identifier. Furthermore, client 320 may construct the shared matrix from the sequence of values and the selection data. Using the constructed shared matrix, client 320 may generate further values in the protocol, and return them with message 333. For example, if this is a key exchange protocol, then message 333 may contain a public key generated by client 320 from the shared matrix and a private key of client 320. Message 320 may also contain encrypted information, encrypted with a key derived from its own private key and the public key obtained in message 332. For example, the encrypted data may contain, say, a credit card number of a user of client 320. Server 310 when it receives the message 333 may use the public key and its own private key matrix to obtain the encryption key and decrypt the encrypted data, e.g., to obtain the credit card number.
  • Many variants are possible on the above protocol, for example, in a first variation, the selection data is not selected, or not only selected, by the server 310 and sent in message 320 but selected, or also selected, by client 320 and sent in message 333 to server 310. In the latter case, it is advantageous that the selection data in message 3333 directly determines a mapping between the sequence of values identified by the sequence identifier and the shared matrix, without using a random seed to generate it. For example, each node may specify a permutation of a base matrix. A particular one, say the initiating node of the protocol, may apply his permutation first followed by the permutation of the responding node.
  • In the various embodiments, the communication interface may be selected from various alternatives. For example, input interface maybe a network interface to a local or wide area network, e.g., the Internet, a storage interface to an internal or external data storage, etc.
  • Base data memory 170 may be implemented as an electronic memory, say a flash memory, or magnetic memory, say hard disk or the like. Base data memory 170 may comprise multiple discrete memories together making up base data memory 170. Base data memory 170 may also be a temporary memory, say a RAM. In the case of a temporary Base data memory 170, Base data memory 170 contains some means to obtain parameters before use, say by obtaining them over an optional network connection (not shown).
  • Typically, the device 110 and the 111 each comprise a microprocessor (not separately shown) which executes appropriate software stored at the device 110 and the 111; for example, that software may have been downloaded and/or stored in a corresponding memory, e.g., a volatile memory such as RAM or a non-volatile memory such as Flash (not separately shown). The devices 310 and 320.1-3 may also be equipped with microprocessors and memories (not separately shown). Alternatively, the devices 110 and the 111 may, in whole or in part, be implemented in programmable logic, e.g., as field-programmable gate array (FPGA). Devices 110 and the 111 may be implemented, in whole or in part, as a so-called application-specific integrated circuit (ASIC), i.e. an integrated circuit (IC) customized for their particular use. For example, the circuits may be implemented in CMOS, e.g., using a hardware description language such as Verilog, VHDL etc.
  • In an embodiment, first network node 110 comprises a communication interface circuit, a base data manager circuit, a matrix generation unit circuit, a cryptographic unit circuit, a matrix multiplication unit circuit, a pseudorandom number generator circuit, etc. The device 100 may comprise additional circuits, e.g., a cache circuit, etc. The circuits implement the corresponding units described herein. The circuits may be a processor circuit and storage circuit, the processor circuit executing instructions represented electronically in the storage circuits.
  • A processor circuit may be implemented in a distributed fashion, e.g., as multiple sub-processor circuits. A storage maybe distributed over multiple distributed sub-storages. Part or all of the memory may be an electronic memory, magnetic memory, etc. For example, the storage may have volatile and a non-volatile part. Part of the storage may be read-only. The circuits may also be, FPGA, ASIC or the like.
  • Below a number of additional embodiments are described that reduce bandwidth and computation requirements in key-exchange schemes and the like, that rely on large matrices. This is especially helpful for servers that have to deal with many connections as it may be used to reduce the computational effort at the server-side if that server will have to handle many connections. In an embodiment, it is proposed to:
    • Have a public static sequence of values P of length Lmn.
    • Exchange a seed between initiator and server to obtain a permutation r of {1, ..., L}. r is then used to obtain the public m × n matrix A used in the key exchange. The top row of A equals (P r 1 ,P r 2 , ..., Prn ), its second row equals P r n+1 ,P r n+2 ,...,P r 2n' ..., and its bottom row equals P r (m-1)n+1 ,P r (m-1)n+2 ,...,Prmn .
  • The performance is better since the elements in r are smaller than the elements in A and therefore can be computed faster and more efficiently. The sequence of values may be obtained in a number of ways. For example:
    • Embodiment 0: it may be a static parameter.
    • Embodiment 1: an initiator publishes seed value per day for all communications.
    • Embodiment 2: an initiator publishes matrix A per day for all communications.
    • Embodiment 3: an initiator publishes seed_long for a long period of time out of which seeds for shorter periods of time can be computed such as seed = PRF(seed_long|time).
  • In some settings, it makes more sense that the responder publishes the seed since it can often happen that the responder is a server handling many connections. This seed can also be computed by a trusted third party independent of server and client according to any of the above embodiments. The initiator and responder maybe taken as the first and second network node or vice versa. For example, the initiator may be network node that initiates the cryptographic protocol. However, other criteria may be used, for example, the initiator may be defined as the network node that uses key reconciliation data, while the responder generates key reconciliation data (key reconciliation data is data used to ensure that both parties arrive at the same share key).
  • Embodiment 4 describes a further embodiment that provides a good trade-off between memory and CPU.
    • Initiator or responder or a third party publishes a first seed used to compute a m × n matrix A 0. Initiator computes a second seed' and applies a pseudorandom function (PRF) to obtain a random permutation r of numbers [0, ..., mn-1].
    • Initiator sends seed' to responder.
    • Responder obtains r and rearranges the entries of A 0according to the permutation to obtain A.
    • Once initiator and responder have obtained A, the rest of the protocol follows as above.
  • Further extensions of embodiment 4:
    • Construct a public sequence P, e.g., the sequence of values or the base matrix, of length Lmn. Exchange a seed between initiator and server to obtain a permutation r of {1,..,L} r is then used to obtain the public m × n matrix A used in the key exchange. The top row of A equals (P r 1 ,P r 2 ,...,Prn ), its second row equals P r n+1 ,P r n+2 ,...,P r 2n ,.., and its bottom row equals P r (m-1)n+1' P r (m-1)n+2 ,...,Prmn .
    • It is not strictly required that r is a permutation. It is sufficient that for 1 ≤ imn, it holds that 1 ≤ ri L.
    • In an embodiment, a PRF is used to generate a sequence of bits, which then is transformed into a permutation.
      • For example, we may generate A bits, where 2 A L! We may interpret the A bits as an integer number and use the Lehmer code to determine the corresponding permutation. The Lehmer code is a mathematical algorithm to encode a permutation.
      • For large L, this may be cumbersome and a smaller set of permutations may be preferred from an implementation perspective. For example, take L = mn. The bit-sequence is partitioned into m blocks each of length B, and block i is considered as a label for a permutation for the entries (i - 1)n + 1, (i - 1)n + 2,... in of P. For example, if 2 B n, the permutation corresponding to a block is a cyclic shift over i positions for some i ∈ {0,1, ..., n - 1}. If 2 B n!, any permutation on n positions can be labelled with a B-bits label. The correspondence between labels and permutations can either be stored explicitly (for sufficiently small n), or can be computed using the Lehmer code.
    • In an embodiment, the permutation is such that it leaves many positions in its place. This reduces the amount of required re-arrangements, and allows that a relatively small number of bits from a PRF need to be generated. As a specific example, take L = mn. The set of numbers {1,2, ..., mn} is partitioned in m subsets of size n, for example, sets of the form {(i - 1)n, (i - 1)n + 1,...,in}. The first s┌log2 m┐ bits of the PRF are used to indicate s subsets in which a permutation will take place. The next s┌log2 n┐ bits are used to select over how many positions the entries in each of the s selected subsets will be shifted.
    • In an embodiment, the permutation is a sequence of s swaps (aka transpositions). The bit sequence is considered as a sequence (x 0, x1,...x 2s-1,) of integers of bit length log2(nm), and the permutation consists of the sequence of swaps (transpositions) of the entries of P in positions x 0,x 1, followed by swapping the entries of P in positions x 2,x 3,..., followed by swapping the entries of P in positions x 2s-2,x 2s-1.
  • There are various ways in which the public sequence P can be obtained. For example, the public sequence may, in one embodiment, be specified in an industry standard. In another embodiment, it is generated by a server S. A client C wishing to communicate with S receives P, or parameters, e.g. a seed, and a method to compute P from S. In this way, the server uses P for multiple sessions and clients, and need not re-compute it. In yet another embodiment P is generated and distributed by a trusted third party (TTP). A server may store P and use it for communication with multiple clients. The sequence P may only be valid during a time-period indicated by the TTP. In yet another embodiment, there are multiple TTPs each generated their own public sequence Pi . A server S stores all such matrices. A client C selects sequences from TTP that it actually trusts, combines them in some prespecified way, and applies a permutation on this combination. It sends to S the indices of the selected TTPs, and a seed so that S can retrieve said permutation. By combining matrices and permuting entries, S can find the matrix actually used by C.
  • The pseudo random function (PRF) can be defined as, e.g.:
    • PRF1: A recursive hash function whose output is divided into groups of ┌log n┐ bits. Each group will then be used to pick up a different element.
    • PRF2: PRF1 will have collisions since ┌log n┐ will be a relatively small number. An alternative is to keep track of the used numbers and discard those that already appeared.
    • PRF3: another alternative consists in gk (mod p) where p > ┌log n┐ where p is a prime number and g is a generator. k would be the seed and this PRF is iterated by increasing k (mod n).
  • The application of above embodiments, in particular Embodiment 4, to other schemes maybe as follows. For example, for the cryptographic lattice based protocol described in "Post-quantum key exchange - a new hope", by Erdem Alkim et al. One could modify their scheme as follows. Given a vector a and secrets s and e, then b is computed as b = (as + e)modulo(xn + 1). Generation of a in this case is cheaper since it only contains n elements, but it might still be expensive for the server if it has to compute many vectors out of an initial seed. An alternative is to have a static p (set of elements) and compute the random permutation vector r. In this way, the computation would be: b = (a[r]s + e)mod(xn + 1) where a[r] represents the permuted version of a according to r. Since r has smaller elements than a, it can be computed more cheaply than a.
  • In lattice-based public-key encryption schemes the public-key, e.g., LWE, the public key is given by a pair (b, A). Matrix A can take a considerable space for storage or alternatively, it may need to be generated dynamically. An alternative is to have a set of public values P. And have as public-key, (b,seed') so that seed' is used to obtain the permutation vector r that determines how the elements in P are mapped to matrix A used to obtain b as b=As+e. The advantage is that the storage needs at a server will be much lower and the computational needs also much lower.
  • Figure 4 schematically shows an example of an embodiment of a method for sharing a matrix 400. Method 400 is an electronic method for a first electronic network node configured for a cryptographic protocol based on a shared matrix, e.g., such as network node 110. The shared matrix having multiple entries each entry having a value. Method 400 comprises
    • establishing (410) digital communication between the first network node and a second network node (111),
    • obtaining (420) a sequence of values for the entries of the shared matrix, the sequence of values being shared with the second network node,
    • receiving (430) selection data from the second network node, or determining selection data and sending the selection data to the second network node, the selection data indicating multiple positions in the sequence of values and assigning to multiple entries of the shared matrix a value of the sequence of values indicated by the selection data,
    • constructing (440) the shared matrix (A) in accordance with the selection data, setting said multiple entries of the shared matrix to the multiple values assigned by the selection data, and
    • applying (450) the shared matrix in the cryptographic protocol.
  • Many different ways of executing the method are possible, as will be apparent to a person skilled in the art. For example, the order of the steps can be varied or some steps may be executed in parallel. Moreover, in between steps other method steps maybe inserted. The inserted steps may represent refinements of the method such as described herein, or may be unrelated to the method. Moreover, a given step may not have finished completely before a next step is started.
  • A method according to the invention may be executed using software, which comprises instructions for causing a processor system to perform method 400. Software may only include those steps taken by a particular sub-entity of the system. The software may be stored in a suitable storage medium, such as a hard disk, a floppy, a memory, an optical disc, etc. The software may be sent as a signal along a wire, or wireless, or using a data network, e.g., the Internet. The software maybe made available for download and/or for remote usage on a server. A method according to the invention may be executed using a bitstream arranged to configure programmable logic, e.g., a field-programmable gate array (FPGA), to perform the method.
  • It will be appreciated that the invention also extends to computer programs, particularly computer programs on or in a carrier, adapted for putting the invention into practice. The program maybe in the form of source code, object code, a code intermediate source, and object code such as partially compiled form, or in any other form suitable for use in the implementation of the method according to the invention. An embodiment relating to a computer program product comprises computer executable instructions corresponding to each of the processing steps of at least one of the methods set forth. These instructions may be subdivided into subroutines and/or be stored in one or more files that may be linked statically or dynamically. Another embodiment relating to a computer program product comprises computer executable instructions corresponding to each of the means of at least one of the systems and/or products set forth.
  • Figure 5a shows a computer readable medium 1000 having a writable part 1010 comprising a computer program 1020, the computer program 1020 comprising instructions for causing a processor system to perform a method of sharing a matrix, according to an embodiment. The computer program 1020 may be embodied on the computer readable medium 1000 as physical marks or by means of magnetization of the computer readable medium 1000. However, any other suitable embodiment is conceivable as well. Furthermore, it will be appreciated that, although the computer readable medium 1000 is shown here as an optical disc, the computer readable medium 1000 may be any suitable computer readable medium, such as a hard disk, solid state memory, flash memory, etc., and may be non-recordable or recordable. The computer program 1020 comprises instructions for causing a processor system to perform said method of sharing a matrix.
  • Figure 5b shows in a schematic representation of a processor system 1140 according to an embodiment. The processor system comprises one or more integrated circuits 1110. The architecture of the one or more integrated circuits 1110 is schematically shown in Figure 5b. Circuit 1110 comprises a processing unit 1120, e.g., a CPU, for running computer program components to execute a method according to an embodiment and/or implement its modules or units. Circuit 1110 comprises a memory 1122 for storing programming code, data, etc. Part of memory 1122 may be read-only. Circuit 1110 may comprise a communication element 1126, e.g., an antenna, connectors or both, and the like. Circuit 1110 may comprise a dedicated integrated circuit 1124 for performing part or all of the processing defined in the method. Processor 1120, memory 1122, dedicated IC 1124 and communication element 1126 may be connected to each other via an interconnect 1130, say a bus. The processor system 1110 maybe arranged for contact and/or contact-less communication, using an antenna and/or connectors, respectively.
  • For example, in an embodiment, the first network node may comprise a processor circuit and a memory circuit, the processor being arranged to execute software stored in the memory circuit. For example, the processor circuit may be an Intel Core i7 processor, ARM Cortex-R8, etc. In an embodiment, the processor circuit may be ARM Cortex M0. The memory circuit may be an ROM circuit, or a non-volatile memory, e.g., a flash memory. The memory circuit may be a volatile memory, e.g., an SRAM memory. In the latter case, the device may comprise a non-volatile software interface, e.g., a hard drive, a network interface, etc., arranged for providing the software.
  • It should be noted that the above-mentioned embodiments illustrate rather than limit the invention, and that those skilled in the art will be able to design many alternative embodiments.
  • In the claims, any reference signs placed between parentheses shall not be construed as limiting the claim. Use of the verb "comprise" and its conjugations does not exclude the presence of elements or steps other than those stated in a claim. The article "a" or "an" preceding an element does not exclude the presence of a plurality of such elements. The invention may be implemented by means of hardware comprising several distinct elements, and by means of a suitably programmed computer. In the device claim enumerating several means, several of these means may be embodied by one and the same item of hardware. The mere fact that certain measures are recited in mutually different dependent claims does not indicate that a combination of these measures cannot be used to advantage.
  • In the claims references in parentheses refer to reference signs in drawings of exemplifying embodiments or to formulas of embodiments, thus increasing the intelligibility of the claim. These references shall not be construed as limiting the claim.
  • List of Reference Numerals in figures 1-3b:
  • 100
    a cryptographic system
    110
    a first electronic network node
    111
    a second electronic network node
    120
    a communication interface
    130
    a base data manager
    140
    a matrix generation unit
    150
    a cryptographic unit
    152
    a matrix multiplication unit
    160
    a pseudorandom number generator
    170
    a base data memory
    210
    a sequence of values
    221,222
    a value
    230
    a shared matrix
    231, 232
    an entry in the shared matrix
    233
    selection data
    241, 242
    a first group
    251, 252
    a second group
    260
    a base matrix
    261-263
    a row
    300
    a cryptographic system
    310
    a server
    320,
    a client
    320.1-320.3 331-333
    a transmission

Claims (17)

  1. A first electronic network node (110) configured for a cryptographic protocol based on a shared matrix, the shared matrix having multiple entries each entry having a value, the first network node comprising
    - a communication interface (120) arranged for digital communication with a second network node (111),
    - a processor circuit configured to
    - obtain a sequence of values from which values for the shared matrix are selected, the sequence of values being shared with the second network node,
    - receive selection data from the second network node, or determining selection data and sending the selection data to the second network node, the selection data indicating multiple positions in the sequence of values and assigning to multiple entries of the shared matrix a value of the sequence of values indicated by the selection data,
    - construct the shared matrix (A) in accordance with the selection data and the sequence of values, setting said multiple entries of the shared matrix to the multiple values assigned by the selection data,
    - applying the shared matrix in the cryptographic protocol.
  2. A first network node (110) as in Claim 1, wherein the processor circuit is configured to select a predetermined first group of values in the sequence of values for a corresponding predetermined second group of entries of the shared matrix, the selection data indicating multiple positions in the first group for the entries in the second group, so that each entry in the second group is assigned a value from the first group, the second group having fewer entries than the shared matrix.
  3. A first network node (110) as in Claim 2, wherein a part of the selection data that indicates the multiple values in the first group for the entries in the second group has a bit size smaller than 1/100 of the total bit size of the values in the second group.
  4. A first network node (110) as in any one of the preceding claims, wherein the selection data comprises multiple parameters, the processor circuit is arranged to compute from a parameter in the selection data at least one entry in the sequence of values and at least one entry in the shared matrix, said computation being linear in the parameter, and assigning the value of said computed entry in the sequence of values to said entry in the shared matrix.
  5. A first network node (110) as in Claim 2,3 or 4, wherein the sequence of values forms a base matrix, the selection data indicating a cyclic permutation of at least one row and/or column of the base matrix by indicating a number of entries over which said row and/or column is rotated.
  6. A first network node (110) as in any one of the preceding claims, wherein the selection data comprises a random seed, the processor circuit being configured to
    - seed a deterministic pseudorandom number generator with the random seed, and obtaining from the output of the deterministic pseudorandom number generator an indication of the multiple values in the sequence of values and/or of the multiple entries of the shared matrix.
  7. A first network node (110) as in any one of the preceding claims, wherein the selection data comprises a permutation, the processor circuit being arranged to permute the sequence of values according to the permutation and assigning the permuted sequence of values to entries of the shared matrix according to a default assignment.
  8. A first network node (110) as in any one of the preceding claims, wherein the processor circuit is configured to compute a matrix product between the shared matrix (A) and a private vector or matrix (r; Sl ) of the first network node as part of the cryptographic protocol.
  9. A first network node (110) as in Claim 8, wherein the first and second network node are configured for a key exchange protocol, and the processor circuit is configured to
    - generate a private key matrix (Sl ),
    - generate a public key matrix (Pl ), said generating comprising at least
    - computing a matrix product between the shared matrix (A) and the private key matrix (Sl ) obtaining a matrix product
    - sending the public key matrix of the first network node to the second network node,
    - receiving a public key matrix (PR ) of the second network node,
    - computing a raw key as a matrix product between the received public key of the second node and the private key matrix of the first network node, wherein the first network node is further configured to compute a shared key from at least the raw key.
  10. A first network node (110) as in Claim 8, wherein the first and second network node are configured for a public-key encryption protocol, the processor circuit is configured to
    - obtain a public key of a second network node, said public key comprising the selection data, and a further public key matrix (B), the further public key matrix having been previously obtained from the shared matrix and a private key matrix (S)
    - choose a random vector r, and compute two matrix products (e.g., a' = ATr, b' = BTr) between the random vector (r) and the shared matrix and between the random vector (r) and the further public key matrix,
    - compute an encrypted message from a plain message by adding a blinding vector computed from a first one of the two matrix products, the encrypted message further including decryption information computed from the second one of the two matrix products.
  11. A first network node (110) as in any one of the preceding claims, comprising
    - a cache memory arranged to cache a sequence of values (A 1,A 2) together with a corresponding sequence identifier which identifies said cached sequence of values, wherein
    - the processor circuit is configured to
    - receive a sequence identifier from the second network node and verify if a sequence of values corresponding to the received sequence identifier is cached in the cache memory and if such a sequence of values is not cached in the cache matrix, obtaining the sequence of values from the second network node, and/or sending a sequence identifier to the second network node corresponding to a sequence of values cached in the cache memory,
    - using the sequence of values identified by the sequence identifier to construct the shared matrix.
  12. A first network node (110) as in Claim 11, wherein the sequence identifier comprises a further random seed, obtaining or sharing the sequence of values comprises seeding a deterministic pseudorandom number generator with the further random seed, and deriving the sequence of values from the output of the seeded deterministic pseudorandom number generator.
  13. A first network node as in any one of the preceding claims, wherein the sequence of values is obtained from a trusted third party.
  14. A first network node as in any one of the preceding claims, wherein the number of different shared matrices obtainable from a single sequence of values using different selection data is at least 264.
  15. A first network node arranged to accept encrypted network connections from multiple second network nodes, the first network node being arranged to accept a connection request from a second node by sending a response message, said response message comprising a random seed, said random seed indicating a sequence of values stored in a cache memory of the first network node, the second network node sending selection data to the first network node.
  16. An electronic method (400) for a first electronic network node (110) configured for a cryptographic protocol based on a shared matrix, the shared matrix having multiple entries each entry having a value, the method comprising
    - establishing (410) digital communication between the first network node and a second network node (111),
    - obtaining (420) a sequence of values from which values for the shared matrix are selected, the sequence of values being shared with the second network node,
    - receiving (430) selection data from the second network node, or determining selection data and sending the selection data to the second network node, the selection data indicating multiple positions in the sequence of values and assigning to multiple entries of the shared matrix a value of the sequence of values indicated by the selection data,
    - constructing (440) the shared matrix (A) in accordance with the selection data, setting said multiple entries of the shared matrix to the multiple values assigned by the selection data, and
    - applying (450) the shared matrix in the cryptographic protocol.
  17. A computer readable medium (1000) comprising transitory or non-transitory data (1020) representing instructions to cause a processor system to perform the method according to claim 16.
EP17159296.7A 2017-03-06 2017-03-06 Device and method for sharing a matrix for use in a cryptographic protocol Withdrawn EP3373505A1 (en)

Priority Applications (7)

Application Number Priority Date Filing Date Title
EP17159296.7A EP3373505A1 (en) 2017-03-06 2017-03-06 Device and method for sharing a matrix for use in a cryptographic protocol
CN201880029798.9A CN110603782B (en) 2017-03-06 2018-02-27 Apparatus and method for sharing matrix used in cryptographic protocol
EP18706753.3A EP3593485B1 (en) 2017-03-06 2018-02-27 Device and method for sharing a matrix for use in a cryptographic protocol
PCT/EP2018/054731 WO2018162272A1 (en) 2017-03-06 2018-02-27 Device and method sharing a matrix for use in a cryptographic protocol
JP2019548404A JP7159183B2 (en) 2017-03-06 2018-02-27 Device and method for sharing matrices for use in cryptographic protocols
US16/490,931 US11212098B2 (en) 2017-03-06 2018-02-27 Device and method sharing a matrix for use in a cryptographic protocol
RU2019131369A RU2765238C2 (en) 2017-03-06 2018-02-27 Apparatus and method for shared use of a matrix for use in a cryptographic protocol

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
EP17159296.7A EP3373505A1 (en) 2017-03-06 2017-03-06 Device and method for sharing a matrix for use in a cryptographic protocol

Publications (1)

Publication Number Publication Date
EP3373505A1 true EP3373505A1 (en) 2018-09-12

Family

ID=58231495

Family Applications (2)

Application Number Title Priority Date Filing Date
EP17159296.7A Withdrawn EP3373505A1 (en) 2017-03-06 2017-03-06 Device and method for sharing a matrix for use in a cryptographic protocol
EP18706753.3A Active EP3593485B1 (en) 2017-03-06 2018-02-27 Device and method for sharing a matrix for use in a cryptographic protocol

Family Applications After (1)

Application Number Title Priority Date Filing Date
EP18706753.3A Active EP3593485B1 (en) 2017-03-06 2018-02-27 Device and method for sharing a matrix for use in a cryptographic protocol

Country Status (6)

Country Link
US (1) US11212098B2 (en)
EP (2) EP3373505A1 (en)
JP (1) JP7159183B2 (en)
CN (1) CN110603782B (en)
RU (1) RU2765238C2 (en)
WO (1) WO2018162272A1 (en)

Cited By (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20200259649A1 (en) * 2017-10-17 2020-08-13 Koninklijke Philips N.V. Configurable device for lattice-based cryptography
WO2020173061A1 (en) * 2019-02-26 2020-09-03 清华大学 Error sampling method for lattice-based public key cryptography
CN111970107A (en) * 2019-05-20 2020-11-20 诺基亚技术有限公司 Shared secret generation
DE102020112102B3 (en) * 2020-05-05 2021-05-20 Infineon Technologies Ag Method and apparatus for generating a symmetrical session key for encrypted communication
WO2021138719A1 (en) * 2020-01-10 2021-07-15 Mesinja Pty Ltd Systems and computer-implemented methods for generating pseudo random numbers
US11212099B2 (en) 2017-10-17 2021-12-28 Koninklijke Philips N.V. Cryptographic device with updatable shared matrix
US11240014B1 (en) 2019-09-10 2022-02-01 Wells Fargo Bank, N.A. Systems and methods for post-quantum cryptography optimization
US11322050B1 (en) 2020-01-30 2022-05-03 Wells Fargo Bank, N.A. Systems and methods for post-quantum cryptography optimization
US11343270B1 (en) 2019-09-10 2022-05-24 Wells Fargo Bank, N.A. Systems and methods for post-quantum cryptography optimization
US11449799B1 (en) 2020-01-30 2022-09-20 Wells Fargo Bank, N.A. Systems and methods for post-quantum cryptography optimization
US11477016B1 (en) 2019-09-10 2022-10-18 Wells Fargo Bank, N.A. Systems and methods for post-quantum cryptography optimization
US11533175B1 (en) 2020-01-30 2022-12-20 Wells Fargo Bank, N.A. Systems and methods for post-quantum cryptography on a smartcard
US11626983B1 (en) 2019-09-10 2023-04-11 Wells Fargo Bank, N.A. Systems and methods for post-quantum cryptography optimization
US11838410B1 (en) 2020-01-30 2023-12-05 Wells Fargo Bank, N.A. Systems and methods for post-quantum cryptography optimization

Families Citing this family (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN115105019B (en) 2017-02-03 2024-05-28 布鲁恩生物有限责任公司 Measurement of edema
US11943348B1 (en) * 2019-12-11 2024-03-26 Q-Net Security, Inc. Method and system for secure cryptographic exchanges using a five-pass protocol
CN111464289B (en) * 2020-01-13 2021-07-27 华中科技大学 Method, equipment and system for realizing post-quantum key exchange protocol
EP4095828A4 (en) * 2020-01-20 2023-10-18 Nippon Telegraph And Telephone Corporation Secure exponential function computation system, secure exponential function computation method, secure computation device, and program
WO2021258109A1 (en) * 2020-06-17 2021-12-23 The Regents Of The University Of California Extra-compact key with reusable common key for encryption
US11294929B1 (en) 2021-06-09 2022-04-05 Aeec Smart water data analytics
CN114095170B (en) * 2022-01-20 2022-05-27 北京信安世纪科技股份有限公司 Data processing method, device, system and computer readable storage medium
US12101401B2 (en) 2022-07-28 2024-09-24 Brax Kinsey Digital forge systems and methods
CN115134475B (en) * 2022-08-31 2022-11-08 智联信通科技股份有限公司 Weighing apparatus weight discrimination intelligent management system
CN118400102A (en) * 2024-04-16 2024-07-26 中国人民解放军国防科技大学 Dynamic unmanned aerial vehicle group identity authentication key negotiation method

Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20120166809A1 (en) * 2010-12-28 2012-06-28 Authernative, Inc. System and method for cryptographic key exchange using matrices

Family Cites Families (21)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2001211153A (en) * 2000-01-25 2001-08-03 Murata Mach Ltd Secret key generating method
JP2002217884A (en) * 2001-01-19 2002-08-02 Murata Mach Ltd Method/equipment for cipher communication, decoder and recording medium
US7184551B2 (en) * 2002-09-30 2007-02-27 Micron Technology, Inc. Public key cryptography using matrices
US20040258240A1 (en) * 2003-05-02 2004-12-23 Singh Mukesh K. Cryptosystems
US7073067B2 (en) * 2003-05-07 2006-07-04 Authernative, Inc. Authentication system and method based upon random partial digitized path recognition
JP4724835B2 (en) * 2005-02-28 2011-07-13 国立大学法人広島大学 Authentication device
US8098815B2 (en) * 2006-10-11 2012-01-17 Frank Rubin Device, system and method for cryptographic key exchange
US8090097B2 (en) * 2006-10-11 2012-01-03 Frank Rubin Device, system and method for cryptographic key exchange
US8837724B2 (en) * 2007-03-27 2014-09-16 Qualcomm Incorporated Synchronization test for device authentication
KR100966071B1 (en) * 2007-12-18 2010-06-28 한국전자통신연구원 Method for multi-party-key agreement using bilinear map and system therefor
WO2010032158A2 (en) * 2008-09-17 2010-03-25 Philips Intellectual Property & Standards Gmbh A method for communicating in a network, a communication device and a system therefor
JP5143049B2 (en) * 2009-02-13 2013-02-13 三菱電機株式会社 Encoded communication method and encoded communication apparatus
SE534384C2 (en) * 2009-07-03 2011-08-02 Kelisec Ab Method of generating an encryption / decryption key
EP2348725A1 (en) * 2010-01-26 2011-07-27 Irdeto Access B.V. Computational efficiently obtaining a control word in a receiver using transformations
CN102164367B (en) * 2011-04-14 2014-04-16 北京理工大学 Key management method used for wireless sensor network
US9230103B2 (en) * 2011-10-03 2016-01-05 Zoosk, Inc. System and method for registering users for communicating information on a web site
CN102412971B (en) * 2011-11-30 2015-04-29 西安西电捷通无线网络通信股份有限公司 SM2 key exchange protocol based key agreement method and device
USRE48643E1 (en) * 2012-04-12 2021-07-13 Jintai Ding Cryptographic system using pairing with errors
US9215072B1 (en) * 2012-10-23 2015-12-15 Authernative, Inc. Back-end matching method supporting front-end knowledge-based probabilistic authentication systems for enhanced credential security
JP6169028B2 (en) * 2014-03-18 2017-07-26 株式会社東芝 COMMUNICATION DEVICE, COMMUNICATION SYSTEM, AND COMMUNICATION METHOD
US9948460B2 (en) * 2015-08-28 2018-04-17 City University Of Hong Kong Multivariate cryptography based on clipped hopfield neural network

Patent Citations (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20120166809A1 (en) * 2010-12-28 2012-06-28 Authernative, Inc. System and method for cryptographic key exchange using matrices

Non-Patent Citations (4)

* Cited by examiner, † Cited by third party
Title
J. BOS; C. COSTELLO; L. DUCAS; I. MIRONOV; M. NAEHRIG; V. NIKOLAENKO; A. RAGHUNATHAN; D. STEBILA, FRODO: TAKE OFF THE RING! PRACTICAL, QUANTUM-SECURE KEY EXCHANGE FROM LWE
J. H. CHEON; D. KIM; J. LEE; Y. SONG, LIZARD: CUT OFF THE TAIL! PRACTICAL POST-QUANTUM PUBLIC-KEY ENCRYPTION FROM LWE AND LWR
NICOLAS SENDRIER: "Code-based One Way Functions", ECRYPT SUMMER SCHOOL EMERGING TOPICS IN CRYPTOGRAPHIC DESIGN AND CRYPTANALYSIS, 3 May 2007 (2007-05-03), XP055403927, Retrieved from the Internet <URL:http://ecrypt-ss07.rhul.ac.uk/Slides/Thursday/sendrier-samos07.pdf> [retrieved on 20170905] *
OLIVIER BILLET ET AL: "Efficient Traitor Tracing from Collusion Secure Codes", 10 August 2008, INFORMATION THEORETIC SECURITY; [LECTURE NOTES IN COMPUTER SCIENCE], SPRINGER BERLIN HEIDELBERG, BERLIN, HEIDELBERG, PAGE(S) 171 - 182, ISBN: 978-3-540-85092-2, XP019102288 *

Cited By (24)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20200259649A1 (en) * 2017-10-17 2020-08-13 Koninklijke Philips N.V. Configurable device for lattice-based cryptography
US11991285B2 (en) 2017-10-17 2024-05-21 Koninklijke Philips N.V. Configurable cryptographic device
US11569993B2 (en) * 2017-10-17 2023-01-31 Koninklijke Philips N.V. Configurable device for lattice-based cryptography
US11212099B2 (en) 2017-10-17 2021-12-28 Koninklijke Philips N.V. Cryptographic device with updatable shared matrix
WO2020173061A1 (en) * 2019-02-26 2020-09-03 清华大学 Error sampling method for lattice-based public key cryptography
CN111970107A (en) * 2019-05-20 2020-11-20 诺基亚技术有限公司 Shared secret generation
US11240014B1 (en) 2019-09-10 2022-02-01 Wells Fargo Bank, N.A. Systems and methods for post-quantum cryptography optimization
US11736281B1 (en) 2019-09-10 2023-08-22 Wells Fargo Bank, N.A. Systems and methods for post-quantum cryptography optimization
US11343270B1 (en) 2019-09-10 2022-05-24 Wells Fargo Bank, N.A. Systems and methods for post-quantum cryptography optimization
US11902431B1 (en) 2019-09-10 2024-02-13 Wells Fargo Bank, N.A. Systems and methods for post-quantum cryptography optimization
US11477016B1 (en) 2019-09-10 2022-10-18 Wells Fargo Bank, N.A. Systems and methods for post-quantum cryptography optimization
US11750378B1 (en) 2019-09-10 2023-09-05 Wells Fargo Bank, N.A. Systems and methods for post-quantum cryptography optimization
US11626983B1 (en) 2019-09-10 2023-04-11 Wells Fargo Bank, N.A. Systems and methods for post-quantum cryptography optimization
WO2021138719A1 (en) * 2020-01-10 2021-07-15 Mesinja Pty Ltd Systems and computer-implemented methods for generating pseudo random numbers
US11727829B1 (en) 2020-01-30 2023-08-15 Wells Fargo Bank, N.A. Systems and methods for post-quantum cryptography optimization
US11322050B1 (en) 2020-01-30 2022-05-03 Wells Fargo Bank, N.A. Systems and methods for post-quantum cryptography optimization
US11727310B1 (en) 2020-01-30 2023-08-15 Wells Fargo Bank, N.A. Systems and methods for post-quantum cryptography optimization
US11533175B1 (en) 2020-01-30 2022-12-20 Wells Fargo Bank, N.A. Systems and methods for post-quantum cryptography on a smartcard
US11838410B1 (en) 2020-01-30 2023-12-05 Wells Fargo Bank, N.A. Systems and methods for post-quantum cryptography optimization
US11449799B1 (en) 2020-01-30 2022-09-20 Wells Fargo Bank, N.A. Systems and methods for post-quantum cryptography optimization
US12073300B2 (en) 2020-01-30 2024-08-27 Wells Fargo Bank, N.A. Systems and methods for post-quantum cryptography optimization
US12074967B2 (en) 2020-01-30 2024-08-27 Wells Fargo Bank, N.A. Systems and methods for post-quantum cryptography optimization
US11882101B2 (en) 2020-05-05 2024-01-23 Infineon Technologies Ag Methods and devices for generating a symmetric session key for encrypted communication
DE102020112102B3 (en) * 2020-05-05 2021-05-20 Infineon Technologies Ag Method and apparatus for generating a symmetrical session key for encrypted communication

Also Published As

Publication number Publication date
EP3593485B1 (en) 2021-04-07
JP2020511832A (en) 2020-04-16
CN110603782A (en) 2019-12-20
JP7159183B2 (en) 2022-10-24
RU2019131369A (en) 2021-04-07
RU2019131369A3 (en) 2021-08-06
WO2018162272A1 (en) 2018-09-13
US20190386828A1 (en) 2019-12-19
CN110603782B (en) 2022-12-27
RU2765238C2 (en) 2022-01-27
US11212098B2 (en) 2021-12-28
EP3593485A1 (en) 2020-01-15

Similar Documents

Publication Publication Date Title
EP3593485B1 (en) Device and method for sharing a matrix for use in a cryptographic protocol
CN109347627B (en) Data encryption and decryption method and device, computer equipment and storage medium
JP6849860B2 (en) A configurable device for lattice-based cryptography
US20230336346A1 (en) Elliptic curve isogeny based key agreement protocol
JP7208987B2 (en) Cryptographic unit with updatable shared matrix
US20230096233A1 (en) Chosen-plaintext secure cryptosystem and authentication
US11909877B2 (en) Public/private key system with decreased public key size
US20160156470A1 (en) System for sharing a cryptographic key
EP3231126A1 (en) Public-key encryption system
CN110493201B (en) Data processing method, device and system
CN114172651B (en) SM9 public key encryption algorithm and decryption algorithm GPU acceleration implementation method
Guo et al. Order‐Revealing Encryption Scheme with Comparison Token for Cloud Computing
CN117134906A (en) Multiparty privacy exchange method and related device
US11228589B2 (en) System and method for efficient and secure communications between devices
CN116074090A (en) Multi-user sequential revealing encryption method and system based on OPRF
CN116011031A (en) Information processing method, device, server and storage medium
JP2002108206A (en) Public key cryptosystem and cipher communication method using the same and storage medium

Legal Events

Date Code Title Description
PUAI Public reference made under article 153(3) epc to a published international application that has entered the european phase

Free format text: ORIGINAL CODE: 0009012

AK Designated contracting states

Kind code of ref document: A1

Designated state(s): AL AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HR HU IE IS IT LI LT LU LV MC MK MT NL NO PL PT RO RS SE SI SK SM TR

AX Request for extension of the european patent

Extension state: BA ME

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: THE APPLICATION IS DEEMED TO BE WITHDRAWN

18D Application deemed to be withdrawn

Effective date: 20190313