[2.0.15] Unexpected Inserter/Belt interaction.
Posted: Fri Nov 08, 2024 11:32 am
Factorio mathematics seem to be broken and it is hurting my soul. It is also hurting my brain figuring out how to describe it.
From what I understand, the inserters have the following rules prioritize picking up from the near side of the feeding belt; only dropping on the far side of a receiving belt. As a result a horizontal inserter will push from right, near first, to far left only; or from left, near first, to far right only. The behavior is similar on the vertical alignment of the inserter. My engineering mine attempts to treat this behavior as being vectored. But the vectored treatment ends up breaking down when it comes to the placement of items on belts sharing the axis of the inserter. Where the orientation of the belt didn't matter before, all of a sudden it does matter. There are also some other unexpected behaviors.
I have attached three images. In the first, in my mind, I show a few situations labelled with red numbers. In the second there are display panels showing letters representing how the same blueprint was flipped. I will discuss the third later.
Image 1:
These behaviors may be intended, but they are counter to the normal mathematics. I would expect i x j = k, j x i = -k, etc. relationships to hold true. Otherwise a blueprint is more likely to break when rotated. A belt that normally had item M on the right side relative to the facing of the belt, could have it on the belt-left side if the blueprint is flipped vertically. I think you can fix this.
More seriously, I am a major fan of you guys and the work you do. I hope some of the detail and drama here make you laugh. Ironically, "fixing" this will probably break a few things that work because it is broken. I can think of a few ways you could trivially make a fix work only for newly designed blueprints and builds, but I don't think you want to maintain that patch forward.
The third image is a design that would work if the inserters didn't violate the laws of mathematics. I spent over an hour searching for this bug being reported. There are no reports I can find. I suspect most people who might have noticed this didn't think it might be a bug and redid their design. I already see a small change I could make to fix this. Others who encounter this have probably done so too. I am posting it because A. it is interesting. and B. it does cause other unexpected issues as I described. I imagine fixing the bug also justifies looking into optimizing the placement/removal of items on belts. I don't know how or why this behavior was programmed in. It feels like there is a weird override somewhere that it was decided the placement should be on the right side of the belt when the axis is like this. Though more particularly it seems to be when an item is in the center of a tile relative to the axis of the belt, it will be shifted to the right lane. The easiest fix would probably be to have an inserter drop the item being placed slightly off center from the tile based on direction of facing. Since it seems inserters prefer counter clockwise rotation, an inserter placing north would be slightly to the east, an inserter to the west would be slightly to the north, an inserter placing south should be placing slightly to the west, an inserter placing east should be placing slightly to the south. etc. Whether the hood of the underground belt should block things is up to you and how much chaos you want to cause. This also could necessitate slightly increasing the rotation speed of inserters. They seem to over time prefer picking up from the arriving direction of supplied products and this will override the counter clockwise rotation paradigm. You could alternatively totally give inserters a handedness where they rotate preferentially cw or ccw dropping on the first lane encountered and this gets flipped if the blueprint is mirrored.
From what I understand, the inserters have the following rules prioritize picking up from the near side of the feeding belt; only dropping on the far side of a receiving belt. As a result a horizontal inserter will push from right, near first, to far left only; or from left, near first, to far right only. The behavior is similar on the vertical alignment of the inserter. My engineering mine attempts to treat this behavior as being vectored. But the vectored treatment ends up breaking down when it comes to the placement of items on belts sharing the axis of the inserter. Where the orientation of the belt didn't matter before, all of a sudden it does matter. There are also some other unexpected behaviors.
I have attached three images. In the first, in my mind, I show a few situations labelled with red numbers. In the second there are display panels showing letters representing how the same blueprint was flipped. I will discuss the third later.
Image 1:
- Situation 1 is the normal dropping of chips on the far side of a belt running perpendicularly to the inserter.
- Situation 2 is an inserter being able to put data in what should be expected to be an illegal position for a deposit on the belt given the other behaviors.
- Situations 3 and 4 show that inserters with opposite facings place on the same side of a parallel belt, and the side is determined by the direction of the belt.
- O is the original micro blueprint for demonstration.
- H is the horizontal flip of O.
- V is the vertical flip of O.
- B has been flipped both horizontally and vertically.
These behaviors may be intended, but they are counter to the normal mathematics. I would expect i x j = k, j x i = -k, etc. relationships to hold true. Otherwise a blueprint is more likely to break when rotated. A belt that normally had item M on the right side relative to the facing of the belt, could have it on the belt-left side if the blueprint is flipped vertically. I think you can fix this.
More seriously, I am a major fan of you guys and the work you do. I hope some of the detail and drama here make you laugh. Ironically, "fixing" this will probably break a few things that work because it is broken. I can think of a few ways you could trivially make a fix work only for newly designed blueprints and builds, but I don't think you want to maintain that patch forward.
The third image is a design that would work if the inserters didn't violate the laws of mathematics. I spent over an hour searching for this bug being reported. There are no reports I can find. I suspect most people who might have noticed this didn't think it might be a bug and redid their design. I already see a small change I could make to fix this. Others who encounter this have probably done so too. I am posting it because A. it is interesting. and B. it does cause other unexpected issues as I described. I imagine fixing the bug also justifies looking into optimizing the placement/removal of items on belts. I don't know how or why this behavior was programmed in. It feels like there is a weird override somewhere that it was decided the placement should be on the right side of the belt when the axis is like this. Though more particularly it seems to be when an item is in the center of a tile relative to the axis of the belt, it will be shifted to the right lane. The easiest fix would probably be to have an inserter drop the item being placed slightly off center from the tile based on direction of facing. Since it seems inserters prefer counter clockwise rotation, an inserter placing north would be slightly to the east, an inserter to the west would be slightly to the north, an inserter placing south should be placing slightly to the west, an inserter placing east should be placing slightly to the south. etc. Whether the hood of the underground belt should block things is up to you and how much chaos you want to cause. This also could necessitate slightly increasing the rotation speed of inserters. They seem to over time prefer picking up from the arriving direction of supplied products and this will override the counter clockwise rotation paradigm. You could alternatively totally give inserters a handedness where they rotate preferentially cw or ccw dropping on the first lane encountered and this gets flipped if the blueprint is mirrored.