Warning: foreach() argument must be of type array|object, bool given in /var/www/html/web/app/themes/studypress-core-theme/template-parts/header/mobile-offcanvas.php on line 20

Suppose that in a long bit string the frequency of occurrence of a 0 bit is 0.9 and the frequency of a 1 bit is 0.1 and bits occur independently.

a. Construct a Huffman code for the four blocks of two bits, 00, 01, 10, and 11. What is the average number of bits required to encode a bit string using this code?

b.Construct a Huffman code for the eight blocks of three bits. What is the average number of bits required to encode a bit string using this code?

Short Answer

Expert verified

a. Therefore, a Huffman codes are 0 for 00, 11 for 01, 100 for 10, and 101 for 11 (exact coding depends on how ties were broken, but all versions are equivalent).And the average number of bits required to encode a bit string using this code is 0.645n.

b. Hence, a Huffman codes are 0 for 000, 100 for 001, 101 for 010, 110 for 100, 11100 for 011, 11101 for 101. 11110 for 110, and 11111 for 111 (exact coding depends on how ties were broken, but all versions are equivalent). And the average number of bits required to encode a bit string using this code is 0.533n.

Step by step solution

Achieve better grades quicker with Premium

  • Unlimited AI interaction
  • Study offline
  • Say goodbye to ads
  • Export flashcards

Over 22 million students worldwide already upgrade their learning with Vaia!

01

General form

Huffman coding (Definition): A procedure for constructing an optimal binary code for a set of symbols, given the frequencies of these symbols.

02

(a) Evaluate the frequencies

Given that, the four blocks of two bits, 00, 01, 10, and 11.

The frequencies of the bit’s strings are 0.81 for 00, 0.09 for 01 and for 10 and 0.01 for 11.

The subsequent Huffman code utilizes 0 for 00, 11 for 01, 100 for 10, and 101 for 11 (exact coding depends on how ties were broken, but all versions are equivalent).

Now, find the string length.

If the length of string is n, then, the normal number of bit’s required to send two bits of the message is

\(0.81 + 2 \times 0.09 + 3 \times 0.09 + 3 \times 0.01 = 1.29\).

Now, the normal number of bits required to encode the string is

\(\left( {1.29} \right) \times \left( {\frac{n}{2}} \right) = 0.645n\).

Conclusion: So, the average number of bits required to encode a bit string using this code is \(0.645n\).

is \(0.533n\).

03

(b) Evaluate the frequencies

Given that, the eight blocks of three bits.

The frequencies of the bit’s strings are 0.729 for 000, 0.081 for 001, 010, and 100, 0.009 for 011, 101, and 110, and 0.001 for 111.

The subsequent Huffman code utilize 0 for 000, 100 for 001, 101 for 010, 110 for 100, 11100 for 011, 11101 for 101. 11110 for 110, and 11111 for 111 (exact coding depends on how ties were broken, but all versions are equivalent).

Now, find the string length.

If the length of string is n, then, the normal number of bit’s required to send three bits of the message is

\(1 \times 0.729 + 3 \times 3 \times 0.081 + 5 \times 3 \times 0.009 + 5 \times 0.001 = 1.598\).

Now, the normal number of bits required to encode the string is

\(\left( {1.598} \right) \times \left( {\frac{n}{3}} \right) = 0.533n\).

So, the average number of bits required to encode a bit string using this code is \(0.533n\).

One App. One Place for Learning.

All the tools & learning materials you need for study success - in one app.

Get started for free

Study anywhere. Anytime. Across all devices.

Sign-up for free