Chemical Plant: Circuit "Set Recipe" not usable?

Don't know how to use a machine? Looking for efficient setups? Stuck in a mission?
Phoenixia
Burner Inserter
Burner Inserter
Posts: 9
Joined: Fri Aug 09, 2024 12:40 pm
Contact:

Chemical Plant: Circuit "Set Recipe" not usable?

Post by Phoenixia »

How do you change the recipe of Chemical Plants if you can't change the input fluids?

Consider the following use case:
I've a bunch of Chemical plants that create solid fuel from petroleum, light/heavy oil.
I want to dynamically change the recipe to the highest reserve of liquid in order to auto-balance.

However I cannot dynamically change the input fluid. So making use of "Set Recipe" seems essentially impossible with the exception of the solid fuel & lubricant recipe as they take the same input.

Except if you use a roundabout way with barrels.
Phoenixia
Burner Inserter
Burner Inserter
Posts: 9
Joined: Fri Aug 09, 2024 12:40 pm
Contact:

Re: Chemical Plant: Circuit "Set Recipe" not usable?

Post by Phoenixia »

Nevermind I found the solution to my problem.
Pumps with filters set by circuits! It's basically a switch. When the pipe is empty It'll allow the other fluid to flow in.

Image

However my new problem is that I can't set the specific recipe for solid fuel for the chemical plant.
Tertius
Smart Inserter
Smart Inserter
Posts: 1024
Joined: Fri Mar 19, 2021 5:58 pm
Contact:

Re: Chemical Plant: Circuit "Set Recipe" not usable?

Post by Tertius »

For solid fuel, chemical plants have always 2 identical inputs. If you want to switch between light oil and petroleum (as I do), you can connect one fluid input with light oil supply and the other with petroleum supply.

This is an example where as default the recipe is solid fuel from light oil, and if there is more than 20000 petroleum in the storage tank, the recipe is switched to solid fuel from petroleum. The petroleum recipe signal is just added to the green wire and the light oil recipe can stay, because the petroleum recipe has priority if both are on the wire (seems some internal ordering).





If you just have one input for a different recipe and that gets switched to a different fluid, you can probably change the fluid in the input pipe. My approach would be to use pumps as a valve and feed the input pipe with the proper fluid currently required by the recipe. And use pipes with filter to flush unwanted fluid from that pipe segment back into their storage. Didn't try that, seems like overengineering, but I don't see why it couldn't work.
Attachments
out.mp4
(6.94 MiB) Downloaded 28 times
Phoenixia
Burner Inserter
Burner Inserter
Posts: 9
Joined: Fri Aug 09, 2024 12:40 pm
Contact:

Re: Chemical Plant: Circuit "Set Recipe" not usable?

Post by Phoenixia »

Oh, I didn't know about
11-01-2024, 00-10-04.png
11-01-2024, 00-10-04.png (4.02 KiB) Viewed 1723 times
.
Thanks for the feedback.
Tertius
Smart Inserter
Smart Inserter
Posts: 1024
Joined: Fri Mar 19, 2021 5:58 pm
Contact:

Re: Chemical Plant: Circuit "Set Recipe" not usable?

Post by Tertius »

And thanks to you for the thread. I didn't realize setting recipes has a real practical use and isn't just mythical base building for the sake (and fun) of building complex circuits. Previously, I had duplicated chemical plants with both recipes and switched supply with pumps. Now it's a very clean design with recipe switching. I guess there are more use cases than this example.
PrimeEagle
Burner Inserter
Burner Inserter
Posts: 16
Joined: Wed Oct 12, 2022 9:51 pm
Contact:

Re: Chemical Plant: Circuit "Set Recipe" not usable?

Post by PrimeEagle »

You can set the recipe and the filter for the pump, and that works for the pipes that come after the pump but that doesn't clear out the previous liquid that was in the pump itself. Any way to address that?
Phoenixia
Burner Inserter
Burner Inserter
Posts: 9
Joined: Fri Aug 09, 2024 12:40 pm
Contact:

Re: Chemical Plant: Circuit "Set Recipe" not usable?

Post by Phoenixia »

So I didn't actually go for either designs in my factory because I had to get it up quickly so I went for petroleum only and having the auto-balancing be done with oil-cracking.
That said Tertius dual fluid design is nice compromise between complexity and Effectiveness.
In order of complexity:
1: One liquid per chemical plant
2: Tertius's Dual liquid per chemical plant design
3: My Triple liquid per chemical plant idea.

