Moderator: OpenTTD Developers
I know you can make criss-crosses with PBS, but that has the drawback that when a train ever decides to switch tracks, they block traffic in the other lane. (bonus problems if it breaks down when it does so)
I've started thinking of designs myself, and here's a three-wide design for a straight line. The branches are organized so that every fork allows you to go straight or move one lane left (where the left lane wraps around back to the right side). By removing tracks from the middle line, this can convert into a two-lane track that allows the two lanes to swap (so that a lane-changer doesn't block traffic)
If I've analyzed it properly, a single train breaking down cannot block traffic completely.
The design shown repeats every 8 tiles, and was intended for 3-tile trains. It could be reduced to 7 tiles, but in that case I didn't like the distance between the middle signal and the signal in the left lane should it decide to switch.
With breakdowns off, any discussion about some designs gains some sense because there isnt the stupid breaking factor anymore.
The design goal the 3-lane design I posted one train cannot block another train, no matter how silly it decides to be. In order for a train to be blocked, it requires two different trains to block the two available paths. This will, of course, never match the throughput of a three-lane no-breakdown track with similar signal spacing, but I'm hoping to average the equivalent of 1.5 to 2 lanes worth.
the point i was trying to make that the switchovers cause more harm during "normal" operation than they help during a breakdown
What is your alternative track/network design that works better? Getting answers to that question is why I started the thread. For the purposes of my question, turning off breakdowns is cheating, and sticking only to short disjoint routes is unsatisfying.
The point is that there's no possible track design that allows more throughput per tile than simply having a few parallel tracks and occasionally suffering breakdowns. Designs such as yours can offer an improvement in some breakdown cases (but not all, because the pathfinder is a bit stupid), but cause delays during normal operation because of trains cutting in front of each other (also because of the very short-termist pathfinding), and take up more space and money to build. Because your network should spend more time operating normally than with a breakdown, overall such designs tend to be less efficient .Hurkyl wrote: What is your alternative track/network design that works better? Getting answers to that question is why I started the thread. For the purposes of my question, turning off breakdowns is cheating, and sticking only to short disjoint routes is unsatisfying.
With the current (known to be flawed) breakdown system, there isn't really an option to maintain a reliable but complex network with breakdowns enabled, hence why many players don't consider disabling them to be cheating. If you really don't want to, the best you can do in terms of throughput is to have as many parallel tracks as possible (to increase spacing between trains and hence the number delayed by each breakdown).
Linux user (XMonad DWM/KDE, Arch), IRC obsessive and rail enthusiast. No longer building robots; now I ring church bells.
Author of an incredibly boring stickied post about NewGRFs.
The straight piece was really just to get started though: I think breakdown tolerant interchanges and station entrances/exits are more important, but much harder to design. (but that could just be due to my poor networking skills!)
I did have another thought on the long straight tracks: rather than trying to put crossovers throughout a straightaway, you could periodically place all-to-all switches (or some subset), then keep to parallel 1-lane tracks between switches. The effect of a breakdown in a straight track will then only directly affect traffic behind it up to the previous switch, and trains have fewer opportunities to do something stupid since the switches are infrequent.
(I wonder if something is already playing this role in "standard" networks, and that's why you guys aren't seeing the need to do something)
I always play with breakdowns on, it makes reliability and servicing trains timely so much more useful.
I do that, and it does work to an extent; the pathfinder nicely distributes trains between the parallel tracks (I normally have 2 or 3). However, I found that sometimes the switch causes massive track switching (every train switches track). When one train switches, the next one from the other track switches too, as the path-finder sees empty space there. The first track is now filled, so the next train from the first track switches also, and so on, until there is a large enough delay to the next train to stop the path-finder into thinking that switching tracks is useful.Hurkyl wrote:I did have another thought on the long straight tracks: rather than trying to put crossovers throughout a straightaway, you could periodically place all-to-all switches (or some subset), then keep to parallel 1-lane tracks between switches. The effect of a breakdown in a straight track will then only directly affect traffic behind it up to the previous switch, and trains have fewer opportunities to do something stupid since the switches are infrequent.
A few weeks ago, I had a small test by inserting a reverse two-way path signal to discourage the path-finder. That improved things, but did not eliminate the massive switching completely.
I want to do some more experiments, one direction is to use priority signalling to stop trains from switching tracks when there is a train at the parallel track.
Another thing I am wondering about is to improve the network so massive switching doesn't degrade throughput (much).
My plan, though, was to go back to the switchover design, but use the backwards signals to encourage all traffic to use the left lane. So a train should only switch over to the right lane if it is overtaking the train in front of it -- and it should only be able to squeeze back into the left lane when it finds a gap in traffic.
This could lead to a propagating chain of switches behind it, but that's okay: the traffic needed to slow down a bit to make room anyways.
Track layout: Often, I use 3 lane PBS (1 lane each way + 1 lane two-way) with X cross-over every 1 trainlength (see image). Trains tend to not use the middle (two-way) lane due to the reverse path signal. Thus, this is (mostly) used for overtaking or when a train on the one-way track is broken down. Sometimes, trains queue up to use the one-way track, even if the middle overtake lane is free. I have never tweaked pathfinder penalties.
If traffic is too high, I widen this into 2x2, with double one way tracks that have X cross-overs less often than one train length. I find that trains tend to not switch if they have a straight track ahead of them.
I understand that my layouts look basic to advanced players, but maybe newer players can use/try them.
Below an example of the kind of tracks I lay for a busy station:
For 2x2 I do exactly as you do in your first attachment, with more lines I make the X's bigger so that trains can switch to any track. This is bad, in case a train breaks down on the X, it blocks ALL tracks. Thus, I like the suggestion of the OP (thanks Hurkyl) to connect tracks in pairs rather than all at the same time. I haven't tried it yet.
By the way Alberth, is there a reason why your north-bound line in the first attachment does not have switches? Is it because of routing different destinations? In such a case, I always keep them together for load balancing until they really HAVE to split, except may be if I want to allow space for a queue before a pick-up station or something. As for your station in the second attachment, you can make the X bigger at the entrance, so that the train seen there doing 2x45 twice does not need to do that.
EDIT: How about this for three lane one-way? It is like the suggestion of Hurkyl, but without elevations? The normal path signals are optional, and are there to discourage unnecessary switching.
I often have more tracks on the way to the unloading stations; trains go slower when loaded, and get to its max speed takes longer, so you need more space/tracks for good flow. Perhaps that's also why there are no crosses in my first picture, the northern direction is the 'empty' direction iirc.
I have never tried 3 parallel tracks like you show; one possible disadvantage may be that you're effectively pushing trains together onto fewer tracks than available, which in itself may also cause more switching to happen.
It seems like a nice experiment to try though.
- (190.7 KiB) Not downloaded yet
I haven't tested it "heavy duty" but I've launched a basic test with a mock track and first impressions are good - it seems to work.
The outside tracks are for priority management. Hence @FLHerne's comment that it's not possible to have prioritized lane switches that would allow greater throughput than allocationg the extra tracks to traffic.
Thus, the room required to have prioritized two-lane switchers would allow 4 non-prioritized lanes instead.
a) either you build extra lanes for priority management, increasing average delivery speed at the expense of throughput
b) you allocate the extra room to non-prioritized lanes, reducing average delivery speed but increasing throughput
- (173 KiB) Not downloaded yet
It looks like a pretty good design but signal length is high, reducing throughput.
It seems to me that trains can’t switch if the jammed block is right ahead and I’m not sure how yapf responds to path signals more than one block ahead.
If you test it I’d like to hear you report on it.
Users browsing this forum: No registered users and 8 guests