From 2b0875b9d36f93cc7b5e33a2ec9f9d00c84f0ec0 Mon Sep 17 00:00:00 2001 From: Tomas Maly Date: Tue, 2 Jan 2024 06:09:06 +0100 Subject: [PATCH] weaken constraints for starting positions (flat radius for a buildable tile reduced from 40 too 35 meters) --- sources/startingPositions.cpp | 4 +++- sources/tileProperties.cpp | 11 +++++------ 2 files changed, 8 insertions(+), 7 deletions(-) diff --git a/sources/startingPositions.cpp b/sources/startingPositions.cpp index 59b7b8a..6e0a53b 100644 --- a/sources/startingPositions.cpp +++ b/sources/startingPositions.cpp @@ -49,7 +49,7 @@ namespace unnatural for (uint32 i : spatQuery->result()) if (tiles[i].buildable) b++; - static constexpr uint32 Threshold = CAGE_DEBUG_BOOL ? 400 : 2000; + static constexpr uint32 Threshold = CAGE_DEBUG_BOOL ? 400 : 2500; return b < Threshold; }); } @@ -92,6 +92,8 @@ namespace unnatural CAGE_LOG(SeverityEnum::Info, "generator", "generating starting positions"); const std::vector allCandidates = generateCadidates(); + if (allCandidates.empty()) + CAGE_THROW_ERROR(Exception, "no starting positions candidates"); Real bestScore = 0; static constexpr uint32 Limit = 100000 / (CAGE_DEBUG_BOOL ? 100 : 1); diff --git a/sources/tileProperties.cpp b/sources/tileProperties.cpp index 528f371..35c5bea 100644 --- a/sources/tileProperties.cpp +++ b/sources/tileProperties.cpp @@ -22,7 +22,7 @@ namespace unnatural const String c = Stringizer() + current; const String r = Stringizer() + 100 * Real(current) / total; const String g = maxc > 0 ? fill(String(), 30 * current / maxc, '#') : String(); - CAGE_LOG_CONTINUE(SeverityEnum::Info, "tileStats", Stringizer() + fill(name, 28) + reverse(fill(reverse(c), 6)) + " ~ " + reverse(fill(reverse(r), 12)) + " % " + g); + CAGE_LOG_CONTINUE(SeverityEnum::Info, "tileStats", Stringizer() + fill(name, 28) + reverse(fill(reverse(c), 6)) + " ~ " + reverse(fill(reverse(r), 13)) + " % " + g); } template @@ -194,13 +194,13 @@ namespace unnatural Holder spatQuery = newSpatialQuery(spatStruct.share()); for (uint32 i = 0; i < cnt; i++) { - if (tiles[i].flatRadius < 40) + static constexpr Real Radius = 35; + if (tiles[i].flatRadius < Radius) continue; if (tiles[i].type >= TerrainTypeEnum::Rough) continue; tiles[i].buildable = true; - uint32 overlapped = 0; - spatQuery->intersection(Sphere(tiles[i].position, 40)); + spatQuery->intersection(Sphere(tiles[i].position, Radius)); for (uint32 j : spatQuery->result()) { if (tiles[j].type >= TerrainTypeEnum::Rough) @@ -208,12 +208,11 @@ namespace unnatural tiles[i].buildable = false; break; } - overlapped++; } if (tiles[i].buildable) { totalBuildable++; - totalOverlapped += overlapped; + totalOverlapped += spatQuery->result().size(); } } const uint32 totalBuildings = totalOverlapped ? numeric_cast(uint64(totalBuildable) * totalBuildable / totalOverlapped) : 0;