Logistic Network Needs to be smarter

Post all other topics which do not belong to any other category.
Escadin
Fast Inserter
Fast Inserter
Posts: 181
Joined: Thu Mar 17, 2016 3:15 pm
Contact:

Logistic Network Needs to be smarter

Post by Escadin »

I mean the bots are dumb AF. There is a lot that could be done to improve their behaviour like letting them observe their tasks to get an update should it no longer be required or various distance checks when it comes to deciding which bot is issued a task and which task it should be. Better task scheduling couldn't hurt either. And of course, a little more control over their AI. Like, additional entities (beacons etc) that allow is to guide them and give us more control over their behaviour.
I don't want to go too much into detail here since this is not supposed to be a suggestion.

The question is: Would that be feasable at all? I mean not only with the scope of their release schedule but also from an optimization point of view. Would it be a bad thing if we generally had to build less bots (with larger cargo) but they're smarter and more efficient in return? Is there any time left for them to implement this until release?
"--? How are commands compounded in a compounded compound command commanding compound composts." -defines.lua
User avatar
Syrchalis
Fast Inserter
Fast Inserter
Posts: 137
Joined: Wed Feb 15, 2017 9:03 am
Contact:

Re: Logistic Network Needs to be smarter

Post by Syrchalis »

First improvement I would put on the list is to make bots not cut corners. While shorter, it makes it impossible to connect outposts to your network, because the robots will not go along the tracks of the train that might have turrets and are secure, but they go the direct route which can get them killed easily. So basically they should try to stay within the construction area of the robotports when traveling.
User avatar
theRustyKnife
Filter Inserter
Filter Inserter
Posts: 259
Joined: Thu Feb 26, 2015 9:26 pm
Contact:

Re: Logistic Network Needs to be smarter

Post by theRustyKnife »

I think the bots are dumb for a good reason: performance. The way they are now, they're really efficient in terms of CPU time, so tens of thousands of them can be used without too many issues. If they were to be smarter, they would have to calculate many more things, thus taking a lot longer than the current system where simply the closest (?) bot is sent to do the task and flies straight to the target no matter what.

Indeed, I wouldn't mind them being smarter either, but I'm certainly willing to make the sacrifice for performance.

That's just my thought tho - I don't know how the game's code actually works, but I think this is a likely scenario.

Cheers TRK
Escadin
Fast Inserter
Fast Inserter
Posts: 181
Joined: Thu Mar 17, 2016 3:15 pm
Contact:

Re: Logistic Network Needs to be smarter

Post by Escadin »

Syrchalis wrote:First improvement I would put on the list is to make bots not cut corners. While shorter, it makes it impossible to connect outposts to your network, because the robots will not go along the tracks of the train that might have turrets and are secure, but they go the direct route which can get them killed easily. So basically they should try to stay within the construction area of the robotports when traveling.
What I would love to see in this regard is a guiding system that the player can install. I.e. a bunch of entities that give you control over some aspects of the AI. Essentially, they could act as the corner pieces of belts making bots behave like belts but you only have to place on entity every X tiles instead of the usual full coverage. That would also include equivialents of splitters that force bots to evenly distribute their cargo.
"--? How are commands compounded in a compounded compound command commanding compound composts." -defines.lua
Escadin
Fast Inserter
Fast Inserter
Posts: 181
Joined: Thu Mar 17, 2016 3:15 pm
Contact:

Re: Logistic Network Needs to be smarter

Post by Escadin »

theRustyKnife wrote:I think the bots are dumb for a good reason: performance. The way they are now, they're really efficient in terms of CPU time, so tens of thousands of them can be used without too many issues. If they were to be smarter, they would have to calculate many more things, thus taking a lot longer than the current system where simply the closest (?) bot is sent to do the task and flies straight to the target no matter what.

Indeed, I wouldn't mind them being smarter either, but I'm certainly willing to make the sacrifice for performance.

That's just my thought tho - I don't know how the game's code actually works, but I think this is a likely scenario.

Cheers TRK
That's what I asked. And also, why I ask if having less bots but smarter and with more cargo would be an acceptable alternative.

