Wolfram Function Repository
Instant-use add-on functions for the Wolfram Language
Function Repository Resource:
Decode data specified by a Huffman encoding
| ResourceFunction["HuffmanDecode"][assoc] returns the decoding of an association assoc representing a Huffman encoding as a string. | 
Decode a Huffman encoding:
| In[1]:= | ![ResourceFunction[
 "HuffmanDecode"][<|"Encoding" -> {1, 1, 0, 1, 0, 0, 1, 1}, "Symbols" -> {"a", "b", "c"}, "CodeWords" -> {{1, 1}, {0}, {1, 0}}|>]](https://www.wolframcloud.com/obj/resourcesystem/images/11b/11b4c445-8a85-43ff-b39f-d29cda456788/3fce0cbac5734804.png) | 
| Out[1]= |  | 
Decode a larger example:
| In[2]:= | ![ResourceFunction[
 "HuffmanDecode"][<|"Symbols" -> {" ", "a", "b", "c", "d", "e", "i", "m", "n", "o", "p", "r", "s", "u", "y"}, "CodeWords" -> {{0, 0, 1}, {0, 0, 0, 1}, {1, 0, 1, 1, 0}, {1, 0, 0, 0}, {1, 1, 0, 1}, {1, 1, 1, 0}, {1, 0, 0, 1}, {1, 0, 1, 1, 1}, {0, 1, 0}, {1, 1, 1, 1}, {1, 1, 0, 0, 0}, {1, 0, 1, 0}, {0, 1, 1}, {1, 1, 0, 0, 1}, {0, 0, 0, 0}}, "Encoding" -> {1, 0, 0, 0, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 0, 0, 0,
     1, 0, 1, 0, 1, 1, 1, 0, 0, 1, 1, 0, 1, 1, 1, 0, 0, 1, 1, 1, 1, 1,
     0, 1, 0, 0, 0, 1, 1, 0, 0, 1, 0, 1, 1, 0, 0, 1, 1, 0, 1, 1, 0, 0,
     0, 0, 1, 0, 1, 1, 1, 1, 1, 0, 1, 1, 0, 1, 0, 0, 1, 1, 1, 1, 1, 0,
     1, 0, 0, 0, 1, 1, 0, 1, 0, 1, 1, 1, 0, 1, 1, 0, 1, 1, 1, 0, 0, 1,
     0, 1, 0, 1, 1, 0, 1, 0, 0, 0, 1, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0}|>]](https://www.wolframcloud.com/obj/resourcesystem/images/11b/11b4c445-8a85-43ff-b39f-d29cda456788/21a989fc7ae6afa2.png) | 
| Out[2]= |  | 
HuffmanDecode is the inverse of the resource function HuffmanEncode:
| In[3]:= | ![encoded = ResourceFunction["HuffmanEncode"]["the cat in the hat"]](https://www.wolframcloud.com/obj/resourcesystem/images/11b/11b4c445-8a85-43ff-b39f-d29cda456788/13f2d7034c0df129.png) | 
| Out[3]= |  | 
| In[4]:= | ![ResourceFunction["HuffmanDecode"][encoded]](https://www.wolframcloud.com/obj/resourcesystem/images/11b/11b4c445-8a85-43ff-b39f-d29cda456788/23d49201cf1376a4.png) | 
| Out[4]= |  | 
This work is licensed under a Creative Commons Attribution 4.0 International License