-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathpush_and_rotate.h
59 lines (54 loc) · 3.01 KB
/
push_and_rotate.h
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
#ifndef PUSH_AND_ROTATE_H
#define PUSH_AND_ROTATE_H
#include <list>
#include <vector>
#include <algorithm>
#include "isearch.h"
#include "dijkstra.h"
#include "astar.h"
#include "agent_set.h"
#include "agent_move.h"
#include "config.h"
#include "multiagent_search_result.h"
#include "multiagent_search_interface.h"
class PushAndRotate : public MultiagentSearchInterface
{
public:
PushAndRotate();
PushAndRotate(ISearch<>* Search);
~PushAndRotate(void);
MultiagentSearchResult startSearch(const Map &Map, const Config &config, AgentSet &AgentSet,
std::chrono::steady_clock::time_point globalBegin = std::chrono::steady_clock::time_point(),
int globalTimeLimit = -1) override;
void clear() override;
private:
bool solve(const Map &map, const Config &config, AgentSet &AgentSet, std::chrono::steady_clock::time_point start);
bool clearNode(const Map &map, AgentSet &agentSet, Node &nodeToClear,
const std::unordered_set<Node, NodeHash>& occupiedNodes);
bool push(const Map &map, AgentSet &agentSet, Node& from, Node& to,
std::unordered_set<Node, NodeHash>& occupiedNodes);
bool multipush(const Map &map, AgentSet &agentSet, Node first, Node second, Node& to, std::list<Node>& path);
bool clear(const Map &map, AgentSet &agentSet, Node& first, Node& second);
void exchange(const Map &map, AgentSet &agentSet, Node& first, Node& second);
void reverse(int begSize, int endSize,
int firstAgentId, int secondAgentId, AgentSet &agentSet);
bool swap(const Map &map, AgentSet &agentSet, Node& first, Node& second);
bool rotate(const Map &map, AgentSet &agentSet, std::vector<Node> &qPath, int cycleBeg);
void getPaths(AgentSet &agentSet);
void getParallelPaths(AgentSet &agentSet, const Config &config);
void getComponent(AgentSet &agentSet, std::pair<Node, Node> &startEdge,
std::vector<std::pair<Node, Node>> &edgeStack,
std::vector<std::unordered_set<Node, NodeHash>>& components);
void combineNodeSubgraphs(AgentSet &agentSet, std::vector<std::unordered_set<Node, NodeHash>>& components,
Node &subgraphNode, int subgraphNum);
void getSubgraphs(const Map &map, AgentSet &agentSet);
int getReachableNodesCount(const Map &map, AgentSet &agentSet, Node &start,
bool (*condition)(const Node&, const Node&, const Map&, const AgentSet&),
const std::unordered_set<Node, NodeHash> &occupiedNodes);
void assignToSubgraphs(const Map &map, AgentSet &agentSet);
void getPriorities(const Map &map, AgentSet &agentSet);
ISearch<>* search;
std::vector<AgentMove> agentsMoves;
MultiagentSearchResult result;
};
#endif // PUSH_AND_ROTATE_H