I have no idea how they programmed the bots either. I know, that I would have tried to copy the concept of Java's threadpooling and completionservice and then make the scheduler based on distance checks and longest-queue-first (for the task queue) with a priority spike for repairs.
"--? How are commands compounded in a compounded compound command commanding compound composts." -defines.lua
User avatar
theRustyKnife
Filter Inserter
Filter Inserter
Posts: 259
Joined: Thu Feb 26, 2015 9:26 pm
Contact:

Re: Logistic Network Needs to be smarter

Post by theRustyKnife »

Escadin wrote:having less bots but smarter and with more cargo would be an acceptable alternative.
That's a good point and it might indeed work quite well. The only other reason I can see then is the complexity of coding such AI. I'm pretty sure the devs have better things to work on, but that doesn't mean this shouldn't be at least considered.
Maybe Ideas and suggestions would be a better place for this?
quinor
Filter Inserter
Filter Inserter
Posts: 404
Joined: Thu Mar 07, 2013 3:07 pm
Contact:

Re: Logistic Network Needs to be smarter

Post by quinor »

Bots are supposed to be dumb so that they require some thinking to use and don't replace trains and belts completely. As long as you're using them properly (networks over small areas, convex networks etc), they behave just fine.
Escadin
Fast Inserter
Fast Inserter
Posts: 181
Joined: Thu Mar 17, 2016 3:15 pm
Contact:

Re: Logistic Network Needs to be smarter

Post by Escadin »

How could they ever replace trains with their speed or belts with their tech requirement?
"--? How are commands compounded in a compounded compound command commanding compound composts." -defines.lua
User avatar
theRustyKnife
Filter Inserter
Filter Inserter
Posts: 259
Joined: Thu Feb 26, 2015 9:26 pm
Contact:

Re: Logistic Network Needs to be smarter

Post by theRustyKnife »

Escadin wrote:How could they ever replace trains with their speed or belts with their tech requirement?
Well, I suppose there are people willing to tear down their factory to replace all belts with bots. Then again, those people probably already use bots for everything already...
Trains are so superior in terms of raw throughput, that I don't think bots will ever have a chance in replacing them. Unless they were buffed like crazy, but that's not what this is about.

Additionally, if you're really worried about balancing, you could just make them suck tons of power, to the point where that would be the limiting factor in how many bots you can have.

Cheers TRK
bobucles
Smart Inserter
Smart Inserter
Posts: 1708
Joined: Wed Jun 10, 2015 10:37 pm
Contact:

Re: Logistic Network Needs to be smarter

Post by bobucles »

You can solve most of these problems by just building smarter. If you need long distance travel use trains or belts. Don't trust bots with huge networks. They work best when they're servicing a smaller area.
User avatar
OdinYggd
Fast Inserter
Fast Inserter
Posts: 200
Joined: Wed May 25, 2016 12:55 pm
Contact:

Re: Logistic Network Needs to be smarter

Post by OdinYggd »

Escadin wrote:
Syrchalis wrote:First improvement I would put on the list is to make bots not cut corners. While shorter, it makes it impossible to connect outposts to your network, because the robots will not go along the tracks of the train that might have turrets and are secure, but they go the direct route which can get them killed easily. So basically they should try to stay within the construction area of the robotports when traveling.
What I would love to see in this regard is a guiding system that the player can install. I.e. a bunch of entities that give you control over some aspects of the AI. Essentially, they could act as the corner pieces of belts making bots behave like belts but you only have to place on entity every X tiles instead of the usual full coverage. That would also include equivialents of splitters that force bots to evenly distribute their cargo.
Or a 'restricted area' transmitter that you can place in order to prevent the bots from pathfinding across it.

If their path would take them into the restricted area, the bot aborts the job and the job is returned to the queue in the hopes that another bot in the system could eventually fill it.

This shouldn't result in a major penalty in computation, but that alone would have some snags in which if there are no bots with line of sight to the obstacle jobs waiting in that area will never be filled.


But you really really REALLY should not have large logistic networks. For optimum logistic performance, the logistics area should not exceed 4-6 roboport spans of coverage in any direction. Exceeding that makes the bots take a long time to arrive and encourages charging port congestion when half the bots in the system deliver to the same place and then must queue up at the nearest roboport to recharge.

Use trains to link separate 4x4 grid logistic networks, or build bridge sections where items are requested from one network and active provider into another. These bridges can be easily blueprinted for convenience.
In my mind, Steam is the eternal king of the railway.
Escadin
Fast Inserter
Fast Inserter
Posts: 181
Joined: Thu Mar 17, 2016 3:15 pm
Contact:

