There would be zero changes to the per-tick calculations compared to the ones introduced in this FFF, only checking if a network is valid by a different metric. It would be very performant, only having hits when combining networks. The arbitrary number of junctions also doesn't mean anything, as the logic doesn't need pathing.Theikkru wrote: βFri Sep 27, 2024 9:19 pmThis would be nice, but in the first fluid FFF, the devs mentioned that one of the motivations for the implementation of "pipe segments" was that they were trying to get away from the complexities (and associated calculation costs) involved in pathing through a pipe network with an arbitrary number of junctions. Even if those calculations only had to be done during construction/deconstruction, bots exist in Factorio, so...protocol_1903 wrote: βFri Sep 27, 2024 8:57 pm[...]What if the pipe limitation was a point-to-point limit instead of a square? Each pipe can only be (for example) 500 fluid boxes away from the furthest pipe before the network becomes invalid.[...]
That's why everyone's been suggesting the slightly less realistic but far more performant "just count the tiles in the pipe segment".
Friday Facts #430 - Drowning in Fluids
-
- Fast Inserter
- Posts: 140
- Joined: Fri Sep 09, 2022 4:33 pm
- Contact:
Re: Friday Facts #430 - Drowning in Fluids
If you need to reach me, message me on discord.
I make qol mods. Check them out, maybe.
https://mods.factorio.com/user/protocol_1903
If you have a mod idea, I can look into it.
I make qol mods. Check them out, maybe.
https://mods.factorio.com/user/protocol_1903
If you have a mod idea, I can look into it.
Re: Friday Facts #430 - Drowning in Fluids
It would need pathing to figure out which branch of the network has the "furthest" fluid box. It's trivial if you have an "L" shaped pipe, but if it's "H" shaped, or more complex, you'd need to keep checking each leg to make sure the longest one hasn't changed due to where pipes are being added/removed. I'm sure there are ways you could make this more performant by saving more graph data in memory, but it's never going to be comparable to just keeping a running total of how many pipe tiles there are in the whole segment.protocol_1903 wrote: βFri Sep 27, 2024 9:42 pm[...]The arbitrary number of junctions also doesn't mean anything, as the logic doesn't need pathing.
-
- Manual Inserter
- Posts: 4
- Joined: Fri Sep 27, 2024 7:06 pm
- Contact:
Re: Friday Facts #430 - Drowning in Fluids
could go for a node based system where network flows, latency, and storage are precalculated between nodes (building connection points) when you construct the network to avoid constant runtime overhead.
or split pipes into separate networks (condition being where 2 pipe components never touch directly or by proxy) and add multithreadding to them.
Re: Friday Facts #430 - Drowning in Fluids
Fair enough. I do realise my post was way too laconic. What I meant was that both contraptions would be valid as "able to carry fluid without additional pumps". It's that one pump can feed a pipe network no matter how big and convoluted as long as it fits in a 250x250 square. I was wondering if making it length or "pipe number" based wouldn't make more sense.thermomug wrote: βFri Sep 27, 2024 8:40 pmI think both contraptions might be equal in terms of throughput to adjacent fluid segments at equilibrium (when fill levels are stable, meaning all input flows equal all output flows), but they are definitely not equal in capacity.
When introducing a fluid flow from one side (NOT the equilibrium case, like when a new oil train arrives at a starved factory), the segment with a higher capacity ( the right in your case ) will fill more slowly and thus also introduce a bigger temporal delay in the whole chain of segments. I think this might be what was meant by the devs with "the fluids feel[ing] much more like fluids again".
But that's really a minor rambling of mine, the 2.0 fluid system seems vastly superior in every aspect to the 1.1 one.
Koub - Please consider English is not my native language.
Re: Friday Facts #430 - Drowning in Fluids
Both of those are just methods of coping with the calculation costs by shunting them to other, hopefully less loaded computing components (memory in the former case and other cores in the latter). Neither actually reduce the costs like the FFFs do.CrazyAmphibian wrote: βFri Sep 27, 2024 9:51 pm[...]could go for a node based system where network flows, latency, and storage are precalculated between nodes (building connection points) when you construct the network to avoid constant runtime overhead.
or split pipes into separate networks (condition being where 2 pipe components never touch directly or by proxy) and add multithreadding to them.
-
- Fast Inserter
- Posts: 140
- Joined: Fri Sep 09, 2022 4:33 pm
- Contact:
Re: Friday Facts #430 - Drowning in Fluids
No, it doesn't. Each pipe keeps track of a value representing the distance to the furthest pipe. Whenever a new pipe is placed, it sets its own value to the lowest value around it + 1. Then each adjacent pipe updates using the same logic if it's distance + 1 is greater than the value , starting with the pipes of the highest value. No directions needed. You just represent the network as a series of nodes. You have to do a maximum of n/2 updates, where n is the number of pipes in the networkTheikkru wrote: βFri Sep 27, 2024 9:48 pmIt would need pathing to figure out which branch of the network has the "furthest" fluid box. It's trivial if you have an "L" shaped pipe, but if it's "H" shaped, or more complex, you'd need to keep checking each leg to make sure the longest one hasn't changed due to where pipes are being added/removed. I'm sure there are ways you could make this more performant by saving more graph data in memory, but it's never going to be comparable to just keeping a running total of how many pipe tiles there are in the whole segment.protocol_1903 wrote: βFri Sep 27, 2024 9:42 pm[...]The arbitrary number of junctions also doesn't mean anything, as the logic doesn't need pathing.
@Koub this is basically your idea
If you need to reach me, message me on discord.
I make qol mods. Check them out, maybe.
https://mods.factorio.com/user/protocol_1903
If you have a mod idea, I can look into it.
I make qol mods. Check them out, maybe.
https://mods.factorio.com/user/protocol_1903
If you have a mod idea, I can look into it.
-
- Manual Inserter
- Posts: 4
- Joined: Fri Sep 27, 2024 7:06 pm
- Contact:
Re: Friday Facts #430 - Drowning in Fluids
yeah? the FFF proposal is a heavily simplified system, of course it'll have lower resource usage.
it's not like factorio uses *that* much memory normally as-is, and i don't imagine this will actually use that much more seeing as these calculations would need to be done anyways (just done every tick), and variables are never free.
fluid simmulations (even simple ones) are very resource intensive.
Re: Friday Facts #430 - Drowning in Fluids
Something about that logic doesn't seem to work quite right, but regardless, my point stands; you have to query/update n/2 pipe elements for each segment change, which is O(n) complexity, whereas keeping a running total is just O(1).protocol_1903 wrote: βFri Sep 27, 2024 9:57 pm[...]Each pipe keeps track of a value representing the distance to the furthest pipe. Whenever a new pipe is placed, it sets its own value to the lowest value around it + 1. Then each adjacent pipe updates using the same logic if it's distance + 1 is greater than the value , starting with the pipes of the highest value. No directions needed. You just represent the network as a series of nodes. You have to do a maximum of n/2 updates, where n is the number of pipes in the network[...]
-
- Fast Inserter
- Posts: 140
- Joined: Fri Sep 09, 2022 4:33 pm
- Contact:
Re: Friday Facts #430 - Drowning in Fluids
The logic is sound, assuming a wrote it correctly. Regardless, I think it's worth trying. It's certainly more performant than 1.1 fluid logistics, and if it's too much then yeah reduce to a running total. But a running total would still be better than the strange square bounding box limitation.
If you need to reach me, message me on discord.
I make qol mods. Check them out, maybe.
https://mods.factorio.com/user/protocol_1903
If you have a mod idea, I can look into it.
I make qol mods. Check them out, maybe.
https://mods.factorio.com/user/protocol_1903
If you have a mod idea, I can look into it.
-
- Inserter
- Posts: 23
- Joined: Fri Apr 26, 2024 12:57 pm
- Contact:
Re: Friday Facts #430 - Drowning in Fluids
It sounds like they even managed to solve that, so that the balance of input and output will be reflected in the level that the pipe settles at. Which, hopefully, should make it easier to get an intuitive sense of "this pipe has a lot of unused throughput, I can expand no problem" vs. "this pipe is nearly tapped out, I need to build up production right away". Which was not something the old system was very helpful about in my experience.morse wrote: βFri Sep 27, 2024 5:16 pm I understood that it would be rarely noticeable in real gameplay, where your production is either higher than the demand, and you won't notice the "magic" since your pipes will be always full, or lower, in which case the throughput won't be your problem, your consumers will starve anyway.
Nothing's been said about them, so I assume they're still there. They're less useful for long-range, high-throughput transfer than fluid wagons (which is intentional, and always was, but was sometimes undermined by all the weirdness about fluid transport), but they have their uses:Danjen wrote: βFri Sep 27, 2024 8:22 pm I might be misremembering, but did the fluid barrels get removed? I know fluid trains are the way to go for bulk distance transport, but conceptually, I love the idea of using barrels and transporting those, since it feels more "industrial" if that makes sense. Not sure if it's so compatible with current fluid throughput though
* They can be carried by bots, which otherwise can't carry fluids at all.
* They can easily be made to piggyback in cargo cars with other materials (e.g., you can have the same cargo car carry sulfuric acid barrels to and from a uranium mine with a few slots, and carry the resulting uranium ore back to base with the rest of its inventory).
* They're easier to split and meter out than piped fluids, in case you need to manage how much of your fluid supply is going to one particular place.
* They can be transported via belt arbitrarily long distances without needing pumps, which might be useful in some cases when supplying distant flamethrower turrets or other outposts (e.g., uranium mining again).
Re: Friday Facts #430 - Drowning in Fluids
Those statements don't seem very congruent with each other, but at the very least the last one is definitely untrue. The model as described in the FFFs is at least a class of complexity lower than the one in 1.1, so the resource savings would not only be significant, but also scale with the calculation burden.CrazyAmphibian wrote: βFri Sep 27, 2024 10:03 pm[...]yeah? the FFF proposal is a heavily simplified system, of course it'll have lower resource usage.[...]i don't imagine this will actually use that much more seeing as these calculations would need to be done anyways (just done every tick), and variables are never free.
fluid simmulations (even simple ones) are very resource intensive.
-
- Manual Inserter
- Posts: 2
- Joined: Fri Sep 27, 2024 10:33 pm
- Contact:
Re: Friday Facts #430 - Drowning in Fluids
The mechanic of just having it be artificially within a region of 250x250 (or 256x256) tiles does not seem right to me. It seems very artificial, and as I saw someone else post, it is way to binary of a system. I also would prefer the idea that the longer the pipeline.
Here is what I think would feel a lot more natural, rather than it being an arbitrary area limit (which as I also saw some people say, how is that area determined?) there is a "soft" cap on the flow rate of the pipes based on the number of pipes in a pipe segment. Where each segment is determined by the number of pipes that are directly connected and not divided by pumps and other machines.
Let us pick some arbitrary value of say 50 pipes in a segment is the soft cap, each pipe above that reduces the maximum throughput of the pipe by 1% per pipe, so the base max rate is 6,000 per second, so if a pipe was 100 pipes long it's maximum throughput is instead 3,000 per second (a -50%). This feels way more natural to me.
I also like the idea that we could treat pipes like conveyor belts, rather than them automatically connecting. I can't tell you how many times I've had to use WAY more space with my pipe setup so that I can keep separate fluid lines all one tile apart. I like building factories as compact as possible.
Here is what I think would feel a lot more natural, rather than it being an arbitrary area limit (which as I also saw some people say, how is that area determined?) there is a "soft" cap on the flow rate of the pipes based on the number of pipes in a pipe segment. Where each segment is determined by the number of pipes that are directly connected and not divided by pumps and other machines.
Let us pick some arbitrary value of say 50 pipes in a segment is the soft cap, each pipe above that reduces the maximum throughput of the pipe by 1% per pipe, so the base max rate is 6,000 per second, so if a pipe was 100 pipes long it's maximum throughput is instead 3,000 per second (a -50%). This feels way more natural to me.
I also like the idea that we could treat pipes like conveyor belts, rather than them automatically connecting. I can't tell you how many times I've had to use WAY more space with my pipe setup so that I can keep separate fluid lines all one tile apart. I like building factories as compact as possible.
Last edited by SpecterNadir7 on Fri Sep 27, 2024 10:38 pm, edited 1 time in total.
Re: Friday Facts #430 - Drowning in Fluids
Assume a T-shaped pipe with 3 along the top and 2 on the vertical.protocol_1903 wrote: βFri Sep 27, 2024 10:11 pm[...]The logic is sound, assuming a wrote it correctly.[...]
According to instructions:
3 2 3protocol_1903 wrote: βFri Sep 27, 2024 9:57 pm[...]Each pipe keeps track of a value representing the distance to the furthest pipe.
- 2
- 3
Add a pipe:
3 2 3 (4=3+1)protocol_1903 wrote: βFri Sep 27, 2024 9:57 pmWhenever a new pipe is placed, it sets its own value to the lowest value around it + 1.
- 2
- 3
Check adjacent:
3 2 (3+1β―4) 4protocol_1903 wrote: βFri Sep 27, 2024 9:57 pmThen each adjacent pipe updates using the same logic if it's distance + 1 is greater than the value , starting with the pipes of the highest value.[...]
- 2
- 3
Update stopped due to condition untrue, but graph is now wrong:
3 2 3 4
- 2(!)
- 3(!)
-
- Fast Inserter
- Posts: 140
- Joined: Fri Sep 09, 2022 4:33 pm
- Contact:
Re: Friday Facts #430 - Drowning in Fluids
Hm, i hadn't thought about the other end. In that case, you would need to propogate down the system until it reaches a low point (in this case, the top of the T junction) then update from there.Theikkru wrote: βFri Sep 27, 2024 10:35 pm Assume a T-shaped pipe with 3 along the top and 2 on the vertical.
According to instructions:3 2 3protocol_1903 wrote: βFri Sep 27, 2024 9:57 pm[...]Each pipe keeps track of a value representing the distance to the furthest pipe.
- 2
- 3
...
Update stopped due to condition untrue, but graph is now wrong:
3 2 3 4
- 2(!)
- 3(!)
So it would be
base layout
Code: Select all
3 2 3
2
3
Code: Select all
3 2 3 4*
2
3
Code: Select all
3 2 3 4
2
3
Code: Select all
3 2 3 4
3*
3
Code: Select all
3 2 3 4
3
4*
If you need to reach me, message me on discord.
I make qol mods. Check them out, maybe.
https://mods.factorio.com/user/protocol_1903
If you have a mod idea, I can look into it.
I make qol mods. Check them out, maybe.
https://mods.factorio.com/user/protocol_1903
If you have a mod idea, I can look into it.
Re: Friday Facts #430 - Drowning in Fluids
I'm just not seeing how you could generalize this across networks of arbitrary complexity without pretty much checking every last leg, and that won't look pretty, computationally.protocol_1903 wrote: βFri Sep 27, 2024 10:42 pm[...]you would need to propogate down the system until it reaches a low point[...]
-
- Fast Inserter
- Posts: 140
- Joined: Fri Sep 09, 2022 4:33 pm
- Contact:
Re: Friday Facts #430 - Drowning in Fluids
There's most likely a way to design the system to work properly. It's probably already been done before elsewhere. My point was that, if done correctly, this system would be better than the bounding box or nodes in network limits
If you need to reach me, message me on discord.
I make qol mods. Check them out, maybe.
https://mods.factorio.com/user/protocol_1903
If you have a mod idea, I can look into it.
I make qol mods. Check them out, maybe.
https://mods.factorio.com/user/protocol_1903
If you have a mod idea, I can look into it.
Re: Friday Facts #430 - Drowning in Fluids
Uh, the bounding box is also O(1)...protocol_1903 wrote: βFri Sep 27, 2024 11:01 pmThere's most likely a way to design the system to work properly. It's probably already been done before elsewhere. My point was that, if done correctly, this system would be better than the bounding box or nodes in network limits
-
- Manual Inserter
- Posts: 2
- Joined: Fri Feb 27, 2015 5:21 am
- Contact:
Re: Friday Facts #430 - Drowning in Fluids
Hm.
I'm a fan of the main idea for 2.0 fluids, but... this loses me a little bit. It's probably fine, especially if you make it 256 for the chunk alignment.
But the "falloff if the area gets bigger with some flow rate multiplier" idea is absolutely preferable to just "it breaks and lets you know where" -- I agree with the idea that being able to solve the problem myself is something I'd rather see than just being told "this is where you need a new pump". Something just breaking out of nowhere because you made it one tile longer doesn't feel very Factorio, on a deep level.
1.1 Fluids had a bunch of issues that I'm glad to be rid of, just hoping this gets another pass before release compared to something this arbitrary...
I'm a fan of the main idea for 2.0 fluids, but... this loses me a little bit. It's probably fine, especially if you make it 256 for the chunk alignment.
But the "falloff if the area gets bigger with some flow rate multiplier" idea is absolutely preferable to just "it breaks and lets you know where" -- I agree with the idea that being able to solve the problem myself is something I'd rather see than just being told "this is where you need a new pump". Something just breaking out of nowhere because you made it one tile longer doesn't feel very Factorio, on a deep level.
1.1 Fluids had a bunch of issues that I'm glad to be rid of, just hoping this gets another pass before release compared to something this arbitrary...
-
- Fast Inserter
- Posts: 140
- Joined: Fri Sep 09, 2022 4:33 pm
- Contact:
Re: Friday Facts #430 - Drowning in Fluids
Better as in makes more sense, less arbitrarily restrictive, and is more intuitive to the player.Theikkru wrote: βFri Sep 27, 2024 11:02 pmUh, the bounding box is also O(1)...protocol_1903 wrote: βFri Sep 27, 2024 11:01 pm There's most likely a way to design the system to work properly. It's probably already been done before elsewhere. My point was that, if done correctly, this system would be better than the bounding box or nodes in network limits
Having to fold your blueprint in half because it's "too long" is not a good constraint.
Having to split your blueprint because you have too many pipes in a network isn't as bad, but isn't amazing. (your other suggestion)
If you need to reach me, message me on discord.
I make qol mods. Check them out, maybe.
https://mods.factorio.com/user/protocol_1903
If you have a mod idea, I can look into it.
I make qol mods. Check them out, maybe.
https://mods.factorio.com/user/protocol_1903
If you have a mod idea, I can look into it.
Re: Friday Facts #430 - Drowning in Fluids
I fully support those changes.
Devs you're doing an amazing job
Devs you're doing an amazing job
I'm not english, sorry for my mistakes