[0.10.9] splitter priority when joining

Bugs that are actually features.
arl85
Fast Inserter
Fast Inserter
Posts: 182
Joined: Tue Jun 10, 2014 7:08 am
Contact:

[0.10.9] splitter priority when joining

Post by arl85 »

Probably a know problem, but still I prefer to report result of my (small) test.

Usually splitter prefers left input for joining, but in two specific configurations it prefers Right one.

Image
(letter next to exit transport belt is the side that have priority)
BurnHard
Filter Inserter
Filter Inserter
Posts: 519
Joined: Mon Oct 21, 2013 5:08 pm
Contact:

Re: [0.10.9] splitter priority when joining

Post by BurnHard »

I have also observed that the prefered input side of your examples sometimes change if one or the other tile directly before the splitters are curved or not. A lot of possible combinations with not really predictable behaviour.
Rseding91
Factorio Staff
Factorio Staff
Posts: 16227
Joined: Wed Jun 11, 2014 5:23 am
Contact:

Re: [0.10.9] splitter priority when joining

Post by Rseding91 »

I'm not sure I understand what you're saying is broken. Are you sure it's not because you're using splitters as joiners? (to me) splitters are meant to split income onto both output belts not join income onto one output belt (and that's why the results seem strange to you).
If you want to get ahold of me I'm almost always on Discord.
arl85
Fast Inserter
Fast Inserter
Posts: 182
Joined: Tue Jun 10, 2014 7:08 am
Contact:

Re: [0.10.9] splitter priority when joining

Post by arl85 »

Rseding91 wrote:I'm not sure I understand what you're saying is broken. Are you sure it's not because you're using splitters as joiners? (to me) splitters are meant to split income onto both output belts not join income onto one output belt (and that's why the results seem strange to you).
I found lot of suggestion about using splitters as joiners, and almost all of them said that, in that case, left input is preferred. I'm just reporting that this is not always true.

I'm not sure it's a bug, because, as you said, splitters are used as joiners, so maybe this is not their role
User avatar
ssilk
Global Moderator
Global Moderator
Posts: 12889
Joined: Tue Apr 16, 2013 10:35 pm
Contact:

Re: [0.10.9] splitter priority when joining

Post by ssilk »

I've been looking quite a while now, why in some situations the splitters (in that case the joiners) seem to prefer the other side. I never came to the idea to systematically test it. The pic above makes sense!

Many thanks for the work! :)

In my eyes this should work either
- only one side (the left) is prefered or
- the connected side (the side where the single belt continues) is prefered.

I think the last option is in some cases more useful (and eventually more intuitive?) cause it enables the player to switch priorities.
Cool suggestion: Eatable MOUSE-pointers.
Have you used the Advanced Search today?
Need help, question? FAQ - Wiki - Forum help
I still like small signatures...
User avatar
DaveMcW
Smart Inserter
Smart Inserter
Posts: 3749
Joined: Tue May 13, 2014 11:06 am
Contact:

Re: [0.10.9] splitter priority when joining

Post by DaveMcW »

The workaround is to use blue joiners, and only on belts going down or to the left.
blue-merger.jpg
blue-merger.jpg (261.78 KiB) Viewed 11486 times
User avatar
ssilk
Global Moderator
Global Moderator
Posts: 12889
Joined: Tue Apr 16, 2013 10:35 pm
Contact:

Re: [0.10.9] splitter priority when joining

Post by ssilk »

Indeed, I can think that it is useful that the blue splitters behave so, that they equally join. But it is very questionable. It's in my eyes really a quite useful behavior, that splitters do prefer one side and for that, every splitter should behave in the same way.
Cool suggestion: Eatable MOUSE-pointers.
Have you used the Advanced Search today?
Need help, question? FAQ - Wiki - Forum help
I still like small signatures...
User avatar
DaveMcW
Smart Inserter
Smart Inserter
Posts: 3749
Joined: Tue May 13, 2014 11:06 am
Contact:

Re: [0.10.9] splitter priority when joining

Post by DaveMcW »

Red joiners also work going to the left.
red-joiner.jpg
red-joiner.jpg (262.43 KiB) Viewed 11462 times
User avatar
ssilk
Global Moderator
Global Moderator
Posts: 12889
Joined: Tue Apr 16, 2013 10:35 pm
Contact:

Re: [0.10.9] splitter priority when joining

Post by ssilk »

Stupid suggestion: If I plug the output to the left side it prefers the left input. If I plug it to the right it tries to output equally from both inputs.
Cool suggestion: Eatable MOUSE-pointers.
Have you used the Advanced Search today?
Need help, question? FAQ - Wiki - Forum help
I still like small signatures...
kovarex
Factorio Staff
Factorio Staff
Posts: 8298
Joined: Wed Feb 06, 2013 12:00 am
Contact:

Re: [0.10.9] splitter priority when joining

Post by kovarex »

Well, currently the priority of joining is not defined explicitely. Sometimes the side that is joined to is always preferred because the side can move, so the items on that side are the first to be picked after free space is created for another item. But it can really depend on the way the items are put on the belt.

I'm moving it to not a bug for now.
User avatar
DaveMcW
Smart Inserter
Smart Inserter
Posts: 3749
Joined: Tue May 13, 2014 11:06 am
Contact:

Re: [0.10.9] splitter priority when joining

Post by DaveMcW »

It turns out exactly 50% of express splitters will join correctly. At least one tile of the splitter must be in the same 2x2 block as the output.

I have made red and yellow splitters join correctly, but the chance is much less than 50% and I'm still trying to figure out the exact formula.
joiner-horizontal.jpg
joiner-horizontal.jpg (138.54 KiB) Viewed 11744 times
joiner-vertical.jpg
joiner-vertical.jpg (135.77 KiB) Viewed 11744 times
User avatar
ssilk
Global Moderator
Global Moderator
Posts: 12889
Joined: Tue Apr 16, 2013 10:35 pm
Contact:

Re: [0.10.9] splitter priority when joining

Post by ssilk »

Wow. This is amazing. And it makes totally sense. One off and the splitter behaves differently. Quite useful, if you know it.

Why didn't I see that myself? :)

And how could I explain that in the wiki? :) :?