Re: Logistic Network Needs to be smarter

Post by Escadin »

Not all problem with bots stem from the size of their network.
The decision making when faced with multiple sources and/or multiple targets for a tasks (construction or transport, regardless) is as crude as it can be and will amost always cause a worst case in my experience. The only solution is to have some form of scheduling that includes but is not limited to distance calculations. No amount of segmenting your network can adress that.
Plus, they improved the charging behaviour but given enough bots they still will clog up the queue of a select few roborts out of the many you have clustered where they are charging. In my experience at least...

Side Q: Do bridge sections even work for generic transport? The only solution I can imagine only works for "specific" pre-defined items.

Additionally, the travel distance shouldn't matter if it's an outside/niche job where belts or trains are overkill. Like occasionally transporting solid fuel to train stations all across your base. Setting this up makes it inevetible to span a coherent network all across your base. Unless, of course, you design your fundamental base layout (trainstations, refinery, chem plants) with that in mind which defeats the purpose of setting up bots in the first place.

And let's not forget that personal logistic slots encourage the hell out of covering your entire production area with one big network so you can actually get the requested items delievered.


---

I also don't see what is wrong with making logistic network an alternative to belts (for production areas at least). Combining trains with logistic bots to smelt ore, ship it off in cargo wagons and then again use bots to feed the assemblers should be a viable end-game choice. The required technology is already almost space tier so it's not like this "trivializes" the game. Most of the game that the majority of players experience happens before space science. Especially since the science rework and with recipe difficulty settings.

It's also not that I am too lazy to use belts. I already do. I just would like a different approach every now and then.
"--? How are commands compounded in a compounded compound command commanding compound composts." -defines.lua
Escadin
Fast Inserter
Fast Inserter
Posts: 181
Joined: Thu Mar 17, 2016 3:15 pm
Contact:

Re: Logistic Network Needs to be smarter

Post by Escadin »

Thinking about your reply OdinYggd, I wonder if the logistic network would be better of if transport bots wouldn't leave their roboport coverage area. I mean imagine they cannot transfer from one port to another and instead you have to setup a storage chest at the next port.
When a transport task comes in the drones will then work like a bucket-brigade.

The obviosu downside: You need to make sure there are always the same amount of bots in every connected roboport or else you'll end up with bottlenecks. However, fixing this could be be automized either by the player or the game.
Player: All we need is the network to broadcast the amount of hooked up roboports together with all the other information.

Game: Bots DO transfer but only very rarely to equalize the network - not to complete tasks.
"--? How are commands compounded in a compounded compound command commanding compound composts." -defines.lua
User avatar
Ranakastrasz
Smart Inserter
Smart Inserter
Posts: 2173
Joined: Thu Jun 12, 2014 3:05 am
Contact:

Re: Logistic Network Needs to be smarter

Post by Ranakastrasz »

Escadin wrote:Thinking about your reply OdinYggd, I wonder if the logistic network would be better of if transport bots wouldn't leave their roboport coverage area. I mean imagine they cannot transfer from one port to another and instead you have to setup a storage chest at the next port.
When a transport task comes in the drones will then work like a bucket-brigade.

The obviosu downside: You need to make sure there are always the same amount of bots in every connected roboport or else you'll end up with bottlenecks. However, fixing this could be be automized either by the player or the game.
Player: All we need is the network to broadcast the amount of hooked up roboports together with all the other information.

Game: Bots DO transfer but only very rarely to equalize the network - not to complete tasks.
that would be great. Maybe set roboports each have a minimum robot count they can accept, and robots fly themselves to other roboports if they have too many.

Roboports would be mostly localized. if you want two roboports to share resources you couldn't, and would instead have to supply resources to both.
My Mods:
Modular Armor Revamp - V16
Large Chests - V16
Agent Orange - V16
Flare - V16
Easy Refineries - V16
Escadin
Fast Inserter
Fast Inserter
Posts: 181
Joined: Thu Mar 17, 2016 3:15 pm
Contact:

Re: Logistic Network Needs to be smarter

Post by Escadin »

