// *************************************************************** // SPDX-FileCopyrightText: Copyright 2024 Ricardo Montañana Gómez // SPDX-FileType: SOURCE // SPDX-License-Identifier: MIT // *************************************************************** #ifndef MST_H #define MST_H #include #include #include namespace bayesnet { class MST { public: MST() = default; MST(const std::vector& features, const torch::Tensor& weights, const int root); void insertElement(std::list& variables, int variable); std::vector> reorder(std::vector>> T, int root_original); std::vector> maximumSpanningTree(); private: torch::Tensor weights; std::vector features; int root = 0; }; class Graph { public: explicit Graph(int V); void addEdge(int u, int v, float wt); int find_set(int i); void union_set(int u, int v); void kruskal_algorithm(); std::vector >> get_mst() { return T; } private: int V; // number of nodes in graph std::vector >> G; // std::vector for graph std::vector >> T; // std::vector for mst std::vector parent; }; } #endif