BuildingScenariosBalancing
Contents
Introduction
I'm writing this wiki article to talk about some things that came up as I was balancing a couple of the scenarios in the South Guard Campaign. I'm going to respond to something that PDF wrote but that I think is a pretty common idea. I don't mean to single him out:
The PDF wrote:
"Adding a difficulty level does not necessarily requires much balancing; you can, for example, just add or remove gold."
I'm going to argue that that is fundamentally a flawed way to balance campaigns, and should only be used in conjunction
with other balancing methods.
A Wesnoth scenario as a tactical problem
Each scenario in Wesnoth presents a tactical problem. The problem is generally phrased something like this: "Kill the enemy leader in so much time while keeping your leader alive," and its most common variation being: "Move your leader to this hex in said amount time with out letting him die." Of course, there are subtleties to these tactical problems. Because of the bonus gold at the end you want to finish in less then the stated time. And since you can recall experienced units for harder scenarios you may not want your vetrans to die, and of course there might be other units that you have or want to keep alive. There may also be certain units you must kill in order to succeed. At its core however, each scenario is a relatively simple tactical problem.
Factors that influence the difficulty of a tactical problem in Wesnoth
I am going to briefly list the factors (that I perceive) which affect the difficulty of a tactical problem in Wesnoth. This list is probably not exhaustive, so if there's something I've missed, post it and I'll add it to the list. They are in no particular order:
- Terrain
- Player's starting gold
- AI's starting gold
- Player's recriutment list
- AI's recriutment list
- Player's recall list
- Time limitations
- Keep sizes
- AI Parameters (more on this in a minute)
- Distribution of villages
- Unexpected reinforcements
- Time of day
Note that the AI's starting gold is one factor among many.
Varying the difficulty of a tactical problem presented to the player in a scenario
Considering the above factors, it is easy (if time consuming for the designer) to present tactical problems of differing difficulty in a single scenario. For most of the above factors, I'll give and example and explain in a sentence how if affects the tactical problem:
Terrain
If the map is predominantly a terrain that favors either the player's forces or the ai's forces, it will have a huge effect on the difficulty of the battle. For example, a player whose units are broadly loyalists will have a disasterous time trying to root Elves out of woods. The terrain is, however, generally fixed by the nature of the scenario (i.e. the designer can't really make a whole new map for each difficulty level). I would submit, however, that 80% of the actual fighting in a typical scenario occurs in less than 10% of the hexes. It is possible to change only one or two hexes and have a dramatic effect on the outcome of the battle if you can identify those "chokepoint" hexes.
This can either be done my having three different maps (which I suspect is more work) or by using the WML tag [terrain].
For example, the code:
  #ifdef EASY
     [terrain]
     x=4
     y=5
     letter=Ce
     [/terrain]
  #endif
will turn the hex at (4,5) into an encampment.
Player's starting gold
If the player has more gold he can make more tactical mistakes because he can recruit more troops to replace the ones he's lost. Additionally, quantity has a quality all of its own; with sufficient starting gold the player can employ a swarm of cheap units to distract and overwhelm the AI forces. Balancing gold becomes difficult in campaigns because of gold carryover, which often has the exact opposite of the desired effect: struggling players will start with less gold (usually the minimum), while accomplished players will have a sizable treasury. This severely limits the designer's ability to balance the scenario by adjusting the player's starting gold.
AI starting gold
If the AI's starting gold is much higher than the players, the player will be unable to make any tactical mistakes and still win the scenario. I'll talk more about this in a moment.
Player's recruitment list
If the player can only recruit units that will be effective against the enemy's forces, then the tactical problem is simplified. If I can only recruit heavy infantry to face a force of skeleton archers, then I have a less difficult tactical decision to make than if I can recruit heavy infantry and spearmen. Especially if I don't know the game well.
AI recruitment list
Restricting the enemy to a certain class of units (i.e. melee-only, ranged-only, impact-attacks-only) can simplify the tactical problem immensely. Consider an enemy who can only recruit thieves and thugs facing a predominantly loyalist force, who can recruit Bowmen and Spearmen. Bowmen are very good against thugs and thieves because they have a strong ranged attack. If the enemy can also recruit poachers and footpads, the tactical problem becomes more difficult because the player must balance the effectiveness of the Bowmen against the thieves and thugs with their (relative) weakness against footpads and poachers.
Player's recall list
Time limitations
The turn limit controls to what extent the player is allowed to waste turns not directly accomplishing his mission. In the most difficult case scenario, a player must move his leader across the map and only enough turns are allotted such that if he ever moves in any other direction, time will run out. Elongating the turn limit allows an inexperienced player to turn-costing make mistakes and still be victorious.
Keep sizes
The size of a player's keep determines at what rate he can recruit troops. The size of the enemy's keep determines at what rate he can recruit troops. Divide one by the other and you get a relative-recruitment-rate (assuming both have lots of gold). If the relative recruitment rate favors the player, the tactical problem should be easier because he can replenish losses more easily than the AI player. If the AI player's keep is larger, then any losses by the human player will be that much more difficult to replace.
Note that these parameters generally only have a significant influence on the first few turns--rarely will players (or AI) have sufficient gold to recruit a full keep of replacement troops (and almost never will they be able to do so on multiple turns in a row). In those first few turns, a smaller AI keep can "spread out" the initial rush, making it easier for the player to defend (but this effect can disappear entirely if the AI improves). The only time keep size is critical to the players is when they are limited to 'X' rounds of recruitment (either because their keep is forcibly removed or they are required to begin moving their leaders towards an objective). In short, while keep size can have an effect in some specific circumstances, it is generally not very useful for balancing scenarios.
AI Parameters
The AI parameters are perhaps the best way to alter a tactical problem. AiWML is a particularly important read for a scenario designer. I'd draw attention to aggression and [target] in particular. attack_depth is also very nice. These parameters are especially important for building scenarios with tactical problems that are fundamentally different from the basic kill-his-leader ones.
Distribution of villages
Using the [terrain] WML tag you can easily alter the distribution of villages in a scenario. Move the distribution towards the player, and things get easier. Move it towards the enemy, and they get harder.
Unexpected reinforcements
Reinforcements, either friendly or hostile, can significantly complicate the tactical problem. They are a surprise that the player must accommodate with already deployed troops. Unfortunately, reinforcements often become tomato surprises, meaning the best course of action for the player is to replay the scenario with foreknowledge of the "surprise". To avoid that result, reinforcements should generally be either foreshadowed, appear early in the scenario, or appear in moderation.
As an example, the scenario Crossroads in HttT introduces enemy enemy reinforcements that randomly appear in hill tiles. These reinforcements are explained near the beginning of the scenario, and the enemy units appear in moderation (a few at a time, and only when the player moves onto hill terrain). The scenario Drowned Plains in EI uses the same code, but adjusts the type of ambushing units depending on the difficulty level. On the other side, many scenarios give the player a few friendly units near the beginning, with the number and type adjusted for difficulty.
Time of day
Time of day can be an interesting factor (assuming the map is not a cave and the armies aren't entirely neutral). While you are normally not free to change the cycle, changing the initial time of day can have a significant impact on the outcome of a battle. In particular, the time of day when the first AI rush is engaged can be crucial. On smaller maps, the time of day for the first engagement is practically dictated by the scenario designer. On a large or open battlefield, the player can arrange for a more favorable first encounter, so the initial time of day is not nearly as important. Note that these effects are most pronounced when the two armies are of opposite alignment.