Ranakastrasz wrote: Roboports would be mostly localized. if you want two roboports to share resources you couldn't, and would instead have to supply resources to both.
That's not quite what I meant. Roboports would still share resources but instead of having a single bot travel across the entire expanded area you'd have a chain of bots carrying the item from port to port. I.e. first bot carries it from first to second port, drops it off and returns home. Second bot picks it up and carries it from second to third port and so on until they reach their originial destination.
Also, the game could check whether the task is still relevant/active at every "checkpoint"(roboport).

That way, items could move through the entire network but individual bots would never leave their port - other than to equalize bot destribution.


An advantage of this would be that the network stays "balanced" at all times and regardless of tasks. Bots don't travel past their max distance and completion of tasks can be pipelined for optimization. Possibly, this could make finding the shortest distance / route easier since an already existing datastructure can express it in number of jumps like a graph. That would mean a more systematic and structured approach for the player as well.
I don't think the logistic system does any of that right now.
"--? How are commands compounded in a compounded compound command commanding compound composts." -defines.lua
User avatar
Killcreek2
Long Handed Inserter
Long Handed Inserter
Posts: 73
Joined: Sat Dec 10, 2016 8:39 am
Contact:

Re: Logistic Network Needs to be smarter

Post by Killcreek2 »

Escadin wrote:Roboports would still share resources but instead of having a single bot travel across the entire expanded area you'd have a chain of bots carrying the item from port to port. I.e. first bot carries it from first to second port, drops it off and returns home. Second bot picks it up and carries it from second to third port and so on until they reach their originial destination.
You have just described exactly how the bridge / relay system works ingame, between separate logistic networks.

I have a wall design that works exactly like this. It uses 2x constant combinators at the depot hub to set required stock levels of 25+ item types for the entire wall system, and between each logi network is a bridge of 1x decider combinator, 1x requester chest, & 1x active provider chest. That is really all you need to make the system work.

The player shoppe in one of my worlds has materials delivered from the main bus in a similar fashion: Items from the bus to shop input boxes via one network, with the shop using its own internal network. Throughput can be very good over short distances.
Converting it to 2-way delivery or multi-way is a bit more complex, but 100% possible in vanilla. You can set it up in a cell-like structure, with different inputs at different points, and the products will spread themselves between the logi network cells as needed.
"Functional simplicity, structural complexity." ~ Appleseed
Escadin
Fast Inserter
Fast Inserter
Posts: 181
Joined: Thu Mar 17, 2016 3:15 pm
Contact:

Re: Logistic Network Needs to be smarter

Post by Escadin »

Can you post a string please? And how does the circuit network know what to relais?
"--? How are commands compounded in a compounded compound command commanding compound composts." -defines.lua
User avatar
Killcreek2
Long Handed Inserter
Long Handed Inserter
Posts: 73
Joined: Sat Dec 10, 2016 8:39 am
Contact:

Re: Logistic Network Needs to be smarter

Post by Killcreek2 »

Escadin wrote:Can you post a string please? And how does the circuit network know what to relais?
Ok, simple description first:
The constant combinators at the depot hub output a global "stock control signal" along the entire wall via a long green wire.
Each roboport section has a supply chest, the contents of only that section are sent via red wire to the combinator at the bridge on the input side. This compares the local stock levels in that section [red] to the global stock control signal [green].
If there is less in stock than required, that item signal is sent to the requester chest and a bot will then deliver it from the nearby network.
That nearby network will then request the [now missing] item from the next network, and repeat, all the way back to the depot hub which will in turn take those items from the supply train.
I also have a set of combinators at each roboport, to limit the numbers of bots allowed in each port, and automagically replace any that get destroyed.
Sample Blueprint
Instructions & notes for the blueprint, please read before using:
Readme
"Functional simplicity, structural complexity." ~ Appleseed
Qon
Smart Inserter
Smart Inserter
Posts: 2164
Joined: Thu Mar 17, 2016 6:27 am
Contact:

Re: Logistic Network Needs to be smarter

Post by Qon »

So many players say "Bots make the game so easy, they remove the design and logistics challenge from the game".
Then they build an aweful zero effort bot base and blame the bot AI for their own mistakes when it doesn't work.
If the bots fail, don't blame the bots. Blame your design.
Escadin wrote:I mean the bots are dumb AF. There is a lot that could be done to improve their behaviour
I think they work fine. Their weakness is long distance high volume transport, but that's why you have trains. They are dumb enough to force you, the designer of your base, to think before you use them for high volume tasks though. I don't think that's a downside really.

