aboutsummaryrefslogtreecommitdiffstats
path: root/src/lib/bs_encode/encode.cpp
diff options
context:
space:
mode:
authorDaniil Cherednik <dan.cherednik@gmail.com>2025-05-03 22:07:17 +0200
committerDaniil Cherednik <dan.cherednik@gmail.com>2025-05-03 22:07:17 +0200
commit98338613d8821f592682928c1096550596cb2550 (patch)
treeabc2318c96ee2a14f06ba1028fb8663f6a6ee35a /src/lib/bs_encode/encode.cpp
parent177622ee9513784a21d9f10ab0c1e9774c0ddc71 (diff)
downloadatracdenc-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.cpp20
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();
+}
+
}