EDIT: This thread brought me to the point, that I now will test this completely through and make the results repeatable, so that it can be documented.
Cool suggestion: Eatable MOUSE-pointers.
Have you used the Advanced Search today?
Need help, question? FAQ - Wiki - Forum help
I still like small signatures...
User avatar
micomico
Long Handed Inserter
Long Handed Inserter
Posts: 94
Joined: Thu Jul 24, 2014 10:55 pm
Contact:

Re: [0.10.9] splitter priority when joining

Post by micomico »

ssilk wrote:Wow. This is amazing. And it makes totally sense. One off and the splitter behaves differently. Quite useful, if you know it.

Why didn't I see that myself? :)

And how could I explain that in the wiki? :) :?

EDIT: This thread brought me to the point, that I now will test this completely through and make the results repeatable, so that it can be documented.
Well, this looks more like a bug to me than ever.

So, players are supposed to know about imaginary 2x2 blocks, in which splitters will work as predicted? Predicted, because most people with common sense will expect the joiner to pickup both inputs equally, even if you say that should not be the case.

The way I see it, even if you say explicitly that splitters will not work as perfect joiners, my reaction would be: "Why not, you lazy bastards...", which you're not, quite the opposite.
kovarex
Factorio Staff
Factorio Staff
Posts: 8298
Joined: Wed Feb 06, 2013 12:00 am
Contact:

Re: [0.10.9] splitter priority when joining

Post by kovarex »

But there are fundamental problems with equal joining. How exactly will you define it?

Once you have available item to move to the belt on left belt, you would have to wait, if some other item on the right belt don't arrive, as it would be the time for the right belt to be activated.

But how long do you wait? And once you wait you limit the throughout of the splitter.
User avatar
micomico
Long Handed Inserter
Long Handed Inserter
Posts: 94
Joined: Thu Jul 24, 2014 10:55 pm
Contact:

