zstdify 1.2.0 → 1.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (63) hide show
  1. package/README.md +47 -9
  2. package/dist/bitstream/bitReaderReverse.d.ts +6 -0
  3. package/dist/bitstream/bitReaderReverse.js +38 -12
  4. package/dist/bitstream/bitReaderReverse.js.map +1 -1
  5. package/dist/bitstream/index.d.ts +1 -0
  6. package/dist/bitstream/index.js +1 -0
  7. package/dist/bitstream/index.js.map +1 -1
  8. package/dist/bitstream/reverseBitWriter.d.ts +1 -0
  9. package/dist/bitstream/reverseBitWriter.js +66 -0
  10. package/dist/bitstream/reverseBitWriter.js.map +1 -0
  11. package/dist/compress.js +46 -5
  12. package/dist/compress.js.map +1 -1
  13. package/dist/decode/debugTrace.d.ts +31 -0
  14. package/dist/decode/debugTrace.js +2 -0
  15. package/dist/decode/debugTrace.js.map +1 -0
  16. package/dist/decode/decompressFrame.d.ts +2 -1
  17. package/dist/decode/decompressFrame.js +96 -18
  18. package/dist/decode/decompressFrame.js.map +1 -1
  19. package/dist/decode/fusedSequences.d.ts +9 -0
  20. package/dist/decode/fusedSequences.js +26 -0
  21. package/dist/decode/fusedSequences.js.map +1 -0
  22. package/dist/decode/literals.js +129 -79
  23. package/dist/decode/literals.js.map +1 -1
  24. package/dist/decode/reconstruct.d.ts +14 -2
  25. package/dist/decode/reconstruct.js +378 -21
  26. package/dist/decode/reconstruct.js.map +1 -1
  27. package/dist/decode/sequences.d.ts +19 -7
  28. package/dist/decode/sequences.js +127 -48
  29. package/dist/decode/sequences.js.map +1 -1
  30. package/dist/decompress.d.ts +3 -0
  31. package/dist/decompress.js +1 -1
  32. package/dist/decompress.js.map +1 -1
  33. package/dist/encode/compressedBlock.d.ts +27 -1
  34. package/dist/encode/compressedBlock.js +573 -367
  35. package/dist/encode/compressedBlock.js.map +1 -1
  36. package/dist/encode/fastMatcher.d.ts +7 -0
  37. package/dist/encode/fastMatcher.js +13 -0
  38. package/dist/encode/fastMatcher.js.map +1 -0
  39. package/dist/encode/greedySequences.d.ts +9 -6
  40. package/dist/encode/greedySequences.js +22 -101
  41. package/dist/encode/greedySequences.js.map +1 -1
  42. package/dist/encode/lazyMatcher.d.ts +7 -0
  43. package/dist/encode/lazyMatcher.js +13 -0
  44. package/dist/encode/lazyMatcher.js.map +1 -0
  45. package/dist/encode/literalsEncoder.d.ts +14 -0
  46. package/dist/encode/literalsEncoder.js +343 -0
  47. package/dist/encode/literalsEncoder.js.map +1 -0
  48. package/dist/encode/optimalParser.d.ts +7 -0
  49. package/dist/encode/optimalParser.js +13 -0
  50. package/dist/encode/optimalParser.js.map +1 -0
  51. package/dist/encode/sequencePlanner.d.ts +23 -0
  52. package/dist/encode/sequencePlanner.js +280 -0
  53. package/dist/encode/sequencePlanner.js.map +1 -0
  54. package/dist/entropy/fse.d.ts +13 -6
  55. package/dist/entropy/fse.js +175 -8
  56. package/dist/entropy/fse.js.map +1 -1
  57. package/dist/entropy/huffman.d.ts +7 -5
  58. package/dist/entropy/huffman.js +18 -7
  59. package/dist/entropy/huffman.js.map +1 -1
  60. package/dist/entropy/index.d.ts +2 -2
  61. package/dist/entropy/weights.js +20 -14
  62. package/dist/entropy/weights.js.map +1 -1
  63. package/package.json +1 -1
