Game Design, Programming and running a one-man games business…

Touchscreens and deep strategy games

Don’t panic just yet. Stay calm. But we might…we just might be in trouble.

Apples market share seems to be climbing quite unstoppably. PC sales are sluggish, tablet sales are booming. Whether the future belongs to apple or samsung, it does look like a big chunk of the future may be on tablets. Even my famously non tech-savvy gaming buddy, when told I’d been playing a ‘new’ game (portal 2) asked me immediately if he could play it on his ipad. Not his PC, his ipad.

We might be in trouble.

Ipads are perfectly good for gaming. I’ve wasted a good few hours on fieldrunners. I know some people live and die by their ipads. I think it’s a perfectly good platform. The trouble is, there is an absolutely perfect match between all the downsides of tablets, and all the demands of deep hardcore strategy gaming.

If you had to list tablet downsides as a developer, I reckon they would be small screen size, low memory, no right-click and no mouse hover. For the kind of games I make ALL of these things are a real pain. I *rely* on tooltips. I think they are awesome. I LOVE right-click menus, they are such a handy bit of functionality. And I like deep, complex games with a lot of information on the screen and a big hefty simulation that gobbles a lot of RAM.

Democracy 3, at the start of a new game has 156,000 neural connections in memory. Am I going to fit that on an ipad or an ipad 2? I doubt it. Now I know there are workarounds, some cunning retooling of GUI’s can have alternatives for tooltips and right clicks, but regardless how ‘retina’ the screens get, we aren’t looking at a 20 inch or 24 inch monitor any more, we aren’t able to assume near-pixel perfect mouse selection, and we aren’t about to get 2 gig or 4 gig of RAM in a tablet any time soon.

So that means taking a perfectly good strategy game design, which frankly any modern PC can cope with with one hand tied behind it’s back, and squeezing and compromising and squashing it to fit onto a tablet. Obviously, I don’t want to do that. Obviously, I’m not going to do that. I’m a PC gamer, through-and-through. If I wanted to compromise a PC game design because of a console, I’d go work for EA. Ahahahahahaha….

Anyway… I do worry the more tablet computers get popular. I know I’ll inevitably have to take the idea of tablet ports much more seriously in future, and I can’t help but feel that I may end up looking back at the days of windows dominance as the easy times. Maybe if I simply stick with PC-centric strategy gaming, I can carve out a big gap in an otherwise abandoned niche?

More about the complexities of Democracy 3 income…

Wealth is a complex thing in Democracy 3. far more so than before. I’ve been wrestling with bugs in it today which have reminded me how intricate the new income simulation is. How does it work? Well here is a rough synopsis.

Every sim voter in the world (defaults to 2,000 of them) has an ‘innate income’ which dictates basically where on a scale of 0 to 1, they sit on the big income spread. This is their best effort, in an unchanging world, to make money. If you implemented no policies, they had no characteristics, and the world was unchanging, this would be their level of income. Obviously the real world is more complex. The simulated voter is actually a fractional member of a whole bunch (maybe 5 to 8) different voter ‘groups’. For example, to keep it simple lets say the voter is 52% motorist and 33% parent. That might sound weird, but this just makes him an average car user, who maybe has teenage children, so not a ‘hardcore’ parent with multiple infants.

Now the player may have policies in place, or simulation values may exist in the world that affect income for the groups in which the voter is a member. For example, Child benefit may make parents better off, whereas Petrol tax may make motorists worse off.  Because our voter is a member of these groups, we run the equations and work out the combined effect on their final income based on these changes.

income

But it’s not that simple… because we also have policies, situations etc which affect people based on their income. For example income taxes affecting the middle classes, or luxury goods taxes affecting the wealthy. The real complexity hits where someone may be middle-income by default, but the taxes levied on them due to their middle-incomeness actually makes them poor. With me so far?

What this means is that the income calculation has to essentially do this:

Step #1: Work out the extent to which we are poor, middle income or wealthy, based on our innate-income. Using this data, calculate the effects of the policies that affect those 3 groups on our actual income

Step #2: Calculate the effects of all the other groups, such as being a farmer, motorist etc, have on our income, to come up with a final figure for our new ‘adjusted’ income.

Step #3: Given the final income figure, place us in the poor, middle income or wealthy group accordingly, which *may* differ from our membership in step #1.

Why all this grief? Because it is possible, through social engineering to take people whose basic income would be poor, and raise them 9through state benefits) to be middle income, and then reap the benefits of their membership in that social group. For example, middle-income members may get a kick out of seeing a certain cabinet minister in office who sympathizes with them as a group (they like the speeches he/she makes…). This can work, despite the effect that only government policy has put them in that situation in the first place.

It’s a difficult effect to describe, but it’s a real one.  Peoples final income differs from their earned income dramatically due to state policies, and you tend to ‘identify’ with the political view of the income group you are ‘effectively’ in. In other words, you base your views on your take-home pay, not your headline salary.

