Saturday, August 29, 2015

I can has pottery

The latest update now includes basic industry! The test industry was the manufacture of earthenware. Earthenware is a tier-2 good, meaning it requires at least one level of intermediate goods to construct.

Earth (raw item) => Sherd (intermediate item) => Earthenware (final item)

Using my amazingly hand drawn graphic of a single blue pottery, you can see it stored inside the "cave" which is nothing more than a square border of rocks on a yellow savannah landscape.

Following this, work will begin on ensuring good consumption works fine. So people will pick up pottery and smash it into their faces to consume it for happiness and health.

Saturday, August 8, 2015

The Continuing Quest of Alpha

Instead of blabbing about stuff here is a list of various bugs that were fixed...

  • Added isInterruptible to actions to make certain system initiated actions non interruptible such as eating food
  • Added a back-off to worker assignment in build structure if materials required aren't available to prevent infinite reassignment
  • Fixed incorrect insufficient material detection in IndustryAction
  • Fixed missing superclass constructor call in BuyItemAction
  • Added exit condition for BuyItemAction if none of that item is found to buy
  • Added exit condition for IndustryAction to cancel if no materials are available
  • Added isInterruptible and it is passed down to stacked actions
  • Fixed IndustryAction distance to factory calculation to use FirstFloorSquare instead of location for better accuracy
  • Fixed BuyItemAction determine whether to buy something if the id of the good to buy is zero
  • Restructured IndustryAction to either perform labour or gather materials, whichever is possible and to end action if nothing is possible
  • Fixed UseConsumableAction to ignore inventory limit otherwise it can stuck in a cycle of failed attempts at PickUpAction
  • Fixed UnitInputManager building material selection to choose first material type off chosen materials
  • Fixed infinite buy loop in BuyItemAction because quantity purchased was not incremented
  • Fixed setPlayerInitiatedAction to properly check the size of the action stack while popping from it to prevent an NPE
  • Fixed IndustryAction stacking of CSpendItemAction which had incorrect parameter values
  • Fixed new estate creation and using the id in BuildStructureAction
  • Switched pathfinder to do start to destination to see if it can early exit for units that are stuck
  • Fixed GraphicsEngine missing dispatch of remove building message
  • Fixed BuildStructureAction to exit once building is complete

Of course, here is a picture of a successfully built inukshuk. By successful I mean it didn't crash while doing it.

Saturday, July 18, 2015

Game Design - Property

There's currently two game cycles designed: food consumption and goods consumption. They're really the same thing except every person in your empire must eat at least one food per day, while they may go on without consuming any goods. The next game cycle to be designed is property items. There will eventually be a number of different kinds of property items but for now it'll just be goods.

In general everything in the Cultura economy is designed with these principles:

  • Each person wants to consume exactly a single unit of it per cycle. Any additional consumption has reduced or no benefits.
  • The optimal amount to produce/store of an item is your population size. For example if your population is 10 then you want to produce 10 items per cycle. This means family size or other factors mostly out of the control of the player do not affect the production amount.
  • All goods are designed such that trade is encouraged.
  • Make this as simple as possible for the player to calculate production requirements and bonuses.

So how does this work for the existing cycles?

Food Consumption

At the end of each day, a person tries to consume food that gets them the highest bonus. Each time a person consumes food the bonus stays with them for a cycle (this cycle is currently 7 days but that might change based on balancing). But, they MUST consume food every day. So even if the highest bonus for the food is zero they still will eat it.

Health and happiness bonuses are cumulative over a season. So at the start of each season every person starts at 0 health and 0 happiness. You have a goal to reach by the end of the season to avoid problems. This gives some leeway for having "bad" days and "good" days to catch up.

Good Consumption

Good consumption is similar to food consumption except that a person only consumes good if the bonus is more than zero.

Property

At the end of each day a family calculates the bonus it receives from the property it owns and adds up the cumulative health/happiness bonus for a season (which gets reset at the end of the season). The property also degrades over time and eventually requires repair.

During the bonus calculation, the family tries to maximize its score. The formula is intended to be simple. The property they own is added up. Each person's consumption of property is separate. So the first person consumes as many unique property as possible, then the next person and so on. In the end the formula would then be: You get full bonus for the first n of each property and half bonus beyond that. The number n is the size of the family.

