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

Describe the m-aryx Huffman coding algorithm in pseudocode.

Short Answer

Expert verified

\({\bf{N}}\): number of symbols,

\({\bf{M}}\): maximum children for an internal node

\({\bf{F}}\): Forest of \({\bf{N}}\) rooted trees, each including of the single vertex ai and assigned weight \({{\bf{w}}_{\bf{i}}}\), \({\bf{k = }}\left( {\left( {{\bf{N - 1}}} \right){\bf{ mod }}\left( {{\bf{m - 1}}} \right)} \right){\bf{ + 1}}\).

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

Step 1:Huffman Coding implements a rule known as a prefix rule. This is to prevent the ambiguities while decoding.

It ensures that the code assigned to any character is not a prefix of the code assigned to any other character.

02

Step 2:One shall write a pseudo code for m-ary tree of Huffman coding;

In a m-ary tree for Huffman coding a set of symbols \({\bf{C}}\) is encoded into strings using \({\bf{m}}\) number of codes or in other words it is the maximum number of children allowed for a node.

Values of in and \({\bf{N}}\) are the inputs, where \({\bf{N}}\) is the number of symbols to be encoded and in determines the number of symbols (in the code) that can be used to encode the \({\bf{N}}\) symbols.

03

The pseudo code is as follows;

Procedure Huffman _M_ary (\({\bf{C}}\): symbols \({\bf{a}}\); with frequencies \({{\bf{w}}_{\bf{i}}}\)

\({\bf{N}}\): number of symbols,

\({\bf{M}}\):maximum children for an internal node)

\({\bf{F}}\): Forest of\({\bf{N}}\)rooted trees, each consisting of the single vertex\({\bf{ai}}\)and assigned weight \({{\bf{w}}_{\bf{i}}}\),\({\bf{k = }}\left( {\left( {{\bf{N - 1}}} \right){\bf{ mod }}\left( {{\bf{m - 1}}} \right)} \right){\bf{ + 1}}\).

Find \({\bf{k}}\) number of least weighted vertices and replace them with a single tree with new root where weight of the tree is the sum of weights of \({\bf{k}}\) vertices and these \({\bf{k}}\) vertices are placed from left to right in the decreasing order of weights as the children of the root. Label the edges from root to the children as \({\bf{0}}\) to \({\bf{K - 1}}\) from left to right.

while \({\bf{F}}\) is not a tree,

Replace the \({\bf{m}}\) rooted trees of least weights from \({\bf{F}}\) with new a tree having a new root whose children from left to right are the roots of these in trees in order(decreasing order) by weight. Label the new edges to these children from left to right as \({\bf{0}}\) to \({\bf{m - 1}}\). Assign weight of the tree to the sum of the weights of these in former trees. {the Huffman coding for the symbol ai is the concatenation of the labels of the edges in the unique path from the root to the vertex ail.

Initially a forest of \({\bf{N}}\) rooted trees is formed. Then \({\bf{k = }}\left( {\left( {{\bf{N - 1}}} \right){\bf{ mod }}\left( {{\bf{m - 1}}} \right)} \right){\bf{ + 1}}\) least weighted vertices are replaced with a single rooted tree with new root.

Children to the root are these \({\bf{k}}\) vertices placed from left to right, ordered by their weight and edges labelled from \({\bf{0}}\) to \({\bf{K - 1}}\). Weight of the new tree is sum of the weights of these \({\bf{K}}\) vertices. Within the loop, instead of replacing the two trees of smallest weight, one finds the \({\bf{m}}\) trees of smallest weight and replace them with a new rooted tree. (Placing youngsters for the new root and labeling edges are same as above case. Instead of \({\bf{k}}\), here it will be \({\bf{m}}\)).

So, the m-aryx Huffman coding algorithm in pseudocode will be as explained above.

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