I’m definitely going to make a simple pong clone one day…

Democracy 3: Voter type income design…

Sooo.. I found myself almost sleepwalking into adding a new feature to Democracy 3. I honestly can’t remember actually making the decision to include it, it just seemed to ‘happen’. In democracy 2, the model for income of voters is fairly basic. You can implement policies which affect different levels of income (luxury goods tax hits the rich, for example), and that would affect the membership of the poor, middle income and wealthy voter groups. So far so good.

But it turns out that life is more complex than that. My example of choice is ‘agriculture subsidies’. In the current game, Agriculture subsidies make farmers happy, and they also encourage people to become farmers (so farmer voter group membership rises). This is accurate, and logical and works well. But it has no actual effect on anybodies personal income. This is clearly wrong. So in Democracy 3, I’ve changed things so that each voter group has an ‘income’ value, and policies (and events) can feed directly into them. You also get an extra tab on the graph, and list of effects to see these things happening.

farmers

So now… Agriculture subsidies have their usual effects, but also they make farmers wealthier. The subtle effect is to push farmers out of poverty, and towards wealth. This may be more logical, and detailed and accurate, but why is it good game design? what does it add?

let’s say you have identified the poor, and farmers as two ‘core’ groups that you will base your support on. They are the bedrock of your voting block, and you will keep them happy. So far so good. One of your policies, as demanded by your poor farming supporters, is higher agriculture subsidies, and so you do their bidding. One of the side effects is now that a chunk of those poor farmers are now not so poor. They start joining the middle income or even wealthy groups, and that brings with it a host of other influences to their thinking (voters are in multiple groups, at varying strengths). Suddenly, there are more farmers thinking ‘hold on, I don’t think I appreciate this luxury goods tax, or inheritance tax. What were you thinking???’. Your policies that subsidized the poor and hit the rich (including those taxes on the rich you levied to pay for the subsidies) are now inadvertently affected the very voters you were trying to help…

it’s a subtle effect, but I think it’s real-world, and also represents an interesting trade off. I see this in British politics a lot. The left were concerned about child poverty and pensioner poverty, so to combat it, we got better provision of child benefit and winter fuel benefits for the elderly. Worthy goals, but they also push up the living standards of parents and the retired. This has side effects. Now, in a time of austerity, the government finds it extremely hard to reduce either benefit. This is the problem of so called ‘middle-class’ benefits. A policy designed to do one thing has had other effects, due to the changes on people’s income.

I think this is an effect worth modeling, and it’s fascinating to see it in game. When trying to make environmentalists happy, all my feed-in-tariffs and grants also make them better off, and suddenly I’m the champion of the wealthy and not the poor. I love trade-offs and compromises like that. They are the key to what makes Democracy interesting to play.

Designing Pressure Groups in Democracy 3

Sooo… the system for pressure groups in Democracy 2 was fairly simplistic in comparison to this. See how this sounds.

There are a host of different pressure groups in Democracy 3. Some are relatively harmless and are mostly a way of registering dissatisfaction by voters. Some of them are more aggressive, some are extremist groups that are actively dangerous to your government. The extremist groups contain the rioters, the assassins, the corporate mega tycoons, fascists and crazies who will try to blow up your presidential car and so on…

Every voter in the game has a predisposition towards militancy. Each group has a required militancy level for people to join it. if you are mild mannered, no matter how upset you are, you will not join the peoples revolutionary army, although you might join the peoples socialist party (for example).

Here is the fun part…

The extremist groups (revolutionary army) have parent groups that are used as a ‘funnel’ into their membership (and that is the only way they get members). So if you are a member of the relatively harmless peoples socialist party, you will, providing you stay angry at the government, get ‘radicalized’ over time. If this radicalization meets a certain threshold, and your innate militancy is high enough, then you become a recruit of the more extreme group. There is also a point at which your radicalization will fall enough for you to quit the extreme group. Only the extremist groups are really worrying.

hamza

I think this is much more realistic, and should give rise to some interesting phenomena, especially ‘lag’. By this, I mean that carrying out an action that really upsets a group of voters (say… a war for oil) will have long term effects because it will push people into radical groups where previously they were happy to just shout slogans. The key is that the ‘leave’ threshold is way below the join one (giving groups some internal momentum) which means that once someone joins the revolutionary army, you need to really cheer them up if you are going to reduce the long term threat and have them leave.

It also means that a large and growing ‘harmless’ pressure group, is a warning sign that you could be looking at an extremist faction developing if you do not take steps to keep that group happy. If the peoples socialist party is huge, you need to be careful what you do to upset socialists further. if it’s tiny, you can probably risk it.

Obviously it will be fun to code stuff like the effects of intelligence services on radicalization, and dilemmas etc. If we arrest a radical without trial, that should accelerate radicalization, as should war. The trouble with this game is it could balloon to be the most complex software in the universe :D