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

Consider the three symbols \({\bf{A, B, and C}}\) with frequencies \({\bf{A:0}}{\bf{.80, B:0}}{\bf{.19, C:0}}{\bf{.01}}\).

a) Construct a Huffman code for these three symbols.

b) Form a new set of nine symbols by grouping together blocks of two symbols, \({\bf{AA, AB, AC, BA, BB, BC, CA, CB, and CC}}\). Construct a Huffman code for these nine symbols, assuming that the occurrences of symbols in the original text are independent.

c) Compare the average number of bits required to encode text using the Huffman code for the three symbols in part (a) and the Huffman code for the nine blocks of two symbols constructed in part (b). Which is more efficient?

Short Answer

Expert verified
  1. \(\begin{array}{l}{\bf{A - 0}}\\\begin{array}{*{20}{l}}{{\bf{B - 10}}}\\{{\bf{C - 11}}}\end{array}\end{array}\)
  2. \(\begin{array}{l}{\bf{AA:0}}\\\begin{array}{*{20}{l}}{{\bf{AB:11}}}\\{{\bf{AC:101110}}}\\{{\bf{BA:100}}}\\{{\bf{BB:1010}}}\\{{\bf{BC:1011111}}}\\{{\bf{CA:10110}}}\\{{\bf{CB:10111100}}}\\{{\bf{CC: 10111101}}}\end{array}\end{array}\)
  3. Part (b)

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

Huffman coding is a fundamental algorithm in data compression, the subject devoted to reducing the number of bits required to represent information

Huffman coding is a greedy algorithm. Replacing the two subtrees with the smallest weight at each step leads to an optimal code in the sense that no binary prefix code for these symbols can encode these symbols using fewer bits.

02

Step2:We shall construct a Huffman code;

Huffman code for the symbols \({\bf{A, 8, C}}\) with given frequencies from the figure are:

\(\begin{array}{*{20}{l}}{{\bf{A - 0}}}\\{{\bf{B - 10}}}\\{{\bf{C - 11}}}\end{array}\)

Average number of bits needed in part (a) is,\({\bf{1}}\left( {{\bf{0}}{\bf{.80}}} \right){\bf{ + 2}}\left( {{\bf{0}}{\bf{.19}}} \right){\bf{ + 2}}\left( {{\bf{0}}{\bf{.01}}} \right){\bf{ = 1}}{\bf{.2}}\)

03

Construct a Huffman code for these nine symbols

Frequencies of the given symbols in part(b) can be calculated first

\(\begin{array}{*{20}{l}}{{\bf{AA:0}}{\bf{.6400, }}\left( {{\bf{0}}{\bf{.80 x 0}}{\bf{.80}}} \right)}\\{{\bf{AB:0}}{\bf{.1520,}}}\\{{\bf{AC:0}}{\bf{.0080,}}}\\{{\bf{BA:0}}{\bf{.1520,}}}\\{{\bf{BB:0}}{\bf{.0361,}}}\\{{\bf{BC:0}}{\bf{.0019,}}}\\{{\bf{CA:0}}{\bf{.0080,}}}\\{{\bf{CB:0}}{\bf{.0019,}}}\\{{\bf{CC:0}}{\bf{.0001}}{\bf{.}}}\end{array}\)

The codes are:

\(\begin{array}{*{20}{l}}{{\bf{AA:0}}}\\{{\bf{AB:11}}}\\{{\bf{AC:101110}}}\\{{\bf{BA:100}}}\\{{\bf{BB:1010}}}\\{{\bf{BC:1011111}}}\\{{\bf{CA:10110}}}\\{{\bf{CB:10111100}}}\\{{\bf{CC: 10111101}}}\end{array}\)

Average number of bits needed in part(b) is,

\(\begin{array}{l}{\bf{1}}\left( {{\bf{0}}{\bf{.6400}}} \right){\bf{ + 2}}\left( {{\bf{0}}{\bf{.1520}}} \right){\bf{ + 6}}\left( {{\bf{0}}{\bf{.0080}}} \right){\bf{ + 3}}\left( {{\bf{0}}{\bf{.1520}}} \right){\bf{ + 4}}\left( {{\bf{0}}{\bf{.0361}}} \right){\bf{ + 7 }}\left( {{\bf{0}}{\bf{.0019}}} \right){\bf{ }}\\{\bf{ + 5 }}\left( {{\bf{ 0}}{\bf{.0080}}} \right){\bf{ + 8 }}\left( {{\bf{ 0}}{\bf{.0019 }}} \right){\bf{ + 8}}\left( {{\bf{0}}{\bf{.0001}}} \right){\bf{ = 1}}{\bf{.6617}}\end{array}\)

04

Compare the average number of bits required to encode text using the Huffman code for the three symbols partially (a) and part (b).

This is for sending 2 symbols.

For sending one symbol in this case,

It needs half of this, that is \({\bf{0}}{\bf{.83085}}\).

Hence the second one is more efficient.

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