From a668dc27210784d94fd3022ad6f01e0f9fb526ac Mon Sep 17 00:00:00 2001 From: MnHebi Date: Thu, 25 Jan 2024 03:26:42 +0200 Subject: [PATCH 1/2] Try to improve VCAI building build order. Testing reveals extra structures still get done before intended build order(seen Market being built when Dwellings were expected). --- AI/VCAI/BuildingManager.cpp | 56 ++++++++++++++++++++++--------------- 1 file changed, 33 insertions(+), 23 deletions(-) diff --git a/AI/VCAI/BuildingManager.cpp b/AI/VCAI/BuildingManager.cpp index f5529777f..d63f78e07 100644 --- a/AI/VCAI/BuildingManager.cpp +++ b/AI/VCAI/BuildingManager.cpp @@ -139,13 +139,14 @@ void BuildingManager::setAI(VCAI * AI) //Set of buildings for different goals. Does not include any prerequisites. static const std::vector essential = { BuildingID::TAVERN, BuildingID::TOWN_HALL }; static const std::vector basicGoldSource = { BuildingID::TOWN_HALL, BuildingID::CITY_HALL }; +static const std::vector cityhallRequirements = { BuildingID::TOWN_HALL, BuildingID::MARKETPLACE, BuildingID::BLACKSMITH, BuildingID::MAGES_GUILD_1 }; +static const std::vector defence = { BuildingID::FORT, BuildingID::CITADEL, BuildingID::CASTLE }; static const std::vector capitolAndRequirements = { BuildingID::FORT, BuildingID::CITADEL, BuildingID::CASTLE, BuildingID::CAPITOL }; static const std::vector unitsSource = { BuildingID::DWELL_LVL_1, BuildingID::DWELL_LVL_2, BuildingID::DWELL_LVL_3, BuildingID::DWELL_LVL_4, BuildingID::DWELL_LVL_5, BuildingID::DWELL_LVL_6, BuildingID::DWELL_LVL_7 }; static const std::vector unitsUpgrade = { BuildingID::DWELL_LVL_1_UP, BuildingID::DWELL_LVL_2_UP, BuildingID::DWELL_LVL_3_UP, BuildingID::DWELL_LVL_4_UP, BuildingID::DWELL_LVL_5_UP, BuildingID::DWELL_LVL_6_UP, BuildingID::DWELL_LVL_7_UP }; -static const std::vector unitGrowth = { BuildingID::FORT, BuildingID::CITADEL, BuildingID::CASTLE, BuildingID::HORDE_1, -BuildingID::HORDE_1_UPGR, BuildingID::HORDE_2, BuildingID::HORDE_2_UPGR }; +static const std::vector unitGrowth = { BuildingID::HORDE_1, BuildingID::HORDE_1_UPGR, BuildingID::HORDE_2, BuildingID::HORDE_2_UPGR }; static const std::vector _spells = { BuildingID::MAGES_GUILD_1, BuildingID::MAGES_GUILD_2, BuildingID::MAGES_GUILD_3, BuildingID::MAGES_GUILD_4, BuildingID::MAGES_GUILD_5 }; static const std::vector extra = { BuildingID::RESOURCE_SILO, BuildingID::SPECIAL_1, BuildingID::SPECIAL_2, BuildingID::SPECIAL_3, @@ -172,10 +173,38 @@ bool BuildingManager::getBuildingOptions(const CGTownInstance * t) if(tryBuildAnyStructure(t, essential)) return true; - //the more gold the better and less problems later //TODO: what about building mage guild / marketplace etc. with city hall disabled in editor? - if(tryBuildNextStructure(t, basicGoldSource)) + if (cb->getDate(Date::DAY_OF_WEEK) < 5) // first 4 days of week - try to focus on dwellings + { + if (tryBuildNextStructure(t, unitsSource, 4)) + return true; + } + + if (cb->getDate(Date::DAY_OF_WEEK) > 4) // last 3 days of week - try to focus on growth by building Fort/Citadel/Castle + { + if (tryBuildNextStructure(t, defence, 3)) + return true; + } + + if (t->hasBuilt(BuildingID::CASTLE)) + { + if (tryBuildAnyStructure(t, unitGrowth, 4)) + return true; + } + + //make required structures for City Hall + if(tryBuildNextStructure(t, cityhallRequirements)) return true; + //try to make City Hall + for (int i = 0; i < cityhallRequirements.size(); i++) + { + if (t->hasBuilt(cityhallRequirements[i])) + { + if (tryBuildThisStructure(t, BuildingID::CITY_HALL)) + return true; + } + } + //workaround for mantis #2696 - build capitol with separate algorithm if it is available if(vstd::contains(t->builtBuildings, BuildingID::CITY_HALL) && getMaxPossibleGoldBuilding(t) == BuildingID::CAPITOL) { @@ -183,25 +212,6 @@ bool BuildingManager::getBuildingOptions(const CGTownInstance * t) return true; } - if(!t->hasBuilt(BuildingID::FORT)) //in vast majority of situations fort is top priority building if we already have city hall, TODO: unite with unitGrowth building chain - if(tryBuildThisStructure(t, BuildingID::FORT)) - return true; - - - - if (cb->getDate(Date::DAY_OF_WEEK) > 6) // last 2 days of week - try to focus on growth - { - if (tryBuildNextStructure(t, unitGrowth, 2)) - return true; - } - - //try building dwellings - if (t->hasBuilt(BuildingID::FORT)) - { - if (tryBuildAnyStructure(t, unitsSource, 8 - cb->getDate(Date::DAY_OF_WEEK))) - return true; - } - //try to upgrade dwelling for (int i = 0; i < unitsUpgrade.size(); i++) { From 8b24b0e9a77aa44464caeae87c9bd0e5ea3d4911 Mon Sep 17 00:00:00 2001 From: MnHebi Date: Fri, 26 Jan 2024 00:56:36 +0200 Subject: [PATCH 2/2] Add Marketplace, Blacksmith into extra buildings category to ensure they get built. Misc changes. --- AI/VCAI/BuildingManager.cpp | 21 +++++---------------- 1 file changed, 5 insertions(+), 16 deletions(-) diff --git a/AI/VCAI/BuildingManager.cpp b/AI/VCAI/BuildingManager.cpp index d63f78e07..843c54d3f 100644 --- a/AI/VCAI/BuildingManager.cpp +++ b/AI/VCAI/BuildingManager.cpp @@ -139,7 +139,6 @@ void BuildingManager::setAI(VCAI * AI) //Set of buildings for different goals. Does not include any prerequisites. static const std::vector essential = { BuildingID::TAVERN, BuildingID::TOWN_HALL }; static const std::vector basicGoldSource = { BuildingID::TOWN_HALL, BuildingID::CITY_HALL }; -static const std::vector cityhallRequirements = { BuildingID::TOWN_HALL, BuildingID::MARKETPLACE, BuildingID::BLACKSMITH, BuildingID::MAGES_GUILD_1 }; static const std::vector defence = { BuildingID::FORT, BuildingID::CITADEL, BuildingID::CASTLE }; static const std::vector capitolAndRequirements = { BuildingID::FORT, BuildingID::CITADEL, BuildingID::CASTLE, BuildingID::CAPITOL }; static const std::vector unitsSource = { BuildingID::DWELL_LVL_1, BuildingID::DWELL_LVL_2, BuildingID::DWELL_LVL_3, @@ -149,8 +148,8 @@ BuildingID::DWELL_LVL_4_UP, BuildingID::DWELL_LVL_5_UP, BuildingID::DWELL_LVL_6_ static const std::vector unitGrowth = { BuildingID::HORDE_1, BuildingID::HORDE_1_UPGR, BuildingID::HORDE_2, BuildingID::HORDE_2_UPGR }; static const std::vector _spells = { BuildingID::MAGES_GUILD_1, BuildingID::MAGES_GUILD_2, BuildingID::MAGES_GUILD_3, BuildingID::MAGES_GUILD_4, BuildingID::MAGES_GUILD_5 }; -static const std::vector extra = { BuildingID::RESOURCE_SILO, BuildingID::SPECIAL_1, BuildingID::SPECIAL_2, BuildingID::SPECIAL_3, -BuildingID::SPECIAL_4, BuildingID::SHIPYARD }; // all remaining buildings +static const std::vector extra = { BuildingID::MARKETPLACE, BuildingID::BLACKSMITH, BuildingID::RESOURCE_SILO, BuildingID::SPECIAL_1, BuildingID::SPECIAL_2, +BuildingID::SPECIAL_3, BuildingID::SPECIAL_4, BuildingID::SHIPYARD }; // all remaining buildings bool BuildingManager::getBuildingOptions(const CGTownInstance * t) { @@ -187,23 +186,13 @@ bool BuildingManager::getBuildingOptions(const CGTownInstance * t) if (t->hasBuilt(BuildingID::CASTLE)) { - if (tryBuildAnyStructure(t, unitGrowth, 4)) + if (tryBuildAnyStructure(t, unitGrowth)) return true; } - //make required structures for City Hall - if(tryBuildNextStructure(t, cityhallRequirements)) - return true; - //try to make City Hall - for (int i = 0; i < cityhallRequirements.size(); i++) - { - if (t->hasBuilt(cityhallRequirements[i])) - { - if (tryBuildThisStructure(t, BuildingID::CITY_HALL)) - return true; - } - } + if (tryBuildNextStructure(t, basicGoldSource)) + return true; //workaround for mantis #2696 - build capitol with separate algorithm if it is available if(vstd::contains(t->builtBuildings, BuildingID::CITY_HALL) && getMaxPossibleGoldBuilding(t) == BuildingID::CAPITOL)