1
0
mirror of https://github.com/vcmi/vcmi.git synced 2024-12-16 10:19:47 +02:00
vcmi/AI/Nullkiller/Engine/DeepDecomposer.h

47 lines
1015 B
C
Raw Normal View History

/*
* 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"
2022-09-26 20:01:07 +02:00
namespace NKAI
{
struct GoalHash
{
uint64_t operator()(const Goals::TSubgoal & goal) const
{
return goal->getHash();
}
};
2023-04-17 23:11:16 +02:00
using TGoalHashSet = std::unordered_map<Goals::TSubgoal, Goals::TGoalVec, GoalHash>;
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);
2022-09-26 20:01:07 +02:00
};
}