So What is Property?

The current concept for Property goods increase health or happiness. Housing can only store a maximum amount of property; if a family wants to own more property then they must expand their housing. Housing can be expanded infinitely but requires land area.

There are some possible simplifications depending on game balancing and understanding difficulty:

  • Will repairing property be necessary?
  • Will there be storage limits of property?

Anyway, we will see!

Saturday, June 27, 2015

Graphics and Events

The graphics engine is underway. There's three pieces to it. First is the graphics component that does the actual rendering, scene management and all the fancy stuff you heard about. Then there is the game-side of the engine where events are generated and processed before being sent off to the actual renderer. The third is the UI. This part sits separate from the game and rendering portions so that user input can be taken in at any time and then processed by the game (to take in commands) and to the rendering (to update the what the user sees).

Currently, the game engine is built to produce events from a unit moving to a tree being chopped down. That's sent off to the test-engine for now, until the rendering engine is built, and then you get to see some magical updates. People carrying rocks, balls of water, shiny rocks, heavy rocks, dark rocks and other stuff. It's the stone age, expect lots of rocks.

With the use of events, I can then move all the graphics code into one spot, the graphics component of the game engine and thus put it into a single class. This makes it easy when I want to switch to the real graphics engine and also centralizes the graphics code. Everyone else is just producing messages to be consumed by whatever component does the listening. It also allows multiplexing!

Here's a sample of the current generated world, all random whenever you start a new game, with graphic entities built via events!

Saturday, April 25, 2015

Road to the Alpha

So I'm on the long road to a first alpha right now. And by alpha I mean an actual alpha and not the "alpha" you see on Early Access these days (which means anything from an actual alpha to a finished game). That means getting the state machines bug free and reaching a point where I can start iterating on game design.

For now the features include: collecting resources, building structures, goods/food consumption, basic management of labour through work orders and labour assignment. These would constitute a game that is roughly equivalent to a Dwarf Fortress clone. After that I'll slowly introduce technological research, uprooting/planting of vegetation, AI factions and then diplomacy.

It's a short post since there's not much to talk about when you're bug squashing.

Friday, March 13, 2015

Big Cup Small Cup

A lot of the joy from an economic game is watching your industries go ahead after you've set them up. One issue that usually stands out is storage of goods. A game like Cultura is really complex, it has fifteen types of raw items and perhaps upwards to thirty finished and intermediate goods (the exact number is still in flux). This gives us two immediate questions: How many types of storage buildings for the different goods? How many sizes of storage buildings of each type?

For Cultura, the question of types of storage buildings is going to be simplified to "food" and "not food". This is mostly because in the game, the idea of useful storage is more about accessibility, space and preventing spoilage. Only food spoils, so its storage is paramount. Everything else is not really much of a concern so they're mostly for space efficiency (piles of goods would generally be less efficient than a storage pit). Then perhaps there's just two sizes of each: big and small. That leaves us with just four types of storage buildings and then upgrades for them as you progress in technology.

Algorithmically interesting is how you decided which storage site to use to drop off your goods and how you coordinate the movement of goods between storage sites. This is where you get the "sit back and watch" comfortable feeling of an economic game. The current idea is to use a "big cup small cup". A worker chooses the closest drop off site to dump goods. Then when a storage location is full, if it has a larger storage location to transfer goods into then it'll queue up a goods transfer job. This means a small cup can be poured into a larger cup. Whether or not goods should transfer between same size cups is still questionable (right now the answer is no, that way any number of storage location sizes can be coded and people simply keep transferring only "upward").

Wednesday, January 21, 2015

The Simulation Game

The title is a pun because there is a movie with a similar name. Hurr. Anyway, Cultura, when it's good and ready to be released will involve farming. The end game will be the neolithic time period so the hope is that you'll be fascinating with min/maxing your empire, engaging in endless diplomatic schemes and building wonders. Also trading with distant lands and marching armies. But back to farming, the lithic time period of humans is probably split between pastoral societies and agrarian societies. There's some mixture but what's important here is getting down to the basics.

This is a simulation game of building up a society from the ground up and so the best place to gather numbers for game mechanics is the real world. Cultura is a game where it doesn't tell you what works, what doesn't and what policies get you what bonuses, instead you do what you want and then the simulation takes care of the effects in a natural manner. With farming, it means that the land production values are going to be design something along the lines of real life.

