1
0
mirror of https://github.com/vcmi/vcmi.git synced 2025-01-20 03:29:32 +02:00
vcmi/AI/Nullkiller/Analyzers/ObjectClusterizer.h

103 lines
2.5 KiB
C++
Raw Normal View History

2021-05-16 14:45:12 +03:00
/*
* DangerHitMapAnalyzer.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 "../Pathfinding/AINodeStorage.h"
#include "../Engine/PriorityEvaluator.h"
2021-05-16 14:45:12 +03:00
2022-09-26 21:01:07 +03:00
namespace NKAI
{
2021-05-16 14:55:57 +03:00
struct ClusterObjectInfo
2021-05-16 14:45:12 +03:00
{
2024-06-17 09:43:22 +00:00
float priority = 0.f;
float movementCost = 0.f;
2024-06-12 18:10:38 +00:00
uint64_t danger = 0;
uint8_t turn = 0;
2021-05-16 14:45:12 +03:00
};
struct ObjectInstanceIDHash
{
ObjectInstanceID::hash hash;
bool equal(ObjectInstanceID o1, ObjectInstanceID o2) const
{
return o1 == o2;
}
};
using ClusterObjects = tbb::concurrent_hash_map<ObjectInstanceID, ClusterObjectInfo, ObjectInstanceIDHash>;
2021-05-16 14:45:12 +03:00
struct ObjectCluster
{
public:
ClusterObjects objects;
2021-05-16 14:45:12 +03:00
const CGObjectInstance * blocker;
void reset()
{
objects.clear();
}
void addObject(const CGObjectInstance * object, const AIPath & path, float priority);
2023-04-18 00:11:16 +03:00
ObjectCluster(const CGObjectInstance * blocker): blocker(blocker) {}
2021-05-16 14:45:12 +03:00
ObjectCluster() : ObjectCluster(nullptr)
{
}
std::vector<const CGObjectInstance *> getObjects(const CPlayerSpecificInfoCallback * cb) const;
const CGObjectInstance * calculateCenter(const CPlayerSpecificInfoCallback * cb) const;
2021-05-16 14:45:12 +03:00
};
using ClusterMap = tbb::concurrent_hash_map<ObjectInstanceID, std::shared_ptr<ObjectCluster>, ObjectInstanceIDHash>;
2021-05-16 14:45:12 +03:00
class ObjectClusterizer
{
private:
2024-03-09 16:20:00 +02:00
static Obj IgnoredObjectTypes[];
2021-05-16 14:45:12 +03:00
ObjectCluster nearObjects;
ObjectCluster farObjects;
ClusterMap blockedObjects;
const Nullkiller * ai;
RewardEvaluator valueEvaluator;
bool isUpToDate;
std::vector<ObjectInstanceID> invalidated;
2021-05-16 14:45:12 +03:00
public:
void clusterize();
std::vector<const CGObjectInstance *> getNearbyObjects() const;
2021-05-16 14:45:45 +03:00
std::vector<const CGObjectInstance *> getFarObjects() const;
2021-05-16 14:45:12 +03:00
std::vector<std::shared_ptr<ObjectCluster>> getLockedClusters() const;
const CGObjectInstance * getBlocker(const AIPath & path) const;
std::optional<const CGObjectInstance *> getBlocker(const AIPathNodeInfo & node) const;
2021-05-16 14:45:12 +03:00
ObjectClusterizer(const Nullkiller * ai): ai(ai), valueEvaluator(ai), isUpToDate(false){}
void validateObjects();
void onObjectRemoved(ObjectInstanceID id);
void invalidate(ObjectInstanceID id);
void reset() {
isUpToDate = false;
invalidated.clear();
}
private:
bool shouldVisitObject(const CGObjectInstance * obj) const;
void clusterizeObject(
const CGObjectInstance * obj,
PriorityEvaluator * priorityEvaluator,
std::vector<AIPath> & pathCache,
std::vector<const CGHeroInstance *> & heroes);
2021-05-16 14:45:12 +03:00
};
2022-09-26 21:01:07 +03:00
}