-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfruchterman_reingold.hpp
70 lines (46 loc) · 1.13 KB
/
fruchterman_reingold.hpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
#pragma once
#include "nodesoup.hpp"
#include <vector>
namespace nodesoup
{
class FruchtermanReingold
{
public:
FruchtermanReingold(const adj_list_t& aAdjList,double aK=15.0);
void Start(bool aStartCircle=true);
void Step(int aStepSize,int aMaxStep,std::vector<NsPosition>& aPositions);
int GetCurrIter() const noexcept;
int GetMaxIters() const noexcept;
double GetK() const noexcept;
void SetK(double aK) noexcept;
double GetEnergy() const noexcept;
void MovePos(vertex_id_t aVertexId,const ImVec2& aDisp,bool aRecalculate);
private:
const adj_list_t& m_AdjList;
double m_K;
double m_KSquared;
double m_Temp;
std::vector<ImVec2> m_Mvmts;
bool m_StartCircle;
int m_CurrIter,m_MaxIter;
std::vector<NsPosition> m_Positions;
void DoStep();
void SetInitPositions();
};
inline int FruchtermanReingold::GetCurrIter() const noexcept
{
return m_CurrIter;
}
inline int FruchtermanReingold::GetMaxIters() const noexcept
{
return m_MaxIter;
}
inline double FruchtermanReingold::GetK() const noexcept
{
return m_K;
}
inline double FruchtermanReingold::GetEnergy() const noexcept
{
return m_Temp;
}
}