1
0
mirror of https://github.com/vcmi/vcmi.git synced 2025-01-24 03:47:18 +02:00
vcmi/AI/Nullkiller/Analyzers/HeroManager.h

122 lines
4.0 KiB
C++
Raw Normal View History

2021-05-15 22:00:02 +03:00
/*
* HeroManager.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
2021-05-16 14:55:57 +03:00
#include "../AIUtility.h"
2021-05-15 22:00:02 +03:00
2021-05-16 14:55:57 +03:00
#include "../../../lib/GameConstants.h"
#include "../../../lib/VCMI_Lib.h"
#include "../../../lib/CTownHandler.h"
#include "../../../lib/CBuildingHandler.h"
2021-05-15 22:00:02 +03:00
2022-09-26 21:01:07 +03:00
namespace NKAI
{
2021-05-15 22:00:02 +03:00
class DLL_EXPORT IHeroManager //: public: IAbstractManager
{
public:
2022-09-22 11:02:16 +03:00
virtual ~IHeroManager() = default;
virtual const std::map<HeroPtr, HeroRole> & getHeroRoles() const = 0;
2021-05-15 22:00:02 +03:00
virtual int selectBestSkill(const HeroPtr & hero, const std::vector<SecondarySkill> & skills) const = 0;
virtual HeroRole getHeroRole(const HeroPtr & hero) const = 0;
virtual void update() = 0;
virtual float evaluateSecSkill(SecondarySkill skill, const CGHeroInstance * hero) const = 0;
2021-05-15 22:02:52 +03:00
virtual float evaluateHero(const CGHeroInstance * hero) const = 0;
virtual bool canRecruitHero(const CGTownInstance * t = nullptr) const = 0;
virtual bool heroCapReached() const = 0;
virtual const CGHeroInstance * findHeroWithGrail() const = 0;
2023-07-28 14:17:01 +03:00
virtual const CGHeroInstance * findWeakHeroToDismiss(uint64_t armyLimit) const = 0;
2021-05-15 22:00:02 +03:00
};
class DLL_EXPORT ISecondarySkillRule
{
public:
2022-09-22 11:02:16 +03:00
virtual ~ISecondarySkillRule() = default;
2021-05-15 22:00:02 +03:00
virtual void evaluateScore(const CGHeroInstance * hero, SecondarySkill skill, float & score) const = 0;
};
class DLL_EXPORT SecondarySkillEvaluator
{
private:
std::vector<std::shared_ptr<ISecondarySkillRule>> evaluationRules;
public:
SecondarySkillEvaluator(std::vector<std::shared_ptr<ISecondarySkillRule>> evaluationRules);
float evaluateSecSkills(const CGHeroInstance * hero) const;
float evaluateSecSkill(const CGHeroInstance * hero, SecondarySkill skill) const;
};
class DLL_EXPORT HeroManager : public IHeroManager
{
private:
static SecondarySkillEvaluator wariorSkillsScores;
static SecondarySkillEvaluator scountSkillsScores;
CCallback * cb; //this is enough, but we downcast from CCallback
const Nullkiller * ai;
std::map<HeroPtr, HeroRole> heroRoles;
2021-05-15 22:00:02 +03:00
public:
HeroManager(CCallback * CB, const Nullkiller * ai) : cb(CB), ai(ai) {}
const std::map<HeroPtr, HeroRole> & getHeroRoles() const override;
HeroRole getHeroRole(const HeroPtr & hero) const override;
2021-05-15 22:00:02 +03:00
int selectBestSkill(const HeroPtr & hero, const std::vector<SecondarySkill> & skills) const override;
void update() override;
float evaluateSecSkill(SecondarySkill skill, const CGHeroInstance * hero) const override;
2021-05-15 22:02:52 +03:00
float evaluateHero(const CGHeroInstance * hero) const override;
bool canRecruitHero(const CGTownInstance * t = nullptr) const override;
bool heroCapReached() const override;
const CGHeroInstance * findHeroWithGrail() const override;
2023-07-28 14:17:01 +03:00
const CGHeroInstance * findWeakHeroToDismiss(uint64_t armyLimit) const override;
2021-05-15 22:00:02 +03:00
private:
float evaluateFightingStrength(const CGHeroInstance * hero) const;
float evaluateSpeciality(const CGHeroInstance * hero) const;
const CGTownInstance * findTownWithTavern() const;
2021-05-15 22:00:02 +03:00
};
// basic skill scores. missing skills will have score of 0
class DLL_EXPORT SecondarySkillScoreMap : public ISecondarySkillRule
{
private:
std::map<SecondarySkill, float> scoreMap;
public:
SecondarySkillScoreMap(std::map<SecondarySkill, float> scoreMap);
void evaluateScore(const CGHeroInstance * hero, SecondarySkill skill, float & score) const override;
};
// Controls when to upgrade existing skills and when get new
class ExistingSkillRule : public ISecondarySkillRule
{
public:
void evaluateScore(const CGHeroInstance * hero, SecondarySkill skill, float & score) const override;
};
// Allows to get wisdom at 12 lvl
class WisdomRule : public ISecondarySkillRule
{
public:
void evaluateScore(const CGHeroInstance * hero, SecondarySkill skill, float & score) const override;
};
// Dynamically controls scores for magic skills
class AtLeastOneMagicRule : public ISecondarySkillRule
{
private:
static std::vector<SecondarySkill> magicSchools;
public:
void evaluateScore(const CGHeroInstance * hero, SecondarySkill skill, float & score) const override;
2022-09-22 11:02:16 +03:00
};
2022-09-26 21:01:07 +03:00
}