Commit 7db5603
committed
feat: Enhance Huffman encoding in pzip for improved compression efficiency
- Added new methods for histogram calculation, dynamic header writing, and code generation in HuffmanBitWriter.
- Introduced a new writeBlockHuff method to handle Huffman-only compression for low token counts.
- Implemented quick entropy detection to optimize compression decisions based on data characteristics.
- Updated FastDeflate to utilize the new Huffman encoding features for better performance.
Log: Improve Huffman encoding and compression efficiency in pzip
bug: https://pms.uniontech.com/bug-view-346679.html1 parent 37c12e0 commit 7db5603
4 files changed
Lines changed: 339 additions & 84 deletions
File tree
- 3rdparty/pzip
- include/pzip
- src
- src/source
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
17 | 17 | | |
18 | 18 | | |
19 | 19 | | |
| 20 | + | |
20 | 21 | | |
21 | 22 | | |
22 | 23 | | |
23 | 24 | | |
| 25 | + | |
24 | 26 | | |
25 | 27 | | |
26 | 28 | | |
| |||
330 | 332 | | |
331 | 333 | | |
332 | 334 | | |
| 335 | + | |
333 | 336 | | |
334 | 337 | | |
335 | 338 | | |
336 | 339 | | |
337 | 340 | | |
338 | 341 | | |
| 342 | + | |
| 343 | + | |
339 | 344 | | |
340 | 345 | | |
341 | 346 | | |
342 | 347 | | |
343 | 348 | | |
344 | 349 | | |
345 | 350 | | |
| 351 | + | |
| 352 | + | |
| 353 | + | |
| 354 | + | |
| 355 | + | |
346 | 356 | | |
347 | 357 | | |
348 | 358 | | |
349 | 359 | | |
350 | 360 | | |
351 | 361 | | |
| 362 | + | |
| 363 | + | |
352 | 364 | | |
353 | 365 | | |
354 | 366 | | |
355 | 367 | | |
| 368 | + | |
| 369 | + | |
356 | 370 | | |
357 | 371 | | |
358 | 372 | | |
| 373 | + | |
| 374 | + | |
359 | 375 | | |
360 | 376 | | |
361 | 377 | | |
| |||
448 | 464 | | |
449 | 465 | | |
450 | 466 | | |
451 | | - | |
| 467 | + | |
452 | 468 | | |
453 | 469 | | |
454 | | - | |
| 470 | + | |
| 471 | + | |
| 472 | + | |
| 473 | + | |
455 | 474 | | |
456 | | - | |
457 | | - | |
| 475 | + | |
| 476 | + | |
| 477 | + | |
458 | 478 | | |
| 479 | + | |
459 | 480 | | |
460 | | - | |
461 | | - | |
| 481 | + | |
| 482 | + | |
| 483 | + | |
| 484 | + | |
| 485 | + | |
| 486 | + | |
462 | 487 | | |
463 | 488 | | |
464 | | - | |
465 | | - | |
466 | | - | |
| 489 | + | |
| 490 | + | |
| 491 | + | |
| 492 | + | |
| 493 | + | |
| 494 | + | |
| 495 | + | |
| 496 | + | |
| 497 | + | |
| 498 | + | |
| 499 | + | |
467 | 500 | | |
468 | 501 | | |
469 | 502 | | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
180 | 180 | | |
181 | 181 | | |
182 | 182 | | |
183 | | - | |
184 | 183 | | |
185 | 184 | | |
186 | 185 | | |
187 | 186 | | |
188 | | - | |
189 | 187 | | |
190 | 188 | | |
191 | 189 | | |
192 | 190 | | |
193 | 191 | | |
194 | | - | |
195 | | - | |
196 | | - | |
197 | | - | |
198 | | - | |
199 | | - | |
200 | | - | |
201 | | - | |
202 | | - | |
203 | | - | |
204 | | - | |
205 | | - | |
206 | | - | |
207 | | - | |
208 | | - | |
209 | | - | |
210 | | - | |
211 | | - | |
212 | | - | |
213 | | - | |
214 | | - | |
215 | | - | |
216 | | - | |
217 | | - | |
218 | | - | |
219 | | - | |
220 | | - | |
221 | | - | |
222 | | - | |
223 | | - | |
| 192 | + | |
| 193 | + | |
| 194 | + | |
224 | 195 | | |
225 | | - | |
| 196 | + | |
| 197 | + | |
| 198 | + | |
226 | 199 | | |
227 | | - | |
228 | | - | |
229 | | - | |
230 | | - | |
231 | | - | |
232 | | - | |
233 | | - | |
234 | | - | |
235 | | - | |
236 | | - | |
237 | | - | |
238 | | - | |
239 | | - | |
240 | | - | |
241 | | - | |
242 | | - | |
243 | | - | |
244 | | - | |
245 | | - | |
246 | | - | |
247 | | - | |
| 200 | + | |
| 201 | + | |
| 202 | + | |
| 203 | + | |
| 204 | + | |
| 205 | + | |
| 206 | + | |
248 | 207 | | |
| 208 | + | |
249 | 209 | | |
250 | | - | |
251 | | - | |
| 210 | + | |
| 211 | + | |
252 | 212 | | |
253 | 213 | | |
254 | 214 | | |
| |||
0 commit comments