Advice Wanted: Improving My Robot Mall's Production Logic

Don't know how to use a machine? Looking for efficient setups? Stuck in a mission?
kuguma
Manual Inserter
Manual Inserter
Posts: 2
Joined: Fri Nov 22, 2024 1:56 am
Contact:

Advice Wanted: Improving My Robot Mall's Production Logic

Post by kuguma »

Hello! I’m playing Factorio again for the first time in 8 years.
(The last save I played was on version 0.12.33...)

I’m amazed by how much has improved, and I’m really enjoying Space Age.

Now, I’m posting here to seek advice from everyone about a Robot Mall I’ve been working on recently.

I’ve built a mall like the one shown below, but it doesn’t work well under certain conditions.
Do you have any good ideas on how to fix this?

Image

------------------------------------------------------------
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
------------------------------------------------------------

This mall is designed to automatically resolve item dependencies and produce items accordingly.
The mechanism is simple:

First, it randomly selects one item from a list of missing items.
Then, it tries to produce the selected item. If there aren’t enough materials in stock, the production is canceled, and a new item is selected at random.
This system works fine in normal cases, but it runs into problems when item stocks are low or when trying to produce items that require large amounts of materials (e.g., rail signals).

To check stock availability, the system refers to the logistics network’s inventory count.
Here’s where the issue arises: when a producible item is found and the request chest is set, robots start transporting the materials, reducing the logistics network’s inventory count.
Because of this decrease, the system concludes there aren’t enough materials, and the assembler cancels production.
As a result, when the stock is insufficient, the mall repeatedly cycles through selecting and canceling items at high speed.

How would you handle this situation? I’d appreciate your advice!
Attachments
cd31000c087a96431de88d8507216e35.mp4
(18.29 MiB) Downloaded 53 times
BaggyK
Inserter
Inserter
Posts: 43
Joined: Fri Mar 01, 2019 12:22 pm
Contact:

Re: Advice Wanted: Improving My Robot Mall's Production Logic

Post by BaggyK »

A couple of general suggestions.

Rather than immediately canceling the craft if the required ingredients drop below the required level, have a delay before canceling. The length of the delay will probably need some experimentation.

Or have two different checks for ingredient levels, an initial check that multiplies the number of items by say 5 before allowing the request for the initial number of items, and then monitor the levels for the actual level in case something else is using them.
Tertius
Smart Inserter
Smart Inserter
Posts: 1449
Joined: Fri Mar 19, 2021 5:58 pm
Contact:

Re: Advice Wanted: Improving My Robot Mall's Production Logic

Post by Tertius »

With a mall that simple you're unable to handle recipes that require complex ingredients you usually create in such a mall as well. The best example is robots. They require a flying robot frame, which require an electric engine unit, which require an engine unit, which require pipes.
If you remove the parent recipe from your assembler, there is no trace in the system which complex dependent ingredients are required, so your mall is just able to create items with simple ingredients you provide from elsewhere. If this isn't fine for you and you intend to implement crafting dependent items as well, I suggest you don't seek to fix the current behavior but instead design a fresh approach that includes dependent items.
kuguma
Manual Inserter
Manual Inserter
Posts: 2
Joined: Fri Nov 22, 2024 1:56 am
Contact:

Re: Advice Wanted: Improving My Robot Mall's Production Logic

Post by kuguma »

I think checking the inventory in a different way is a great idea. I’ll give it a try right away. Thank you for the advice!

As for recipes that involve liquids, I’m also struggling with those.
If the items can be made using assemblers, it might be possible to handle them by pre-placing pipes, but I haven’t tried that yet. (Since liquids would go to waste every time the recipe changes, some clever use of pumps might be necessary.)
The same applies to items that require chemical plants.

For other materials, even those with dependencies, this mall should be able to produce them on its own. (For example, modules.)
Tertius
Smart Inserter
Smart Inserter
Posts: 1449
Joined: Fri Mar 19, 2021 5:58 pm
Contact:

Re: Advice Wanted: Improving My Robot Mall's Production Logic

Post by Tertius »

About fluids: they don't go away if you change the recipe. They're pushed back into the pipe. And for an automated mall, in case you intend to support recipes with different fluids such as blue belts (lubricant) and concrete (water), you need to flush (pump back) the previous fluid. Only if the previous fluid is flushed completely, a different fluid will be allowed to enter the pipe.

Prepositioning pipes works, by the way. If the rotation is correct, they connect to the assembling machine if a recipe is set that requires fluid.

In case you're looking for examples, there are some dynamic mall examples in the "Show your creations" part of the forum: viewforum.php?f=193
Post Reply

Return to “Gameplay Help”