-
Notifications
You must be signed in to change notification settings - Fork 85
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Unify traffic measurement methods #66
Comments
Both TrafficMeasurementManager and vanilla traffic density caculate is used for better pathfind, to aviod congestion route, so they only consider traffic amout, not traffic speed. For example, if a highway contains lots of traffic, but vehicle flow is not at a standstill, instead they are at a certain speed. We should consider this road is clear. But in current game, this road with be consider as high density. So in my mod, I use vehicle speed / Land speed limit as a factor to caculate trafficDensity. trafficDensity will only affect vanilla traffic density report tool, trafficBuffer will affect pathfinding, I think TMPE can also do some change to caculate trafficBuffer with (vehicle speed / Land speed limit) to choose better way for pathfinding |
While the vanilla traffic density measurements might seem overkill on their own, I suspect there will be some linkage with the *noise pollution system, so be sure to check that too. It would make sense that while scanning all the roads and vehicles that the game calculates both traffic density and noise pollution from same data? |
@aubergine10 Yes, it both happens within the same method. @pcfantasy Actually it seems that pathfinding is not at all affected by traffic situation. It would be nice if it was, but for that we definitely need better density measurement which your mod provides. By the way, I think that TMPE measurement calculates the density from the flow too, not only from the amount of cars. |
These seem to be prime areas where TMPE uses the road utilisation metrics:
See also: https://tmpe.viathinksoft.com/wiki/index.php?title=Vehicle_routing |
where is blow codes? in which method? int noisePollution = (int)(100 - (data.m_trafficDensity - 100) * (data.m_trafficDensity - 100) / 100); |
@aubergine10 I forgot about the dynamic lane changing. But the fact that traffic density is used directly for pathfinding is new to me, I don't know where in the code does that happen. @pcfantasy This is the same piece of code as in the vanilla game. It is in the RoadAI class. |
In vanilla game, this logic is blow: In Addtraffic logic, vanilla code will also add data.m_noiseDensity In TMPE, public void AddTraffic(ushort segmentId, byte laneIndex, ushort speed) So there must be some mismatch bettween TMPE and vanilla game , I think we need to correct that. |
It is possible. But I don't even know when the AddTraffic method is called. |
@Strdate I will try to fix this in TMPE and create a pull |
@pcfantasy As I looked through the TMPE measurement, it seems that it is almost the same as yours, but doesn't show the data on the map. I don't know if the units are the same and if it can be directly loaded into NetSegment.m_trafficDensity (you could know). In any case, we can let the vanilla measurement method run in background and calculate the noise according to it. |
You could find it via the dnSpy debugger: https://github.com/krzychu124/Cities-Skylines-Traffic-Manager-President-Edition/wiki/Attaching-Debugger-to-Cities-Skylines Once that's up and running, right-click a method definition and choose Analyze to find what uses it. |
Would it be possible to get both traffic views (congestion, and density)?
Maybe tabs could be added to the info view panel (like the Routes or Education info views have). One tab would show density, the other congestion. |
No I do not think TMPE measurement is the same as mine, you can see TMPE measurement and vannila game will add num into trafficBuffer for every vehicle. In my mod, only those slow speed vehicle will increase trafficBuffer. Then trafficBuffer will impact on trafficDensity and show on traffic congestion report. |
Currently, there are two methods of measuring traffic flow/density that run at the same time. The algorithm root is located at this method:
https://github.com/krzychu124/Cities-Skylines-Traffic-Manager-President-Edition/blob/139bcbaf47a057c00bc92ff6e56ce3b07012dc37/TLM/TLM/Custom/AI/CustomRoadAI.cs#L50
One of them is the vanilla traffic measurement, which is happening at the original method (which is called by the new implementation), second is a technique implemented by TrafficMeasurementManager.
Issues:
The custom traffic measurement manager should report its data back to vanilla traffic density report tool (NetSegment.m_trafficDensity)
When the custom implementation is running, the vanilla one should be turned off
Moreover, this all can be somehow unified with the Advanced Traffic Congestion Report by pcfantasy
It measures traffic per segment, not per lane, but it could be implemented. I don't know its advantages compared to TMPE implementation.
All custom measurements are performance hungry, they can be done once per second or even at longer intervals, not every simulation step as now.
I am looking at it myself a bit...
The text was updated successfully, but these errors were encountered: