- Huffman Algorithm was developed by David Huffman in 1951.
- This is a technique which is used in a data compression or it can be said that it is a coding technique which is used for encoding data.
- This technique is a mother of all data compression scheme.
- This idea is basically dependent upon the frequency, i.e. the frequency of the corresponding character which needs to be compressed, and by that frequency, only Huffman code will be generated.
- In case of Huffman coding, the most generated character will get the small code and least generated character will get the large code.
- Huffman tree is a specific method of representing each symbol.
- This technique produces a code in such a manner that no codeword is a prefix of some other code word. These codes are called as prefix code.
Example:
Let obtain a set of Huffman code for the message (m1.....m7) with relative frequencies (q1.....q7) = (4,5,7,8,10,12,20). Let us draw the Huffman tree for the given set of codes.
Step 1) Arrange the data in ascending order in a table.
4,5,7,8,10,12,20
Step 2) Combine first two entries of a table and by this create a parent node.
data:image/s3,"s3://crabby-images/4b1ba/4b1ba5557240e0aa4cd63bbf5e3c57221169d8b7" alt="Huffman coding algo 1"
Step 3)
A) Remove the entries 4 and 5 from the table and inert 9 at its appropriate position. 7,8,9,10,12,20
Combine minimum value of table and create a parent node.
data:image/s3,"s3://crabby-images/a32f2/a32f2f2788934020604011eacb87f31c33a66941" alt="Huffman coding algo 2"
B) Now remove the entries 7 and 8 from the table and insert 15 at its appropriate position. 9,10,12,15,20
Combine minimum value of two blocks and create a parent node.
data:image/s3,"s3://crabby-images/5f62a/5f62a419c60c24e4f320ce146a194f0736a3c646" alt="Huffman coding algo 3"
C) Remove the entries 9 and 10 from the table and insert 19 at its proper position. 12,15,19,20.
Combine minimum value of two blocks and create parent node.
data:image/s3,"s3://crabby-images/0fe58/0fe5889f48875c4b8a3de0e517a638274fa6beaf" alt="Huffman coding algo 4"
D) Remove the entries 15 and 12 from the table and insert 27 at its appropriate position. 19,20,27
Combine minimum value of two blocks and create parent node.
data:image/s3,"s3://crabby-images/2ebc3/2ebc306d9b283b106735e0c6d615ed6612945906" alt="Huffman coding algo 5"
E) Remove the entries 19 and 20 from the table and insert 39 in the table. 27,39
Combine minimum value of two blocks and create parent node.
data:image/s3,"s3://crabby-images/f45aa/f45aa578521252b20fe37ccee3da719e1ea78dd4" alt="Huffman coding algo 6"
Step 4) Now assign left child as 0 and right child as 1 to encode the frequencies.
data:image/s3,"s3://crabby-images/1baa9/1baa986f7a63656018d4da9ddec507d1a9c59c0e" alt="Huffman coding algo 7"
Now, codes for the given frequencies are given below:
data:image/s3,"s3://crabby-images/07f8f/07f8f04bbe6a01a8ab874986946b63b7b74bec60" alt="Huffman coding algo 8"
Time complexity:
O(nlogn) is the overall time complexity. Where n is the number of characters.
0 Comments