| /* |
| * Copyright (c) 2020 The WebRTC project authors. All Rights Reserved. |
| * |
| * Use of this source code is governed by a BSD-style license |
| * that can be found in the LICENSE file in the root of the source |
| * tree. An additional intellectual property rights grant can be found |
| * in the file PATENTS. All contributing project authors may |
| * be found in the AUTHORS file in the root of the source tree. |
| */ |
| |
| #ifndef MODULES_VIDEO_CODING_CHAIN_DIFF_CALCULATOR_H_ |
| #define MODULES_VIDEO_CODING_CHAIN_DIFF_CALCULATOR_H_ |
| |
| #include <stdint.h> |
| |
| #include <vector> |
| |
| #include "absl/container/inlined_vector.h" |
| #include "absl/types/optional.h" |
| |
| namespace webrtc { |
| |
| // This class is thread compatible. |
| class ChainDiffCalculator { |
| public: |
| ChainDiffCalculator() = default; |
| ChainDiffCalculator(const ChainDiffCalculator&) = default; |
| ChainDiffCalculator& operator=(const ChainDiffCalculator&) = default; |
| |
| // Restarts chains, i.e. for position where chains[i] == true next chain_diff |
| // will be 0. Saves chains.size() as number of chains in the stream. |
| void Reset(const std::vector<bool>& chains); |
| |
| // Returns chain diffs based on flags if frame is part of the chain. |
| absl::InlinedVector<int, 4> From(int64_t frame_id, |
| const std::vector<bool>& chains); |
| |
| private: |
| absl::InlinedVector<int, 4> ChainDiffs(int64_t frame_id) const; |
| |
| absl::InlinedVector<absl::optional<int64_t>, 4> last_frame_in_chain_; |
| }; |
| |
| } // namespace webrtc |
| |
| #endif // MODULES_VIDEO_CODING_CHAIN_DIFF_CALCULATOR_H_ |