2021-05-16 13:56:42 +02:00
|
|
|
/*
|
|
|
|
* 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
|
|
|
|
{
|
|
|
|
|
2021-05-16 13:56:42 +02:00
|
|
|
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>;
|
2021-05-16 13:56:42 +02:00
|
|
|
|
|
|
|
class DeepDecomposer
|
|
|
|
{
|
|
|
|
private:
|
|
|
|
std::vector<Goals::TGoalVec> goals;
|
|
|
|
std::vector<TGoalHashSet> decompositionCache;
|
|
|
|
int depth;
|
2024-03-31 17:39:00 +02:00
|
|
|
const Nullkiller * ai;
|
2021-05-16 13:56:42 +02:00
|
|
|
|
|
|
|
public:
|
2024-03-31 17:39:00 +02:00
|
|
|
DeepDecomposer(const Nullkiller * ai);
|
2021-05-16 13:56:42 +02:00
|
|
|
void reset();
|
2024-04-14 14:23:44 +02:00
|
|
|
void decompose(Goals::TGoalVec & result, Goals::TSubgoal behavior, int depthLimit);
|
2021-05-16 13:56:42 +02:00
|
|
|
|
|
|
|
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
|
|
|
};
|
|
|
|
|
|
|
|
}
|