The actual problem: They struggle with repairing railways when they have to fly over large hostile areas, which I don't know how to deal with really except building one enclosed megasquare containing your whole rail network and keeping natives out. That isn't a graceful and quick solution either. Maybe trains with roboport equipment will one day solve that problem.
OdinYggd wrote: But you really really REALLY should not have large logistic networks. For optimum logistic performance, the logistics area should not exceed 4-6 roboport spans of coverage in any direction. Exceeding that makes the bots take a long time to arrive and encourages charging port congestion when half the bots in the system deliver to the same place and then must queue up at the nearest roboport to recharge.
No, wrong. If your base is designed correctly with bot behaviour in mind, then any size is possible. Separating your logistics networks is just one way to solve the problem of rising complexity when you have more connected production areas.

For optimum logistic performance, you need to understand the workings, strengths and weaknesses of bots. No magical rules, just knowledge. If you are fine with non-optimal performance then many tiny networks is probably a good enough solution in many cases.
Escadin wrote:Not all problem with bots stem from the size of their network.
I would say that it's never the size of the network that causes the problems. The problems come from not taking everything within the network into account when building the large network. Separating the networks does not solve your problems because the networks are smaller. It solves your problems because when you can't build a single network properly, using bots less helps you because bots and big networks are hard to use and belts and trains are "easy". When you separate your networks you force yourself to use other simpler methods than bots for logistics.

It's not big sizes, it's that everything within a single logistics networks have the potential to affect everything else in the network and bots will take long paths if the short paths within cells can't be taken because you starved machines of input/blocked output/misbalanced the production cells.
Escadin wrote: The decision making when faced with multiple sources and/or multiple targets for a tasks (construction or transport, regardless) is as crude as it can be and will amost always cause a worst case in my experience. The only solution is to have some form of scheduling that includes but is not limited to distance calculations. No amount of segmenting your network can adress that.
Are you talking about scheduling as a solution in game that the player implements, or some update that you believe the developers need to add to the game for bot AI?
Escadin wrote: Plus, they improved the charging behaviour but given enough bots they still will clog up the queue of a select few roborts out of the many you have clustered where they are charging. In my experience at least...
If the bots aren't given enough roboports to charge in spiky high traffic areas then they will clog up. You probably don't have enough roboports in your big network. 4 charging ports per roboport means you need more than 1 every 50 tiles if you are going to use bots for bulk logistics.
My mods: Capsule Ammo | HandyHands - Automatic handcrafting | ChunkyChunks - Configurable Gridlines
Some other creations: Combinassembly Language GitHub w instructions and link to run it in your browser | 0~drain Laser
Bauer
Filter Inserter
Filter Inserter
Posts: 349
Joined: Fri May 05, 2017 12:48 pm
Contact:

Re: Logistic Network Needs to be smarter

Post by Bauer »

Qon wrote:
No, wrong. If your base is designed correctly with bot behaviour in mind, then any size is possible. Separating your logistics networks is just one way to solve the problem of rising complexity when you have more connected production areas.

For optimum logistic performance, you need to understand the workings, strengths and weaknesses of bots. No magical rules, just knowledge. If you are fine with non-optimal performance then many tiny networks is probably a good enough solution in many cases.
When delivering stuff to storage chests, bots can be really stupid. All bots fly to one box, they realize that the box is full only when arriving. Then they decide what box is the second best option to delivery to. So all bot continue flying to another (random) chest that could be very far away. That can mess up the complete system. What is your solution for this? How can you design in order to avoid this mess?

This is why I use only small networks, e.g. close to a train station for train loading/unload, storage, sorting and transfer to/from belts. Otherwise, if your train delivers 20 k iron plates and the bots decide that the chest 1000 tiles away is the one, just to realize that it's full only when they arrive to fly to the next one that will also be full when they arrive. It's really aweful to abserve this crazy ballet when there are 20 empty boxes next door to the station. Plus the fact that the iron plates most like will also be used close the station. So the flying caravan all comes back.

PS: I like the bot how they are. You need to think and they are not long distance. Because I also like trains... :-)
PPS: I'm just curious how Qon solves this problem intelligently.
Post Reply

Return to “General discussion”