Re: [0.10.9] splitter priority when joining

Post by micomico »

I understand that speaking/writing is so much easier than coding. I was just expressing what I would think, if I was watching this behaviour as a new player.

I would expect that, given a clear output belt and constant input from both belts, the output would be perfectly balanced. Like splitters do when splitting. Of course, this might be impossible/too complex for the real returns obtained, to actually code it.
Boogieman14
Filter Inserter
Filter Inserter
Posts: 778
Joined: Sun Sep 07, 2014 12:59 pm
Contact:

Re: [0.10.9] splitter priority when joining

Post by Boogieman14 »

kovarex wrote: But how long do you wait? And once you wait you limit the throughout of the splitter.
How about no waiting, but simply checking both inputs in turn? If an item isn't readily available, just forward an item from the other input.
I don't have OCD, I have CDO. It's the same, but with the letters in the correct order.
kovarex
Factorio Staff
Factorio Staff
Posts: 8298
Joined: Wed Feb 06, 2013 12:00 am
Contact:

Re: [0.10.9] splitter priority when joining

Post by kovarex »

Well, maybe something that works quite ok might be done without too big of an effort, the splitter does the update of the left side and then on the right side.

It could remember the few last items balance of left/right and prioritize the one that was used less when moving items. That way it would probably work, but I would have to play with the details, definitelly this is not solving of a bug, but adding a new logic/feature, so it will be not solved for 0.10.x
User avatar
ssilk
Global Moderator
Global Moderator
Posts: 12889
Joined: Tue Apr 16, 2013 10:35 pm
Contact:

Re: [0.10.9] splitter priority when joining

Post by ssilk »

I've made a test, to prove the different theories, one test looks like so:
SplitterTesting.jpg
SplitterTesting.jpg (364.85 KiB) Viewed 11720 times
These are 8 test-drives, I place coal and alien eggs (due to the good visibility) on a belt, compress the stuff, so that it should be really one on one and then put it into a splitter and join that. The top row joins to the right belt, the lower row to the left. The other difference is the placing on even or odd tiles. See the rail-segments I placed besides the splitter, to understand that.

So I've 4 of those "tests" (one for every direction) and two extra double tests. All in all 48 test-drives. Didn't had enough resources left to make more. :)
I tried that also with faster belts (not in the save), and the result is about the same, even more complex. :)

What I can see is:
- Well, there are tendencies. A splitter to the left or up tends to join from the right side, to right or down from the left side. This matches fantastic with the inserter preferences (https://forums.factorio.com/wiki/inde ... =Inserters - top orientation for horizontal belts, or the left for vertical belts).
- There is no real dependency to the even tiles (look at the rails I placed near the splitter). I would say forget that idea...

Rules?

Found no rules. When you load the Splitter Testing Savegame and watch these test-drives a while, the picture changes. All the time.I think it is as Kovarex says: The result depends on how the items come into the splitter. So the dependency is, how the items are laying on the belts before the come into the splitter and when will the splitter look for the next time and when will the item before leave the placing-zone of the splitter?

More ideas how to see more:
- Adding faster belt after splitter or before only.
- Perhaps something without compression?
- taking randomly some item away from one side (inserter) to change the "order how the items are coming in".
- Add different tests, that show, that these test-drives are correct (or complete bullshit)

Maybe this savegame helps to stabilize this complex behavior, or someone finds a rule or so?


EDIT: I saw that this screenshoot is a bit too old, cause there are not all coal chests filled. This doesn't matter, even with full chests the picture is about the same.
Cool suggestion: Eatable MOUSE-pointers.
Have you used the Advanced Search today?
Need help, question? FAQ - Wiki - Forum help
I still like small signatures...
User avatar
DaveMcW
Smart Inserter
Smart Inserter
Posts: 3749
Joined: Tue May 13, 2014 11:06 am
Contact:

Re: [0.10.9] splitter priority when joining

Post by DaveMcW »

It looks like south and east splitters don't work unless they are express and share a 2x2 square.

North and west splitters always work if they share a 2x2 square.
Post Reply

Return to “Not a bug”