Factorio Von Neumann Mk 1 - Lessons Learned and the Question
Posted: Sat Feb 14, 2015 4:52 am
Cross posted from reddit.
http://imgur.com/a/P5PKp/titledesc
My computer's starting to struggle with the simulation, so I figure this is a good time to stop and take stock.
The dream of the Von Neumann factory is the dream of Factorio - a factory that spits out more factories. In theory, with blueprints, a Von Neumann factory could double its size every 20 minutes, but in practice there are a number of interesting challenges to contend with when playing with the base game.
1) Mineral patches are randomly distributed, so there must necessarily be some manual involvement in the layout of mining outposts.
2) Logistics robots do not have any kind of priority algorithm. They seem to choose tasks within their network arbitrarily and their pathing distance grows exponentially. As far as I can tell, there is no way to establish effective filtering or resource distribution in storage chests to attenuate this pathing distance explosion. Logistics networks simply cannot scale beyond a screen or two, so they must manually be separated between factory expansions.
3) Large blueprints, more than two or three screens in size, are very difficult to place accurately. The ideal way to grow a factory with blueprints is to tessellate it, with overlapping identical parts on the edges, but blueprints are always centered on the cursor, so it can be hard to find a common overlap. Even when you can, it can then later be hard to tell what random tree or rock off the edge of the screen is blocking your blueprint placement. The dream of doubling the blueprint size with every iteration is not realistic when construction robots can't destroy rocks or fill in small bodies of water (or clear biter nests).
I thought these problems would be fun to engineer around and I think I've found some modest success with this first try. I built this factory off of my speedrun save, so biters are passive and resource patches are rich and the tech is maxed.
*
I'm fairly satisfied with the baseline factory expansion design. It's quite compact. I settled on 12 refineries, feeding 3 plastic and 12 batteries. The plastic fed 25 red circut factory (1 roboport factory) and the batteries fed 4 accumulator factories. The elements of the design are simple - two assemblers fed by a requester chest and feeding into a provider chest, with an electric pole and red wired smart inserters to manage the buffer. When fully supplied, the factory creates enough components to create a copy of itself every 20 minutes, refineries and trains and logistic robots and mining outpost materials and all.
The components are loaded onto a 9 car train and shipped to the next factory site. The roboports in the center, surrounded by lights, are laid out at very particular ranges. The leftmost allows for the preliminary construction of the loading station in which the 9 car train can be offloaded. The second brings the offload chests into logistics network range, allowing construction to begin once the networks has been disconnected from the previous factory, as we do not want logistics robots stealing the supplies. The third brings the loading chests into logistics network range, once the factory is running and ready to produce the next copy.
The raw resource loading station is fairly straight forward. I have 5 drop spots - c, i, o, s, and m for copper, iron, oil, stone/coal, and mixed copper/iron. The outposts are generally named c1, i1, o1, etc. It's very important to name them the same for every factory expansion, as it quickly becomes unweildly managing 30+ train stops. Because their names are the same, it's important that the raw resource train network remains disconnected between factories. Trains will prioritize the nearest available stop and have no sense of the current fullness of the station, so you'd very quickly get factory starvation. Unfortunately, water must be connected manually, but it's not terrible. A single water line supported by four-pump pumping stations can support roughly 3-4 factory expansions.
*
Important lessons:
-It doesn't actually seem important to minimize the number of requester/provider chests in a factory logistics network. The throughput is the same, whether a robots feed one chest feeding a line feeding 8 furnaces, or whether robots feed 8 chests. Thus, I settled on a belt-less design, as belts are rather space-inefficient when squeezing a factory into a train.
-Put the barrel assembler right next to the 9 car factory train and load directly into it. Do not put barrel assembly onto the logistics network, or you will saturate your pipeline with empty barrels and actually prevent the emptying of full ones.
-Refineries require level 3 assemblers, so you might as well use them elsewhere as well. I'm pretty happy with feeding each level 2 green with a single level 3 wire factory (and double fast-inserters). I'm not actually sure if double fast-inserters are necessary with the inserter bonus - I assume they are.
-Rail signals are very awkward to try to blueprint on top of each other. Avoid putting them within your blueprint's overlaps, if you can.
-I allow my copper and iron to pollute each other a bit at outposts, as it's trivial to clean up at the station. Logistics robots will clean them up for you, but be sure to have a couple of smart inserters filtering specifically for one or the other per train car, to ensure that copper doesn't saturate and starve out iron (and vice versa).
-Factories take much more iron to make than they do copper. Modules are the only real copper sink in the game.
*
Mining outposts have been more problematic for me. I went through a number of ideas before I settled on this scheme.
-I initially planned to blanket the map in roboport coverage, until I learned that I only needed about 2 roboports worth of solar panels to power each expansion, and until I learned that I had to manually disconnect the logistics networks of each outpost to prevent the robots from blowing out their pathing distances. It was more work to disconnect the networks than it was to just set up small networks on the line.
-I played with the idea of powering each mining outpost independently with solar, without stringing power out to them, but it was a massive pain to layout, and you could only set up the initial roboport during the day. It just wasn't worth it - big electric poles are pretty easy to string from a train.
-I was using blueprints to stamp rail, but it really is just faster to manually lay it from a train (especially because of the aforementioned big-blueprint problems).
-I was also stamping 4 way intersections, with a roundabout embedded between the two tracks. This is theoretically a fine layout for expanding mining north or south, but it caused east and westbound traffic to block each other, which was no good. I find that a simple narrow loop is a lot more robust.
-For a long time, I was committed to the idea of having a small supply train that carried all the outpost materials I needed, but it was always unwieldy. A train with 2 cars is slower to lay track than a lone locomotive. It's difficult to get a precise number of materials into a train without reserving train car spots, and it's not possible to blueprint those and it's inconvenient to copy them from one expansion to another. And at the end of the day, two train cars really only gets you 40 slots - your inventory has 80 some, and you really only need most of it for laying mining expansions once the plans are set. It's just easier to set up personal logistics slots or a couple of requester chests near the factory exit.
The current scheme is this. I fill my inventory with track and mining materials, I place a locomotive, and I lay track west until I've seen enough resource patches. I manually put down a turn and lay track back east to the factory. I make a second circuit to place power poles, and a third to lay periodic rail signals. I go out a fourth time to plop blueprints for the miners and the loading stations and I start up each station's 2 car train.
One thing I hadn't changed was having the miners feed directly into electric furnaces. Smelting is very space consuming, so it makes sense to do it out in the field rather than having it crowd my factory. It's not possible to get full coverage with electric furnaces on top of ore fields, but really, only 2 tiles are wasted out of 24 - that's 92% coverage. It's an independent self-scaling modular plan that requires no alignment. The loss in mining density can be somewhat painful, but this feels like the fastest possible way to set up miners.
The most time consuming thing is still clearing out big-spitter nests, even with maxed upgrades of everything. In future attempts, I think I may play with small nests.
*
It may look like I'm over producing power, but most of the factories are not operating at capacity. I believe my math is about right here.
In the future, I may consider using substations instead of tessellating medium power poles for my solar farms. Certain configurations can give medium power poles exceptional space efficiency, but substations may just be easier to work with, and aren't much more expensive.
*
You can see it plainly in the production tab. The production is very modest compared to some factories I've seen on reddit. I could up the throughput by expanding more rapidly, consuming the resources the 6 expansions can produce, but my computer seems rather unhappy with my ambitions.
This is my big question, to anyone who might know: What is the most computationally expensive thing about my factory, and how can I minimize it? Is it the 200 logistics robots servicing 200 requester/provider chests per factory expansion? Is it the 70 isolated red wire networks per expansion? Is it the logistics networks at the mining outposts? Or is it simply the biter/spitter density?
I'm planning a Mk 2, possibly on a map with smaller biter nests, and I'm considering things to do differently.
1) The station layout, with supplies laid out vertically while the factories themselves expanded vertically, was very awkward. The previous factory couldn't build the next factory's loading station without manual intervention to disconnect the two logistics networks, and in my experience, it's far more work to disconnect two logistics networks than it is to simply start a fresh one.
A far more elegant solution would be to simply place providers at the bottom and requesters at the top. The requesters would feed directly into the next factory's providers with smart inserters in the 1-tile gap between each factory's logistics network. If there's a shortage of materials in one factory, the factory before it can feed the one that comes after. It would function much like a huge main bus, and every factory along the line could participate in a large expansion without any player intervention.
A direct chest-to-chest bus would be less flexible than the train solution. It would be quite a lot of work to turn or extend the line to avoid lakes and the like. But at least I wouldn't be drowning in seldom-used factory supply stops.
2) Without the need to squeeze the factory into a train, I'm free to use a wider variety of materials in the factory's design. I'm thinking about using belts again, if the raw number of requester/provider chests is in fact the computational problem. The main bus could be an actual 30-wide bus, if the belts simulate better than 200 logistics robots.
3) I believe I'll start automating poison capsules at each factory.
Any other suggestions?
http://imgur.com/a/P5PKp/titledesc
My computer's starting to struggle with the simulation, so I figure this is a good time to stop and take stock.
The dream of the Von Neumann factory is the dream of Factorio - a factory that spits out more factories. In theory, with blueprints, a Von Neumann factory could double its size every 20 minutes, but in practice there are a number of interesting challenges to contend with when playing with the base game.
1) Mineral patches are randomly distributed, so there must necessarily be some manual involvement in the layout of mining outposts.
2) Logistics robots do not have any kind of priority algorithm. They seem to choose tasks within their network arbitrarily and their pathing distance grows exponentially. As far as I can tell, there is no way to establish effective filtering or resource distribution in storage chests to attenuate this pathing distance explosion. Logistics networks simply cannot scale beyond a screen or two, so they must manually be separated between factory expansions.
3) Large blueprints, more than two or three screens in size, are very difficult to place accurately. The ideal way to grow a factory with blueprints is to tessellate it, with overlapping identical parts on the edges, but blueprints are always centered on the cursor, so it can be hard to find a common overlap. Even when you can, it can then later be hard to tell what random tree or rock off the edge of the screen is blocking your blueprint placement. The dream of doubling the blueprint size with every iteration is not realistic when construction robots can't destroy rocks or fill in small bodies of water (or clear biter nests).
I thought these problems would be fun to engineer around and I think I've found some modest success with this first try. I built this factory off of my speedrun save, so biters are passive and resource patches are rich and the tech is maxed.
*
I'm fairly satisfied with the baseline factory expansion design. It's quite compact. I settled on 12 refineries, feeding 3 plastic and 12 batteries. The plastic fed 25 red circut factory (1 roboport factory) and the batteries fed 4 accumulator factories. The elements of the design are simple - two assemblers fed by a requester chest and feeding into a provider chest, with an electric pole and red wired smart inserters to manage the buffer. When fully supplied, the factory creates enough components to create a copy of itself every 20 minutes, refineries and trains and logistic robots and mining outpost materials and all.
The components are loaded onto a 9 car train and shipped to the next factory site. The roboports in the center, surrounded by lights, are laid out at very particular ranges. The leftmost allows for the preliminary construction of the loading station in which the 9 car train can be offloaded. The second brings the offload chests into logistics network range, allowing construction to begin once the networks has been disconnected from the previous factory, as we do not want logistics robots stealing the supplies. The third brings the loading chests into logistics network range, once the factory is running and ready to produce the next copy.
The raw resource loading station is fairly straight forward. I have 5 drop spots - c, i, o, s, and m for copper, iron, oil, stone/coal, and mixed copper/iron. The outposts are generally named c1, i1, o1, etc. It's very important to name them the same for every factory expansion, as it quickly becomes unweildly managing 30+ train stops. Because their names are the same, it's important that the raw resource train network remains disconnected between factories. Trains will prioritize the nearest available stop and have no sense of the current fullness of the station, so you'd very quickly get factory starvation. Unfortunately, water must be connected manually, but it's not terrible. A single water line supported by four-pump pumping stations can support roughly 3-4 factory expansions.
*
Important lessons:
-It doesn't actually seem important to minimize the number of requester/provider chests in a factory logistics network. The throughput is the same, whether a robots feed one chest feeding a line feeding 8 furnaces, or whether robots feed 8 chests. Thus, I settled on a belt-less design, as belts are rather space-inefficient when squeezing a factory into a train.
-Put the barrel assembler right next to the 9 car factory train and load directly into it. Do not put barrel assembly onto the logistics network, or you will saturate your pipeline with empty barrels and actually prevent the emptying of full ones.
-Refineries require level 3 assemblers, so you might as well use them elsewhere as well. I'm pretty happy with feeding each level 2 green with a single level 3 wire factory (and double fast-inserters). I'm not actually sure if double fast-inserters are necessary with the inserter bonus - I assume they are.
-Rail signals are very awkward to try to blueprint on top of each other. Avoid putting them within your blueprint's overlaps, if you can.
-I allow my copper and iron to pollute each other a bit at outposts, as it's trivial to clean up at the station. Logistics robots will clean them up for you, but be sure to have a couple of smart inserters filtering specifically for one or the other per train car, to ensure that copper doesn't saturate and starve out iron (and vice versa).
-Factories take much more iron to make than they do copper. Modules are the only real copper sink in the game.
*
Mining outposts have been more problematic for me. I went through a number of ideas before I settled on this scheme.
-I initially planned to blanket the map in roboport coverage, until I learned that I only needed about 2 roboports worth of solar panels to power each expansion, and until I learned that I had to manually disconnect the logistics networks of each outpost to prevent the robots from blowing out their pathing distances. It was more work to disconnect the networks than it was to just set up small networks on the line.
-I played with the idea of powering each mining outpost independently with solar, without stringing power out to them, but it was a massive pain to layout, and you could only set up the initial roboport during the day. It just wasn't worth it - big electric poles are pretty easy to string from a train.
-I was using blueprints to stamp rail, but it really is just faster to manually lay it from a train (especially because of the aforementioned big-blueprint problems).
-I was also stamping 4 way intersections, with a roundabout embedded between the two tracks. This is theoretically a fine layout for expanding mining north or south, but it caused east and westbound traffic to block each other, which was no good. I find that a simple narrow loop is a lot more robust.
-For a long time, I was committed to the idea of having a small supply train that carried all the outpost materials I needed, but it was always unwieldy. A train with 2 cars is slower to lay track than a lone locomotive. It's difficult to get a precise number of materials into a train without reserving train car spots, and it's not possible to blueprint those and it's inconvenient to copy them from one expansion to another. And at the end of the day, two train cars really only gets you 40 slots - your inventory has 80 some, and you really only need most of it for laying mining expansions once the plans are set. It's just easier to set up personal logistics slots or a couple of requester chests near the factory exit.
The current scheme is this. I fill my inventory with track and mining materials, I place a locomotive, and I lay track west until I've seen enough resource patches. I manually put down a turn and lay track back east to the factory. I make a second circuit to place power poles, and a third to lay periodic rail signals. I go out a fourth time to plop blueprints for the miners and the loading stations and I start up each station's 2 car train.
One thing I hadn't changed was having the miners feed directly into electric furnaces. Smelting is very space consuming, so it makes sense to do it out in the field rather than having it crowd my factory. It's not possible to get full coverage with electric furnaces on top of ore fields, but really, only 2 tiles are wasted out of 24 - that's 92% coverage. It's an independent self-scaling modular plan that requires no alignment. The loss in mining density can be somewhat painful, but this feels like the fastest possible way to set up miners.
The most time consuming thing is still clearing out big-spitter nests, even with maxed upgrades of everything. In future attempts, I think I may play with small nests.
*
It may look like I'm over producing power, but most of the factories are not operating at capacity. I believe my math is about right here.
In the future, I may consider using substations instead of tessellating medium power poles for my solar farms. Certain configurations can give medium power poles exceptional space efficiency, but substations may just be easier to work with, and aren't much more expensive.
*
You can see it plainly in the production tab. The production is very modest compared to some factories I've seen on reddit. I could up the throughput by expanding more rapidly, consuming the resources the 6 expansions can produce, but my computer seems rather unhappy with my ambitions.
This is my big question, to anyone who might know: What is the most computationally expensive thing about my factory, and how can I minimize it? Is it the 200 logistics robots servicing 200 requester/provider chests per factory expansion? Is it the 70 isolated red wire networks per expansion? Is it the logistics networks at the mining outposts? Or is it simply the biter/spitter density?
I'm planning a Mk 2, possibly on a map with smaller biter nests, and I'm considering things to do differently.
1) The station layout, with supplies laid out vertically while the factories themselves expanded vertically, was very awkward. The previous factory couldn't build the next factory's loading station without manual intervention to disconnect the two logistics networks, and in my experience, it's far more work to disconnect two logistics networks than it is to simply start a fresh one.
A far more elegant solution would be to simply place providers at the bottom and requesters at the top. The requesters would feed directly into the next factory's providers with smart inserters in the 1-tile gap between each factory's logistics network. If there's a shortage of materials in one factory, the factory before it can feed the one that comes after. It would function much like a huge main bus, and every factory along the line could participate in a large expansion without any player intervention.
A direct chest-to-chest bus would be less flexible than the train solution. It would be quite a lot of work to turn or extend the line to avoid lakes and the like. But at least I wouldn't be drowning in seldom-used factory supply stops.
2) Without the need to squeeze the factory into a train, I'm free to use a wider variety of materials in the factory's design. I'm thinking about using belts again, if the raw number of requester/provider chests is in fact the computational problem. The main bus could be an actual 30-wide bus, if the belts simulate better than 200 logistics robots.
3) I believe I'll start automating poison capsules at each factory.
Any other suggestions?