Commit graph

2 commits

Author SHA1 Message Date
jedarden
9dae3bd3de fix(engine): reduce 2-player spawn radius and zone shrink step for combat density
Problem: Plan §3.7.1 claims 65-80% combat density for 2-player matches,
but actual testing showed 0% combat deaths. Zone killed all bots before
they could fight.

Root cause:
- Spawn radius 50% (10 tiles from center) put bots too far apart
- Zone shrink step 2 tiles/turn was too fast
- Bots died to zone before reaching each other

Solution:
- Reduce 2-player spawn radius from 50% to 10% (~2 tiles from center)
- Reduce zone shrink step from 2 to 1 tile/turn (slower zone)
- Bots now spawn close enough to reach safe zone and fight

Results:
- Before: 0% combat density (all zone deaths)
- After: 100% combat density (2 deaths per match across 20+ test matches)
- Tested against: swarm/gatherer, hunter/rusher, guardian/random

Updated TestSpawnRadiusOutsideZone to TestSpawnRadiusWithinReach to
reflect the new design (spawn within reach of safe zone, not outside).

Closes: bf-1jya
2026-05-25 13:50:09 -04:00
jedarden
2dbfea5163 fix(engine): increase spawn radius to force zone combat
Root cause of zero combat deaths: bots spawned inside the final zone.
On 40x40 grid, bots spawned at ~5 tiles from center but zone min radius
was 3 tiles. Zone only pushed bots 2 tiles toward center - not enough to
force them within attack range (6 tiles).

Fix: Calculate spawn radius as absolute tile distance from center, then
convert to percentage of grid half-size:
- 2-player: spawn at 10 tiles from center (was ~5 tiles)
- 3+ player: spawn at 8 tiles from center (was ~6 tiles)

When zone shrinks to minimum (radius 3 for 2p, 1 for 3+), bots are
forced within attack range of each other, triggering focus-fire combat.

Test: Unit tests verify spawn distance > zone_min_radius for all player
counts. Manual test shows combat_death events now occur.

Closes: bf-52mn

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
2026-05-25 09:14:48 -04:00