* -------------------------------------------------------------------------
* This file is part of the MindStudio project.
* Copyright (c) 2025 Huawei Technologies Co.,Ltd.
*
* MindStudio is licensed under Mulan PSL v2.
* You can use this software according to the terms and conditions of the Mulan PSL v2.
* You may obtain a copy of Mulan PSL v2 at:
*
* http://license.coscl.org.cn/MulanPSL2
*
* THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
* EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
* MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
* See the Mulan PSL v2 for more details.
* -------------------------------------------------------------------------
*/
#ifndef PROFILER_SERVER_TOPNADVICEMAINTAINER_H
#define PROFILER_SERVER_TOPNADVICEMAINTAINER_H
#include <functional>
#include <queue>
#include "ClusterDef.h"
namespace Dic::Module::Summary {
double GetTotalSynchronizeTime(const AdviceInfoForSlowRank &info);
* 用一个小顶堆,维护总同步时间为TopN的元素
*/
class TopNAdviceMaintainer {
public:
explicit TopNAdviceMaintainer(uint32_t len)
: length(len), cmp([](const AdviceInfoForSlowRank &a, const AdviceInfoForSlowRank &b) {
return GetTotalSynchronizeTime(a) > GetTotalSynchronizeTime(b);
}),
queue(cmp) {}
void Insert(const AdviceInfoForSlowRank &info);
std::vector<AdviceInfoForSlowRank> GetTopNSlowest(uint32_t topN) const;
bool IsEmpty() const;
private:
uint32_t length;
std::function<bool(const AdviceInfoForSlowRank &, const AdviceInfoForSlowRank &)> cmp;
std::priority_queue<AdviceInfoForSlowRank, std::vector<AdviceInfoForSlowRank>, decltype(cmp)> queue;
};
}
#endif