Theory
The dispatcher has to find one solution of a complex search problem. The search space is constrained by the track properties set by the route author, the instructions of the scenario author, and the trains already placed. There are different possible cases.
On the one hand, a problem can be over-constraint. This means that there is no solution to it which fulfils all constraints. E.g., all routes are blocked. This is more likely to happen the more constraints you set forth, as a route builder or as a scenario author.
On the other hand, a problem can also be under-constraint. This means that there are so many possibilities that the memory or processing time is not sufficient to explore them all. AI typically uses rules of thumb, called heuristics, to cut a heap of those considerations. This generally leads to solutions which are less then perfect, but they are generated in short time while the perfect solution would take very long to find.
Nothing is known about the heuristics of the RW dispatcher. But it has been observed that he does not work too hard to find out when a blocking train will move on. Instead, he simplifies the situation for himself by assuming that the train will stay there and finds complex ways to shunt around it. While this could be a good cop out in hard cases, it is not desired in many cases where the heuristics claiming that the block will stay simply fails.
An important questions in evaluating heuristics are metrics for solution quality. Nothing has been revealed and nothing can be set by the user, and few people are aware of the issue at all. What makes a solution good, or unacceptable? This requires complex knowledge certainly not able to model in RW currently. E.g., a passenger train will not reverse into a parallel track even if it wins him 5 minute, because shunting trains with passengers in them may be prohibited, or because waiting for the station staff to perform the manoeuvre causes of loss of 5 minutes.
This means that even though everyone would wish for a clever automatic genius, arriving there is a tough challenge.
An important factor RW AI is the train density. For moderate density, i.e., about 2 clear blocks between succeeding trains, many weird solutions do not get on the table at all. But people want to see dense operation, with waiting for opposite movements and then, finding a solution gets hard and harder.
Of course, there should be an ideal golden path in the middle between over and under-constraining. There are two things to consider in this quest.
- Optimising the trade-off between desired guidance and undesired limitation cause by each information bit attached to any piece of track.
- Perfect communication between those who make the rules of usage and those who need to follow them.
Practice
- Marking a track as passenger locks out freight trains.
- Likewise, marking track as freight locks out passenger trains.
- Of course, uni-directional track locks out traffic for the other direction.
Note that freight and passenger exclusively refers to the train type selected for the driver icon in scenario editor, and nothing else.
Unfortunately, these are all the hard facts that I really can establish.
Track type yard remains a miracle. While I had the impression that it is avoided, it is clearly not a stop block for any train type. In one case, a freight train preferred 15 mph yard track over 50 mph mainline, while the same train from the same location took the mainline to reach the same destination when classified as passenger train.
Also line speed versus route length is a soft factor. I saw AI crawl along a speed restriction zone when the mainline just beside was clear and unrestricted. But I also saw AI prefer the faster track. I guess that the AI does not consider acceleration and deceleration losses. A short limit of 10 mph does not impress it, but a long one by just a few mph less makes it reconsider the route.
Sometimes I feel the the number of switches to pass is a factor. I saw AI take the loop when the clear mainline had a few more switches to other sidings in it.
A note on the hard blocks mentioned above: A a short piece of such track is sufficient for the result. This means that there is no need for miles of it. Therefore, keep direction restrictions out of places where someone might want to shunt, which is easy for route track. At the same time, make the marks long enough to be clearly seen when flying along the route. And do document them.
AI speed
This is calculated by the following interesting formula:
Line speed * (100 + tolerance) / 100 * performance
Line speed is the speed set in the track rules or by marking the track and setting the speed for this stretch. The choice of primary or secondary speed limit is decided by the train type defined in the scenario editor.
Tolerance is pegged to 60%. It is not the MaxSpeedTolerance defined in the XML of the track rule, as I believed earlier. That figure only influences the sharpness of easements, but not the speed of I, as later tests showed.
Performance is the % figure defaulting to 75% which you set for each intermediate destination.
If you want to experiment, start a scenario without being bound to a train, press F3 and then click on an AI train at an interesting place. It will shut off the power, so you need to take a quick look at the F3 display to see the value from the speed will steadily decrease. You also see the current speed limit, which can be well below the actual speed.
Given the uncertainty described above, using exactly one track class everywhere sounds most advisable, if only to rule out another factor of uncertainty with regards to AI behaviour.
great observations again! thank you very much for your research and for sharing it with us. :)
ReplyDeleteryo
Andis, thanks for taking the time to post all this useful information. A question. Do you have any idea what determines the accelaration rate of AI?
ReplyDeleteStuart
Thanks, regarding the AI acceleration, I am sure that it is hard-coded in the game. There is no trace or it in the consist and scenario data, at least none that I found.
ReplyDeleteQuite funny that the article which received the most comments is the one that contained a major error. In my original tests, MaxSpeedTolerance seemed to influence AI speed. I only tested it with values around 60. Later, I found out that this is the design speed for the easement curve, and that AI will still run 60% fast if you set that value to 200.
ReplyDeleteLesson learnt: always include a few insane values in your test set to validate your theory, even if you believe to see a clear trend in your observations.
This comment has been removed by the author.
ReplyDelete