diff options
author | Daniil Cherednik <dan.cherednik@gmail.com> | 2025-05-03 22:07:17 +0200 |
---|---|---|
committer | Daniil Cherednik <dan.cherednik@gmail.com> | 2025-05-03 22:07:17 +0200 |
commit | 98338613d8821f592682928c1096550596cb2550 (patch) | |
tree | abc2318c96ee2a14f06ba1028fb8663f6a6ee35a /src/lib/bs_encode/encode.cpp | |
parent | 177622ee9513784a21d9f10ab0c1e9774c0ddc71 (diff) | |
download | atracdenc-98338613d8821f592682928c1096550596cb2550.tar.gz |
[AT3P] Adjust number of quant units during encoding.
Diffstat (limited to 'src/lib/bs_encode/encode.cpp')
-rw-r--r-- | src/lib/bs_encode/encode.cpp | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/src/lib/bs_encode/encode.cpp b/src/lib/bs_encode/encode.cpp index 4c17ce9..230ae0f 100644 --- a/src/lib/bs_encode/encode.cpp +++ b/src/lib/bs_encode/encode.cpp @@ -32,6 +32,7 @@ public: void DoSubmit(size_t gotBits) noexcept; bool DoCheck(size_t gotBits) const noexcept; void DoRun(void* frameData, TBitStream& bs); + uint32_t DoGetCurGlobalConsumption() const noexcept; private: std::vector<IBitStreamPartEncoder::TPtr> Encoders; size_t CurEncPos; @@ -109,6 +110,9 @@ void TBitStreamEncoder::TImpl::DoRun(void* frameData, TBitStream& bs) } if (status == IBitStreamPartEncoder::EStatus::Repeat) { cont = true; + for (size_t i = 0; i < CurEncPos; i++) { + Encoders[i]->Reset(); + } RepeatEncPos = 0; break; } @@ -120,6 +124,15 @@ void TBitStreamEncoder::TImpl::DoRun(void* frameData, TBitStream& bs) } } +uint32_t TBitStreamEncoder::TImpl::DoGetCurGlobalConsumption() const noexcept +{ + uint32_t consumption = 0; + for (size_t i = 0; i < CurEncPos; i++) { + consumption += Encoders[i]->GetConsumption(); + } + return consumption; +} + ///// TBitStreamEncoder::TBitStreamEncoder(std::vector<IBitStreamPartEncoder::TPtr>&& encoders) @@ -161,4 +174,11 @@ bool TBitAllocHandler::Check(size_t gotBits) const noexcept const TBitStreamEncoder::TImpl* self = static_cast<const TBitStreamEncoder::TImpl*>(this); return self->DoCheck(gotBits); } + +uint32_t TBitAllocHandler::GetCurGlobalConsumption() const noexcept +{ + const TBitStreamEncoder::TImpl* self = static_cast<const TBitStreamEncoder::TImpl*>(this); + return self->DoGetCurGlobalConsumption(); +} + } |