@@ -0,0 +1,280 @@
1
+ const WINDOW_SIZE = 128 * 1024;
2
+ const MIN_MATCH = 3;
3
+ const HASH_BITS = 16;
4
+ const HASH_SIZE = 1 << HASH_BITS;
5
+ export function createSequencePlannerState() {
6
+ const historyHeads = new Int32Array(HASH_SIZE);
7
+ historyHeads.fill(-1);
8
+ return {
9
+ historyBytes: new Uint8Array(0),
10
+ historyChainPrev: new Int32Array(0),
11
+ historyHeads,
12
+ };
13
+ }
14
+ function hash3(data, pos) {
15
+ const a = data[pos];
16
+ const b = data[pos + 1];
17
+ const c = data[pos + 2];
18
+ return ((a * 2654435761 + b * 2246822519 + c * 3266489917) >>> 0) >>> (32 - HASH_BITS);
19
+ }
20
+ function bytesEqual(a, b) {
21
+ if (a.length !== b.length)
22
+ return false;
23
+ for (let i = 0; i < a.length; i++) {
24
+ if ((a[i] ?? 0) !== (b[i] ?? 0))
25
+ return false;
26
+ }
27
+ return true;
28
+ }
29
+ function buildChainPrev(data, historyLength, plannerState) {
30
+ const heads = new Int32Array(HASH_SIZE);
31
+ heads.fill(-1);
32
+ const chainPrev = new Int32Array(data.length);
33
+ chainPrev.fill(-1);
34
+ let startPos = 0;
35
+ if (plannerState &&
36
+ historyLength > 0 &&
37
+ plannerState.historyBytes.length === historyLength &&
38
+ plannerState.historyChainPrev.length === historyLength &&
39
+ bytesEqual(data.subarray(0, historyLength), plannerState.historyBytes)) {
40
+ chainPrev.set(plannerState.historyChainPrev, 0);
41
+ heads.set(plannerState.historyHeads);
42
+ startPos = historyLength;
43
+ }
44
+ for (let pos = startPos; pos + MIN_MATCH <= data.length; pos++) {
45
+ const h = hash3(data, pos);
46
+ const prev = heads[h];
47
+ chainPrev[pos] = prev;
48
+ heads[h] = pos;
49
+ }
50
+ return chainPrev;
51
+ }
52
+ function updatePlannerState(plannerState, combined, chainPrev) {
53
+ if (!plannerState)
54
+ return;
55
+ const historyStart = Math.max(0, combined.length - WINDOW_SIZE);
56
+ const historyLength = combined.length - historyStart;
57
+ const historyBytes = new Uint8Array(historyLength);
58
+ historyBytes.set(combined.subarray(historyStart), 0);
59
+ const historyChainPrev = new Int32Array(historyLength);
60
+ for (let pos = 0; pos < historyLength; pos++) {
61
+ const globalPos = historyStart + pos;
62
+ const prev = chainPrev[globalPos] ?? -1;
63
+ historyChainPrev[pos] = prev >= historyStart ? prev - historyStart : -1;
64
+ }
65
+ const historyHeads = new Int32Array(HASH_SIZE);
66
+ historyHeads.fill(-1);
67
+ for (let pos = 0; pos + MIN_MATCH <= historyLength; pos++) {
68
+ const h = hash3(historyBytes, pos);
69
+ historyHeads[h] = pos;
70
+ }
71
+ plannerState.historyBytes = historyBytes;
72
+ plannerState.historyChainPrev = historyChainPrev;
73
+ plannerState.historyHeads = historyHeads;
74
+ }
75
+ function longestMatch(data, pos, candidate, maxLength) {
76
+ let len = 0;
77
+ while (len + 8 <= maxLength) {
78
+ if (data[pos + len] !== data[candidate + len] ||
79
+ data[pos + len + 1] !== data[candidate + len + 1] ||
80
+ data[pos + len + 2] !== data[candidate + len + 2] ||
81
+ data[pos + len + 3] !== data[candidate + len + 3] ||
82
+ data[pos + len + 4] !== data[candidate + len + 4] ||
83
+ data[pos + len + 5] !== data[candidate + len + 5] ||
84
+ data[pos + len + 6] !== data[candidate + len + 6] ||
85
+ data[pos + len + 7] !== data[candidate + len + 7]) {
86
+ break;
87
+ }
88
+ len += 8;
89
+ }
90
+ while (len < maxLength && data[pos + len] === data[candidate + len]) {
91
+ len++;
92
+ }
93
+ return len;
94
+ }
95
+ function scoreMatch(length, offset, repOffsets, repScoreBonus) {
96
+ let score = length * 16;
97
+ if (offset === repOffsets[0])
98
+ score += repScoreBonus[0];
99
+ else if (offset === repOffsets[1])
100
+ score += repScoreBonus[1];
101
+ else if (offset === repOffsets[2])
102
+ score += repScoreBonus[2];
103
+ return score;
104
+ }
105
+ function findBestMatchAt(parse, pos, repOffsets) {
106
+ const data = parse.input;
107
+ if (pos + MIN_MATCH > data.length)
108
+ return null;
109
+ let candidate = parse.chainPrev[pos] ?? -1;
110
+ if (candidate < 0)
111
+ return null;
112
+ const minCandidate = Math.max(0, pos - WINDOW_SIZE);
113
+ const maxLength = data.length - pos;
114
+ let depth = 0;
115
+ let best = null;
116
+ while (candidate >= minCandidate && depth < parse.options.chainLimit) {
117
+ const offset = pos - candidate;
118
+ if (offset > 0 &&
119
+ data[pos] === data[candidate] &&
120
+ data[pos + 1] === data[candidate + 1] &&
121
+ data[pos + 2] === data[candidate + 2]) {
122
+ const length = longestMatch(data, pos, candidate, maxLength);
123
+ if (length >= MIN_MATCH) {
124
+ const score = scoreMatch(length, offset, repOffsets, parse.options.repScoreBonus);
125
+ if (!best || score > best.score || (score === best.score && length > best.length)) {
126
+ best = { pos, offset, length, score };
127
+ if (length >= maxLength)
128
+ break;
129
+ }
130
+ }
131
+ }
132
+ candidate = parse.chainPrev[candidate] ?? -1;
133
+ depth++;
134
+ }
135
+ return best;
136
+ }
137
+ function applyRepOffsetUpdate(repOffsets, offsetValue, literalsLength) {
138
+ const next = [repOffsets[0], repOffsets[1], repOffsets[2]];
139
+ const ll0 = literalsLength === 0;
140
+ const isNonRepeat = offsetValue > 3 || (offsetValue === 3 && ll0);
141
+ if (isNonRepeat) {
142
+ const actualOffset = offsetValue === 3 ? next[0] - 1 : offsetValue - 3;
143
+ next[2] = next[1];
144
+ next[1] = next[0];
145
+ next[0] = actualOffset;
146
+ return next;
147
+ }
148
+ let repeatIndex;
149
+ if (ll0)
150
+ repeatIndex = offsetValue === 1 ? 1 : 2;
151
+ else
152
+ repeatIndex = (offsetValue - 1);
153
+ if (repeatIndex === 1) {
154
+ next[1] = next[0];
155
+ next[0] = repOffsets[1];
156
+ }
157
+ else if (repeatIndex === 2) {
158
+ next[2] = next[1];
159
+ next[1] = next[0];
160
+ next[0] = repOffsets[2];
161
+ }
162
+ return next;
163
+ }
164
+ function toOffsetValue(offset, literalsLength, repOffsets) {
165
+ // Keep conservative non-repeat offset encoding for interoperability.
166
+ // Repeat-offset modeling is still used for scoring/search decisions.
167
+ const offsetValue = offset + 3;
168
+ return {
169
+ offsetValue,
170
+ nextRepOffsets: applyRepOffsetUpdate(repOffsets, offsetValue, literalsLength),
171
+ };
172
+ }
173
+ function copyLiterals(dst, dstOffset, data, srcStart, srcEnd) {
174
+ if (srcEnd <= srcStart)
175
+ return dstOffset;
176
+ dst.set(data.subarray(srcStart, srcEnd), dstOffset);
177
+ return dstOffset + (srcEnd - srcStart);
178
+ }
179
+ function pickMatch(parse, pos) {
180
+ const direct = findBestMatchAt(parse, pos, parse.repOffsets);
181
+ if (parse.options.searchWindow <= 1)
182
+ return direct;
183
+ let best = direct;
184
+ let bestScore = best?.score ?? 0;
185
+ const end = Math.min(parse.input.length - MIN_MATCH, pos + parse.options.searchWindow - 1);
186
+ const maxRepBonus = Math.max(...parse.options.repScoreBonus);
187
+ for (let probePos = pos + 1; probePos <= end; probePos++) {
188
+ const delayed = probePos - pos;
189
+ const maxProbeLength = parse.input.length - probePos;
190
+ const theoreticalBestDelayedScore = maxProbeLength * 16 + maxRepBonus - delayed * 8;
191
+ if (theoreticalBestDelayedScore <= bestScore) {
192
+ break;
193
+ }
194
+ const probeCandidate = parse.chainPrev[probePos] ?? -1;
195
+ if (probeCandidate < 0 || probeCandidate < Math.max(0, probePos - WINDOW_SIZE))
196
+ continue;
197
+ const probe = findBestMatchAt(parse, probePos, parse.repOffsets);
198
+ if (!probe)
199
+ continue;
200
+ const delayedScore = probe.score - delayed * 8;
201
+ if (!best || delayedScore > bestScore) {
202
+ best = { ...probe, score: delayedScore };
203
+ bestScore = delayedScore;
204
+ }
205
+ }
206
+ return best;
207
+ }
208
+ export function planSequences(input, options) {
209
+ if (input.length < MIN_MATCH) {
210
+ return {
211
+ literals: input.slice(),
212
+ sequences: [],
213
+ trailingLiterals: input.length,
214
+ finalRepOffsets: options.repOffsets ?? [1, 4, 8],
215
+ };
216
+ }
217
+ const history = options.history && options.history.length > 0
218
+ ? options.history.subarray(Math.max(0, options.history.length - WINDOW_SIZE))
219
+ : new Uint8Array(0);
220
+ const historyLength = history.length;
221
+ const combined = new Uint8Array(historyLength + input.length);
222
+ if (historyLength > 0)
223
+ combined.set(history, 0);
224
+ combined.set(input, historyLength);
225
+ const parse = {
226
+ input: combined,
227
+ chainPrev: buildChainPrev(combined, historyLength, options.plannerState),
228
+ repOffsets: options.repOffsets ? [options.repOffsets[0], options.repOffsets[1], options.repOffsets[2]] : [1, 4, 8],
229
+ options: {
230
+ chainLimit: Math.max(1, options.chainLimit),
231
+ repScoreBonus: options.repScoreBonus ?? [48, 24, 12],
232
+ lazyDepth: Math.max(0, options.lazyDepth ?? 0),
233
+ searchWindow: Math.max(1, options.searchWindow ?? 1),
234
+ },
235
+ };
236
+ const sequences = [];
237
+ const literals = new Uint8Array(input.length);
238
+ let literalOut = 0;
239
+ let anchor = historyLength;
240
+ let pos = historyLength;
241
+ while (pos + MIN_MATCH <= combined.length) {
242
+ let best = pickMatch(parse, pos);
243
+ if (best && parse.options.lazyDepth > 0 && best.pos === pos) {
244
+ const maxDelta = Math.min(parse.options.lazyDepth, combined.length - pos - MIN_MATCH);
245
+ for (let delta = 1; delta <= maxDelta; delta++) {
246
+ const candidate = findBestMatchAt(parse, pos + delta, parse.repOffsets);
247
+ if (!candidate)
248
+ continue;
249
+ if (candidate.score > best.score + delta * 8)
250
+ best = { ...candidate };
251
+ }
252
+ }
253
+ if (!best || best.length < MIN_MATCH) {
254
+ pos++;
255
+ continue;
256
+ }
257
+ const matchPos = best.pos;
258
+ const literalsLength = matchPos - anchor;
259
+ literalOut = copyLiterals(literals, literalOut, combined, anchor, matchPos);
260
+ const { offsetValue, nextRepOffsets } = toOffsetValue(best.offset, literalsLength, parse.repOffsets);
261
+ sequences.push({
262
+ literalsLength,
263
+ offset: offsetValue,
264
+ matchLength: best.length,
265
+ });
266
+ parse.repOffsets = nextRepOffsets;
267
+ anchor = matchPos + best.length;
268
+ pos = anchor;
269
+ }
270
+ const trailingLiterals = combined.length - anchor;
271
+ literalOut = copyLiterals(literals, literalOut, combined, anchor, combined.length);
272
+ updatePlannerState(options.plannerState, combined, parse.chainPrev);
273
+ return {
274
+ literals: literalOut < literals.length ? literals.subarray(0, literalOut) : literals,
275
+ sequences,
276
+ trailingLiterals,
277
+ finalRepOffsets: [parse.repOffsets[0], parse.repOffsets[1], parse.repOffsets[2]],
278
+ };
279
+ }
280
+ //# sourceMappingURL=sequencePlanner.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sequencePlanner.js","sourceRoot":"","sources":["../../src/encode/sequencePlanner.ts"],"names":[],"mappings":"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"}
@@ -3,21 +3,23 @@
3
3
  * Zstd FSE streams are read backward.
