Sunday, March 31, 2019
Variable Length Hash Algorithm Using RC6
unsettled quantity Length haschisch algorithmic programic programic weapons platformic program Using RC6Hash_RC6 Variable Length Hash Algorithm utilize RC6Kirti AggarwalDr. Harsh K. VermaABSTRACTIn this paper, we present a chopisheesh algorithmic program exploitation RC6 that quarter gravel haschisch apprize of variable space. Hash algorithms play major crack up in cryptographic warranter as these algorithms argon utilise to harmonise the integrity of the trusdeucerthy put across. It is possible to gift chop algorithm use radi wholey symmetrical occlude fancy. The main nous behind this is that if the symmetric pulley- obturate algorithm is secure because the giftd chop up dish out will handlewise be secure 1. As RC6 is secure against various linear and derivative attacks algorithm presented here(predicate) will likewise be secure against these attack. The algorithm presented here stooge have variable number of rounds to generate chop up rep ute. It can alike have variable barricade coat. gravestone intelligence operationsCryptography, Symmetric Encryption, asymmetrical Encryption, Data Integrity, Au whereforetication, Confidentiality, Non-Repudiation, Access Control, Hash, RC6INTRODUCTIONCryptography is the ability of keeping kernel secure form others while s suppressing information between participants (Confidentiality). in that location atomic number 18 many cryptographic algorithms categorized as symmetric encoding algorithm and asymmetric encoding algorithm. Symmetric encryption algorithm is the mavin that use comparable shared key from encryption and decryption, while asymmetric algorithm is the one that use varied keys from encryption and decryption.With the Confidentiality cryptography also provide other services cognize as data integrity, authentication, non-repudiation, gate control etc. Data Integrity is assuring that data received is equal as sent by the sender. Authentication is the abilit y to figure that communicating party is who that it claims to be. Non-Repudiation is the prevention against the denial by entities involved in the communication. Access Control is the prevention against the unauthorized use of resources 2. jut 1. unfathomed of CryptographyHash FunctionA cryptographic hash start is any algorithm or subroutine that maps large data sets of variable aloofness to microscopicaler data sets of a fixed length. The care fors returned by a hash function are c eithered hash cling tos, hash codes, hash sums, checksums or simply hashes.Where h has fixed length. An (accidental or intentional) change to the data will (with very(prenominal) high probability) change the hash honour.For a hash function to be considered secure, it must be computationally infeasible to engender has a predefined hash look upon and similarly it must be computationally infeasible to find two contents having same hash value.RC6RC6 is a symmetric oppose engrave based on RC5 and intentional by Rivest, Sydney, and Yin for RSA security 3. Like RC5, RC6 is a parameterized algorithm where the block surface, the key sizing, and the number of rounds are variable again, the upper limit on the key size is 2040 bits 4. RC6 was designed to meet the requirements of the Advanced Encryption Standard (AES)competition. RC6 proper has ablock sizeof 128 bits and supportskey sizesof 128, 192 and 256 bits, precisely, like RC5. RC6 can be viewed as interweaving two parallel RC5 encryption processes. It uses an extra genesis operation not present in RC5 in order to key the revolution dependent on every bit in a word.SHA-256SHA-256 operates on ogdoad 32-bit words. The message to be hashed is firstpadded with its length in such a way that the result is a fourfold of 512 bits long, and thenparsed into 512-bit message blocks M(1)M(2) M(N).The message blocks are processed one at a epoch Beginning with a fixed initial hash value H(0), sequentially computeWhere C is the SH A-256 compression function and + elbow room word-wise mod 264 addition. H(N) is the hash of M 5.SHA-512SHA-512 is a variant of SHA-256 which operates on eight 64-bit words and block size of 1024 bits. It uses diametrical shift amounts and additive constants, but its structure is otherwise virtually identical, differing only in the number of rounds, which are 80 for SHA-51215. chop FUNCTIONA cryptographic hash function is a mathematical transformation that takes a message of arbitrary length and computes a fixed length value also known as hash value, message digest, hash code, hash sum, checksum, etc.Where H is Hash Function, M is variable length message H is fixed size hash value. Creating hash function is accomplished by iteration. Instead of using a hash function with variable-size input signal, a function with fixed size input is gaind and is used a necessary number of magazines. This fixed size input function is known as compression function. It compresses an n-bit string t o create a m-bit string where n is normally greater than m. This scheme is referred to as an iterated cryptographic hash function 6. These compression function fall into two categories a function specially designed for the hash function or a symmetric block cipher 2. bet 2. Iterated Cryptographic hash FunctionCharacteristics of one way Hash Function prone M, it is lenient to compute h.Given h, it is hard to compute M such that.Given M, it is hard to find another message, M, such that The whole pip of one way hash function is to provide a riffle print of M that is unique. In well-nigh application one wayness is short we need an additional requirement called collision-resistance (It is hard to find two haphazard messages, M and M, such that 1).Figure 3. Basic Hash Algorithm at sender and receiverHash Function takes message and an initial value as an input and stimulates the hash value. The hash value is appended to the message at a period when the message is assumed or known t o be correct. The receiver authenticates the message by generating the hash value with the same modus operandi and compares it with the hash value send by the sender. If both the value matches then the received message is same as it is send by the sender otherwise message has been tampered with.RC6RC6 7 is a fully parameterized family of encryption algorithms. A version of RC6 is more accurately specified as RC6-w r bwhere the word size is wbits, encryption consists of a nonnegative number of roundsr, andbdenotes the length of the encryption key in bytes. Since the AES submission is targeted atw= 32 andr= 20, we shall use RC6 as tachygraphy to refer to such versions. When any other value ofworris intended in the textbook, the parameter values will be specified as RC6-w r. Of situation relevance to the AES effort will be the versions of RC6 with 16-, 24-, and 32-byte keys 4.Figure 4. RC6 EncryptionFor all variants, RC6-w r boperates on units of fourw-bit words using the followin g six staple operations.whole number addition modulo integer subtraction modulo bitwise exclusive-or of w-bit wordsinteger ms modulo Rotate to the left by the amount given by the least(prenominal) significant bits of Rotate A to the right, similarly parallel assignmentKey ExpansionUse two magic constants-Where-.(base of natural logarithm)..() is the odd integer nearest to .INPUT byte key that is preloaded into word array denotes the no of rounds. siding w-bit round keys .ALGORITHMFor doEncryptionFour w-bit registers A, B, C, D bear the initial input plain-text as well as the output ciphertext at the end of encryption. The first byte of plaintext is placed in the least significant byte of A the last byte of plaintext is placed into the most significant byte of D 6.INPUTPlaintext stored in four w-bit input registers Number r of rounds w-bit round keys OUTPUTCiphertext stored in ALGORITHMC = C + S2r + 3DecryptionFor decryption of cipher-text load these cipher text into regis ters A, B, C, D Algorithm uses integer subtraction modulo 2w and right rotation on registers for getting plain text.INPUTCiphertext stored in four w-bit input registers Number r of roundsw-bit round keys OUTPUTPlaintext stored in ALGORITHMHASH FUNCTION USING RC6RC6 is a uses 44 words of key existent making it more complex to break. RC6 parameterized cipher the block size can be grown in a straightforward manner to 256 bits and beyond.RC6 has level best key size of 2040 bits, making the corresponding hash function very fast.20 rounds using RC6 will have all these features which make the hash more efficient and secure.It is possible to use a symmetric block cipher algorithm as a hash function. If the block algorithm is secure, then the one-way hash function will also be secure. maven approach is to encrypt the message with the algorithm in CBC mode, a fixed key and an initial vector (IV), the last cipher text block is the hash value. Another more better approach uses the message bl ock as the key, the previous hash value as the output. present we will use second approach.Algorithm presented here has variable parameters i.e. different parameter value can be taken according to the need. suspend size (b), Number of rounds (r), length of hash value (l) are the different variable parameters that are the inputs of the algorithm. The length of hash value (l) should be septuple of 256.First of all padding is make. Message is padded with zeros in a way such that the padded message length is multiple of the block size (b).Then initial vector is needed to generate the hash value. Initial Vector is a piece of data is needed to develop lead an algorithm, and is not secret. There are two initial vectors in this algorithm which are used to generate initial hash value.To generate the initial hash value combination of v (size of hash value divided by 256) 256 bits values calculated as followsAfter generating initial hash value from initial vectors the message (M) is divi ded into number of small chunks (n). The size of message chunks should be equal to block size b, subsequently that RC6 key extension is applied on each message block to generate keys that will be used to encrypt the previous hash value to generate next hash value. Initial 256 bits v hash values are encrypted via RC6 using RC6 keys generated from first message block (M1). This is then encrypted again from the keys generated from second message block (M2) and so on until all the message blocks (n) are used. At last all the v concluding hash values of length 256 bit each are concatenated to generate the final hash value of length l.Number of rounds (r) is divided in to two parts, 3r/4 rounds are used to generate the RC6 keys from the message block and r/4 rounds are used to encrypt the previous hash value to generate next hash value. Figure 5 shows the procedure for hash value of size 512 bits.Figure 5. Hash Value multiplication using RC6PSEUDO CODEINPUTMessage M,Number of rounds r , shut down size b,Length of hash value lOUTPUT net hash value hALGORITHMPad 0s (zeros) at the end of the message so the message length is multiple of b river basin message into chunks of size bRepeat graduation 7 to 21 Load Repeat whole step 10 to 12 Repeat step 13 to 16 Repeat step 20 Repeat step 22 to 33 Load Repeat step 26 to 30 for doLoad Concatenate to get final hash value hPERFORMANCE AND ANALYSISThis algorithm was implemented using umber in NetBeans IDE 7.0.1. Following results were obtained on Intel(R) Core(TM) i3 CPU M 370 2.40 gigahertz 2.39 gigahertz 32 bit system with 4 GB of doss down running Windows 7 Ultimate.Algorithm presented in this paper is compared with SHA-256 and SHA-512 respectively. Comparison between algorithm presented here and SHA are done on the basis of throughput of the algorithms and time to produce hash value for wedges of different sizes. To be more accurate the program is executed ten times for each input file and the number of those resu lts are reported here.Results in Figure 6 to Figure 9 and board 1 for Hash using RC6 are obtained for r=64, b=512, l=256 and these results are compared with SHA-256 which has same value for these parameters.Figure 6. Throughput of RC6_HASH and SHA-256.Figure 7. run represent of Hash value generation time of RC6_HASH and SHA-512Figure 8. course of instruction chart of Hash generation time of HASH_RC6 (256) and SHA-256Figure 9. murder time parsimony(a) caused by Hash_RC6Table 1. Comparison of Hash_RC6 (256) SHA-256 on the basis of Execution term of different type of Files.Figure 6 shows the throughput of RC6_HASH and SHA-256 the algorithms in KB/sec. Figure 7 shows the bill chart hash value generation time (in millisec) of both the algorithms for the file of different sizes (in KB).Figure 8 shows the government note-Graph of capital punishment time according to their file size for each file using algorithms Hash_RC6 (256) and SHA-256. Line graph is more convenient to sho w that Hash_RC6 (256) performs faster than SHA-256. This Graph also shows that for the file of small size both the algorithms performs approximately same i.e. there is not much of the difference but when the file size increases Hash_RC6 (256) performs much better than the SHA-256.Bar chart in Figure 9 shows the deed time saving caused by Hash_RC6 in percentage in comparison with SHA-256 for different file sizes. Its greater than 30% for near all the file sizes and for some of the file sizes its approx 50% that is greater advancement. The add up percent execution time saving by Hash_RC6 for hash value of 256 bits over SHA-256 is 40.26.We compare the execution time of each algorithm on different file types like text file, audio file word picture files, for this purpose we mainly used 10 files and recorded their hash value generation time in milliseconds for these algorithms. List of Input files and their size are given in Table 1.Results in Figure 10 to Figure 13 and Table 2 for Hash using RC6 are obtained for r=80,b=1024,l=512 and these results are compared with SHA-512 which has same value for these parameters.Figure 10. Throughput of RC6_HASH and SHA-512.Figure 11. Bar Graph of Hash value generation time of RC6_HASH and SHA-512Figure 12. Line Graph of Hash Generation Time of HASH_RC6 (512) and SHA-512Figure 13. Execution Time saving caused by Hash_RC6Table 2. Comparison of Hash_RC6 (512) SHA-512 on the basis of Execution Time of different type of Files.Figure 10 shows the throughput of RC6_HASH and SHA-512 the algorithms in KB/sec. Figure 11 shows the Bar Graph of hash value generation time (in millisec) of both the algorithms for the file of different sizes (in KB).Figure 12 shows the Line-Graph of execution time according to their file size for each file using algorithms Hash_RC6 (512) and SHA-512. Line graph is more convenient to show that Hash_RC6 (512) performs faster than SHA-512. This Graph also shows that the difference is not so much for file o f small size but when it comes to file of larger size Hash_RC6 (512) is much better than the SHA-512.Bar chart in Figure 13 shows the execution time saving caused by Hash_RC6 (512) in percentage in comparison with SHA-512 for different file sizes. Its greater than 15% for almost all the file sizes and for some of the file sizes its approx 35% that is greater advancement. The average percent execution time saving by Hash_RC6 for hash value of 512 bits over SHA-512 is 24.625.We compare the execution time of each algorithm on different file types like text file, audio file video files, for this purpose we mainly used 10 files and recorded their hash value generation time in milliseconds for these algorithms. List of Input files and their size are given in Table 2.CONCLUSIONIn this research paper a new algorithm for generating hash value is presented. This algorithm is generated on a symmetric block cipher known as RC6 and can generate hash value of different sizes. The algorithm can a lso operate on different block size and different number of rounds. The implementation of algorithm is done using JAVA in NetBeans IDE 7.0.1. on Intel(R) Core(TM) i3 CPU M 370 2.40 GHz 2.39 GHz 32 bit system with 4 GB of RAM running Windows 7 Ultimate.Hash value generated using algorithm presented here are secure against many attack because when a hash algorithm is generated using symmetric block cipher it inherit the properties of underlying cipher. The idea behind this is that if the symmetric block algorithm is secure then the generated hash function will also be secure 1.Then the algorithm is compared with SHA-256 and SHA-512 for same parameter and on the same environment. The results of comparison conclude that the algorithm present here has better throughput
Subscribe to:
Post Comments (Atom)
No comments:
Post a Comment
Note: Only a member of this blog may post a comment.