Index: webrtc/modules/rtp_rtcp/source/vp8_partition_aggregator.h |
diff --git a/webrtc/modules/rtp_rtcp/source/vp8_partition_aggregator.h b/webrtc/modules/rtp_rtcp/source/vp8_partition_aggregator.h |
deleted file mode 100644 |
index ccd22e5be2141acfd6ded55ad5bcda39be264e54..0000000000000000000000000000000000000000 |
--- a/webrtc/modules/rtp_rtcp/source/vp8_partition_aggregator.h |
+++ /dev/null |
@@ -1,137 +0,0 @@ |
-/* |
- * Copyright (c) 2011 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 WEBRTC_MODULES_RTP_RTCP_SOURCE_VP8_PARTITION_AGGREGATOR_H_ |
-#define WEBRTC_MODULES_RTP_RTCP_SOURCE_VP8_PARTITION_AGGREGATOR_H_ |
- |
-#include <vector> |
- |
-#include "webrtc/base/constructormagic.h" |
-#include "webrtc/modules/include/module_common_types.h" |
-#include "webrtc/typedefs.h" |
- |
-namespace webrtc { |
- |
-// Class used to solve the VP8 aggregation problem. |
-class PartitionTreeNode { |
- public: |
- // Create a tree node. |
- PartitionTreeNode(PartitionTreeNode* parent, |
- const size_t* size_vector, |
- size_t num_partitions, |
- size_t this_size); |
- |
- // Create a root node. |
- static PartitionTreeNode* CreateRootNode(const size_t* size_vector, |
- size_t num_partitions); |
- |
- ~PartitionTreeNode(); |
- |
- // Calculate the cost for the node. If the node is a solution node, the cost |
- // will be the actual cost associated with that solution. If not, the cost |
- // will be the cost accumulated so far along the current branch (which is a |
- // lower bound for any solution along the branch). |
- int Cost(size_t penalty); |
- |
- // Create the two children for this node. |
- bool CreateChildren(size_t max_size); |
- |
- // Get the number of packets for the configuration that this node represents. |
- size_t NumPackets(); |
- |
- // Find the optimal solution given a maximum packet size and a per-packet |
- // penalty. The method will be recursively called while the solver is |
- // probing down the tree of nodes. |
- PartitionTreeNode* GetOptimalNode(size_t max_size, size_t penalty); |
- |
- // Setters and getters. |
- void set_max_parent_size(int size) { max_parent_size_ = size; } |
- void set_min_parent_size(int size) { min_parent_size_ = size; } |
- PartitionTreeNode* parent() const { return parent_; } |
- PartitionTreeNode* left_child() const { return children_[kLeftChild]; } |
- PartitionTreeNode* right_child() const { return children_[kRightChild]; } |
- size_t this_size() const { return this_size_; } |
- bool packet_start() const { return packet_start_; } |
- |
- private: |
- enum Children { |
- kLeftChild = 0, |
- kRightChild = 1 |
- }; |
- |
- int this_size_int() const { return static_cast<int>(this_size_); } |
- void set_packet_start(bool value) { packet_start_ = value; } |
- |
- PartitionTreeNode* parent_; |
- PartitionTreeNode* children_[2]; |
- size_t this_size_; |
- const size_t* size_vector_; |
- size_t num_partitions_; |
- int max_parent_size_; |
- int min_parent_size_; |
- bool packet_start_; |
- |
- RTC_DISALLOW_COPY_AND_ASSIGN(PartitionTreeNode); |
-}; |
- |
-// Class that calculates the optimal aggregation of VP8 partitions smaller than |
-// the maximum packet size. |
-class Vp8PartitionAggregator { |
- public: |
- typedef std::vector<size_t> ConfigVec; |
- |
- // Constructor. All partitions in the fragmentation header from index |
- // first_partition_idx to last_partition_idx must be smaller than |
- // maximum packet size to be used in FindOptimalConfiguration. |
- Vp8PartitionAggregator(const RTPFragmentationHeader& fragmentation, |
- size_t first_partition_idx, |
- size_t last_partition_idx); |
- |
- ~Vp8PartitionAggregator(); |
- |
- // Set the smallest and largest payload sizes produces so far. |
- void SetPriorMinMax(int min_size, int max_size); |
- |
- // Find the aggregation of VP8 partitions that produces the smallest cost. |
- // The result is given as a vector of the same length as the number of |
- // partitions given to the constructor (i.e., last_partition_idx - |
- // first_partition_idx + 1), where each element indicates the packet index |
- // for that partition. Thus, the output vector starts at 0 and is increasing |
- // up to the number of packets - 1. |
- ConfigVec FindOptimalConfiguration(size_t max_size, size_t penalty); |
- |
- // Calculate minimum and maximum packet sizes for a given aggregation config. |
- // The extreme packet sizes of the given aggregation are compared with the |
- // values given in min_size and max_size, and if either of these are exceeded, |
- // the new extreme value will be written to the corresponding variable. |
- void CalcMinMax(const ConfigVec& config, int* min_size, int* max_size) const; |
- |
- // Calculate the number of fragments to divide a large partition into. |
- // The large partition is of size large_partition_size. The payload must not |
- // be larger than max_payload_size. Each fragment comes at an overhead cost |
- // of penalty bytes. If the size of the fragments fall outside the range |
- // [min_size, max_size], an extra cost is inflicted. |
- static size_t CalcNumberOfFragments(size_t large_partition_size, |
- size_t max_payload_size, |
- size_t penalty, |
- int min_size, |
- int max_size); |
- |
- private: |
- PartitionTreeNode* root_; |
- size_t num_partitions_; |
- size_t* size_vector_; |
- size_t largest_partition_size_; |
- |
- RTC_DISALLOW_COPY_AND_ASSIGN(Vp8PartitionAggregator); |
-}; |
-} // namespace webrtc |
- |
-#endif // WEBRTC_MODULES_RTP_RTCP_SOURCE_VP8_PARTITION_AGGREGATOR_H_ |