Feedback on our docs? Contribute changes and suggestions on Discord.
NMMO Gameplay Narrative
This Wiki is meant as a quick reference. To understand the game at a high-level, consider this narrative example:
Our team of 8 agents spawns on the edge of a large square map. At this time, we are assigned a task to complete (see Tasks), with potential hostile teams just out of view to the left and right.
Immediate strategic choices arise: rushing into the map center, attempting a quick elimination of nearby teams, or dispatching scouts to gauge the behavior of the nearby teams. This opening flurry of decision making, which encompasses the first 15-30 seconds of a 10-minute game, culminates in a strategic situation that sets the tone for the rest of the game.
- The subsequent gameplay phases in Neural MMO 2.0 now depend not only on the surviving agents, nearby resources and terrain, but also on our assigned task. Simple tasks, such as cutting down a tree, can be completed consistently regardless of initial conditions. For harder tasks, such as acquiring high-level equipment, we will have to play more passively if a required resource is far away or if we have lost several agents in the opening stage. But assuming good conditions, we can use the next few minutes to gain an advantage versus the competition. Agents can enhance their capabilities through practice in any of 8 different professions, each conferring unique offensive or defensive benefits. Task completion often requires specific skill levels, prompting agents to specialize and cooperate. For example:
If our task is to obtain level 5 arrows, it would make sense to have one agent practice carving to produce them while another capitalizes on the surplus of ammunition by training ranged combat.
We might assign another agent to practice herbalism and provide healing potions for the team. Provided we can keep this agent safe, it would also be a good candidate to hold the team’s gold and attempt to buy items on the exchange.
This would allow us to invest heavily in equipping our range agent to fight powerful NPCs, which have a chance to drop the level 5 axe our carver will need to produce level 5 arrows.
These are but a few possibilities, and ultimately, decisions are a matter of strategy and opportunism.
The Game Map#
Each instance of Neural MMO contains an automatically generated tile-based game map of 128 x 128 tiles. The map is surrounded by Void. Agents that attempt to walk into the void dissapear, never to be seen again.
- Tiles are broadly categorized as follows:
Passable tiles can be walked on while obstacle tiles block movement
Resource tiles can be harvested while non-resource cannot
Tile Type |
Passable |
Obstacle |
---|---|---|
Resource |
Foliage, Ore, Tree, Crystal |
Water, Fish |
Non-resource |
Grass, Harvested Tile |
Stone, Void |
Resource tiles may be harvested. Passable tiles are harvested by walking over them and non-passable tiles by walking next to them. The resource is then consumed from the tile. It will regenerate randomly over time on the same tile. The only exception is the Water tile, which provides unlimited resource.
Visibility range is 7 tiles.
About the tile generation algorithm
The default tile generation algorithm is more sophisticated than typical Perlin noise – it stretches the space of one Perlin fractal using a second Perlin fractal. It further attempts to scale spacial frequency to be higher at the edges of the map and lower at the center. This effect is not noticable in small maps but creates large deviations in local terrain structure in larger maps.
Survival#
Agents have health, food, and water. These are displayed overhead as green, gold, and blue bars respectively. Agents must stay full, hydrated, and healthy in order to survive.
- Losing and gaining resources:
Health, food, and water start at 100
Agents lose 5 food and 5 water per game tick
Agents lose 10 health per tick if out of food
Agents lose 10 health per tick if out of water
These values add - lose 20 health if out of food and water per tick
If above half food and half water, agents regain 10 health per tick
Tick: The gameplay consists of time units called “ticks.” When rendering, the game moves at 0.6s/tick.
Agents can replenish food and water. Walking on a foliage tile restores food to 100. The foliage tile then is harvested and will respawn at a random time in the same place. Walking adjacent to a water tile restores water to 100. Water tiles do not empty.
Competition Environment and Levels#
At the start of a game, all agents on all teams spawn (enter the game) together around the perimeter of the map on the same tile. Agent teams are evenly dispersed around the perimeter.
Non-Player Characters (NPCs) are any agent not controlled by a user; sometimes called a mob. NPCs are scattered across the entire map. They get stronger and more aggressive towards the center. NPCs are all individuals; they fight each other as well; and they are all controlled by basic scripts. Their aggression and strength levels are correlated, but otherwise are identical.
Agents can occupy the same tile as other agents. There is no limit to number or type of agents on a single tile, including enemy agents and NPCs.
Time and Gameplay Each tick provides the opportunity for every Agent and NPC to do any, all or none of the following actions:
Move 1 tile in any available direction
Agents cannot move off of the game space, or into water.
As the game progresses, the action space becomes constrained as a fog encircles the board. Agents cannot be in tiles covered in fog, and all gradually move towards the center of the game space.
Attack an Agent - either NPC or from another team
Attack can only be against one other Agent or NPC
To attack, your Agent must be within three tiles of the opponent (within a 7x7 square around your Agent).
Inventory Management
Inventory capacity is 12 items, including armor, weapon, tools, and consumables.
Buy or Sell in the Market
Destroy an item if no market value
Giving an item to a team mate is only permitted when standing on the same tile
About the Observation Space
Each agent observes a groups of entities comprising nearby tiles and agents, its own inventory, and the market. Continuous and discrete tensors of attributes parametrize each entity group. An extra variable N counts the number of entities per group.
observation_space(agent_id) = {
'AgentId': Discrete(1),
'Entity' :Box(-1048576.0, 1048576.0, (100, 22), float32),
'Inventory': Box(-1048576.0, 1048576.0, (12, 16), float32),
'Market': Box(-1048576.0, 1048576.0, (640, 16), float32),
'Tick': Box(-1048576.0, 1048576.0, (1, 1), float32),
'Tile': Box(-1048576.0, 1048576.0, (225, 3), float32)
}
Levels#
Levels range from 1 to 10
Agents spawn with all skills at level 1 (0 XP)
Level n+1 requires 10 x XP x 2^n
Agents are awarded 1 XP per attack
Agents are awarded 1 XP per ammunition resource gathered
Agents are awarded 5 XP per consumable resource gathered
All items except gold will appear in varying levels
All items appear in level 1-10 variants.
Agents can equip armor up to the level of their highest skill
Agents can equip weapons up to the level of the associated skill
Agents can equip ammunition and tools up to the level of the associated skill
About the Action Space
Each agent may take multiple actions per tick – one from each category. Each action accepts a list of arguments. Each argument is a discrete variable. This can be either a standard index (i.e. 0-4 for direction) or a pointer to an entity (i.e. inventory item or agent).
action_space(agent_idx) = {
nmmo.action.Move: {
nmmo.action.Direction: {
nmmo.action.North,
nmmo.action.South,
nmmo.action.East,
nmmo.action.West,
nmmo.action.Stay,
},
},
nmmo.action.Attack: {
nmmo.action.Style: {
nmmo.action.Melee,
nmmo.action.Range,
nmmo.action.Mage,
},
nmmo.action.Target: {
Entity Pointer,
}
},
nmmo.action.Use: {
nmmo.action.InventoryItem: {
Inventory Pointer,
},
},
nmmo.action.Destroy: {
nmmo.action.InventoryItem: {
Inventory Pointer,
},
},
nmmo.action.Give: {
nmmo.action.InventoryItem: {
Inventory Pointer,
},
nmmo.action.Target: {
Entity Pointer,
}
},
nmmo.action.GiveGold: {
nmmo.action.Price: {
Discrete Value,
},
nmmo.action.Target: {
Entity Pointer,
}
},
nmmo.action.Sell: {
nmmo.action.InventoryItem: {
Inventory Pointer,
},
nmmo.action.Price: {
Discrete Value,
},
},
nmmo.action.Buy: {
nmmo.action.MarketItem: {
Market Pointer,
},
},
nmmo.action.Comm: {
nmmo.action.Token: {
Discrete Value,
},
},
}
About Combat#
Each agent can attack one opponent per game tick. In a given tick, multiple enemy agents can attack a single agent. Agents select from Melee, Range, and Mage style attacks. An agent’s main combat skill is the one that they use the most / have the highest level in. This is denoted by the hat they are wearing.
- Attack skills obey a rock-paper-scissors dominance relationship:
Melee beats Range
Range beats Mage
Mage beats Melee
Attack range is 3 tiles, full sweep view.
Insert Image
The attacker can select the skill strongest against the target’s main skill. This multiplies the effectiveness of the attack. However, the defender can immediately retaliate in the same way. A strong agent with a higher level and better equipment can still beat a weaker agent, even if the weaker agent uses the attack style that multiplies damage.
There are three pieces of armor: Hat, Top, Bottom. Armor requires at least one skill ≥ the item level to equip. Armor provides defense that increases with equipment level.
Weapons require an associated fighting style skill level ≥ the item level to equip. Weapons boost attacks; higher level weapons provide more boost. Tools grant a flat defense regardless of item level.
- Damage to health is a randomized function based on several factors, including:
Fighting style
Combat skill level
Weapon level
Armor levels
def COMBAT_DAMAGE_FORMULA(self, offense, defense, multiplier):
'''Damage formula'''
return int(multiplier * (offense * (15 / (15 + defense))))
Example combat interaction
Start:
Agent You: 100 HP, poor armor and weapons
Agent Them: 75 HP, good armor and weapons
Tick 1:
You attack them. They lose 18 HP
They attack you. You lose 27 HP
Tick 2:
You attack them. They lose 14 HP
They attack you. You lose 32 HP
Tick 3:
You attack them. They lose 18 HP
They run
Tick 4: You chase and attack them. They lose 15 HP.
They consume a poultice to regain 50 HP and run some more.
This continues for some time, with your opponent running away, and you chasing them. Eventually, you give up and let them go. Your HP is low, and they had to consume a poultice.
Fortunately, this was only a training run, and you now can reconsider your strategy for the next round.
Professions, Tools, and Items#
There are 8 Professions that Agents can learn and level up in. Agents can improve their skills in multiple Professions, but will not be able to progress in all Professions. How Professions are distributed across Agent teams is a part of game strategy.
For Skills Prospecting, Carving, and Alchemy, agents walk on the associated resource tile to harvest the resource. Agent receives a different quality/level of resource, depending on agent levels/tools. The resource tile will respawn later in the same place. There is a 2.5 percent chance to obtain a weapon while gathering ammunition on a tile.
Agents have an inventory that can hold 12 items.
Item Type |
Profession |
Tool |
Level up method |
HP Effect |
Food/Water Level |
Market Buy/Sell |
---|---|---|---|---|---|---|
Combat |
Mage |
Wand |
Hitting and damaging NPCs and Enemies |
-HP level unless you take no damage |
Wand |
|
Melee |
Sword |
Sword |
||||
Range |
Bow |
Bow |
||||
Gathering |
Fishing |
Rod |
Level up via experience and use |
+HP level |
+Food & Water level |
Fish Ration |
Herbalism |
Gloves |
+HP level |
Poultice |
|||
Carving |
Chisel |
+HP level |
Chisel & Shaving |
|||
Prospecting |
Pickaxe |
+HP level |
Pickaxe & Scrap |
|||
Alchemy |
Arcane |
Arcane & Shards |
- Tools
All Tools provide a flat 30 defense regardless of item level
Tools need a relevant skill level (fishing, herbalism, prospecting, carving, alchemy) ≥ the item level to equip
Tools enable an agent to collect an associated resource (ration, poultice, scrap, shaving, shard) at a level equal to the item level
- Rations
Consume rations to restore 5 food and water per item level
Requires at least one skill greater than or equal to the item level to use
A rod is used to collect the rations. Alternatively, agents can buy rations in the market.
For example, agents can harvest a level 3 fish only with a level 3 rod. If they buy a fish in the market, they can eat level 3 fish by just having any skill level 3 or above. If they buy a ration with a level higher than any of their skills, they can store but cannot eat it until a skill level = the ration level.
- Poultices
Consume to restore 5 health per gloves level.
Requires at least one skill greater than or equal to the glove level to use.
The same rules about levels apply to poultices and rations.
Market#
Gold coins are the currency for buying and selling items in NMMO. Gold coins cannot be sub-divided. Agents set their own prices and receive gold when someone is willing to accept their price. Within the same team, can gift to one another if they are standing on the same tile.
- Market interactions are as follows:
Agents place sell offers on the market for one of their items at a desired price
The item is immediately removed from the seller’s inventory
Other agents can immediately buy that item and receive it
If multiple agents attempt to buy the same item at the same time, the market will attempt to fulfill the request from another seller at a price no more than 10% higher.
Agents only observe the current best offer for each item of each level. This bounds the observation and action spaces.
BUY and SELL with GOLD |
|||
---|---|---|---|
COMBAT items |
|||
Tools |
Ammunitions |
Weapons |
Armors |
AXE |
Wood ARROWS |
BOW |
HAT |
PICKAXE |
Rock WHETSTONES |
SWORD |
TOP |
CHISEL |
Magic RUNES |
WAND |
BOTTOM |
Health items |
|||
Tools |
Consumables |
||
ROD |
HARVEST fish to produce RATION items (restore water and food) |
||
GLOVES |
HARVEST herbs to produce POTION items (restore health) |
NPCs#
- Characteristics
NPCs are controlled by one of three scripted AIs
Passive NPCs wander randomly and cannot attack
Neutral NPCs wander randomly but will attack aggressors and give chase using a Dijkstra’s algorithm based pathing routine
Hostile NPCs will actively hunt down and attack other NPCs and players using the same pathing algorithm
NPCs will appear in varying levels
- NPC Items
NPCs spawn with random armor piece
NPCs spawn with a random tool
Any equipment dropped will be of level equal to the NPC’s level
NPCs spawn with gold equal to their level
Generally, Passive NPCs will spawn towards the edges of the map, Hostile NPCs spawn in the middle, and Neutral NPCs spawn somewhere between.
Tasks#
- About Tasks
Goal is to accomplish specific tasks from the curriculum for points.
Tasks are randomly generated and assigned at the beginning of each round.
If a Team accomplishes a Task, they receive 1 point for the round.
Each team receives different tasks from one another each round.
Difficulty of the tasks evens out, as all teams compete with each other 1024 rounds to determine the best teams overall in that group.
Based on the average scores, teams are placed in the next round of 1024 with other teams whose performance matches their own.
Sample tasks
- Inflict(damage_type, quantity) -
Damage_type = 3 combat styles
Quantity = 1-100 HP out of total 100 HP
Ex. Inflict 5 damage with melee
- Defeat(npc/player, level)
npc/player = NPC or Player, Unit = 1
Level = 1-10
Defeat a level 5 npc
- Achieve(skill, level)
Skill = 8 skills (Professions)
Level = 10
Ex: Achieve level 5 prospecting
- Harvest(resource, level)
Resource = 5 resources
Level = 10 levels
Ex: collect a level 3 shard
- Equip(type, level)
Type = Hat, Top, Bottom
Level = 10
Ex: equip a level 5 hat
- Hoard(gold) - Accumulate a total of 20 gold as a team
Gold: Units of transaction ingots
- Group(num_tiles, num_teammates) - Always stay within 5 tiles of at least 3 of your teammates
Num_tiles: Variable starting with tile you’re on as 0
Num_teammates: Self evident. Stay together-ish
- Spread(num_tiles, num_teammates) - Always stay at least 5 tiles away from at least 3 of your teammates
Opposite of Group
- Defend(teammate) - Don’t let your 3rd teammate die
Teammate: Specific member of your team can’t die
- Eliminate(team, direction) - Eliminate the team that spawns to your right
Team: ID # of team
Direction: Left; Right
Tiles Quick Reference#
Tile Resource |
Purpose |
Obtaining |
---|---|---|
WATER Tile Resources |
||
WATER |
WATER to DRINK |
Stand next to WATER to DRINK |
FISH |
RATION item to EAT |
ROD to HARVEST |
GRASS Tile Resources |
||
FOOD |
FOOD to EAT |
Stand on FOOD to EAT |
HERB |
POTION item to increase HEALTH |
GLOVES to HARVEST |
TREE |
ARROWS boost BOW damage of RANGE combat |
AXE to HARVEST |
STONE Tile Resources |
||
ORE |
WHETSTONES boost SWORD damage of MELEE combat |
PICKAXE to HARVEST |
CRYSTAL |
RUNES boost WAND damage of MAGIC combat |
CHISEL to HARVEST |
GOLD Resources |
||
GOLD |
BUY items from other players on the MARKET |
SELL items. DEFEAT NPCs. |