This application is the national phase entry of International Application No. PCT/TR2016/050441, filed on Nov. 14, 2016, the entire contents of which are incorporated herein by reference.
The invention is related with encryption method, which reduces the amount of required encryption operations.
The invention is particularly related with an encryption method, which claim the security by using the hardness of the unique decodability of the variable-length non-prefix-free (NPF) codes.
In terms of computational load, the encryption operations are heavy duties occupying significant CPU time, and thus, they are serious power consumers. Reducing this load is especially important in battery-constrained computational environments with limited processing capacities such as the sensor networks, unmanned aerial vehicles, mobile video transmission, and etc.
When data volume is huge such as the case in video transmission, encryption of the whole data introduces a heavy computational load, and also a serious power consumption in parallel. Thus, methods to reduce this load have attained significant attention. There are some developments present in the known state of the art that aim to reduce the amount of encryption operations while securing data. The main approach in those studies is selective (or partial) encryption of the data. In selective encryption some selected parts that are assumed to be important information content of the data are encrypted, and the rest of the data is transmitted/stored in plain format.
The daily practice in securing data is to first compress the data and then encrypt it with an encryption scheme that is assumed to be secure. In that sense perform the compression and encryption steps together has also been considered. However, notice that, in that approach the number of encryption operations are not reduced, but the main point is to achieve the compression and encryption in a single step to gain from elapsed time. We provide some of the exemplary patents regarding to both combined compression and encryption as well as the partial (selective) encryption.
For example in the US2016124983A1 patent document which can be given as an example to these developments, secure compression algorithms are provided that may be employed as a single operation on raw data to produce compressed and encrypted data. In embodiments, the algorithms described herein may be performed using any type of dictionary based encryption. In one embodiment, upon adding a new prefix to a dictionary table, the dictionary table may be permuted to randomize the entries into the table. The randomization may be based upon a permutation value generated by a deterministic pseudo-random generator and/or pseudo-random function. Other embodiments of randomization may be employed to provide secure compression.
In the paper titled “A simple storage scheme for strings achieving entropy bounds” (FERRAGINA et all, Theoretical Computer SCI, Amsterdam, Vol. 372) a non prefix free code where the sequence of code words is separated from the information of the starting position of each code words is disclosed.
In the American Patent document numbered US20120134496 a method of partial encryption wherein a server receiving a sequence of image frames comprises the image frames into blocks of variable size and parameters representing inter frames including block sizes, is disclosed.
In the American Patent document numbered US2007083467A1 within the known state of the art, the invention pertains to improved techniques to partially encrypt media files. The encryption serves to cryptographically secure only a portion of the media data within a media file, while the remaining portion of the media data is not cryptographically secured. Although only partial encryption is used, the portion being encrypted serves to substantially disrupt usefulness of other parts of the media file which are not encrypted. In other words, the partial encryption renders the media file substantially unusable by unauthorized users.
In the American Patent document numbered US2007110225A1 within the known state of the art, methods and devices are provided for accelerating the throughput and or reducing the power consumption of symmetric cryptography algorithms. Certain computations of a symmetric encryption or decryption algorithm are performed during a first phase, the results are saved to memory, and the results are retrieved to encode data during a second phase. If the first phase is implemented while the battery is being charged and the second phase is implemented while the system runs on battery power, the battery life is significantly extended compared to the battery life when all phases are implemented using solely battery power.
In the American Patent document numbered US2004193871A1 within the known state of the art, particular portions of a message receive strong encryption while other parts of the message are less strongly encrypted or even unencrypted, resulting in a differentially encrypted data set. The data set is transmitted to a receiving end where it may be decrypted as desired. Receiving stations requiring the encrypted information and having authorized access may decrypt it, while other stations may decrypt this information only partially or not at all. Required computational power is reduced both on the client side and in channel processing because only selected portions of the message are subject to strong encryption and decryption processing, and latency and problems associated with latency are reduced.
In the American Patent document numbered US2007263876A1 within the known state of the art, methods and devices related to compression and encryption of data. Data to be encrypted and compressed is first received and then stored in physical memory. Once stored in a data structure in physical memory, the data is streamed to a process which compresses the data. The compressed data is then streamed, from the physical memory, to an encryption process. The compressed and encrypted data can then be transmitted. To decrypt and decompress, the compressed and encrypted data is first read into another data structure that stores the data into physical memory. The data is then streamed from the physical memory to, in turn, a decryption process and then a decompression process.
There are lots of patents based on selective (partial) encryption especially targeting the multimedia data transmission and storage also, such as US20050141713A1 Selective multimedia data encryption (SCM microsystems), US US20080065903A1 Selective encryption of data stored on removable media in an automated data storage library (IBM), U.S. Pat. No. 7,039,938B2 Selective Encryption for video-on-demand, U.S. Pat. No. 5,805,700A Policy based selective encryption of compressed video data (Intel), and many more.
It had been previously shown that symetric security algorithms roughly doubles the energy consumption of normal operation in those environments, and asymetric security algorithms increase the energy usage per bit in orders of magnitudes. Providing the data security in such platforms is becoming more and more important considering their wide-spread in the fast approaching era of the internet of things (IoT), where privacy will be a necessity rather than a preference.
As it can be understood from the similar mentioned documents above different methods are being used in order to develop an encryption method to be applied on compressed data. The difference of the proposed study from selective (partial) encryption is that the proposed invention provides the security of the full data, where in selective encryption only the selected sections of the data are secured. The reduction in the amount of encryption improves on larger files with the proposed technique, where around 10 percent encryption of the data becomes sufficient. In selective encryption the ratio is fixed regardless of the size of the data. When compared to combined encryption/compression schemes, those schemes do not aim to reduce the encryption operations but to reduce the time required for the total operations, and thus, not very much related with the aim of this invention.
The aim of this invention is to provide a method for data encryption which reduces the amount of required encryption operations.
The data encryption method provided in order to reach the aims of the invention comprises the code-word boundaries which is absolutely necessary for correct decoding.
In the proposed data encryption method, process is applied on randomly distributed input data, which is obtained by applying a compression algorithm on the input data when the data itself is not assumed to be independent and identically distributed. When the data itself reflects a random distribution, then the compression step can be skipped and the proposed method can directly be applied on the input data. From now on, we will refer to the compressed input data or the input data that is already i.i.d without compression as IID data and the proposed NPF coding scheme will be applied on that IID data.
The proposed invention makes it possible to secure the IID data with up to 90% less encryption. The gain in the encryption amount with the proposed technique is based on a parameter d, that specifies the block-size in bits, which is selected according to the size of the compressed data. The block-size parameter d is selected such that n≥d.2d, where n is the number of bits in the IID data. Thus, larger the n value, it becomes feasible to select larger d values. With larger d values the code-word boundary information becomes smaller in volume, and since we are only encrypting it for the security, the gain in encryption improves.
The data encryption method that is provided in order to reach the aims of the invention has been illustrated in the attached figures. According to the figures;
The parts in the figures have been numbered as follows;
The proposed technique processes the n bits long IID data (4) in d-bits long blocks, and replaces every d-bits long block by its corresponding variable-length non-prefix-free code-word generated according to the introduced new coding scheme. The IID data (4) is obtained from input data (1) by compressing (2) it. When input data (1) can be assumed to be independently and identically distributed, the IID data (4) is directly the input data (1) itself omitting the compression (2) step.
A typical block length parameter d is selected such that n≥d.2d. The IID data (4) is encoded with the introduced method of variable-length non-prefix-free coding scheme (NPF) (5). The NPF encoding (5) step creates two streams of data. The first stream of is the code-word stream (7), where each fixed d-bits long block of the IID data (4) is NPF encoded (5) with a code-word of varying bit-length. The second stream is the code-word boundary information (6) that specifies the lengths of each code-word in the code-word stream (7).
The NPF code-words set is generated without the prefix-free restriction so that a code-word may be a prefix of another. Thus, non-prefix-free (NPF) code words stream (7) is ambiguous and cannot be decoded without the knowledge of the code-word boundaries information (6). The lack of unique decodability without the code-word boundaries information (6) in NPF encoding (5) provides a unique opportunity in terms of security. Therefore, encrypting (8) the code-word boundary information (6) with an appropriate encryption algorithm is sufficient to provide the security of the input data (1).
The code-words stream (7) is kept intact as it cannot be decoded without the code-word boundary information (6), that is already encrypted (8).
Generally, the security of a system depends on the hardness of solving a mathematical question such as the discrete logarithm or the factorization problems. In this invention it is made use of the hardness of decoding a sequence NPF encoded (5) with variable-length non-prefix-free codes in case the knowledge of the code-word boundaries information (6) is missing. The hardness of cipher-text only attacks on non-prefix-free codes and even on prefix codes had been previously studied in the literature (CITATIONs from the paper).
To examine in detail, A=a1a2 . . . an is an independently and identically distributed (i.i.d) random bit sequence (4), and d>1 is an integer indicating a bit block length. Without loss of generality, it is assumed n is divisible by d as it is always possible to pad the A with necessary number of randomly generated bits if this is not the case.
The number of d-bits long blocks in A is r=n/d and A can be represented as B=b1 b2 . . . br, where each d-bits long bi in B, for 1≤I≤r, is drawn from the alphabet Σ={0, 1, 2, . . . 2d−−1}. For instance, when d=3, the alphabet becomes Σ={000,001,010,011,100,101,110,111}, and |Σ|=2d=8. Since A has been assumed to be an i.i.d random bit sequence, B can also be assumed i.i.d. over Σ for reasonable d values selected according to the size of A.
Definition 1.
The minimum binary representation (MBR) of an integer i≥2 is its binary representation without the leftmost 1 bit.
As an example, the minimum binary representation of 21 is MBR (21)=0101 by omitting the leftmost set bit in its binary representation as 21=(10101)2.
Definition 2.
Let Σ″={ϵ1, ϵ2, . . . , ϵz} for z=2d be a random permutation of the alphabet Σ={0, 1, 2, . . . , 2d−1}, and W={w1, w2, wz} is a code-word set such that
Assuming an input sequence B=b1 b2 . . . br, where 0≤bi≥2d d for all 1≤i≤r, the non-prefix-free encoding (4) of B is denoted by N P F (B)=w1+b
The NPF encoding (4) of a sample sequence according to the Definitions 1 and 2 with the parameter d=3 is shown in Scheme 2. The code-words w1 and w5 are sets due to the corresponding values of ϵi=6=23−2 and ϵ5=7=23−1. Thus, when bi=4 or bi=0, a randomly selected code-word respectively from sets w5 or w1, is inserted into the NPF (B) stream. At a first glance, using multiple code-words as an exception for the two ϵi≥2d−2 values might seem a bit strange. The reason for that is to avoid a possible statistical attack.
Proposition 1.
In a code-word set W that is generated for a block length d>1 according to Definition 2, the bit-lengths of the code-words are in {1, 2, . . . , d}. The number of l-bits long code-words for each l∈{1, 2, . . . , d−1} is 2l, and there exist 2 sets of code-words for l=d each of which includes 2d−1 code-words.
=
Scheme. 2.
A simple sketch of the non-prefix-free encoding (4) of an input data (1) bit sequence. A is the input data (1), where B is the representation of A by assuming the block length d=3. Σ′ is a randomly selected permutation of the corresponding alphabet Σ, and W is the non-prefix-free code-word set generated for Σ′ according to Definition 2.
Proof.
According to Definition 2, the entities in W are minimum binary representations of numbers {2, 3, . . . , 2d+1−1}. Since the MBR bit-lengths of those numbers range from 1 to d, there are d distinct code-word lengths in W. Each code-word length l∈{1, 2, . . . , d−1} defines 2l distinct code-words, and thus, total number of code-words defined by all possible l values becomes
Σi=1d−12i=2d−2
The remaining 2 code-words out of the |W|=2d items require d-bits long bit sequences. For example, when d=3, the |W| includes 2(=21) code-words of 1-bit long, 4(=22) code-words of length 2, and 2(=23−6) code-word sets of length 3-bits as shown in Scheme 2.
Lemma 1.
Assuming B=b1 b2 . . . br denotes an input sequence, where d-bits long bi values for 1≤i≤r and d>1 are independent and identically distributed over {0, 1, 2, . . . , 2d−1}, the total bit length of the non-prefix-free code-words encoding the B sequence is
Proof.
Since B is i.i.d., each value from set {0, 1, 2, . . . , 2d−1} appears r/(2d) times in B. As stated in Proposition 1, the code-word lengths for NPF encoding (4) in W vary from 1 to d such that there are 2l code-words for each l∈{1, 2, . . . , d−1}, and l=d bits long code-words are included in 2 separately maintained sets. The number of bi values that are represented by each l∈{1, 2, . . . , d−1} bits in NPF(B) is (2l.(r/(2d)) and thus their contribution to |NPF(B)| is (l.2l.(r/(2d)) bits. Since there are 2 code-word set options for length l=d, they produce (d.2.(r/(2d)) bits in NPF (B). Summing these up gives the total length of the NPF code-stream as:
While computing the summation term in
it is used the formula from basic algebra that
Σi=1pi.2i=2p+1(p−1)+2
and substitute p=d−1.
However, since non-prefix-free codes are not uniquely decodable, NPF (B) cannot be converted back to the original B sequence in absence of the code-word boundaries information (6) on NPF (B). Thus, it is rigidly necessary that representing the code-word boundaries information (6) positions on NPF (B) for proper decoding. Lemma 2 states an efficient method to achieve this task.
Lemma 2.
Let B=b1 b2 . . . br denotes an input sequence such that the bi values are i.i.d. over {0, 1, 2, . . . , 2d−1}. The number of bits required to represent the code-word boundaries information (6) in the NPF (B) is
Proof.
There exists 2l code-words for each code-word length l∈{1, 2, . . . , d−1}, and each code-word is substituted in place of r/2d items in B=b1 b2 . . . br during the NPF encoding (5) of the B. For l=d−1, the number of code-words with that length is
and similarly, when l=d−2, there appears
code-words having length d−2. As a generalization, for l=d−2 where i={1, 2, . . . , d−1}, there are
code-words with length l on NPF (B). It is maintained (d−1) bitmaps denoted by D1, D2, Dd-1 such that Di is dedicated to the specific code-word length l=d−i for i=1 to i=d−1. The bit sequence Di is of
bits long, in which the positions that correspond to (d−i)-bits long code-words are marked with 1, and rest to 0.
For instance, on the first level bitmap D1 the positions of code-words with length l=d−1 are specified by 1, and rest with 0. D1 contains r bits, and the number of zero and one bits are equal since there are
items whose NPF code length is l=d−1. The second bitmap D2 is r/2 bits long that are reserved for the items represented by 0 in D1. In D2, the positions whose length l=d−2 are set to 1, and rest to 0. Same process is repeated on all bitmaps. The last bitmap Dd-i becomes
bits long, on which the code-words of lengths l=1 and l=d are marked with 1 and 0 bits, respectively. The total number of bits in these (d−1) bitmaps can be computed with
1 =
2 =
Scheme 3.
Marking the code-word boundaries information (5) on the sample NPF (B) via the proposed method. The 2-bits long code-words are marked on the first bitmap D1 by 1 bits. The lengths for those that are represented by 0 on D1 are specified on the second bitmap D2, on which 1- and 3-bits long code-words represented, respectively, by 1 and 0 bits.
Scheme 2 depicts the proposed method to mark the code-word boundaries information (6) on the sample NPF (B) introduced in Scheme 2 Since d=3 in that sample, there are d−1=2 bitmaps. On the first bitmap D1 that is r=8 bits long, the positions represented with 1 bits indicate that the corresponding code-words that are d−1=2 bits long. The second bitmap D2 is r/2=4 bits long, on which the positions with bit 1 mark the (d−2)=1 bit long code-words, and the positions with 0 bit indicate the d=3 bits long code-words. In total
bits are used.
Theorem 1.
Let B=b1 b2 . . . br be an input sequence, where the bi values, for 1≤i≤r, are i.i.d. over Σ={0,1,2, . . . 2d−1}, and represented by d-bits. The total bit length of the NPF encoding (4) of the sequence 13 with the code-word boundaries information (5) specification information is:
Proof.
Sum of the space consumption described in Lemmas 1 and 2 returns this.
The NPF encoding (5) of the input sequence 13, which is originally r·d bits long, introduces an overhead that requires
more bits as seen on Theorem 1. The number of extra bits per each original bit in B can be computed with
Table 1 summarizes the amount of extra bits introduced by the proposed NPF encoding (5) per each original bit IID data (4). Thanks to the exponentially increasing denominator (2d−1) in the denominator of the equation
that the extra space consumption quickly becomes very small, and even negligible with larger d values. When d=8, the proposed NPF encoding (5) method produces only 6.8 extra bits per a thousand bit. Similarly, the overhead becomes less than 3 bits per 100K bits, and less than 2 bits per a million bit for the values of d=16 and d=20, respectively. Thus, while selecting d, one needs to choose a high d value not to spend more space, where as a minimum d=8 seems to be useful in practical applications.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/TR2016/050441 | 11/14/2016 | WO | 00 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2018/088975 | 5/17/2018 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
5805700 | Nardone | Sep 1998 | A |
7039938 | Candelore | May 2006 | B2 |
7199735 | Wen | Apr 2007 | B1 |
7426636 | McGrew | Sep 2008 | B1 |
20040193871 | Seshadri | Sep 2004 | A1 |
20050141713 | Genevois | Jun 2005 | A1 |
20070083467 | Lindahl | Apr 2007 | A1 |
20070110225 | Leventhal | May 2007 | A1 |
20070263876 | De Waal | Nov 2007 | A1 |
20080065903 | Goodman | Mar 2008 | A1 |
20120134496 | Farkash | May 2012 | A1 |
20130054850 | Co | Feb 2013 | A1 |
20130330013 | Singh | Dec 2013 | A1 |
20140210652 | Bartnik | Jul 2014 | A1 |
20160124867 | Oportus Valenzuela | May 2016 | A1 |
20160124983 | Kelly | May 2016 | A1 |
20190007681 | Tsai | Jan 2019 | A1 |
Number | Date | Country |
---|---|---|
WO-2018088975 | May 2018 | WO |
Entry |
---|
Ferragina et al., A simple storage scheme for strings achieving entropy bounds, Theoretical Computer Science, Feb. 15, 2007, pp. 115-121, vol. 372, No. 1. |
Marco Dalai et al., Non prefix-free codes for constrained sequences, Arixv.org, Jun. 10, 2005. |
Number | Date | Country | |
---|---|---|---|
20180351730 A1 | Dec 2018 | US |