File: DeepDecomposer.h

package info (click to toggle)
vcmi 1.1.0%2Bdfsg-1
  • links: PTS, VCS
  • area: contrib
  • in suites: bookworm
  • size: 14,672 kB
  • sloc: cpp: 181,738; sh: 220; python: 178; ansic: 69; objc: 66; xml: 59; makefile: 34
file content (46 lines) | stat: -rw-r--r-- 1,015 bytes parent folder | download
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
/*
* DeepDecomposer.h, part of VCMI engine
*
* Authors: listed in file AUTHORS in main folder
*
* License: GNU General Public License v2.0 or later
* Full text of license available in license.txt file, in main folder
*
*/
#pragma once

#include "../Goals/AbstractGoal.h"

namespace NKAI
{

struct GoalHash
{
	uint64_t operator()(const Goals::TSubgoal & goal) const
	{
		return goal->getHash();
	}
};

typedef std::unordered_map<Goals::TSubgoal, Goals::TGoalVec, GoalHash> TGoalHashSet;

class DeepDecomposer
{
private:
	std::vector<Goals::TGoalVec> goals;
	std::vector<TGoalHashSet> decompositionCache;
	int depth;

public:
	void reset();
	Goals::TGoalVec decompose(Goals::TSubgoal behavior, int depthLimit);

private:
	Goals::TSubgoal aggregateGoals(int startDepth, Goals::TSubgoal last);
	Goals::TSubgoal unwrapComposition(Goals::TSubgoal goal);
	bool isCompositionLoop(Goals::TSubgoal goal);
	Goals::TGoalVec decomposeCached(Goals::TSubgoal goal, bool & fromCache);
	void addToCache(Goals::TSubgoal goal);
};

}