4
4
  */
5
5
  import type { BitReaderReverse } from '../bitstream/bitReaderReverse.js';
6
- export interface FSEDecodeRow {
7
- symbol: number;
8
- numBits: number;
9
- baseline: number;
6
+ export interface FSEDecodeTable {
7
+ symbol: Uint16Array;
8
+ numBits: Uint8Array;
9
+ baseline: Int32Array;
10
+ tableLog: number;
11
+ length: number;
10
12
  }
11
13
  /**
12
14
  * Build FSE decode table from normalized counts.
13
15
  * Counts are -1 for "less than 1" (full state reset) symbols.
14
16
  * Based on zstd FSE_buildDTable logic.
15
17
  */
16
- export declare function buildFSEDecodeTable(normalizedCounter: readonly number[], tableLog: number): FSEDecodeRow[];
18
+ export declare function buildFSEDecodeTable(normalizedCounter: readonly number[], tableLog: number): FSEDecodeTable;
17
19
  /**
18
20
  * Decode one FSE symbol. Updates state in place.
19
21
  */
20
- export declare function decodeFSESymbol(table: readonly FSEDecodeRow[], _tableLog: number, reader: BitReaderReverse, state: {
22
+ export declare function decodeFSESymbol(table: FSEDecodeTable, _tableLog: number, reader: BitReaderReverse, state: {
21
23
  value: number;
22
24
  }): number;
23
25
  /**
@@ -31,3 +33,8 @@ export declare function readNCount(data: Uint8Array, offset: number, maxSymbolVa
31
33
  maxSymbolValue: number;
32
34
  bytesRead: number;
33
35
  };
36
+ export declare function normalizeCountsForTable(counts: readonly number[], tableLog: number): {
37
+ normalizedCounter: number[];
38
+ maxSymbolValue: number;
39
+ };
40
+ export declare function writeNCount(normalizedCounter: readonly number[], maxSymbolValue: number, tableLog: number): Uint8Array;
@@ -3,6 +3,7 @@
3
3
  * Zstd FSE streams are read backward.
4
4
  */
5
5
  import { ZstdError } from '../errors.js';
6
+ const FSE_MIN_TABLELOG = 5;
6
7
  const FSE_TABLESTEP = (tableSize) => (tableSize >> 1) + (tableSize >> 3) + 3;
7
8
  /**
8
9
  * Build FSE decode table from normalized counts.
@@ -43,7 +44,9 @@ export function buildFSEDecodeTable(normalizedCounter, tableLog) {
43
44
  } while (position > highThreshold);
44
45
  }
45
46
  }
46
- const table = new Array(tableSize);
47
+ const symbolByState = new Uint16Array(tableSize);
48
+ const numBitsByState = new Uint8Array(tableSize);
49
+ const baselineByState = new Int32Array(tableSize);
47
50
  for (let u = 0; u < tableSize; u++) {
48
51
  const symbol = tableSymbol[u];
49
52
  if (symbol === undefined) {
@@ -55,20 +58,29 @@ export function buildFSEDecodeTable(normalizedCounter, tableLog) {
55
58
  symbolNext[symbol] = nextState + 1;
56
59
  const nbBits = tableLog - 31 + Math.clz32(nextState);
57
60
  const baseline = (nextState << nbBits) - tableSize;
58
- table[u] = { symbol, numBits: nbBits, baseline };
61
+ symbolByState[u] = symbol;
62
+ numBitsByState[u] = nbBits;
63
+ baselineByState[u] = baseline;
59
64
  }
60
- return table;
65
+ return {
66
+ symbol: symbolByState,
67
+ numBits: numBitsByState,
68
+ baseline: baselineByState,
69
+ tableLog,
70
+ length: tableSize,
71
+ };
61
72
  }
62
73
  /**
63
74
  * Decode one FSE symbol. Updates state in place.
64
75
  */
65
76
  export function decodeFSESymbol(table, _tableLog, reader, state) {
66
- const row = table[state.value];
67
- if (!row)
77
+ const stateValue = state.value;
78
+ if (stateValue < 0 || stateValue >= table.length) {
68
79
  throw new ZstdError('FSE invalid state', 'corruption_detected');
69
- const symbol = row.symbol;
70
- const nbBits = row.numBits;
71
- const baseline = row.baseline;
80
+ }
81
+ const symbol = table.symbol[stateValue];
82
+ const nbBits = table.numBits[stateValue];
83
+ const baseline = table.baseline[stateValue];
72
84
  const bits = nbBits > 0 ? reader.readBits(nbBits) : 0;
73
85
  state.value = baseline + bits;
74
86
  return symbol;
@@ -210,4 +222,159 @@ export function readNCount(data, offset, maxSymbolValue, maxTableLog) {
210
222
  }
211
223
  return parseBody(data.subarray(offset), remainingInput);
212
224
  }
225
+ export function normalizeCountsForTable(counts, tableLog) {
226
+ const tableSize = 1 << tableLog;
227
+ if (tableSize <= 0) {
228
+ throw new ZstdError('FSE normalize: invalid tableLog', 'parameter_unsupported');
229
+ }
230
+ const maxSymbolValue = counts.length - 1;
231
+ if (maxSymbolValue < 0) {
232
+ throw new ZstdError('FSE normalize: empty counts', 'parameter_unsupported');
233
+ }
234
+ const normalizedCounter = new Array(counts.length).fill(0);
235
+ let total = 0;
236
+ let nonZero = 0;
237
+ for (let s = 0; s < counts.length; s++) {
238
+ const c = counts[s] ?? 0;
239
+ if (c > 0) {
240
+ total += c;
241
+ nonZero++;
242
+ }
243
+ }
244
+ if (total <= 0 || nonZero === 0) {
245
+ throw new ZstdError('FSE normalize: empty distribution', 'parameter_unsupported');
246
+ }
247
+ if (nonZero > tableSize) {
248
+ throw new ZstdError('FSE normalize: table too small for distribution', 'parameter_unsupported');
249
+ }
250
+ const remainders = new Array(counts.length).fill(0);
251
+ let assigned = 0;
252
+ for (let s = 0; s < counts.length; s++) {
253
+ const c = counts[s] ?? 0;
254
+ if (c <= 0)
255
+ continue;
256
+ const scaled = (c * tableSize) / total;
257
+ let value = Math.floor(scaled);
258
+ if (value < 1)
259
+ value = 1;
260
+ normalizedCounter[s] = value;
261
+ remainders[s] = scaled - Math.floor(scaled);
262
+ assigned += value;
263
+ }
264
+ while (assigned > tableSize) {
265
+ let bestSymbol = -1;
266
+ let bestCount = 0;
267
+ for (let s = 0; s < normalizedCounter.length; s++) {
268
+ const n = normalizedCounter[s] ?? 0;
269
+ if (n > 1 && n > bestCount) {
270
+ bestCount = n;
271
+ bestSymbol = s;
272
+ }
273
+ }
274
+ if (bestSymbol < 0) {
275
+ throw new ZstdError('FSE normalize: failed to reduce distribution', 'parameter_unsupported');
276
+ }
277
+ normalizedCounter[bestSymbol] = (normalizedCounter[bestSymbol] ?? 1) - 1;
278
+ assigned--;
279
+ }
280
+ while (assigned < tableSize) {
281
+ let bestSymbol = -1;
282
+ let bestRemainder = -1;
283
+ let bestCount = -1;
284
+ for (let s = 0; s < normalizedCounter.length; s++) {
285
+ const n = normalizedCounter[s] ?? 0;
286
+ if (n <= 0)
287
+ continue;
288
+ const rem = remainders[s] ?? 0;
289
+ if (rem > bestRemainder || (rem === bestRemainder && n > bestCount)) {
290
+ bestRemainder = rem;
291
+ bestCount = n;
292
+ bestSymbol = s;
293
+ }
294
+ }
295
+ if (bestSymbol < 0) {
296
+ throw new ZstdError('FSE normalize: failed to complete distribution', 'parameter_unsupported');
297
+ }
298
+ normalizedCounter[bestSymbol] = (normalizedCounter[bestSymbol] ?? 0) + 1;
299
+ assigned++;
300
+ }
301
+ return { normalizedCounter, maxSymbolValue };
302
+ }
303
+ export function writeNCount(normalizedCounter, maxSymbolValue, tableLog) {
304
+ if (tableLog < FSE_MIN_TABLELOG) {
305
+ throw new ZstdError('FSE writeNCount: tableLog too small', 'parameter_unsupported');
306
+ }
307
+ if (maxSymbolValue < 0 || maxSymbolValue >= normalizedCounter.length) {
308
+ throw new ZstdError('FSE writeNCount: invalid max symbol', 'parameter_unsupported');
309
+ }
310
+ const tableSize = 1 << tableLog;
311
+ const out = [];
312
+ let bitStream = 0 >>> 0;
313
+ let bitCount = 0;
314
+ let nbBits = tableLog + 1;
315
+ let remaining = tableSize + 1;
316
+ let threshold = tableSize;
317
+ let symbol = 0;
318
+ const alphabetSize = maxSymbolValue + 1;
319
+ let previousIs0 = false;
320
+ const flush16 = () => {
321
+ out.push(bitStream & 0xff, (bitStream >>> 8) & 0xff);
322
+ bitStream >>>= 16;
323
+ bitCount -= 16;
324
+ };
325
+ bitStream = (bitStream + ((tableLog - FSE_MIN_TABLELOG) << bitCount)) >>> 0;
326
+ bitCount += 4;
327
+ while (symbol < alphabetSize && remaining > 1) {
328
+ if (previousIs0) {
329
+ let start = symbol;
330
+ while (symbol < alphabetSize && (normalizedCounter[symbol] ?? 0) === 0)
331
+ symbol++;
332
+ if (symbol === alphabetSize)
333
+ break;
334
+ while (symbol >= start + 24) {
335
+ start += 24;
336
+ bitStream = (bitStream + ((0xffff << bitCount) >>> 0)) >>> 0;
337
+ flush16();
338
+ }
339
+ while (symbol >= start + 3) {
340
+ start += 3;
341
+ bitStream = (bitStream + ((3 << bitCount) >>> 0)) >>> 0;
342
+ bitCount += 2;
343
+ }
344
+ bitStream = (bitStream + ((symbol - start) << bitCount)) >>> 0;
345
+ bitCount += 2;
346
+ while (bitCount > 16) {
347
+ flush16();
348
+ }
349
+ }
350
+ let count = normalizedCounter[symbol] ?? 0;
351
+ symbol++;
352
+ const max = 2 * threshold - 1 - remaining;
353
+ remaining -= count < 0 ? -count : count;
354
+ count += 1;
355
+ if (count >= threshold)
356
+ count += max;
357
+ bitStream = (bitStream + (((count >>> 0) << bitCount) >>> 0)) >>> 0;
358
+ bitCount += nbBits;
359
+ if (count < max)
360
+ bitCount -= 1;
361
+ previousIs0 = count === 1;
362
+ if (remaining < 1) {
363
+ throw new ZstdError('FSE writeNCount: invalid normalized distribution', 'parameter_unsupported');
364
+ }
365
+ while (remaining < threshold) {
366
+ nbBits--;
367
+ threshold >>= 1;
368
+ }
369
+ while (bitCount > 16) {
370
+ flush16();
371
+ }
372
+ }
373
+ if (remaining !== 1) {
374
+ throw new ZstdError('FSE writeNCount: invalid normalized sum', 'parameter_unsupported');
375
+ }
376
+ out.push(bitStream & 0xff, (bitStream >>> 8) & 0xff);
377
+ const finalSize = out.length - (2 - ((bitCount + 7) >> 3));
378
+ return new Uint8Array(out.slice(0, finalSize));
379
+ }
213
380
  //# sourceMappingURL=fse.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"fse.js","sourceRoot":"","sources":["../../src/entropy/fse.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"fse.js","sourceRoot":"","sources":["../../src/entropy/fse.ts"],"names":[],"mappings":"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"}
@@ -3,9 +3,11 @@
3
3
  * Zstd Huffman streams are read backward.
4
4
  */
5
5
  import type { BitReaderReverse } from '../bitstream/bitReaderReverse.js';
6
- export interface HuffmanDecodeRow {
7
- symbol: number;
8
- numBits: number;
6
+ export interface HuffmanDecodeTable {
7
+ symbol: Uint8Array;
8
+ numBits: Uint8Array;
9
+ maxNumBits: number;
10
+ length: number;
9
11
  }
10
12
  /**
11
13
  * Convert weights to number of bits per symbol.
@@ -17,8 +19,8 @@ export declare function weightsToNumBits(weights: readonly number[], maxNumBits:
17
19
  * Build Huffman decode table from symbol bit lengths.
18
20
  * Returns table indexed by prefix code (first maxNumBits bits).
19
21
  */
20
- export declare function buildHuffmanDecodeTable(numBits: readonly number[], maxNumBits: number): HuffmanDecodeRow[];
22
+ export declare function buildHuffmanDecodeTable(numBits: readonly number[], maxNumBits: number): HuffmanDecodeTable;
21
23
  /**
22
24
  * Decode one Huffman symbol. Reader must be positioned at start of code.
23
25
  */
24
- export declare function decodeHuffmanSymbol(table: readonly HuffmanDecodeRow[], maxNumBits: number, reader: BitReaderReverse): number;
26
+ export declare function decodeHuffmanSymbol(table: HuffmanDecodeTable, maxNumBits: number, reader: BitReaderReverse): number;