diff options
author | Devtools Arcadia <arcadia-devtools@yandex-team.ru> | 2022-02-07 18:08:42 +0300 |
---|---|---|
committer | Devtools Arcadia <arcadia-devtools@mous.vla.yp-c.yandex.net> | 2022-02-07 18:08:42 +0300 |
commit | 1110808a9d39d4b808aef724c861a2e1a38d2a69 (patch) | |
tree | e26c9fed0de5d9873cce7e00bc214573dc2195b7 /library/cpp/monlib/metrics/histogram_collector_explicit.cpp | |
download | ydb-1110808a9d39d4b808aef724c861a2e1a38d2a69.tar.gz |
intermediate changes
ref:cde9a383711a11544ce7e107a78147fb96cc4029
Diffstat (limited to 'library/cpp/monlib/metrics/histogram_collector_explicit.cpp')
-rw-r--r-- | library/cpp/monlib/metrics/histogram_collector_explicit.cpp | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/library/cpp/monlib/metrics/histogram_collector_explicit.cpp b/library/cpp/monlib/metrics/histogram_collector_explicit.cpp new file mode 100644 index 0000000000..377fc233ef --- /dev/null +++ b/library/cpp/monlib/metrics/histogram_collector_explicit.cpp @@ -0,0 +1,55 @@ +#include "histogram_collector.h" +#include "atomics_array.h" + +#include <util/generic/algorithm.h> +#include <util/generic/vector.h> +#include <util/generic/yexception.h> +#include <util/generic/ylimits.h> + +namespace NMonitoring { + + /////////////////////////////////////////////////////////////////////////// + // TExplicitHistogramCollector + /////////////////////////////////////////////////////////////////////////// + class TExplicitHistogramCollector: public IHistogramCollector { + public: + TExplicitHistogramCollector(TBucketBounds bounds) + : Values_(bounds.size() + 1) + , Bounds_(std::move(bounds)) + { + // add one bucket as +INF + Bounds_.push_back(Max<TBucketBound>()); + } + + void Collect(double value, ui32 count) override { + auto it = LowerBound(Bounds_.begin(), Bounds_.end(), value); + auto index = std::distance(Bounds_.begin(), it); + Values_.Add(index, count); + } + + void Reset() override { + Values_.Reset(); + } + + IHistogramSnapshotPtr Snapshot() const override { + auto values = Values_.Copy(); + return ExplicitHistogramSnapshot(Bounds_, values); + } + + private: + TAtomicsArray Values_; + TBucketBounds Bounds_; + }; + + IHistogramCollectorPtr ExplicitHistogram(TBucketBounds bounds) { + Y_ENSURE(bounds.size() >= 1, + "explicit histogram must contain at least one bucket"); + Y_ENSURE(bounds.size() <= HISTOGRAM_MAX_BUCKETS_COUNT, + "buckets count must be <=" << HISTOGRAM_MAX_BUCKETS_COUNT + << ", but got: " << bounds.size()); + Y_ENSURE(IsSorted(bounds.begin(), bounds.end()), + "bounds for explicit histogram must be sorted"); + + return MakeHolder<TExplicitHistogramCollector>(bounds); + } +} |