This game is bonkers. It’s bonkers in terms of gameplay, where you have to deal with the chaos that emerges from large, unwieldy, unpredictable simulations that run over a large area. It’s also bonkers in the sense that the developers decided to make a game built around large, unwieldy, unpredictable simulations that run over a large area, and were 100% successful at it.
Noita is a side-scrolling game where you play as some sort of robed practitioner of magic. You begin at the mouth of a cave and descend ever downward. Creatures try to kill you, and you try to prevent this using your collection of randomly-generated wands. Every so often you’ll reach the end of a zone where you can take a breather, top off your health, and purchase some upgrades. Then you resume your descent into ever-more dangerous underground locations.
What’s at the bottom? What sort of prize lurks at the heart of this endless cave system? What sort of reward could motivate our nameless protagonist to endure this endless cavalcade of violence, murder, and misfortune?
I have no idea. I’ve never beat the game. All I can say is that it had better be really good.
A Misfortune Simulator
The hook with this game is that it runs a massive per-pixel simulation on the entire level. Liquids flow, slosh around, and mix or separate by weightOil and water are the classic example.. Granular substances will slide and fall until they reach their angle of repose. Gases rise and expand. Fire spreads, consuming structures and unleashing even more gas and liquids that will create fascinating new situations that will probably kill you.
It’s amazing how complete this simulation is. We’ve got all four states of matter: Solid, liquid, gas, and plasmaWhat? No Bose-Einstein condensates?, all doing the stuff they’re known for: Melting, freezing, evaporating, burning, dousing, suffocating, crushing, and dissolvingActually, I think condensation is left out. You can burn something into a gas, and you can freeze a liquid into a solid, but to my knowledge you can’t condense a gas into a liquid.. There are almost 80 different substances in the game, and the interactions between them can be fairly complicated. The full breakdown is documented in this handy community-made spreadsheet.
What you end up with is a lot of chain reaction-type situations. You’ll find a wooden basin full of (say) whiskey. Maybe you’ll get the bright idea to shoot a hole in the side and let the alcohol flood the level below you, so you can set it all on fire and kill everyone without ever needing to go down and face your foes in combat. But then the fire starts spreading out of control and it lights the platform you’re standing on. So you hop from one crumbling platform to the next, looking for something that isn’t going to burn away in this inferno. You find solid purchase in a small room, but it’s flooded with smoke. Oh! and now your robe has caught fire, there’s nowhere left to stand, and below you is a lake of burning whiskey. You throw your water bottle at the ceiling, which douses you and the nearby fire to give you some time to come up with an escape plan. But now you see that the fire has spread to the levels above, and only now do you remember passing a giant wooden vat of acid.
You hop down into the fire to escape the torrent of acid. You run frantically, looking for a spot of momentary safety. In the chaos, you spot a pool of liquid below. You leap in, only to realize at the last second that it’s a pool of polymorphine, which turns you into a sheep on contact. The burning whiskey overtakes you, and your story ends with your character becoming roast mutton.
How Did They…?
I have no idea how the developers accomplished this. That’s a lot of complicated logic that needs to be run on a LOT of data. There are 2,073,600 individual pixels on your typical 1080p monitor. Running complex simulation logic on that many things sounds like a large and framerate-destroying task. My first instinct would be to create a custom shader and dump all of that processing on the graphics card, which ought to have lots of spare power in a 2D game like this. But I’m not so sure how practical it would be to try and simulate 80 different substances in a shader. Shaders are really great at doing mathematical transformations like “make this color 0.2 brighter”. But they’re notoriously bad at branching logic like “If any of the surrounding pixels are fire, then make this pixel catch fire, unless we’re being doused by liquid. But! We can only be doused by non-flammable liquids. If we’re consumed by fire, then turn into the appropriate gas.” I’m nowhere near an expert on current-gen graphics cards and what their shader programs can do, but that sounds like a ridiculous pain in the ass to writeThe problem being that it’s really hard to communicate with shaders, since they only output pixel data. You’d need to pack all of your logic into RGB values.. I’m positive it could be done, but it would be really complicated and would create some fairly complex support problems for the developers as they worked to develop shaders that worked on all the many variants of all the generations of graphics cards, including the countless mutant systems that have cut-rate integrated graphics that can’t actually do the stuff they promise they can do.
If the devs were doing this on the GPU, then I’d expect to see that reflected in the system requirements. Also, I think the forums would be flooded with odd reports from people with weird edge-case cards. I don’t see any of that, which indicates that all of this pixel simulation must be running on your CPU. Indeed, the system requirements lists “The more the better” for recommended CPU cores, which suggests that this is the case.
That’s amazing. I have no idea how they’re running something this immense and complex on consumer-grade CPUsI’m willing to bet the simulation runs at a lower framerate than the game. That would certainly help..
But wait! It’s worse! Above I said that we have over 2 million pixels on the screen at a time, and they all need to be simulated. The problem is that the simulation doesn’t just run on the screen, it also runs on pixels that are very far away. Like, many screens away. We can tell the simulation is still running in distant areas, because sometimes we can hear explosions from far away that weren’t caused by the player. When you arrive to a new zone, it takes the map a few seconds to “settle”. If rival creatures spawn near each other, they might fight, that fight might set off explosions, and those explosions can be heard and feltIn the form of screen shake. by the player.
Making this even more impressive is that a lot of zones are wider than they seem. Your overall goal is to just progress to the bottom of the current zone to reach the teleporter. However, if you travel sideways you’ll often encounter another entire extra zone. That’s a whole bunch of extra gamespace that needs to exist in memory and participate in the simulation, but which is rarely encountered by the player. As a programmer, it feels like the devs are showboating at this point.
As magnificent as this simulation is, I’m not really in love with the game.
Not Really My Thing
Aside from the physics simulation, this is a pretty standard old-school roguelike. You get better gear, fight tougher enemies, and when you die, you start over.
My problem with Noita is that there’s no meta-progression. I much prefer a roguelike in the style of Spelunky, where you gradually unlock things like maps, weapons, or characters. Even when you die, you still get a little bit of comfort knowing you made some sort of progress. Even if you didn’t get a new unlock, you probably earned a little bit of progress towards one.
For contrast, a game like Noita doesn’t have those sorts of consolation prizes. When you die, you have nothing to show for it. I find this to be kind of demoralizing. I know I’m not going to beat the entire game, so without unlocks to chase it all feels kind of empty and depressing.
This might be okay if the game was entirely skill-based, but by design Noita is incredibly chaotic. One run you’ll get a world-smashing fireball wand and you’ll be immune to fire, enabling you to spam this incredibly powerful spell with impunity. Then you’ll have two dozen runs where you never get anywhere near that level of power. Yes, it helps to learn the game’s systems and get good at the controls, but luck still dominates your progression. A skilled player can be obliterated by a string of hilarious bad luck, and a newbie can stumble into some really good gear and get really far without knowing what they’re doing. Completing the game comes down to having that one perfect run where you don’t make any mistakes AND the RNG is incredibly generous.
None of these design choices are invalid. In fact, this is pretty much how the genre worked on the old days. But I find it hard to go back to the cruelty of old school roguelikes after being coddled by newer games. I prefer a system of steady unlocks, time-saving shortcuts, and where player skill isn’t completely overwhelmed by random fortune.
In fact, the game doesn’t even have achievements to mark your progress. There’s one achievement, and to get it you need to beat the whole game.
Off to a Good Start
To be fair, this game is still in early access and a lot can change between now and release. The game is still in active developmentThe last update was less than a week ago. and the devs are responsive to player feedback. So I’m sure this game will evolve quite a bit over the coming months. If you’re reading this article in the archive, you should probably look up something newer if you want to know how the game is doing.
Even if you’re like me and you’re not into brutal roguelikes where there’s no prize for second place and foes always have a chance to 1-hit kill youSeriously, polymorph attacks can piss right off., I’d still recommend giving Noita a try. The simulation itself is amusing enough to be worth playing around with. Also, the game fully supports mods through the Steam workshop, and there are lots of rule-bending and game-breaking cheats / mods if you just want to plow through the content.
This is cool. Give it a look.
 Oil and water are the classic example.
 What? No Bose-Einstein condensates?
 Actually, I think condensation is left out. You can burn something into a gas, and you can freeze a liquid into a solid, but to my knowledge you can’t condense a gas into a liquid.
 The problem being that it’s really hard to communicate with shaders, since they only output pixel data. You’d need to pack all of your logic into RGB values.
 I’m willing to bet the simulation runs at a lower framerate than the game. That would certainly help.
 In the form of screen shake.
 The last update was less than a week ago.
 Seriously, polymorph attacks can piss right off.
There are two major schools of thought about how you should write software. Here's what they are and why people argue about it.
Resident Evil 4
Who is this imbecile and why is he wandering around Europe unsupervised?
Philosophy of Moderation
The comments on most sites are a sewer of hate, because we're moderating with the wrong goals in mind.
Two minutes of fun at the expense of a badly-run theme park.
The true story of three strange days in 1989, when the last months of my adolescence ran out and the first few sparks of adulthood appeared.