arithmetic_coder 1.0.4
arithmetic_coder: ^1.0.4 copied to clipboard
Adaptive arithmetic coding for efficient lossless compression of bytes in pure Dart.
1.0.4 #
-
ArithmeticCoder:- Exposed
buildContextModelmethod to allow customization of the context model creation. - Renamed
_buildModelsto_buildContextModelCachedand updated to usebuildContextModel. - Updated
decodemethod to usemodels.eofsymbol dynamically instead of hardcoded256.
- Exposed
-
ContextModelandContextState:- Added support for order-3 context model:
- Added
ContextStateOrder3with three previous symbols. - Added
ContextModelOrder3with a 3D Fenwick tree structure and a shrink factor to reduce memory usage.
- Added
- Added
ordergetter toContextStateandContextModelto indicate the model order. - Added static
maxContextOrderconstant (value 3) toContextModel. - Updated factory constructor in
ContextModelto support order 3. - Updated all context state classes to implement
ordergetter. - Updated all context model classes to implement
ordergetter. ContextModelOrder3:- Uses a 3D list of Fenwicks with size reduction on the 3rd dimension.
- Added support for order-3 context model:
1.0.3 #
Fenwick- reduce memory usage:- Updated
_treefield initialization to use typed lists (Uint8List,Uint16List,Uint32List,Uint64List) based on the bit length ofmaxTotalfor memory efficiency. - Added private static method
_buildIntListto create appropriate typed list for frequency storage. - Adjusted
computeMaxTotalto return(1 << (precision ~/ 2)) - 1instead of1 << (precision ~/ 2)to correctly compute maximum total frequency. - Changed
_treeinitialization fromList.filledto use_buildIntListin constructor.
- Updated
1.0.2 #
-
Added context modeling support to
ArithmeticCoder:- Added
orderparameter to specify finite-order Markov models (0, 1, or 2). - Integrated
ContextModelabstraction with adaptive Fenwick trees per context. - Updated encoding and decoding to use context-dependent frequency models.
- Added
toStringoverride toArithmeticCodershowing order and model size.
- Added
-
ContextModel:- Introduced abstract
ContextModelwith factory constructor for orders 0, 1, and 2. - Implemented
ContextModelOrder0,ContextModelOrder1, andContextModelOrder2with correspondingContextStateclasses. - Each model maintains Fenwick trees for symbol frequencies per context.
- Adaptive frequency updates and context state transitions implemented.
- Introduced abstract
-
arithmetic_coder.dart:- Refactored to use
ContextModelfor symbol frequency management. - Encoding and decoding now maintain and update context states.
- Added detailed comments on algorithm and context modeling.
- Refactored to use
-
example/arithmetic_coder_example.dart:- Updated example to use
ArithmeticCoder(order: 2). - Increased input repetition count for better compression demonstration.
- Added output of compression ratio and integrity check.
- Added helper
_listEqualsfor byte list comparison.
- Updated example to use
-
test/arithmetic_coder_test.dart:- Parameterized tests to run for orders 0, 1, and 2.
- Removed redundant
ArithmeticCoderinstantiations inside tests. - Verified encode-decode correctness and compression ratio for all orders.
-
pubspec.yaml:- Bumped version to
1.0.1.
- Bumped version to
1.0.0 #
- Initial version.