/* -------------------------------------------------------------------------
 * Copyright (c) 2025 Huawei Technologies Co., Ltd.
 * This file is part of the MindStudio project.
 *
 * 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 ANALYSIS_APPLICATION_OP_SUMMARY_ASSEMBLE_H
#define ANALYSIS_APPLICATION_OP_SUMMARY_ASSEMBLE_H

#include <cstdint>
#include <map>
#include "analysis/csrc/application/summary/summary_assembler.h"
#include "analysis/csrc/infrastructure/data_inventory/include/data_inventory.h"
#include "analysis/csrc/domain/entities/viewer_data/ai_task/include/task_info_data.h"
#include "analysis/csrc/domain/entities/viewer_data/ai_task/include/ascend_task_data.h"
#include "analysis/csrc/domain/entities/viewer_data/ai_task/include/communication_info_data.h"
#include "analysis/csrc/domain/entities/viewer_data/ai_task/include/metric_summary.h"

namespace Analysis {
namespace Application {
using namespace Analysis::Infra;
using namespace Analysis::Domain;
class OpSummaryAssembler : public SummaryAssembler {
public:
    OpSummaryAssembler() = default;
    OpSummaryAssembler(const std::string &name, const std::string &profPath);
protected:
    void WriteToFile(const std::string &fileName, const std::set<int> &maskCols);
private:
    uint8_t AssembleData(DataInventory &dataInventory);
    void GenerateOpBody(std::vector<AscendTaskData> &taskData, std::shared_ptr<MetricSummary> &pmu);
    void GenerateHcclBody(std::vector<CommunicationOpData> &opData);
    void SplitDataByTaskId(std::vector<TaskInfoData> &taskInfo);
    std::vector<std::string> GenerateOneTaskRow(const TaskInfoData &computeTask, const AscendTaskData &task);
    void MergeTaskAndPmu(std::shared_ptr<MetricSummary> &pmu, std::vector<std::string> &row, const TaskId &id,
                         std::unordered_map<std::string, int> &indexTable);
    void AddCubeUsage(std::vector<std::string> &data, std::unordered_map<std::string, int> &indexTable);
    void CalculateWaitTime();
    std::set<int> GetMaskCols();
private:
    std::map<TaskId, TaskInfoData*> computeTask_;
};
}
}
#endif // ANALYSIS_APPLICATION_OP_SUMMARY_ASSEMBLE_H