mirror of
https://github.com/Xevion/easy7zip.git
synced 2025-12-06 15:14:59 -06:00
22 lines
406 B
C
Executable File
22 lines
406 B
C
Executable File
/* HuffEnc.h -- functions for Huffman encoding
|
|
2008-03-26
|
|
Igor Pavlov
|
|
Public domain */
|
|
|
|
#ifndef __HUFFENC_H
|
|
#define __HUFFENC_H
|
|
|
|
#include "Types.h"
|
|
|
|
/*
|
|
Conditions:
|
|
num <= 1024 = 2 ^ NUM_BITS
|
|
Sum(freqs) < 4M = 2 ^ (32 - NUM_BITS)
|
|
maxLen <= 16 = kMaxLen
|
|
Num_Items(p) >= HUFFMAN_TEMP_SIZE(num)
|
|
*/
|
|
|
|
void Huffman_Generate(const UInt32 *freqs, UInt32 *p, Byte *lens, UInt32 num, UInt32 maxLen);
|
|
|
|
#endif
|