To (sorta) answer PrimeEagle's question.
In theory you could pump it back into your supply with filters pumps & power switch making all the non active fluid's pumps active.
But, there is more to it, you'll also need to take into account when fluids hit equilibrium and start switching recipes too quickly when you have the switch condition:

P: Petroleum
L: Light oil
H: Heavy Oil

P: {P<L AND P<H} -> Use Petroleum recipe
L: {L<P AND L<H} -> Use Light oil recipe
H: {H<P AND H<L} -> Use Heavy oil recipe

You'll need a buffer, to remedy this you can use a upper and a lower bound... or something TBD. I need to get back to my mess of a factory.

In practice, I'll give it a shot when I finish space age. Or sooner.
Tertius
Smart Inserter
Smart Inserter
Posts: 1024
Joined: Fri Mar 19, 2021 5:58 pm
Contact:

Re: Chemical Plant: Circuit "Set Recipe" not usable?

Post by Tertius »

Switching recipes this way isn't a good approach, in my opinion. One should prefer the light oil recipe, because it is the most efficient. It requires 10 light oil. The other ones need double. They are just there for emergency use or to get rid of the fluid faster. However, to get rid of some fluid, you better use cracking.

For example, heavy oil cracking consumes 40 heavy oil and produces 30 light oil, which can be converted to 3 solid fuel. Directly converting 40 heavy oil to solid fuel just yields 2 solid fuel. It's even worse if you crack light oil to petroleum, then make solid fuel.
This will happen if you just check for oil level to decide which recipe you use.

If you have a production line just for solid fuel+rocket fuel, there is an easy optimal algorithm for advanced oil processing:
- crack heavy oil to light oil
- build the proper amount of light oil-to-solid fuel plants and petroleum-to-solid fuel plants
- the amount of machines is fixed, because the ratio of petroleum and light oil is fixed.
- no dynamic recipe switch required, because all the plants are operating simultaneously

Similar for coal liquefaction. I didn't actually compute numbers, but as far as I see it, this is the most efficient way for solid fuel production. You need much less petroleum processing plants and can move them to the light oil recipe. Heavy oil is still cracked to light oil. Such a factory also doesn't need dynamic recipes.

You need dynamic recipes only for unknown output ratios, for example if you feed a mall that's producing items you need for building. In this case, you need heavy oil for lubricant, light oil for solid fuel, petroleum gas for plastic and sulfur. Just the surplus of light and heavy oil needs to be cracked. It must be cracked to keep all 3 fluids balanced, but in a balanced (circuit controlled) way. The challenge is that if there is a surplus of petroleum, the refineries will clog.
So this is where we can employ dynamic recipes. We use petroleum-to-solid fuel only for getting rid of petroleum surplus, because there is no other way to get rid of it (given that for some reason our mall doesn't need plastic/sulfur and nothing except trains will consume something from our plant).

So do this:
- enable heavy oil cracking only if the heavy oil storage is full (MUST do to unclog refinery from heavy oil)
- enable light oil cracking only if the light oil storage is full (MUST do to unclog refinery from light oil)
- enable petroleum-to-solid fuel recipe if the petroleum storage is full (MUST do to unclog refinery from petroleum)
- enable petroleum-to-solid fuel recipe if the light oil storage is empty (MUST do to consume petroleum to restart refinery processing to get more light oil)
- enable light oil-to-solid fuel recipe otherwise

In my own oil processing plant, I added another component. It can happen the mall consumes more heavy oil (through lubricant) the plant is able to produce without clogging petroleum. I encountered this by building huge amounts of blue belts and nothing else at the same time. So I added one coal liquefaction refinery to produce the missing heavy oil, and all refineries get additional controls:
- enable coal liquefaction refinery if heavy oil storage is empty (MUST do to have enough heavy oil/lubricant)
- enable advanced oil processing refineries if petroleum is below threshold; threshold is below recipe switching threshold to avoid getting stuck in the inefficient petroleum-to-solid fuel recipe; interacts with the threshold of the recipe switching above (MUST do to get efficient solid fuel recipe)
Tertius
Smart Inserter
Smart Inserter
Posts: 1024
Joined: Fri Mar 19, 2021 5:58 pm
Contact:

Re: Chemical Plant: Circuit "Set Recipe" not usable?

Post by Tertius »

I also made a naive implementation that uses all 3 oil types and performs pipe flushing: viewtopic.php?p=633905#p633905
Post Reply

Return to “Gameplay Help”