BayesNet/bayesnet/utils/Mst.h

33 lines
1.0 KiB
C
Raw Normal View History

#ifndef MST_H
#define MST_H
#include <vector>
#include <string>
2024-03-08 21:20:54 +00:00
#include <torch/torch.h>
namespace bayesnet {
class MST {
private:
2023-11-08 17:45:35 +00:00
torch::Tensor weights;
std::vector<std::string> features;
2023-07-29 17:38:42 +00:00
int root = 0;
public:
MST() = default;
2023-11-08 17:45:35 +00:00
MST(const std::vector<std::string>& features, const torch::Tensor& weights, const int root);
std::vector<std::pair<int, int>> maximumSpanningTree();
};
class Graph {
private:
int V; // number of nodes in graph
2023-11-08 17:45:35 +00:00
std::vector <std::pair<float, std::pair<int, int>>> G; // std::vector for graph
std::vector <std::pair<float, std::pair<int, int>>> T; // std::vector for mst
std::vector<int> parent;
public:
2023-07-29 17:38:42 +00:00
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();
void display_mst();
2023-11-08 17:45:35 +00:00
std::vector <std::pair<float, std::pair<int, int>>> get_mst() { return T; }
};
}
#endif