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

a) Use Huffman coding to encode these symbols with frequencies \({\bf{a: 0}}{\bf{.4, b: 0}}{\bf{.2, c: 0}}{\bf{.2, d: 0}}{\bf{.1, e: 0}}{\bf{.1}}\) in two different ways by breaking ties in the algorithm differently. First, among the trees of minimum weight select two trees with the largest number of vertices to combine at each stage of the algorithm. Second, among the trees of minimum weight select two trees with the smallest number of vertices at each stage.

b) Compute the average number of bits required to encode a symbol with each code and compute the variances of this number of bits for each code. Which tiebreaking procedure produced the smaller variance in the number of bits required to encode a symbol?

Short Answer

Expert verified
  1. \({\bf{a:1, b:01, c:000, d:0010, e:0011}}\)

  2. \({\bf{a:00, b:10, :1 1, d:010, e:011}}\)

The variance for the first method is \({\bf{1}}{\bf{.36}}\) and for the second method is \({\bf{0}}{\bf{.16}}\)

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

Step 2:We shall construct binary tree using Huffman coding to encode these symbols with frequencies

\({\bf{A:0}}{\bf{.4, b: 0}}{\bf{.2, c :0}}{\bf{.2}}{\bf{. d: 0}}{\bf{.1, e:0}}{\bf{.1}}\)in two different ways and find which way has the smaller variance.

Firstly, one combines\({\bf{e}}\) and \({\bf{d}}\) into a tree \({{\bf{T}}_{\bf{1}}}\), with weight \({\bf{0}}{\bf{.2}}\). Then using the rule, one chooses\({{\bf{T}}_{\bf{1}}}\), and, \({\bf{c}}\) to combine into a tree \({{\bf{T}}_{\bf{2}}}\) with weight \({\bf{0}}{\bf{.4}}\). Then again combine \({{\bf{T}}_{\bf{2}}}\) and \({\bf{b}}\) into \({{\bf{T}}_{\bf{3}}}\) with weight \({\bf{0}}{\bf{.6}}\), and finally \({{\bf{T}}_{\bf{3}}}\) and \({\bf{a}}\).

Hence, this gives codes,\({\bf{a:1, b:01, c:000, d:0010, e:0011}}\).

03

Now solve the (b) part of the question,

(b)

For the other method, one first combines\({\bf{d}}\) and \({\bf{e}}\) to form a tree \({{\bf{T}}_{\bf{1}}}\) with weight \({\bf{0}}{\bf{.2}}\). Next, one combines\({\bf{b}}\) and \({\bf{c}}\) into a tree \({{\bf{T}}_{\bf{2}}}\) with weight \({\bf{0}}{\bf{.4}}\). Next, one is forced to combine a with \({{\bf{T}}_{\bf{1}}}\), to form \({{\bf{T}}_{\bf{3}}}\) with weight \({\bf{0}}{\bf{.6}}\), and then \({{\bf{T}}_{\bf{3}}}\)and\({{\bf{T}}_{\bf{2}}}\).

Hence, this gives the codes,\({\bf{a:00, b:10, :1 1, d:010, e:011}}\).

The average for the first method is \({\bf{1 \bullet 0}}{\bf{.4 + 2 \bullet 0}}{\bf{.2 + 3 \bullet 0}}{\bf{.2 + 4 \bullet 0}}{\bf{.1 + 4 \bullet 0}}{\bf{.1 = 2}}{\bf{.2}}\) and the average for the second method is \({\bf{2 \bullet 0}}{\bf{.4 + 2 \bullet 0}}{\bf{.2 + 2 \bullet 0}}{\bf{.2 + 3 \bullet 0}}{\bf{.1 + 3 \bullet 0}}{\bf{.1 = 2}}{\bf{.2}}\).

They are the same.

For variance use the formula \({\bf{v}}\left( {\bf{x}} \right){\bf{ = E}}\left( {\bf{X}} \right){\bf{2 - E}}{\left( {\bf{X}} \right)^{\bf{2}}}\) expectation of the square of the number of bits.

\(\begin{array}{c}{\bf{E}}{\left( {\bf{X}} \right)^{\bf{2}}}{\bf{ = }}{{\bf{1}}^{\bf{2}}}{\bf{ \times 0}}{\bf{.4 + }}{{\bf{2}}^{\bf{2}}}{\bf{ \times 0}}{\bf{.2 + }}{{\bf{3}}^{\bf{2}}}{\bf{ \times 0}}{\bf{.2 + }}{{\bf{4}}^{\bf{2}}}{\bf{ \times 0}}{\bf{.1 + }}{{\bf{4}}^{\bf{2}}}{\bf{ \times 01}}\\{\bf{ = 6}}{\bf{.2}}\end{array}\)

And for the second method

\(\begin{array}{c}{\bf{E}}{\left( {\bf{X}} \right)^{\bf{2}}}{\bf{ = }}{{\bf{2}}^{\bf{2}}}{\bf{ \times 0}}{\bf{.4 + }}{{\bf{2}}^{\bf{2}}}{\bf{ \times 0}}{\bf{.2 + }}{{\bf{2}}^{\bf{2}}}{\bf{ \times 0}}{\bf{.2 + }}{{\bf{3}}^{\bf{2}}}{\bf{ \times 0}}{\bf{.1 + }}{{\bf{3}}^{\bf{2}}}{\bf{ \times 01}}\\{\bf{ = 5}}{\bf{.0}}\end{array}\)

The second method has a smaller variance in this example.

Therefore, the variance for the first method is \({\bf{6}}{\bf{.2 - 2}}{\bf{.}}{{\bf{2}}^{\bf{2}}}{\bf{ = 1}}{\bf{.36}}\)

Andfor the second method it is \({\bf{5}}{\bf{.0 - 2}}{\bf{.}}{{\bf{2}}^{\bf{2}}}{\bf{ = 0}}{\bf{.16}}\).

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