Okay, let's look at agrarian production rates:

  • 223 kg/ha in Han Dynasty based on a statement from an official commenting on unfairly high tax rates
  • 442 kg/ha in Qin Dynasty based on a statement from an official commenting on new farming methods
  • 1431 kg/ha in Egypt Middle Kingdom based on a priests's statement on what a "good harvest" would be
  • 714 kg/ha to 1429 kg/ha in Egypt New Kingdom based on some records from archaeologists

So that varies a lot and the Nile is especially productive. That's not a surprise; China's Yangtze is not going to be good competition against the floodplains of the Nile. We could probably average the Egyptians to be around 1000 kg/ha. The Chinese number is harder to judge but perhaps we could just take an average and say it is 300 kg/ha.

That brings us to pastoral societies. What kind of food production might one expect from herders? And for that matter, animal meat production.

  • 1.16 kg/ha meat + ?? kg/ha milk for the Borana

That data... is a little sparse but there's little data gathering for pastoral societies. For the Borana, there's around 1162 kg/ha dry mass produced from the land they live on, on average per family, including the wet/dry areas they might move about in. They mostly rely on milk products to survive and their population density is exceptionally low. Each person lives on around 43 kg of meat per year plus a lot of dairy.

Lastly, we want to look at what animal production would be for grain-fed farm animals. This is important for mixed farming (where you do both herding and growing crops). These numbers come from a Stanford study:

  • Cattle: 8:1 feed to mass ratio, 20:1 feed to edible mass ratio
  • Pork: 7.3:1 feed to mass ratio, 4:1 feed to edible mass ratio
  • Chicken: 4.5:1 feed to mass ratio, 2.5:1 feed to edible mass ratio
  • Milk: 1.1:1 feed to mass ratio, 1:1 feed to edible mass ratio
  • Fish: 3:1 feed to mass ratio, 1.8:1 feed to edible mass ratio

These are fairly rough numbers and what they translate into game design here is relative values. So we want good arable land to produce around 200-400 units of food per square area, we want dryland to produce around 1100 units of dry mass for fodder per unit area, and we want a conversion ratio of grain feed or wild forage in the table above. Dryland would be unsuitable for growing crops, while floodplains would be super productive at 700-1400 units of food per unit area. We could translate this to being something simple like: dryland produces 1100 dry fodder per square per year or 50 units of cereal (so not worth it), grassland produces 450 units of cereal per year (or perhaps 1500 dry fodder?), floodplains or other super area produces 1000 units of cereal per year (and perhaps 2000 fodder?). Looking at data for dryland crops however appears to show that they can have quite good yields and especially during ancient times they may have rivalled the twentieth century yields (though I suspect that it was unsustainable and led to destruction of soil fertility since they would not have had access to many other technologies that could have kept up soil fertility).

I think perhaps I may simplify soil fertility or I may not, it depends on the sort of decisions it can give the player. If I bring in the concept of soil fertility, the idea is that certain technologies can maintain the fertility levels (such as the application of manure) but ultimately the land plus the technology determines the carrying capacity and going beyond this is a short term gain at a long term cost.

Soil fertility might be some value which decreases per unit harvested off of the land, increased by technological tools (such as manure) up to the max of what that technology can provide and there is some natural regrowth (and maximum). That model gives a very simple way of expressing responsible land use to the player, something well studied throughout history (accidental over farming leading to exhausted soil and then agricultural collapse) yet is still very very lenient because it doesn't consider fertilizer run-off causing algae blooms, deforestation leading to changes in the water cycle, drainage of wetlands leading to flooding and so on. I'm not quite building a weather simulator here but how far should I go to create the simulation to avoid sacrificing emergent properties that come out of environmental questions of how a society interacts with the land it lives on?

Deforestation can already be pretty devastating in the game. Wood is obviously a very useful resource but the growth rate depends on the number of trees. Chopping more trees gets you more wood but decreases the forest growth rate. It's similar to grasses and whatnot. Luckily, the player does not need to think about canopy cover and the like that prevents the soil from drying up from being overly exposed to sunlight. So your overgrazing won't lead to desertification but it does lead to loss of grasses and then your animals die of starvation, then you die of starvation.